/* ===========================================================================
   COMPASS · by Collins Tech — Refined editorial system
   =========================================================================== */
@import url('https://api.fontshare.com/v2/css?f[]=general-sans@400,500,600,700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

:root{
  --paper:#FBFAF7; --paper-2:#F4F1EA; --ink:#1A1A1A; --ink-soft:#2A2A28;
  --stone:#6B6760; --stone-2:#8A857C; --sage:#5C7A5A; --sage-deep:#4A6549; --ochre:#B8863B;
  --line:rgba(26,26,26,.13); --line-soft:rgba(26,26,26,.08);
  --serif:'General Sans',system-ui,sans-serif; --body:'Inter',system-ui,sans-serif;
  --wrap:1140px; --narrow:780px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--body);background:var(--paper);color:var(--ink);font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{display:block;max-width:100%}
a{color:var(--ink);text-decoration:none}
::selection{background:var(--sage);color:var(--paper)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:600;letter-spacing:-.03em;line-height:1.04}
h1{font-size:clamp(46px,6.2vw,84px)}
h2{font-size:clamp(32px,4vw,52px)}
h3{font-size:clamp(24px,2.4vw,30px);letter-spacing:-.02em}
.it{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--sage)}

.wrap{max-width:var(--wrap);margin:0 auto;padding:0 40px}
.narrow{max-width:var(--narrow);margin:0 auto;padding:0 40px}
section{padding:clamp(72px,9vw,120px) 0}
.kicker{font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--ochre);font-weight:600}
.lead{font-size:clamp(18px,1.7vw,21px);line-height:1.55;color:var(--stone)}
.note{font-size:13px;color:var(--stone)}
.muted{color:var(--stone)}
.center{text-align:center}
.tint{background:var(--paper-2)}
hr.rule{border:none;border-top:1px solid var(--line)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--body);font-weight:600;font-size:15px;padding:13px 24px;border:1px solid var(--ink);border-radius:2px;cursor:pointer;transition:background .15s,color .15s,transform .15s}
.btn-f{background:var(--ink);color:var(--paper)}
.btn-f:hover{background:#000;transform:translateY(-1px)}
.btn-o{background:transparent;color:var(--ink)}
.btn-o:hover{background:var(--ink);color:var(--paper)}
.btn-lg{padding:16px 30px;font-size:16px}
.link{display:inline-flex;align-items:center;gap:8px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--ink);padding-bottom:2px}
.link .arr{transition:transform .2s}.link:hover .arr{transform:translateX(4px)}

/* nav */
.nav{position:sticky;top:0;z-index:60;background:rgba(251,250,247,.85);backdrop-filter:saturate(140%) blur(12px);-webkit-backdrop-filter:saturate(140%) blur(12px);border-bottom:1px solid transparent;transition:border-color .2s}
.nav.scrolled{border-bottom-color:var(--line)}
.nav-in{display:flex;align-items:center;gap:34px;max-width:var(--wrap);margin:0 auto;padding:24px 40px}
.logo{font-family:var(--serif);font-weight:600;font-size:22px;letter-spacing:-.02em;line-height:1}
.logo span{display:block;font-family:var(--body);font-size:10.5px;font-weight:500;color:var(--stone);letter-spacing:.06em;margin-top:4px}
.links{display:flex;gap:30px;margin-left:auto;font-size:14.5px;font-weight:500}
.links a{opacity:.78;transition:opacity .15s}.links a:hover{opacity:1}
.burger{display:none;background:none;border:none;cursor:pointer;padding:6px;margin-left:auto}
.burger svg{width:26px;height:26px;stroke:var(--ink)}
@media(max-width:840px){
  .links{position:absolute;top:100%;left:0;right:0;flex-direction:column;align-items:stretch;gap:0;background:var(--paper);border-bottom:1px solid var(--line);padding:6px 40px 16px;display:none}
  .nav.open .links{display:flex}
  .links a{padding:14px 0;border-bottom:1px solid var(--line-soft);font-size:16px;opacity:1}
  .links a:last-child{border-bottom:none}
  .burger{display:block;order:3}
  .nav .nav-cta{order:2;margin-left:auto}
}

/* hero (home) */
.hero{padding:clamp(64px,8vw,104px) 0 clamp(56px,6vw,80px)}
.hero .kicker{display:block;margin-bottom:28px}
.hero h1{max-width:1000px}
.under{display:grid;grid-template-columns:1fr 1fr;gap:60px;margin-top:48px;align-items:end}
.under .lead{max-width:460px}
.under .act{display:flex;gap:14px;justify-content:flex-end;flex-wrap:wrap}
.under .note{text-align:right;margin-top:14px}
@media(max-width:840px){.under{grid-template-columns:1fr;gap:28px}.under .act,.under .note{justify-content:flex-start;text-align:left}}

