/* Phronia Counsel — the "Believe" design system (Ted Lasso / AFC Richmond inspired).
   Single source of truth. Fonts are loaded per-page via <link> (preconnect). */
:root{
  --blue:#1f4fd6; --blue-deep:#13338f; --blue-soft:#e8eefc;
  --ink:#10204a; --ink-soft:#41527c;
  --honey:#f6b338; --honey-deep:#e09a16;
  --cream:#fbf7ee; --cream-2:#f4ecdd; --paper:#fffdf8;
  --red:#e0492f;
  --line:rgba(16,32,74,.10);
  --shadow:0 18px 50px -22px rgba(16,32,74,.35);
  --shadow-sm:0 8px 24px -14px rgba(16,32,74,.30);
  --r:20px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:var(--cream);color:var(--ink);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden}
h1,h2,h3,h4{font-family:'Plus Jakarta Sans',sans-serif;line-height:1.08;letter-spacing:-.02em;color:var(--ink)}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
.wrap.narrow{max-width:54rem}
a{color:inherit}
:focus-visible{outline:3px solid var(--honey);outline-offset:3px;border-radius:6px}
.believe{font-family:'Caveat',cursive;color:var(--blue);font-weight:700}

/* ---------- nav ---------- */
header.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(140%) blur(10px);background:rgba(251,247,238,.82);border-bottom:1px solid var(--line)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.32rem;letter-spacing:-.02em;display:flex;align-items:center;gap:.1rem;text-decoration:none}
.brand .dot{color:var(--honey-deep);margin:0 .12rem}
.brand .c{color:var(--blue)}
.nav-links{display:flex;align-items:center;gap:8px}
.nav-links a{text-decoration:none;font-weight:600;font-size:.95rem;color:var(--ink-soft);padding:9px 14px;border-radius:999px;transition:.2s}
.nav-links a:hover,.nav-links a.on{color:var(--blue);background:var(--blue-soft)}
.nav-cta{background:var(--ink);color:var(--cream)!important}
.nav-cta:hover{background:var(--blue)!important;color:#fff!important}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:'Plus Jakarta Sans';font-weight:700;font-size:1rem;text-decoration:none;padding:15px 26px;border-radius:999px;transition:.22s;border:2px solid transparent;cursor:pointer}
.btn-primary{background:var(--blue);color:#fff;box-shadow:0 14px 30px -12px rgba(31,79,214,.7)}
.btn-primary:hover{background:var(--blue-deep);transform:translateY(-2px)}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-2px)}
.btn-honey{background:var(--honey);color:var(--ink)}
.btn-honey:hover{background:var(--honey-deep);color:#fff}
.btn .arrow{transition:.22s}
.btn:hover .arrow{transform:translateX(3px)}
.cta-row{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}

/* ---------- shared bits ---------- */
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-weight:600;font-size:.82rem;letter-spacing:.14em;text-transform:uppercase;color:var(--blue-deep);background:#fff;border:1px solid var(--line);padding:8px 16px;border-radius:999px;box-shadow:var(--shadow-sm)}
.eyebrow .pip{width:9px;height:9px;border-radius:50%;background:var(--honey);box-shadow:0 0 0 4px rgba(246,179,56,.25)}
.kicker{display:inline-block;font-weight:600;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--honey-deep)}
section{padding:84px 0}
.sec-head h2{font-size:clamp(1.9rem,3.6vw,2.9rem);font-weight:800;margin-top:12px;max-width:760px}
.sec-head p{color:var(--ink-soft);max-width:640px;margin-top:14px;font-size:1.08rem}

