:root{
  --navy:#0c1f47;
  --navy-deep:#081530;
  --azure:#1f63d6;
  --azure-br:#3d82f2;
  --sky:#86b4f2;
  --sky-soft:#cfe0fb;
  --ice:#eef4ff;
  --ice-2:#e1ecfd;
  --paper:#ffffff;
  --cream:#f7f5ec;
  --ink:#0d1b38;
  --muted:#566889;
  --line:#e2e9f5;
  --shadow:0 30px 70px -30px rgba(12,31,71,.34);
  --shadow-sm:0 14px 34px -16px rgba(12,31,71,.26);
  --r:20px;
  --maxw:1180px;
  --display:"Poppins",system-ui,sans-serif;
  --body:"Poppins",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;overflow-x:hidden}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
h1,h2,h3,h4{font-family:var(--display);line-height:1.04;letter-spacing:-.025em;font-weight:800}
.eyebrow{font-family:var(--body);font-weight:700;letter-spacing:.16em;text-transform:uppercase;font-size:.74rem;color:var(--azure);margin-bottom:16px}
.eyebrow.light{color:var(--sky)}
.btn{display:inline-flex;align-items:center;gap:.5em;font-family:var(--body);font-weight:700;font-size:1rem;border:none;cursor:pointer;
  border-radius:12px;padding:15px 26px;transition:transform .2s,box-shadow .2s,background .2s,color .2s;white-space:nowrap;line-height:1}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(4px)}
