/* Blueprint360 Coaching — Editorial / Paper Design System */
:root{
  --paper:#F1E9DA; --paper-2:#E8DDC8; --paper-3:#FBF7EE;
  --navy:#15233D; --navy-2:#0E1A30;
  --tan:#C7A87E; --tan-dark:#A8895F;
  --sky:#4380A0; --sky-light:#84B4CC;
  --ink:#15233D; --ink-dim:#56607A; --ink-onnavy:#C9CFDC;
  --rule:rgba(21,35,61,.16);
  --max:1240px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,sans-serif;
  font-size:17px;line-height:1.72;color:var(--ink);
  background:var(--paper);-webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.4;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 32px}

/* ---- type ---- */
h1,h2,h3{font-family:'Oswald',sans-serif;font-weight:300;line-height:1.04;letter-spacing:-.005em;text-transform:lowercase}
h1{font-size:clamp(46px,7vw,98px)}
h2{font-size:clamp(32px,4.6vw,62px);font-weight:400}
h3{font-size:clamp(22px,2.4vw,30px);font-weight:500}
h4{font-family:'Oswald',sans-serif;font-weight:500;font-size:20px;text-transform:lowercase;line-height:1.2}
p{text-wrap:pretty}
em{font-style:normal;color:var(--sky)}
.dot{color:var(--tan-dark)}
strong{color:var(--navy);font-weight:600}

.tag{
  font-family:'Anton',sans-serif;font-weight:400;font-size:12px;
  letter-spacing:.13em;text-transform:lowercase;color:var(--sky);
  display:inline-flex;align-items:center;gap:9px;
}
.tag::before{content:"";width:22px;height:2px;background:var(--tan);display:inline-block}
.tag.center{justify-content:center}
.idx{font-family:'Anton',sans-serif;font-size:clamp(40px,5vw,64px);color:var(--rule);line-height:1;letter-spacing:.02em}

/* ---- buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:14px;
  letter-spacing:.02em;padding:16px 26px;border:1.5px solid var(--navy);
  background:var(--navy);color:var(--paper);cursor:pointer;
  transition:transform .25s ease,background .25s ease,color .25s ease,border-color .25s ease;
}
.btn .ar{transition:transform .25s ease}
.btn:hover{background:var(--sky);border-color:var(--sky)}
.btn:hover .ar{transform:translateX(5px)}
.btn.ghost{background:transparent;color:var(--navy)}
.btn.ghost:hover{background:var(--navy);color:var(--paper);border-color:var(--navy)}
.btn.lite{background:var(--paper);color:var(--navy);border-color:var(--paper)}
.btn.lite:hover{background:var(--sky);border-color:var(--sky);color:var(--paper)}
.btn.outline-lite{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.4)}
.btn.outline-lite:hover{background:var(--paper);color:var(--navy);border-color:var(--paper)}
.btn.invert{background:transparent;color:var(--paper);border-color:rgba(255,255,255,.4)}
.btn.invert:hover{background:var(--paper);color:var(--navy);border-color:var(--paper)}

/* ---- nav ---- */
nav{position:fixed;top:0;left:0;right:0;z-index:200;
  transition:background .3s ease,box-shadow .3s ease,border-color .3s ease;
  border-bottom:1px solid transparent}
nav.scrolled{background:rgba(241,233,218,.94);backdrop-filter:blur(10px);
  border-bottom-color:var(--rule);box-shadow:0 1px 30px rgba(21,35,61,.06)}
.nav-in{max-width:var(--max);margin:0 auto;padding:18px 32px;
  display:flex;align-items:center;justify-content:space-between;gap:24px}
.mark{font-family:'Oswald',sans-serif;font-size:23px;font-weight:600;
  letter-spacing:-.01em;color:var(--navy);display:flex;align-items:baseline;gap:1px}
.mark b{font-weight:700;color:var(--sky)}
.mark .deg{font-size:13px;color:var(--tan-dark);transform:translateY(-7px)}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:14px;font-weight:500;color:var(--ink-dim);
  transition:color .2s ease;position:relative}
.nav-links a:hover{color:var(--navy)}
.nav-links a.active{color:var(--navy)}
.nav-links a.cta{font-weight:600;color:var(--navy);
  border:1.5px solid var(--navy);padding:10px 18px;display:inline-flex;gap:7px}
