/* ============================================================
   ANCHOR & WAVE — base system (shared across all directions)
   ============================================================ */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--navy);
  scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.18) transparent}
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.18);border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.3)}
body{font-family:var(--font-ui);color:var(--ink);background:var(--bg);
  transition:background .6s ease,color .6s ease}
img{max-width:100%;display:block}
a{color:inherit}

/* ---------- design tokens (defaults = Harbour) ---------- */
:root{
  --navy:#0F2A3F; --navy-2:#1A3A52; --navy-deep:#0A1E2E;
  --brass:#C4913A; --brass-deep:#946109; --brass-soft:#E2B873;
  --sand:#F4EDE4; --sand-dark:#E8DDD0; --cream:#FDFBF8; --white:#fff;
  --ink:#1C1C1C; --muted:#5A6672; --soft:#6A7480; --light:#8B95A1; --slate:#8197AE;
  --accent:#C4913A; --accent-deep:#946109;
  --bg:#FDFBF8; --surface:#fff; --hairline:#E8DDD0;
  --font-display:'DM Serif Display',Georgia,serif;
  --font-ui:'Libre Franklin','Helvetica Neue',sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --radius:12px; --radius-sm:8px; --maxw:1120px;
  --hero-h:600px; --section-y:56px;
  --shadow-card:0 16px 48px rgba(15,42,63,.10);
  --topbar-h:56px;
}

/* ---------- motion ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.23,1,.32,1),transform .9s cubic-bezier(.23,1,.32,1)}
.reveal.from-left{transform:translate3d(-40px,0,0)}
.reveal.from-right{transform:translate3d(40px,0,0)}
.reveal.fade-only{transform:none;transition:opacity 1.2s cubic-bezier(.23,1,.32,1)}
.reveal.visible{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.4s}
body.no-motion .reveal{opacity:1!important;transform:none!important;transition:none!important}
body.no-motion *{animation:none!important}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1!important;transform:none!important}}

/* page is pushed down below the switcher */
.page{padding-top:var(--topbar-h);overflow-x:clip}

/* ============================================================
   NAV
   ============================================================ */