/* ---------- home hero ---------- */
.hero{position:relative;padding:96px 0 88px;overflow:hidden}
.hero:before{content:"";position:absolute;inset:0;z-index:-2;background:radial-gradient(60% 70% at 82% 12%, rgba(246,179,56,.30), transparent 60%),radial-gradient(55% 65% at 8% 88%, rgba(31,79,214,.16), transparent 60%)}
.hero h1{font-size:clamp(2.6rem,6.4vw,5rem);font-weight:800;margin:26px 0 0}
.hero h1 .u{position:relative;white-space:nowrap}
.hero h1 .u:after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;border-radius:6px;background:linear-gradient(90deg,var(--honey),var(--honey-deep));z-index:-1;opacity:.9}
.lede{font-size:clamp(1.08rem,1.8vw,1.32rem);color:var(--ink-soft);max-width:620px;margin:26px 0 0}
.hero-grid{display:grid;grid-template-columns:1.25fr .75fr;gap:50px;align-items:center}
.sign{position:relative;background:linear-gradient(180deg,#fff7e0,#ffedbf);border-radius:8px;padding:38px 30px;box-shadow:var(--shadow);transform:rotate(-3deg);border:1px solid rgba(224,154,22,.4)}
.sign:before,.sign:after{content:"";position:absolute;width:62px;height:22px;background:rgba(31,79,214,.22);border:1px solid rgba(31,79,214,.3);border-radius:3px;backdrop-filter:blur(1px)}
.sign:before{top:-11px;left:24px;transform:rotate(-6deg)}
.sign:after{top:-11px;right:24px;transform:rotate(7deg)}
.sign .word{font-family:'Caveat',cursive;font-weight:700;font-size:3.4rem;color:var(--blue);text-align:center;line-height:1;letter-spacing:.02em}
.sign .sub{text-align:center;color:var(--ink-soft);font-size:.86rem;margin-top:10px;font-weight:500}
.sign .greek{text-align:center;font-family:'Plus Jakarta Sans';font-weight:700;color:var(--honey-deep);margin-top:4px}
.strip{margin-top:70px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:22px 0;display:flex;flex-wrap:wrap;gap:14px 40px;align-items:center;justify-content:center;font-weight:600;color:var(--ink-soft);font-size:.95rem;text-align:center}
.strip b{color:var(--ink)}
.strip .sep{width:6px;height:6px;border-radius:50%;background:var(--honey)}

/* ---------- inner-page hero ---------- */
.phero{position:relative;overflow:hidden;padding:66px 0 42px;border-bottom:1px solid var(--line)}
.phero:before{content:"";position:absolute;inset:0;z-index:-2;background:radial-gradient(55% 80% at 88% 6%, rgba(246,179,56,.22), transparent 60%),radial-gradient(45% 70% at 4% 94%, rgba(31,79,214,.12), transparent 60%)}
.phero h1{font-size:clamp(2.1rem,5.4vw,3.6rem);font-weight:800;margin:20px 0 0;max-width:18ch}
.phero h1 .u{position:relative;white-space:nowrap}
.phero h1 .u:after{content:"";position:absolute;left:0;right:0;bottom:.06em;height:.16em;border-radius:6px;background:linear-gradient(90deg,var(--honey),var(--honey-deep));z-index:-1;opacity:.9}
.phero .lede{margin-top:18px}
.eff{color:var(--ink-soft);font-weight:600;font-size:.82rem;letter-spacing:.04em;margin-top:18px}

/* ---------- manifesto ---------- */
.manifesto{background:var(--paper);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.manifesto .grid{display:grid;grid-template-columns:1fr 1fr;gap:46px;align-items:start}
.manifesto p{font-size:1.12rem;color:var(--ink-soft)}
.manifesto .lead{font-size:1.4rem;color:var(--ink);font-family:'Plus Jakarta Sans';font-weight:600;line-height:1.32}
.pullbar{border-left:4px solid var(--honey);padding-left:18px}

/* ---------- prose (legal / independence / essay) ---------- */
.prose{max-width:46rem;font-size:1.06rem;line-height:1.7;color:var(--ink-soft)}
.prose>p,.prose>ul,.prose>ol{margin:0 0 1.15rem}
.prose .lead{font-size:1.22rem;line-height:1.5;color:var(--ink);font-family:'Plus Jakarta Sans';font-weight:600}
.prose h2{font-family:'Plus Jakarta Sans';font-weight:700;font-size:clamp(1.35rem,2.6vw,1.8rem);color:var(--ink);letter-spacing:-.02em;margin:2.4rem 0 .7rem}
.prose h3{font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.15rem;color:var(--ink);margin:1.6rem 0 .5rem}
.prose a{color:var(--blue);text-decoration:none;border-bottom:1px solid rgba(31,79,214,.32);font-weight:600}
.prose a:hover{color:var(--blue-deep)}
.prose ul,.prose ol{padding-left:1.2rem}
.prose li{margin:0 0 .5rem}
.prose strong,.prose b{color:var(--ink);font-weight:700}
.prose blockquote{border-left:4px solid var(--honey);padding-left:18px;margin:1.4rem 0;color:var(--ink);font-style:normal}
.prose code{font-family:ui-monospace,Menlo,monospace;font-size:.92em;background:var(--cream-2);padding:.1em .35em;border-radius:5px}
.em{color:var(--blue);font-weight:700}
.pull{font-family:'Plus Jakarta Sans';font-weight:700;font-size:clamp(1.3rem,2.6vw,1.7rem);line-height:1.25;letter-spacing:-.015em;color:var(--ink);max-width:24ch;margin:0 0 1.2rem}

/* ---------- service / outcome rows ---------- */
.audhead{display:flex;align-items:baseline;gap:1rem;flex-wrap:wrap;margin:0 0 .2rem;padding-bottom:.9rem;border-bottom:1px solid var(--line)}
.audhead .who{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.3rem;color:var(--ink)}
.audhead .for{color:var(--ink-soft);font-weight:600;font-size:.78rem;text-transform:uppercase;letter-spacing:.1em}
.out{margin:2rem 0 0}
.outh{font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.18rem;color:var(--ink);margin:0 0 .2rem;display:flex;align-items:baseline;gap:.7rem;flex-wrap:wrap}
.outh .on{color:var(--honey-deep);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-family:'Plus Jakarta Sans'}
.svc{display:grid;grid-template-columns:2rem 1fr;gap:1.1rem;padding:1.35rem 0;border-bottom:1px solid var(--line)}
.svc .n{font-family:'Caveat',cursive;font-weight:700;font-size:1.7rem;color:var(--honey-deep);line-height:1;padding-top:.1rem}
.svc .t{font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.15rem;color:var(--ink)}
.svc .d{color:var(--ink-soft);font-size:1rem;line-height:1.55;margin:.4rem 0 0;max-width:46rem}

/* feature panel (annual partnership) */
.feature{background:var(--paper);border:1px solid var(--line);border-top:3px solid var(--honey);border-radius:var(--r);padding:2.5rem 2.3rem;box-shadow:var(--shadow-sm)}
.feature h2{font-family:'Plus Jakarta Sans';font-weight:800;font-size:clamp(1.5rem,3vw,2rem);margin:.2rem 0 0}
.feature .inc{list-style:none;margin:1.7rem 0 0;padding:0;display:grid;gap:.7rem}
.feature .inc li{padding-left:1.5rem;position:relative;color:var(--ink-soft);font-size:1.02rem;line-height:1.5}
.feature .inc li:before{content:"";position:absolute;left:0;top:.62rem;width:.5rem;height:.5rem;background:var(--honey);border-radius:50%}
.feature .why{margin-top:1.7rem;padding-top:1.6rem;border-top:1px solid var(--line)}
.note{color:var(--blue);font-weight:700}

/* two on-ramps side by side */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin:1.6rem 0 0}
.duo .feature{padding:2rem 1.9rem}
.duo .feature h2{font-size:clamp(1.4rem,2.4vw,1.7rem)}
@media(max-width:760px){.duo{grid-template-columns:1fr}}
.price{font-family:'Plus Jakarta Sans';font-weight:800;font-size:1.4rem;color:var(--ink);margin:1.1rem 0 0}
.price .off{font-weight:600;font-size:.95rem;color:var(--honey-deep)}
.price.small{font-size:1.02rem;font-weight:700;color:var(--honey-deep)}

/* founding-client special banner */
.special{display:flex;flex-wrap:wrap;gap:1rem 1.6rem;align-items:center;justify-content:space-between;background:linear-gradient(180deg,#fff7e0,#ffedbf);border:1px solid rgba(224,154,22,.5);border-radius:var(--r);padding:1.5rem 1.8rem;margin:1.8rem 0 0}
.special .lab{font-family:'Caveat',cursive;font-weight:700;font-size:1.7rem;color:var(--blue);line-height:1;display:block;margin-bottom:.25rem}
.special .txt{color:var(--ink);font-weight:500;max-width:46rem}
.special .pct{font-family:'Plus Jakarta Sans';font-weight:800;font-size:2rem;color:var(--honey-deep);letter-spacing:-.02em;white-space:nowrap}

/* cards (home services) */
.aud-tabs{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0 36px}
.tab{font-family:'Plus Jakarta Sans';font-weight:700;font-size:.98rem;padding:11px 20px;border-radius:999px;border:2px solid var(--line);background:#fff;cursor:pointer;transition:.2s;color:var(--ink-soft)}
.tab.active{background:var(--blue);color:#fff;border-color:var(--blue);box-shadow:var(--shadow-sm)}
.tab:hover:not(.active){border-color:var(--blue);color:var(--blue)}
.cards{display:flex;flex-wrap:wrap;gap:20px;justify-content:center}
.cards .card{flex:1 1 290px;max-width:360px}
.card{background:var(--paper);border:1px solid var(--line);border-radius:var(--r);padding:26px 24px;transition:.25s;position:relative;overflow:hidden}
.card:hover{transform:translateY(-5px);box-shadow:var(--shadow);border-color:rgba(31,79,214,.3)}
.card .num{font-family:'Caveat',cursive;font-weight:700;font-size:1.9rem;color:var(--honey-deep);line-height:1}
.card h3{font-size:1.18rem;margin:10px 0 8px}
.card p{color:var(--ink-soft);font-size:.98rem}
.card:after{content:"";position:absolute;left:0;top:0;height:100%;width:5px;background:var(--blue);transform:translateX(-5px);transition:.25s}
.card:hover:after{transform:translateX(0)}
.panel{display:none}
.panel.active{display:block;animation:fade .4s ease}
@keyframes fade{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}

/* ---------- blue band (integrity / Cincinnatus / engagement) ---------- */
.integrity,.band{background:linear-gradient(160deg,var(--blue),var(--blue-deep));color:#fff;position:relative;overflow:hidden}
.integrity:before,.band:before{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(246,179,56,.35),transparent 65%);top:-180px;right:-120px}
.integrity .kicker,.band .kicker,.band .lbl{color:var(--honey)}
.integrity h2,.band h2{color:#fff}
.integrity .sec-head p,.band p{color:rgba(255,255,255,.85)}
.band .prose{color:rgba(255,255,255,.86)}
.band .prose .em{color:#fff}
.band .pull{color:#fff}
.icards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-top:40px}
.icard{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:var(--r);padding:26px;backdrop-filter:blur(4px);transition:.25s}
.icard:hover{background:rgba(255,255,255,.14);transform:translateY(-4px)}
.icard h3{color:#fff;font-size:1.2rem;margin-bottom:10px;display:flex;align-items:center;gap:10px}
.icard h3 .ic{width:34px;height:34px;border-radius:9px;background:var(--honey);color:var(--blue-deep);display:grid;place-items:center;font-weight:800;flex:none;font-family:'Plus Jakarta Sans'}
.icard p{color:rgba(255,255,255,.84);font-size:.98rem}
.icard p b{color:var(--honey)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:2.2rem;margin:2.6rem 0 0}
.steps .s .lbl{color:var(--honey);font-weight:700;text-transform:uppercase;letter-spacing:.1em;font-size:.76rem;margin:0 0 .5rem;display:block}
.steps .s .h{font-family:'Plus Jakarta Sans';font-weight:700;font-size:1.05rem;color:#fff;margin:0 0 .4rem}
.steps .s p{color:rgba(255,255,255,.82);font-size:.96rem;margin:0}

/* ---------- founder ---------- */
.founder{background:var(--cream-2)}
.founder .grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:46px;align-items:center}
.avatar{aspect-ratio:1;border-radius:24px;background:linear-gradient(160deg,var(--blue),var(--blue-deep));display:grid;place-items:center;box-shadow:var(--shadow);position:relative;overflow:hidden}
.avatar .mono{font-family:'Plus Jakarta Sans';font-weight:800;font-size:5rem;color:#fff;opacity:.95}
.avatar:after{content:"φρόνησις";position:absolute;bottom:18px;font-family:'Caveat';color:var(--honey);font-size:1.5rem}
.founder h2{font-size:clamp(1.8rem,3vw,2.5rem)}
.founder .role{color:var(--blue);font-weight:700;font-family:'Plus Jakarta Sans';margin-top:8px}
.founder p{color:var(--ink-soft);margin-top:14px;font-size:1.06rem}

/* ---------- final CTA box ---------- */
.final{text-align:center}
.final .box{background:var(--ink);color:var(--cream);border-radius:30px;padding:64px 32px;position:relative;overflow:hidden}
.final .box:before{content:"";position:absolute;inset:0;background:radial-gradient(50% 90% at 50% 0%,rgba(246,179,56,.22),transparent 60%)}
.final h2{color:#fff;font-size:clamp(2rem,4vw,3rem);position:relative}
.final .believe{color:var(--honey);font-size:1.3em}
.final p{color:rgba(255,255,255,.82);max-width:520px;margin:18px auto 0;position:relative}
.final .btn-primary{background:var(--honey);color:var(--ink);margin-top:30px;position:relative}
.final .btn-primary:hover{background:var(--honey-deep);color:#fff}
.contact a{color:var(--blue);text-decoration:none;border-bottom:2px solid var(--honey);padding-bottom:1px;font-weight:600}
.contact a:hover{color:var(--blue-deep)}

/* ---------- footer ---------- */
footer{padding:46px 0;border-top:1px solid var(--line);color:var(--ink-soft);font-size:.92rem}
.foot-in{display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;align-items:center}
.foot-links{display:flex;gap:18px;flex-wrap:wrap}
.foot-links a{text-decoration:none;font-weight:600}
.foot-links a:hover{color:var(--blue)}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:40px}
  .sign{max-width:340px;margin:0 auto;transform:rotate(-2deg)}
  .manifesto .grid,.founder .grid{grid-template-columns:1fr;gap:28px}
  .steps{grid-template-columns:1fr;gap:1.6rem}
  .nav-links a:not(.nav-cta){display:none}
}
@media(prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none;transition:none}
  .btn,.card,.icard,.card:after,.btn .arrow{transition:none}
  .panel.active{animation:none}
}
