/* ============================================================
   Mitas Law — "Sea & Sun" design system
   Premium, build-ready stylesheet for the 4k website.
   ============================================================ */

:root{
  /* palette */
  --mist:#F4F6F5; --paper:#FFFFFF; --warm:#FBFAF6; --sand:#ECE9E1;
  --sea:#0E4C52; --sea-deep:#0A363B; --sea-bright:#15666E;
  --sun:#E0A33D; --sun-soft:#F5E6C7;
  --ink:#1E2B29; --muted:#5C6B68; --line:#E1E3DD; --line-warm:#E4DFD3;

  /* type */
  --disp:'Bricolage Grotesque',sans-serif;
  --body:'Hanken Grotesk',sans-serif;

  /* spacing scale (8pt) */
  --s1:4px; --s2:8px; --s3:12px; --s4:16px; --s5:24px;
  --s6:32px; --s7:48px; --s8:64px; --s9:96px;

  /* radii */
  --r-card:16px; --r-btn:10px; --r-pill:20px;

  /* elevation — soft, sea-tinted */
  --sh-sm:0 4px 16px -10px rgba(14,76,82,.30);
  --sh-md:0 22px 40px -28px rgba(14,76,82,.45);
  --sh-lg:0 40px 80px -40px rgba(10,54,59,.42);

  --maxw:1080px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--body);
  background:var(--mist);
  color:var(--ink);
  line-height:1.65;
  font-size:17px;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}

h1,h2,h3,h4{font-family:var(--disp);line-height:1.1;font-weight:600;color:var(--sea-deep);letter-spacing:-0.01em}
a{color:var(--sea);text-decoration:none;transition:color .2s}
a:hover{color:var(--sea-bright)}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 36px}
.eyebrow{font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--sea-bright);font-weight:600}
.muted{color:var(--muted)}

/* ---------- horizon signature ---------- */
.horizon{display:flex;align-items:center;gap:0;margin:0;width:100%}
.horizon .ln{height:1px;background:var(--line-warm);flex:1}
.horizon .sun{width:9px;height:9px;border-radius:50%;background:var(--sun);margin:0 6px;flex:0 0 auto;box-shadow:0 0 0 5px rgba(224,163,61,.14)}

/* ============================================================
   Buttons
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--body);font-weight:600;font-size:15.5px;
  padding:14px 26px;border-radius:var(--r-btn);
  cursor:pointer;border:none;transition:.25s;white-space:nowrap;
  line-height:1;
}
.btn svg{width:17px;height:17px;stroke-width:2;fill:none}
.btn-pri{background:var(--sea);color:#fff}
.btn-pri:hover{background:var(--sea-bright);transform:translateY(-2px);box-shadow:var(--sh-md);color:#fff}
.btn-sec{background:transparent;color:var(--sea);border:1.5px solid var(--line-warm)}
.btn-sec:hover{border-color:var(--sea);background:var(--paper);color:var(--sea)}
.btn-sun{background:var(--sun);color:var(--sea-deep)}
.btn-sun:hover{background:#d4953097;filter:brightness(1.05);transform:translateY(-2px);box-shadow:0 18px 34px -22px rgba(224,163,61,.7);color:var(--sea-deep)}
.btn-ghost-light{background:rgba(255,255,255,.08);color:#fff;border:1.5px solid rgba(255,255,255,.22)}
.btn-ghost-light:hover{background:rgba(255,255,255,.16);color:#fff}

/* ============================================================
   Header / nav
   ============================================================ */
.site-head{
  position:sticky;top:0;z-index:60;
  background:rgba(244,246,245,.82);
  backdrop-filter:saturate(160%) blur(14px);
  -webkit-backdrop-filter:saturate(160%) blur(14px);
  border-bottom:1px solid transparent;
  transition:border-color .3s,background .3s;
}
.site-head.scrolled{border-bottom-color:var(--line);background:rgba(244,246,245,.92)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{display:flex;align-items:center;gap:11px}
.brand .mk{flex:0 0 auto}
.brand .wm{font-family:var(--disp);font-size:21px;font-weight:600;color:var(--sea-deep);letter-spacing:-.02em;line-height:1}
.brand .wm span{color:var(--muted);font-weight:500}
.nav-links{display:flex;align-items:center;gap:4px}
.nav-links a{
  font-size:14.5px;font-weight:500;color:var(--ink);
  padding:9px 14px;border-radius:var(--r-btn);transition:.2s;
}
.nav-links a:hover{background:var(--sand);color:var(--sea-deep)}
.nav-links a.active{color:var(--sea-deep)}
.nav-cta{display:flex;align-items:center;gap:10px}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--sea-deep)}
.nav-toggle svg{width:26px;height:26px;stroke:currentColor;stroke-width:1.8;fill:none}

/* ============================================================
   Sections
   ============================================================ */
section{position:relative}
.sec{padding:var(--s9) 0}
.sec-tight{padding:var(--s8) 0}
.band-dark{background:var(--sea-deep);color:#dfeae9}
.band-dark h1,.band-dark h2,.band-dark h3,.band-dark h4{color:#fff}
.band-warm{background:var(--warm)}
.band-paper{background:var(--paper)}

.sec-head{max-width:62ch;margin-bottom:var(--s7)}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-size:clamp(28px,3.8vw,42px);margin:12px 0 14px}
.sec-head .lead{font-size:19px;color:var(--muted);line-height:1.6}
.band-dark .sec-head .lead{color:rgba(223,234,233,.82)}

/* ============================================================
   Hero
   ============================================================ */
.hero{
  position:relative;overflow:hidden;
  padding:clamp(70px,11vw,128px) 0 clamp(64px,9vw,108px);
  background:
    radial-gradient(120% 90% at 78% -10%, rgba(224,163,61,.13), transparent 55%),
    linear-gradient(180deg,var(--mist) 0%, #eef2f0 100%);
}
.hero .coastline{
  position:absolute;right:-6%;bottom:-4%;width:min(760px,72vw);
  opacity:.5;pointer-events:none;z-index:0;
}
.hero .coastline svg{width:100%;height:auto;stroke:var(--sea-bright);fill:none;opacity:.45}
.hero .wrap{position:relative;z-index:2}
.hero-inner{max-width:46rem}
.hero .eyebrow{display:inline-flex;align-items:center;gap:9px}
.hero .eyebrow::before{content:"";width:22px;height:1px;background:var(--sun)}
.hero h1{
  font-size:clamp(40px,6vw,68px);font-weight:600;margin:20px 0 0;
  max-width:16ch;line-height:1.04;
}
.hero h1 .accent{position:relative;white-space:nowrap}
.hero h1 .accent::after{
  content:"";position:absolute;left:0;right:0;bottom:.06em;height:.14em;
  background:var(--sun);opacity:.85;border-radius:3px;z-index:-1;
}
.hero .sub{font-size:clamp(17px,2vw,20px);color:var(--muted);margin-top:24px;max-width:52ch;line-height:1.6}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:36px}
.hero-meta{
  display:flex;gap:30px;flex-wrap:wrap;margin-top:46px;padding-top:28px;
  border-top:1px solid var(--line-warm);max-width:46rem;
}
.hero-meta .m .v{font-family:var(--disp);font-size:24px;font-weight:600;color:var(--sea-deep)}
.hero-meta .m .l{font-size:13px;color:var(--muted);margin-top:2px}

/* ============================================================
   Trust strip
   ============================================================ */
.trust{background:var(--sea-deep);color:#fff;padding:26px 0}
.trust .row{display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:center}
.trust .item{display:flex;align-items:center;gap:11px;font-size:15px;color:rgba(255,255,255,.92);font-weight:500}
.trust .item svg{width:19px;height:19px;stroke:var(--sun);stroke-width:2;fill:none;flex:0 0 auto}
.trust .dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.25)}

