  :root {
    --navy: #1B2A4A;
    --navy-2: #22335A;
    --navy-3: #2C406B;
    --orange: #E07B2A;
    --orange-2: #C66A20;
    --cream: #F5EFE4;
    --cream-2: #FAF6EE;
    --muted: #6B7B95;
    --grey: #4A5568;
    --white: #FFFFFF;
  }
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: 'Lato', sans-serif;
    color: var(--navy);
    background: var(--cream-2);
    -webkit-font-smoothing: antialiased;
    line-height: 1.6;
  }
  .container { max-width: 1180px; margin: 0 auto; padding: 0 15px; }
  .display { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 400; line-height: 1.05; }
  .display em { font-style: italic; color: var(--orange); }
  .eyebrow {
    font-size: 12px; font-weight: 700; letter-spacing: 0.16em;
    text-transform: uppercase; color: var(--orange);
  }


  /* ── NAV ──────────────────────────────────────── */
  nav {
    background: var(--navy); color: var(--white);
    padding: 18px 0; border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  nav .row { display: flex; align-items: center; justify-content: space-between; }
  nav .brand {
    font-weight: 900; letter-spacing: 0.08em; font-size: 14px;
  }
  nav .brand small { display: block; font-size: 9px; color: var(--orange); letter-spacing: 0.18em; margin-top: 2px; font-weight: 400; }
  nav .links { display: flex; gap: 28px; font-size: 13px; letter-spacing: 0.04em; }
  nav .links a { color: rgba(255,255,255,0.85); text-decoration: none; }
  nav .links a:hover { color: var(--orange); }
  nav .cta {
    background: var(--orange); color: var(--white);
    padding: 9px 18px; border-radius: 4px; font-size: 12px;
    font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
    text-decoration: none;
  }


  /* ── HERO ─────────────────────────────────────── */
  .hero {
    background:
      linear-gradient(135deg, rgba(27,42,74,0.92) 0%, rgba(27,42,74,0.78) 100%),
      url('https://images.unsplash.com/photo-1559339352-11d035aa65de?auto=format&fit=crop&w=1600&q=80') center/cover;
    color: var(--white);
    padding: 100px 0 80px;
    position: relative;
  }
  .hero .grid { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: 60px; align-items: center; }
  .hero h1 { font-size: 64px; margin-bottom: 24px; }
  .hero .lede {
    font-size: 19px; color: rgba(255,255,255,0.85);
    margin-bottom: 32px; line-height: 1.55; max-width: 540px;
  }
  .hero .stats {
    display: flex; gap: 32px; margin-top: 40px;
    padding-top: 32px; border-top: 1px solid rgba(255,255,255,0.15);
  }
  .hero .stat { display: flex; flex-direction: column; }
  .hero .stat .num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 36px; color: var(--orange); line-height: 1;
  }
  .hero .stat .lbl {
    font-size: 11px; color: rgba(255,255,255,0.7);
    letter-spacing: 0.12em; text-transform: uppercase; margin-top: 6px;
  }
  .hero-card {
    background: rgba(34,51,90,0.85);
    backdrop-filter: blur(8px);
    border: 1px solid rgba(224,123,42,0.25);
    border-radius: 12px;
    padding: 32px;
    box-shadow: 0 30px 80px rgba(0,0,0,0.4);
  }
  .hero-card .eyebrow { color: var(--orange); margin-bottom: 12px; }
  .hero-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 28px; font-weight: 500; color: var(--white);
    margin-bottom: 16px; line-height: 1.2;
  }
  .hero-card p { color: rgba(255,255,255,0.78); font-size: 14px; margin-bottom: 24px; }
  .hero-card .btn {
    display: block; background: var(--orange); color: var(--white);
    text-align: center; padding: 14px; border-radius: 6px;
    font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
    font-size: 13px; text-decoration: none;
    transition: transform 0.15s ease;
  }
  .hero-card .btn:hover { transform: translateY(-2px); }
  .hero-card .below {
    margin-top: 14px; text-align: center; font-size: 11px;
    color: rgba(255,255,255,0.55); letter-spacing: 0.06em;
  }


  /* ── SECTION SHELL ────────────────────────────── */
  section.std { padding: 100px 0; }
  
  section.std h2 { font-size: 48px; margin-bottom: 16px; }
  section.std .lede { font-size: 18px; color: var(--grey); max-width: 720px; line-height: 1.65; margin-bottom: 5px; }
  section.std .eyebrow { margin-bottom: 14px; display: block; }


  /* ── PROBLEM SECTION ──────────────────────────── */
  .problem { background: var(--white); }
  .problem .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; margin-top: 60px; }
  .problem .item {
    border-left: 3px solid var(--orange);
    padding: 8px 0 8px 24px;
  }
  .problem .item .num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 56px; color: var(--orange); line-height: 1; margin-bottom: 12px;
  }
  .problem .item h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 24px; font-weight: 500; color: var(--navy);
    margin-bottom: 10px; line-height: 1.2;
  }
  .problem .item p { font-size: 15px; color: var(--grey); }


  /* ── CALCULATOR EMBED ─────────────────────────── */
  .calc-section {
    background: linear-gradient(180deg, var(--cream) 0%, var(--cream-2) 100%);
    padding: 100px 0;
  }
  .calc-section .header { text-align: center; margin-bottom: 50px; }
  .calc-section h2 { font-size: 48px; margin-bottom: 16px; }
  .calc-section .lede { font-size: 18px; color: var(--grey); max-width: 660px; margin: 0 auto; }
  .calc-frame {
    max-width: 540px; margin: 0 auto;
    border-radius: 14px; overflow: hidden;
    box-shadow: 0 30px 80px rgba(27,42,74,0.18);
    background: var(--navy);
  }
  .calc-frame iframe { width: 100%; height: 950px; border: none; display: block; }
  .calc-mock {
    background: var(--navy); color: var(--white); padding: 50px 32px; text-align: center;
  }
  .calc-mock svg { margin-bottom: 20px; }
  .calc-mock .placeholder {
    font-family: 'Cormorant Garamond', serif; font-size: 22px;
    color: rgba(255,255,255,0.85); margin-bottom: 8px;
  }
  .calc-mock .small { font-size: 13px; color: rgba(255,255,255,0.5); }


  /* ── PRODUCT TILES ────────────────────────────── */
  .products { background: var(--navy); color: var(--white); }
  .products h2 { color: var(--white); }
  .products .lede { color: rgba(255,255,255,0.7); }
  .products .grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .product {
    background: var(--navy-2);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 10px;
    padding: 32px;
    transition: transform 0.2s ease, border-color 0.2s ease;
  }
  .product:hover { transform: translateY(-4px); border-color: rgba(224,123,42,0.5); }
  .product .icon {
    width: 48px; height: 48px; margin-bottom: 20px;
    background: rgba(224,123,42,0.15); border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
    font-size: 22px;
  }
  .product h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 26px; font-weight: 500; margin-bottom: 10px; line-height: 1.2;
  }
  .product p { font-size: 14px; color: rgba(255,255,255,0.7); margin-bottom: 16px; }
  .product .feat { font-size: 12px; color: var(--orange); letter-spacing: 0.06em; }


  /* ── TRUST / WHY CCP ──────────────────────────── */
  .why { background: var(--white); }
  .why .grid { display: grid; grid-template-columns: 1fr 1fr; gap: 80px; align-items: center; }
  .why .text h2 { font-size: 44px; margin-bottom: 24px; }
  .why .text p {
    font-size: 16px; color: var(--grey); line-height: 1.7; margin-bottom: 16px;
  }
  .why .specs { background: var(--cream); padding: 25px; border-radius: 12px; }
  .why .spec-row {
    display: flex; justify-content: space-between; align-items: center; gap: 15px;
    padding: 14px 0; border-bottom: 1px solid rgba(27,42,74,0.10);
  }
  .why .spec-row:last-child { border-bottom: none; }
  .why .spec-row .lbl { font-size: 14px; color: var(--grey); }
  .why .spec-row .val { font-size: 14px; font-weight: 700; color: var(--navy); }


  /* ── CASE STUDY / TESTIMONIAL ─────────────────── */
  .quote {
    background: linear-gradient(135deg, var(--orange) 0%, var(--orange-2) 100%);
    color: var(--white); padding: 100px 0;
  }
  .quote blockquote {
    font-family: 'Cormorant Garamond', serif;
    font-size: 38px; font-weight: 400; line-height: 1.3;
    max-width: 900px; margin: 0 auto 24px; text-align: center;
    font-style: italic;
  }
  .quote .attr { text-align: center; font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; opacity: 0.85; }


  /* ── FAQ ──────────────────────────────────────── */
  .faq { background: var(--cream-2); }
  .faq .grid { display: grid; grid-template-columns: 1fr 2fr; gap: 80px; align-items: start; }
  .faq h2 { font-size: 44px; margin-bottom: 16px; }
  .faq .lede { font-size: 16px; color: var(--grey); }
  .faq .item {
    border-bottom: 1px solid rgba(27,42,74,0.10); padding: 24px 0;
  }
  .faq .item:first-child { padding-top: 0; }
  .faq .item:last-child { border-bottom: none; }
  .faq .item h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 22px; font-weight: 500; color: var(--navy); margin-bottom: 10px;
  }
  .faq .item p { font-size: 15px; color: var(--grey); line-height: 1.65; }


  /* ── FINAL CTA ────────────────────────────────── */
  .final-cta {
    background: var(--navy); color: var(--white);
    padding: 100px 0; text-align: center;
  }
  .final-cta h2 { font-size: 56px; margin-bottom: 20px; color: var(--white); }
  .final-cta p { font-size: 18px; color: rgba(255,255,255,0.75); max-width: 640px; margin: 0 auto 40px; line-height: 1.6; }
  .final-cta .btns { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }
  .final-cta .btn-primary, .final-cta .btn-ghost {
    padding: 16px 32px; border-radius: 6px; text-decoration: none;
    font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; font-size: 13px;
  }
  .final-cta .btn-primary { background: var(--orange); color: var(--white); }
  .final-cta .btn-ghost { border: 1px solid rgba(255,255,255,0.4); color: var(--white); }


  /* ── FOOTER ───────────────────────────────────── */
  footer { background: var(--navy-3); color: rgba(255,255,255,0.6); padding: 40px 0; font-size: 13px; text-align: center; }
  footer .brand { color: var(--white); font-weight: 700; letter-spacing: 0.08em; margin-bottom: 8px; }


  /* ── RESPONSIVE ───────────────────────────────── */
  @media (max-width: 900px) {
    .hero { padding: 60px 0; }
    .hero h1 { font-size: 42px; }
    .hero .grid, .why .grid, .faq .grid { grid-template-columns: 1fr; gap: 40px; }
    .problem .grid, .products .grid { grid-template-columns: 1fr; gap: 24px; }
    section.std h2, .calc-section h2, .why .text h2, .faq h2, .final-cta h2 { font-size: 32px; }
    nav .links { display: none; }
    
    section.std { padding: 50px 0; }
    .calc-section { padding: 50px 0; }
    .quote { padding: 50px 0; }
    .final-cta { padding: 50px 0; }
    .faq .item p { margin: 0; }
    
    .quote blockquote { font-size: 24px;  }
  }