.nav-links a.cta:hover{background:var(--navy);color:var(--paper)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px}
.burger span{width:24px;height:2px;background:var(--navy);transition:.3s}

/* ---- hero (homepage) ---- */
.hero{position:relative;padding:188px 0 110px;overflow:hidden}
.hero-split{position:relative;z-index:2;display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center}
.hero-img{position:relative}
.hero-img img{width:100%;height:auto;border-radius:14px;border:1.5px solid var(--navy);display:block;filter:contrast(1.04)}
.hero-grid{position:absolute;inset:0;z-index:0;
  background-image:
    linear-gradient(var(--rule) 1px,transparent 1px),
    linear-gradient(90deg,var(--rule) 1px,transparent 1px);
  background-size:46px 46px;
  -webkit-mask-image:linear-gradient(180deg,#000 0%,transparent 78%);
          mask-image:linear-gradient(180deg,#000 0%,transparent 78%);
  opacity:.5}
.ring{position:absolute;z-index:0;right:-180px;top:60px;width:660px;height:660px;
  opacity:.9;pointer-events:none}
.hero-in{position:relative;z-index:2;max-width:880px}
.hero h1{margin:18px 0 0}
.hero h1 .l2{display:block;color:var(--ink-dim);font-size:.62em;margin-top:.08em}
.deck{font-family:'Oswald',sans-serif;font-weight:300;
  font-size:clamp(18px,2vw,24px);color:var(--navy);
  margin:26px 0 0;max-width:620px;line-height:1.4}
.deck .pill{color:var(--sky)}
.lede{font-size:18px;color:var(--ink-dim);max-width:560px;margin:22px 0 0}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.hero-meta{display:flex;gap:30px;flex-wrap:wrap;margin-top:46px;
  padding-top:26px;border-top:1px solid var(--rule)}
.hero-meta div{font-size:13px;color:var(--ink-dim)}
.hero-meta b{display:block;font-family:'Oswald',sans-serif;font-weight:600;
  font-size:26px;color:var(--navy);line-height:1}

/* ---- credibility strip ---- */
.strip{background:var(--navy);color:var(--paper)}
.strip-in{max-width:var(--max);margin:0 auto;padding:22px 32px;
  display:flex;flex-wrap:wrap;align-items:center;justify-content:center;
  gap:14px 30px}
.strip span{font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.07em;
  text-transform:lowercase;color:var(--paper);display:flex;align-items:center;gap:13px}
.strip span::before{content:"";width:7px;height:7px;background:var(--sky-light);
  transform:rotate(45deg);flex-shrink:0}

/* ---- generic section ---- */
section{position:relative}
.sec{padding:clamp(76px,11vw,138px) 0}
.sec.alt{background:var(--paper-2)}
.head{max-width:780px}
.head .row{display:flex;align-items:flex-start;gap:22px}
.head h2{margin-top:6px}
.head p{color:var(--ink-dim);margin-top:20px;font-size:18px}

/* ---- method principle ---- */
.principle{margin-top:54px;display:grid;grid-template-columns:1.05fr 1fr;
  gap:54px;align-items:start}
.principle .big{font-family:'Oswald',sans-serif;font-weight:300;
  font-size:clamp(28px,3.6vw,46px);line-height:1.12;text-transform:lowercase}
.principle .big em{color:var(--sky)}
.principle .note{border-left:2px solid var(--tan);padding-left:24px;
  font-size:16px;color:var(--ink-dim)}
.principle .note .stamp{font-family:'Anton',sans-serif;font-size:13px;
  letter-spacing:.1em;color:var(--navy);text-transform:lowercase;
  display:block;margin-bottom:10px}

/* ---- pillar cards ---- */
.pillars{margin-top:58px;display:grid;
  grid-template-columns:repeat(5,1fr);gap:0;
  border:1px solid var(--rule);background:var(--rule)}
.pillar{background:var(--paper);padding:32px 26px 38px;position:relative;
  transition:background .3s ease,transform .3s ease}
.pillar:hover{background:var(--paper-3)}
.pillar .pn{font-family:'Anton',sans-serif;font-size:13px;color:var(--tan-dark)}
.pillar .plabel{font-family:'Anton',sans-serif;font-size:18px;
  text-transform:lowercase;letter-spacing:.02em;color:var(--navy);
  margin:16px 0 0}
.pillar .pbar{width:30px;height:3px;background:var(--sky);margin:14px 0 16px;
  transition:width .35s ease}
.pillar:hover .pbar{width:54px}
.pillar h3{font-size:21px;font-weight:500;margin-bottom:9px}
.pillar p{font-size:14.5px;color:var(--ink-dim);line-height:1.62}

/* ---- data band ---- */
.band{background:var(--navy-2);color:var(--paper);position:relative;overflow:hidden}
.band::before{content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px);
  background-size:54px 54px}
.band-in{position:relative;z-index:1;max-width:var(--max);margin:0 auto;
  padding:clamp(70px,10vw,118px) 32px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:56px;align-items:center}
.band .tag{color:var(--sky-light)}
.band .tag::before{background:var(--tan)}
.band h2{color:var(--paper);margin-top:14px}
.band p{color:var(--ink-onnavy);margin-top:18px;font-size:17px}
.measures{display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);border-radius:12px;overflow:hidden}
.measure{background:var(--navy-2);padding:26px 22px}
.measure .mt{font-family:'Anton',sans-serif;font-size:13px;
  letter-spacing:.06em;color:var(--sky-light);text-transform:lowercase}