/* ============================================================
   Service cards
   ============================================================ */
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.svc-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);
  padding:30px 28px;transition:.3s;display:flex;flex-direction:column;height:100%;
  position:relative;overflow:hidden;
}
.svc-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg,var(--sea),var(--sun));
  transform:scaleX(0);transform-origin:left;transition:transform .35s;
}
.svc-card:hover{transform:translateY(-6px);box-shadow:var(--sh-md);border-color:transparent}
.svc-card:hover::before{transform:scaleX(1)}
.svc-card .ic{
  width:50px;height:50px;border-radius:14px;background:var(--sun-soft);
  display:flex;align-items:center;justify-content:center;margin-bottom:20px;flex:0 0 auto;
}
.svc-card .ic svg{width:25px;height:25px;stroke:var(--sea);fill:none;stroke-width:1.7}
.svc-card h3{font-size:20px;font-weight:600;margin-bottom:9px}
.svc-card p{font-size:15px;color:var(--muted);margin:0 0 18px}
.svc-card .more{margin-top:auto;font-size:14.5px;font-weight:600;color:var(--sea);display:inline-flex;align-items:center;gap:7px}
.svc-card .more svg{width:15px;height:15px;stroke:currentColor;stroke-width:2.2;fill:none;transition:transform .25s}
.svc-card:hover .more svg{transform:translateX(4px)}

/* ============================================================
   Who we help — two paths
   ============================================================ */
.path{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);
  padding:34px 32px;transition:.3s;
}
.path:hover{box-shadow:var(--sh-md);transform:translateY(-4px)}
.path .tag{font-size:11.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--sun);font-weight:700}
.path h3{font-size:24px;margin:12px 0 12px}
.path p{color:var(--muted);font-size:15.5px;margin-bottom:18px}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{display:inline-block;background:var(--sand);color:var(--sea-deep);font-size:13px;font-weight:600;padding:7px 14px;border-radius:var(--r-pill)}