nav{position:fixed;top:var(--topbar-h);left:0;right:0;z-index:120;padding:18px 30px;
  transition:all .4s ease;border-bottom:1px solid transparent;color:#fff}
nav.scrolled{padding:11px 30px;background:rgba(253,251,248,.95);backdrop-filter:blur(16px);
  border-bottom-color:var(--hairline);color:var(--navy)}
nav .inner{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.logo{display:flex;flex-direction:column;text-decoration:none;color:inherit;line-height:1}
.logo .lw{font-family:var(--font-display);font-size:22px;letter-spacing:-.3px;white-space:nowrap}
.logo .lw em{color:var(--brass);font-style:normal}
.logo .ls{font-family:var(--font-ui);font-size:9px;letter-spacing:4.5px;font-weight:600;opacity:.55;margin-top:3px;padding-left:2px;white-space:nowrap}
nav .links{display:flex;align-items:center;gap:30px}
nav .links a{font-size:13.5px;font-weight:500;text-decoration:none;letter-spacing:.3px;
  color:rgba(255,255,255,.82);transition:color .2s}
nav .links a:hover{color:#fff}
nav.scrolled .links a{color:var(--muted)}
nav.scrolled .links a:hover{color:var(--navy)}
/* vertical divider separating the three service links from the rest */
.navdiv{width:1px;height:22px;border-radius:1px;background:rgba(255,255,255,.5);flex:none;margin:0 6px}
nav.scrolled .navdiv{background:rgba(15,42,63,.28)}
html:has(.svc-hero) nav:not(.scrolled) .navdiv{background:rgba(15,42,63,.28)}
.navcta{padding:9px 20px;border-radius:6px;font-size:13px!important;font-weight:600!important;white-space:nowrap;
  background:var(--brass);color:var(--navy)!important;transition:all .25s}
.navcta:hover{background:var(--brass-soft);transform:translateY(-1px);box-shadow:0 8px 22px rgba(196,145,58,.3)}
.hamburger{display:none;width:24px;height:17px;position:relative;cursor:pointer}
.hamburger span{display:block;position:absolute;height:2px;width:100%;background:currentColor;border-radius:2px;transition:.3s}
.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:7.5px}.hamburger span:nth-child(3){top:15px}
.hamburger.open span:nth-child(1){top:7.5px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:7.5px;transform:rotate(-45deg)}
.mobile-menu{display:none;flex-direction:column;gap:6px;max-height:0;overflow:hidden;transition:max-height .35s ease}
.mobile-menu.open{max-height:340px;margin:0 -30px;padding:12px 30px 18px;background:rgba(253,251,248,.98)}
/* keep the whole bar solid while the menu is open, even at the top of the page over the hero photo */
nav.menuopen,#nav.menuopen{background:rgba(253,251,248,.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom-color:var(--hairline);color:var(--navy)}
.mobile-menu a:not(.btn){font-size:15px;font-weight:500;color:var(--navy);text-decoration:none;padding:9px 0;border-bottom:1px solid var(--sand-dark)}
.mobile-menu a:not(.btn):last-of-type{border-bottom:none}
@media(max-width:860px){nav .links{display:none}.hamburger{display:block}.mobile-menu{display:flex}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:15px 32px;font-family:var(--font-ui);
  font-size:14.5px;font-weight:600;letter-spacing:.4px;text-decoration:none;border-radius:6px;white-space:nowrap;
  cursor:pointer;border:none;transition:all .3s ease}
.btn-primary{background:var(--navy);color:#fff}
.btn-primary:hover{background:var(--navy-2);transform:translateY(-2px);box-shadow:0 10px 28px rgba(15,42,63,.3)}
.btn-brass{background:var(--brass);color:var(--navy)}
.btn-brass:hover{background:var(--brass-soft);transform:translateY(-2px);box-shadow:0 10px 28px rgba(196,145,58,.32)}
.btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.45)}
.btn-ghost:hover{border-color:#fff;transform:translateY(-2px);background:rgba(255,255,255,.06)}
.btn-line{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-line:hover{transform:translateY(-2px);background:var(--navy);color:#fff}
.btn-full{width:100%;justify-content:center}
.btn-sm{padding:10px 22px;font-size:13px}

/* ============================================================
   SECTION SCAFFOLD
   ============================================================ */
.section{padding:var(--section-y) 24px;position:relative}
.section .inner{max-width:var(--maxw);margin:0 auto}
.eyebrow{font-family:var(--font-ui);font-size:11.5px;font-weight:600;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--accent-deep);margin-bottom:14px;display:inline-flex;align-items:center;gap:9px}
.eyebrow.light{color:var(--brass)}
.eyebrow .tick{width:22px;height:1.5px;background:currentColor;display:inline-block}
.sec-title{font-family:var(--font-display);font-size:clamp(31px,4.4vw,47px);font-weight:400;
  color:var(--navy);line-height:1.13;margin:0 0 20px;letter-spacing:-.5px;text-wrap:balance}
.sec-title.white{color:#fff}
.sec-body{font-size:17px;line-height:1.72;color:var(--muted);margin:0 0 16px;max-width:620px;text-wrap:pretty}
.sec-body.dim{color:rgba(255,255,255,.62)}

/* wave dividers */
.wave-divider{line-height:0;margin-top:-1px;margin-bottom:-1px;overflow:hidden}
.wave-divider svg{display:block;width:140%;margin-left:-20%;animation:wavedrift 18s ease-in-out infinite alternate}
@keyframes wavedrift{from{transform:translateX(0)}to{transform:translateX(6%)}}

/* ============================================================
   HERO (base — themed heavily per direction)
   ============================================================ */
.hero{position:relative;overflow:hidden;background:var(--navy);color:#fff;
  min-height:var(--hero-h);display:flex;align-items:center;padding:120px 24px 96px}
.hero-photo{position:absolute;inset:0;z-index:0;will-change:transform}
.hero-photo-img{position:absolute;inset:-12% 0;background:url("assets/hero.jpg") 58% center/cover no-repeat;
  transform-origin:62% 50%;animation:kenburns 26s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1.05)}to{transform:scale(1.14)}}
.hero-scrim{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(100deg,rgba(15,42,63,.92) 0%,rgba(15,42,63,.78) 30%,rgba(15,42,63,.42) 52%,rgba(15,42,63,.12) 70%,rgba(15,42,63,0) 85%),
  linear-gradient(to bottom,rgba(15,42,63,.45) 0%,rgba(15,42,63,0) 26%,rgba(15,42,63,0) 58%,rgba(15,42,63,.55) 84%,var(--navy) 100%)}
.hero-inner{position:relative;z-index:3;max-width:var(--maxw);width:100%;margin:0 auto;
  display:grid;grid-template-columns:minmax(0,1fr);gap:40px;align-items:center}
.hero-copy{max-width:660px}
.badge{display:inline-block;background:var(--brass);color:var(--navy);font-family:var(--font-ui);
  font-size:11px;font-weight:600;letter-spacing:1px;padding:5px 13px;border-radius:4px;
  text-transform:uppercase;margin-bottom:24px}
.hero h1{font-family:var(--font-display);font-size:clamp(40px,6vw,70px);font-weight:400;
  line-height:1.05;color:#fff;margin:0 0 24px;letter-spacing:-1px;text-wrap:balance}
.hero h1 em{color:var(--brass);font-style:italic}
.hero .lede{font-size:18.5px;max-width:510px;margin-bottom:36px;color:rgba(255,255,255,.86);line-height:1.7}
.cta-row{display:flex;gap:14px;flex-wrap:wrap}
.scroll-cue{position:absolute;left:50%;bottom:22px;z-index:4;color:rgba(255,255,255,.6);
  transform:translateX(-50%);animation:cuebob 2.2s ease-in-out infinite}
@keyframes cuebob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(7px)}}

/* ============================================================
   TRUST BAR
   ============================================================ */
.trust{background:var(--navy);padding:60px 24px 46px}
.trust .slogan{font-family:var(--font-display);font-style:italic;font-size:clamp(20px,2.4vw,27px);
  color:var(--slate);text-align:center;max-width:780px;margin:0 auto 44px;line-height:1.25}
.trust .inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:30px;text-align:center}
.trust .item{position:relative}
.trust .item h3{font-size:15px;font-weight:600;color:#fff;letter-spacing:.3px;margin-bottom:6px}
.trust .item p{font-size:13px;color:var(--light);line-height:1.5}
.trust .item:not(:last-child)::after{content:"";position:absolute;right:-15px;top:6px;bottom:6px;width:1px;background:rgba(255,255,255,.08)}
@media(max-width:768px){.trust .inner{grid-template-columns:1fr 1fr;gap:24px}.trust .item:nth-child(2)::after{display:none}}

/* ============================================================
   SERVICES / PRICING
   ============================================================ */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.svc-head{display:flex;justify-content:space-between;align-items:center;gap:18px 32px;flex-wrap:wrap}
.svc-head .sec-title{margin-bottom:0}
.svc-head .btn{padding:15px 38px}
@media(max-width:560px){.svc-head .btn{width:100%;justify-content:center}}
.card{background:var(--surface);border-radius:var(--radius);padding:34px 30px;border:1px solid var(--hairline);
  display:flex;flex-direction:column;transition:transform .4s cubic-bezier(.23,1,.32,1),box-shadow .4s,border-color .4s;position:relative}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-card)}
