*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,sans-serif;background:hsl(240,60%,95%);color:hsl(260,10%,10%);line-height:1.6;-webkit-font-smoothing:antialiased}
a{color:hsl(282,100%,41%);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;display:block}
details>summary{list-style:none}
details>summary::-webkit-details-marker{display:none}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;height:64px;transition:all .3s ease;background:transparent;border-bottom:1px solid transparent}
.nav.scrolled{background:hsl(240,60%,95%,0.95);backdrop-filter:blur(20px);border-bottom:1px solid hsl(260,20%,82%);box-shadow:0 1px 8px rgba(0,0,0,.06)}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 1rem;height:100%;display:flex;align-items:center;justify-content:space-between}
@media(min-width:640px){.nav-inner{padding:0 1.5rem}}
@media(min-width:1024px){.nav-inner{padding:0 2.5rem}}
.nav-logo img{height:80px;transition:filter .3s;filter:brightness(0) invert(1)}
.nav.scrolled .nav-logo img{filter:none}
.nav-links{display:flex;align-items:center;gap:1.25rem}
.nav-signin{font-size:.875rem;font-weight:500;color:rgba(255,255,255,.8);text-decoration:none;transition:color .2s}
.nav.scrolled .nav-signin{color:hsl(260,8%,42%)}
.nav-signin:hover{color:#fff}
.nav.scrolled .nav-signin:hover{color:hsl(260,10%,10%)}
.btn-glow{display:inline-flex;align-items:center;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:600;font-size:.875rem;padding:.5rem 1rem;border-radius:9999px;border:none;cursor:pointer;text-decoration:none;box-shadow:0 4px 14px hsl(282,100%,41%,.3),0 1px 3px hsl(282,100%,41%,.15);transition:box-shadow .3s ease-out,transform .15s ease-out;animation:pulse-cta 2s ease-in-out infinite}
.btn-glow:hover{box-shadow:0 6px 20px hsl(282,100%,41%,.4),0 2px 6px hsl(282,100%,41%,.2);color:#fff;text-decoration:none}
.btn-glow:active{transform:scale(.97)}
@keyframes pulse-cta{0%,100%{box-shadow:0 4px 14px hsl(282,100%,41%,.3),0 0 0 0 hsl(282,100%,41%,.35)}50%{box-shadow:0 4px 14px hsl(282,100%,41%,.3),0 0 0 8px hsl(282,100%,41%,0)}}

/* HERO */
.hero{position:relative;min-height:100svh;overflow:hidden}
.hero-bg-img{position:absolute;inset:0;z-index:0;width:100%;height:100%;object-fit:cover;object-position:center top}
.hero-overlay-left{position:absolute;inset:0;z-index:1;background:linear-gradient(to right,rgba(26,10,48,.78) 0%,rgba(26,10,48,.45) 45%,transparent 100%);display:none}
.hero-overlay-bottom{position:absolute;inset-x:0;bottom:0;z-index:1;height:30%;background:linear-gradient(to top,hsl(240,60%,95%) 0%,rgba(240,242,255,.6) 50%,transparent 100%);display:none}
.hero-overlay-mobile{position:absolute;inset:0;z-index:1;background:linear-gradient(to bottom,rgba(26,10,48,.72) 0%,rgba(26,10,48,.52) 55%,hsl(240,60%,95%) 100%)}
@media(min-width:1024px){.hero-overlay-left{display:block}.hero-overlay-bottom{display:block}.hero-overlay-mobile{display:none}}

/* DESKTOP HERO */
.hero-desktop{display:none;position:relative;z-index:2;height:100svh;flex-direction:column}
@media(min-width:1024px){.hero-desktop{display:flex}}
.hero-spacer{height:80px;flex-shrink:0}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.9);backdrop-filter:blur(4px);color:#1a0a30;font-size:11px;font-weight:500;padding:6px 14px;border-radius:9999px;box-shadow:0 2px 12px rgba(0,0,0,.12);margin:0 3.5rem 1.5rem;width:fit-content}
.badge-dot{width:8px;height:8px;border-radius:50%;background:hsl(282,100%,41%);animation:bdot 2s infinite}
@keyframes bdot{0%,100%{opacity:1}50%{opacity:.4}}
.hero-content{flex:1;display:flex;flex-direction:row;align-items:center;padding:0 3.5rem;gap:2rem}
.hero-left{width:55%;padding-right:3rem}
.hero-h1{font-family:'Barlow Condensed',system-ui,sans-serif;font-weight:900;text-transform:uppercase;color:#fff;line-height:.88;letter-spacing:-.02em;font-size:clamp(2.8rem,8vw,8rem);margin-bottom:1.5rem}
.hero-indent{margin-left:.55em;display:inline-block}
.hero-subtitle{color:rgba(255,255,255,.75);font-size:.875rem;text-transform:uppercase;letter-spacing:.12em;line-height:1.65;max-width:400px}
.hero-right{width:45%;max-width:380px;margin-left:auto;display:flex;flex-direction:column;gap:.75rem}
.hero-cta-bar{flex-shrink:0;padding:1rem 2rem 2rem}
.hero-cta-inner{max-width:700px;margin:0 auto;display:flex;flex-direction:column;align-items:center}
.hero-scan-form{display:flex;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.18);border-radius:9999px;padding:5px 5px 5px 20px;max-width:560px;width:100%;gap:.5rem;backdrop-filter:blur(8px)}
.hero-input{flex:1;height:48px;border:none;background:transparent;color:#fff;font-size:.95rem;font-family:'Inter',sans-serif;outline:none;min-width:0}
.hero-input::placeholder{color:rgba(255,255,255,.4)}
.btn-hero{height:48px;padding:0 1.5rem;border-radius:9999px;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:.9rem;border:none;cursor:pointer;white-space:nowrap;box-shadow:0 4px 14px hsl(282,100%,41%,.4);transition:box-shadow .2s,transform .15s;flex-shrink:0}
.btn-hero:hover{box-shadow:0 6px 20px hsl(282,100%,41%,.5);transform:translateY(-1px)}
.hero-footnote{display:flex;align-items:center;gap:1.25rem;margin-top:.75rem;font-size:11px;color:rgba(255,255,255,.5)}

/* MOBILE HERO */
.hero-mobile{display:flex;flex-direction:column;align-items:center;position:relative;z-index:2;min-height:100svh;padding:6rem 1.25rem 2.5rem}
@media(min-width:1024px){.hero-mobile{display:none}}
.hero-mobile .hero-badge{margin:0 0 1.25rem}
.hero-mobile-h1{font-family:'Barlow Condensed',system-ui,sans-serif;font-weight:900;text-transform:uppercase;color:#fff;line-height:.9;letter-spacing:-.02em;text-align:center;font-size:clamp(2.6rem,12vw,4.5rem);margin-bottom:1rem}
.hero-mobile-sub{color:rgba(255,255,255,.7);font-size:.8125rem;text-align:center;line-height:1.65;max-width:320px;margin-bottom:1.5rem}
.hero-mobile-scan{width:100%;max-width:360px;display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}
.hero-mobile-input{width:100%;height:50px;border-radius:12px;border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.08);backdrop-filter:blur(8px);color:#fff;font-size:.9rem;font-family:'Inter',sans-serif;padding:0 1.1rem;outline:none}
.hero-mobile-input::placeholder{color:rgba(255,255,255,.4)}
.btn-hero-mobile{width:100%;height:50px;border-radius:12px;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:.9rem;border:none;cursor:pointer;box-shadow:0 6px 24px hsl(282,100%,41%,.4);animation:pulse-cta 2s ease-in-out infinite}
.hero-mobile-note{font-size:11px;color:rgba(255,255,255,.45);text-align:center;margin-bottom:1.5rem}

/* DASHBOARD CARDS (white, on hero) */
.card-white{background:rgba(255,255,255,.95);backdrop-filter:blur(12px);border-radius:1rem;padding:1.25rem;box-shadow:0 2px 20px rgba(0,0,0,.07)}
.card-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.65rem}
.card-icon{width:24px;height:24px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.card-label{font-size:11px;font-weight:500;color:rgba(26,10,48,.45);letter-spacing:.03em}
.card-title{font-size:.875rem;font-weight:600;color:#1a0a30}
.score-num{font-size:1.75rem;font-weight:700;color:#1a0a30;line-height:1;font-variant-numeric:tabular-nums}
.score-up{font-size:11px;color:#10b981;font-weight:600}
.score-denom{font-size:9px;color:rgba(26,10,48,.3)}
.bar-row{display:flex;align-items:center;justify-content:space-between;font-size:11px;margin-bottom:.375rem}
.bar-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-right:6px}
.bar-name{color:rgba(26,10,48,.55);display:flex;align-items:center}
.bar-val{font-weight:600;color:#1a0a30;font-variant-numeric:tabular-nums}
.amber-big{font-size:1.25rem;font-weight:700;color:#f59e0b;font-variant-numeric:tabular-nums}

/* SECTIONS (light bg) */
.section{padding:4rem 1.5rem}
.section-inner{max-width:1000px;margin:0 auto}
.section-alt{background:rgba(255,255,255,.5);border-top:1px solid hsl(260,20%,82%);border-bottom:1px solid hsl(260,20%,82%)}
.eyebrow{font-size:.7rem;font-weight:700;color:hsl(282,100%,41%);text-transform:uppercase;letter-spacing:.1em;text-align:center;margin-bottom:.6rem}
.section-title{font-family:'Sora',system-ui,sans-serif;font-size:clamp(1.5rem,3.5vw,2.25rem);font-weight:800;color:hsl(260,10%,10%);margin-bottom:.75rem;text-align:center;letter-spacing:-.02em}
.section-sub{font-size:.9375rem;color:hsl(260,8%,42%);max-width:560px;margin:0 auto 2.5rem;text-align:center;line-height:1.7}
.center{text-align:center}
.mt-2{margin-top:2rem}
.btn-cta-lg{display:inline-flex;align-items:center;gap:.4rem;height:52px;padding:0 2rem;border-radius:9999px;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:.95rem;text-decoration:none;box-shadow:0 4px 14px hsl(282,100%,41%,.3);transition:box-shadow .2s,transform .15s}
.btn-cta-lg:hover{box-shadow:0 6px 20px hsl(282,100%,41%,.4);transform:translateY(-1px);color:#fff;text-decoration:none}

/* INSIGHT */
.insight-stat{background:rgba(124,0,211,.06);border:1px solid rgba(124,0,211,.18);border-radius:16px;padding:1.35rem 1.5rem;margin-bottom:2.25rem;display:flex;gap:1.1rem;align-items:flex-start}
.stat-icon{width:42px;height:42px;border-radius:12px;background:rgba(124,0,211,.1);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0;margin-top:2px}
.stat-label{font-size:.68rem;font-weight:700;color:hsl(282,100%,41%);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem}
.stat-text{color:hsl(260,10%,10%);font-weight:700;font-size:1rem;line-height:1.5;margin-bottom:.35rem}
.stat-why{color:hsl(260,8%,42%);font-size:.875rem;line-height:1.65}
.two-col{display:grid;gap:2rem}
@media(min-width:640px){.two-col{grid-template-columns:1fr 1fr}}
.col-title{font-size:.68rem;font-weight:700;color:hsl(260,8%,42%);text-transform:uppercase;letter-spacing:.08em;display:flex;align-items:center;gap:.5rem;margin-bottom:.9rem}
.col-icon{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:.72rem;flex-shrink:0}
.col-icon-p{background:rgba(124,0,211,.1)}
.col-icon-r{background:rgba(239,68,68,.1)}
.query-item{display:flex;align-items:flex-start;gap:.55rem;background:rgba(124,0,211,.04);border:1px solid rgba(124,0,211,.12);border-radius:10px;padding:.65rem .85rem;margin-bottom:.45rem;font-size:.85rem;color:hsl(260,10%,10%);font-style:italic;line-height:1.5}
.query-arr{color:hsl(282,100%,41%);flex-shrink:0;margin-top:2px;font-style:normal}
.problem-item{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.65rem;font-size:.875rem;color:hsl(260,8%,42%);line-height:1.55}
.x-badge{width:20px;height:20px;border-radius:50%;background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);color:#ef4444;font-size:.6rem;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}

/* FEATURE CARDS */
.cards{display:grid;gap:1.25rem}
@media(min-width:640px){.cards{grid-template-columns:repeat(3,1fr)}}
.feat-card{background:#fff;border:1px solid hsl(260,20%,82%);border-radius:16px;padding:1.5rem;transition:box-shadow .2s,border-color .2s}
.feat-card:hover{box-shadow:0 4px 24px rgba(124,0,211,.1);border-color:rgba(124,0,211,.25)}
.feat-icon{width:44px;height:44px;border-radius:12px;background:rgba(124,0,211,.08);display:flex;align-items:center;justify-content:center;margin-bottom:.9rem;font-size:1.15rem}
.feat-card h3{font-family:'Sora',system-ui,sans-serif;font-size:.95rem;font-weight:700;color:hsl(260,10%,10%);margin-bottom:.4rem}
.feat-card p{font-size:.85rem;color:hsl(260,8%,42%);line-height:1.65}

/* STEPS */
.steps{display:grid;gap:2.5rem;text-align:center}
@media(min-width:640px){.steps{grid-template-columns:repeat(3,1fr)}}
.step-num{width:52px;height:52px;border-radius:50%;background:rgba(124,0,211,.08);border:2px solid rgba(124,0,211,.2);color:hsl(282,100%,41%);font-weight:800;font-size:1.1rem;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem}
.step h3{font-family:'Sora',system-ui,sans-serif;font-size:1rem;font-weight:700;color:hsl(260,10%,10%);margin-bottom:.4rem}
.step p{font-size:.875rem;color:hsl(260,8%,42%);line-height:1.65}

/* FAQ */
.faq-section{background:rgba(255,255,255,.5);border-top:1px solid hsl(260,20%,82%)}
.faq-list{display:flex;flex-direction:column;gap:.5rem;max-width:740px;margin:0 auto}
.faq-item{background:#fff;border:1px solid hsl(260,20%,82%);border-radius:12px;overflow:hidden;transition:border-color .2s}
.faq-item:hover{border-color:rgba(124,0,211,.3)}
.faq-item summary{padding:1.1rem 1.35rem;cursor:pointer;font-family:'Sora',system-ui,sans-serif;font-weight:600;color:hsl(260,10%,10%);font-size:.92rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;user-select:none}
.faq-toggle{width:24px;height:24px;border-radius:50%;border:1px solid hsl(260,20%,82%);color:hsl(260,8%,42%);font-size:1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .2s,background .2s,border-color .2s}
.faq-item[open] .faq-toggle{transform:rotate(45deg);background:rgba(124,0,211,.08);border-color:rgba(124,0,211,.3);color:hsl(282,100%,41%)}
.faq-answer{padding:.25rem 1.35rem 1.1rem;font-size:.875rem;color:hsl(260,8%,42%);line-height:1.8;border-top:1px solid hsl(260,20%,82%)}

/* FINAL CTA */
.final-cta{padding:6rem 1.5rem;text-align:center;background:linear-gradient(180deg,hsl(240,60%,95%) 0%,hsl(270,60%,93%) 100%);border-top:1px solid hsl(260,20%,82%)}
.final-cta-inner{max-width:560px;margin:0 auto}
.final-h2{font-family:'Barlow Condensed',system-ui,sans-serif;font-weight:900;text-transform:uppercase;font-size:clamp(2rem,5vw,3.5rem);color:hsl(260,10%,10%);letter-spacing:-.02em;line-height:.9;margin-bottom:1rem}
.final-h2 em{font-style:normal;color:hsl(282,100%,41%)}
.final-sub{color:hsl(260,8%,42%);margin-bottom:2.25rem;font-size:.9375rem;line-height:1.7}
.final-form{display:flex;background:#fff;border:1px solid hsl(260,20%,82%);border-radius:9999px;padding:5px 5px 5px 1.25rem;max-width:480px;margin:0 auto;gap:.5rem;box-shadow:0 2px 16px rgba(0,0,0,.06)}
@media(max-width:480px){.final-form{border-radius:12px;flex-direction:column;padding:.5rem}}
.final-input{flex:1;height:44px;border:none;background:transparent;color:hsl(260,10%,10%);font-size:.875rem;font-family:'Inter',sans-serif;outline:none;min-width:0}
@media(max-width:480px){.final-input{padding:0 .75rem}}
.final-input::placeholder{color:hsl(260,8%,42%)}
.btn-final{height:44px;padding:0 1.35rem;border-radius:9999px;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:.875rem;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0;box-shadow:0 2px 12px hsl(282,100%,41%,.35)}
@media(max-width:480px){.btn-final{border-radius:8px;height:46px}}

/* RELATED */
.related{padding:2.5rem 1.5rem;border-top:1px solid hsl(260,20%,82%)}
.related-inner{max-width:1000px;margin:0 auto;text-align:center}
.related-label{font-size:.7rem;color:hsl(260,8%,42%);font-weight:700;text-transform:uppercase;letter-spacing:.07em;margin-bottom:1rem}
.related-links{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}
.related-link{padding:.35rem .9rem;border-radius:9999px;border:1px solid hsl(260,20%,82%);font-size:.78rem;color:hsl(260,8%,42%);text-decoration:none;background:#fff;transition:border-color .15s,color .15s,box-shadow .15s}
.related-link:hover{border-color:rgba(124,0,211,.3);color:hsl(282,100%,41%);box-shadow:0 2px 8px rgba(124,0,211,.1)}

/* FOOTER */
.footer{padding:3rem 1.5rem;border-top:1px solid hsl(260,20%,82%)}
.footer-inner{max-width:1000px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:.5rem}
.footer img{height:64px}
.footer-links{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}
.footer-links a{font-size:.78rem;color:hsl(260,8%,42%);text-decoration:none;transition:color .15s}
.footer-links a:hover{color:hsl(260,10%,10%)}
.footer-copy{max-width:1000px;margin:0 auto;font-size:.73rem;color:hsl(260,8%,42%);text-align:center}

@media(max-width:640px){.section{padding:2.5rem 1rem}.hero-mobile{padding:5.5rem 1.25rem 2rem}}

/* MONEY PAGE ARTICLE */
.money-hero{padding:7rem 1.5rem 3.5rem;background:linear-gradient(135deg,hsl(260,40%,12%) 0%,hsl(282,60%,20%) 100%);text-align:center}
.money-hero-eyebrow{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);font-size:.72rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;padding:5px 14px;border-radius:9999px;margin-bottom:1.25rem}
.money-hero h1{font-family:'Barlow Condensed',system-ui,sans-serif;font-weight:900;text-transform:uppercase;color:#fff;font-size:clamp(2.2rem,6vw,4.5rem);line-height:.9;letter-spacing:-.02em;margin-bottom:1rem}
.money-hero-sub{color:rgba(255,255,255,.7);font-size:1rem;max-width:580px;margin:0 auto 2rem;line-height:1.7}
.money-hero-form{display:flex;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.2);border-radius:9999px;padding:5px 5px 5px 20px;max-width:500px;margin:0 auto;gap:.5rem}
.money-hero-input{flex:1;height:46px;border:none;background:transparent;color:#fff;font-size:.9rem;font-family:'Inter',sans-serif;outline:none}
.money-hero-input::placeholder{color:rgba(255,255,255,.4)}
.money-hero-btn{height:46px;padding:0 1.5rem;border-radius:9999px;background:hsl(282,100%,41%);color:#fff;font-family:'Inter',sans-serif;font-weight:700;font-size:.875rem;border:none;cursor:pointer;white-space:nowrap;flex-shrink:0}
.money-note{font-size:11px;color:rgba(255,255,255,.4);margin-top:.75rem;text-align:center}

.money-article{max-width:820px;margin:0 auto;padding:3.5rem 1.5rem}
.money-article h2{font-family:'Sora',system-ui,sans-serif;font-size:clamp(1.3rem,2.5vw,1.75rem);font-weight:800;color:hsl(260,10%,10%);margin:2.75rem 0 .9rem;letter-spacing:-.02em;padding-bottom:.5rem;border-bottom:2px solid rgba(124,0,211,.12)}
.money-article h3{font-family:'Sora',system-ui,sans-serif;font-size:1rem;font-weight:700;color:hsl(260,10%,10%);margin:1.5rem 0 .5rem}
.money-article p{color:hsl(260,8%,32%);line-height:1.8;margin-bottom:1rem;font-size:.9375rem}
.money-article ul,.money-article ol{padding-left:1.4rem;margin-bottom:1rem}
.money-article li{color:hsl(260,8%,32%);line-height:1.8;font-size:.9375rem;margin-bottom:.3rem}
.money-article strong{color:hsl(260,10%,10%)}
.money-article em{font-style:italic;color:hsl(260,8%,42%)}

.money-lead{background:rgba(124,0,211,.04);border-left:3px solid hsl(282,100%,41%);padding:1.25rem 1.5rem;border-radius:0 12px 12px 0;margin-bottom:2rem}
.money-lead p{margin-bottom:.6rem;font-size:1rem}
.money-lead p:last-child{margin-bottom:0}

.money-toc{background:#fff;border:1px solid hsl(260,20%,82%);border-radius:12px;padding:1.25rem 1.5rem;margin-bottom:2.5rem}
.money-toc-label{font-size:.68rem;font-weight:700;color:hsl(282,100%,41%);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem}
.money-toc ol{padding-left:1.2rem;margin:0}
.money-toc li{font-size:.875rem;color:hsl(260,8%,42%);margin-bottom:.4rem}
.money-toc a{color:hsl(282,100%,41%);text-decoration:none}
.money-toc a:hover{text-decoration:underline}

.m-signal{display:flex;gap:1.25rem;margin-bottom:2rem;padding:1.25rem;background:#fff;border:1px solid hsl(260,20%,82%);border-radius:14px}
.m-signal-n{width:36px;height:36px;border-radius:50%;background:hsl(282,100%,41%);color:#fff;font-weight:800;font-size:.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:3px}
.m-signal-body h3{margin-top:0}

.m-step{background:#fff;border:1px solid hsl(260,20%,82%);border-radius:14px;padding:1.35rem 1.5rem;margin-bottom:1.25rem}
.m-step-hd{font-family:'Sora',system-ui,sans-serif;font-weight:700;color:hsl(260,10%,10%);font-size:1rem;margin-bottom:.75rem;display:flex;align-items:center;gap:.75rem}
.m-step-badge{background:hsl(282,100%,41%);color:#fff;font-size:.7rem;font-weight:700;padding:3px 10px;border-radius:9999px;white-space:nowrap}

.m-example{background:rgba(124,0,211,.03);border:1px solid rgba(124,0,211,.15);border-radius:14px;padding:1.35rem 1.5rem;margin-bottom:1.25rem}
.m-example-label{font-size:.7rem;font-weight:700;color:hsl(282,100%,41%);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.6rem}

.m-timeline{display:flex;gap:1.25rem;margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid hsl(260,20%,82%)}
.m-timeline:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}
.m-tl-period{font-family:'Sora',system-ui,sans-serif;font-weight:700;color:hsl(282,100%,41%);font-size:.8rem;width:90px;flex-shrink:0;padding-top:3px;line-height:1.4}
.m-tl-content p{margin-bottom:.4rem}

.m-mistake{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid hsl(260,20%,82%)}
.m-mistake:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}
.m-mistake h3{color:hsl(282,100%,41%);margin-top:0}

.m-callout{background:hsl(282,100%,41%);color:#fff;border-radius:16px;padding:2rem;text-align:center;margin:2.5rem 0}
.m-callout h3{font-family:'Sora',system-ui,sans-serif;font-weight:800;font-size:1.25rem;color:#fff;margin-bottom:.5rem}
.m-callout p{color:rgba(255,255,255,.85);margin-bottom:1.25rem;font-size:.9375rem}
.m-callout-btn{display:inline-flex;align-items:center;height:48px;padding:0 1.75rem;border-radius:9999px;background:#fff;color:hsl(282,100%,41%);font-family:'Inter',sans-serif;font-weight:700;font-size:.9rem;text-decoration:none;transition:box-shadow .2s}
.m-callout-btn:hover{box-shadow:0 4px 20px rgba(0,0,0,.2);color:hsl(282,100%,41%);text-decoration:none}

.m-platform-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin:1.25rem 0}
.m-platform-card{background:#fff;border:1px solid hsl(260,20%,82%);border-radius:12px;padding:1rem 1.25rem}
.m-platform-card h4{font-size:.875rem;font-weight:700;color:hsl(260,10%,10%);margin-bottom:.4rem}
.m-platform-card p{font-size:.8125rem;color:hsl(260,8%,42%);margin-bottom:0;line-height:1.6}

/* HUB PAGE CITY GRID */
.city-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.5rem;margin-top:1.5rem}
.city-link{padding:.6rem 1rem;background:#fff;border:1px solid hsl(260,20%,82%);border-radius:10px;font-size:.8125rem;color:hsl(260,8%,42%);text-decoration:none;display:flex;align-items:center;gap:.4rem;transition:border-color .15s,color .15s}
.city-link:hover{border-color:rgba(124,0,211,.3);color:hsl(282,100%,41%)}
.city-link-arrow{opacity:.4;font-size:.75rem}

/* DYNAMIC INTRO */
.dyn-intro{background:rgba(124,0,211,.04);border:1px solid rgba(124,0,211,.12);border-radius:12px;padding:1rem 1.25rem;margin-bottom:2.5rem;font-size:.9rem;color:hsl(260,8%,32%);line-height:1.7}
.dyn-intro strong{color:hsl(282,100%,41%)}

@media(max-width:640px){.money-article{padding:2rem 1rem}.m-signal{flex-direction:column;gap:.75rem}.m-timeline{flex-direction:column;gap:.4rem}.m-tl-period{width:auto}}