/* ============================================================
   LOCUTION â€” GLOBAL STYLESHEET
   Loaded automatically by the Locution child theme (functions.php).
   Build pages with Custom HTML blocks wrapped in <div class="loc"> â€¦ </div>.
   ============================================================ */

/* ---- Fonts ---- */
/* Fonts enqueued by the theme â€” see functions.php */

/* ---- Tokens ---- */
:root{
  --paper:#EEEDE8; --paper-2:#E5E3DC; --ink:#191917; --ink-soft:#5B5953;
  --graphite:#403E38; --line:rgba(25,25,23,0.14); --line-soft:rgba(25,25,23,0.07);
}

/* ---- Base ---- */
.loc *{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:130px}
body{background:var(--paper);color:var(--ink);font-family:'Hanken Grotesk',sans-serif;
  font-weight:400;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
/* Break the page content out of the block theme's narrow content column */
.loc{width:100vw;max-width:100vw;margin-left:calc(50% - 50vw);margin-right:calc(50% - 50vw)}
.loc .wrap,.loc-nav .wrap,.loc-footer .wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.loc .narrow{max-width:1000px}
.loc .kicker{font-family:'JetBrains Mono',monospace;font-size:11.5px;letter-spacing:0.22em;
  text-transform:uppercase;color:var(--graphite);font-weight:500}

/* ---- Nav (Header template part) ---- */
.loc-nav{position:fixed;top:0;left:0;right:0;z-index:100;backdrop-filter:blur(8px);
  background:rgba(238,237,232,0.72);border-bottom:1px solid transparent;
  transition:border-color .4s ease,background .4s ease}
.loc-nav.scrolled{border-bottom:1px solid var(--line);background:rgba(238,237,232,0.92)}
.loc-nav .nav-inner{display:flex;align-items:center;justify-content:space-between;
  min-height:96px;padding-top:20px;padding-bottom:20px}
/* Don't let the WP admin toolbar cover the nav when logged in */
.admin-bar .loc-nav{top:32px}
@media screen and (max-width:782px){.admin-bar .loc-nav{top:46px}}
.loc-nav .nav-logo{height:84px;width:auto;display:block}
.loc-nav .nav-links{display:flex;align-items:center;gap:38px}
.loc-nav .nav-links a{text-decoration:none;color:var(--ink-soft);font-size:14.5px;
  transition:color .2s ease;position:relative}
.loc-nav .nav-links a:hover{color:var(--ink)}
.loc-nav .nav-links a.active{color:var(--ink)}
.loc-nav .nav-links a.active::after{content:"";position:absolute;left:0;right:0;bottom:-10px;
  height:2px;background:var(--ink)}
.loc-nav .nav-cta{border:1px solid var(--ink);border-radius:100px;padding:9px 20px !important;
  color:var(--ink) !important;transition:all .25s ease}
.loc-nav .nav-cta:hover{background:var(--ink);color:var(--paper) !important}
.loc-nav .nav-cta.active::after{display:none}
@media(max-width:760px){.loc-nav .nav-links a:not(.nav-cta){display:none}}

/* ---- Buttons ---- */
.loc .btn-primary{background:var(--ink);color:var(--paper);text-decoration:none;font-size:15px;
  font-weight:500;padding:15px 28px;border-radius:100px;display:inline-flex;align-items:center;
  gap:10px;transition:all .25s ease}
.loc .btn-primary:hover{background:#000;transform:translateY(-1px);box-shadow:0 10px 30px rgba(25,25,23,.22)}
.loc .btn-primary .arr{transition:transform .25s ease}
.loc .btn-primary:hover .arr{transform:translateX(4px)}
.loc .btn-text{color:var(--ink);text-decoration:none;font-size:15px;font-weight:500;
  border-bottom:1px solid var(--line);padding-bottom:3px;transition:border-color .25s}
.loc .btn-text:hover{border-color:var(--ink)}

/* ---- Hero (Home) ---- */
.loc .hero{padding:172px 0 110px;position:relative}
.loc .hero-grid{display:grid;grid-template-columns:1.05fr 0.95fr;gap:60px;align-items:center}
.loc .hero-copy .kicker{display:block;margin-bottom:28px;opacity:0;animation:rise .9s .1s forwards}
.loc .hero h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(40px,5vw,68px);
  line-height:1.04;letter-spacing:-0.02em;font-variation-settings:'opsz' 144;margin-bottom:30px}
.loc .hero h1 .em{font-style:italic}
.loc .hero h1 span{display:inline-block;opacity:0;animation:rise 1s forwards}
.loc .hero p.lead{font-size:19px;color:var(--ink-soft);max-width:480px;line-height:1.65;
  margin-bottom:38px;opacity:0;animation:rise 1s .55s forwards}
.loc .hero-actions{display:flex;gap:18px;align-items:center;opacity:0;animation:rise 1s .7s forwards}

/* ---- Authority graph (Home hero) ---- */
.loc .graph-stage{position:relative;height:440px;opacity:0;animation:fade 1.4s .4s forwards}
.loc .graph-stage svg{width:100%;height:100%;overflow:visible}
.loc .gline{stroke:var(--line);stroke-width:1;fill:none;stroke-dasharray:240;stroke-dashoffset:240;
  animation:draw 1.6s ease forwards}
.loc .node-label{font-family:'JetBrains Mono',monospace;font-size:10.5px;letter-spacing:0.08em;
  fill:var(--ink-soft);text-transform:uppercase}
.loc .node-dot{fill:var(--paper);stroke:var(--ink);stroke-width:1.4}
.loc .node-sat{opacity:0;animation:pop .5s forwards}
.loc .core circle.ring{fill:none;stroke:var(--ink);stroke-width:1.3;opacity:.3;
  transform-origin:center;transform-box:fill-box;animation:pulse 3.6s ease-in-out infinite}
.loc .core circle.ring2{fill:none;stroke:var(--ink);stroke-width:1;opacity:.18;
  transform-origin:center;transform-box:fill-box;animation:pulse 3.6s ease-in-out infinite 1.2s}
.loc .core circle.fill{fill:var(--ink)}
.loc .core text{font-family:'Fraunces',serif;font-size:13px;fill:var(--paper);font-style:italic}

/* ---- Insight (Home) ---- */
.loc .insight{padding:120px 0;border-top:1px solid var(--line-soft)}
.loc .insight .wrap{max-width:1000px}
.loc .insight .kicker{display:block;margin-bottom:36px}
.loc .insight blockquote{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(26px,3.3vw,40px);
  line-height:1.28;letter-spacing:-0.01em;font-variation-settings:'opsz' 144}
.loc .insight blockquote .hl{font-style:italic;text-decoration:underline;text-decoration-thickness:1px;
  text-underline-offset:6px;text-decoration-color:var(--line)}
.loc .insight .resolve{margin-top:34px;font-size:19px;color:var(--ink-soft);max-width:620px;line-height:1.6}

/* ---- What we build (Home) ---- */
.loc .build{padding:30px 0 130px}
.loc .build-head{max-width:560px;margin-bottom:70px}
.loc .build-head .kicker{display:block;margin-bottom:22px}
.loc .build-head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(30px,3.6vw,44px);
  line-height:1.12;letter-spacing:-0.02em;font-variation-settings:'opsz' 144}