.btn-primary{background:var(--azure);color:#fff;box-shadow:0 12px 26px -10px rgba(31,99,214,.65)}
.btn-primary:hover{transform:translateY(-2px);background:#1a57c2;box-shadow:0 18px 34px -10px rgba(31,99,214,.8)}
.btn-light{background:#fff;color:var(--navy);box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-2px)}
.btn-ghost{background:var(--ice);color:var(--navy);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--azure);color:var(--azure);transform:translateY(-2px)}
.btn-ghost-light{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn-ghost-light:hover{background:rgba(255,255,255,.12);transform:translateY(-2px)}

/* announcement bar */
.topbar a{color:var(--sky);font-weight:700;text-decoration:underline;text-underline-offset:2px}
.topbar b{color:#fff}

/* header */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.86);backdrop-filter:blur(14px);transition:box-shadow .3s}
header.scrolled{box-shadow:0 1px 0 var(--line),0 8px 24px -20px rgba(12,31,71,.4)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px}
.logo{font-family:var(--display);font-weight:700;font-size:1.5rem;letter-spacing:-.02em;color:var(--navy)}
.logo span{color:var(--azure-br)}
.nav-links{display:flex;gap:30px;align-items:center}
.nav-links a{font-weight:600;font-size:.95rem;color:var(--ink);opacity:.82;transition:opacity .2s}
.nav-links a:hover{opacity:1}
.nav-links a.nav-active{opacity:1;color:var(--azure)}
.nav-cta{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;background:none;border:none;cursor:pointer}

/* hero */
.hero{position:relative;overflow:hidden;padding:74px 0 70px;background:
  radial-gradient(60% 80% at 88% -10%,var(--ice-2),transparent 60%),
  radial-gradient(46% 60% at 0% 100%,var(--ice),transparent 60%),
  var(--cream)}
.hero-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:48px;align-items:center;position:relative;z-index:2}
.hero h1{font-size:clamp(2.1rem,4.2vw,3.4rem);color:var(--navy);font-weight:800}
.hero h1 .seg{color:var(--sky)}
.hero h1 em{font-style:normal;color:var(--azure);background:linear-gradient(transparent 58%,rgba(134,180,242,.5) 0);padding:0 .04em}
.hero .sub{font-size:clamp(1.06rem,1.5vw,1.26rem);color:var(--muted);max-width:36ch;margin:24px 0 32px;font-weight:500}
.hero-cta{display:flex;gap:13px;flex-wrap:wrap;align-items:center}
.micro{margin-top:16px;font-size:.86rem;color:var(--muted);font-weight:600;display:flex;align-items:center;gap:8px}
.micro svg{flex:none}

/* hero card */
.hero-visual{position:relative}
.dash{background:#fff;border-radius:22px;box-shadow:var(--shadow);border:1px solid var(--line);overflow:hidden}
.dash-top{background:var(--navy);color:#fff;padding:18px 22px;display:flex;justify-content:space-between;align-items:center}
.dash-top .t{font-family:var(--display);font-weight:600;font-size:1.05rem}
.dash-top .dt{color:var(--sky);font-weight:500;font-family:var(--body);font-size:.85rem}
.dash-body{padding:22px}
.kpis{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:18px}
.kpi{background:var(--ice);border-radius:13px;padding:14px}
.kpi .l{font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.kpi .v{font-family:var(--display);font-weight:700;font-size:1.5rem;color:var(--navy);margin-top:4px}
.kpi .v .pct{font-size:.95rem;color:var(--muted);font-weight:700;font-family:var(--body)}
.dash-foot{display:flex;align-items:center;gap:9px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-size:.8rem;font-weight:600;color:var(--muted)}
.dash-foot .fck{width:20px;height:20px;border-radius:50%;background:var(--ice);color:var(--azure);display:grid;place-items:center;flex:none}
.chart-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px}
.chart-title{font-size:.74rem;font-weight:700;color:var(--navy);text-transform:uppercase;letter-spacing:.04em}
.chart-trend{font-size:.74rem;font-weight:700;color:#1aa564;display:flex;align-items:center;gap:5px}
.chart-trend span{color:var(--muted);font-weight:600}
.chart-plot{display:flex;gap:10px;height:150px}
.y-axis{display:flex;flex-direction:column;justify-content:space-between;font-size:.6rem;font-weight:700;color:var(--muted);text-align:right;flex:none;width:30px;padding-bottom:2px}
.chart{flex:1;display:flex;align-items:flex-end;gap:9px;position:relative;background-image:repeating-linear-gradient(to top,transparent 0,transparent calc(33.33% - 1px),var(--line) calc(33.33% - 1px),var(--line) 33.33%);background-position:bottom;border-bottom:1px solid var(--line)}
.bar{flex:1;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--sky),var(--azure));transform-origin:bottom;animation:grow .9s cubic-bezier(.2,.7,.3,1) both;position:relative}
.bar:nth-child(6){background:linear-gradient(180deg,#8fe3b3,#1aa564)}
.bar-val{position:absolute;top:-19px;left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;font-size:.62rem;font-weight:700;padding:2px 6px;border-radius:5px;white-space:nowrap;font-family:var(--body)}
@keyframes grow{from{transform:scaleY(.05);opacity:.4}to{transform:scaleY(1);opacity:1}}
.chart-x{display:flex;justify-content:space-between;font-size:.64rem;color:var(--muted);font-weight:700;margin-top:8px;padding-left:40px}
.float-tag{position:absolute;background:#fff;border-radius:13px;box-shadow:0 18px 42px -16px rgba(12,31,71,.36);padding:11px 15px;z-index:5;border:1px solid var(--line)}
.float-tag .ft-l{font-size:.62rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.float-tag .ft-v{font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--navy);margin-top:2px;line-height:1}
.ft-a{top:-54px;left:-26px;animation:floaty 5s ease-in-out infinite}
.ft-b{bottom:-26px;right:-26px;animation:floaty 6s ease-in-out infinite .6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}

/* marquee */
.marquee-sec{background:var(--navy);padding:32px 0}
.marquee-label{text-align:center;font-weight:700;letter-spacing:.18em;text-transform:uppercase;font-size:.74rem;color:var(--sky);margin-bottom:22px}
.marquee{position:relative;overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex;width:max-content;animation:scroll 26s linear infinite;-webkit-backface-visibility:hidden;backface-visibility:hidden}
.marquee:hover .marquee-track{animation-play-state:paused}
@keyframes scroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
.logo-item{flex:none;height:34px;width:auto;object-fit:contain;opacity:1;margin-right:62px}
.marquee:hover .logo-item{opacity:1}
.logo img{height:30px;width:auto;display:block}
.foot-grid .logo img{height:34px}
.dpc-logo{height:38px;width:auto;border-radius:7px;display:block}
.badge-osprey{height:24px;width:auto;display:block}
.logo-hint{height:34px}
.guide{perspective:1500px}
.guide-img{width:100%;max-width:430px;margin:0 auto;display:block;border-radius:8px;box-shadow:0 40px 80px -28px rgba(8,21,48,.55),0 12px 28px -16px rgba(8,21,48,.4);transform:perspective(1400px) rotateY(-6deg) rotateX(1.5deg) rotate(-1.5deg);transition:transform .6s cubic-bezier(.2,.7,.3,1)}
.guide:hover .guide-img{transform:perspective(1400px) rotateY(-2deg) rotateX(0deg) rotate(0deg) translateY(-6px)}

/* section scaffold */
.sec{padding:92px 0}
.sec-head{max-width:680px;margin:0 auto 52px;text-align:center}
.sec-head h2{font-size:clamp(2rem,3.7vw,3.1rem);color:var(--navy);font-weight:600}
.sec-head p{font-size:1.1rem;color:var(--muted);margin-top:16px;font-weight:500}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.3,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}

/* who we serve */
#serve{background:var(--ice)}
.serve-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.serve-card{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;transition:transform .28s,box-shadow .28s}
.serve-card:hover{transform:translateY(-7px);box-shadow:var(--shadow)}
.serve-card .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px;background:linear-gradient(135deg,var(--azure-br),var(--azure));color:#fff}
.serve-card h3{font-size:1.4rem;color:var(--navy);margin-bottom:10px;font-weight:600}
.serve-card p{color:var(--muted);font-weight:500;font-size:.99rem}

/* services */
.cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;transition:transform .28s,box-shadow .28s,border-color .28s}
.svc:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:transparent}
.svc .ic{width:54px;height:54px;border-radius:14px;display:grid;place-items:center;margin-bottom:20px;background:var(--ice);color:var(--azure)}
.svc h3{font-size:1.34rem;color:var(--navy);margin-bottom:10px;font-weight:600}
.svc p{color:var(--muted);font-size:.99rem;font-weight:500}
.svc ul{list-style:none;margin-top:16px;display:flex;flex-direction:column;gap:9px}
.svc li{display:flex;gap:10px;align-items:flex-start;font-size:.93rem;font-weight:600;color:var(--navy)}
.svc li svg{flex:none;margin-top:3px}

/* stat band */
.stats{background:var(--ice-2)}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.stat b{display:block;font-family:var(--display);font-weight:700;font-size:clamp(2.6rem,4.6vw,3.6rem);color:var(--azure);line-height:1}
.stat span{display:block;color:var(--navy);font-weight:600;font-size:.97rem;margin-top:10px}

/* pricing */
#pricing{background:#fff}
.cards3.pricing{align-items:stretch}
.pcard{background:var(--navy);color:#fff;border:1px solid var(--navy);border-radius:22px;padding:34px 30px;display:flex;flex-direction:column;transition:transform .28s,box-shadow .28s;position:relative}
.pcard:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.pc-ex{font-weight:700;letter-spacing:.12em;text-transform:uppercase;font-size:.72rem;color:var(--sky)}
.pc-name{font-family:var(--display);font-weight:600;font-size:1.7rem;color:#fff;margin:10px 0 16px}
.pc-price{font-family:var(--display);font-weight:700;font-size:3rem;color:#fff;line-height:1}
.pc-price small{font-size:1rem;color:rgba(255,255,255,.7);font-weight:600;font-family:var(--body)}
.pc-desc{color:rgba(255,255,255,.82);font-weight:500;margin:14px 0;font-size:.97rem;min-height:70px}
.pc-metrics{display:flex;gap:10px;padding:14px 0;border-top:1px solid rgba(255,255,255,.16);border-bottom:1px solid rgba(255,255,255,.16)}
.pc-metrics div{flex:1;text-align:center}
.pc-metrics b{display:block;font-family:var(--display);font-weight:700;font-size:1.18rem;color:#fff}
.pc-metrics span{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--sky)}
.pc-inc{font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.6);margin:20px 0 14px}
.pc-list{list-style:none;display:flex;flex-direction:column;gap:12px;flex:1}
.pc-list li{display:flex;gap:11px;align-items:center;font-weight:600;font-size:.96rem;color:#fff}
.pc-list .ck{flex:none;width:24px;height:24px;border-radius:7px;background:rgba(255,255,255,.14);display:grid;place-items:center;color:var(--sky)}
.pcard .btn{margin-top:26px;justify-content:center}
.pcard .btn-ghost{background:#fff;color:var(--navy);border-color:#fff}
.pcard .btn-ghost:hover{background:var(--ice);border-color:var(--ice);color:var(--navy);transform:translateY(-2px)}
.feat-flag{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--sky);color:var(--navy);font-weight:700;font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;padding:6px 16px;border-radius:100px;white-space:nowrap;z-index:2}
.price-actions{text-align:center;margin-top:38px;display:flex;gap:13px;justify-content:center;flex-wrap:wrap}
.price-note{text-align:center;max-width:600px;margin:18px auto 0;color:var(--muted);font-weight:600;font-size:.95rem}
.price-note b{color:var(--navy)}

/* process */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:32px 28px;position:relative}
.step .num{font-family:var(--display);font-weight:700;font-size:1rem;color:#fff;background:var(--azure);width:40px;height:40px;border-radius:11px;display:grid;place-items:center;margin-bottom:18px}
.step h3{font-size:1.26rem;color:var(--navy);margin-bottom:9px;font-weight:600}
.step p{color:var(--muted);font-weight:500;font-size:.97rem}

/* resource / my dpc story */
#resource{background:var(--navy);color:#fff;position:relative;overflow:hidden}
#resource:before{content:"";position:absolute;inset:0;background:radial-gradient(40% 70% at 92% 6%,rgba(134,180,242,.22),transparent 60%),radial-gradient(50% 80% at 4% 100%,rgba(61,130,242,.2),transparent 60%)}
#resource .wrap{position:relative;z-index:2}
.res-grid{display:grid;grid-template-columns:1fr 1fr;gap:58px;align-items:center}
.res-grid h2{font-size:clamp(2rem,3.6vw,2.9rem);color:#fff;font-weight:600}
.res-grid h2 em{font-style:normal;color:var(--sky);background:linear-gradient(transparent 58%,rgba(134,180,242,.2) 0);padding:0 .04em}
.res-grid p.lead{color:rgba(255,255,255,.82);opacity:1;font-size:1.06rem;font-weight:500;margin:22px 0 28px}
.partner-badge{display:inline-flex;align-items:center;gap:13px;background:#fff;border-radius:100px;padding:10px 18px;box-shadow:var(--shadow-sm);margin-bottom:24px;font-weight:700;color:var(--navy);font-family:var(--display);font-size:1.05rem}
.partner-badge .pmid{font-family:var(--body);font-weight:700;font-size:.68rem;letter-spacing:.1em;color:var(--muted);text-transform:uppercase;text-align:center}
.dpc-chip{background:#f5d04e;color:#1a1a1a;font-weight:800;font-size:.64rem;line-height:1;padding:7px 9px;border-radius:7px;font-family:var(--body);text-align:center}
.book{position:relative;perspective:1400px}
.book-cover{background:#fff;border:13px solid var(--azure-br);border-radius:6px;padding:38px 34px;box-shadow:var(--shadow);transform:rotateY(-9deg) rotateX(2deg);transition:transform .5s}
.book:hover .book-cover{transform:rotateY(-3deg)}
.book-month{border:2px solid #1a1a1a;display:inline-block;padding:6px 22px;font-weight:700;letter-spacing:.22em;font-size:.68rem;font-family:var(--body);margin-bottom:28px}
.book-title{font-family:var(--display);font-weight:700;font-size:2.5rem;color:var(--navy-deep);line-height:1.02;margin-bottom:24px}
.book-sub{font-size:.7rem;font-weight:700;letter-spacing:.13em;line-height:1.8;color:var(--navy);text-transform:uppercase;margin-bottom:28px;font-family:var(--body)}
.book-cc{font-size:.64rem;font-weight:700;letter-spacing:.2em;color:var(--muted);text-transform:uppercase;margin-bottom:14px;font-family:var(--body)}
.book-logos{display:flex;align-items:center;gap:13px;justify-content:center;margin-bottom:28px}
.book-foot{font-size:.66rem;font-weight:700;letter-spacing:.1em;color:var(--navy);text-transform:uppercase;line-height:1.7;text-align:center;font-family:var(--body)}

/* testimonials */

/* faq */
#faq{background:var(--ice)}
.faq-wrap{max-width:780px;margin:0 auto}
.faq{background:#fff;border:1px solid var(--line);border-radius:14px;margin-bottom:13px;overflow:hidden;transition:box-shadow .25s}
.faq[open]{box-shadow:var(--shadow-sm)}
.faq summary{cursor:pointer;padding:21px 24px;font-weight:700;font-size:1.06rem;color:var(--navy);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px}
.faq summary::-webkit-details-marker{display:none}
.faq summary .pl{flex:none;width:24px;height:24px;border-radius:7px;background:var(--ice);color:var(--azure);display:grid;place-items:center;font-weight:700;transition:transform .3s;font-size:1.2rem;line-height:1}
.faq[open] summary .pl{transform:rotate(45deg)}
.faq .ans{padding:0 24px 22px;color:var(--muted);font-weight:500;font-size:1rem;line-height:1.6}
.faq .ans b{color:var(--navy)}

/* newsletter */
.news{background:var(--navy);color:#fff;border-radius:30px;padding:60px 54px;position:relative;overflow:hidden}
.news:before{content:"";position:absolute;inset:0;background:radial-gradient(40% 80% at 100% 0%,rgba(134,180,242,.24),transparent 60%),radial-gradient(50% 80% at 0% 100%,rgba(61,130,242,.18),transparent 55%)}
.news .inner{position:relative;z-index:2;max-width:640px}
.news .kicker{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);padding:7px 15px;border-radius:100px;font-weight:600;font-size:.82rem;color:var(--sky);margin-bottom:20px}
.news h2{font-size:clamp(1.9rem,3.2vw,2.6rem);font-weight:600}
.news p{color:rgba(255,255,255,.82);font-size:1.06rem;margin:16px 0 26px;font-weight:500;max-width:54ch}
.news-form{display:flex;gap:11px;flex-wrap:wrap}
.news-form input{flex:1;min-width:240px;border:none;border-radius:12px;padding:15px 20px;font-family:var(--body);font-size:1rem;font-weight:500;background:#fff;color:var(--ink)}
.news-form input:focus{outline:3px solid var(--sky)}
.formmsg{margin-top:13px;font-weight:700;color:var(--sky);min-height:1.2em;font-size:.94rem}
.formmsg--ok{color:#1a8a4a}
.formmsg--err{color:#c0392b}
.news-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:44px;align-items:center;position:relative;z-index:2}
.mme-logo{height:56px;width:auto;display:block;margin-bottom:22px}
.issue-card{display:block;background:#fff;border-radius:18px;overflow:hidden;text-decoration:none;box-shadow:0 26px 54px -26px rgba(0,0,0,.55);transition:transform .3s,box-shadow .3s}
.issue-thumb{width:100%;height:auto;display:block}
.issue-body{padding:24px 28px 24px}
.issue-card:hover{transform:translateY(-5px);box-shadow:0 36px 68px -26px rgba(0,0,0,.6)}
.issue-label{display:inline-block;font-size:.7rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--azure-br);margin-bottom:12px}
.issue-card h3{color:var(--navy);font-size:1.22rem;font-weight:700;line-height:1.26;margin:0 0 12px;font-family:var(--display)}
.issue-meta{color:var(--muted);font-size:.85rem;font-weight:600;margin-bottom:12px}
.issue-card p{color:#46587a;font-size:.95rem;font-weight:500;margin:0 0 16px;line-height:1.5}
.issue-link{color:var(--azure-br);font-weight:700;font-size:.95rem;display:inline-flex;align-items:center;gap:6px}
.issue-link .arr{transition:transform .25s}
.issue-card:hover .issue-link .arr{transform:translateX(5px)}
@media(max-width:760px){.news-grid{grid-template-columns:1fr;gap:26px}.mme-logo{height:48px}}

/* final */
.final{text-align:center;padding:100px 0;background:radial-gradient(50% 80% at 50% -10%,var(--ice-2),transparent 60%)}
.final h2{font-size:clamp(2.2rem,4.4vw,3.5rem);color:var(--navy);max-width:18ch;margin:0 auto;font-weight:600}
.final p{color:var(--muted);font-size:1.14rem;font-weight:500;margin:20px auto 32px;max-width:50ch}
.final .btn{font-size:1.06rem;padding:18px 34px}
.final .micro{justify-content:center}

/* legal pages */
.legal-page{padding-top:120px}
.legal-page h1{font-size:clamp(2rem,3.6vw,2.8rem);color:var(--navy);margin-bottom:8px}
.legal-updated{color:var(--muted);font-weight:600;font-size:.92rem;margin-bottom:40px}
.legal-page h2{font-size:1.3rem;color:var(--navy);margin:36px 0 14px;font-weight:700}
.legal-page h3{font-size:1.05rem;color:var(--navy);margin:24px 0 10px;font-weight:700}
.legal-page p{color:var(--muted);font-weight:500;font-size:1rem;line-height:1.7;margin-bottom:14px;max-width:72ch}
.legal-page ul{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:18px;max-width:72ch}
.legal-page li{color:var(--muted);font-weight:500;font-size:1rem;line-height:1.7;padding-left:20px;position:relative}
.legal-page li:before{content:"";position:absolute;left:0;top:10px;width:7px;height:7px;border-radius:50%;background:var(--azure)}
.legal-page a{color:var(--azure);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.legal-page a:hover{color:var(--azure-br)}

/* resources page */
.res-hero{padding:74px 0 72px;text-align:center;background:radial-gradient(60% 80% at 88% -10%,var(--ice-2),transparent 60%),radial-gradient(46% 60% at 0% 100%,var(--ice),transparent 60%),var(--cream)}
.res-hero h1{font-size:clamp(2.1rem,4.2vw,3.4rem);color:var(--navy);font-weight:800;margin-bottom:10px}
.res-hero-sub{color:var(--muted);font-weight:500;font-size:clamp(1.06rem,1.5vw,1.26rem);max-width:48ch;margin:0 auto;margin-bottom:48px}
.guide-hero-card{display:grid;grid-template-columns:280px 1fr;gap:54px;align-items:center;background:var(--navy-deep);color:#fff;border-radius:20px;padding:48px 48px;text-align:left}
.guide-hero-visual{display:flex;justify-content:center}
.guide-hero-img{width:100%;max-width:260px;border-radius:12px;box-shadow:0 20px 50px -16px rgba(0,0,0,.45)}
.guide-hero-content .partner-badge{background:#fff;border:none;color:var(--navy)}
.guide-hero-content .partner-badge .pmid{color:var(--muted)}
.guide-hero-content .pmid{color:rgba(255,255,255,.6)}
.res-tag{display:inline-block;font-size:.68rem;font-weight:800;letter-spacing:.14em;text-transform:uppercase;color:var(--sky);margin-bottom:12px}
.guide-hero-content h2{font-size:clamp(1.8rem,3.2vw,2.5rem);color:#fff;font-weight:700;margin-bottom:10px}
.res-feature-sub{color:rgba(255,255,255,.7);font-weight:500;font-size:1.06rem;line-height:1.65;margin-bottom:24px}
.guide-inside-heading{font-size:1rem;font-weight:700;color:var(--sky);text-transform:uppercase;letter-spacing:.08em;margin-bottom:14px}
.guide-inside-list{list-style:none;padding:0;margin:0 0 28px}
.guide-inside-list li{position:relative;padding-left:24px;color:rgba(255,255,255,.85);font-size:.95rem;font-weight:500;line-height:1.55;margin-bottom:12px}
.guide-inside-list li::before{content:"\2713";position:absolute;left:0;color:var(--sky);font-weight:700}
.guide-inside-list strong{color:#fff}
.article-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}
.article-card{display:flex;flex-direction:column;padding:28px 28px 24px;background:#fff;border:1px solid var(--line);border-radius:var(--r);transition:transform .25s,box-shadow .25s;text-decoration:none}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.article-card-top{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.article-type{font-size:.62rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:100px;line-height:1}
.article-type--newsletter{background:#e8f0fe;color:var(--azure)}
.article-type--guide{background:#e6f4ea;color:#1a7f37}
.article-topic{font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.article-card h3{font-family:var(--display);font-weight:700;font-size:1.12rem;color:var(--navy);line-height:1.3;margin-bottom:8px}
.article-card p{color:var(--muted);font-size:.92rem;font-weight:500;line-height:1.55;margin-bottom:14px;flex:1}
.article-link{font-size:.88rem;font-weight:700;color:var(--azure)}
.article-card--soon{opacity:.45;pointer-events:none;border-style:dashed}
.article-soon-label{font-size:.78rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
@media(max-width:980px){.guide-hero-card{grid-template-columns:1fr;gap:36px;text-align:center}.guide-hero-visual{order:-1}.guide-inside-list{text-align:left;max-width:480px;margin-left:auto;margin-right:auto}}

/* blog post page */
.post-page{padding-top:120px}
.post-page .wrap{display:flex;flex-direction:column;align-items:center}
.post-back{display:inline-flex;align-items:center;gap:6px;font-weight:700;font-size:.88rem;color:var(--azure);margin-bottom:28px;align-self:flex-start}
.post-back:hover{color:var(--azure-br)}
.post-page h1{font-size:clamp(1.8rem,3.4vw,2.6rem);color:var(--navy);max-width:22ch;margin-bottom:14px;text-align:center}
.post-meta{color:var(--muted);font-weight:600;font-size:.92rem;margin-bottom:36px;display:flex;align-items:center;gap:16px}
.post-content{max-width:72ch;margin:0 auto}
.post-content h2{font-size:1.3rem;color:var(--navy);margin:36px 0 14px;font-weight:700}
.post-content h3{font-size:1.1rem;color:var(--navy);margin:28px 0 10px;font-weight:700}
.post-content p{color:var(--ink);font-weight:500;font-size:1.04rem;line-height:1.75;margin-bottom:18px}
.post-content ul,.post-content ol{margin:0 0 18px 0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:10px}
.post-content li{color:var(--ink);font-weight:500;font-size:1.04rem;line-height:1.75;padding-left:22px;position:relative}
.post-content li:before{content:"";position:absolute;left:0;top:12px;width:7px;height:7px;border-radius:50%;background:var(--azure)}
.post-content strong{color:var(--navy);font-weight:700}
.post-content blockquote{border-left:4px solid var(--azure);padding:16px 24px;margin:24px 0;background:var(--ice);border-radius:0 12px 12px 0}
.post-content blockquote p{color:var(--navy);font-weight:600;margin-bottom:0}
.post-cta{margin-top:48px;padding:34px 30px;background:var(--ice);border-radius:22px}
.post-cta h3{font-size:1.3rem;color:var(--navy);margin-bottom:10px;font-weight:700}
.post-cta p{color:var(--muted);font-weight:500;margin-bottom:20px;max-width:50ch}
.post-sign-off{margin-top:32px;font-size:1.05rem}
.post-beehiiv{margin-top:12px;font-size:.9rem;color:var(--muted);font-weight:600}
.post-beehiiv a{color:var(--azure);font-weight:700}
.post-disclaimer{margin-top:32px;font-size:.88rem;color:var(--muted);line-height:1.65}
.post-disclaimer em{font-weight:500}

/* post — table of contents */
.post-toc{background:var(--ice);border-radius:16px;padding:24px 28px;margin-bottom:36px}
.post-toc-title{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--azure);margin-bottom:12px}
.post-toc ol{margin:0;padding-left:0;list-style:none;display:flex;flex-direction:column;gap:6px;counter-reset:toc}
.post-toc li{counter-increment:toc;padding-left:0}
.post-toc li:before{display:none}
.post-toc a{color:var(--navy);font-weight:600;font-size:.94rem;text-decoration:none;display:flex;align-items:baseline;gap:8px;transition:color .2s}
.post-toc a:before{content:counter(toc, decimal-leading-zero);font-size:.78rem;font-weight:800;color:var(--azure);min-width:20px}
.post-toc a:hover{color:var(--azure)}

/* post — stat cards */
.post-stat-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:24px 0 28px}
.post-stat{background:var(--ice);border-radius:14px;padding:22px 20px;text-align:center}
.post-stat-num{font-size:1.5rem;font-weight:800;color:var(--navy);line-height:1.2;margin-bottom:6px}
.post-stat-label{font-size:.82rem;font-weight:600;color:var(--muted);line-height:1.4}

/* post — callout box */
.post-callout{background:var(--ice);border-left:4px solid var(--azure);border-radius:0 14px 14px 0;padding:20px 24px;margin:28px 0}
.post-callout-title{font-size:.72rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--azure);margin-bottom:8px}
.post-callout p{margin-bottom:0;font-size:.97rem}
.post-callout--warn{border-left-color:#d4a017;background:#fdf8ec}
.post-callout--warn .post-callout-title{color:#a07d14}

/* post — comparison table */
.post-table{width:100%;border-collapse:separate;border-spacing:0;margin:24px 0 28px;border-radius:14px;overflow:hidden;border:1px solid var(--line);font-size:.95rem}
.post-table thead{background:var(--navy)}
.post-table th{color:#fff;font-weight:700;text-align:left;padding:14px 18px;font-size:.85rem;letter-spacing:.03em}
.post-table td{padding:14px 18px;color:var(--ink);font-weight:500;border-top:1px solid var(--line)}
.post-table tbody tr:nth-child(even){background:var(--ice)}
.post-table tbody tr:hover{background:#e8eff9}

/* post — numbered steps */
.post-step{display:flex;gap:18px;align-items:flex-start;margin:28px 0}
.post-step-num{flex-shrink:0;width:38px;height:38px;border-radius:50%;background:var(--azure);color:#fff;font-weight:800;font-size:.95rem;display:flex;align-items:center;justify-content:center;margin-top:2px}
.post-step-body{flex:1}
.post-step-body h3{margin-top:0;font-size:1.1rem;color:var(--navy);font-weight:700;margin-bottom:8px}
.post-step-body p{margin-bottom:12px}
.post-step-body ul{margin-bottom:12px}

@media(max-width:600px){.post-stat-row{grid-template-columns:1fr}.post-table{font-size:.85rem}.post-table th,.post-table td{padding:10px 12px}}

/* contact page */
.contact-page{padding-top:74px;background:
  radial-gradient(60% 80% at 88% -10%,var(--ice-2),transparent 60%),
  radial-gradient(46% 60% at 0% 100%,var(--ice),transparent 60%),
  var(--cream)}
.contact-page h1{font-size:clamp(2rem,3.6vw,2.8rem);color:var(--navy);margin-bottom:16px}
.contact-sub{color:var(--muted);font-weight:500;font-size:1.06rem;line-height:1.6;max-width:50ch;margin-bottom:36px}
.contact-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:60px;align-items:start}
.contact-form{display:flex;flex-direction:column;gap:20px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-weight:700;font-size:.85rem;color:var(--navy)}
.form-group input,.form-group select,.form-group textarea{border:1.5px solid var(--line);border-radius:12px;padding:14px 18px;font-family:var(--body);font-size:1rem;font-weight:500;color:var(--ink);background:#fff;transition:border-color .2s,box-shadow .2s}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--azure);box-shadow:0 0 0 3px rgba(31,99,214,.15)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--muted);opacity:.6}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23566889' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:40px;cursor:pointer}
.form-group textarea{resize:vertical;min-height:120px}
.contact-form .btn{align-self:flex-start;margin-top:4px}
.contact-sidebar{display:flex;flex-direction:column;gap:28px}
.contact-card{background:var(--navy);color:#fff;border-radius:22px;padding:34px 30px}
.contact-card h3{font-size:1.4rem;margin-bottom:10px;font-weight:600}
.contact-card p{color:rgba(255,255,255,.8);font-weight:500;margin-bottom:22px;font-size:.97rem}
.contact-card .btn{width:100%;justify-content:center}
.contact-info{padding:28px 30px;background:var(--ice);border-radius:22px}
.contact-info h4{font-family:var(--body);font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:var(--navy);margin-bottom:16px}
.contact-info a,.contact-info div{display:block;margin-bottom:10px;font-weight:500;color:var(--muted);font-size:.97rem}
.contact-info a:hover{color:var(--azure)}
@media(max-width:980px){.contact-grid{grid-template-columns:1fr;gap:40px}}

/* gated download modal */
.gate-modal{display:none;position:fixed;inset:0;z-index:300;align-items:center;justify-content:center}
.gate-modal.open{display:flex}
.gate-backdrop{position:absolute;inset:0;background:rgba(8,21,48,.65);backdrop-filter:blur(6px)}
.gate-card{position:relative;background:#fff;border-radius:22px;padding:40px 36px;max-width:420px;width:90%;text-align:center;box-shadow:0 32px 80px -20px rgba(12,31,71,.4);z-index:2;animation:gateIn .3s ease}
@keyframes gateIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.gate-close{position:absolute;top:14px;right:14px;background:none;border:none;cursor:pointer;color:var(--muted);transition:color .2s}
.gate-close:hover{color:var(--navy)}
.gate-cover{width:140px;height:auto;border-radius:8px;box-shadow:0 8px 24px -8px rgba(12,31,71,.2);margin-bottom:20px;display:block;margin-left:auto;margin-right:auto}
.gate-card h3{font-size:1.5rem;color:var(--navy);margin-bottom:8px;font-weight:700}
.gate-card p{color:var(--muted);font-weight:500;font-size:.95rem;line-height:1.55;margin-bottom:20px}
.gate-card p em{font-style:italic;color:var(--navy);font-weight:600}
.gate-card form{display:flex;flex-direction:column;gap:12px}
.gate-card input[type="email"]{width:100%;padding:14px 16px;border:1.5px solid var(--line);border-radius:11px;font-size:1rem;font-family:var(--body);font-weight:500;transition:border-color .2s;box-sizing:border-box}
.gate-card input[type="email"]:focus{outline:none;border-color:var(--azure)}
.gate-card .btn{width:100%;justify-content:center}

/* podcast inline card */
.podcast-inline{display:flex;align-items:center;gap:16px;margin-top:24px;padding:14px 18px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:14px;transition:background .2s,transform .2s;text-decoration:none}
.podcast-inline:hover{background:rgba(255,255,255,.14);transform:translateY(-2px)}
.podcast-inline img{width:80px;height:80px;object-fit:cover;border-radius:10px;flex:none}
.podcast-inline div{display:flex;flex-direction:column;gap:4px}
.podcast-label{font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--sky)}
.podcast-title{font-size:.92rem;font-weight:600;color:#fff;line-height:1.35}

/* footer social icons */
.foot-social{display:flex;gap:14px;align-items:center}
.foot-social a{color:rgba(255,255,255,.5);transition:color .2s}
.foot-social a:hover{color:#fff}

/* footer */
footer{background:var(--navy-deep);color:rgba(255,255,255,.72);padding:60px 0 36px}
.foot-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;padding-bottom:38px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-grid .logo{color:#fff;margin-bottom:14px;font-size:0;line-height:0;letter-spacing:0;border:none;text-decoration:none;overflow:hidden}
.foot-grid .logo span{color:var(--sky)}
.foot-grid p{font-weight:500;max-width:36ch}
.foot-col h4{font-family:var(--body);font-weight:700;color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:16px}
.foot-col a,.foot-col div{display:block;margin-bottom:10px;font-weight:500;transition:color .2s}
.foot-col a:hover{color:#fff}
.foot-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:24px;font-size:.85rem}

/* sticky cta */
.sticky-cta{position:fixed;left:0;right:0;bottom:0;z-index:90;background:rgba(12,31,71,.97);backdrop-filter:blur(10px);padding:11px 18px;display:none;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 -10px 30px -12px rgba(0,0,0,.4);transform:translateY(110%);transition:transform .35s}
.sticky-cta.show{transform:none}
.sticky-cta .sc-txt{color:#fff;font-weight:700;font-family:var(--display);font-size:.98rem;line-height:1.15}
.sticky-cta .sc-txt small{display:block;font-family:var(--body);font-weight:500;color:var(--sky);font-size:.74rem}
.sticky-cta .btn{padding:12px 18px;font-size:.9rem}

@media(max-width:980px){
  .hero-grid,.res-grid{grid-template-columns:1fr;gap:46px}
  .hero-visual{max-width:440px;margin:0 auto}
  .cards3,.serve-grid,.steps,.tgrid,.cards3.pricing{grid-template-columns:1fr}
  .stat-grid{grid-template-columns:1fr 1fr;gap:34px 24px}
  .pcard:hover{transform:translateY(-6px)}
  .news{padding:46px 28px;border-radius:24px}
  .news-form{flex-direction:column}
  .news-form input{min-width:0;width:100%}
  .news-form .btn{width:100%;text-align:center}
  .nav-links{display:none}
  .menu-btn{display:grid}
}
@media(max-width:760px){
  .nav .nav-cta .btn:not(.menu-btn){display:none}
  .sticky-cta{display:flex}
  .sec{padding:68px 0}
  .book-title{font-size:2rem}
  .hero{padding:48px 0 56px}
  .foot-grid{grid-template-columns:1fr;gap:32px}
  .foot-bottom{flex-direction:column;text-align:center;align-items:center}
  footer{padding-bottom:80px}
  .float-tag{display:none}
  .marquee-track{animation-duration:14s}
  .hero .hero-grid>div:first-child{text-align:center}
  .hero-cta{justify-content:center}
  #resource .res-grid>div:first-child{text-align:center}
  #resource .res-grid .btn{align-self:center;margin:0 auto}
}
.mobile-menu{display:none;position:fixed;inset:0;z-index:200;background:var(--navy);flex-direction:column;align-items:center;justify-content:center;gap:24px}
.mobile-menu.open{display:flex}
.mobile-menu a{color:#fff;font-family:var(--display);font-weight:600;font-size:1.6rem}
.mobile-menu .close{position:absolute;top:22px;right:22px;background:none;border:none;color:#fff;cursor:pointer}