/* figure (treated photography) */
.fig{border-radius:3px;overflow:hidden;position:relative;aspect-ratio:21/9}
.fig img{width:100%;height:100%;object-fit:cover;filter:grayscale(1) contrast(1.05) brightness(.98)}
.fig::after{content:"";position:absolute;inset:0;background:rgba(92,122,90,.26);mix-blend-mode:multiply}
.fig.tall{aspect-ratio:4/5}
.cap{font-size:13px;color:var(--stone);margin-top:12px;font-style:italic}

/* index rows (offerings overview) */
.idx .lead-row{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;margin-bottom:54px}
.idx .lead-row p{align-self:center}
.row{display:grid;grid-template-columns:56px 1.1fr 1.5fr auto;gap:36px;align-items:start;padding:36px 0;border-top:1px solid var(--line);text-decoration:none;color:var(--ink);transition:padding-left .2s}
.row:last-of-type{border-bottom:1px solid var(--line)}
.row:hover{padding-left:8px}
.row .no{font-family:var(--serif);font-weight:500;font-size:22px;color:var(--ochre)}
.row h3{margin-bottom:8px}
.row .tag{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--stone)}
.row .desc{color:var(--stone);font-size:16px}
.row .desc b{color:var(--ink);font-weight:600}
.row .arr{font-size:22px}
@media(max-width:840px){.idx .lead-row{grid-template-columns:1fr;gap:18px}.row{grid-template-columns:36px 1fr;gap:8px 20px}.row .desc{grid-column:1/-1}.row .arr{display:none}}

/* editorial stat figures */
.figrow{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.figitem{padding:40px 32px 8px;border-right:1px solid var(--line)}
.figitem:last-child{border-right:none}
.figitem .n{font-family:var(--serif);font-weight:600;font-size:64px;line-height:1;letter-spacing:-.03em}
.figitem .n.sage{color:var(--sage)}.figitem .n.ochre{color:var(--ochre)}
.figitem .l{font-size:15px;color:var(--ink);margin-top:16px;line-height:1.5}
.figitem .s{font-size:12px;color:var(--stone-2);margin-top:14px}
@media(max-width:840px){.figrow{grid-template-columns:1fr}.figitem{border-right:none;border-bottom:1px solid var(--line)}}

/* prose */
.prose{max-width:720px}
.prose>p{font-size:18px;line-height:1.78;margin-bottom:22px}
.prose>p.muted{color:var(--stone)}
.prose h3{margin:44px 0 14px}.prose h3:first-child{margin-top:0}
.prose .pull{font-family:var(--serif);font-weight:500;font-size:clamp(24px,2.8vw,32px);line-height:1.28;letter-spacing:-.02em;padding:8px 0 8px 26px;border-left:2px solid var(--sage);margin:38px 0}
.prose .pull em{font-style:italic;color:var(--sage)}

/* offering detail (what we do) */
.offer{padding:clamp(56px,6vw,84px) 0;border-top:1px solid var(--line);scroll-margin-top:90px}
.offer-head{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:baseline;margin-bottom:28px}
.offer-head .no{font-family:var(--serif);font-weight:500;font-size:30px;color:var(--ochre)}
.offer-head .tag{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-bottom:8px}
.offer .body{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.offer .body>p{font-size:18px;color:var(--stone);line-height:1.7}
.deliver{list-style:none}
.deliver .dh{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--ink);margin-bottom:8px}
.deliver li{position:relative;padding:13px 0 13px 26px;border-top:1px solid var(--line-soft);font-size:15.5px}
.deliver li:first-of-type{border-top:none}
.deliver li::before{content:"";position:absolute;left:0;top:20px;width:7px;height:7px;background:var(--sage);transform:rotate(45deg)}
@media(max-width:840px){.offer .body{grid-template-columns:1fr;gap:30px}.offer-head{grid-template-columns:1fr;gap:6px}}

/* resources list */
.reslist{border-top:1px solid var(--line)}
.resrow{display:grid;grid-template-columns:1.2fr 1.6fr auto;gap:36px;align-items:center;padding:30px 0;border-bottom:1px solid var(--line);color:var(--ink)}
.resrow:hover{padding-left:8px;transition:padding-left .2s}
.resrow .tag{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ochre);margin-bottom:8px}
.resrow h3{font-size:24px}
.resrow p{color:var(--stone);font-size:15.5px}
.resrow .arr{font-size:20px}
@media(max-width:840px){.resrow{grid-template-columns:1fr;gap:8px}.resrow .arr{display:none}}