.loc .layers{display:grid;grid-template-columns:1fr 1fr;gap:0}
.loc .layer{padding:38px 40px 38px 0;border-top:1px solid var(--line)}
.loc .layer:nth-child(odd){padding-right:60px}
.loc .layer:nth-child(even){padding-left:60px;border-left:1px solid var(--line)}
.loc .layer .num{font-family:'JetBrains Mono',monospace;font-size:12px;color:var(--graphite);
  letter-spacing:0.1em;margin-bottom:16px;display:block}
.loc .layer h3{font-family:'Fraunces',serif;font-weight:500;font-size:23px;margin-bottom:12px;
  letter-spacing:-0.01em;font-variation-settings:'opsz' 60}
.loc .layer p{font-size:15.5px;color:var(--ink-soft);line-height:1.6}
.loc .build-note{margin-top:54px;padding-top:34px;border-top:1px solid var(--line);
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:clamp(19px,2.2vw,25px);
  color:var(--ink);max-width:780px;line-height:1.4}
@media(max-width:760px){
  .loc .hero-grid{grid-template-columns:1fr;gap:30px}
  .loc .graph-stage{height:340px;order:-1}
  .loc .layers{grid-template-columns:1fr}
  .loc .layer:nth-child(even){padding-left:0;border-left:none}
  .loc .layer:nth-child(odd){padding-right:0}
}

