/* =========================================================
   KODIE — shared site chrome (nav, footer, sections, prose)
   ========================================================= */

body{background:var(--paper);}
.wrap{max-width:1200px;margin:0 auto;padding:0 40px;}
section{position:relative;}

/* ---------- NAV ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(245,247,247,.82);backdrop-filter:blur(12px);border-bottom:1px solid transparent;transition:.2s;}
.nav.scrolled{border-bottom-color:var(--line);box-shadow:var(--sh-sm);}
.nav .row{display:flex;align-items:center;justify-content:space-between;height:74px;}
.nav .brand-link{text-decoration:none;display:inline-flex;}
.nav .links{display:flex;align-items:center;gap:30px;}
.nav .links a{font-family:var(--display);font-weight:500;font-size:15px;color:var(--ink-700);text-decoration:none;transition:.14s;white-space:nowrap;}
.nav .links a:hover{color:var(--teal-700);}
.nav .links a.active{color:var(--teal-700);}
.nav .links a.btn-primary{color:#fff;}
.nav .links a.btn-primary:hover{color:#fff;}
/* Home: navy nav continuing the dark hero, reverts to light bar once scrolled */
.home .nav:not(.scrolled){background:var(--ink-900);backdrop-filter:none;border-bottom-color:transparent;}
.home .nav:not(.scrolled) .wordmark{color:#fff;}
.home .nav:not(.scrolled) .links a:not(.btn){color:#fff;}
.home .nav:not(.scrolled) .links a:not(.btn):hover{color:var(--teal-400);}

/* ---------- PAGE HERO (inner pages) ---------- */
.page-hero{padding:78px 0 26px;}
.page-hero .eyebrow{display:block;margin-bottom:16px;}
.page-hero h1{font-family:var(--display);font-weight:600;font-size:clamp(38px,4.6vw,58px);line-height:1.04;letter-spacing:-.03em;color:var(--ink-900);margin:0 0 18px;text-wrap:balance;max-width:760px;}
.page-hero .intro{font-size:19.5px;line-height:1.6;color:var(--ink-700);max-width:620px;}

/* ---------- SECTIONS ---------- */
.sec{padding:88px 0;}
.sec.tight{padding:56px 0;}
.sec.dark{background:var(--ink-900);color:#fff;}
.sec.warm{background:var(--paper-warm);}
.sec-title{font-family:var(--display);font-weight:600;font-size:clamp(30px,3.6vw,44px);line-height:1.08;letter-spacing:-.025em;color:var(--ink-900);margin:0;text-wrap:balance;}
.sec.dark .sec-title{color:#fff;}
.sec-intro{font-size:18px;line-height:1.6;color:var(--ink-700);max-width:580px;}
.sec.dark .sec-intro{color:#AFC3C8;}
.eyebrow.center{display:block;text-align:center;margin-bottom:16px;}
.center{text-align:center;}
.center .sec-intro{margin-left:auto;margin-right:auto;}

/* ---------- FINAL CTA BAND ---------- */
.finalcta{background:var(--ink-900);color:#fff;border-radius:var(--r-xl);padding:68px 60px;text-align:center;position:relative;overflow:hidden;}
.finalcta .dotfield{position:absolute;inset:0;opacity:.5;background-image:radial-gradient(var(--teal-700) 1.4px,transparent 1.4px);background-size:26px 26px;-webkit-mask-image:radial-gradient(120% 90% at 50% 0%,#000,transparent 70%);mask-image:radial-gradient(120% 90% at 50% 0%,#000,transparent 70%);}
.finalcta>*{position:relative;}
.finalcta h2{font-family:var(--display);font-weight:600;font-size:clamp(30px,3.8vw,44px);letter-spacing:-.025em;margin:0 0 16px;color:#fff;text-wrap:balance;}
.finalcta p{color:#C9D7DA;font-size:18px;max-width:480px;margin:0 auto 32px;}

/* ---------- FOOTER ---------- */
footer{padding:60px 0 50px;}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-start;gap:40px;flex-wrap:wrap;}
.foot-grid .links{display:flex;gap:60px;flex-wrap:wrap;}
.foot-col h4{font-family:var(--display);font-weight:600;font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:var(--faint);margin:0 0 14px;}
.foot-col a{display:block;font-size:14.5px;color:var(--ink-700);text-decoration:none;margin-bottom:9px;transition:.14s;}
.foot-col a:hover{color:var(--teal-700);}
.foot-bottom{margin-top:46px;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;font-size:13px;color:var(--faint);}
.foot-bottom a{color:var(--faint);text-decoration:none;}

/* ---------- REVEAL (enhancement only) ---------- */
.rv{opacity:1;transform:none;}
html.js-anim .rv{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease;}
html.js-anim .rv.in{opacity:1;transform:none;}
@media (prefers-reduced-motion: reduce){html.js-anim .rv{opacity:1;transform:none;transition:none;}}

/* ---------- POST / CARD GRIDS (blog + case studies) ---------- */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.post{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);box-shadow:var(--sh-sm);overflow:hidden;display:flex;flex-direction:column;text-decoration:none;transition:.18s;}
.post:hover{box-shadow:var(--sh-md);transform:translateY(-3px);border-color:var(--teal-100);}
.post .thumb{aspect-ratio:16/9;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.post .body{padding:24px 26px 26px;display:flex;flex-direction:column;gap:10px;flex:1;}
.post h3{margin:0;font-size:19px;line-height:1.3;color:var(--ink-900);}
.post p{margin:0;font-size:14.5px;line-height:1.55;color:var(--muted);flex:1;}
.post .meta{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--faint);margin-top:4px;}
.post .meta span{white-space:nowrap;}
.post .meta .pill{font-size:11.5px;padding:3px 10px;}

/* decorative thumb patterns */
.thumb.t-teal{background:var(--teal-600);}
.thumb.t-ink{background:var(--ink-900);}
.thumb.t-sand{background:var(--amber-soft);}
.thumb.t-mist{background:var(--teal-50);}
.thumb .glyph{width:64px;height:64px;color:rgba(255,255,255,.9);}
.thumb.t-sand .glyph{color:#9A6B22;}
.thumb.t-mist .glyph{color:var(--teal-700);}
.thumb .glyph svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.thumb .dots{position:absolute;inset:0;opacity:.35;background-image:radial-gradient(rgba(255,255,255,.5) 1.2px,transparent 1.2px);background-size:18px 18px;-webkit-mask-image:radial-gradient(110% 90% at 85% 10%,#000,transparent 60%);mask-image:radial-gradient(110% 90% at 85% 10%,#000,transparent 60%);}
.thumb.t-sand .dots,.thumb.t-mist .dots{background-image:radial-gradient(rgba(0,0,0,.22) 1.2px,transparent 1.2px);}

/* ---------- ARTICLE PROSE ---------- */
.prose{max-width:680px;font-size:17.5px;line-height:1.75;color:var(--ink-700);}
.prose p{margin:0 0 1.45em;}
.prose h2{font-family:var(--display);font-weight:600;font-size:27px;letter-spacing:-.015em;color:var(--ink-900);margin:2em 0 .7em;}
.prose h3{font-family:var(--display);font-weight:600;font-size:21px;color:var(--ink-900);margin:1.8em 0 .6em;}
.prose ul{margin:0 0 1.45em;padding-left:1.2em;}
.prose li{margin-bottom:.5em;}
.prose li::marker{color:var(--teal-500);}
.prose strong{color:var(--ink-800);}
.prose blockquote{margin:2em 0;padding:6px 0 6px 26px;border-left:3px solid var(--teal-400);font-family:var(--display);font-weight:500;font-size:21px;line-height:1.5;color:var(--ink-800);font-style:normal;}
.prose .aside{background:var(--teal-50);border:1px solid var(--teal-100);border-radius:var(--r-md);padding:22px 24px;font-size:15.5px;margin:2em 0;}
.article-meta{display:flex;align-items:center;gap:12px;font-size:14px;color:var(--muted);flex-wrap:wrap;}
.article-meta span{white-space:nowrap;}
.article-meta .sep{color:var(--line);}

/* inline CTA box inside articles */
.prose-cta{background:var(--ink-900);border-radius:var(--r-lg);padding:30px 32px;margin:2.4em 0;color:#fff;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;}
.prose-cta .t{font-family:var(--display);font-weight:600;font-size:19px;color:#fff;max-width:340px;line-height:1.35;}
.prose-cta .s{font-size:14px;color:#AFC3C8;margin-top:6px;}

/* ---------- FAQ ---------- */
.faq{max-width:760px;}
.faq details{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-md);box-shadow:var(--sh-sm);margin-bottom:12px;overflow:hidden;}
.faq summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;font-family:var(--display);font-weight:600;font-size:17px;color:var(--ink-800);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";font-size:22px;color:var(--teal-600);font-weight:500;flex:none;transition:.2s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq .a{padding:0 24px 22px;font-size:15.5px;line-height:1.65;color:var(--ink-700);max-width:640px;}

/* ---------- MISC ---------- */
.crumb{font-size:14px;color:var(--muted);display:flex;align-items:center;gap:8px;white-space:nowrap;}
.crumb a{color:var(--teal-700);text-decoration:none;font-weight:600;}
.placeholder-note{font-size:12.5px;color:var(--faint);font-style:italic;}

/* ---------- Landing pages (commercial) ---------- */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center;}
.split-img{width:100%;height:auto;display:block;border-radius:var(--r-xl);box-shadow:var(--sh-md);}
.split.rev .split-text{order:2;}
.lp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:42px;}
.lp-grid.two{grid-template-columns:repeat(2,1fr);}
.lp-card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r-lg);padding:28px;box-shadow:var(--sh-sm);}
.lp-card .ic{width:46px;height:46px;border-radius:12px;background:var(--teal-50);color:var(--teal-700);display:flex;align-items:center;justify-content:center;margin-bottom:16px;}
.lp-card .ic .icon{width:23px;height:23px;}
.lp-card h3{margin:0 0 8px;font-size:18px;}
.lp-card p{margin:0;font-size:15px;color:var(--ink-700);line-height:1.6;}
.lp-list{margin:20px 0 0;padding-left:1.25em;}
.lp-list li{margin-bottom:.55em;font-size:16.5px;line-height:1.55;color:var(--ink-700);}
.lp-list li::marker{color:var(--teal-500);}
.lp-cta{background:var(--ink-900);color:#fff;border-radius:var(--r-xl);padding:64px 56px;text-align:center;}
.lp-cta h2{font-family:var(--display);font-weight:600;font-size:clamp(28px,3.6vw,40px);letter-spacing:-.025em;margin:0 0 14px;color:#fff;text-wrap:balance;}
.lp-cta p{color:#C9D7DA;font-size:17px;max-width:480px;margin:0 auto 28px;}

@media(max-width:900px){
  .wrap{padding:0 24px;}
  .nav .links a:not(.btn){display:none;}
  .post-grid{grid-template-columns:1fr;}
  .page-hero{padding:56px 0 20px;}
  .lp-grid,.lp-grid.two{grid-template-columns:1fr;}
  .split{grid-template-columns:1fr;gap:30px;}
  .split.rev .split-text{order:0;}
}
