:root {
      --forest:     #20403a;
      --deep-teal:  #316259;
      --sage:       #7b8e7e;
      --light-sage: #96a699;
      --mid-sage:   #637365;
      --off-white:  #f7f5f2;
      --white:      #ffffff;
      --text:       #1c2b26;
      --muted:      #7a8c84;
      --border:     #e6e2dd;
    }
    *, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
    html { scroll-behavior:smooth; }
    body { font-family:'Plus Jakarta Sans',sans-serif; background:var(--white); color:var(--text); overflow-x:hidden; -webkit-font-smoothing:antialiased; }
    h1,h2,h3,h4 { font-family:'Poppins',sans-serif; }
    a { text-decoration:none; color:inherit; }
    img { max-width:100%; display:block; }

    .nav { position:relative; height:68px; display:flex; align-items:center; justify-content:flex-start; padding:0 52px; background:var(--white); border-bottom:1px solid var(--border); }
.nav-logo-name { font-family:'Poppins',sans-serif; font-size:18px; font-weight:900; letter-spacing:3px; text-transform:uppercase; color:var(--forest); }
    .nav-menu-btn { display:none; background:none; border:none; cursor:pointer; padding:4px; color:var(--forest); position:relative; z-index:201; }
    .nav-menu-btn svg { width:26px; height:26px; display:block; }
    .nav-links { display:flex; align-items:center; gap:2px; margin-left:auto; list-style:none; }
    .nav-links.show { display:flex; }
    .nav-links a { font-size:13px; font-weight:500; color:var(--muted); padding:8px 14px; border-radius:6px; transition:color .2s,background .2s; }
    .nav-links a:hover { color:var(--forest); background:rgba(32,64,58,.05); }
    .nav-cta { background:var(--forest); color:white !important; padding:9px 20px; border-radius:8px; font-size:13px; font-weight:600; transition:background .2s,transform .15s; }
    .nav-cta:hover { background:var(--deep-teal) !important; transform:translateY(-1px); }
    .nav-overlay { display:none; }

    .hero { position:relative; height:100vh; min-height:680px; display:flex; align-items:flex-end; overflow:hidden; }
    .hero-img { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1586023492125-27b2c045efd7?w=1800&q=90&fit=crop') center/cover no-repeat; }
    .hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(12,20,17,.88) 0%,rgba(12,20,17,.3) 55%,transparent 100%); }
    .hero-content { position:relative; z-index:1; padding:0 52px 80px; max-width:760px; }
    .hero-pill { display:inline-flex; align-items:center; gap:8px; background:rgba(255,255,255,.12); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.2); border-radius:100px; padding:5px 14px; font-size:11px; font-weight:600; color:rgba(255,255,255,.9); letter-spacing:1px; text-transform:uppercase; margin-bottom:22px; }
    .hero-pill-dot { width:5px; height:5px; border-radius:50%; background:var(--light-sage); animation:blink 2s infinite; }
    @keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
    .hero-title { font-size:clamp(46px,7vw,82px); font-weight:900; line-height:1.03; letter-spacing:-2.5px; color:white; margin-bottom:18px; }
    .hero-title em { color:var(--light-sage); font-style:italic; }
    .hero-sub { font-size:17px; font-weight:400; color:rgba(255,255,255,.7); line-height:1.75; max-width:460px; margin-bottom:36px; }
    .hero-btns { display:flex; gap:12px; flex-wrap:wrap; }
    .btn-white { background:white; color:var(--forest); padding:13px 28px; font-size:13px; font-weight:700; border-radius:8px; border:none; cursor:pointer; display:inline-flex; align-items:center; gap:8px; transition:transform .15s,box-shadow .2s; }
    .btn-white:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.2); }
    .btn-ghost { background:transparent; color:white; padding:13px 28px; font-size:13px; font-weight:500; border-radius:8px; border:1px solid rgba(255,255,255,.35); display:inline-flex; align-items:center; gap:8px; transition:background .2s,border-color .2s; }
    .btn-ghost:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.65); color:white; }
    .hero-scroll { position:absolute; bottom:40px; right:52px; z-index:1; display:flex; flex-direction:column; align-items:center; gap:6px; }
    .hero-scroll-text { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,.4); writing-mode:vertical-lr; }
    .hero-scroll-line { width:1px; height:44px; background:linear-gradient(to bottom,rgba(255,255,255,.4),transparent); animation:scrl 2s ease-in-out infinite; }
    @keyframes scrl { 0%,100%{opacity:1} 50%{opacity:.2} }

    .sec-header { text-align:center; margin-bottom:60px; }
    .eyebrow { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--sage); margin-bottom:14px; display:flex; align-items:center; gap:10px; }
    .eyebrow.center { justify-content:center; }
    .eyebrow.center::before, .eyebrow.center::after { content:''; width:28px; height:1.5px; background:var(--sage); flex-shrink:0; }
    .sec-title { font-size:clamp(26px,3.2vw,38px); font-weight:800; color:var(--forest); line-height:1.2; letter-spacing:-.5px; margin-bottom:14px; }
    .sec-sub { font-size:15px; color:var(--muted); line-height:1.85; max-width:520px; margin:0 auto; }

    .problem-wrap { padding:100px 52px; max-width:740px; margin:0 auto; text-align:center; }

    .services-section { background:var(--off-white); padding:100px 0; }
    .services-inner { max-width:1100px; margin:0 auto; padding:0 52px; }
    .svc-row { display:grid; grid-template-columns:1fr 1fr; gap:0; background:var(--border); border-radius:16px; overflow:hidden; margin-bottom:3px; }
    .svc-row:last-child { margin-bottom:0; }
    .svc-text { background:white; padding:56px 52px; display:flex; flex-direction:column; justify-content:center; transition:background .25s; }
    .svc-row:hover .svc-text { background:#fafaf8; }
    .svc-photo { overflow:hidden; min-height:380px; }
    .svc-photo img { width:100%; height:380px; object-fit:cover; transition:transform .6s; }
    .svc-row:hover .svc-photo img { transform:scale(1.04); }
    .svc-row.reverse .svc-text { order:2; }
    .svc-row.reverse .svc-photo { order:1; }
    .svc-icon-wrap { width:52px; height:52px; border-radius:14px; background:rgba(123,142,126,.1); display:flex; align-items:center; justify-content:center; margin-bottom:24px; transition:background .25s; }
    .svc-row:hover .svc-icon-wrap { background:rgba(49,98,89,.13); }
    .svc-icon-wrap svg { width:24px; height:24px; }
    .svc-num { font-size:10px; font-weight:700; letter-spacing:2px; color:var(--light-sage); text-transform:uppercase; margin-bottom:10px; }
    .svc-title { font-size:20px; font-weight:700; color:var(--forest); margin-bottom:12px; }
    .svc-desc { font-size:14px; color:var(--muted); line-height:1.85; }
    .svc-link { display:inline-flex; align-items:center; gap:6px; margin-top:20px; font-size:13px; font-weight:600; color:var(--deep-teal); transition:gap .2s; }
    .svc-row:hover .svc-link { gap:10px; }

    .why-section { position:relative; padding:120px 52px; overflow:hidden; }
    .why-bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1615873968403-89e068629265?w=1800&q=85&fit=crop') center/cover no-repeat; }
    .why-overlay { position:absolute; inset:0; background:rgba(8,16,12,.76); }
    .why-inner { position:relative; z-index:1; max-width:1100px; margin:0 auto; }
    .why-header { text-align:center; margin-bottom:64px; }
    .why-eyebrow { font-size:11px; font-weight:700; letter-spacing:3px; text-transform:uppercase; color:var(--light-sage); margin-bottom:14px; display:flex; align-items:center; justify-content:center; gap:10px; }
    .why-eyebrow::before, .why-eyebrow::after { content:''; width:28px; height:1.5px; background:var(--light-sage); }
    .why-title { font-size:clamp(28px,3.5vw,42px); font-weight:800; color:white; line-height:1.2; letter-spacing:-.5px; margin-bottom:16px; }
    .why-body-text { font-size:16px; color:rgba(255,255,255,.6); line-height:1.8; max-width:560px; margin:0 auto; }
    .why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; }
    .why-card { background:rgba(255,255,255,.11); border:1px solid rgba(255,255,255,.15); -webkit-backdrop-filter:blur(4px); backdrop-filter:blur(4px); border-radius:14px; padding:32px 28px; transition:background .25s, border-color .25s, transform .25s; }
    .why-card:hover { background:rgba(255,255,255,.18); border-color:rgba(150,166,153,.35); transform:translateY(-4px); }
    .why-card-icon { width:44px; height:44px; border-radius:12px; background:rgba(150,166,153,.18); display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
    .why-card-icon svg { width:20px; height:20px; }
    .why-card-title { font-size:14px; font-weight:700; color:white; margin-bottom:8px; }
    .why-card-desc { font-size:12px; color:rgba(255,255,255,.72); line-height:1.7; }

    .process-section { background:var(--off-white); padding:100px 52px; }
    .process-inner { max-width:1100px; margin:0 auto; }
    .process-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; background:var(--border); border-radius:16px; overflow:hidden; margin-top:60px; }
    .proc-card { background:white; padding:52px 40px; position:relative; overflow:hidden; transition:background .25s; }
    .proc-card:hover { background:#fafaf8; }
    .proc-num-bg { position:absolute; top:20px; right:28px; font-family:'Poppins',sans-serif; font-size:96px; font-weight:800; color:rgba(32,64,58,.04); line-height:1; user-select:none; }
    .proc-icon-wrap { width:48px; height:48px; border-radius:12px; background:rgba(49,98,89,.1); display:flex; align-items:center; justify-content:center; margin-bottom:28px; }
    .proc-icon-wrap svg { width:22px; height:22px; }
    .proc-label { font-size:10px; font-weight:700; letter-spacing:2.5px; text-transform:uppercase; color:var(--sage); margin-bottom:14px; }
    .proc-title { font-size:20px; font-weight:700; color:var(--forest); margin-bottom:14px; }
    .proc-desc { font-size:13px; color:var(--muted); line-height:1.85; }

    .cta-section { position:relative; overflow:hidden; min-height:440px; display:flex; align-items:center; justify-content:center; }
    .cta-bg { position:absolute; inset:0; background:url('https://images.unsplash.com/photo-1600585154340-be6161a56a0c?w=1600&q=85&fit=crop') center/cover no-repeat; }
    .cta-overlay { position:absolute; inset:0; background:rgba(12,22,18,.80); }
    .cta-inner { position:relative; z-index:1; text-align:center; padding:80px 40px; }
    .cta-title { font-size:clamp(34px,5vw,56px); font-weight:800; color:white; line-height:1.1; letter-spacing:-1.5px; margin-bottom:18px; }
    .cta-sub { font-size:16px; color:rgba(255,255,255,.65); max-width:440px; margin:0 auto 44px; line-height:1.75; }
    .cta-btns { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

    .footer { background:var(--forest); padding:72px 52px 44px; }
    .footer-top { display:grid; grid-template-columns:1.8fr 1fr 1fr 1fr; gap:56px; margin-bottom:52px; }
    .footer-brand-name { font-family:'Poppins',sans-serif; font-size:18px; font-weight:900; letter-spacing:3px; text-transform:uppercase; color:white; margin-bottom:16px; display:inline-block; }
    .footer-desc { font-size:13px; color:rgba(255,255,255,.45); line-height:1.8; max-width:260px; margin-bottom:24px; }
    .btn-subtle { background:rgba(150,166,153,.12); color:var(--light-sage); padding:10px 20px; font-size:13px; font-weight:600; border-radius:8px; border:1px solid rgba(150,166,153,.25); display:inline-flex; align-items:center; gap:8px; width:fit-content; transition:background .2s,border-color .2s; }
    .btn-subtle:hover { background:rgba(150,166,153,.2); border-color:rgba(150,166,153,.45); color:white; }
    .social-row { display:flex; gap:10px; margin-top:20px; }
    .social-icon { width:36px; height:36px; border-radius:8px; background:rgba(255,255,255,.07); border:1px solid rgba(255,255,255,.1); display:flex; align-items:center; justify-content:center; transition:background .2s,border-color .2s,transform .15s; }
    .social-icon:hover { background:rgba(255,255,255,.14); border-color:rgba(255,255,255,.25); transform:translateY(-2px); }
    .social-icon svg { width:16px; height:16px; }
    .footer-col-title { font-size:10px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:rgba(255,255,255,.35); margin-bottom:18px; }
    .footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px; }
    .footer-col ul li a { font-size:13px; color:rgba(255,255,255,.5); transition:color .2s; }
    .footer-col ul li a:hover { color:white; }
    .footer-bottom { display:flex; align-items:center; justify-content:flex-start; padding-top:28px; border-top:1px solid rgba(255,255,255,.08); flex-wrap:wrap; gap:12px; }
    .footer-copy { font-size:12px; color:rgba(255,255,255,.3); }
    .footer-legal { display:flex; gap:20px; }
    .footer-legal a { font-size:12px; color:rgba(255,255,255,.3); transition:color .2s; }
    .footer-legal a:hover { color:rgba(255,255,255,.65); }

    .reveal { opacity:0; transform:translateY(24px); transition:opacity .65s ease,transform .65s ease; }
    .reveal.in { opacity:1; transform:none; }
    .reveal-d1 { transition-delay:.12s; }
    .reveal-d2 { transition-delay:.24s; }
    .reveal-d3 { transition-delay:.36s; }

    @media(max-width:960px){
      .svc-row, .svc-row.reverse { grid-template-columns:1fr; }
      .svc-row.reverse .svc-text { order:0; }
      .svc-row.reverse .svc-photo { order:0; }
      .svc-photo, .svc-photo img { min-height:260px; height:260px; }
      .why-grid { grid-template-columns:repeat(4,1fr); gap:12px; }
    }
    @media(max-width:768px){
      .nav { padding:0 20px; }
      .nav-menu-btn { display:flex; align-items:center; justify-content:center; width:40px; height:40px; }
      /* Full-screen overlay menu from right */
      .nav-overlay {
        display:block; position:fixed; top:0; right:0; width:0; height:100vh; z-index:200;
        background:rgba(0,0,0,.4); opacity:0; visibility:hidden;
        transition:opacity .3s, visibility .3s;
      }
      .nav-overlay.open { opacity:1; visibility:visible; width:100%; }
      .nav-links {
        position:fixed; top:0; right:-280px; width:280px; height:100vh; z-index:202;
        flex-direction:column; padding:90px 32px 40px; gap:2px;
        background:var(--white);
        transition:right .35s cubic-bezier(.22,1,.36,1);
        box-shadow:-4px 0 30px rgba(0,0,0,.08);
        display:flex !important;
        list-style:none;
      }
      .nav-links.open { right:0; }
      .nav-close-item { display:flex; justify-content:flex-end; margin-bottom:8px; }
    .nav-close-btn { background:none; border:none; cursor:pointer; padding:4px; color:var(--forest); }
    .nav-close-btn svg { width:28px; height:28px; display:block; }
    .nav-links a {
        font-size:17px; font-weight:500; color:var(--text);
        padding:14px 16px; border-radius:10px;
        display:block; transition:background .2s;
      }
      .nav-links a:hover { background:rgba(32,64,58,.06); }
      .nav-links .nav-cta {
        background:var(--forest); color:white !important;
        text-align:center; margin-top:12px; border-radius:10px;
        font-weight:600;
      }
      .hero-content { padding:0 24px 64px; }
      .hero-scroll { display:none; }
      .problem-wrap { padding:72px 24px; }
      .services-inner { padding:0 20px; }
      .services-section, .process-section { padding-left:0; padding-right:0; }
      .why-section { padding:80px 24px; }
      .why-grid { grid-template-columns:1fr; gap:10px; }
      .why-card { padding:24px 20px; }
      .process-section { padding:72px 24px; }
      .process-grid { grid-template-columns:1fr; }
      .footer { padding:56px 24px 36px; }
      .footer-top { grid-template-columns:1fr; gap:32px; }
    }