/* ---- Page hero (interior pages) ---- */
.loc .phero{padding:158px 0 80px}
.loc .phero .kicker{display:block;margin-bottom:26px;opacity:0;animation:rise .8s .1s forwards}
.loc .phero h1{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(38px,5vw,64px);
  line-height:1.06;letter-spacing:-0.02em;font-variation-settings:'opsz' 144;max-width:14ch;
  opacity:0;animation:rise 1s .22s forwards}
.loc .phero h1 .em{font-style:italic}
.loc .phero p{font-size:19px;color:var(--ink-soft);max-width:560px;margin-top:30px;line-height:1.65;
  opacity:0;animation:rise 1s .42s forwards}

/* ---- The shift (Approach) ---- */
.loc .shift{padding:90px 0;border-top:1px solid var(--line-soft)}
.loc .shift .head{max-width:620px;margin-bottom:60px}
.loc .shift .kicker{display:block;margin-bottom:22px}
.loc .shift .head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,3.4vw,42px);
  line-height:1.14;letter-spacing:-0.02em;font-variation-settings:'opsz' 144}
.loc .shift .head h2 .em{font-style:italic}
.loc .cols{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line)}
.loc .col{padding:40px 48px 44px 0}
.loc .col:last-child{padding:40px 0 44px 48px;border-left:1px solid var(--line)}
.loc .col .tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;margin-bottom:20px;color:var(--graphite)}
.loc .col.old .tag{color:var(--ink-soft)}
.loc .col h3{font-family:'Fraunces',serif;font-weight:500;font-size:24px;margin-bottom:18px;
  letter-spacing:-0.01em;font-variation-settings:'opsz' 60}
.loc .col.old h3{color:var(--ink-soft)}
.loc .col ul{list-style:none}
.loc .col li{font-size:15.5px;color:var(--ink-soft);padding:11px 0;border-bottom:1px solid var(--line-soft);
  display:flex;gap:12px;align-items:flex-start}
.loc .col li::before{content:"â€”";color:var(--graphite);flex-shrink:0}
.loc .col.now li{color:var(--ink)}
@media(max-width:760px){.loc .cols{grid-template-columns:1fr}.loc .col{padding:36px 0 8px}
  .loc .col:last-child{padding:36px 0 8px;border-left:none;border-top:1px solid var(--line)}}

/* ---- Authority layers expanded (Approach) ---- */
.loc .layers-sec{padding:90px 0;background:var(--paper-2)}
.loc .layers-sec .head{max-width:640px;margin-bottom:64px}
.loc .layers-sec .kicker{display:block;margin-bottom:22px}
.loc .layers-sec .head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,3.4vw,42px);
  line-height:1.14;letter-spacing:-0.02em;font-variation-settings:'opsz' 144}
.loc .layer-row{display:grid;grid-template-columns:140px 1fr;gap:40px;padding:36px 0;
  border-top:1px solid var(--line);align-items:start}
.loc .layer-row:last-child{border-bottom:1px solid var(--line)}
.loc .layer-row .num{font-family:'Fraunces',serif;font-style:italic;font-size:40px;color:var(--ink);
  font-variation-settings:'opsz' 144;line-height:1}
.loc .layer-row .num small{font-family:'JetBrains Mono',monospace;font-style:normal;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--graphite);display:block;margin-top:10px}
.loc .layer-row h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;margin-bottom:12px;
  letter-spacing:-0.01em;font-variation-settings:'opsz' 60}
.loc .layer-row p{font-size:16px;color:var(--ink-soft);line-height:1.62;max-width:680px}
.loc .layer-row .ex{margin-top:14px;font-family:'JetBrains Mono',monospace;font-size:12px;
  color:var(--graphite);letter-spacing:.02em}
@media(max-width:760px){.loc .layer-row{grid-template-columns:1fr;gap:14px}.loc .layer-row .num{font-size:32px}}

/* ---- Process (Approach) ---- */
.loc .process{padding:96px 0}
.loc .process .head{max-width:600px;margin-bottom:70px}
.loc .process .kicker{display:block;margin-bottom:22px}
.loc .process .head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,3.4vw,42px);
  line-height:1.14;letter-spacing:-0.02em;font-variation-settings:'opsz' 144}
.loc .steps{position:relative;max-width:760px;margin-left:8px}
.loc .steps::before{content:"";position:absolute;left:13px;top:14px;bottom:14px;width:1px;background:var(--line)}
.loc .step{position:relative;padding:0 0 46px 56px}
.loc .step:last-child{padding-bottom:0}
.loc .step .dot{position:absolute;left:6px;top:4px;width:15px;height:15px;border-radius:50%;
  background:var(--paper);border:1.6px solid var(--ink)}