.card.featured{border:1.5px solid var(--brass);box-shadow:0 8px 32px rgba(196,145,58,.12)}
.card .popular{position:absolute;top:-12px;left:30px;background:var(--brass);color:var(--navy);
  font-size:10.5px;font-weight:700;letter-spacing:1.5px;padding:5px 13px;border-radius:4px;text-transform:uppercase}
.card .tier{font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent-deep);margin-bottom:10px}
.card a.tier{display:inline-flex;align-items:center;gap:6px;width:fit-content;text-decoration:none;transition:color .2s}
.card a.tier:hover{color:var(--navy)}
.card a.tier .tarr{transition:transform .2s}
.card a.tier:hover .tarr{transform:translateX(3px)}
/* card-head: tier + price stacked */
.card .card-head{display:block;width:fit-content}
.card .card-head .tier{display:inline-flex;align-items:center;gap:6px}
.card .card-head .price{display:block}
.card .price{font-family:var(--font-display);font-size:35px;color:var(--navy);line-height:1}
.card .price .from{display:inline;font-family:var(--font-ui);font-size:14.5px;font-weight:500;letter-spacing:0;text-transform:none;color:var(--soft);margin:0 7px 0 0}
.card .price span{font-family:var(--font-ui);font-size:14.5px;color:var(--soft)}
.card .cdesc{font-size:14.5px;line-height:1.6;color:var(--muted);margin:15px 0 22px}
/* services pricing hierarchy: tier name is the star, descriptor next, price quietest */
#services .card .tier{font-family:var(--font-display);font-size:30px;font-weight:400;letter-spacing:0;text-transform:none;color:var(--navy);line-height:1.05;margin-bottom:0}
#services .card .cdesc{margin:8px 0 13px}
#services .card .price{font-family:var(--font-display);font-size:24px;font-weight:400;color:var(--accent-deep);line-height:1;margin-bottom:22px}
#services .card .price .from,#services .card .price span{font-size:13px;font-weight:500;color:var(--soft)}
@media(min-width:861px){
  /* subgrid: tier / descriptor / price / features / button share row lines across
     all three cards, so the price line aligns no matter how each descriptor wraps */
  #services .svc-grid{grid-template-rows:auto auto auto 1fr}
  #services .svc-grid > .card{display:grid;grid-template-rows:subgrid;grid-row:span 4;row-gap:0}
  #services .svc-grid > .card .cdesc{min-height:0}
}
.card .feats{border-top:1px solid var(--sand);padding-top:20px;flex-grow:1;display:flex;flex-direction:column;gap:11px}
.feat{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--ink);line-height:1.45}
.feat .ck{color:var(--accent-deep);font-weight:700;flex-shrink:0;margin-top:1px}
.feat.rollup{font-weight:600;color:var(--navy);font-size:14.5px;margin-bottom:7px}
.card .learn{display:inline-flex;justify-content:center;gap:6px;margin-top:12px;font-size:13.5px;
  font-weight:500;color:var(--muted);text-decoration:none;transition:color .2s}
.card .learn:hover{color:var(--navy)}
.card .learn span{transition:transform .2s}
.card .learn:hover span{transform:translateX(4px)}
.fineprint{font-size:13px;color:var(--soft);text-align:center;margin-top:28px;font-style:italic;max-width:var(--maxw);margin-inline:auto;line-height:1.6}
@media(max-width:860px){.svc-grid{grid-template-columns:1fr;max-width:440px;margin-inline:auto}}

/* ============================================================
   PROCESS STEPS
   ============================================================ */
.steps{margin-top:46px}
.step{display:grid;grid-template-columns:78px 1fr;gap:24px;padding:30px 0;border-bottom:1px solid var(--hairline);align-items:start}
.step:last-child{border-bottom:none}
.step .num{font-family:var(--font-display);font-size:42px;color:var(--accent);line-height:1;opacity:.6}
.step h3{font-family:var(--font-display);font-size:23px;color:var(--navy);margin:0 0 8px;font-weight:400}
.step p{font-size:15.5px;line-height:1.68;color:var(--muted);margin:0;padding-right:96px}
@media(max-width:768px){.step{grid-template-columns:54px 1fr;gap:16px}.step .num{font-size:32px}.step p{padding-right:0}}

/* ============================================================
   PRINCIPAL
   ============================================================ */
