:root {
      --gold:#1B3A5C;--gold-light:#4A7BA7;--gold-dark:#0F2440;
      --accent:#D4AF37;--accent-dark:#96792F;--accent-pale:#F5EDD4;--ink:#1a1a2e;--ink-soft:#2a2a2a;--body:#64748b;--subtle:#94a3b8;--rule:#e8e8e8;--bg:#FDFCFA;--bg-warm:#F8F7F4;--white:#fff;
      --serif:'Libre Baskerville',Georgia,serif;--sans:'DM Sans',-apple-system,sans-serif;
      --green:#3A8A5C;--green-pale:#E8F5EC;--blue:#3A6B8A;--blue-pale:#E5EFF6;--red:#B84A3E;--red-pale:#FCEAE8;--purple:#6B4F8A;--purple-pale:#F0E9F6;--gold-pale:#E6EEF5;
      --sidebar-w:260px;--sidebar-w-collapsed:72px;--header-h:64px;
    }
    .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
    *,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
    html{scroll-behavior:smooth;font-size:16px}
    body{font-family:var(--sans);color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;overflow-x:hidden}
    ::selection{background:var(--gold-light);color:var(--white)}
    .js-ready .reveal{opacity:0;transform:translateY(20px);transition:opacity .7s ease,transform .7s ease}
    .reveal.visible{opacity:1;transform:translateY(0)}
    .reveal-delay-1{transition-delay:.1s}.reveal-delay-2{transition-delay:.2s}.reveal-delay-3{transition-delay:.3s}.reveal-delay-4{transition-delay:.4s}.reveal-delay-5{transition-delay:.5s}

    /* CORPORATE POLISH */
    .lp-card{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:28px;transition:all .3s ease}
    .lp-card:hover{border-color:rgba(27,58,92,.2);box-shadow:0 8px 30px rgba(27,58,92,.08);transform:translateY(-3px)}
    .lp-dark-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:8px;padding:28px;transition:all .3s ease}
    .lp-dark-card:hover{background:rgba(255,255,255,.07);border-color:rgba(212,175,55,.2);transform:translateY(-2px)}
    .btn-primary{transition:all .3s ease}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(27,58,92,.2)}
    .btn-secondary:hover svg{transform:translateX(4px);transition:transform .3s}
    .lp-section-divider{width:60px;height:3px;background:linear-gradient(90deg,var(--gold),var(--accent));border-radius:2px;margin-top:16px}
    .lp-stat{text-align:center;position:relative}
    .lp-stat::after{content:'';position:absolute;right:0;top:20%;height:60%;width:1px;background:var(--rule)}
    .lp-stat:last-child::after{display:none}
    .lp-step-num{width:64px;height:64px;border-radius:50%;background:var(--gold);color:var(--white);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:28px;font-weight:700;margin:0 auto 20px;box-shadow:0 4px 16px rgba(27,58,92,.15);transition:transform .3s}
    .lp-step-num:hover{transform:scale(1.08)}
    .lp-icon-box{width:44px;height:44px;border-radius:10px;background:var(--gold-pale);display:flex;align-items:center;justify-content:center;margin-bottom:16px;transition:transform .3s}
    .lp-card:hover .lp-icon-box{transform:scale(1.08)}
    .lp-testimonial{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:28px;transition:all .3s;position:relative}
    .lp-testimonial::before{content:'\201C';position:absolute;top:16px;right:24px;font-family:var(--serif);font-size:60px;color:var(--gold-pale);line-height:1}
    .lp-testimonial:hover{box-shadow:0 8px 30px rgba(27,58,92,.06)}

    /* HEADER */
    .site-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:all .4s;background:rgba(253,252,250,0)}
    .site-header.scrolled{background:rgba(253,252,250,.96);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.06)}
    .header-inner{max-width:1320px;margin:0 auto;padding:24px 48px;display:flex;justify-content:space-between;align-items:center;transition:padding .4s}
    .site-header.scrolled .header-inner{padding:16px 48px}
    .wordmark{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--ink);text-decoration:none;letter-spacing:-.02em;display:flex;align-items:center;gap:14px}
    .wordmark-mark{width:36px;height:36px;background:transparent;display:flex;align-items:center;justify-content:center}
    .wordmark-mark svg{width:20px;height:20px}
    .wordmark em{font-style:italic;color:var(--accent);font-weight:400}
    .header-nav{display:flex;align-items:center;gap:28px}
    .header-nav a{font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color .3s;position:relative}
    .header-nav a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--gold);transition:width .3s}
    .header-nav a:hover{color:var(--gold-dark)}.header-nav a:hover::after{width:100%}
    .header-cta{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--white)!important;background:var(--ink);padding:12px 28px;text-decoration:none;transition:all .3s}
    .header-cta::after{display:none!important}.header-cta:hover{background:var(--gold-dark)!important;color:var(--white)!important}
    .mobile-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px}
    .mobile-toggle span{display:block;width:22px;height:1.5px;background:var(--ink);margin:5px 0;transition:all .3s}
    .mobile-overlay{display:none;position:fixed;inset:0;background:var(--bg);z-index:99;padding:100px 48px 48px;flex-direction:column;overflow-y:auto}
    .mobile-overlay.open{display:flex}
    .mobile-overlay a{font-family:var(--serif);font-size:32px;font-weight:400;color:var(--ink);text-decoration:none;padding:20px 0;border-bottom:1px solid var(--rule);transition:color .3s}
    .mobile-overlay a:hover{color:var(--gold)}
    @media(max-width:900px){#pricing .pricing-inner>div:nth-child(2){grid-template-columns:1fr!important}#rights-preview>div:nth-child(2){grid-template-columns:1fr!important}#capabilities .capabilities-inner>div:last-child{grid-template-columns:1fr!important}.header-nav{display:none}.mobile-toggle{display:block}.header-inner{padding:20px 24px}.site-header.scrolled .header-inner{padding:14px 24px}}

    /* HERO */
    .hero{min-height:100vh;display:flex;align-items:center;padding:140px 48px 100px;position:relative}
    .hero-inner{max-width:1320px;margin:0 auto;width:100%;display:grid;grid-template-columns:1fr 420px;gap:80px;align-items:center}
    .hero-eyebrow{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:28px;display:flex;align-items:center;gap:12px}
    .hero-eyebrow::before{content:'';width:40px;height:1px;background:var(--gold)}
    .hero h1{font-family:var(--serif);font-size:clamp(36px,4.5vw,58px);font-weight:700;line-height:1.15;color:var(--ink);letter-spacing:-.03em;margin-bottom:32px}
    .hero h1 i{font-style:italic;color:var(--accent)}
    .hero-body{font-size:18px;line-height:1.75;color:var(--body);max-width:540px;margin-bottom:48px;font-weight:300}
    .hero-actions{display:flex;gap:20px;align-items:center;flex-wrap:wrap}
    .btn-primary{display:inline-block;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:var(--gold);color:var(--white);padding:16px 36px;text-decoration:none;transition:all .35s}
    .btn-primary:hover{background:var(--gold-dark);box-shadow:0 8px 24px rgba(27,58,92,.25);transform:translateY(-2px)}
    .btn-secondary{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);text-decoration:none;transition:color .3s}
    .btn-secondary:hover{color:var(--gold)}.btn-secondary svg{transition:transform .3s}.btn-secondary:hover svg{transform:translateX(4px)}
    .hero-sidebar{border-left:1px solid var(--rule);padding-left:48px}
    .hero-stat{padding:28px 0;border-bottom:1px solid var(--rule)}.hero-stat:last-child{border-bottom:none}
    .hero-stat-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--subtle);margin-bottom:8px}
    .hero-stat-value{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink);letter-spacing:-.01em}
    @media(max-width:1000px){.hero{padding:140px 24px 80px}.hero-inner{grid-template-columns:1fr;gap:48px}.hero-sidebar{border-left:none;padding-left:0;display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--rule)}.hero-stat{border-bottom:none;border-right:1px solid var(--rule);padding:24px 20px}.hero-stat:nth-child(2n){border-right:none}}

    /* SECTIONS */
    .notice-strip{border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:18px 48px;text-align:center;background:var(--bg-warm)}
    .notice-strip p{font-family:var(--sans);font-size:13px;color:var(--body);max-width:800px;margin:0 auto;line-height:1.6}
    .notice-strip strong{color:var(--gold-dark);font-weight:600}
    .section-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;display:flex;align-items:center;gap:12px}
    .section-label::before{content:'';width:28px;height:1px;background:var(--gold)}
    .philosophy{padding:120px 48px;max-width:1320px;margin:0 auto}
    .philosophy-header{display:grid;grid-template-columns:1fr 1fr;gap:80px;margin-bottom:100px;align-items:end}
    .philosophy-title{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.15;color:var(--ink);letter-spacing:-.025em}
    .philosophy-intro{font-size:17px;line-height:1.8;color:var(--body);font-weight:300;align-self:end;padding-bottom:8px}
    .pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--rule)}
    .pillar{padding:40px 32px 40px 0;border-right:1px solid var(--rule);position:relative}.pillar:last-child{border-right:none}
    .pillar-number{font-family:var(--serif);font-size:56px;font-weight:400;color:var(--gold-light);opacity:.35;line-height:1;margin-bottom:20px;letter-spacing:-.04em}
    .pillar h3{font-family:var(--sans);font-size:16px;font-weight:600;color:var(--ink);margin-bottom:14px;letter-spacing:-.01em}
    .pillar p{font-size:14px;line-height:1.75;color:var(--body);font-weight:300}
    @media(max-width:1000px){.philosophy{padding:80px 24px}.philosophy-header{grid-template-columns:1fr;gap:24px;margin-bottom:60px}.pillars{grid-template-columns:1fr 1fr}.pillar{border-bottom:1px solid var(--rule);padding:32px 24px 32px 0}.pillar:nth-child(2n){border-right:none;padding-left:24px}}
    @media(max-width:600px){.pillars{grid-template-columns:1fr}.vDash .ag3{grid-template-columns:1fr!important}.pillar{border-right:none;padding:32px 0}}
    .capabilities{background:var(--ink);color:var(--white);padding:120px 48px;position:relative;overflow:hidden}
    .capabilities::before{content:'';position:absolute;top:0;right:0;width:40%;height:100%;background:linear-gradient(135deg,rgba(27,58,92,.06),transparent);pointer-events:none}
    .capabilities-inner{max-width:1320px;margin:0 auto;position:relative}
    .capabilities .section-label{color:var(--gold-light)}.capabilities .section-label::before{background:var(--gold-light)}
    .capabilities-title{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.12;letter-spacing:-.025em;color:var(--white);max-width:600px;margin-bottom:80px}
    .cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid rgba(255,255,255,.12)}
    .cap-item{padding:44px 40px 44px 0;border-bottom:1px solid rgba(255,255,255,.12);border-right:1px solid rgba(255,255,255,.12);position:relative;transition:background .4s}
    .cap-item:nth-child(2n){border-right:none;padding-left:40px;padding-right:0}
    .cap-item:hover{background:rgba(27,58,92,.04)}
    .cap-item-number{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.12em;color:var(--gold-light);margin-bottom:16px}
    .cap-item h3{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--white);margin-bottom:14px;letter-spacing:-.01em}
    .cap-item p{font-size:15px;line-height:1.75;color:rgba(255,255,255,.6);font-weight:300}
    @media(max-width:900px){.capabilities{padding:80px 24px}.cap-grid{grid-template-columns:1fr}.cap-item{border-right:none!important;padding:36px 0!important}}

    /* PRICING */
    .pricing-section{background:var(--bg-warm);padding:120px 48px}
    .pricing-inner{max-width:1320px;margin:0 auto}
    .pricing-header{text-align:center;margin-bottom:80px}
    .pricing-title{font-family:var(--serif);font-size:clamp(28px,3.5vw,44px);font-weight:700;line-height:1.12;letter-spacing:-.025em;color:var(--ink)}
    .pricing-toggle{display:flex;justify-content:center;gap:0;margin-top:24px;border:1px solid var(--rule);border-radius:6px;overflow:hidden;width:fit-content;margin-left:auto;margin-right:auto}
    .pricing-toggle button{padding:10px 24px;font-family:var(--sans);font-size:13px;font-weight:500;border:none;cursor:pointer;background:var(--white);color:var(--body);transition:all .2s}
    .pricing-toggle button.act{background:var(--gold);color:var(--white);font-weight:600}
    .pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--rule);background:var(--white)}
    .price-col{padding:48px 40px;border-right:1px solid var(--rule);position:relative;transition:background .35s}
    .price-col:last-child{border-right:none}
    .price-col:hover{background:rgba(253,252,250,1)}.price-col.featured{background:var(--ink);color:var(--white)}.price-col.featured:hover{background:#1a1a1a}
    .price-col-label{font-family:var(--sans);font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--subtle);margin-bottom:24px}
    .price-col.featured .price-col-label{color:var(--accent)}
    .price-col-name{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--ink);margin-bottom:8px;letter-spacing:-.02em}
    .price-col.featured .price-col-name{color:var(--white)}
    .price-col-amount{font-family:var(--serif);font-size:44px;font-weight:700;color:var(--accent);margin:20px 0 4px;letter-spacing:-.04em;line-height:1}
    .price-col-period{font-size:14px;color:var(--subtle);margin-bottom:32px;font-weight:300}
    .price-col.featured .price-col-period{color:rgba(255,255,255,.5)}
    .price-col hr{border:none;height:1px;background:var(--rule);margin-bottom:28px}.price-col.featured hr{background:rgba(255,255,255,.12)}
    .price-col ul{list-style:none;margin-bottom:36px}
    .price-col li{font-size:14px;line-height:1.5;color:var(--body);padding:10px 0;border-bottom:1px solid rgba(0,0,0,.04);display:flex;align-items:flex-start;gap:10px;font-weight:300}
    .price-col.featured li{color:rgba(255,255,255,.65);border-bottom-color:rgba(255,255,255,.06)}
    .price-col li::before{content:'\2014';color:var(--gold);font-weight:500;flex-shrink:0}
    .price-cta{display:block;text-align:center;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:15px 0;text-decoration:none;transition:all .3s;border:1px solid var(--ink);color:var(--ink);background:transparent}
    .price-cta:hover{background:var(--ink);color:var(--white)}
    .price-col.featured .price-cta{border-color:var(--accent);color:var(--accent)}.price-col.featured .price-cta:hover{background:var(--accent);color:var(--ink)}
    .price-save{display:inline-block;font-size:11px;font-weight:600;color:var(--green);background:var(--green-pale);padding:2px 8px;border-radius:3px;margin-left:6px}
    @media(max-width:900px){.pricing-section{padding:80px 24px}.pricing-grid{grid-template-columns:1fr}.price-col{border-right:none;border-bottom:1px solid var(--rule)}.price-col:last-child{border-bottom:none}}

    /* CTA & FOOTER */
    .final-cta{padding:120px 48px;text-align:center;max-width:800px;margin:0 auto}
    .final-cta-title{font-family:var(--serif);font-size:clamp(32px,4vw,50px);font-weight:700;line-height:1.1;letter-spacing:-.03em;color:var(--ink);margin-bottom:24px}
    .final-cta-title i{font-style:italic;color:var(--accent)}
    .final-cta p{font-size:17px;line-height:1.75;color:var(--body);font-weight:300;margin-bottom:44px}
    .final-cta-sub{margin-top:24px;font-size:13px;color:var(--subtle)}
    @media(max-width:900px){.final-cta{padding:80px 24px}.notice-strip{padding:18px 24px}}
    @media(max-width:900px){
      #how-it-works div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
      #landing-page section > div > div[style*="1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #landing-page footer > div > div[style*="2fr 1fr"]{grid-template-columns:1fr 1fr!important}
      #landing-page section#providers > div > div[style*="1fr 1fr"]{grid-template-columns:1fr!important}
    }
    @media(max-width:600px){
      #landing-page footer > div > div[style*="2fr 1fr"]{grid-template-columns:1fr!important}
      .hero .lp-stat::after{display:none}
    }
    /* CLEARPATH COLLEGE RESPONSIVE */
    @media(max-width:1000px){
      #collegiate + div + section > div > div[style*="grid-template-columns:1fr 1fr"],
      #collegiate + div + section > div > div[style*="grid-template-columns:1fr 1fr;gap:0"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr;gap:80px"]{grid-template-columns:1fr!important;gap:48px!important}
    }
    @media(max-width:600px){
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr;gap:20px"]{grid-template-columns:1fr!important}
      #collegiate{padding:80px 24px 60px!important}
      #collegiate ~ section{padding-left:24px!important;padding-right:24px!important}
    }
    .site-footer{border-top:1px solid var(--rule);padding:48px;background:var(--bg)}
    .footer-inner{max-width:1320px;margin:0 auto}
    .footer-disclaimer{border:1px solid var(--rule);padding:24px 32px;margin-bottom:40px;background:var(--white)}
    .footer-disclaimer p{font-size:12px;line-height:1.7;color:var(--body)}.footer-disclaimer strong{color:var(--ink);font-weight:600}
    .footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px}
    .footer-wordmark{font-family:var(--serif);font-size:18px;font-weight:700;color:var(--ink)}
    .footer-wordmark em{font-style:italic;color:var(--accent);font-weight:400}
    .footer-meta{display:flex;align-items:center;gap:24px}.footer-meta span,.footer-meta a{font-size:12px;color:var(--subtle);text-decoration:none}.footer-meta a:hover{color:var(--gold)}
    @media(max-width:900px){.site-footer{padding:40px 24px}.footer-bottom{flex-direction:column;align-items:flex-start}}

    /* LOGIN */
    #landing-page{display:block}#app-view{display:none}
    .login-overlay{display:none;position:fixed;inset:0;z-index:9999;background:var(--bg);flex-direction:column;align-items:center;justify-content:center}
    .login-overlay.active{display:flex}
    .login-box{width:100%;max-width:460px;padding:0 24px;text-align:center}
    .login-logo{display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:48px}
    .login-logo-mark{width:44px;height:44px;background:transparent;display:flex;align-items:center;justify-content:center}
    .login-logo-text{font-family:var(--serif);font-size:24px;font-weight:700;color:var(--ink);letter-spacing:-.02em}
    .login-logo-text em{font-style:italic;color:var(--accent);font-weight:400}
    .login-title{font-family:var(--serif);font-size:26px;font-weight:700;color:var(--ink);margin-bottom:8px;line-height:1.3}
    .login-sub{font-size:14px;color:var(--body);margin-bottom:32px;font-weight:300;line-height:1.6}
    .login-field{width:100%;padding:14px 16px;margin-bottom:12px;border:1px solid var(--rule);border-radius:8px;background:var(--white);font-family:var(--sans);font-size:14px;color:var(--ink);outline:none;transition:border-color .3s;box-sizing:border-box}
    .login-field:focus{border-color:var(--ink);box-shadow:0 0 0 3px rgba(27,58,92,.08)}.login-field::placeholder{color:#bbb}
    .login-btn{width:100%;padding:15px;margin-top:12px;background:var(--ink);color:var(--white);border:none;border-radius:8px;font-family:var(--sans);font-size:14px;font-weight:600;letter-spacing:.04em;cursor:pointer;transition:all .3s}
    .login-btn:hover{background:#0F2440;box-shadow:0 4px 12px rgba(27,58,92,.2)}
    .login-btn:disabled,.login-btn[style*="opacity"]{background:#C5CDD5;cursor:default;box-shadow:none}
    .login-back{margin-top:20px;font-size:13px;color:var(--subtle);background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:500;transition:color .3s}.login-back:hover{color:var(--ink)}
    .login-notice{margin-top:32px;font-size:11px;color:#bbb;line-height:1.6}
    .login-step{display:none}.login-step.active{display:block}
    .login-divider{display:flex;align-items:center;gap:12px;margin:20px 0;font-size:12px;color:var(--subtle)}.login-divider::before,.login-divider::after{content:'';flex:1;height:1px;background:var(--rule)}
    .role-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:28px}
    .role-card{display:flex;align-items:center;gap:16px;text-align:left;padding:18px 20px;border:1.5px solid var(--rule);border-radius:10px;background:var(--white);cursor:pointer;transition:all .25s;font-family:var(--sans);width:100%}
    .role-card:hover{border-color:var(--gold);background:rgba(27,58,92,.02);box-shadow:0 2px 8px rgba(0,0,0,.04)}
    .role-card.selected{border-color:var(--ink);background:rgba(27,58,92,.04);box-shadow:0 2px 12px rgba(27,58,92,.1)}
    .role-card-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .role-card-icon.parent-icon{background:#E6EEF5;color:var(--gold-dark)}
    .role-card-icon.school-icon{background:#E5EFF6;color:#3A6B8A}
    .role-card-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:2px}
    .role-card-desc{font-size:12px;color:var(--body);font-weight:300;line-height:1.5}
    .role-card-check{margin-left:auto;width:24px;height:24px;border-radius:50%;border:2px solid var(--rule);flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .25s}
    .role-card.selected .role-card-check{border-color:var(--ink);background:var(--ink)}
    .auth-toggle{display:flex;gap:0;border:1.5px solid var(--rule);border-radius:8px;overflow:hidden;margin-bottom:24px}
    .auth-toggle button{flex:1;padding:11px;font-family:var(--sans);font-size:13px;font-weight:500;border:none;cursor:pointer;background:var(--white);color:var(--body);transition:all .2s}
    .auth-toggle button.active{background:var(--ink);color:var(--white);font-weight:600}
    .tos-container{margin-bottom:14px;padding:14px 16px;background:rgba(27,58,92,.03);border-radius:8px;border:1.5px solid var(--rule)}
    .tos-container label{display:flex;align-items:flex-start;gap:10px;font-size:12px;color:var(--body);cursor:pointer;line-height:1.6}
    .tos-container a{color:var(--ink);font-weight:600;text-decoration:underline}

    /* APP SIDEBAR */
    .app-sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-w);background:var(--ink);color:var(--white);display:flex;flex-direction:column;transition:width .3s;z-index:50;overflow-y:auto;overflow-x:hidden}
    .app-sidebar.collapsed{width:var(--sidebar-w-collapsed)}
    .app-sidebar .sb-logo{padding:24px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:12px;min-height:var(--header-h)}
    .app-sidebar.collapsed .sb-logo{padding:24px 0;justify-content:center}.app-sidebar.collapsed .sb-logo-text{display:none}
    .app-sidebar .sb-mark{width:32px;height:32px;background:transparent;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .app-sidebar .sb-logo-text{font-family:var(--serif);font-size:16px;font-weight:700;letter-spacing:-.02em;white-space:nowrap}
    .app-sidebar .sb-logo-text em{font-style:italic;color:var(--accent);font-weight:400}
    .app-sidebar .sb-student{padding:20px 24px;border-bottom:1px solid rgba(255,255,255,.08)}
    .app-sidebar.collapsed .sb-student{display:none}
    .app-sidebar .sb-student-label{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-light);margin-bottom:8px}
    .app-sidebar .sb-student-name{font-size:15px;font-weight:500}.app-sidebar .sb-student-meta{font-size:12px;color:rgba(255,255,255,.5);margin-top:2px}
    .app-sidebar .sb-state{padding:12px 24px;border-bottom:1px solid rgba(255,255,255,.08);display:flex;align-items:center;gap:8px}
    .app-sidebar.collapsed .sb-state{display:none}
    .sb-state-badge{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:3px;background:rgba(27,58,92,.15);color:var(--gold-light)}
    .app-sidebar .sb-nav{flex:1;padding:16px 0}
    .sb-nav-section{font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.25);padding:18px 24px 6px;margin-top:4px}
    .app-sidebar.collapsed .sb-nav-section{display:none}
    .app-sidebar .sb-nav-item{display:flex;align-items:center;gap:14px;width:100%;border:none;padding:12px 24px;background:transparent;color:rgba(255,255,255,.55);font-size:13px;font-weight:400;transition:all .2s;position:relative;text-align:left;letter-spacing:.01em;font-family:var(--sans);cursor:pointer}
    .app-sidebar.collapsed .sb-nav-item{padding:12px 0;justify-content:center}.app-sidebar.collapsed .sb-nav-label{display:none}
    .app-sidebar .sb-nav-item:hover{background:rgba(255,255,255,.04);color:rgba(255,255,255,.8)}
    .app-sidebar .sb-nav-item.active{background:rgba(27,58,92,.12);color:var(--accent);font-weight:600}
    .app-sidebar .sb-nav-item.active::before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--accent);border-radius:0 2px 2px 0}
    .app-sidebar .sb-nav-item.locked{opacity:.45;cursor:default}
    .app-sidebar .sb-nav-item.locked:hover{background:transparent;color:rgba(255,255,255,.55)}
    .app-sidebar .sb-footer{padding:16px 24px;border-top:1px solid rgba(255,255,255,.08)}
    .app-sidebar.collapsed .sb-footer{padding:16px 0}
    .app-sidebar .sb-collapse{display:flex;align-items:center;gap:10px;width:100%;border:none;background:none;color:rgba(255,255,255,.4);font-size:12px;padding:8px 0;transition:color .2s;font-family:var(--sans);cursor:pointer}
    .app-sidebar.collapsed .sb-collapse{justify-content:center}.app-sidebar.collapsed .sb-collapse-label{display:none}
    .app-sidebar .sb-collapse:hover{color:rgba(255,255,255,.7)}
    .app-sidebar .sb-collapse svg{transition:transform .3s}.app-sidebar.collapsed .sb-collapse svg{transform:rotate(180deg)}
    .app-sidebar .sb-signout{display:flex;align-items:center;gap:10px;width:100%;border:none;background:none;color:rgba(255,255,255,.35);font-size:11px;padding:8px 0;transition:color .2s;font-family:var(--sans);cursor:pointer;margin-top:4px;letter-spacing:.06em;text-transform:uppercase}
    .app-sidebar.collapsed .sb-signout-label{display:none}.app-sidebar .sb-signout:hover{color:#e05}

    /* APP TOPBAR & MAIN */
    .app-topbar{position:fixed;top:0;right:0;left:var(--sidebar-w);height:var(--header-h);background:rgba(253,252,250,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--rule);display:flex;align-items:center;justify-content:space-between;padding:0 32px;z-index:46;transition:left .3s}
    .app-sidebar.collapsed~.app-topbar{left:var(--sidebar-w-collapsed)}
    .app-topbar .tb-left{font-size:12px;color:#999;font-weight:500}.app-topbar .tb-left strong{color:var(--ink);font-weight:600}
    .app-topbar .tb-right{display:flex;align-items:center;gap:16px}
    .app-topbar .tb-avatar{width:34px;height:34px;border-radius:50%;background:var(--gold-pale);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:var(--gold-dark)}
    .app-topbar .tb-mobile-btn{display:none;background:none;border:none;padding:4px;cursor:pointer;touch-action:manipulation;min-width:44px;min-height:44px;align-items:center;justify-content:center}
    .tb-search{flex:1;max-width:420px;margin:0 24px}
    .tb-search-trigger{display:flex;align-items:center;gap:10px;padding:7px 14px;border:1px solid var(--rule);border-radius:8px;cursor:pointer;color:var(--subtle);transition:border-color .2s,box-shadow .2s;background:var(--bg)}
    .tb-search-trigger:hover{border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,175,55,.08)}
    .tb-search-text{font-size:13px;font-weight:400;flex:1}
    .tb-search-shortcut{font-size:10px;font-weight:600;color:var(--subtle);background:var(--white);border:1px solid var(--rule);border-radius:4px;padding:2px 6px;letter-spacing:.04em}
    .search-overlay{position:fixed;inset:0;z-index:99999;background:rgba(0,0,0,.5);display:flex;align-items:flex-start;justify-content:center;padding-top:min(20vh,120px)}
    .search-palette{background:var(--white);width:100%;max-width:560px;border-radius:12px;box-shadow:0 16px 48px rgba(0,0,0,.2);overflow:hidden}
    .search-input-wrap{display:flex;align-items:center;gap:12px;padding:16px 20px;border-bottom:1px solid var(--rule)}
    .search-input-wrap svg{flex-shrink:0;color:var(--subtle)}
    .search-input{flex:1;border:none;outline:none;font-family:var(--sans);font-size:16px;color:var(--ink);background:transparent}
    .search-input::placeholder{color:var(--subtle)}
    .search-results{max-height:400px;overflow-y:auto;padding:8px 0}
    .search-results:empty::after{content:'Start typing to search...';display:block;padding:32px;text-align:center;font-size:14px;color:var(--subtle)}
    .search-empty{padding:32px;text-align:center;font-size:14px;color:var(--subtle)}
    .search-group{padding:6px 20px 4px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--subtle)}
    .search-item{display:flex;align-items:center;gap:12px;padding:10px 20px;cursor:pointer;transition:background .1s}
    .search-item:hover,.search-item.active{background:rgba(212,175,55,.06)}
    .search-item-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}
    .search-item-text{flex:1;min-width:0}
    .search-item-title{font-size:14px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .search-item-desc{font-size:12px;color:var(--subtle);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .search-item-badge{font-size:10px;font-weight:600;color:var(--subtle);background:var(--bg);padding:2px 8px;border-radius:4px;flex-shrink:0}
    .search-footer{padding:10px 20px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-size:11px;color:var(--subtle)}
    .search-footer kbd{font-size:10px;background:var(--bg);border:1px solid var(--rule);border-radius:3px;padding:1px 5px}
    .app-main{margin-left:var(--sidebar-w);padding-top:var(--header-h);transition:margin-left .3s;min-height:100vh}
    .app-sidebar.collapsed~.app-main{margin-left:var(--sidebar-w-collapsed)}
    .app-main .main-inner{padding:40px 40px 80px;max-width:1100px;margin:0 auto}
    /* Overlay sits below topbar (topbar z:46) so hamburger stays tappable to close */
    .amo{display:none;position:fixed;left:0;right:0;top:var(--header-h);bottom:0;background:rgba(0,0,0,.4);z-index:45}.amo.open{display:block}
    @media(max-width:900px){
      .app-sidebar{transform:translateX(-100%);width:var(--sidebar-w)!important;top:0!important;z-index:50}
      .app-sidebar.mobile-open{transform:translateX(0);box-shadow:4px 0 32px rgba(0,0,0,.35)}
      .app-topbar{left:0!important;z-index:46!important;padding:0 16px 0 12px}
      .app-main{margin-left:0!important}.app-main .main-inner{padding:24px 20px 60px}
      .app-topbar .tb-mobile-btn{display:flex!important}
      .tb-search{margin:0 8px}.tb-search-text{display:none}.tb-search-shortcut{display:none}.tb-search-trigger{padding:7px 10px}
      /* Hide collapse btn on mobile — icon-only sidebar makes no sense for a drawer */
      .sb-collapse{display:none!important}
    }

    /* APP COMPONENTS */
    .asl{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);margin-bottom:16px;display:flex;align-items:center;gap:10px}
    .asl::before{content:"";width:20px;height:1px;background:var(--gold)}
    .apt{font-family:var(--serif);font-size:clamp(24px,2.5vw,34px);font-weight:700;color:var(--ink);letter-spacing:-.025em;line-height:1.15}
    .aps{font-size:15px;color:var(--body);margin-top:8px;font-weight:300}
    .aph{margin-bottom:36px}
    .ac{background:var(--white);border:1px solid #f0f0f0;border-radius:12px;padding:28px;transition:all .3s;box-shadow:0 1px 2px rgba(0,0,0,.02)}
    .ac.hov{cursor:pointer}.ac.hov:hover{box-shadow:0 4px 16px rgba(0,0,0,.05);border-color:#e0e0e0;transform:translateY(-1px)}
    .ac.np{padding:0}
    .ac.adc{background:#1B3A5C;border-color:transparent;box-shadow:0 4px 20px rgba(27,58,92,.15)}

    /* Dashboard widget grid */
    .dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px}
    .dash-grid-full{grid-column:1/-1}
    @media(max-width:768px){.dash-grid{grid-template-columns:1fr}}

    /* Binder upload zone */
    .upload-zone{width:100%;padding:14px;border:2px dashed var(--rule);border-radius:8px;background:rgba(253,252,250,.6);font-size:13px;cursor:pointer;font-family:var(--sans);display:flex;align-items:center;justify-content:center;gap:8px;transition:all .25s;color:var(--subtle)}
    .upload-zone:hover{border-color:var(--ink);background:rgba(27,58,92,.03);color:var(--ink)}
    .upload-zone.priority{border-color:#6B4F8A;color:#6B4F8A;font-weight:600}.upload-zone.priority:hover{background:rgba(107,79,138,.06)}
    .upload-zone.iep{border-color:var(--gold);color:var(--gold-dark);font-weight:600}.upload-zone.iep:hover{background:rgba(212,175,55,.06)}

    /* Binder file rows */
    .binder-file{padding:14px 0;transition:background .15s;border-radius:6px;margin:0 -8px;padding-left:8px;padding-right:8px}
    .binder-file:hover{background:rgba(27,58,92,.02)}
    .binder-file+.binder-file{border-top:1px solid var(--rule)}
    .binder-file-actions{display:flex;gap:12px;flex-shrink:0;align-items:center}
    .binder-file-actions a,.binder-file-actions button{font-size:11px;font-weight:600;background:none;border:none;cursor:pointer;font-family:var(--sans);padding:4px 8px;border-radius:4px;transition:background .15s}
    .binder-file-actions a:hover,.binder-file-actions button:hover{background:var(--bg-warm)}

    /* Quick action row */
    .quick-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:24px}
    @media(max-width:768px){.quick-row{grid-template-columns:1fr 1fr}}
    .asl2{font-size:11px;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:#999;margin-bottom:10px}
    .asv{font-family:var(--serif);font-size:32px;font-weight:700;color:var(--accent);letter-spacing:-.03em;line-height:1}
    .ass{font-size:13px;color:var(--body);margin-top:6px;font-weight:300}
    .apb{width:100%;height:6px;background:var(--rule);border-radius:3px;overflow:hidden}
    .apbf{height:100%;background:var(--accent);border-radius:3px;transition:width .8s}
    .apb.tall{height:10px}.apb.tall .apbf{border-radius:5px}
    .abg{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:4px}
    .abg-dot{width:6px;height:6px;border-radius:50%}
    .abg-ot{background:var(--green-pale);color:var(--green)}.abg-ot .abg-dot{background:var(--green)}
    .abg-ip{background:var(--blue-pale);color:var(--blue)}.abg-ip .abg-dot{background:var(--blue)}
    .abg-ar{background:var(--red-pale);color:var(--red)}.abg-ar .abg-dot{background:var(--red)}
    .arb{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:3px}
    .arb-p{background:var(--gold-pale);color:var(--gold-dark)}
    .arb-t{background:var(--blue-pale);color:var(--blue)}
    .arb-th{background:var(--green-pale);color:var(--green)}
    .avab{background:none;border:none;color:var(--gold);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;display:inline-flex;align-items:center;gap:4px;cursor:pointer;font-family:var(--sans)}
    .afp{padding:7px 16px;border-radius:4px;font-size:12px;font-weight:500;border:1px solid var(--rule);background:transparent;color:var(--body);letter-spacing:.02em;transition:all .2s;cursor:pointer;font-family:var(--sans)}
    .afp.act{border-color:var(--gold);background:var(--gold);color:var(--white)}
    .ach{padding:20px 24px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center}
    .ach h3{font-size:16px;font-weight:600}
    .acr{padding:18px 24px;border-bottom:1px solid var(--rule)}.acr:last-child{border-bottom:none}
    .aco{display:flex;align-items:flex-start;gap:16px}
    .aco-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
    .aco-title{font-size:14px;font-weight:600;color:var(--ink);margin-bottom:4px}
    .aco-body{font-size:13px;color:var(--body);line-height:1.65;font-weight:300}
    .apf{padding:14px 28px;border-top:1px solid var(--rule);background:var(--bg);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px;border-radius:0 0 8px 8px}
    .ag2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
    .ag3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
    .ag4{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}
    .agn{font-family:var(--serif);font-size:40px;font-weight:400;color:var(--gold-light);opacity:.4;line-height:1;width:50px;flex-shrink:0;letter-spacing:-.04em}
    .aab{width:4px;flex-shrink:0;border-radius:8px 0 0 8px}
    .aam span{font-size:12px}.aam .ml{color:#999;font-weight:500}.aam .mv{color:var(--ink-soft);font-weight:400}
    .abc{display:flex;align-items:flex-end;gap:6px;height:80px}
    .abc-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
    .abc-v{font-size:10px;color:#999}.abc-f{width:100%;border-radius:3px 3px 0 0;min-height:4px}.abc-l{font-size:9px;color:#999}
    .abtn{padding:10px 24px;background:var(--gold);color:var(--white);border:none;border-radius:8px;font-size:13px;font-weight:600;letter-spacing:.04em;transition:all .25s;cursor:pointer;font-family:var(--sans)}
    .abtn:hover{box-shadow:0 4px 12px rgba(27,58,92,.2);transform:translateY(-1px)}
    .abtn:active{transform:translateY(0);box-shadow:none}
    .abtn:disabled,.abtn.loading{opacity:.6;cursor:default;transform:none;box-shadow:none}
    .abtn-outline{padding:10px 24px;background:transparent;color:var(--gold);border:1.5px solid var(--gold);border-radius:8px;font-size:13px;font-weight:600;letter-spacing:.04em;transition:all .25s;cursor:pointer;font-family:var(--sans)}
    .abtn-outline:hover{background:rgba(27,58,92,.04);box-shadow:0 2px 8px rgba(27,58,92,.08)}

    /* Empty state component */
    .empty-state{text-align:center;padding:56px 32px}
    .empty-state-icon{width:64px;height:64px;border-radius:50%;background:var(--gold-pale);display:flex;align-items:center;justify-content:center;margin:0 auto 20px}
    .empty-state-title{font-family:var(--serif);font-size:20px;font-weight:700;color:var(--ink);margin-bottom:8px}
    .empty-state-desc{font-size:14px;color:var(--body);line-height:1.7;max-width:400px;margin:0 auto 24px;font-weight:300}

    /* Modal animation */
    @keyframes cpFadeIn{from{opacity:0}to{opacity:1}}
    @keyframes cpSlideUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
    .abtn:hover{background:var(--gold-dark)}
    .abtn-outline{padding:10px 24px;background:transparent;color:var(--gold);border:1px solid var(--gold);border-radius:4px;font-size:13px;font-weight:600;letter-spacing:.04em;transition:all .3s;cursor:pointer;font-family:var(--sans)}
    .abtn-outline:hover{background:var(--gold);color:var(--white)}
    .aer{cursor:pointer}.aer:hover{background:rgba(27,58,92,.02)}
    .aec{border-top:1px solid var(--rule);padding:24px 28px;background:var(--bg);display:none;border-radius:0 0 8px 8px}
    .aec.open{display:block}.aev{transition:transform .3s}.aev.open{transform:rotate(180deg)}
    .aag{display:grid;grid-template-columns:1fr 1fr;gap:0}
    .aai{padding:14px 0;font-size:14px;color:var(--body);font-weight:300;border-bottom:1px solid var(--rule);display:flex;align-items:flex-start;gap:10px}
    .aai:nth-child(odd){padding-right:24px;border-right:1px solid var(--rule)}.aai:nth-child(even){padding-left:24px}
    .aan{color:var(--gold);font-weight:500;flex-shrink:0}
    .agt{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;color:var(--gold-dark);background:var(--gold-pale);padding:4px 10px;border-radius:4px}
    .acb{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:var(--green-pale);color:var(--green);padding:3px 8px;border-radius:3px}
    .ack{width:22px;height:22px;border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center}
    .ack.unc{border:2px solid var(--rule);background:transparent}.ack.chk{border:none;background:var(--green)}

    /* LETTER BUILDER */
    .letter-preview{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:40px;font-size:14px;line-height:1.8;color:var(--ink);font-family:var(--sans);white-space:pre-wrap;max-height:500px;overflow-y:auto}
    .letter-field{width:100%;padding:10px 14px;border:1px solid var(--rule);border-radius:4px;font-family:var(--sans);font-size:14px;color:var(--ink);margin-bottom:8px;outline:none;transition:border-color .2s}
    .letter-field:focus{border-color:var(--gold)}
    .letter-tabs{display:flex;gap:0;border-bottom:2px solid var(--rule);margin-bottom:24px}
    .letter-tab{padding:12px 20px;font-size:13px;font-weight:500;color:var(--subtle);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;font-family:var(--sans);background:none;border-top:none;border-left:none;border-right:none;transition:all .2s}
    .letter-tab.act{color:var(--gold);border-bottom-color:var(--gold);font-weight:600}

    /* RIGHTS CARDS */
    .rights-card{background:var(--white);border:1px solid var(--rule);border-radius:8px;padding:28px;margin-bottom:16px;transition:all .3s;cursor:pointer}
    .rights-card:hover{border-color:var(--gold);box-shadow:0 4px 16px rgba(27,58,92,.08)}
    .rights-card h3{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:8px;display:flex;align-items:center;gap:10px}
    .rights-card p{font-size:14px;line-height:1.7;color:var(--body);font-weight:300}
    .rights-card .rights-law{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-top:12px}
    .rights-expand{display:none;margin-top:16px;padding-top:16px;border-top:1px solid var(--rule)}
    .rights-card.open .rights-expand{display:block}

    /* GLOSSARY */
    .glossary-search{width:100%;padding:14px 20px;border:1px solid var(--rule);border-radius:8px;font-family:var(--sans);font-size:15px;color:var(--ink);outline:none;margin-bottom:24px;transition:border-color .2s}
    .glossary-search:focus{border-color:var(--gold)}
    .glossary-item{padding:20px 0;border-bottom:1px solid var(--rule)}
    .glossary-term{font-size:16px;font-weight:600;color:var(--ink);margin-bottom:6px}
    .glossary-def{font-size:14px;line-height:1.7;color:var(--body);font-weight:300}

    /* TIMELINE */
    .tl-item{display:flex;gap:20px;padding:20px 0;border-bottom:1px solid var(--rule)}
    .tl-date{width:120px;flex-shrink:0;text-align:right}
    .tl-date-main{font-size:15px;font-weight:600;color:var(--ink)}
    .tl-date-sub{font-size:11px;color:var(--subtle)}
    .tl-line{width:20px;display:flex;flex-direction:column;align-items:center;flex-shrink:0}
    .tl-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--gold);background:var(--white);flex-shrink:0}
    .tl-dot.done{background:var(--gold)}
    .tl-dot.urgent{border-color:var(--red);background:var(--red)}
    .tl-bar{flex:1;width:2px;background:var(--rule);margin-top:4px}
    .tl-content{flex:1}
    .tl-title{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:4px}
    .tl-desc{font-size:13px;color:var(--body);font-weight:300;line-height:1.6}
    .tl-badge{display:inline-block;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:3px 8px;border-radius:3px;margin-top:8px}
    .tl-badge-done{background:var(--green-pale);color:var(--green)}
    .tl-badge-upcoming{background:var(--gold-pale);color:var(--gold-dark)}
    .tl-badge-overdue{background:var(--red-pale);color:var(--red)}

    /* MEETING PREP */
    .mp-phase{margin-bottom:32px}
    .mp-phase-header{display:flex;align-items:center;gap:12px;margin-bottom:16px}
    .mp-phase-num{width:36px;height:36px;border-radius:50%;background:var(--gold);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
    .mp-phase-title{font-size:18px;font-weight:600;color:var(--ink)}
    .mp-check{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid var(--rule);cursor:pointer}
    .mp-check:hover{background:rgba(27,58,92,.02)}
    .mp-check-box{width:22px;height:22px;border:2px solid var(--rule);border-radius:4px;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;margin-top:1px}
    .mp-check.done .mp-check-box{border-color:var(--green);background:var(--green)}
    .mp-check-text{font-size:14px;color:var(--body);font-weight:300;line-height:1.6}
    .mp-check.done .mp-check-text{text-decoration:line-through;color:#bbb}

    /* SIGNATURE PAD */
    .sig-pad-wrap{border:1px solid var(--rule);border-radius:8px;overflow:hidden;margin:16px 0;background:var(--white)}
    .sig-pad-header{padding:12px 16px;background:var(--bg);border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:center}
    .sig-pad-header span{font-size:12px;color:var(--subtle);font-weight:500}
    .sig-pad-clear{font-size:11px;color:var(--gold);background:none;border:none;cursor:pointer;font-family:var(--sans);font-weight:600;letter-spacing:.04em;text-transform:uppercase}
    .sig-pad-canvas{display:block;width:100%;height:120px;cursor:crosshair;touch-action:none}
    .sig-actions{display:flex;gap:12px;align-items:center;margin-top:12px}
    .sig-date{font-size:12px;color:var(--subtle)}
    .doc-status-pending{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:4px;background:#FFF3E0;color:#E65100}
    .doc-status-signed{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 10px;border-radius:4px;background:var(--green-pale);color:var(--green)}
    .doc-urgent{display:inline-block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:3px 8px;border-radius:3px;background:var(--red-pale);color:var(--red);margin-left:8px}
    .doc-meta-row{display:flex;gap:24px;flex-wrap:wrap;margin-top:12px}
    .doc-meta-item span:first-child{font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--subtle)}
    .doc-meta-item span:last-child{font-size:13px;color:var(--ink);margin-left:6px}

    @media(max-width:900px){.ag2,.aag,.ag3{grid-template-columns:1fr}.aai:nth-child(odd){padding-right:0;border-right:none}.aai:nth-child(even){padding-left:0}.tl-date{width:80px}}

    /* CHILD SWITCHER */
    .cs-current{display:flex;align-items:center;gap:12px;cursor:pointer;padding:2px 0;transition:opacity .2s}
    .cs-current:hover{opacity:.85}
    .cs-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}
    .cs-avatar.ard{background:rgba(212,175,55,.2);color:var(--accent)}
    .cs-avatar.plan504{background:rgba(58,107,138,.2);color:#7AB5D6}
    .cs-info{flex:1;min-width:0}
    .cs-name{font-size:14px;font-weight:600;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .cs-plan{font-size:11px;color:rgba(255,255,255,.4);margin-top:1px}
    .cs-chevron{color:rgba(255,255,255,.3);flex-shrink:0;transition:transform .2s}
    .cs-dropdown{display:none;margin-top:12px;padding-top:12px;border-top:1px solid rgba(255,255,255,.08)}
    .cs-dropdown.open{display:block}
    .cs-child-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 0;background:none;border:none;cursor:pointer;font-family:var(--sans);transition:opacity .2s}
    .cs-child-btn:hover{opacity:.8}
    .cs-child-btn .cs-avatar{width:30px;height:30px;font-size:12px}
    .cs-child-btn .cs-name{font-size:13px;font-weight:500;color:rgba(255,255,255,.6)}
    .cs-child-btn.active .cs-name{color:var(--accent);font-weight:600}
    .cs-add-btn{display:flex;align-items:center;gap:10px;width:100%;padding:10px 0;background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:12px;color:rgba(255,255,255,.3);transition:color .2s;margin-top:4px}
    .cs-add-btn:hover{color:rgba(255,255,255,.5)}
    .app-sidebar.collapsed .cs-info,.app-sidebar.collapsed .cs-chevron,.app-sidebar.collapsed .cs-dropdown,.app-sidebar.collapsed .cs-add-btn span{display:none}

    /* UPGRADE MODAL */
    .upgrade-overlay{display:none;position:fixed;inset:0;z-index:9999;background:rgba(0,0,0,.5);align-items:center;justify-content:center}
    .upgrade-overlay.active{display:flex}
    .upgrade-box{background:var(--white);max-width:440px;width:calc(100% - 48px);padding:40px;border-radius:12px;text-align:center}
    .upgrade-box h3{font-family:var(--serif);font-size:22px;font-weight:700;color:var(--ink);margin-bottom:12px}
    .upgrade-box p{font-size:15px;color:var(--body);line-height:1.7;margin-bottom:24px}
    .upgrade-box .upgrade-cta{display:inline-block;background:var(--gold);color:var(--white);padding:14px 32px;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s;text-decoration:none}
    .upgrade-box .upgrade-cta:hover{background:var(--gold-dark)}
    .upgrade-box .upgrade-dismiss{display:block;margin-top:16px;font-size:13px;color:var(--subtle);background:none;border:none;cursor:pointer;font-family:var(--sans)}

    /* ========== COMPREHENSIVE RESPONSIVE FIXES ========== */
    /* Prevent horizontal overflow globally */
    html,body{overflow-x:hidden;max-width:100vw}
    @keyframes spin{to{transform:rotate(360deg)}}

    /* ========== TABLET (601–1024px) ========== */
    @media(min-width:601px) and (max-width:1024px){
      /* Landing page grids */
      #landing-page div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
      #landing-page div[style*="grid-template-columns:1fr 1fr 1fr"]:not([style*="1fr 1fr 1fr 1fr"]){grid-template-columns:1fr 1fr!important}
      /* App grids — both space and no-space variants */
      #appContent div[style*="repeat(4,1fr)"],
      #appContent div[style*="repeat(4, 1fr)"]{grid-template-columns:1fr 1fr!important}
      /* Sidebar */
      .app-sidebar{width:220px!important}
      .app-topbar{left:220px!important}
      .app-main{margin-left:220px!important}
    }

    /* ========== LANDING PAGE — max-width:900px ========== */
    @media(max-width:900px){
      #pricing .pricing-inner>div:nth-child(2){grid-template-columns:1fr!important}
      #rights-preview>div:nth-child(2){grid-template-columns:1fr!important}
      #capabilities .capabilities-inner>div:last-child{grid-template-columns:1fr!important}
      .header-nav{display:none}.mobile-toggle{display:block}
      .header-inner{padding:20px 24px}.site-header.scrolled .header-inner{padding:14px 24px}
      /* How it works / providers / general 3-col */
      #how-it-works div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
      #landing-page section > div > div[style*="1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #landing-page section#providers > div > div[style*="1fr 1fr"]{grid-template-columns:1fr!important}
      /* Footer */
      #landing-page footer > div > div[style*="2fr 1fr"]{grid-template-columns:1fr 1fr!important}
      .site-footer{padding:40px 24px}.footer-bottom{flex-direction:column;align-items:flex-start}
      /* College sections */
      #collegiate + div + section > div > div[style*="grid-template-columns:1fr 1fr"],
      #collegiate + div + section > div > div[style*="grid-template-columns:1fr 1fr;gap:0"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr;gap:80px"]{grid-template-columns:1fr!important;gap:48px!important}
      /* College transition timeline stack */
      #student-shift ~ section div[style*="grid-template-columns:1fr 1fr 1fr 1fr;gap:0;border-top"]{grid-template-columns:1fr!important}
      #student-shift ~ section div[style*="grid-template-columns:1fr 1fr 1fr 1fr;gap:0;border-top"] > div{padding:32px 0!important;border-right:none!important;border-bottom:1px solid var(--rule);text-align:center}
      #student-shift ~ section div[style*="grid-template-columns:1fr 1fr 1fr 1fr;gap:0;border-top"] > div:last-child{border-bottom:none}
      #student-shift ~ section div[style*="font-size:56px"]{text-align:center}
      /* K-12 vs College grid */
      #student-shift + section div[style*="grid-template-columns:1fr 1fr;gap:0;border"]{grid-template-columns:1fr!important}
      #student-shift + section div[style*="grid-template-columns:1fr 1fr;gap:0;border"] > div{border-right:none!important}
    }

    /* ========== LANDING PAGE — max-width:768px ========== */
    @media(max-width:768px){
      /* Section padding */
      #landing-page section,
      #landing-page > section{padding-left:20px!important;padding-right:20px!important}
      #landing-page section[style*="padding:100px"]{padding-top:60px!important;padding-bottom:60px!important}
      #landing-page section[style*="padding:120px"]{padding-top:70px!important;padding-bottom:70px!important}
      /* Hero */
      #home{padding:120px 20px 60px!important}
      #home h1{font-size:clamp(28px,7vw,42px)!important}
      #home .btn-primary,#home .btn-secondary{width:100%;text-align:center;justify-content:center}
      /* Hero stats */
      #home div[style*="display:flex;gap:48px"],
      #home div[style*="gap:48px"]{gap:20px!important;flex-wrap:wrap!important;justify-content:space-around!important}
      /* Trust bar */
      div[style*="gap:40px;flex-wrap:wrap"]{gap:16px!important}
      /* 2-col grids with large gaps */
      div[style*="grid-template-columns:1fr 1fr;gap:80px"]{grid-template-columns:1fr!important;gap:32px!important}
      #landing-page div[style*="grid-template-columns:1fr 1fr;gap:24px"]{grid-template-columns:1fr!important}
      #landing-page div[style*="grid-template-columns:1fr 1fr;gap:20px"]{grid-template-columns:1fr!important}
      /* Provider section */
      #providers div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
      /* Testimonials / 3-col */
      div[style*="grid-template-columns:1fr 1fr 1fr;gap:24px"],
      div[style*="grid-template-columns:1fr 1fr 1fr;gap:40px"]{grid-template-columns:1fr!important}
      /* Pricing */
      #pricing{padding:60px 20px!important}
      #landing-page div[style*="grid-template-columns:1fr 1fr 1fr;gap:0"]{grid-template-columns:1fr!important}
      /* 4-col grids → 2-col */
      #landing-page div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important}
      /* Footer */
      #landing-page footer{padding:40px 20px 30px!important}
      #landing-page footer div[style*="2fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important;gap:24px!important}
      footer div[style*="grid-template-columns"]{grid-template-columns:1fr!important}
      /* FAQ / Contact */
      #faq{padding:60px 20px!important}
      #contact{padding:60px 20px!important}
      /* College */
      #collegiate{padding:80px 20px 60px!important}
      /* App view schedule horizontal scroll */
      #appContent .ac.np{overflow-x:auto!important;-webkit-overflow-scrolling:touch}
      #appContent div[style*="min-width:800px"]{overflow-x:auto;-webkit-overflow-scrolling:touch}
      /* Provider 72px icon cards */
      #landing-page div[style*="grid-template-columns:72px 1fr"]{grid-template-columns:1fr!important;gap:16px!important;padding:24px!important;text-align:center}
      #landing-page div[style*="grid-template-columns:72px 1fr"] > div:first-child{margin:0 auto}
    }

    /* ========== APP VIEW — max-width:900px ========== */
    @media(max-width:900px){
      /* Sidebar becomes overlay drawer */
      .app-sidebar{transform:translateX(-100%);width:var(--sidebar-w)!important}
      .app-sidebar.mobile-open{transform:translateX(0);box-shadow:4px 0 24px rgba(0,0,0,.3)}
      .app-topbar{left:0!important}.app-main{margin-left:0!important}
      .app-main .main-inner{padding:24px 20px 60px}
      .app-topbar .tb-mobile-btn{display:flex!important}
      /* Force all inline 2-col grids to stack */
      #appContent div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
      /* Force all inline 3-col grids to stack */
      #appContent div[style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      /* Force all 4-col grids to 2-col (both space variants) */
      #appContent div[style*="repeat(4,1fr)"],
      #appContent div[style*="repeat(4, 1fr)"]{grid-template-columns:1fr 1fr!important}
      /* Reference library 2fr grids */
      #appContent div[style*="grid-template-columns:2fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important;font-size:12px!important}
      /* Schedule grid — make scrollable */
      #appContent div[style*="min-width:800px"]{min-width:auto!important;overflow-x:auto!important;-webkit-overflow-scrolling:touch!important}
      #appContent div[style*="grid-template-columns:70px"]{grid-template-columns:1fr!important;min-width:auto!important}
      /* Auto-fill grids */
      #appContent div[style*="repeat(auto-fill,minmax(320px"]{grid-template-columns:1fr!important}
      /* Flex layout fixes */
      #appContent div[style*="display:flex;gap:80px"],
      #appContent div[style*="display:flex; gap:80px"]{gap:24px!important;flex-direction:column!important}
      #appContent div[style*="display:flex;gap:48px"]{gap:16px!important;flex-wrap:wrap!important}
      #appContent div[style*="display:flex;gap:20px"]{flex-wrap:wrap!important;gap:12px!important}
      #appContent div[style*="display:flex;gap:12px;flex-wrap:wrap"]{gap:8px!important}
      /* Card headers & rows */
      .ach{flex-wrap:wrap;gap:8px}
      .acr{flex-wrap:wrap}
      /* Topbar breadcrumb */
      .app-topbar .tb-left{font-size:11px;max-width:60%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
      /* Modals */
      div[style*="max-width:520px"],
      div[style*="max-width:480px"],
      div[style*="max-width:460px"],
      div[style*="max-width:440px"],
      div[style*="max-width:380px"]{max-width:100%!important;margin:16px!important}
      /* Grid utility classes */
      #appContent .ag3{grid-template-columns:1fr!important}
      /* Binder doc action buttons */
      #appContent .ac div[style*="display:flex;align-items:center;gap:10px"] a[href],
      #appContent .ac div[style*="display:flex;align-items:center;gap:10px"] button[data-fn="deleteUploadedDoc"]{font-size:11px!important;padding:4px 6px}
      /* Upload area full width */
      #appContent label[for^="upload_"]{width:100%;box-sizing:border-box}
      /* Letter preview max height on mobile */
      .letter-preview{max-height:260px!important;padding:16px!important}
      /* Letter tabs — horizontal scroll */
      .letter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
      .letter-tabs::-webkit-scrollbar{display:none}
      .letter-tab{white-space:nowrap;padding:10px 14px!important;font-size:12px!important}
    }

    /* ========== MOBILE — max-width:600px ========== */
    @media(max-width:600px){
      .pillars{grid-template-columns:1fr}.vDash .ag3{grid-template-columns:1fr!important}
      .pillar{border-right:none;padding:32px 0}
      /* Landing footer single col */
      #landing-page footer > div > div[style*="2fr 1fr"]{grid-template-columns:1fr!important}
      .hero .lp-stat::after{display:none}
      /* College sections */
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #collegiate ~ section > div > div[style*="grid-template-columns:1fr 1fr;gap:20px"]{grid-template-columns:1fr!important}
      #collegiate{padding:80px 24px 60px!important}
      #collegiate ~ section{padding-left:24px!important;padding-right:24px!important}
      /* 4-col grids → single col (both space variants) */
      #appContent div[style*="repeat(4,1fr)"],
      #appContent div[style*="repeat(4, 1fr)"]{grid-template-columns:1fr!important}
      /* 4-col landing grids → single col */
      #landing-page div[style*="grid-template-columns:1fr 1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #landing-page footer div[style*="2fr 1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      /* Schedule grid — scrollable */
      .ac.np[style*="overflow-x"]{overflow-x:auto!important;-webkit-overflow-scrolling:touch}
      #appContent div[style*="grid-template-columns:70px repeat(6,1fr)"]{grid-template-columns:70px repeat(6,minmax(100px,1fr))!important;min-width:780px!important}
      /* Hero stats */
      #home div[style*="gap:48px"] .lp-stat,
      #home div[style*="gap:48px"] > div{min-width:calc(50% - 16px)!important;text-align:center}
      #home div[style*="gap:48px"] > div::after{display:none!important}
      /* Trust bar */
      div[style*="gap:40px;flex-wrap:wrap"]{gap:12px!important;justify-content:center}
      div[style*="gap:40px;flex-wrap:wrap"] span[style*="font-size:16px"]{font-size:14px!important}
      /* Contact form */
      #contactForm{padding:20px!important}
      #contactForm input,#contactForm select,#contactForm textarea{width:100%!important;box-sizing:border-box!important}
      #contactForm div[style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
      /* Timeline */
      .tl-date{width:60px!important}
      .tl-date-main{font-size:13px!important}
      .tl-item{gap:12px!important}
      /* Stat values */
      .asv{font-size:26px!important}
      /* Login */
      .login-box{padding:0 16px}
      .role-card{padding:14px 16px!important}
      .role-card-desc{font-size:11px!important}
      /* Letter builder */
      .letter-preview{padding:20px!important;max-height:300px!important}
      .letter-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}
      .letter-tab{white-space:nowrap;padding:10px 14px!important;font-size:12px!important}
      /* Form inputs */
      #appContent select,
      #appContent input[type="text"],
      #appContent input[type="email"],
      #appContent input[type="date"],
      #appContent input[type="number"],
      #appContent textarea{max-width:100%!important;box-sizing:border-box!important}
      /* Provider template tabs */
      #appContent div[style*="display:flex;gap:0;border-bottom"]{overflow-x:auto;-webkit-overflow-scrolling:touch}
      /* Touch targets */
      .mp-check{padding:16px 0!important;min-height:48px}
      .sb-nav-item{min-height:44px!important;padding:14px 24px!important}
      /* Main content padding */
      .app-main .main-inner{padding:16px 14px 60px!important}
      /* Page headers */
      .apt{font-size:22px!important}
      /* Goal card fixes */
      #appContent .aer{padding:16px!important;gap:12px!important}
      #appContent .agn{font-size:28px!important;width:36px!important}
      #appContent .aer>div:last-of-type:not(.aev){min-width:60px!important}
      #appContent .aer>div:last-of-type:not(.aev) .asv,
      #appContent .aer>div:last-of-type:not(.aev) div[style*="font-size:28px"],
      #appContent .aer>div:last-of-type:not(.aev) div[style*="font-size:32px"]{font-size:22px!important}
      #appContent .aec{padding:16px!important}
      #appContent .ag4{grid-template-columns:1fr 1fr!important;gap:12px!important}
      /* Goal upload form */
      #appContent label[for="iepUpload"]{width:100%;justify-content:center;text-align:center;box-sizing:border-box}
      #appContent div[style*="display:flex;gap:12px;margin-top:10px"]{flex-direction:column!important;align-items:stretch!important}
      #appContent div[style*="display:flex;gap:12px;margin-top:10px"] .abtn{width:100%;text-align:center}
      #appContent div[style*="display:flex;gap:12px;margin-top:10px"] span{text-align:center}
    }

    /* ========== EXTRA SMALL — max-width:480px ========== */
    @media(max-width:480px){
      #landing-page footer div[style*="2fr 1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      /* ag4 single col on tiny screens */
      #appContent .ag4{grid-template-columns:1fr!important}
      /* Goal cards */
      #appContent .aer{padding:14px!important;gap:10px!important}
      #appContent .agn{font-size:24px!important;width:32px!important}
      /* Stat values */
      .asv{font-size:24px!important}
      /* Login overlay */
      .login-overlay{padding:80px 16px 32px!important}
      .login-box{max-width:100%!important}
      .login-title{font-size:20px!important}
      .login-sub{font-size:13px!important}
      .role-cards{gap:8px!important}
      .role-card{padding:12px 14px!important;gap:12px!important}
      .role-card-desc{display:none}
      /* Buttons full width in app on tiny screens */
      #appContent .abtn{min-height:44px;touch-action:manipulation}
      /* Binder upload label */
      #appContent label[for^="upload_"]{padding:14px!important;font-size:12px!important}
    }

    /* ========== SAFE AREA for notched phones ========== */
    @supports(padding-bottom: env(safe-area-inset-bottom)){
      .app-main{padding-bottom:env(safe-area-inset-bottom)}
      .app-sidebar{padding-bottom:env(safe-area-inset-bottom)}
    }

    /* ========== PRINT ========== */
    @media print{
      .app-sidebar,.app-topbar,.amo{display:none!important}
      .app-main{margin-left:0!important;padding-top:0!important}
    }

    /* ══════════════════════════════════════════════════════════════
       LANDING PAGE — MOBILE OVERRIDES
       Covers all inline-styled grids, padding, and flex layouts
       that don't have their own breakpoints.
       ═══════════════════════════════════════════════════════════ */

    @media(max-width:768px){
      /* ── Sections: reduce side padding ── */
      #home{padding:120px 24px 60px!important}
      #about,#advocacy,#rights-preview,#how-it-works,#providers,
      #pricing,#faq,#contact,#full-service,#collegiate{padding-left:24px!important;padding-right:24px!important}
      section[style*="padding:100px 48px"],
      section[style*="padding:120px 48px"],
      section[style*="padding:80px 48px"]{padding-left:24px!important;padding-right:24px!important}

      /* ── Grids: stack all multi-column to single column ── */
      [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}
      [style*="grid-template-columns: 1fr 1fr"]{grid-template-columns:1fr!important}
      [style*="grid-template-columns:72px 1fr"]{grid-template-columns:1fr!important}

      /* ── Provider cards: stack icon above text ── */
      #providers [style*="grid-template-columns:72px"]{grid-template-columns:1fr!important;gap:16px!important}
      #providers [style*="width:72px;height:72px"]{margin:0 auto}

      /* ── Stat rows: wrap and reduce gap ── */
      .reveal.reveal-delay-4[style*="gap:48px"],
      [style*="display:flex;gap:48px"]{gap:20px!important;flex-wrap:wrap!important}

      /* ── Trust bar ── */
      [style*="gap:40px;flex-wrap:wrap"]{gap:16px!important}
      div[style*="border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);padding:24px 48px"]{padding:16px 24px!important}

      /* ── Dark bridge section ── */
      section[style*="padding:80px 48px;background:var(--ink)"]{padding:60px 24px!important}

      /* ── Escalation trigger cards ── */
      section[style*="KNOW THE THRESHOLD"] [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

      /* ── Feature cards, how-it-works steps ── */
      .lp-card{margin-bottom:12px}

      /* ── ClearPath College: stack comparison grids ── */
      #collegiate [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

      /* ── Footer ── */
      footer [style*="grid-template-columns:2fr 1fr 1fr 1fr"]{grid-template-columns:1fr 1fr!important;gap:24px!important}

      /* ── Dark card inner CTA box ── */
      [style*="padding:48px;text-align:center"]{padding:28px 20px!important}

      /* ── Concierge feature columns ── */
      #full-service [style*="display:flex;justify-content:center;gap:16px;flex-wrap:wrap"]{flex-direction:column!important}

      /* ── Contact form ── */
      #contactForm [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

      /* ── Pricing cards ── */
      #parentPricing [style*="grid-template-columns:1fr 1fr 1fr"]{grid-template-columns:1fr!important}
      #providerPricing [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

      /* ── ClearPath College timeline shift box ── */
      #student-shift [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr!important}

      /* ── About section tags ── */
      #about [style*="display:flex;flex-wrap:wrap;gap:12px"]{gap:8px!important}
    }

    @media(max-width:480px){
      /* ── Extra-small: tighter stats ── */
      .lp-stat div:first-child{font-size:24px!important}
      [style*="display:flex;gap:48px"]{gap:12px!important}

      /* ── Footer: full stack ── */
      footer [style*="grid-template-columns"]{grid-template-columns:1fr!important}

      /* ── Hero headline size ── */
      #home h1{font-size:32px!important}
    }