/* ============================================================
   How we work — numbered steps
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:22px;counter-reset:step}
.step{position:relative;padding-top:14px}
.step .n{
  font-family:var(--disp);font-size:15px;font-weight:700;color:var(--sun);
  width:42px;height:42px;border-radius:50%;border:1.5px solid rgba(224,163,61,.4);
  display:flex;align-items:center;justify-content:center;margin-bottom:18px;
}
.band-dark .step h4{color:#fff;font-size:18px;margin-bottom:8px}
.band-dark .step p{color:rgba(223,234,233,.72);font-size:15px}
.step-line{position:absolute;top:35px;left:42px;right:-22px;height:1px;background:rgba(255,255,255,.14)}
.step:last-child .step-line{display:none}

/* ---- scroll-scrubbed step flow (home "Four steps") ---- */
.flow{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:14px}
.flow-rail{position:absolute;top:21px;left:12.5%;right:12.5%;height:2px;background:rgba(255,255,255,.16);border-radius:2px;overflow:hidden;z-index:0}
.flow-rail-fill{position:absolute;left:0;top:0;bottom:0;width:0;background:linear-gradient(90deg,var(--sea-bright),var(--sun));border-radius:2px;transition:width .12s linear}
.flow-step{position:relative;z-index:1;text-align:center}
.flow-step .n{
  width:44px;height:44px;border-radius:50%;margin:0 auto 20px;display:flex;align-items:center;justify-content:center;
  font-family:var(--disp);font-weight:700;font-size:15px;color:rgba(255,255,255,.7);
  background:var(--sea-deep);border:2px solid rgba(255,255,255,.22);
  transition:background .4s,border-color .4s,color .4s,box-shadow .4s,transform .4s;
}
.flow-step.on .n{border-color:var(--sun);background:var(--sun);color:var(--sea-deep);box-shadow:0 0 0 6px rgba(224,163,61,.18);transform:scale(1.08)}
.flow-step h4{color:#fff;font-size:18px;margin-bottom:8px}
.flow-step p{color:rgba(223,234,233,.72);font-size:15px;max-width:24ch;margin:0 auto;line-height:1.55}

/* ============================================================
   Relocating feature block
   ============================================================ */
.feature{
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
}
.feature .copy h2{font-size:clamp(26px,3.4vw,38px);margin-bottom:16px}
.feature .copy p{color:var(--muted);font-size:17px;margin-bottom:14px;max-width:46ch}
.feature-list{margin:22px 0 28px;display:grid;gap:12px}
.feature-list .li{display:flex;gap:12px;align-items:flex-start;font-size:15.5px}
.feature-list .li svg{width:20px;height:20px;stroke:var(--sea);stroke-width:2;fill:none;flex:0 0 auto;margin-top:2px}
.feature-card{
  background:linear-gradient(155deg,var(--sea) 0%,var(--sea-deep) 100%);
  border-radius:22px;padding:38px 34px;color:#fff;position:relative;overflow:hidden;
  box-shadow:var(--sh-lg);
}
.feature-card::after{
  content:"";position:absolute;right:-150px;top:-160px;width:440px;height:440px;border-radius:50%;
  background:radial-gradient(circle at center,rgba(224,163,61,.40) 0%,rgba(224,163,61,.14) 40%,rgba(224,163,61,0) 70%);
  filter:blur(30px);pointer-events:none;
}
.feature-card .horizon{margin-bottom:24px;max-width:120px}
.feature-card .horizon .ln{background:rgba(255,255,255,.3)}
.feature-card h3{color:#fff;font-size:23px;margin-bottom:14px;position:relative}
.feature-card .qa{position:relative;z-index:2}
.feature-card .qa .q{font-weight:600;color:#fff;font-size:15.5px;margin-bottom:4px}
.feature-card .qa .a{color:rgba(255,255,255,.74);font-size:14.5px;margin-bottom:18px;line-height:1.55}

/* ============================================================
   About teaser
   ============================================================ */
.about{display:grid;grid-template-columns:.8fr 1.2fr;gap:48px;align-items:center}
.about .portrait{
  aspect-ratio:4/5;border-radius:20px;overflow:hidden;background:var(--sand);
  position:relative;box-shadow:var(--sh-md);
}
.about .portrait .ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:10px;color:var(--muted);font-size:13px;text-align:center;
  background:linear-gradient(160deg,#e9ece8,#dfe4df);
}
.about .portrait .ph svg{width:48px;height:48px;stroke:var(--sea-bright);opacity:.5;stroke-width:1.3;fill:none}
.about blockquote{font-family:var(--disp);font-size:clamp(22px,3vw,30px);font-weight:500;color:var(--sea-deep);line-height:1.3;letter-spacing:-.01em}
.about .sig{margin-top:22px;display:flex;align-items:center;gap:14px}
.about .sig .nm{font-family:var(--disp);font-weight:600;color:var(--sea-deep);font-size:17px}
.about .sig .ro{font-size:14px;color:var(--muted)}

/* ============================================================
   Meet Mitas — personal greeting
   ============================================================ */
.meet{display:grid;grid-template-columns:.82fr 1.18fr;gap:52px;align-items:center}
.meet .portrait{
  aspect-ratio:4/5;border-radius:20px;overflow:hidden;background:var(--sand);
  position:relative;box-shadow:var(--sh-md);
}
.meet .portrait .ph{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  flex-direction:column;gap:10px;color:var(--muted);font-size:13px;text-align:center;padding:20px;
  background:linear-gradient(160deg,#e9ece8,#dfe4df);
}
.meet .portrait .ph svg{width:46px;height:46px;stroke:var(--sea-bright);opacity:.5;stroke-width:1.3;fill:none}
.meet .portrait .badge{
  position:absolute;left:16px;bottom:16px;right:16px;background:rgba(255,255,255,.92);
  backdrop-filter:blur(6px);border-radius:12px;padding:11px 14px;display:flex;align-items:center;gap:10px;
  box-shadow:var(--sh-sm);
}
.meet .portrait .badge .av{width:34px;height:34px;border-radius:50%;background:var(--sea);color:#fff;font-family:var(--disp);font-weight:600;font-size:15px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.meet .portrait .badge .nm{font-family:var(--disp);font-weight:600;font-size:14.5px;color:var(--sea-deep);line-height:1.2}
.meet .portrait .badge .ro{font-size:12px;color:var(--muted)}
.meet .greet{font-family:var(--disp);font-size:clamp(22px,3vw,30px);font-weight:500;color:var(--sea-deep);line-height:1.3;letter-spacing:-.01em}
.meet .greet b{font-weight:600}
.meet p{color:var(--muted);font-size:16.5px;margin-top:16px;max-width:50ch}
.signature{font-family:'Caveat',cursive;font-size:40px;color:var(--sea-deep);line-height:.9;margin-top:22px}
.signature + .sig-role{font-size:13.5px;color:var(--muted);margin-top:2px}

/* ============================================================
   Testimonials
   ============================================================ */
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.tcard{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);
  padding:28px 26px;display:flex;flex-direction:column;transition:.3s;height:100%;
}
.tcard:hover{box-shadow:var(--sh-md);transform:translateY(-4px);border-color:transparent}
.tcard .mark{font-family:var(--disp);font-size:46px;line-height:.6;color:var(--sun);height:26px}
.tcard blockquote{font-size:16px;color:var(--ink);line-height:1.6;margin:6px 0 20px;flex:1}
.tcard .who{display:flex;align-items:center;gap:12px;margin-top:auto}
.tcard .who .av{width:42px;height:42px;border-radius:50%;background:var(--sun-soft);color:var(--sea-deep);font-family:var(--disp);font-weight:600;font-size:16px;display:flex;align-items:center;justify-content:center;flex:0 0 auto}
.tcard .who .nm{font-weight:700;color:var(--sea-deep);font-size:14.5px}
.tcard .who .ctx{font-size:13px;color:var(--muted)}

/* horizontal auto-scrolling review loop */
.quotes-marquee{
  position:relative;overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 7%,#000 93%,transparent);
}
.quotes-track{display:flex;align-items:stretch;gap:22px;width:max-content;animation:quotes-scroll 48s linear infinite}
.quotes-marquee:hover .quotes-track{animation-play-state:paused}
.quotes-track .tcard{flex:0 0 min(380px,82vw)}
@keyframes quotes-scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:760px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--line);background:transparent}
.faq-q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:var(--disp);font-size:19px;font-weight:600;color:var(--sea-deep);
}
.faq-q .ic{flex:0 0 auto;width:26px;height:26px;border-radius:50%;background:var(--sand);
  display:flex;align-items:center;justify-content:center;transition:.3s}
.faq-q .ic svg{width:14px;height:14px;stroke:var(--sea);stroke-width:2.4;fill:none;transition:.3s}
.faq-item.open .faq-q .ic{background:var(--sea)}
.faq-item.open .faq-q .ic svg{stroke:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a .inner{padding:0 0 24px;color:var(--muted);font-size:16px;max-width:64ch;line-height:1.65}

/* ============================================================
   Contact CTA
   ============================================================ */
.contact{
  background:
    radial-gradient(90% 120% at 85% 0%, rgba(224,163,61,.16), transparent 50%),
    var(--sea-deep);
  color:#fff;border-radius:28px;padding:clamp(40px,6vw,68px);position:relative;overflow:hidden;
}
.contact h2{color:#fff;font-size:clamp(28px,3.8vw,42px);max-width:18ch}
.contact p{color:rgba(255,255,255,.78);font-size:18px;margin-top:14px;max-width:46ch}
.contact-grid{display:grid;grid-template-columns:1fr .9fr;gap:48px;align-items:start;position:relative;z-index:2}
.contact-info{margin-top:30px;display:grid;gap:18px}
.contact-info .ci{display:flex;gap:14px;align-items:flex-start}
.contact-info .ci svg{width:21px;height:21px;stroke:var(--sun);stroke-width:1.9;fill:none;flex:0 0 auto;margin-top:2px}
.contact-info .ci .k{font-size:13px;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.08em}
.contact-info .ci .v{font-size:15.5px;color:#fff;font-weight:500}
.form{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:28px}
.field{display:block;margin-bottom:16px}
.field label{font-size:13px;font-weight:600;color:rgba(255,255,255,.85);letter-spacing:.01em;display:block;margin-bottom:7px}
.field input,.field textarea,.field select{
  width:100%;padding:13px 15px;border:1.5px solid rgba(255,255,255,.18);
  border-radius:var(--r-btn);font-family:var(--body);font-size:15px;
  background:rgba(255,255,255,.06);color:#fff;transition:.2s;
}
.field textarea{resize:vertical;min-height:96px}
.field input::placeholder,.field textarea::placeholder{color:rgba(255,255,255,.4)}
.field input:focus,.field textarea:focus,.field select:focus{
  outline:none;border-color:var(--sun);background:rgba(255,255,255,.1);
  box-shadow:0 0 0 3px rgba(224,163,61,.2);
}
.form .note{font-size:13px;color:rgba(255,255,255,.6);margin-top:6px}

/* ============================================================
   Footer
   ============================================================ */
.site-foot{background:#082b30;color:rgba(255,255,255,.66);padding:64px 0 32px}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;margin-bottom:44px}
.site-foot .brand .wm{color:#fff}
.site-foot .brand .wm span{color:rgba(255,255,255,.5)}
.site-foot .tagline{margin-top:16px;font-size:14.5px;max-width:30ch;line-height:1.6}
.foot-col h5{font-family:var(--disp);font-size:13px;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.5);margin-bottom:16px;font-weight:600}
.foot-col a{display:block;color:rgba(255,255,255,.72);font-size:14.5px;padding:5px 0}
.foot-col a:hover{color:var(--sun)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;color:rgba(255,255,255,.5)}

/* ============================================================
   Reveal on scroll
   ============================================================ */
/* progressive enhancement: only hide when JS is present (html.js) */
.js .reveal{
  opacity:0;transform:translateY(30px);
  transition:opacity .75s cubic-bezier(.2,.7,.2,1),transform .75s cubic-bezier(.2,.7,.2,1),filter .75s ease;
  will-change:transform,opacity;
}
.js .reveal.from-left{transform:translateX(-54px)}
.js .reveal.from-right{transform:translateX(54px)}
.js .reveal.zoom{transform:scale(.88)}
.js .reveal.blur{filter:blur(16px)}
.js .reveal.flip{transform:perspective(1200px) rotateX(22deg) translateY(48px);transform-origin:center top}
.js .reveal.in{opacity:1;transform:none;filter:none}

/* scroll parallax targets (driven by JS) */
[data-parallax]{will-change:transform}

/* ---- marquee trust ticker ---- */
.trust.marquee{padding:0;overflow:hidden}
.trust.marquee .marquee-track{
  display:flex;align-items:center;gap:0;width:max-content;
  padding:26px 0;animation:marquee 38s linear infinite;
}
.trust.marquee:hover .marquee-track{animation-play-state:paused}
.trust.marquee .item{padding:0 30px;white-space:nowrap}
.trust.marquee .dot{flex:0 0 auto}
@keyframes marquee{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}

/* ============================================================
   Floating WhatsApp button
   ============================================================ */
.wa-float{
  position:fixed;right:22px;bottom:22px;z-index:90;
  display:inline-flex;align-items:center;gap:12px;
  background:var(--paper);border:1px solid var(--line);
  border-radius:50px;padding:9px 20px 9px 9px;
  box-shadow:0 14px 30px -12px rgba(10,54,59,.4);
  text-decoration:none;transition:transform .25s, box-shadow .25s;
}
.wa-float:hover{transform:translateY(-3px);box-shadow:0 20px 38px -14px rgba(10,54,59,.5)}
.wa-float .wa-ic{
  width:46px;height:46px;border-radius:50%;background:#25D366;
  display:flex;align-items:center;justify-content:center;flex:0 0 auto;
  box-shadow:0 0 0 0 rgba(37,211,102,.5);animation:wa-pulse 2.6s ease-out infinite;
}
.wa-float .wa-ic svg{width:27px;height:27px;fill:#fff}
.wa-float .wa-tx{display:flex;flex-direction:column;line-height:1.25}
.wa-float .wa-tx .t{font-family:var(--disp);font-weight:600;font-size:14.5px;color:var(--sea-deep)}
.wa-float .wa-tx .s{font-size:12.5px;color:var(--muted)}
@keyframes wa-pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.45)}70%{box-shadow:0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

/* ============================================================
   Faded squares decoration (Sea & Sun)
   Reusable behind heroes — scattered translucent tiles.
   ============================================================ */
.deco-squares{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0}
.deco-squares .sq{
  position:absolute;border-radius:7px;background:var(--sand);opacity:.55;
  will-change:transform;
}
/* size + position + tone variety — clustered, irregular */
.deco-squares .sq:nth-child(1){width:150px;height:150px;left:9%;top:14%;background:var(--sun-soft);opacity:.5}
.deco-squares .sq:nth-child(2){width:96px;height:96px;left:24%;top:30%;background:var(--sand);opacity:.7}
.deco-squares .sq:nth-child(3){width:210px;height:210px;left:34%;top:6%;background:var(--sun-soft);opacity:.32}
.deco-squares .sq:nth-child(4){width:120px;height:120px;left:46%;top:24%;background:var(--sand);opacity:.5}
.deco-squares .sq:nth-child(5){width:80px;height:80px;left:2%;top:46%;background:var(--sun-soft);opacity:.55}
.deco-squares .sq:nth-child(6){width:110px;height:110px;left:14%;top:62%;background:var(--sand);opacity:.45}
.deco-squares .sq:nth-child(7){width:70px;height:70px;left:0%;top:78%;background:var(--sun-soft);opacity:.5}
.deco-squares .sq:nth-child(8){width:140px;height:140px;left:84%;top:8%;background:var(--sand);opacity:.42}
.deco-squares .sq:nth-child(9){width:90px;height:90px;left:91%;top:34%;background:var(--sun-soft);opacity:.4}
.deco-squares .sq:nth-child(10){width:170px;height:170px;left:72%;top:60%;background:rgba(14,76,82,.06);opacity:.9}
.deco-squares .sq:nth-child(11){width:64px;height:64px;left:60%;top:72%;background:var(--sand);opacity:.5}
.deco-squares .sq:nth-child(12){width:120px;height:120px;left:30%;top:80%;background:var(--sun-soft);opacity:.34}

/* ---- 3D floating books (enabled by JS: html not reduced-motion) ---- */
.deco-squares.is3d{perspective:1500px;perspective-origin:50% 42%;transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.book3d{
  transform-style:preserve-3d;background:transparent!important;border-radius:0!important;
  animation:bookSpin var(--dur,20s) linear infinite;animation-delay:var(--delay,0s);will-change:transform;
}
.deco-squares.is3d .sq:nth-child(2n){animation-direction:reverse}
.book3d .face{position:absolute;top:50%;left:50%;overflow:hidden}

/* covers — cream "law book": gold horizon + sea title bars + crisp sea edge */
.book3d .f-front,.book3d .f-back{
  width:var(--w);height:var(--h);border-radius:3px 7px 7px 3px;
  background:
    linear-gradient(var(--sea-deep),var(--sea-deep)) no-repeat 24% 58% / 42% 3px,
    linear-gradient(var(--sea-deep),var(--sea-deep)) no-repeat 24% 66% / 30% 3px,
    linear-gradient(var(--sun),var(--sun)) no-repeat 24% 40% / 38% 3px,
    linear-gradient(135deg,#FCFBF7 0%,#ECE9E1 100%);
  box-shadow:inset 0 0 0 1.5px rgba(14,76,82,.42), inset 0 0 18px rgba(10,54,59,.12);
}
.book3d .f-back{background:linear-gradient(135deg,#F4F1E9 0%,#E6E2D6 100%);box-shadow:inset 0 0 0 1.5px rgba(14,76,82,.30)}
.book3d .f-front{transform:translate(-50%,-50%) translateZ(calc(var(--t)/2))}
.book3d .f-back {transform:translate(-50%,-50%) rotateY(180deg) translateZ(calc(var(--t)/2))}
/* sun dot sitting on the gold horizon line */
.book3d .f-front::after{content:"";position:absolute;left:19%;top:calc(40% - 3px);width:9px;height:9px;border-radius:50%;background:var(--sun);box-shadow:0 0 0 2px rgba(252,251,247,.9)}

/* fore-edge & page tops — cream with fine page striations */
.book3d .f-right{
  width:var(--t);height:var(--h);
  background:repeating-linear-gradient(to right,#fbfaf6 0,#fbfaf6 1.5px,#e3ddcd 2.5px,#fbfaf6 3.5px);
  transform:translate(-50%,-50%) rotateY(90deg) translateZ(calc(var(--w)/2));
}
.book3d .f-top{
  width:var(--w);height:var(--t);
  background:repeating-linear-gradient(to bottom,#fdfcf8 0,#fdfcf8 1.5px,#e6e0d0 2.5px,#fdfcf8 3.5px);
  transform:translate(-50%,-50%) rotateX(90deg) translateZ(calc(var(--h)/2));
}
.book3d .f-bottom{
  width:var(--w);height:var(--t);
  background:repeating-linear-gradient(to bottom,#f1eee3 0,#f1eee3 1.5px,#dad3c1 2.5px,#f1eee3 3.5px);
  transform:translate(-50%,-50%) rotateX(-90deg) translateZ(calc(var(--h)/2));filter:brightness(.92);
}
/* spine — sea with gold ribbing */
.book3d .f-left{
  width:var(--t);height:var(--h);border-radius:2px;
  background:linear-gradient(to right,var(--sea-deep),var(--sea) 55%,var(--sea-deep));
  transform:translate(-50%,-50%) rotateY(-90deg) translateZ(calc(var(--w)/2));
}
.book3d .f-left::before{
  content:"";position:absolute;inset:16% 32%;
  background:repeating-linear-gradient(to bottom,transparent 0,transparent 7px,rgba(224,163,61,.55) 7px,rgba(224,163,61,.55) 8px);
}
@keyframes bookSpin{
  0%  {transform:rotateX(0deg)   rotateY(0deg)   translateY(0)}
  50% {transform:rotateX(180deg) rotateY(180deg) translateY(-22px)}
  100%{transform:rotateX(360deg) rotateY(360deg) translateY(0)}
}

/* ============================================================
   Header dropdown (Services)
   ============================================================ */
.has-drop{position:relative}
.drop-toggle{
  display:inline-flex;align-items:center;gap:6px;
  font-size:14.5px;font-weight:500;color:var(--ink);
  padding:9px 14px;border-radius:var(--r-btn);transition:.2s;background:none;border:none;cursor:pointer;font-family:var(--body);
}
.drop-toggle svg{width:14px;height:14px;stroke:currentColor;stroke-width:2;fill:none;transition:transform .25s}
.drop-toggle:hover{background:var(--sand);color:var(--sea-deep)}
.drop-menu{
  position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%) translateY(8px);
  background:var(--paper);border:1px solid var(--line);border-radius:14px;
  box-shadow:var(--sh-md);padding:8px;min-width:282px;
  opacity:0;visibility:hidden;transition:.22s;z-index:70;
}
.has-drop:hover .drop-menu,.has-drop:focus-within .drop-menu{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.has-drop:hover .drop-toggle svg{transform:rotate(180deg)}
.drop-menu a{display:flex;gap:12px;align-items:flex-start;padding:11px 13px;border-radius:10px;transition:.18s}
.drop-menu a:hover{background:var(--warm)}
.drop-menu a .di{width:34px;height:34px;border-radius:9px;background:var(--sun-soft);flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.drop-menu a .di svg{width:18px;height:18px;stroke:var(--sea);stroke-width:1.7;fill:none}
.drop-menu a .dt{font-weight:600;color:var(--sea-deep);font-size:14.5px;line-height:1.3}
.drop-menu a .dd{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.4}

/* ============================================================
   Page hero (inner pages)
   ============================================================ */
.page-hero{
  position:relative;overflow:hidden;
  padding:clamp(56px,8vw,96px) 0 clamp(44px,6vw,64px);
  background:
    radial-gradient(120% 110% at 82% -20%, rgba(224,163,61,.12), transparent 52%),
    linear-gradient(180deg,var(--mist) 0%, #eef2f0 100%);
}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--muted);margin-bottom:20px}
.page-hero .breadcrumb a{color:var(--muted)}
.page-hero .breadcrumb a:hover{color:var(--sea)}
.page-hero .breadcrumb svg{width:13px;height:13px;stroke:var(--line-warm);stroke-width:2;fill:none}
.page-hero h1{font-size:clamp(34px,5vw,56px);max-width:18ch;margin-top:6px;line-height:1.05}
.page-hero .lead{font-size:clamp(17px,2vw,20px);color:var(--muted);max-width:56ch;margin-top:18px;line-height:1.6}
.page-hero .ph-cta{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px}
.page-hero .icon-badge{width:54px;height:54px;border-radius:15px;background:var(--sun-soft);display:flex;align-items:center;justify-content:center;margin-bottom:6px}
.page-hero .icon-badge svg{width:27px;height:27px;stroke:var(--sea);stroke-width:1.7;fill:none}

/* ============================================================
   Prose / content
   ============================================================ */
.prose{max-width:68ch}
.prose h2{font-size:clamp(24px,3vw,32px);margin:40px 0 14px}
.prose h3{font-size:21px;margin:28px 0 10px;color:var(--sea-deep)}
.prose p{margin-bottom:14px;color:var(--ink);font-size:17px}
.prose ul{list-style:none;margin:8px 0 18px;padding:0}
.prose li{position:relative;padding-left:26px;margin-bottom:11px;color:var(--ink)}
.prose li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--sun)}
.prose strong{color:var(--sea-deep)}

.split{display:grid;grid-template-columns:1.4fr .9fr;gap:48px;align-items:start}
.aside-card{
  background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);
  padding:26px 24px;position:sticky;top:96px;box-shadow:var(--sh-sm);
}
.aside-card h4{font-size:17px;margin-bottom:14px}
.aside-card .row{display:flex;gap:11px;align-items:flex-start;font-size:14.5px;color:var(--muted);margin-bottom:12px}
.aside-card .row svg{width:18px;height:18px;stroke:var(--sea);stroke-width:1.9;fill:none;flex:0 0 auto;margin-top:2px}
.aside-card .row b{color:var(--sea-deep);display:block;font-weight:600}

/* checklist cards */
.check-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:18px 0}
.check{display:flex;gap:13px;align-items:flex-start;background:var(--warm);border:1px solid var(--line-warm);border-radius:12px;padding:16px 18px}
.check svg{width:21px;height:21px;stroke:var(--sea);stroke-width:2;fill:none;flex:0 0 auto;margin-top:1px}
.check .t{font-weight:600;color:var(--sea-deep);font-size:15px}
.check .d{font-size:13.5px;color:var(--muted);margin-top:3px}

/* ============================================================
   CTA band (reused on inner pages)
   ============================================================ */
.cta-band{
  background:radial-gradient(90% 130% at 88% 0%, rgba(224,163,61,.18), transparent 52%),var(--sea-deep);
  color:#fff;border-radius:28px;padding:clamp(40px,6vw,64px);text-align:center;position:relative;overflow:hidden;
}
.cta-band .horizon{max-width:120px;margin:0 auto 22px}
.cta-band .horizon .ln{background:rgba(255,255,255,.3)}
.cta-band h2{color:#fff;font-size:clamp(28px,3.6vw,40px);max-width:20ch;margin:0 auto}
.cta-band p{color:rgba(255,255,255,.78);font-size:18px;margin:14px auto 0;max-width:48ch}
.cta-band .btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:32px}

/* ============================================================
   Insights / blog cards
   ============================================================ */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.post{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;transition:.3s;height:100%}
.post:hover{transform:translateY(-5px);box-shadow:var(--sh-md);border-color:transparent}
.post .thumb{aspect-ratio:16/10;background:linear-gradient(150deg,var(--sea) 0%,var(--sea-deep) 100%);position:relative;overflow:hidden}
.post .thumb::after{content:"";position:absolute;right:-30px;top:-30px;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 30% 30%,rgba(224,163,61,.5),transparent 64%)}
.post .thumb .cat{position:absolute;left:16px;bottom:14px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:#fff;font-weight:600;z-index:2}
.post .pbody{padding:22px;display:flex;flex-direction:column;flex:1}
.post .pbody h3{font-size:18px;line-height:1.25;margin-bottom:8px}
.post .pbody p{font-size:14px;color:var(--muted);margin-bottom:16px}
.post .pmeta{margin-top:auto;font-size:12.5px;color:var(--muted);display:flex;gap:10px;align-items:center}

/* ============================================================
   Contact page
   ============================================================ */
.map-embed{width:100%;aspect-ratio:16/10;border:0;border-radius:var(--r-card);background:var(--sand);filter:grayscale(.2) contrast(.95)}
.hours-table{width:100%;border-collapse:collapse;font-size:15px}
.hours-table td{padding:11px 0;border-bottom:1px solid var(--line)}
.hours-table td:last-child{text-align:right;color:var(--sea-deep);font-weight:600}

/* timeline (how we work) */
.timeline{max-width:760px;margin:0 auto;position:relative}
.timeline::before{content:"";position:absolute;left:23px;top:10px;bottom:10px;width:2px;background:var(--line-warm)}
.tl-item{position:relative;padding:0 0 38px 70px}
.tl-item .num{position:absolute;left:0;top:0;width:48px;height:48px;border-radius:50%;background:var(--paper);border:2px solid var(--sun);color:var(--sea-deep);font-family:var(--disp);font-weight:700;font-size:18px;display:flex;align-items:center;justify-content:center;z-index:2}
.tl-item h3{font-size:21px;margin-bottom:8px}
.tl-item p{color:var(--muted);max-width:52ch}

/* ============================================================
   How-we-work — scrollytelling journey
   ============================================================ */
.read-progress{
  position:fixed;left:0;top:0;height:3px;width:0;z-index:100;
  background:linear-gradient(90deg,var(--sea),var(--sun));
  box-shadow:0 0 12px rgba(224,163,61,.5);will-change:width;
}
.journey-sec{padding-top:var(--s7)}
.journey{display:grid;grid-template-columns:minmax(260px,.78fr) 1.22fr;gap:56px;align-items:start;position:relative}

/* sticky aside */
.journey-aside{position:sticky;top:0;height:100vh;display:flex;align-items:center}
.j-panel{width:100%}
.j-panel .eyebrow{display:block;margin-bottom:10px}
.j-num{height:1.04em;overflow:hidden;font-family:var(--disp);font-weight:700;font-size:clamp(96px,11vw,148px);line-height:1.04;color:var(--sea-deep);letter-spacing:-.04em}
.j-reel{display:flex;flex-direction:column;transition:transform .6s cubic-bezier(.7,0,.18,1)}
.j-reel span{height:1.04em;display:block}
.j-active-title{font-size:clamp(21px,2.3vw,28px);margin-top:10px;min-height:2.3em;color:var(--sea-deep);transition:opacity .35s}
.j-nav{margin-top:26px;position:relative;padding-left:24px}
.j-nav::before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:2px;background:var(--line-warm);border-radius:2px}
.j-nav-fill{position:absolute;left:5px;top:8px;width:2px;height:0;background:linear-gradient(var(--sea),var(--sun));border-radius:2px;transition:height .15s linear}
.j-nav-item{position:relative;display:flex;align-items:center;padding:10px 0;cursor:pointer;color:var(--muted);font-size:14.5px;font-weight:500;transition:.25s;line-height:1.3}
.j-nav-item .d{position:absolute;left:-24px;top:50%;transform:translateY(-50%);width:12px;height:12px;border-radius:50%;background:var(--paper);border:2px solid var(--line-warm);transition:.3s}
.j-nav-item:hover{color:var(--sea-deep)}
.j-nav-item.done{color:var(--sea-deep)}
.j-nav-item.done .d{border-color:var(--sea);background:var(--sea)}
.j-nav-item.active{color:var(--sea-deep);font-weight:700}
.j-nav-item.active .d{border-color:var(--sun);background:var(--sun);box-shadow:0 0 0 4px rgba(224,163,61,.2)}

/* steps */
.journey-steps{display:flex;flex-direction:column}
.j-step{min-height:84vh;display:flex;align-items:center}
.j-card{
  position:relative;background:var(--paper);border:1px solid var(--line);border-radius:20px;
  padding:42px 40px;width:100%;box-shadow:var(--sh-sm);overflow:hidden;
  opacity:.35;transform:translateY(40px) scale(.985);
  transition:opacity .65s cubic-bezier(.2,.7,.2,1),transform .65s cubic-bezier(.2,.7,.2,1),box-shadow .45s,border-color .45s;
}
.j-card.in{opacity:1;transform:none}
.j-card.active{box-shadow:var(--sh-lg);border-color:transparent}
.j-card.active::before{content:"";position:absolute;left:0;top:30px;bottom:30px;width:4px;border-radius:0 4px 4px 0;background:linear-gradient(var(--sea),var(--sun))}
.j-watermark{position:absolute;right:24px;top:8px;font-family:var(--disp);font-weight:700;font-size:130px;line-height:1;color:var(--sand);opacity:.55;pointer-events:none;z-index:0}
.j-card > *{position:relative;z-index:1}
.j-icon{width:62px;height:62px;border-radius:16px;background:var(--sun-soft);display:flex;align-items:center;justify-content:center;margin-bottom:22px;transition:transform .5s}
.j-card.active .j-icon{transform:translateY(-2px) scale(1.04)}
.j-icon svg{width:31px;height:31px;stroke:var(--sea);stroke-width:1.7;fill:none}
.j-kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--sun);font-weight:700}
.j-card h3{font-size:clamp(22px,2.5vw,30px);margin:8px 0 14px}
.j-card .lead{font-size:17px;color:var(--muted);margin-bottom:20px;max-width:48ch;line-height:1.6}
.j-detail{list-style:none;display:grid;gap:11px;padding:0;margin:0}
.j-detail li{position:relative;padding-left:28px;color:var(--ink);font-size:15px;line-height:1.5}
.j-detail li svg{position:absolute;left:0;top:3px;width:18px;height:18px;stroke:var(--sea);stroke-width:2.2;fill:none}

@media(max-width:900px){
  .journey{grid-template-columns:1fr;gap:0}
  .journey-aside{display:none}
  .j-step{min-height:auto;padding:12px 0}
  .j-card{padding:30px 24px}
  .j-watermark{font-size:90px;right:14px}
}
@media(prefers-reduced-motion:reduce){
  .j-card{opacity:1!important;transform:none!important;transition:none!important}
  .j-reel{transition:none!important}
  .read-progress{display:none}
}

/* ============================================================
   Promise cards (dark band — "What you can count on")
   ============================================================ */
.promises{position:relative;overflow:hidden}
.promises::before{
  content:"";position:absolute;left:50%;top:-10%;width:680px;height:420px;transform:translateX(-50%);
  background:radial-gradient(circle at 50% 40%,rgba(224,163,61,.16),transparent 62%);
  pointer-events:none;
}
.promises .wrap{position:relative;z-index:1}
.promise-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.promise{
  position:relative;overflow:hidden;border-radius:20px;padding:34px 30px;
  background:linear-gradient(160deg,rgba(255,255,255,.07),rgba(255,255,255,.02));
  border:1px solid rgba(255,255,255,.12);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),border-color .4s,box-shadow .4s;
}
.promise::after{
  content:"";position:absolute;right:-40px;top:-40px;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,rgba(224,163,61,.5),transparent 65%);
  opacity:0;transition:opacity .45s;pointer-events:none;
}
.promise:hover{transform:translateY(-7px);border-color:rgba(224,163,61,.45);box-shadow:0 34px 60px -34px rgba(0,0,0,.7)}
.promise:hover::after{opacity:.5}
.promise .ptop{position:absolute;left:0;top:0;height:3px;width:100%;background:linear-gradient(90deg,var(--sea-bright),var(--sun));transform:scaleX(0);transform-origin:left;transition:transform .45s}
.promise:hover .ptop{transform:scaleX(1)}
.promise .pnum{position:absolute;right:20px;top:4px;font-family:var(--disp);font-weight:700;font-size:92px;line-height:1;color:rgba(255,255,255,.05);pointer-events:none}
.promise .pic{
  position:relative;z-index:1;width:60px;height:60px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:rgba(224,163,61,.14);border:1px solid rgba(224,163,61,.32);margin-bottom:22px;transition:box-shadow .45s,transform .45s;
}
.promise:hover .pic{box-shadow:0 0 26px -2px rgba(224,163,61,.55);transform:translateY(-2px)}
.promise .pic svg{width:27px;height:27px;stroke:var(--sun);stroke-width:1.8;fill:none}
.promise h4{position:relative;z-index:1;color:#fff;font-size:20px;margin-bottom:10px;font-family:var(--disp);font-weight:600}
.promise p{position:relative;z-index:1;color:rgba(223,234,233,.74);font-size:14.5px;margin:0;line-height:1.6}

/* ============================================================
   "Who I help" — auto-sliding image carousel with text overlay
   ============================================================ */
.who-section{position:relative}
.whoslider{position:relative;overflow:hidden;background:var(--sea-deep)}
.whoslider-eyebrow{
  position:absolute;z-index:3;top:clamp(26px,4vw,46px);
  left:max(clamp(36px,5vw,68px),calc((100% - 1120px)/2));
  color:var(--sun);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:700;
  text-shadow:0 1px 8px rgba(0,0,0,.5);
}
.whoslides{position:relative;min-height:clamp(440px,58vh,600px)}
.whoslide{position:absolute;inset:0;display:flex;align-items:center;visibility:hidden;transition:transform .8s cubic-bezier(.7,0,.18,1);will-change:transform}
.whoslide.is-active,.whoslide.is-prev{visibility:visible}
.whoslide.is-active{z-index:1}
.whoslide-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.whoslide-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(8,43,48,.94) 0%,rgba(8,43,48,.66) 44%,rgba(8,43,48,.18) 100%)}
.whoslide.is-active .whoslide-bg{animation:kenburns 9s ease-out both}
@keyframes kenburns{from{transform:scale(1.09)}to{transform:scale(1)}}
.whoslide-content{position:relative;z-index:1;max-width:40rem;color:#fff;padding:clamp(36px,5vw,60px);margin-left:max(0px,calc((100% - 1180px)/2))}
.whoslide-content > *{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s cubic-bezier(.2,.7,.2,1)}
.whoslide.is-active .whoslide-content > *{opacity:1;transform:none}
.whoslide.is-active .whoslide-content > *:nth-child(2){transition-delay:.1s}
.whoslide.is-active .whoslide-content > *:nth-child(3){transition-delay:.18s}
.whoslide.is-active .whoslide-content > *:nth-child(4){transition-delay:.26s}
.whoslide.is-active .whoslide-content > *:nth-child(5){transition-delay:.34s}
.ws-tag{display:inline-block;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--sun);font-weight:700}
.whoslide-content h3{color:#fff;font-size:clamp(32px,4.6vw,54px);margin:14px 0 16px;line-height:1.04;letter-spacing:-.01em}
.whoslide-content p{color:rgba(255,255,255,.85);font-size:clamp(16px,1.4vw,19px);line-height:1.6;margin-bottom:24px;max-width:42ch}
.whoslide-content .pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:28px}
.whoslide-content .pill{background:rgba(255,255,255,.14);color:#fff;border:1px solid rgba(255,255,255,.18)}
.whoslider-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:3}
.ws-dot{width:34px;height:5px;border-radius:3px;border:none;background:rgba(255,255,255,.35);cursor:pointer;transition:.35s;padding:0}
.ws-dot:hover{background:rgba(255,255,255,.6)}
.ws-dot.is-active{background:var(--sun);width:50px}
.ws-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(8,43,48,.4);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.25s}
.ws-arrow:hover{background:rgba(8,43,48,.75);border-color:var(--sun)}
.ws-prev{left:18px}.ws-next{right:18px}

/* ============================================================
   Responsive
   ============================================================ */
@media(max-width:980px){
  .feature,.about,.contact-grid,.split,.meet{grid-template-columns:1fr;gap:32px}
  .quotes{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr;gap:30px 22px}
  .step-line{display:none}
  .flow{grid-template-columns:1fr;gap:30px}
  .flow-rail{display:none}
  .grid-3,.post-grid{grid-template-columns:1fr 1fr}
  .aside-card{position:static}
}
@media(max-width:760px){
  body{font-size:16px}
  .wrap{padding:0 22px}
  .sec{padding:var(--s8) 0}
  .nav-links{
    position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--paper);border-bottom:1px solid var(--line);padding:14px 22px 22px;
    gap:2px;box-shadow:var(--sh-md);transform:translateY(-130%);transition:transform .3s;
    z-index:55;
  }
  .nav-links.open{transform:none}
  .nav-links a{padding:13px 14px;font-size:16px}
  .nav .nav-cta .btn-sec{display:none}
  .nav-toggle{display:block}
  /* dropdown becomes inline on mobile */
  .has-drop{width:100%}
  .drop-toggle{width:100%;justify-content:space-between;padding:13px 14px;font-size:16px}
  .drop-menu{position:static;transform:none;opacity:1;visibility:visible;box-shadow:none;border:none;border-radius:0;padding:0 0 6px 10px;min-width:0;background:transparent}
  .drop-menu a{padding:10px 8px}
  .drop-menu a .dd{display:none}
  .grid-3,.grid-2,.steps,.post-grid,.check-grid,.quotes,.promise-grid{grid-template-columns:1fr}
  .meet .portrait{max-width:340px}
  .ws-arrow{display:none}
  .whoslides{min-height:clamp(440px,76vh,560px)}
  .whoslide-content p{font-size:16px}
  .tl-item{padding-left:62px}
  /* fewer squares on small screens */
  .deco-squares .sq:nth-child(3),.deco-squares .sq:nth-child(8),.deco-squares .sq:nth-child(9),.deco-squares .sq:nth-child(10),.deco-squares .sq:nth-child(11){display:none}
  .trust .row{flex-direction:column;gap:14px}
  .trust .dot{display:none}
  .hero-meta{gap:24px 30px}
}

@media(max-width:560px){
  .wa-float{right:16px;bottom:16px;padding:0;border:none;background:transparent;box-shadow:none}
  .wa-float .wa-tx{display:none}
  .wa-float .wa-ic{width:54px;height:54px;box-shadow:0 12px 26px -8px rgba(10,54,59,.5)}
  .wa-float .wa-ic svg{width:30px;height:30px}
}

@media(prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;filter:none!important;transition:none!important}
  .btn:hover,.svc-card:hover,.path:hover{transform:none!important}
  .wa-float .wa-ic{animation:none!important}
  .trust.marquee .marquee-track{animation:none!important;justify-content:center;width:100%;flex-wrap:wrap;gap:10px 0}
  .quotes-track{animation:none!important;flex-wrap:wrap;justify-content:center;width:100%}
  .quotes-marquee{-webkit-mask-image:none;mask-image:none}
  [data-parallax]{transform:none!important}
  .flow-rail-fill{width:100%!important;transition:none!important}
  .flow-step .n{border-color:var(--sun);background:var(--sun);color:var(--sea-deep)}
  .whoslide{transition:none!important}
  .whoslide.is-active .whoslide-bg{animation:none!important}
  .whoslide-content > *{opacity:1!important;transform:none!important}
}