.loc .step .st{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--graphite);margin-bottom:8px}
.loc .step h3{font-family:'Fraunces',serif;font-weight:500;font-size:22px;margin-bottom:9px;
  letter-spacing:-0.01em;font-variation-settings:'opsz' 60}
.loc .step p{font-size:15.5px;color:var(--ink-soft);line-height:1.6;max-width:560px}

/* ---- Honest timeline (Approach) ---- */
.loc .truth{padding:90px 0;background:var(--paper-2);border-top:1px solid var(--line-soft)}
.loc .truth .head{max-width:640px;margin-bottom:60px}
.loc .truth .kicker{display:block;margin-bottom:22px}
.loc .truth .head h2{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(28px,3.4vw,42px);
  line-height:1.14;letter-spacing:-0.02em;font-variation-settings:'opsz' 144}
.loc .truth .head h2 .em{font-style:italic}
.loc .truth .head p{margin-top:20px;font-size:17px;color:var(--ink-soft);max-width:600px}
.loc .tl{display:grid;grid-template-columns:1fr 1fr 1fr;gap:0;position:relative;margin-top:20px}
.loc .tl::before{content:"";position:absolute;left:0;right:0;top:7px;height:1px;background:var(--line)}
.loc .phase{padding:30px 30px 0 0;position:relative}
.loc .phase:not(:first-child){padding-left:30px}
.loc .phase .pdot{position:absolute;top:1px;left:0;width:14px;height:14px;border-radius:50%;background:var(--ink)}
.loc .phase:not(:first-child) .pdot{left:30px}
.loc .phase .when{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.12em;
  text-transform:uppercase;color:var(--graphite);margin-bottom:12px}
.loc .phase h4{font-family:'Fraunces',serif;font-weight:500;font-size:19px;margin-bottom:10px;
  font-variation-settings:'opsz' 60}
.loc .phase p{font-size:14.5px;color:var(--ink-soft);line-height:1.55}
@media(max-width:760px){.loc .tl{grid-template-columns:1fr}
  .loc .tl::before{left:7px;top:0;bottom:0;right:auto;width:1px;height:auto}
  .loc .phase{padding:8px 0 30px 30px}.loc .phase:not(:first-child){padding-left:30px}
  .loc .phase .pdot,.loc .phase:not(:first-child) .pdot{left:0}}

/* ---- Closing (shared) ---- */
.loc .closing{background:var(--ink);color:var(--paper);padding:120px 0;text-align:center;
  position:relative;overflow:hidden}
.loc .closing .kicker{color:rgba(238,237,232,0.55);display:block;margin-bottom:30px}
.loc .closing h2{font-family:'Fraunces',serif;font-weight:300;font-size:clamp(32px,4.4vw,56px);
  line-height:1.1;letter-spacing:-0.02em;font-variation-settings:'opsz' 144;max-width:820px;margin:0 auto 38px}
.loc .closing h2 .em{font-style:italic;color:#FFFDF7}
.loc .closing .btn-primary{background:var(--paper);color:var(--ink)}
.loc .closing .btn-primary:hover{background:#fff;color:#000}
.loc .glow{position:absolute;width:620px;height:620px;border-radius:50%;
  background:radial-gradient(circle,rgba(255,255,255,0.16),transparent 68%);
  bottom:-310px;left:50%;transform:translateX(-50%);pointer-events:none}

/* ---- Footer (Footer template part) ---- */
.loc-footer{padding:50px 0;background:var(--ink);color:rgba(238,237,232,0.55);
  border-top:1px solid rgba(238,237,232,0.1)}
.loc-footer .foot-inner{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.loc-footer .foot-brand{font-family:'Fraunces',serif;font-size:21px;color:var(--paper);letter-spacing:-0.01em}
.loc-footer .foot-tag{font-family:'Fraunces',serif;font-style:italic;font-size:15px}

/* ---- Animations ---- */
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes fade{to{opacity:1}}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{transform:scale(1);opacity:.3}50%{transform:scale(1.6);opacity:0}}
.loc .reveal{opacity:0;transform:translateY(28px);transition:opacity .9s ease,transform .9s ease}
.loc .reveal.in{opacity:1;transform:none}