/* big quote */
.quote{text-align:center}
.quote p{font-family:var(--serif);font-weight:500;font-size:clamp(28px,3.6vw,42px);line-height:1.22;letter-spacing:-.02em;max-width:900px;margin:0 auto}
.quote p em{font-style:italic;color:var(--sage)}
.quote .who{margin-top:30px;font-size:14px;color:var(--stone)}
.quote .who b{color:var(--ink);font-weight:600;font-family:var(--body)}

/* page hero (sub-pages) */
.phero{padding:clamp(56px,7vw,96px) 0 clamp(40px,5vw,64px);border-bottom:1px solid var(--line)}
.phero .crumb{font-size:13px;color:var(--stone);margin-bottom:22px}
.phero .crumb a{color:var(--stone)}.phero .crumb span{margin:0 8px;color:var(--line)}
.phero .kicker{display:block;margin-bottom:20px}
.phero h1{font-size:clamp(42px,5.4vw,72px);margin-bottom:20px}
.phero .lead{max-width:680px}

/* form */
.cwrap{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start}
.cform{border:1px solid var(--line);border-radius:3px;padding:36px 34px;background:var(--paper)}
.fld{margin-bottom:20px}.fld label{display:block;font-size:14px;font-weight:600;margin-bottom:7px}
.fld .opt{color:var(--stone);font-weight:400}
.fld input,.fld textarea{width:100%;font-family:var(--body);font-size:16px;background:var(--paper);border:1px solid var(--line);border-radius:2px;padding:13px 14px;transition:border-color .15s}
.fld input:focus,.fld textarea:focus{outline:none;border-color:var(--sage);box-shadow:0 0 0 3px rgba(92,122,90,.14)}
.fld textarea{resize:vertical;min-height:120px}
.cform .btn{width:100%;justify-content:center}.cform .note{margin-top:14px;text-align:center}
.csuccess{display:none;border:1px solid var(--sage);background:rgba(92,122,90,.07);border-radius:3px;padding:28px;text-align:center}
.csuccess h3{margin-bottom:10px}.cform.sent .cfields{display:none}.cform.sent .csuccess{display:block}
.aside h3{margin-bottom:20px}
.expect{list-style:none}.expect li{display:flex;gap:16px;padding:18px 0;border-top:1px solid var(--line-soft)}
.expect li:first-child{border-top:none}
.expect .n{flex-shrink:0;width:30px;height:30px;border:1px solid var(--ochre);color:var(--ochre);font-family:var(--serif);font-weight:600;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:50%}
.expect b{display:block;margin-bottom:3px}.expect span{color:var(--stone);font-size:15px}
@media(max-width:840px){.cwrap{grid-template-columns:1fr;gap:36px}}

/* faq */
.faq{max-width:780px}
.faq details{border-top:1px solid var(--line)}.faq details:last-child{border-bottom:1px solid var(--line)}
.faq summary{cursor:pointer;list-style:none;padding:24px 44px 24px 0;position:relative;font-family:var(--serif);font-weight:600;font-size:20px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";position:absolute;right:4px;top:50%;transform:translateY(-50%);font-size:26px;font-weight:400;color:var(--ochre)}
.faq details[open] summary::after{content:"–"}
.faq details>p{color:var(--stone);line-height:1.7;padding:0 44px 26px 0}

/* footer */
.footer{border-top:1px solid var(--line);padding:72px 0 40px}
.fgrid{display:grid;grid-template-columns:2.2fr 1fr 1fr 1fr;gap:48px;margin-bottom:54px}
.fbrand p{color:var(--stone);font-size:15px;max-width:300px;margin:18px 0}
.badge{display:inline-flex;font-size:12px;font-weight:600;color:var(--sage-deep);border:1px solid var(--sage);border-radius:2px;padding:6px 13px}
.badge:hover{background:var(--sage);color:var(--paper)}
.fcol h5{font-size:12px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--stone);margin-bottom:16px;font-family:var(--body)}
.fcol ul{list-style:none}.fcol li{margin-bottom:11px}.fcol a{font-size:15px;color:var(--ink);opacity:.8}.fcol a:hover{opacity:1}
.fbot{border-top:1px solid var(--line);padding-top:24px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px}
.fbot p{font-size:13px;color:var(--stone)}
@media(max-width:840px){.fgrid{grid-template-columns:1fr 1fr;gap:32px}}
@media(max-width:520px){.fgrid{grid-template-columns:1fr}}

/* reveal */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.2,.7,.3,1),transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none}}