.measure .md{font-family:'Oswald',sans-serif;font-weight:400;font-size:21px;
  color:var(--paper);margin-top:8px;text-transform:lowercase}
.measure-icon{width:48px;height:48px;margin-bottom:14px;color:var(--sky-light);flex-shrink:0}

/* ---- programs ---- */
.progs{margin-top:58px;display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.prog{border:1.5px solid var(--navy);padding:38px 32px 34px;
  background:var(--paper);position:relative;display:flex;flex-direction:column;
  transition:transform .3s ease,box-shadow .3s ease}
.prog:hover{transform:translateY(-6px);box-shadow:-10px 14px 0 var(--tan)}
.prog.feat{background:var(--navy);color:var(--paper);border-color:var(--navy)}
.prog.feat:hover{box-shadow:-10px 14px 0 var(--sky)}
.prog .crop{position:absolute;width:13px;height:13px}
.prog .crop.tl{top:-1px;left:-1px;border-top:2px solid var(--tan);border-left:2px solid var(--tan)}
.prog .crop.br{bottom:-1px;right:-1px;border-bottom:2px solid var(--tan);border-right:2px solid var(--tan)}
.badge{position:absolute;top:-13px;left:32px;background:var(--sky);
  color:var(--paper);font-family:'Anton',sans-serif;font-size:11px;
  letter-spacing:.1em;text-transform:lowercase;padding:6px 13px}
.prog .ptier{font-family:'Anton',sans-serif;font-size:30px;
  text-transform:lowercase;letter-spacing:.01em}
.prog .ptag{font-size:14px;color:var(--sky);font-weight:600;margin-top:4px}
.prog.feat .ptag{color:var(--sky-light)}
.prog .pdesc{font-size:15px;color:var(--ink-dim);margin-top:16px;line-height:1.62}
.prog.feat .pdesc{color:var(--ink-onnavy)}
.prog .pmeta{margin-top:22px;padding-top:20px;border-top:1px solid var(--rule);
  display:flex;flex-direction:column;gap:11px}
.prog.feat .pmeta{border-top-color:rgba(255,255,255,.16)}
.prog .pmeta div{display:flex;justify-content:space-between;gap:14px;font-size:13.5px}
.prog .pmeta .k{color:var(--ink-dim);font-weight:500}
.prog.feat .pmeta .k{color:var(--sky-light)}
.prog .pmeta .v{font-weight:600;text-align:right}
.prog .pcta{margin-top:26px}
.prog .pcta a{display:inline-flex;align-items:center;gap:9px;
  font-weight:600;font-size:14px;color:var(--navy);
  border-bottom:2px solid var(--tan);padding-bottom:3px;transition:gap .2s ease}
.prog.feat .pcta a{color:var(--paper);border-bottom-color:var(--sky-light)}
.prog .pcta a:hover{gap:15px}

/* ---- results gallery ---- */
.results-grid{margin-top:48px;display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.result-card{overflow:hidden;border-radius:14px;border:1.5px solid var(--rule);position:relative;
  background:var(--paper-3);
  transition:transform .4s cubic-bezier(.2,.7,.2,1),box-shadow .4s cubic-bezier(.2,.7,.2,1),border-color .3s ease}
.result-card:hover{transform:translateY(-8px);box-shadow:0 20px 48px rgba(21,35,61,.14);border-color:var(--navy)}
.result-card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.result-card::after{content:"";position:absolute;inset:0;border-radius:14px;
  background:linear-gradient(to top,rgba(21,35,61,.06) 0%,transparent 40%);pointer-events:none}
.result-label{position:absolute;bottom:14px;left:14px;z-index:2;
  font-family:'Anton',sans-serif;font-size:11px;letter-spacing:.1em;text-transform:lowercase;
  color:var(--paper);background:rgba(21,35,61,.72);backdrop-filter:blur(6px);
  padding:6px 12px;border-radius:6px;pointer-events:none}

/* ---- about (homepage) ---- */
.about-in{display:grid;grid-template-columns:1fr 1.15fr;gap:60px;
  margin-top:50px;align-items:start}
.about-left{display:flex;flex-direction:column;gap:24px}
.coach-action-img{overflow:hidden;border-radius:14px;border:1.5px solid var(--rule);
  transition:box-shadow .4s cubic-bezier(.2,.7,.2,1),border-color .3s ease}
.coach-action-img:hover{box-shadow:0 12px 36px rgba(21,35,61,.12);border-color:var(--navy)}
.coach-action-img img{width:100%;height:auto;display:block;filter:contrast(1.05)}
.coachcard{border:1.5px solid var(--rule);background:var(--paper-3);
  padding:34px 30px;position:relative;border-radius:14px;
  transition:border-color .3s ease,box-shadow .4s cubic-bezier(.2,.7,.2,1)}
.coachcard:hover{border-color:var(--navy);box-shadow:0 10px 30px rgba(21,35,61,.08)}
.coachcard .ccmark{position:absolute;top:24px;right:26px;width:54px;height:54px;
  opacity:.85}
.coachcard .cname{font-family:'Anton',sans-serif;font-size:26px;
  text-transform:lowercase;color:var(--navy)}
.coachcard .crole{font-size:13.5px;color:var(--sky);font-weight:600;margin-top:3px}
.creds{margin-top:24px;padding-top:22px;border-top:1px solid var(--rule);
  display:flex;flex-direction:column;gap:13px}
.creds div{display:flex;gap:12px;align-items:flex-start;font-size:14px;
  color:var(--ink-dim)}
.creds div::before{content:"";width:8px;height:8px;background:var(--sky);
  transform:rotate(45deg);margin-top:6px;flex-shrink:0}
.about-body p{font-size:17px;color:var(--ink-dim);margin-top:18px}
.about-body p:first-child{margin-top:0}
.about-body p strong{color:var(--navy);font-weight:600}
.pullquote{font-family:'Oswald',sans-serif;font-weight:300;
  font-size:clamp(22px,2.7vw,32px);line-height:1.2;text-transform:lowercase;
  color:var(--navy);margin-top:28px;padding-left:24px;
  border-left:3px solid var(--tan)}
.pullquote em{color:var(--sky)}

/* ---- start / CTA section ---- */
.start{background:var(--navy);color:var(--paper);position:relative;overflow:hidden}
.start .hero-grid{opacity:.32;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent);
          mask-image:linear-gradient(180deg,#000,transparent)}
.start-in{position:relative;z-index:1;max-width:var(--max);margin:0 auto;
  padding:clamp(76px,10vw,128px) 32px}
.start .tag{color:var(--sky-light)}
.start .tag::before{background:var(--tan)}
.start h2{color:var(--paper);margin-top:14px;max-width:760px}
.start .sub{color:var(--ink-onnavy);max-width:560px;margin-top:18px;font-size:17px}
.paths{margin-top:44px;display:grid;grid-template-columns:1fr 1fr;gap:22px;
  max-width:840px}
.path{border:1.5px solid rgba(255,255,255,.22);padding:30px 28px;
  background:rgba(255,255,255,.03);transition:border-color .25s,background .25s}
.path:hover{border-color:var(--sky-light);background:rgba(255,255,255,.06)}
.path .pk{font-family:'Anton',sans-serif;font-size:12px;letter-spacing:.1em;
  text-transform:lowercase;color:var(--sky-light)}
.path h3{color:var(--paper);font-weight:500;margin:10px 0 8px;font-size:24px}
.path p{font-size:14.5px;color:var(--ink-onnavy);margin-bottom:20px}
.contact-line{margin-top:48px;padding-top:26px;
  border-top:1px solid rgba(255,255,255,.16);
  display:flex;flex-wrap:wrap;gap:10px 26px;font-size:14px;color:var(--ink-onnavy)}
.contact-line a{color:var(--paper);font-weight:600}
.contact-line a:hover{color:var(--sky-light)}

/* ---- footer ---- */
footer{background:var(--navy-2);color:var(--ink-onnavy);
  padding:64px 0 30px;position:relative}
.fgrid{max-width:var(--max);margin:0 auto;padding:0 32px;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
.fbrand .mark{color:var(--paper);margin-bottom:14px}
.fbrand p{font-size:14px;max-width:280px}
.footer-logo{width:220px;height:auto;margin-bottom:14px;filter:brightness(1);border-radius:6px}
.fcol h4{font-family:'Anton',sans-serif;font-size:13px;letter-spacing:.08em;
  text-transform:lowercase;color:var(--paper);margin-bottom:14px}
.fcol a{display:block;font-size:14px;margin-bottom:9px;transition:color .2s}
.fcol a:hover{color:var(--sky-light)}
.fbot{max-width:var(--max);margin:48px auto 0;padding:24px 32px 0;
  border-top:1px solid rgba(255,255,255,.1);
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:12px;
  font-size:13px}
.fbot .socs{display:flex;gap:20px}
.fbot a:hover{color:var(--sky-light)}

/* ---- reveal ---- */
.rv{opacity:0;transform:translateY(22px);
  transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.rv.in{opacity:1;transform:none}
.d1{transition-delay:.07s}.d2{transition-delay:.14s}.d3{transition-delay:.21s}
.d4{transition-delay:.28s}.d5{transition-delay:.35s}

.arc{stroke-dasharray:78 100;stroke-dashoffset:100;
  animation:draw 2s cubic-bezier(.2,.7,.2,1) .25s forwards}
@keyframes draw{to{stroke-dashoffset:0}}

/* ============================================================
   INTERNAL PAGES — program detail, about, contact, scheduling, intake, 404
   ============================================================ */

/* ---- page header ---- */
.page-header{padding:160px 0 70px;position:relative;overflow:hidden}
.page-header .hero-grid{opacity:.4}
.page-header .breadcrumb{font-size:13px;color:var(--ink-dim);margin-bottom:16px}
.page-header .breadcrumb a{color:var(--sky);transition:color .2s}
.page-header .breadcrumb a:hover{color:var(--navy)}
.page-header h1{margin-top:8px}
.page-header .lede{margin-top:20px;max-width:620px}

/* ---- program hero ---- */
.program-hero{background:var(--navy);color:var(--paper);padding:180px 0 90px;
  text-align:center;position:relative;overflow:hidden}
.program-hero .hero-grid{opacity:.28;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px)}
.program-hero .wrap{position:relative;z-index:1}
.program-hero .program-hero-icon{font-size:42px;opacity:.7;margin-bottom:12px}
.program-hero .tag{color:var(--sky-light)}
.program-hero .tag::before{background:var(--tan)}
.program-hero h1{color:var(--paper);margin-top:10px}
.program-hero .program-tagline{font-family:'Oswald',sans-serif;font-weight:300;
  font-size:clamp(18px,2vw,24px);color:var(--sky-light);margin-top:14px}
.program-hero .lede{color:var(--ink-onnavy);max-width:720px;margin:20px auto 0}
.program-hero .program-meta-bar{display:flex;justify-content:center;gap:50px;
  margin-top:40px;padding-top:30px;border-top:1px solid rgba(255,255,255,.16)}
.program-hero .program-meta-bar div{text-align:center}
.program-hero .program-meta-bar strong{display:block;font-family:'Oswald',sans-serif;
  font-weight:600;font-size:24px;color:var(--paper)}
.program-hero .program-meta-bar span{font-size:13px;color:var(--ink-onnavy)}
.program-hero .btn{margin-top:32px}

/* ---- feature grid (program pages) ---- */
.feature-grid{margin-top:48px;display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--rule);background:var(--rule)}
.feature-item{background:var(--paper);padding:30px 28px;
  display:flex;gap:18px;align-items:flex-start;
  transition:background .3s ease}
.feature-item:hover{background:var(--paper-3)}
.feature-num{font-family:'Anton',sans-serif;font-size:32px;color:var(--rule);
  line-height:1;flex-shrink:0;min-width:44px}
.feature-body h4{margin-bottom:6px;font-size:18px}
.feature-body p{font-size:14.5px;color:var(--ink-dim);line-height:1.62}

/* ---- cta strip (used on internal pages) ---- */
.cta-strip{background:var(--navy);color:var(--paper);
  padding:clamp(76px,10vw,128px) 0;text-align:center;
  position:relative;overflow:hidden}
.cta-strip .hero-grid{opacity:.28;
  background-image:
    linear-gradient(rgba(255,255,255,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.045) 1px,transparent 1px)}
.cta-strip .wrap{position:relative;z-index:1}
.cta-strip .tag{color:var(--sky-light)}
.cta-strip .tag::before{background:var(--tan)}
.cta-strip h2{color:var(--paper);margin:14px auto 0;max-width:760px}
.cta-strip p{color:var(--ink-onnavy);margin:18px auto 0;max-width:560px;font-size:17px}
.btn-row{display:flex;gap:14px;flex-wrap:wrap;justify-content:center;margin-top:34px}

/* ---- about page ---- */
.founder-block{display:grid;grid-template-columns:1fr 1.3fr;gap:50px;
  align-items:start;margin-top:10px}
.founder-photo{width:100%;aspect-ratio:2/3;background-size:cover;
  background-position:center;border:1.5px solid var(--rule);border-radius:14px;
  transition:box-shadow .4s cubic-bezier(.2,.7,.2,1),border-color .3s ease}
.founder-photo:hover{box-shadow:0 16px 40px rgba(21,35,61,.12);border-color:var(--navy)}
.founder-content{font-size:17px;color:var(--ink-dim);line-height:1.72}
.founder-content p{margin-top:18px}
.founder-content p:first-child{margin-top:0}
.founder-content h3{margin-top:32px;margin-bottom:12px;color:var(--navy)}
.founder-content ul{margin:14px 0;display:flex;flex-direction:column;gap:10px}
.founder-content li{display:flex;gap:12px;align-items:flex-start;font-size:15px}
.founder-content li::before{content:"";width:8px;height:8px;background:var(--sky);
  transform:rotate(45deg);margin-top:6px;flex-shrink:0}

/* ---- contact page ---- */
.form-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:50px;align-items:start}
.form-info{background:var(--navy);color:var(--paper);padding:36px 30px;border:1.5px solid var(--navy);border-radius:14px}
.form-info h3{color:var(--paper);margin-bottom:12px}
.form-info p{color:var(--ink-onnavy);font-size:15px}
.form-info .label{font-family:'Anton',sans-serif;font-size:12px;letter-spacing:.08em;
  text-transform:lowercase;color:var(--sky-light);margin-bottom:4px}
.form-info a{color:var(--paper);font-weight:500;transition:color .2s}
.form-info a:hover{color:var(--sky-light)}
.form-info .contact-line{margin-top:22px;padding-top:18px;border-top:1px solid rgba(255,255,255,.12);
  display:block}
.contact-card{border:1.5px solid var(--rule);padding:28px 24px;border-radius:14px;
  background:var(--paper-3);transition:border-color .25s,box-shadow .3s ease}
.contact-card:hover{border-color:var(--sky);box-shadow:0 8px 24px rgba(21,35,61,.08)}
.contact-card .label{font-family:'Anton',sans-serif;font-size:12px;letter-spacing:.08em;
  text-transform:lowercase;color:var(--sky)}
.contact-card a{color:var(--sky);font-weight:600;transition:color .2s}
.contact-card a:hover{color:var(--navy)}

/* ---- embed wrappers (scheduling, intake) ---- */
.scheduling-wrapper,.intake-wrapper{max-width:860px;margin:0 auto}
.scheduling-wrapper iframe,.intake-wrapper iframe{width:100%;border:none;min-height:700px}
.embed-placeholder{position:relative;background:var(--paper-2);
  border:1px solid var(--rule);padding:60px 30px;text-align:center;
  transition:opacity .5s ease}
.embed-placeholder.loaded{opacity:0;position:absolute;pointer-events:none}
.embed-placeholder-spinner{width:28px;height:28px;border:3px solid var(--rule);
  border-top-color:var(--sky);border-radius:50%;margin:0 auto 14px;
  animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.embed-placeholder-text{color:var(--ink-dim);font-size:14px}

/* ---- prose ---- */
.prose{max-width:760px;margin-left:auto;margin-right:auto;
  font-size:17px;color:var(--ink-dim);line-height:1.72}
.prose p{margin-top:18px}
.prose p:first-child{margin-top:0}
.prose strong{color:var(--navy)}

/* ---- 404 ---- */
.four04-num{font-family:'Oswald',sans-serif;font-weight:300;
  font-size:clamp(120px,20vw,220px);line-height:1;color:var(--rule)}

/* ---- responsive ---- */
@media(max-width:1000px){
  .hero-split{grid-template-columns:1fr;gap:34px}
  .hero-img{max-width:560px}
  .principle,.about-in,.band-in,.founder-block,.form-grid{grid-template-columns:1fr;gap:34px}
  .pillars{grid-template-columns:1fr 1fr}
  .progs{grid-template-columns:1fr;max-width:480px}
  .results-grid{grid-template-columns:1fr 1fr;gap:20px}
  .feature-grid{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr;gap:34px}
  .program-hero .program-meta-bar{gap:30px}
}
@media(max-width:760px){
  nav,nav.scrolled{background:var(--paper);backdrop-filter:none;-webkit-backdrop-filter:none}
  .wrap,.nav-in{padding-left:22px;padding-right:22px}
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(82vw,330px);
    background:var(--paper);flex-direction:column;align-items:flex-start;
    justify-content:flex-start;gap:6px;padding:104px 30px 40px;
    transform:translateX(100%);transition:transform .35s ease;
    box-shadow:-20px 0 60px rgba(21,35,61,.18);z-index:150}
  .nav-links.open{transform:none}
  .nav-links a{font-size:17px;padding:11px 0;width:100%;color:var(--navy)}
  .nav-links a.cta{margin-top:12px;justify-content:center}
  .nav-overlay{display:none;position:fixed;inset:0;background:rgba(21,35,61,.35);z-index:140}
  .nav-overlay.show{display:block}
  .burger{display:flex;z-index:200;min-width:44px;min-height:44px;align-items:center;justify-content:center}
  .burger span{background:var(--navy)}
  .burger.x span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .burger.x span:nth-child(2){opacity:0}
  .burger.x span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
  .hero{padding:140px 0 80px}
  .ring{right:-44%;top:auto;bottom:-12%;width:430px;height:430px;opacity:.5}
  .head .row{flex-direction:column;gap:8px}
  .pillars{grid-template-columns:1fr}
  .paths,.measures{grid-template-columns:1fr}
  .results-grid{grid-template-columns:1fr;max-width:360px;margin-left:auto;margin-right:auto;gap:20px}
  .hero-meta{gap:20px 30px}
  .program-hero{padding:140px 0 70px}
  .program-hero .program-meta-bar{flex-direction:column;gap:16px}
  .page-header{padding:130px 0 50px}
  .fgrid{grid-template-columns:1fr;gap:28px}
  .fbot{flex-direction:column;text-align:center}
  .fbot .socs{justify-content:center}
  .strip-in{gap:10px 20px}
  .strip span{font-size:11px}
  .founder-photo{max-width:340px}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001s!important;transition-duration:.001s!important}
  html{scroll-behavior:auto}
}