.principal{background:var(--navy);padding:var(--section-y) 24px;overflow:hidden}
.principal .inner{max-width:var(--maxw);margin:0 auto}
.prin-grid{display:grid;grid-template-columns:.8fr 1fr;gap:56px;align-items:stretch}
.prin-left{display:flex;flex-direction:column}
.prin-photo{position:relative;min-height:500px;border-radius:14px;overflow:hidden;
  background:linear-gradient(150deg,#15334a,#0c2336)}
.prin-photo .ph-stripe{position:absolute;inset:0;opacity:.5;
  background:repeating-linear-gradient(135deg,rgba(255,255,255,.03) 0 14px,transparent 14px 28px)}
.prin-photo .ph-label{position:absolute;left:0;right:0;bottom:24px;text-align:center;
  font-family:var(--font-mono);font-size:11px;letter-spacing:1px;color:rgba(255,255,255,.4)}
.prin-photo .ph-ring{position:absolute;left:50%;top:44%;transform:translate(-50%,-50%);
  width:128px;height:128px;border-radius:50%;border:1.5px solid rgba(196,145,58,.5);display:grid;place-items:center}
.prin-photo .ph-ring span{font-family:var(--font-display);font-size:46px;color:var(--brass)}
.p-kicker{font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--brass);margin-bottom:14px}
.p-head{font-family:var(--font-display);font-size:clamp(27px,3.3vw,39px);color:#fff;font-weight:400;line-height:1.14;margin:0 0 22px;letter-spacing:-.5px}
.p-bio{font-size:15.5px;line-height:1.75;color:rgba(255,255,255,.82);margin:0 0 18px;max-width:520px}
.p-sign{margin-top:22px}
.p-name{display:block;font-family:var(--font-display);font-style:italic;font-size:20px;color:#fff}
.p-title{display:block;font-size:13px;color:var(--light);margin-top:5px}
/* credential marks under the signature. Each .cred is a fixed-height slot so
   official badge artwork can replace the text one-for-one. The 44px slot
   height clears the CPA mark's 34px digital minimum, and the row gap gives
   the required protected space around any licensed logo. */
.p-creds{margin-top:22px;display:flex;flex-wrap:wrap;gap:14px 36px;max-width:520px}
.cred{display:flex;flex-direction:column;justify-content:center;height:44px}
.cred-kicker{font-family:var(--font-mono);font-size:9.5px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;color:rgba(255,255,255,.45)}
.cred-name{font-size:14.5px;font-weight:600;color:rgba(255,255,255,.88);margin-top:3px;letter-spacing:.2px}
.cred-img{height:44px;width:auto;display:block}
@media(max-width:860px){.prin-grid{grid-template-columns:1fr;gap:30px}.prin-photo{min-height:360px}}

/* ============================================================
   TESTIMONIALS (former employers)
   ============================================================ */
.testimonials{background:var(--navy-deep);padding:var(--section-y) 24px;overflow:hidden}
.testimonials .inner{max-width:var(--maxw);margin:0 auto}
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:46px}
.tm-card{position:relative;display:flex;flex-direction:column;
  background:rgba(255,255,255,.035);border:1px solid rgba(255,255,255,.09);
  border-radius:var(--radius);padding:32px 30px 26px;
  transition:transform .4s cubic-bezier(.23,1,.32,1),border-color .4s,background .4s}
.tm-card:hover{transform:translateY(-5px);border-color:rgba(196,145,58,.4);background:rgba(255,255,255,.05)}
.tm-mark{position:absolute;top:16px;right:26px;font-family:var(--font-display);
  font-size:58px;line-height:1;color:var(--brass);pointer-events:none}
.tm-quote{font-size:15.5px;line-height:1.72;color:rgba(255,255,255,.84);
  margin:14px 0 24px;padding-right:34px;flex-grow:1;text-wrap:pretty}
.tm-attrib{display:flex;align-items:center;gap:13px;margin-top:auto;
  padding-top:18px;border-top:1px solid rgba(196,145,58,.28)}
.tm-avatar{width:42px;height:42px;border-radius:50%;flex-shrink:0;
  border:1.5px dashed rgba(196,145,58,.55);display:grid;place-items:center;
  font-family:var(--font-mono);font-size:15px;color:rgba(196,145,58,.7)}
.tm-who{display:flex;flex-direction:column;gap:2px;min-width:0}
.tm-name{font-family:var(--font-display);font-size:16px;color:#fff;line-height:1.2}
.tm-role{font-size:12.5px;color:var(--light);line-height:1.3}
.tm-rel{font-size:11.5px;color:var(--slate);margin-top:5px;line-height:1.3}
@media(max-width:860px){.tm-grid{grid-template-columns:1fr;gap:18px}}

/* ============================================================
   BOOK / CONTACT CTA
   ============================================================ */
.book{position:relative;overflow:hidden;background:var(--navy);padding:118px 24px;text-align:center}
.book-photo{position:absolute;inset:0;z-index:0;will-change:transform}
.book-photo-img{position:absolute;inset:-12% 0;background:url("assets/book-centered.jpg") center 52%/cover no-repeat;
  animation:kenburns 30s ease-in-out infinite alternate}
.book-scrim{position:absolute;inset:0;z-index:1;
  background:linear-gradient(to bottom,var(--navy) 0%,rgba(15,42,63,.9) 8%,rgba(15,42,63,.6) 30%,rgba(15,42,63,.6) 55%,rgba(13,33,49,.86) 80%,var(--navy-deep) 100%)}
.book .content{position:relative;z-index:2;max-width:640px;margin:0 auto}
.book .amp{font-family:var(--font-display);font-size:46px;color:var(--brass);margin-bottom:6px}
.book h2{font-family:var(--font-display);font-size:clamp(29px,4vw,44px);color:#fff;margin:18px 0 16px;
  font-weight:400;line-height:1.14;text-shadow:0 2px 22px rgba(9,24,38,.55)}
.book .bbody{font-size:16.5px;line-height:1.7;color:rgba(255,255,255,.9);margin:0 auto 34px;max-width:470px;text-shadow:0 1px 14px rgba(9,24,38,.6)}
.book .sub{font-size:13px;color:rgba(255,255,255,.62);margin-top:20px}

/* ============================================================
   FOOTER
   ============================================================ */
footer{background:var(--navy-deep);padding:54px 24px 34px}
footer .inner{max-width:var(--maxw);margin:0 auto;display:flex;justify-content:space-between;
  align-items:flex-start;flex-wrap:wrap;gap:34px}
footer .lw{font-family:var(--font-display);font-size:25px;color:#fff;letter-spacing:-.3px}
footer .lw em{color:var(--brass);font-style:normal}
footer .ls{font-family:var(--font-ui);font-size:9.5px;letter-spacing:5px;font-weight:600;color:rgba(255,255,255,.4);margin:4px 0 12px}
footer .ftag{font-family:var(--font-display);font-style:italic;font-size:15px;color:rgba(255,255,255,.5);margin-bottom:14px;letter-spacing:.2px}
footer .col-title{font-size:11.5px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-bottom:12px}
footer a,footer p.ft{font-size:13.5px;color:rgba(255,255,255,.5);text-decoration:none;display:block;margin-bottom:7px}
footer a:hover{color:var(--brass-soft)}
footer .blurb{font-size:13px;color:rgba(255,255,255,.35);max-width:280px;line-height:1.6}
footer .bottom{max-width:var(--maxw);margin:36px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
footer .bottom p,footer .bottom a{font-size:12px;color:rgba(255,255,255,.42);margin:0}
.disclaimer{max-width:var(--maxw);margin:18px auto 0;padding-top:14px;border-top:1px solid rgba(255,255,255,.06);
  font-size:11.5px;line-height:1.6;color:rgba(255,255,255,.4);text-align:center}

.skip-link{position:fixed;left:14px;top:-60px;z-index:300;background:var(--brass);color:var(--navy);padding:11px 20px;border-radius:6px;font-family:var(--font-ui);font-weight:600;font-size:14px;text-decoration:none;box-shadow:0 8px 24px rgba(9,24,38,.3);transition:top .2s ease}
.skip-link:focus{top:14px}
:focus-visible{outline:3px solid var(--brass);outline-offset:2px}

/* pages */
/* ============================================================
   SUB-PAGES — service pages + questionnaire
   Built on base.css tokens; themed across all 4 directions.
   ============================================================ */

/* ---------- service hero ---------- */
/* nav dark over light sub-page heroes */
html:has(.svc-hero) nav:not(.scrolled){color:var(--navy)}
html:has(.svc-hero) nav:not(.scrolled) .links a{color:var(--muted)}
html:has(.svc-hero) nav:not(.scrolled) .links a:hover{color:var(--navy)}
html:has(.svc-hero) nav:not(.scrolled) .navcta{color:var(--navy)!important}
.svc-hero{position:relative;overflow:hidden;padding:150px 24px 96px;
  background:linear-gradient(165deg,var(--cream) 0%,var(--sand) 58%,#F8F0E3 100%)}
.svc-hero .grid-bg{position:absolute;inset:0;opacity:.05;
  background-image:linear-gradient(var(--navy) 1px,transparent 1px),linear-gradient(90deg,var(--navy) 1px,transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 90% 80% at 25% 30%,#000,transparent 80%)}
.svc-hero .content{max-width:var(--maxw);margin:0 auto;position:relative;z-index:2}
.back-link{font-size:13.5px;color:var(--muted);text-decoration:none;transition:color .2s;display:inline-flex;align-items:center;gap:7px}
.back-link:hover{color:var(--navy)}
.svc-hero h1{font-family:var(--font-display);font-size:clamp(36px,5.2vw,58px);font-weight:400;
  color:var(--navy);line-height:1.06;letter-spacing:-.8px;margin:16px 0 18px;max-width:780px;text-wrap:balance}
.svc-hero .lead{font-size:18px;line-height:1.7;color:var(--muted);max-width:600px;margin-bottom:30px;text-wrap:pretty}
.svc-hero .hero-wave{position:absolute;bottom:-1px;left:0;width:100%;display:block;z-index:1}
.svc-hero .hero-wave svg{display:block;width:100%}

/* ---------- "what's included" feature cards ---------- */
.svc-features{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-top:44px}
.svc-feat{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:26px 28px;transition:transform .35s cubic-bezier(.23,1,.32,1),box-shadow .35s,border-color .35s}
.svc-feat:hover{transform:translateY(-4px);box-shadow:var(--shadow-card);border-color:transparent}
.svc-feat h3{font-size:16px;font-weight:600;color:var(--navy);margin-bottom:9px;display:flex;align-items:flex-start;gap:9px;line-height:1.35}
.svc-feat h3 .ck{color:var(--accent-deep);font-weight:700;flex-shrink:0}
.svc-feat p{font-size:14.5px;line-height:1.66;color:var(--muted);margin:0}
@media(max-width:760px){.svc-features{grid-template-columns:1fr}}

/* ---------- "what makes this different" points ---------- */
.svc-points{display:grid;grid-template-columns:1fr 1fr;gap:34px 48px;margin-top:44px}
.svc-point{position:relative;padding-left:24px}
.svc-point::before{content:"";position:absolute;left:0;top:6px;bottom:6px;width:3px;border-radius:2px;background:var(--accent);opacity:.55}
.svc-point h3{font-family:var(--font-display);font-size:21px;font-weight:400;color:var(--navy);margin-bottom:9px}
.svc-point p{font-size:15.5px;line-height:1.7;color:var(--muted);margin:0}
@media(max-width:760px){.svc-points{grid-template-columns:1fr;gap:26px}}

/* ---------- pricing box ---------- */
.price-box{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:40px;max-width:560px;margin-top:30px;position:relative;overflow:hidden}
.price-box .pt{font-size:11.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--accent-deep);margin-bottom:8px}
.price-box .pr{font-family:var(--font-display);font-size:34px;color:var(--navy);line-height:1;margin-bottom:16px}
.price-box .pn{font-size:15px;line-height:1.65;color:var(--muted);margin:0 0 8px}
html[data-dir="ledger"] .price-box .pr{font-family:var(--font-mono);font-size:28px;font-weight:600;letter-spacing:-1px}

/* ---------- navy CTA ---------- */
.svc-cta{background:var(--navy);padding:92px 24px;text-align:center;position:relative;overflow:hidden}
.svc-cta .amp{font-family:var(--font-display);font-size:46px;color:var(--brass);margin-bottom:6px}
.svc-cta h2,.svc-cta h1{font-family:var(--font-display);font-size:clamp(28px,3.6vw,42px);color:#fff;font-weight:400;line-height:1.15;margin:16px 0 16px}
.svc-cta p{font-size:16.5px;line-height:1.7;color:rgba(255,255,255,.6);max-width:600px;margin:0 auto 34px;text-wrap:balance}
.svc-cta .sub{font-size:13px;color:rgba(255,255,255,.4);margin-top:20px}
/* orphan prevention: short blocks balance, longer prose stays pretty */
.lead,.svc-cta h2,.svc-cta h1,.sec-title,.svc-feat h3{text-wrap:balance}
.sec-body,.svc-feat p,.card .cdesc,.faq-a-inner p,.fineprint{text-wrap:pretty}

/* related services strip */
.related{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}
.related a{font-size:13.5px;font-weight:500;color:rgba(255,255,255,.7);text-decoration:none;
  border:1px solid rgba(255,255,255,.18);border-radius:30px;padding:9px 18px;transition:all .2s;background:transparent}
.related a:hover{color:var(--brass);border-color:var(--brass);background:rgba(196,145,58,.08);transform:translateY(-2px)}

/* direction nuance for service hero */
html[data-dir="ledger"] .svc-hero{background:var(--bg)}
html[data-dir="ledger"] .svc-hero .grid-bg{opacity:.08}
html[data-dir="brass"] .svc-hero{background:linear-gradient(165deg,var(--bg) 0%,#F4E9D6 100%)}
html[data-dir="brass"] .svc-hero h1{font-size:clamp(40px,6vw,72px);letter-spacing:-1.5px}
html[data-dir="tide"] .svc-hero h1{font-size:clamp(40px,6vw,76px)}

/* ============================================================
   QUESTIONNAIRE — multi-step interactive form
   ============================================================ */
.q-wrap{max-width:760px;margin:0 auto;padding:0 24px 100px}
.q-alt{text-align:center;margin-top:22px;font-size:13.5px;color:var(--soft)}
.q-alt a{color:var(--accent-deep);font-weight:600;text-decoration:none;border-bottom:1px solid rgba(196,145,58,.4)}
.q-alt a:hover{border-bottom-color:var(--accent-deep)}
.q-card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--radius);
  padding:42px 46px 38px;box-shadow:0 18px 50px rgba(15,42,63,.07)}
@media(max-width:640px){.q-card{padding:30px 22px}}

/* progress */
.q-progress{display:flex;align-items:center;gap:0;margin-bottom:34px}
.q-pstep{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;position:relative}
.q-pstep .pdot{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  font-family:var(--font-mono);font-size:12px;font-weight:600;background:var(--sand);color:var(--soft);
  border:1.5px solid var(--hairline);transition:all .3s;z-index:2}
.q-pstep .plabel{font-size:11px;font-weight:600;letter-spacing:.3px;color:var(--soft);text-align:center;transition:color .3s}
.q-pstep::after{content:"";position:absolute;top:15px;left:50%;width:100%;height:1.5px;background:var(--hairline);z-index:1;transition:background .3s}
.q-pstep:last-child::after{display:none}
.q-pstep.active .pdot{background:var(--accent);color:#fff;border-color:var(--accent)}
.q-pstep.active .plabel{color:var(--navy)}
.q-pstep.done .pdot{background:var(--navy);color:#fff;border-color:var(--navy)}
.q-pstep.done::after{background:var(--navy)}
.q-pstep.done .plabel{color:var(--navy)}
.q-pstep.clickable{cursor:pointer}
.q-pstep.clickable .pdot{cursor:pointer}
.q-pstep.done .pdot::after{content:"✓"}
.q-pstep.done .pdot span{display:none}
@media(max-width:640px){.q-pstep .plabel{display:none}}

/* steps */
.q-step{display:none;animation:qfade .4s ease}
.q-step.active{display:block}
@keyframes qfade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.q-step-title{font-family:var(--font-display);font-size:24px;color:var(--navy);margin-bottom:6px;font-weight:400}
.q-step-desc{font-size:14.5px;color:var(--muted);margin-bottom:24px;line-height:1.6}

.fgroup{margin-bottom:20px}
.fgroup label.flabel{display:block;font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:7px;letter-spacing:.2px}
.fgroup .opt{font-weight:400;color:var(--soft);font-size:12.5px}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.frow{grid-template-columns:1fr}}
.fgroup input[type=text],.fgroup input[type=email],.fgroup input[type=tel],.fgroup input[type=url],.fgroup input[type=number],.fgroup select,.fgroup textarea{
  width:100%;padding:12px 15px;font-family:var(--font-ui);font-size:15px;color:var(--ink);background:#fff;
  border:1.5px solid var(--hairline);border-radius:var(--radius-sm);transition:border-color .2s,box-shadow .2s;outline:none}
html[data-dir="ledger"] .fgroup input,html[data-dir="ledger"] .fgroup select,html[data-dir="ledger"] .fgroup textarea{border-radius:4px}
.fgroup input:focus,.fgroup select:focus,.fgroup textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,145,58,.18)}
.fgroup input.err,.fgroup select.err{border-color:#C2453A;box-shadow:0 0 0 3px rgba(194,69,58,.14)}
.fgroup textarea{min-height:104px;resize:vertical}
.fgroup select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%238B95A1' stroke-width='1.5' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px}
.ferr{font-size:12px;color:#C2453A;margin-top:5px;display:none}
.fgroup.show-err .ferr{display:block}
.q-note{margin-top:9px;font-size:12.5px;line-height:1.55;color:var(--muted);
  background:var(--sand);border:1px solid var(--sand-dark);border-radius:var(--radius-sm);padding:10px 13px}

/* choice chips */
.chip-fieldset{border:none;padding:0;margin:0;min-width:0}
.chip-fieldset legend{padding:0}
.chip-fieldset.show-err .ferr{display:block}
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
/* "Who is this for?" — full-width stacked rows for a clean, coherent
   multi-select list (overrides the 2-col .chip-grid base) */
.chip-grid.path-grid{grid-template-columns:1fr}
/* section divider when more than one path is active, so the form reads as
   distinct sub-questionnaires on one page */
.q-divider{margin:36px 0 20px;padding-bottom:9px;border-bottom:1px solid var(--hairline);
  font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--accent-deep)}
/* conditional fields driven by who-it's-for (multi-select, OR logic):
   default-hide, then restore each element's natural display when ANY of its
   types is active. Only fgroup/fieldset/divider (block) and frow (grid) carry data-when. */
#q-form [data-when]{display:none}
#q-form.has-business [data-when~="business"]:not(.frow),
#q-form.has-personal [data-when~="personal"]:not(.frow),
#q-form.has-military [data-when~="military"]:not(.frow){display:block}
#q-form.has-business .frow[data-when~="business"],
#q-form.has-personal .frow[data-when~="personal"],
#q-form.has-military .frow[data-when~="military"]{display:grid}
.chip-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:560px){.chip-grid{grid-template-columns:1fr}}
.chip-fieldset+.chip-fieldset{margin-top:26px}
.chip{display:flex;align-items:center;gap:11px;padding:14px 16px;border:1.5px solid var(--hairline);
  border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;background:#fff}
html[data-dir="ledger"] .chip{border-radius:4px}
.chip:hover{border-color:var(--accent);background:rgba(196,145,58,.05)}
.chip:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(196,145,58,.18)}
.chip.checked{border-color:var(--accent);background:rgba(196,145,58,.09)}
.chip .box{width:20px;height:20px;border-radius:5px;border:1.5px solid var(--hairline);flex-shrink:0;
  display:grid;place-items:center;transition:all .2s}
.chip.checked .box{background:var(--accent);border-color:var(--accent)}
.chip.checked .box::after{content:"✓";color:#fff;font-size:12px;font-weight:700}
.chip span.txt{font-size:14.5px;color:var(--ink);line-height:1.35}
/* service chips with an inline explainer */
.chip:has(.chip-sub){align-items:flex-start}
.chip:has(.chip-sub) .box{margin-top:2px}
.chip .chip-name{display:block;font-size:14.5px;color:var(--ink);line-height:1.3}
.chip .chip-sub{display:block;font-size:12px;color:var(--soft);line-height:1.42;margin-top:3px}
/* tier picker — reuses the site's .svc-grid / .card markup, made selectable
   and stacked full-width so each plan stays readable inside the form */
.q-fieldhint{font-size:12.5px;color:var(--soft);line-height:1.55;margin:0 0 18px}
.tier-fieldset .svc-grid{grid-template-columns:1fr;gap:16px;margin-top:0}
.tier-fieldset label.card{cursor:pointer;scroll-margin-top:90px}
.tier-fieldset label.card .tier{display:block}
.tier-fieldset label.card:hover{transform:none;box-shadow:none;border-color:var(--accent)}
.tier-fieldset label.card:focus-within{box-shadow:0 0 0 3px rgba(196,145,58,.25)}
.tier-fieldset label.card:has(input:checked){border-color:var(--accent);box-shadow:0 0 0 2px var(--accent);background:rgba(196,145,58,.045)}
.tier-fieldset label.card::after{content:"";position:absolute;top:18px;right:18px;width:24px;height:24px;border-radius:50%;border:1.5px solid var(--hairline);transition:all .2s}
.tier-fieldset label.card:has(input:checked)::after{content:"✓";border-color:var(--accent);background:var(--accent);color:#fff;display:grid;place-items:center;font-size:13px;font-weight:700}
@media(min-width:861px){.tier-fieldset .svc-grid .card .cdesc{min-height:0}}

/* nav buttons */
.q-nav{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:30px;
  padding-top:22px;border-top:1px solid var(--hairline)}
.q-nav .time-note{font-size:12.5px;color:var(--soft);font-style:italic}
.btn-back{background:transparent;border:none;color:var(--muted);font-family:var(--font-ui);font-size:14px;
  font-weight:600;cursor:pointer;padding:10px 6px;display:inline-flex;align-items:center;gap:7px;transition:color .2s}
.btn-back:hover{color:var(--navy)}
.btn-back[disabled]{opacity:0;pointer-events:none}

/* success */
.q-success{display:none;text-align:center;padding:30px 10px}
.q-success.active{display:block;animation:qfade .5s ease}
.q-success .seal{width:72px;height:72px;border-radius:50%;background:var(--navy);display:grid;place-items:center;margin:0 auto 22px}
.q-success .seal span{font-family:var(--font-display);font-size:36px;color:var(--brass)}
.q-success h2{font-family:var(--font-display);font-size:30px;color:var(--navy);font-weight:400;margin-bottom:12px}
.q-success p{font-size:16px;color:var(--muted);line-height:1.7;max-width:440px;margin:0 auto 8px}
.q-summary{background:var(--sand);border:1px solid var(--sand-dark);border-radius:var(--radius);
  padding:20px 24px;max-width:420px;margin:24px auto 0;text-align:left}
.q-summary .sr{display:flex;flex-direction:column;gap:3px;font-size:14px;padding:9px 0}
.q-summary .sr+.sr{border-top:1px solid var(--sand-dark)}
.q-summary .sr .k{color:var(--soft);font-size:10.5px;font-weight:700;letter-spacing:.7px;text-transform:uppercase}
.q-summary .sr .v{color:var(--navy);font-weight:600}

/* ---- production lock (Harbour) ---- */
:root{--topbar-h:0px}
.hero{--hero-h:620px}

/* ---------- legal / privacy content ---------- */
.legal{max-width:740px;margin:0 auto}
.legal .updated{font-family:var(--font-mono);font-size:11.5px;letter-spacing:1px;color:var(--soft);margin-bottom:30px;text-transform:uppercase}
.legal h2{font-family:var(--font-display);font-size:24px;color:var(--navy);margin:38px 0 12px;font-weight:400}
.legal h2:first-of-type{margin-top:0}
.legal p{font-size:16px;line-height:1.78;color:var(--muted);margin:0 0 16px}
.legal ul{margin:0 0 16px;padding-left:22px}
.legal li{font-size:16px;line-height:1.75;color:var(--muted);margin-bottom:8px}
.legal li::marker{color:var(--accent)}
.legal a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px}
.legal a:hover{color:var(--navy)}
/* 404 */
.nf{min-height:80vh;display:flex;align-items:center;justify-content:center;text-align:center;
  padding:200px 24px 150px;background:linear-gradient(165deg,var(--cream) 0%,var(--sand) 52%,#F8F0E3 100%);position:relative;overflow:hidden}
.nf .grid-bg{position:absolute;inset:0;opacity:.05;background-image:linear-gradient(var(--navy) 1px,transparent 1px),linear-gradient(90deg,var(--navy) 1px,transparent 1px);background-size:64px 64px;mask-image:radial-gradient(ellipse 80% 80% at 50% 40%,#000,transparent 78%)}
.nf .inner-nf{max-width:580px;margin:0 auto;position:relative;z-index:2}
.nf .amp{font-family:var(--font-display);font-size:78px;line-height:1;color:var(--brass);margin-bottom:10px}
.nf .code{font-family:var(--font-mono);font-size:12.5px;letter-spacing:3px;text-transform:uppercase;color:var(--accent-deep);margin-bottom:18px}
.nf h1{font-family:var(--font-display);font-weight:400;font-size:clamp(32px,5vw,46px);line-height:1.14;color:var(--navy);margin:0 0 18px}
.nf p{font-size:18px;line-height:1.7;color:var(--muted);margin:0 0 34px}


/* FAQ */
.faq{max-width:820px;margin:42px auto 0;border-top:1px solid var(--sand-dark)}
.faq-item{border-bottom:1px solid var(--sand-dark)}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;
  font-family:var(--font-display);font-size:clamp(19px,2.1vw,23px);color:var(--navy);font-weight:400;
  padding:24px 48px 24px 0;position:relative;display:block;line-height:1.32;transition:color .2s;letter-spacing:-.2px}
.faq-q:hover{color:var(--accent-deep)}
.faq-ic{position:absolute;right:4px;top:32px;width:16px;height:16px}
.faq-ic::before,.faq-ic::after{content:"";position:absolute;background:var(--accent-deep);border-radius:2px;transition:transform .3s cubic-bezier(.4,0,.2,1),opacity .3s ease}
.faq-ic::before{left:0;right:0;top:7px;height:2px}
.faq-ic::after{top:0;bottom:0;left:7px;width:2px}
.faq-q[aria-expanded="true"]{color:var(--accent-deep)}
.faq-q[aria-expanded="true"] .faq-ic::after{transform:scaleY(0);opacity:0}
.faq-a{max-height:0;overflow:hidden;transition:max-height .42s cubic-bezier(.4,0,.2,1)}
.faq-a-inner{padding:0 56px 26px 0}
.faq-a-inner p{font-size:16px;line-height:1.74;color:var(--muted);margin:0;text-wrap:pretty}
.faq-a-inner p + p{margin-top:1.1em}
.faq-a-inner a{color:var(--accent-deep);text-decoration:underline;text-underline-offset:2px;font-weight:500}
.faq-a-inner a:hover{color:var(--navy)}
@media(max-width:560px){.faq-q{font-size:18px;padding-right:40px}.faq-ic{top:30px}}

/* FAQ on navy (blends into the navy Contact + footer) */
.faq-navy .faq{border-top-color:rgba(255,255,255,.16)}
.faq-navy .faq-item{border-bottom-color:rgba(255,255,255,.16)}
.faq-navy .faq-q{color:#fff}
.faq-navy .faq-q:hover,.faq-navy .faq-q[aria-expanded="true"]{color:var(--brass)}
.faq-navy .faq-ic::before,.faq-navy .faq-ic::after{background:var(--brass)}
.faq-navy .faq-a-inner p{color:rgba(255,255,255,.66)}
.faq-navy .faq-a-inner a{color:var(--brass)}
.faq-navy .faq-a-inner a:hover{color:#fff}

/* principal portrait — clean rounded card */
.prin-photo{flex:1 1 auto;background:#0a0e12;border-radius:14px;overflow:hidden}
.prin-photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 22%}

/* philosophy lead (now the heading of the contact panel) */
.phil-tick{width:42px;height:2px;background:var(--brass);opacity:.65;margin:0 auto 28px}
.phil-line{font-family:var(--font-display);font-size:clamp(26px,3.6vw,42px);line-height:1.24;color:#fff;letter-spacing:-.5px;margin:0 0 20px;text-wrap:balance;text-shadow:0 2px 20px rgba(9,24,38,.5)}
.phil-close{font-family:var(--font-display);font-style:italic;font-size:clamp(18px,2.1vw,25px);color:var(--brass);margin:0;text-shadow:0 1px 14px rgba(9,24,38,.5)}
.book{padding:92px 24px 104px}
.book .amp{margin:0 0 18px}
.book .phil-close{margin-bottom:34px}
/* nav CTA: hidden over the hero, appears once the nav compacts on scroll */
nav:not(.scrolled) .navcta{display:none}