*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
/* Global readability bump: every rem-based size below scales with this */
html{font-size:17.5px;}
@media(max-width:720px){html{font-size:17px;}}
/* Inline Lucide icons, sized to the parent's font-size */
.lc{display:inline-block;width:1em;height:1em;vertical-align:-.15em;flex-shrink:0;stroke-width:2;}
.pchip .lc,.fchip .lc{margin-right:.25em;}
:root{
  --n1:#EDE8D8;--n2:#E4DCC4;--n3:#D8CFB4;
  --teal:#7C8C56;--purple:#5E6B3E;
  --white:#2C3326;--soft:#43492F;--line:rgba(44,51,38,.40);--label:#5E5192;--lilac:#8C79C0;--lilac-soft:rgba(140,121,192,.18);--wm1:#6E5FB0;--wm2:#8C79C0;--wm3:#B49AD6;--field:#FBF8EE;
  --foil-deep:#3D2F7A;--foil-mid:#8C79C0;--foil-pale:#B49AD6;--foil-hot:#D4BFEC;
  --paper-rgb:237,232,216;
  --fh:'Lora',Georgia,serif;--fb:'Mulish',system-ui,sans-serif;
  color-scheme:light;
}
:root[data-theme="dark"]{
  --n1:#181C16;--n2:#21261C;--n3:#2C3324;
  --teal:#A6B673;--purple:#9DAE6B;
  --white:#ECE8D8;--soft:#BCC0A9;--line:rgba(236,232,216,.28);--label:#C9BCEC;--lilac:#C4B2EC;--lilac-soft:rgba(196,178,236,.20);--wm1:#A99BE8;--wm2:#C4B2EC;--wm3:#DBCDF5;--field:#14180F;
  --foil-deep:#6E5FB0;--foil-mid:#A99BE8;--foil-pale:#C4B2EC;--foil-hot:#DBCDF5;
  --paper-rgb:20,24,18;
  color-scheme:dark;
}
html{scroll-behavior:smooth;}
html{overflow-x:hidden;}
body{background:var(--n1);color:var(--white);font-family:var(--fb);line-height:1.6;overflow-x:hidden;min-height:100vh;position:relative;width:100%;}
.gt{color:var(--purple);text-decoration:underline;text-decoration-color:var(--lilac);text-decoration-thickness:.055em;text-underline-offset:.16em;}
.pop{background:linear-gradient(110deg,var(--wm1) 0%,var(--wm2) 26%,var(--wm3) 50%,var(--wm2) 74%,var(--wm1) 100%);background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:var(--lilac);-webkit-text-fill-color:transparent;animation:gshift 5s linear infinite;}
@keyframes gshift{0%{background-position:0%}50%{background-position:100%}100%{background-position:0%}}

.page{display:none;min-height:100vh;}
.page.active{display:block;}

/* ── NAV ── */
nav{
  position:sticky;top:0;z-index:99;
  background:rgba(var(--paper-rgb),.96);
  backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);
  border-bottom:3px solid var(--lilac);
  height:116px;padding:0 5%;
  display:flex;align-items:center;justify-content:space-between;
  transition:box-shadow .3s;
}
nav.scrolled{box-shadow:0 6px 40px rgba(0,0,0,.35);}
.nlogo{display:flex;align-items:center;cursor:pointer;flex-shrink:0;}
.nlogo img{height:64px;display:block;transition:transform .25s;}
.nlogo img:hover{transform:scale(1.04);}
.nlinks{display:flex;gap:.85rem;list-style:none;align-items:center;}
.nlinks a{color:var(--soft);text-decoration:none;font-family:var(--fh);font-size:1.26rem;font-weight:700;padding:.58rem 1.35rem;border-radius:50px;border:1.5px solid transparent;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s,background .2s;}
.nlinks a:hover{color:var(--white);border-color:var(--lilac);background:var(--lilac-soft);}
.nlinks a.active{color:var(--white);background:var(--lilac-soft);border-color:var(--lilac);}
.nlinks a.active span{color:var(--lilac);}
/* Enroll Now button overrides */
.nlinks a.btn-grad{color:#F4EFE2 !important;background:var(--teal);border:none;box-shadow:0 4px 20px rgba(94,107,62,.35);-webkit-text-fill-color:#F4EFE2;}
.nlinks a.btn-grad:hover{color:#F4EFE2 !important;-webkit-text-fill-color:#F4EFE2;border:none;transform:translateY(-2px);box-shadow:0 8px 28px rgba(94,107,62,.5);background:var(--teal);}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;border:none;background:none;z-index:101;}
.hamburger span{display:block;width:26px;height:2px;background:var(--soft);border-radius:2px;transition:transform .3s,opacity .3s;}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.mobile-nav{display:none;position:fixed;inset:0;z-index:98;background:rgba(var(--paper-rgb),.98);backdrop-filter:blur(20px);flex-direction:column;align-items:center;justify-content:flex-start;gap:1.2rem;opacity:0;pointer-events:none;transition:opacity .3s;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:6rem 1rem 3rem;}
.mobile-nav.open{opacity:1;pointer-events:all;}
.mobile-nav a{font-family:var(--fh);font-size:2rem;font-weight:700;color:var(--soft);text-decoration:none;cursor:pointer;padding:.5rem 1.6rem;border-radius:50px;border:1.5px solid transparent;transition:all .2s;}
.mobile-nav a:hover,.mobile-nav a.active{color:var(--white);background:rgba(124,140,86,.1);border-color:rgba(94,107,62,.25);}

/* ── BUTTONS ── */
.btn-grad{display:inline-block;background:var(--teal);color:#F4EFE2;font-family:var(--fh);font-size:1.38rem;font-weight:700;padding:1rem 2.8rem;border-radius:50px;text-decoration:none;border:none;cursor:pointer;position:relative;overflow:hidden;transition:transform .2s,box-shadow .2s;letter-spacing:.02em;box-shadow:0 4px 20px rgba(94,107,62,.35);}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(94,107,62,.5);}
.btn-grad::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,.18);opacity:0;transition:opacity .2s;}
.btn-grad:hover{transform:translateY(-2px);box-shadow:0 12px 36px rgba(124,140,86,.28);}
.btn-grad:hover::before{opacity:1;}
.btn-outline{display:inline-block;background:transparent;color:var(--white);font-family:var(--fh);font-size:1.38rem;font-weight:700;padding:1rem 2.8rem;border-radius:50px;border:2px solid var(--white);text-decoration:none;cursor:pointer;transition:border-color .2s,color .2s,background .2s;}
.btn-outline:hover{border-color:var(--white);color:var(--n1);background:var(--white);}
.btn-outline:hover{border-color:var(--white);color:var(--n1);background:var(--white);}

hr.r{border:none;position:relative;z-index:1;}
hr.r::before{content:'';display:block;height:1px;background:transparent;opacity:.35;}
section{padding:4.5rem 6%;position:relative;z-index:1;}
.ey{display:inline-block;font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--label);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.85rem;}
.st{font-family:var(--fh);font-size:clamp(2.8rem,4.8vw,4.2rem);font-weight:700;line-height:1.06;margin-bottom:1.2rem;}
.sd{font-size:1.33rem;color:var(--soft);line-height:1.7;max-width:600px;margin-bottom:3rem;}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .6s cubic-bezier(.22,1,.36,1),transform .6s cubic-bezier(.22,1,.36,1);}
.reveal.visible{opacity:1;transform:none;}
.rd1{transition-delay:.07s}.rd2{transition-delay:.14s}.rd3{transition-delay:.21s}.rd4{transition-delay:.09s}

/* ════════════════════════════════
   HOME PAGE
   ════════════════════════════════ */

/* Arc decoration layer, sits behind hero text */
.hero-arcs{
  position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:0;
}
/* big ring top-right */
.arc-ring{
  position:absolute;border-radius:50%;border-style:solid;
}
.arc-ring-1{
  width:700px;height:700px;
  top:-280px;right:-180px;
  border-width:1.5px;
  border-color:rgba(124,140,86,.30);
  animation:arcpulse 8s ease-in-out infinite;
}
.arc-ring-2{
  width:500px;height:500px;
  top:-160px;right:-60px;
  border-width:1.5px;
  border-color:rgba(140,121,192,.26);
  animation:arcpulse 10s ease-in-out infinite reverse;
}
.arc-ring-3{
  width:320px;height:320px;
  bottom:-80px;left:10%;
  border-width:1px;
  border-color:rgba(124,140,86,.22);
  animation:arcpulse 12s ease-in-out infinite;
}
/* small accent arc bottom-left */
.arc-accent{
  position:absolute;
  width:180px;height:180px;
  border-radius:50%;
  bottom:10%;left:5%;
  border:1.5px solid rgba(140,121,192,.30);
  animation:arcpulse 9s ease-in-out infinite reverse;
}
@keyframes arcpulse{
  0%,100%{transform:scale(1);opacity:1;}
  50%{transform:scale(1.03);opacity:.7;}
}

/* sweep line arcs using SVG */
.arc-svg{
  position:absolute;inset:0;width:100%;height:100%;
  pointer-events:none;
}

/* gradient orbs */
.hero-orb{position:absolute;border-radius:50%;pointer-events:none;filter:blur(60px);}
.hero-orb-1{width:640px;height:640px;top:-220px;right:-160px;background:rgba(124,140,86,.30);}
.hero-orb-2{width:460px;height:460px;bottom:-120px;left:4%;background:rgba(140,121,192,.26);}

.home-hero{
  padding:4.5rem 6% 1rem;
  position:relative;z-index:1;
  text-align:center;
  overflow:hidden;
  min-height:54vh;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.home-hero h1{
  font-family:var(--fh);
  font-size:clamp(2.8rem,6.4vw,6rem);
  font-weight:700;line-height:1.05;letter-spacing:-.025em;
  max-width:1400px;margin:0 auto 1.1rem;
  animation:hi .8s .1s cubic-bezier(.22,1,.36,1) both;
  position:relative;z-index:1;
  text-shadow:0 2px 1px rgba(44,51,38,.05);
}
.home-hero .sub{
  font-family:var(--fh);font-size:clamp(1.1rem,2.2vw,1.65rem);
  font-weight:500;color:var(--soft);margin-bottom:4rem;
  animation:hi .8s .2s cubic-bezier(.22,1,.36,1) both;
  position:relative;z-index:1;
}
@keyframes hi{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:none}}

/* ── SPLIT CARDS ── */
.split{
  display:grid;grid-template-columns:1fr;
  position:relative;z-index:1;
  animation:hi .9s .3s cubic-bezier(.22,1,.36,1) both;
}
.split-card{
  padding:0;position:relative;overflow:hidden;
  min-height:520px;display:flex;
}
.split-card.ap{
  background:var(--n1);
  border-top:1px solid var(--line);
  border-right:1px solid rgba(124,140,86,.07);
}
.split-card.stem{
  background:var(--n1);
  border-top:1px solid var(--line);
}

/* ghost: centered horizontally in the empty space between text and chips */
.ghost-layer{
  position:absolute;
  left:62%;top:50%;transform:translate(-50%,-50%);
  right:auto;
  pointer-events:none;user-select:none;z-index:0;
}
.ghost-ap-text{
  font-family:var(--fh);font-weight:700;font-size:14rem;
  line-height:1;color:var(--teal);
  opacity:.07;letter-spacing:-.05em;
  display:block;
}
.ghost-sun{
  width:320px;height:320px;
  color:var(--purple);opacity:.10;
  display:block;
}

/* deco chips, right 38% of card, evenly spaced vertically */
.deco-layer{
  position:absolute;inset:0;z-index:1;pointer-events:none;
}
@keyframes fd{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-13px) rotate(2deg)}}
.fchip,.pchip{
  position:absolute;right:var(--r,5%);top:var(--t,20%);
  background:var(--n2);border:1px solid rgba(124,140,86,.55);
  border-radius:10px;padding:.5rem 1.05rem;
  font-family:var(--fh);font-size:1.18rem;font-weight:600;
  color:var(--purple);
  box-shadow:0 4px 16px rgba(0,0,0,.08);
  animation:fd var(--d,7s) ease-in-out infinite;
}

/* content layer */
.card-content{
  position:relative;z-index:2;
  padding:4.5rem 4rem 4.5rem;
  display:flex;flex-direction:column;align-items:flex-start;
  width:60%;min-height:580px;
}
.sc-badge{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--fh);font-size:1.0rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.4rem 1rem;border-radius:50px;margin-bottom:1.5rem;}
.sc-badge.ap{color:var(--label);background:rgba(124,140,86,.1);border:1px solid rgba(124,140,86,.22);}
.sc-badge.stem{color:var(--label);background:rgba(94,107,62,.1);border:1px solid rgba(94,107,62,.22);}
.sc-badge .dot{width:6px;height:6px;border-radius:50%;flex-shrink:0;}
.sc-badge.ap .dot{background:var(--teal);}
.sc-badge.stem .dot{background:var(--purple);}
/* Simple section labels for the split-card hero (replaces .sc-badge pillbox) */
.sc-label{display:block;font-family:var(--fh);font-size:1.18rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;margin-bottom:1.4rem;line-height:1;}
.sc-label.stem{color:var(--label);}
.sc-label.ap{color:var(--label);}
.card-content h2{font-family:var(--fh);font-size:clamp(2.2rem,3.6vw,3.2rem);font-weight:700;line-height:1.08;margin-bottom:1.2rem;}
.card-desc{font-size:1.28rem;color:var(--soft);line-height:1.7;margin-bottom:auto;padding-bottom:2.5rem;max-width:560px;}
.card-btn{margin-top:1.8rem;}

.split-div{display:none;}

/* ════ PARENTS PAGE ════ */
.parents-hero{padding:6rem 6% 3.5rem;text-align:center;position:relative;z-index:1;overflow:hidden;}
.parents-hero h1,.parents-hero h2{font-family:var(--fh);font-size:clamp(2.6rem,5.5vw,5rem);font-weight:700;line-height:1.06;letter-spacing:-.02em;max-width:800px;margin:0 auto 1.4rem;animation:hi .8s cubic-bezier(.22,1,.36,1) both;}
.parents-hero .psub{font-size:1.28rem;color:var(--soft);max-width:540px;margin:0 auto 3rem;line-height:1.7;animation:hi .8s .15s cubic-bezier(.22,1,.36,1) both;}
.parents-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-bottom:5rem;}
.pcard{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:2.2rem 1.8rem;position:relative;overflow:hidden;transition:border-color .3s,transform .3s;}
.pcard:hover{border-color:rgba(124,140,86,.3);transform:translateY(-4px);}
.pcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.pcard-icon{font-size:2.2rem;margin-bottom:1rem;display:block;}
.pcard h3{font-family:var(--fh);font-size:1.33rem;font-weight:700;margin-bottom:.6rem;}
.pcard p{font-size:1.06rem;color:var(--soft);line-height:1.7;}

/* ── OUTCOMES (What you get) ── */
.outcomes-sec{background:var(--n1);}
.outcomes-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.6rem;
  margin-top:3rem;
}
.ocard{
  background:var(--n2);border:1px solid var(--line);border-radius:22px;
  padding:2.4rem 2.2rem;position:relative;overflow:hidden;
  transition:border-color .3s,transform .3s;
}
.ocard:hover{border-color:rgba(124,140,86,.35);transform:translateY(-4px);}
.ocard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.ocard-icon{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px;background:rgba(124,140,86,.13);border:1px solid rgba(124,140,86,.3);margin-bottom:1.1rem;}
.ocard-icon svg{width:24px;height:24px;color:var(--teal);stroke-width:1.7;}
.ocard-tag{font-family:var(--fh);font-size:.88rem;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);margin-bottom:.5rem;}
.ocard h3{font-family:var(--fh);font-size:1.5rem;font-weight:700;color:var(--white);margin-bottom:.8rem;line-height:1.25;}
.ocard p{font-size:1.07rem;color:var(--soft);line-height:1.75;margin-bottom:0;}
.ocard p + p{margin-top:.7rem;}
.ocard-feature{
  grid-column:1 / -1;
  background:linear-gradient(180deg,rgba(124,140,86,.06) 0%,var(--n2) 60%);
  border-color:rgba(124,140,86,.32);
  padding:2.8rem 2.5rem;
}
.ocard-feature::before{height:3px;background:linear-gradient(90deg,var(--teal),rgba(124,140,86,.5),var(--teal));}
.ocard-feature h3{font-size:1.85rem;}
.ocard-feature p{font-size:1.13rem;}
.ocard-feature em{color:var(--white);font-style:italic;font-weight:600;}
@media(max-width:860px){
  .outcomes-grid{grid-template-columns:1fr;}
  .ocard-feature{padding:2rem 1.5rem;}
}
.contact-box{background:var(--n2);border:1px solid var(--line);border-radius:24px;padding:4rem 3rem;text-align:center;max-width:700px;margin:0 auto;position:relative;overflow:hidden;}
.contact-box::before{content:'';position:absolute;inset:0;background:rgba(94,107,62,.1);pointer-events:none;}
.contact-box h2{font-family:var(--fh);font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;line-height:1.1;margin-bottom:.9rem;}
.contact-box p{font-size:1.15rem;color:var(--soft);line-height:1.7;max-width:460px;margin:0 auto 2rem;}
.email-link{display:inline-block;background:var(--teal);color:#F4EFE2;font-family:var(--fh);font-size:1.28rem;font-weight:700;padding:.9rem 2.5rem;border-radius:50px;text-decoration:none;transition:transform .2s,box-shadow .2s;position:relative;z-index:1;}
.email-link:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(124,140,86,.25);}
.contact-note{font-size:1.03rem;color:var(--soft);margin-top:2rem;font-style:italic;line-height:1.7;}
/* ── CONTACT FORMS (inside .contact-box or .contact-collapse-body) ── */
.contact-box .mform,.contact-collapse-body .mform{max-width:520px;margin:0 auto;text-align:left;position:relative;z-index:1;}
.contact-box .mform .mfield label,.contact-collapse-body .mform .mfield label{font-size:1.05rem;}
.contact-box .mform .mfield input,
.contact-box .mform .mfield select,
.contact-box .mform .mfield textarea,
.contact-collapse-body .mform .mfield input,
.contact-collapse-body .mform .mfield select,
.contact-collapse-body .mform .mfield textarea{font-size:1.05rem;padding:.78rem 1rem;}
.contact-box textarea,.contact-collapse-body textarea{background:var(--field);border:1.5px solid var(--line);border-radius:12px;color:var(--white);font-family:var(--fb);transition:border-color .2s,box-shadow .2s;width:100%;resize:vertical;min-height:120px;line-height:1.55;}
.contact-box textarea::placeholder,.contact-collapse-body textarea::placeholder{color:var(--soft);opacity:.75;}
.contact-box textarea:focus,.contact-collapse-body textarea:focus{outline:none;border-color:rgba(124,140,86,.5);box-shadow:0 0 0 3px rgba(124,140,86,.1);}
.contact-box .mform button[type="submit"],.contact-collapse-body .mform button[type="submit"]{margin-top:.4rem;width:100%;font-size:1.18rem;padding:.95rem 2rem;}
.contact-box .modal-success,.contact-collapse-body .modal-success{padding:1rem 0 0;position:relative;z-index:1;}
.contact-or{font-size:.95rem;color:var(--soft);margin:1.4rem 0 0;text-align:center;position:relative;z-index:1;font-style:normal;}
.contact-or a{color:var(--teal);text-decoration:none;font-weight:600;}
.contact-or a:hover{text-decoration:underline;}

/* ── COLLAPSIBLE CONTACT CARDS (Giving Back) ── */
.contact-collapse{background:var(--n2);border:1px solid var(--line);border-radius:24px;max-width:760px;margin:0 auto;overflow:hidden;transition:border-color .25s,box-shadow .25s;}
.contact-collapse:hover{border-color:rgba(124,140,86,.28);}
.contact-collapse[open]{border-color:rgba(124,140,86,.4);box-shadow:0 10px 36px rgba(94,107,62,.08);}
.contact-collapse > summary{padding:1.85rem 2.3rem;display:flex;align-items:center;justify-content:space-between;gap:1.4rem;cursor:pointer;list-style:none;-webkit-tap-highlight-color:transparent;}
.contact-collapse > summary::-webkit-details-marker{display:none;}
.contact-collapse > summary::marker{content:'';}
.contact-collapse-head{flex:1;min-width:0;text-align:left;}
.contact-collapse-head h2{font-family:var(--fh);font-size:clamp(1.45rem,2.5vw,1.95rem);font-weight:700;line-height:1.22;margin:0 0 .35rem;color:var(--white);}
.contact-collapse-head p{font-size:1rem;color:var(--soft);line-height:1.55;margin:0;max-width:none;}
.contact-collapse-icon{flex-shrink:0;width:42px;height:42px;font-size:1.38rem;border-radius:50%;border:1.5px solid rgba(124,140,86,.3);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:transform .3s,background .25s,border-color .25s;}
.contact-collapse-icon svg{width:20px;height:20px;}
.contact-collapse[open] .contact-collapse-icon{transform:rotate(45deg);background:rgba(124,140,86,.12);border-color:rgba(124,140,86,.5);}
.contact-collapse-body{padding:.6rem 2.3rem 2.4rem;border-top:1px solid var(--line);padding-top:2rem;}
.contact-collapse-body > p:first-child{font-size:1.08rem;color:var(--soft);line-height:1.65;margin:0 auto 1.6rem;max-width:520px;text-align:center;}
@media (max-width:640px){
  .contact-collapse > summary{padding:1.5rem 1.4rem;gap:1rem;}
  .contact-collapse-body{padding:1.6rem 1.4rem 1.8rem;}
}

/* ════ AP PAGE ════ */
.ap-page-hero{padding:5rem 6% 3rem;position:relative;z-index:1;text-align:center;}
.ap-page-hero h1,.ap-page-hero h2{font-family:var(--fh);font-size:clamp(2.6rem,5vw,4.5rem);font-weight:700;line-height:1.06;letter-spacing:-.02em;margin-bottom:1rem;animation:hi .8s cubic-bezier(.22,1,.36,1) both;}
.ap-page-hero p{font-size:1.23rem;color:var(--soft);max-width:560px;margin:0 auto;line-height:1.7;}
/* Giving Back page: scaled UP for stronger visual presence */
#page-grants .ap-page-hero{padding:5.5rem 6% 3rem;}
#page-grants .ap-page-hero h1,#page-grants .ap-page-hero h2{font-size:clamp(3rem,5.4vw,5rem);margin-bottom:1.4rem;line-height:1.04;}
#page-grants .ap-page-hero .ey{font-size:1.23rem;margin-bottom:1.2rem;}
#page-grants .ap-page-hero p{font-size:1.38rem;max-width:720px;line-height:1.7;}
#page-grants .ey{font-size:1.23rem;}
#page-grants .st{font-size:clamp(2.6rem,4.4vw,3.7rem);line-height:1.08;margin-bottom:1.3rem;}
#page-grants .sd{font-size:1.33rem;max-width:680px;line-height:1.75;margin-bottom:3rem;}
#page-grants section{padding-top:6rem;padding-bottom:6rem;}
#page-grants .fcards{margin-top:3rem;margin-bottom:4rem;}
#page-grants .fcard{padding:2.2rem 2rem;}
#page-grants .fcard-ic{font-size:2.2rem;width:64px;height:64px;}
#page-grants .fcard h3{font-size:1.48rem;margin-bottom:.6rem;}
#page-grants .fcard p{font-size:1.18rem;line-height:1.7;}
#page-grants .contact-box h2{font-size:clamp(2.2rem,3.8vw,3rem);}
#page-grants .contact-box p{font-size:1.28rem;}
#page-grants .contact-box .email-link{font-size:1.38rem;padding:1rem 2.7rem;}
#page-grants .contact-note{font-size:1.18rem;margin-top:2.4rem;line-height:1.7;}
.ap-coming-note{display:inline-block;font-family:var(--fh);font-size:1.0rem;font-weight:600;color:var(--soft);background:var(--n2);border:1px solid var(--line);border-radius:50px;padding:.4rem 1.1rem;margin-top:1.4rem;}
.ap-grid-section{padding:2rem 6% 6rem;position:relative;z-index:1;}
.ap-cat-label{font-family:var(--fh);font-size:1.0rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:1rem;margin-top:2.8rem;display:block;}
.ap-cat-label:first-child{margin-top:0;}
.ap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:.85rem;}
.ap-btn{background:var(--n2);border:1px solid var(--line);border-radius:14px;padding:1.35rem 1.2rem;display:flex;flex-direction:column;align-items:flex-start;gap:.45rem;cursor:default;position:relative;overflow:hidden;transition:border-color .25s,transform .2s;}
.ap-btn:hover{border-color:rgba(124,140,86,.25);transform:translateY(-2px);}
.ap-btn::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);opacity:.5;}
.ap-btn-icon{font-size:1.5rem;line-height:1;}
.ap-btn-name{font-family:var(--fh);font-size:1.13rem;font-weight:700;line-height:1.2;color:var(--white);}
.ap-btn-soon{font-family:var(--fh);font-size:0.9rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;background:var(--n3);border:1px solid var(--line);border-radius:50px;padding:.15rem .55rem;margin-top:.1rem;}

/* ════ STEM PAGE ════ */
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.7rem;}
.acard{background:var(--n3);border:1px solid var(--line);border-radius:20px;padding:2.4rem 2rem;position:relative;overflow:hidden;transition:border-color .3s,transform .3s,box-shadow .3s;}
.acard:hover{border-color:rgba(94,107,62,.35);transform:translateY(-5px);box-shadow:0 18px 44px rgba(94,107,62,.1);}
.acard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.acard::after{content:'';position:absolute;inset:0;background:rgba(124,140,86,.04);opacity:0;transition:opacity .3s;}
.acard:hover::after{opacity:1;}
.ac-icon{width:48px;height:48px;border-radius:14px;background:rgba(124,140,86,.1);border:1px solid rgba(124,140,86,.15);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.2rem;transition:transform .3s;flex-shrink:0;}
.acard:hover .ac-icon{transform:scale(1.08);}
.acard h3{font-family:var(--fh);font-size:1.38rem;font-weight:700;margin-bottom:.6rem;}
.acard p{font-size:1.08rem;color:var(--soft);line-height:1.7;}
.community{background:var(--n1);}
.comm-inner{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;}
.comm-left p{font-size:1.3rem;color:var(--soft);line-height:1.7;margin-bottom:1.3rem;}
.comm-left p b{color:var(--white);font-weight:500;}
.comm-right{display:flex;flex-direction:column;gap:1.2rem;}
.cblock{background:var(--n2);border:1px solid var(--line);border-radius:16px;padding:1.85rem 2rem;position:relative;overflow:hidden;transition:border-color .25s,transform .25s;}
.cblock:hover{border-color:rgba(124,140,86,.3);transform:translateX(4px);}
.cblock::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--teal);border-radius:3px 0 0 3px;}
.cblock h4{font-family:var(--fh);font-size:1.38rem;font-weight:700;margin-bottom:.5rem;}
.cblock p{font-size:1.18rem;color:var(--soft);line-height:1.6;}
.pct-badge{display:flex;flex-direction:column;align-items:flex-start;gap:.6rem;margin-bottom:1.6rem;}
.pct-badge .pct-num{font-family:var(--fh);font-size:5.2rem;font-weight:700;line-height:1;color:var(--teal);text-decoration:underline;text-decoration-color:var(--lilac);text-decoration-thickness:.06em;text-underline-offset:.12em;}
.pct-badge .pct-label{font-family:var(--fh);font-size:1.48rem;font-weight:600;color:var(--soft);line-height:1.3;}
.subj-wrap{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;}
.scard{background:var(--n2);border:1px solid var(--line);border-radius:16px;padding:1.7rem;display:flex;align-items:flex-start;gap:1.1rem;transition:border-color .25s,transform .25s,box-shadow .25s;}
.scard:hover{border-color:rgba(124,140,86,.3);transform:translateY(-3px);box-shadow:0 12px 30px rgba(124,140,86,.08);}
.si{flex-shrink:0;width:46px;height:46px;background:var(--n3);border:1px solid var(--line);border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:1.53rem;transition:transform .25s,border-color .25s;}
.scard:hover .si{transform:rotate(-6deg) scale(1.08);border-color:rgba(124,140,86,.3);}
.scard h3{font-family:var(--fh);font-size:1.18rem;font-weight:700;margin-bottom:.35rem;}
.scard p{font-size:1.0rem;color:var(--soft);line-height:1.6;}
.tracks-bg{background:var(--n2);}
.track-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;}
.tcard{border-radius:22px;padding:2.8rem 2.4rem;position:relative;overflow:hidden;transition:transform .3s,box-shadow .3s;}
.tcard:hover{transform:translateY(-4px);}
.tcard.ta{background:rgba(124,140,86,.04);border:1px solid rgba(124,140,86,.18);}
.tcard.ta:hover{box-shadow:0 18px 44px rgba(124,140,86,.1);}
.tcard.tb{background:rgba(94,107,62,.04);border:1px solid rgba(94,107,62,.18);}
.tcard.tb:hover{box-shadow:0 18px 44px rgba(94,107,62,.1);}
.tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2.5px;}
.tcard.ta::before{background:var(--teal);}
.tcard.tb::before{background:var(--purple);}
.tcard-bg-num{position:absolute;right:1.6rem;top:1.6rem;font-family:var(--fh);font-size:2.2rem;font-weight:700;line-height:1;opacity:1;pointer-events:none;user-select:none;letter-spacing:-.01em;}
.tcard.ta .tcard-bg-num{color:var(--teal);}
.tcard.tb .tcard-bg-num{color:var(--purple);}
.tcard-grade{display:block;font-family:var(--fh);font-size:1.0rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.85rem;}
.tcard h3{font-family:var(--fh);font-size:clamp(2rem,3.2vw,2.8rem);font-weight:700;line-height:1;margin-bottom:.45rem;}
.tcard.ta h3{color:var(--teal);}
.tcard.tb h3{color:var(--purple);}
.tgrades{font-family:var(--fb);font-size:1.06rem;color:var(--soft);margin-bottom:1.6rem;line-height:1.5;}
.tcard ul{list-style:none;display:flex;flex-direction:column;gap:.75rem;}
.tcard li{font-size:1.06rem;color:var(--soft);display:flex;align-items:flex-start;gap:.65rem;line-height:1.5;}
.td{flex-shrink:0;width:5px;height:5px;border-radius:50%;margin-top:7px;}
.td.a{background:var(--teal)}.td.b{background:var(--purple)}
/* Two-week schedule rotation graphic */
.schedule-sec{padding:4.5rem 6%;}
.schedule-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1rem;margin:2.5rem 0 2rem;position:relative;}
.schedule-grid::before{content:'';position:absolute;top:50%;left:2%;right:2%;height:2px;background:linear-gradient(90deg,rgba(124,140,86,.05),rgba(124,140,86,.45) 15%,rgba(124,140,86,.45) 85%,rgba(124,140,86,.05));z-index:0;pointer-events:none;}
.schedule-card{background:var(--n2);border:1px solid var(--line);border-radius:18px;padding:1.4rem 1.2rem;text-align:center;position:relative;z-index:1;transition:transform .25s,border-color .25s,box-shadow .25s;display:flex;flex-direction:column;align-items:center;gap:.55rem;}
.schedule-card:hover{transform:translateY(-4px);border-color:rgba(124,140,86,.4);box-shadow:0 14px 30px rgba(124,140,86,.1);}
.schedule-card .sch-week{font-family:var(--fh);font-size:0.98rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--label);}
.schedule-card .sch-days{font-family:var(--fb);font-size:1.13rem;font-weight:600;color:var(--soft);line-height:1.35;}
.schedule-card .sch-icon{width:54px;height:54px;border-radius:50%;background:rgba(124,140,86,.12);border:1.5px solid rgba(124,140,86,.3);display:flex;align-items:center;justify-content:center;color:var(--purple);font-size:1.5rem;margin:.4rem 0;flex-shrink:0;}
.schedule-card .sch-subject{font-family:var(--fh);font-size:1.38rem;font-weight:700;color:var(--white);}
.schedule-card .sch-tag{font-family:var(--fh);font-size:0.96rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--teal);background:rgba(124,140,86,.12);padding:.25rem .7rem;border-radius:50px;}
.schedule-card.sc-1 .sch-icon{color:#A06D58;background:rgba(160,109,88,.1);border-color:rgba(160,109,88,.3);}
.schedule-card.sc-2 .sch-icon{color:var(--purple);}
.schedule-card.sc-3 .sch-icon{color:#5E6B9E;background:rgba(94,107,158,.1);border-color:rgba(94,107,158,.3);}
.schedule-card.sc-4 .sch-icon{color:var(--lilac);background:rgba(140,121,192,.12);border-color:rgba(140,121,192,.3);}
.schedule-card.sc-5 .sch-icon{color:var(--teal);}
.schedule-foot{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.2rem;}
.sch-foot-item{font-size:1.18rem;color:var(--soft);line-height:1.6;padding-left:1rem;border-left:3px solid rgba(124,140,86,.35);}
.sch-foot-item strong{color:var(--white);font-weight:700;}
@media(max-width:960px){.schedule-grid{grid-template-columns:repeat(2,1fr);}.schedule-grid::before{display:none;}.schedule-foot{grid-template-columns:1fr;}}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;position:relative;}
.step{background:var(--n2);border:1px solid var(--line);border-radius:18px;padding:1.8rem 1.5rem;text-align:center;transition:border-color .25s,transform .25s,box-shadow .25s;}
.step:hover{border-color:rgba(94,107,62,.35);transform:translateY(-4px);box-shadow:0 14px 36px rgba(94,107,62,.1);}
.sn{width:50px;height:50px;border-radius:50%;background:var(--teal);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:1.43rem;font-weight:700;color:#F4EFE2;margin:0 auto 1.1rem;transition:transform .25s,box-shadow .25s;}
.step:hover .sn{transform:scale(1.1) rotate(6deg);box-shadow:0 0 0 6px rgba(124,140,86,.1);}
.step h4{font-family:var(--fh);font-size:1.28rem;font-weight:700;margin-bottom:.5rem;}
.step p{font-size:1.13rem;color:var(--soft);line-height:1.6;}
.cta-sec{background:var(--n2);text-align:center;padding:5.5rem 6%;position:relative;overflow:hidden;}
.cta-sec::before{content:'';position:absolute;width:1280px;height:840px;border-radius:50%;background:rgba(140,121,192,.10);top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none;}
.cta-sec .st{font-size:clamp(2.5rem,5vw,4rem);margin-bottom:.9rem;}
.cta-sec .sd{margin:0 auto 1.5rem;}
.ptag{display:inline-block;background:rgba(124,140,86,.08);border:1px solid rgba(94,107,62,.25);border-radius:50px;padding:.55rem 1.7rem;font-family:var(--fh);font-size:1.15rem;font-weight:600;margin-bottom:2rem;}
.ptag span{color:var(--teal);}
.cta-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:1.1rem;}
.cta-note{font-size:0.94rem;color:var(--soft);}
footer{border-top:1px solid rgba(124,140,86,.1);padding:2.5rem 6%;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:2rem;position:relative;z-index:1;}
.footer-logo img{height:68px;transition:transform .25s;cursor:pointer;}
.footer-logo img:hover{transform:scale(1.04);}
footer p{font-size:0.95rem;color:var(--soft);text-align:center;}
.fl{display:flex;gap:1.6rem;list-style:none;justify-content:flex-end;}
.fl a{font-family:var(--fh);font-size:1.06rem;color:var(--soft);text-decoration:none;font-weight:600;transition:color .2s;cursor:pointer;}
.fl a:hover{color:var(--teal);}

/* ════ MOBILE ════ */

/* ── STEM OVERVIEW ── */
.stem-intro{margin-bottom:0;}
.stem-features{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:1.6rem;
}
.sfeat{
  background:var(--n3);border:1px solid var(--line);
  border-radius:20px;padding:2.4rem 2.1rem;
  display:flex;align-items:flex-start;gap:1.25rem;
  transition:border-color .25s,transform .25s;
}
.sfeat:hover{border-color:rgba(124,140,86,.28);transform:translateY(-3px);}
.sfeat-icon{font-size:2.2rem;flex-shrink:0;line-height:1;}
.sfeat h4{font-family:var(--fh);font-size:1.55rem;font-weight:700;margin-bottom:.55rem;line-height:1.2;}
.sfeat p{font-size:1.18rem;color:var(--soft);line-height:1.65;}
@media(max-width:860px){
  .stem-features{grid-template-columns:1fr;}
}

@media(max-width:1100px){
  .nlinks{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}
}
@media(max-width:860px){
  .home-hero{padding:5rem 6% 0;min-height:auto;}
  .home-hero h1{font-size:clamp(2.4rem,9vw,3.8rem);}
  .home-hero .sub{font-size:1.28rem;margin-bottom:3rem;}
  .split{grid-template-columns:1fr;}
  .split-div{display:none;}
  .split-card{min-height:auto;flex-direction:column;}
  .card-content{width:100%;padding:3.5rem 6%;align-items:center;text-align:center;min-height:auto;}
  .card-content h2{font-size:clamp(1.8rem,6vw,2.5rem);}
  .deco-layer{display:none;}
  .ghost-layer{display:none;}
  .parents-grid{grid-template-columns:1fr;}
  .parents-hero{padding:6rem 6% 3rem;}
  .about-grid,.subj-wrap,.track-grid,.steps,.comm-inner{grid-template-columns:1fr;}
  .steps::before{display:none;}
  section{padding:5rem 6%;}
  footer{grid-template-columns:1fr;text-align:center;}
  .fl{justify-content:center;}
  .footer-logo img{height:58px;}
  .ap-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));}
  .arc-ring,.arc-accent{display:none;}
}
@media(max-width:480px){
  .home-hero h1{font-size:2.2rem;}
  .btn-grad,.btn-outline{font-size:1.23rem;padding:.9rem 2rem;width:100%;text-align:center;}
  .cta-row{flex-direction:column;align-items:center;}
  .nlogo img{height:52px;}
}

/* ── SKIP LINK ── */
.skip-link{position:absolute;top:-100px;left:1rem;background:var(--teal);color:#EDE8D8;padding:.5rem 1rem;border-radius:8px;font-family:var(--fh);font-weight:700;z-index:9999;transition:top .2s;text-decoration:none;}
.skip-link:focus{top:1rem;outline:3px solid var(--purple);}

/* ── FOCUS VISIBLE ── */
:focus-visible{outline:2px solid var(--teal);outline-offset:3px;border-radius:6px;}
button:focus-visible,a:focus-visible{outline:2px solid var(--teal);outline-offset:3px;}

/* ── REDUCE MOTION ── */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.15ms!important;}
  .reveal{opacity:1!important;transform:none!important;}
}

/* ── STATS BAR ── */
.stats-bar{display:flex;justify-content:center;align-items:center;gap:0;flex-wrap:wrap;position:relative;z-index:1;background:rgba(var(--paper-rgb),.7);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stat{text-align:center;padding:2rem 3.5rem;position:relative;}
.stat+.stat::before{content:'';position:absolute;left:0;top:25%;bottom:25%;width:1px;background:var(--line);}
.stat-num{font-family:var(--fh);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;color:var(--purple);display:block;line-height:1;}
.stat-label{font-size:0.98rem;color:var(--soft);text-transform:uppercase;letter-spacing:.1em;font-family:var(--fh);display:block;margin-top:.35rem;}

/* ── HERO CTA ROW ── */
.hero-cta{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;margin-bottom:3rem;position:relative;z-index:1;}

/* ── MODAL ── */
.modal-backdrop{position:fixed;inset:0;z-index:9900;background:rgba(0,0,0,.7);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;padding:1rem;opacity:0;pointer-events:none;transition:opacity .3s;}
.modal-backdrop.open{opacity:1;pointer-events:all;}
.modal{background:var(--n2);border:1px solid rgba(124,140,86,.2);border-radius:24px;padding:3.2rem 3rem;max-width:760px;width:100%;position:relative;overflow:hidden;max-height:92vh;overflow-y:auto;transform:translateY(28px) scale(.97);transition:transform .35s cubic-bezier(.22,1,.36,1);}
.modal-backdrop.open .modal{transform:none;}
.modal::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);}
.modal-close{position:absolute;top:1.2rem;right:1.2rem;background:none;border:none;color:var(--soft);cursor:pointer;font-size:1.5rem;line-height:1;width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:color .2s,background .2s;}
.modal-close:hover{color:var(--white);background:rgba(255,255,255,.08);}
.modal-eyebrow{font-family:var(--fh);font-size:1.0rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem;}
.modal h2{font-family:var(--fh);font-size:clamp(2rem,3.4vw,2.6rem);font-weight:700;margin-bottom:.5rem;line-height:1.08;}
.modal .msubhead{font-size:1.26rem;color:var(--soft);line-height:1.6;margin-bottom:1.8rem;}
.mpricetag{display:flex;align-items:baseline;gap:.85rem;background:linear-gradient(135deg,rgba(124,140,86,.14),rgba(124,140,86,.06));border:2px solid rgba(124,140,86,.42);border-radius:18px;padding:1.15rem 1.5rem;font-family:var(--fh);font-size:1.53rem;font-weight:700;color:var(--white);margin-bottom:1.5rem;line-height:1.1;box-shadow:0 4px 18px rgba(124,140,86,.12);}
.mpricetag .price{color:var(--teal);font-size:2.2rem;font-weight:800;letter-spacing:-.02em;}
.mpricetag .mprice-link{margin-left:auto;font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--label);text-decoration:none;border-bottom:1.5px solid rgba(140,121,192,.4);padding-bottom:1px;transition:color .2s,border-color .2s;white-space:nowrap;}
.mpricetag .mprice-link:hover{color:var(--lilac);border-color:var(--lilac);}
.mform{display:flex;flex-direction:column;gap:1rem;}
.mfield{display:flex;flex-direction:column;gap:.35rem;}
.mfield label{font-family:var(--fh);font-size:1.23rem;font-weight:700;color:var(--white);}
.mfield input,.mfield select{background:var(--field);border:1.5px solid var(--line);border-radius:12px;padding:.95rem 1.15rem;color:var(--white);font-family:var(--fb);font-size:1.26rem;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;appearance:none;width:100%;margin-top:auto;}
.mfield input::placeholder{color:var(--soft);opacity:.75;}
.mfield input:focus,.mfield select:focus{outline:none;border-color:rgba(124,140,86,.5);box-shadow:0 0 0 3px rgba(124,140,86,.1);}
.mfield select option{background:var(--n2);color:var(--white);}
.mrow{display:grid;grid-template-columns:1fr 1fr;gap:.9rem;align-items:stretch;}
.mcheck{display:flex;align-items:center;gap:.55rem;cursor:pointer;font-size:1.13rem;color:var(--soft);line-height:1.4;margin-top:.6rem;}
.mcheck input[type=checkbox]{flex-shrink:0;width:18px;height:18px;margin:0;accent-color:var(--teal);cursor:pointer;}
.mcheck a{color:var(--teal);}
.mcheck a:hover{text-decoration:underline;}
.mnote{font-size:0.92rem;color:var(--soft);font-style:italic;text-align:center;margin-top:.3rem;}
.modal-success{text-align:center;display:none;padding:1.5rem 0;}
.modal-success.show{display:block;}
.modal-success-icon{font-size:3.5rem;margin-bottom:1rem;display:block;}
.modal-success h3{font-family:var(--fh);font-size:1.7rem;font-weight:700;margin-bottom:.6rem;}
.modal-success p{font-size:1.08rem;color:var(--soft);line-height:1.65;}
.mform.hidden{display:none;}

/* ── FAQ ── */
.faq-section{background:var(--n2);}
.faq-list{display:flex;flex-direction:column;gap:.9rem;max-width:1040px;margin:0 auto;}
.faq-item{background:var(--n1);border:1px solid var(--line);border-radius:18px;overflow:hidden;transition:border-color .25s;}
.faq-item:hover{border-color:rgba(124,140,86,.2);}
.faq-item[data-open="true"]{border-color:rgba(124,140,86,.28);}
.faq-q{width:100%;background:none;border:none;padding:1.7rem 2rem;display:flex;align-items:center;justify-content:space-between;gap:1.2rem;cursor:pointer;text-align:left;color:var(--white);}
.faq-q-text{font-family:var(--fh);font-size:1.43rem;font-weight:700;line-height:1.3;}
.faq-icon{flex-shrink:0;width:36px;height:36px;font-size:1.38rem;border-radius:50%;border:1.5px solid rgba(124,140,86,.25);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:transform .3s,background .25s,border-color .25s;}
.faq-item[data-open="true"] .faq-icon{transform:rotate(45deg);background:rgba(124,140,86,.1);border-color:rgba(124,140,86,.5);}
.faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .32s cubic-bezier(.22,1,.36,1);}
.faq-item[data-open="true"] .faq-a{grid-template-rows:1fr;}
.faq-a-inner{overflow:hidden;padding:0 2rem;transition:padding .25s;}
.faq-item[data-open="true"] .faq-a-inner{padding:0 2rem 1.6rem;}
.faq-a-inner p{font-size:1.23rem;color:var(--soft);line-height:1.7;}

/* ── SPECIALISTS SECTION (PARENTS) ── */
.spec-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1.4rem;margin-bottom:6rem;}
.scard-p{flex:0 1 calc(33.333% - 1rem);min-width:260px;background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:2rem 1.7rem;position:relative;overflow:hidden;transition:border-color .3s,transform .25s;}
.scard-p:hover{border-color:rgba(124,140,86,.3);transform:translateY(-4px);}
.scard-p::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.scard-p-icon{width:52px;height:52px;border-radius:14px;background:rgba(124,140,86,.12);border:1px solid rgba(124,140,86,.18);display:flex;align-items:center;justify-content:center;font-size:1.5rem;margin-bottom:1.1rem;}
.scard-p h3{font-family:var(--fh);font-size:1.38rem;font-weight:700;margin-bottom:.5rem;}
.scard-p p{font-size:1.18rem;color:var(--soft);line-height:1.65;}
.vetting-row{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin:5rem 0 4rem;padding:4rem 2.5rem;background:rgba(124,140,86,.05);border:1px solid rgba(124,140,86,.18);border-radius:24px;}
.vetting-left p{font-size:1.23rem;color:var(--soft);line-height:1.7;margin-bottom:1rem;}
.vetting-left p b{color:var(--white);font-weight:500;}
.vetting-right{display:flex;flex-direction:column;gap:.9rem;}
.vcrit{display:flex;align-items:flex-start;gap:.95rem;background:var(--n2);border:1px solid var(--line);border-radius:14px;padding:1.3rem 1.5rem;transition:border-color .25s;}
.vcrit:hover{border-color:rgba(124,140,86,.25);}
.vcrit-icon{font-size:1.58rem;flex-shrink:0;margin-top:.15rem;}
.vcrit h4{font-family:var(--fh);font-size:1.28rem;font-weight:700;margin-bottom:.3rem;}
.vcrit p{font-size:1.13rem;color:var(--soft);line-height:1.55;}

/* ── AP WAITLIST ── */
.waitlist-sect{padding:2rem 6% 4rem;position:relative;z-index:1;}
.waitlist-box{background:rgba(124,140,86,.05);border:1px solid rgba(124,140,86,.18);border-radius:24px;padding:2.8rem 3rem;max-width:640px;margin:0 auto;text-align:center;position:relative;overflow:hidden;}
.waitlist-box::before{content:'';position:absolute;inset:0;background:rgba(124,140,86,.06);pointer-events:none;}
.waitlist-box h2{font-family:var(--fh);font-size:clamp(1.5rem,2.8vw,2rem);font-weight:700;margin-bottom:.5rem;position:relative;z-index:1;}
.waitlist-box p{font-size:1.08rem;color:var(--soft);max-width:420px;margin:0 auto 1.6rem;line-height:1.7;position:relative;z-index:1;}
.wl-form{display:flex;gap:.7rem;max-width:420px;margin:0 auto;position:relative;z-index:1;}
.wl-input{flex:1;background:var(--field);border:1.5px solid var(--line);border-radius:50px;padding:.78rem 1.4rem;color:var(--white);font-family:var(--fb);font-size:1.11rem;transition:border-color .2s;}
.wl-input:focus{outline:none;border-color:rgba(124,140,86,.5);box-shadow:0 0 0 3px rgba(124,140,86,.1);}
.wl-input::placeholder{color:var(--soft);opacity:.75;}
.wl-success{display:none;color:var(--teal);font-family:var(--fh);font-size:1.23rem;font-weight:600;padding:.5rem 0;position:relative;z-index:1;}
.wl-form.hidden{display:none;}
.wl-success.show{display:block;}

/* ── AP COURSE CARDS ── */
.ap-btn{cursor:default;background:var(--n2);}

/* ── FOOTER LINKS ── */
.fl a[onclick*="privacy"],.fl a[onclick*="terms"]{color:var(--soft);opacity:.75;}

/* ── REVIEWS / TESTIMONIALS ── */
.reviews-sec{background:var(--n2);padding-top:5rem;padding-bottom:5rem;}
.reviews-grid{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:1.6rem;
  max-width:1200px;
  margin:3rem auto 2rem;
}
.rcard{
  position:relative;
  background:var(--n1);
  border:1px solid var(--line);
  border-radius:20px;
  padding:2.2rem 2rem 1.8rem;
  margin:0;
  overflow:hidden;
  transition:border-color .3s,transform .3s;
}
.rcard:hover{border-color:rgba(124,140,86,.32);transform:translateY(-3px);}
.rcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.rcard-quote{
  position:absolute;
  top:-.4rem;right:1.2rem;
  font-family:Georgia,serif;
  font-size:5.5rem;font-weight:700;
  color:rgba(124,140,86,.18);
  line-height:1;pointer-events:none;
}
.rcard blockquote{margin:0 0 1.4rem;}
.rcard blockquote p{
  font-size:1.13rem;
  color:var(--white);
  line-height:1.7;
  font-style:italic;
  margin:0;
}
.rcard figcaption{
  border-top:1px solid var(--line);
  padding-top:1rem;
  display:flex;
  flex-direction:column;
  gap:.25rem;
}
.rcard-stars{
  color:var(--teal);
  font-size:1.05rem;
  letter-spacing:.15em;
  margin-bottom:.25rem;
}
.rcard-name{
  font-family:var(--fh);
  font-size:1.08rem;
  font-weight:700;
  color:var(--white);
}
.rcard-meta{
  font-size:.95rem;
  color:var(--soft);
}
.reviews-disclaimer{
  text-align:center;
  font-size:.95rem;
  color:var(--soft);
  font-style:italic;
  max-width:760px;
  margin:2rem auto 0;
  line-height:1.6;
}
@media(max-width:860px){
  .reviews-grid{grid-template-columns:1fr;}
  .rcard{padding:1.8rem 1.4rem 1.5rem;}
}

/* ── ENROLLMENT MODAL (widened + accented) ── */
#modal-enroll .modal{
  max-width:900px;
  padding:3.4rem 3.4rem 3rem;
  border:1.5px solid rgba(124,140,86,.42);
  box-shadow:0 50px 110px rgba(0,0,0,.55),0 0 0 1px rgba(124,140,86,.15),0 -2px 0 rgba(124,140,86,.55) inset;
  background:var(--n2);
}
#modal-enroll .modal::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--teal) 0%,rgba(124,140,86,.6) 50%,var(--teal) 100%);
}
#modal-enroll #enroll-title{font-size:clamp(2rem,3.2vw,2.65rem);}
#modal-enroll .mform{max-width:none;}
.menroll-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--fh);font-size:.92rem;font-weight:700;
  letter-spacing:.14em;text-transform:uppercase;color:var(--teal);
  background:rgba(124,140,86,.13);border:1px solid rgba(124,140,86,.35);
  border-radius:999px;padding:.4rem .85rem;margin-bottom:1rem;
}
.menroll-badge::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--teal);
  box-shadow:0 0 0 4px rgba(124,140,86,.25);
}
@media(max-width:860px){
  #modal-enroll .modal{padding:2.4rem 1.6rem 2.2rem;}
}

/* ── PRIVACY / TERMS MODAL ── */
.legal-modal .modal{max-width:680px;}
.legal-modal .modal-body{font-size:1.06rem;color:var(--soft);line-height:1.85;max-height:60vh;overflow-y:auto;padding-right:.5rem;}
.legal-modal .modal-body h3{font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--white);margin:1.4rem 0 .4rem;}
.legal-modal .modal-body p{margin-bottom:.75rem;}

/* ── MOBILE NEW ── */
@media(max-width:860px){
  .stats-bar{gap:0;}
  .stat{padding:1.6rem 2rem;flex:1 1 45%;}
  .stat+.stat::before{display:none;}
  .spec-grid{grid-template-columns:1fr;}
  .vetting-row{grid-template-columns:1fr;gap:2rem;}
  .mrow{grid-template-columns:1fr;}
  .wl-form{flex-direction:column;border-radius:16px;}
  .wl-input{border-radius:12px;}
  .waitlist-box{padding:2rem 1.5rem;}
  .modal{padding:2rem 1.5rem;}
}
@media(max-width:480px){
  .stat{flex:1 1 100%;padding:1.4rem 1.5rem;}
  .stat+.stat{border-top:1px solid var(--line);}
}

/* ══════════════════════════════
   AP RESOURCE SYSTEM
══════════════════════════════ */
.ap-view{display:none;}
.ap-view.active{display:block;animation:apFadeUp .35s cubic-bezier(.22,1,.36,1);}
@keyframes apFadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* Live subject cards */
.ap-live-section{padding:2rem 6% 0;}
.ap-live-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.1rem;margin-bottom:3rem;}
.ap-live-card{position:relative;border-radius:20px;padding:2rem 1.8rem;cursor:pointer;
  background:rgba(124,140,86,.06);
  border:1px solid rgba(124,140,86,.22);transition:transform .25s,box-shadow .25s,border-color .25s;overflow:hidden;}
.ap-live-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.ap-live-card:hover{transform:translateY(-5px);box-shadow:0 18px 44px rgba(124,140,86,.12);border-color:rgba(124,140,86,.45);}
.ap-live-badge{display:inline-flex;align-items:center;gap:.4rem;background:rgba(124,140,86,.1);border:1px solid rgba(124,140,86,.28);border-radius:50px;padding:.18rem .65rem;font-family:var(--fh);font-size:0.93rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.8rem;}
.ap-live-dot{width:6px;height:6px;border-radius:50%;background:var(--teal);animation:ldotpulse 2s ease-in-out infinite;flex-shrink:0;}
@keyframes ldotpulse{0%,100%{opacity:1}50%{opacity:.25}}
.ap-live-card .alc-icon{font-size:1.9rem;margin-bottom:.6rem;display:block;}
.ap-live-card h3{font-family:var(--fh);font-size:1.33rem;font-weight:700;margin-bottom:.3rem;}
.ap-live-card .alc-desc{font-size:1.0rem;color:var(--soft);line-height:1.6;margin-bottom:1rem;}
.ap-try-now{font-family:var(--fh);font-size:1.03rem;font-weight:700;color:var(--teal);display:flex;align-items:center;gap:.3rem;transition:gap .2s;}
.ap-live-card:hover .ap-try-now{gap:.55rem;}

/* Coming soon mini cards */
.ap-coming-sect{padding:0 6% 5rem;}
.ap-coming-grid-sm{display:grid;grid-template-columns:repeat(auto-fill,minmax(155px,1fr));gap:.65rem;margin-bottom:2rem;}
.ap-cs-card{background:var(--n2);border:1px solid var(--line);border-radius:13px;padding:.95rem 1rem;display:flex;align-items:center;gap:.7rem;opacity:1;}
.ap-cs-icon{font-size:1.38rem;flex-shrink:0;}
.ap-cs-info{min-width:0;}
.ap-cs-name{font-family:var(--fh);font-size:1.01rem;font-weight:700;color:var(--white);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.ap-cs-tag{font-family:var(--fh);font-size:0.9rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.06em;}

/* Dashboard */
.ap-dash{padding:2rem 6%;}
.ap-back-btn{display:inline-flex;align-items:center;gap:.45rem;background:none;border:1px solid var(--line);color:var(--soft);font-family:var(--fh);font-size:1.06rem;font-weight:600;padding:.45rem 1.1rem;border-radius:50px;cursor:pointer;margin-bottom:2rem;transition:color .2s,border-color .2s;}
.ap-back-btn:hover{color:var(--white);border-color:rgba(124,140,86,.3);}
.ap-dash-hd{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem;flex-wrap:wrap;}
.ap-dash-hd-left h2{font-family:var(--fh);font-size:clamp(1.8rem,3.5vw,2.5rem);font-weight:700;margin-bottom:.3rem;line-height:1.1;}
.ap-dash-hd-left p{font-size:1.08rem;color:var(--soft);max-width:480px;line-height:1.65;}
.ap-session-stats{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;padding-top:.25rem;}
.ap-stat-chip{background:var(--n3);border:1px solid var(--line);border-radius:50px;padding:.4rem .95rem;font-family:var(--fh);font-size:1.06rem;font-weight:700;}
.ap-stat-chip.score{color:var(--teal);}
.ap-stat-chip.streak{color:#f59e0b;}

/* API key card */
.ap-key-card{background:var(--n2);border:1px solid rgba(124,140,86,.18);border-radius:18px;padding:1.8rem;margin-bottom:2rem;}
.ap-key-card h3{font-family:var(--fh);font-size:1.18rem;font-weight:700;margin-bottom:.35rem;}
.ap-key-card p{font-size:1.01rem;color:var(--soft);line-height:1.65;margin-bottom:.9rem;}
.ap-key-row{display:flex;gap:.65rem;}
.ap-key-input{flex:1;background:var(--field);border:1.5px solid var(--line);border-radius:10px;padding:.68rem 1rem;color:var(--white);font-family:var(--fb);font-size:1.06rem;transition:border-color .2s;}
.ap-key-input:focus{outline:none;border-color:rgba(124,140,86,.5);box-shadow:0 0 0 3px rgba(124,140,86,.1);}
.ap-key-input::placeholder{color:var(--soft);opacity:.75;}
.ap-key-note{font-size:0.89rem;color:var(--soft);font-style:italic;margin:.5rem 0 0;line-height:1.5;}
.ap-key-connected{display:inline-flex;align-items:center;gap:.4rem;font-family:var(--fh);font-size:1.06rem;font-weight:700;color:var(--teal);padding:.75rem 0;}
.ap-key-connected .akc-dot{width:8px;height:8px;border-radius:50%;background:var(--teal);animation:ldotpulse 2s ease-in-out infinite;}

/* Unit pills */
.ap-unit-select{margin-bottom:2rem;}
.ap-unit-select label{font-family:var(--fh);font-size:1.06rem;font-weight:700;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;display:block;margin-bottom:.6rem;}
.ap-unit-pills{display:flex;flex-wrap:wrap;gap:.5rem;}
.ap-unit-tag{display:inline-flex;align-items:center;background:rgba(124,140,86,.06);border:1px solid rgba(124,140,86,.18);border-radius:50px;padding:.38rem .9rem;font-family:var(--fh);font-size:1.0rem;font-weight:600;color:var(--teal);cursor:default;}
.ap-unit-pill{background:var(--n3);border:1.5px solid var(--line);border-radius:50px;padding:.38rem .9rem;font-family:var(--fh);font-size:1.0rem;font-weight:600;color:var(--soft);cursor:pointer;transition:all .2s;}
.ap-unit-pill:hover,.ap-unit-pill.active{background:rgba(124,140,86,.1);border-color:rgba(124,140,86,.4);color:var(--teal);}

/* Mode cards */
.ap-mode-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem;margin-bottom:2.5rem;}
.ap-mode-card{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:1.9rem 1.6rem;cursor:pointer;transition:border-color .25s,transform .25s,box-shadow .25s;position:relative;overflow:hidden;}
.ap-mode-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);opacity:0;transition:opacity .25s;}
.ap-mode-card:hover{border-color:rgba(124,140,86,.3);transform:translateY(-4px);box-shadow:0 12px 32px rgba(124,140,86,.09);}
.ap-mode-card:hover::before{opacity:1;}
.ap-mode-icon{font-size:2.1rem;margin-bottom:.9rem;display:block;}
.ap-mode-card h3{font-family:var(--fh);font-size:1.23rem;font-weight:700;margin-bottom:.35rem;}
.ap-mode-card p{font-size:0.99rem;color:var(--soft);line-height:1.65;margin-bottom:.9rem;}
.ap-mode-ai-tag{display:inline-flex;align-items:center;gap:.28rem;background:rgba(124,140,86,.08);border:1px solid rgba(124,140,86,.18);border-radius:50px;padding:.18rem .65rem;font-family:var(--fh);font-size:0.9rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.08em;}

/* Practice & shared tool top bar */
.ap-tool-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:2rem;flex-wrap:wrap;gap:1rem;}
.ap-tool-meta{font-family:var(--fh);font-size:1.03rem;color:var(--soft);}
.ap-tool-meta .tm-unit{color:var(--teal);font-weight:600;}
.ap-score-row{display:flex;gap:.55rem;}

/* Loading */
.ap-loading{text-align:center;padding:5rem 2rem;}
.ap-loading-dots{display:inline-flex;gap:.4rem;margin-bottom:1rem;}
.ap-loading-dots span{width:9px;height:9px;border-radius:50%;background:var(--teal);animation:ldot .8s ease-in-out infinite;}
.ap-loading-dots span:nth-child(2){animation-delay:.15s;}
.ap-loading-dots span:nth-child(3){animation-delay:.3s;}
@keyframes ldot{0%,80%,100%{transform:scale(.45);opacity:.25}40%{transform:scale(1);opacity:1}}
.ap-loading p{font-family:var(--fh);font-size:1.18rem;color:var(--soft);}

/* Question card */
.ap-q-card{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:2.2rem;margin-bottom:1.1rem;}
.ap-q-meta{font-family:var(--fh);font-size:1.0rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.6rem;}
.ap-q-text{font-family:var(--fh);font-size:clamp(1.05rem,2vw,1.2rem);font-weight:600;line-height:1.6;color:var(--white);margin-bottom:1.7rem;}
.ap-q-hint{font-size:0.99rem;color:var(--soft);font-style:italic;margin-top:.5rem;padding:.6rem 1rem;background:rgba(94,107,62,.07);border-radius:8px;display:none;}
.ap-q-hint.show{display:block;}
.ap-options{display:flex;flex-direction:column;gap:.6rem;}
.ap-option{width:100%;background:var(--n3);border:1.5px solid var(--line);border-radius:12px;padding:.85rem 1.15rem;text-align:left;font-family:var(--fh);font-size:1.13rem;font-weight:600;color:var(--white);cursor:pointer;transition:border-color .18s,background .18s,transform .13s;display:flex;align-items:center;gap:.75rem;}
.ap-option .ao-letter{width:27px;height:27px;border-radius:50%;border:1.5px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:0.98rem;flex-shrink:0;transition:all .18s;}
.ap-option:hover:not(:disabled){border-color:rgba(124,140,86,.35);background:rgba(124,140,86,.04);transform:translateX(4px);}
.ap-option:hover:not(:disabled) .ao-letter{border-color:rgba(124,140,86,.5);color:var(--teal);}
.ap-option.correct{border-color:#3de896;background:rgba(61,232,150,.07);color:#3de896;}
.ap-option.correct .ao-letter{border-color:#3de896;background:rgba(61,232,150,.12);color:#3de896;}
.ap-option.wrong{border-color:#e85b3d;background:rgba(232,91,61,.07);color:#e85b3d;}
.ap-option.wrong .ao-letter{border-color:#e85b3d;color:#e85b3d;}
.ap-option.dim{opacity:.45;}
.ap-option:disabled{cursor:default;}
.ap-explanation{background:rgba(124,140,86,.05);border:1px solid rgba(124,140,86,.18);border-radius:14px;padding:1.4rem 1.7rem;margin-top:1rem;display:none;}
.ap-explanation.show{display:block;animation:apFadeUp .3s ease;}
.ap-exp-label{font-family:var(--fb);font-size:0.83rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.13em;margin-bottom:.45rem;}
.ap-exp-text{font-size:1.06rem;color:var(--soft);line-height:1.78;}
.ap-next-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-top:1.4rem;}
.ap-hint-btn{background:none;border:1px solid var(--line);color:var(--soft);font-family:var(--fh);font-size:1.0rem;font-weight:600;padding:.42rem .95rem;border-radius:50px;cursor:pointer;transition:all .2s;}
.ap-hint-btn:hover{border-color:rgba(124,140,86,.3);color:var(--white);}

/* Difficulty selector */
.ap-diff-row{display:flex;gap:.5rem;align-items:center;margin-top:-.5rem;margin-bottom:1.8rem;}
.ap-diff-label{font-family:var(--fh);font-size:0.98rem;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;margin-right:.25rem;}
.ap-diff-btn{background:var(--n3);border:1px solid var(--line);border-radius:50px;padding:.32rem .85rem;font-family:var(--fh);font-size:0.96rem;font-weight:700;color:var(--soft);cursor:pointer;transition:all .18s;}
.ap-diff-btn.active{background:rgba(94,107,62,.12);border-color:rgba(94,107,62,.4);color:var(--purple);}

/* Flashcard */
.ap-fc-progress{text-align:center;font-family:var(--fh);font-size:1.06rem;color:var(--soft);margin-bottom:1.4rem;}
.ap-fc-progress span{color:var(--teal);font-weight:700;}
.ap-flip-card{width:100%;max-width:580px;height:260px;margin:0 auto 2rem;perspective:1200px;cursor:pointer;}
.ap-flip-inner{width:100%;height:100%;position:relative;transform-style:preserve-3d;transition:transform .55s cubic-bezier(.22,1,.36,1);}
.ap-flip-card.flipped .ap-flip-inner{transform:rotateY(180deg);}
.ap-flip-front,.ap-flip-back{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:20px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem 2.5rem;text-align:center;}
.ap-flip-front{background:var(--n2);border:1px solid var(--line);}
.ap-flip-back{background:rgba(124,140,86,.06);border:1px solid rgba(124,140,86,.25);transform:rotateY(180deg);}
.ap-fc-tap{position:absolute;bottom:.9rem;left:0;right:0;font-family:var(--fb);font-size:0.83rem;color:var(--soft);opacity:.5;text-align:center;}
.ap-fc-cat{font-family:var(--fh);font-size:0.96rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.65rem;}
.ap-fc-term{font-family:var(--fh);font-size:clamp(1.2rem,2.5vw,1.65rem);font-weight:700;color:var(--white);line-height:1.25;}
.ap-fc-def{font-size:1.1rem;color:var(--soft);line-height:1.75;}
.ap-fc-nav{display:flex;justify-content:center;align-items:center;gap:1.5rem;}
.ap-fc-nav-btn{width:44px;height:44px;border-radius:50%;background:var(--n2);border:1px solid var(--line);color:var(--soft);font-size:1.38rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;}
.ap-fc-nav-btn:hover{border-color:rgba(124,140,86,.35);color:var(--teal);}
.ap-fc-dots{display:flex;gap:.35rem;}
.ap-fc-dot{width:7px;height:7px;border-radius:50%;background:var(--line);transition:background .2s,transform .2s;}
.ap-fc-dot.active{background:var(--teal);transform:scale(1.3);}

/* Study guide */
.ap-guide-wrap{max-width:740px;}
.ap-guide-card{background:var(--n2);border:1px solid var(--line);border-radius:16px;padding:1.7rem;margin-bottom:1.1rem;}
.ap-guide-card h3{font-family:var(--fh);font-size:1.15rem;font-weight:700;color:var(--teal);margin-bottom:.85rem;}
.ap-guide-list{list-style:none;display:flex;flex-direction:column;gap:.5rem;}
.ap-guide-list li{font-size:1.05rem;color:var(--soft);line-height:1.7;padding-left:1.1rem;position:relative;}
.ap-guide-list li::before{content:'›';position:absolute;left:0;color:var(--teal);}
.ap-formula-row{background:var(--n3);border:1px solid var(--line);border-radius:10px;padding:.75rem 1rem;margin:.4rem 0;}
.ap-formula-nm{font-family:var(--fh);font-size:0.98rem;font-weight:700;color:var(--white);margin-bottom:.18rem;}
.ap-formula-eq{font-family:'Courier New',monospace;font-size:1.06rem;color:var(--teal);}
.ap-formula-use{font-size:0.93rem;color:var(--soft);margin-top:.18rem;}
.ap-mistake{display:flex;gap:.65rem;align-items:flex-start;margin-bottom:.5rem;}
.ap-mistake-ico{flex-shrink:0;font-size:1.03rem;margin-top:.1rem;}
.ap-mistake-txt{font-size:1.04rem;color:var(--soft);line-height:1.65;}

/* Error state */
.ap-err{background:rgba(232,91,61,.07);border:1px solid rgba(232,91,61,.22);border-radius:14px;padding:1.5rem;text-align:center;}
.ap-err p{font-size:1.06rem;color:#e8503d;line-height:1.65;margin-bottom:.8rem;}
.ap-err code{background:rgba(232,91,61,.1);padding:.12rem .38rem;border-radius:4px;font-family:monospace;font-size:0.98rem;}

/* Mobile */
@media(max-width:860px){
  .ap-live-grid{grid-template-columns:1fr;}
  .ap-mode-grid{grid-template-columns:1fr;}
  .ap-q-card{padding:1.5rem;}
  .ap-dash{padding:1.5rem 5%;}
  .ap-live-section,.ap-coming-sect{padding-left:5%;padding-right:5%;}
  .ap-flip-card{height:220px;}
}


/* ══════════════════════════════════════════════════
   PROGRESS SYSTEM ,  XP, Levels, Mastery, Streaks
══════════════════════════════════════════════════ */

/* ── Global progress bar (top of AP page) ── */
.ap-prog-overview{
  background:rgba(var(--paper-rgb),.85);
  border-bottom:1px solid var(--line);
  padding:.9rem 6%;
  display:flex;align-items:center;gap:2rem;flex-wrap:wrap;
  position:sticky;top:96px;z-index:90;
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
}
.apo-stat{display:flex;align-items:center;gap:.55rem;}
.apo-stat-icon{font-size:1.28rem;line-height:1;}
.apo-stat-label{font-family:var(--fh);font-size:0.96rem;font-weight:600;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;}
.apo-stat-val{font-family:var(--fh);font-size:1.23rem;font-weight:700;color:var(--white);}
.apo-divider{width:1px;height:28px;background:var(--line);flex-shrink:0;}
.apo-xp-wrap{flex:1;min-width:160px;max-width:240px;}
.apo-xp-label{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.35rem;}
.apo-xp-bar{height:6px;background:rgba(124,140,86,.12);border-radius:99px;overflow:hidden;}
.apo-xp-fill{height:100%;background:var(--teal);border-radius:99px;transition:width .6s cubic-bezier(.22,1,.36,1);}
.apo-level-badge{
  display:inline-flex;align-items:center;gap:.4rem;
  padding:.3rem .85rem;border-radius:50px;
  font-family:var(--fh);font-size:1.0rem;font-weight:700;
  background:rgba(124,140,86,.1);
  border:1px solid rgba(124,140,86,.25);
  color:var(--teal);
}

/* ── Progress rings (SVG mastery circles) ── */
.prog-ring-wrap{position:relative;width:58px;height:58px;flex-shrink:0;}
.prog-ring{width:58px;height:58px;transform:rotate(-90deg);}
.prog-ring-track{fill:none;stroke:rgba(124,140,86,.1);stroke-width:4;}
.prog-ring-fill{fill:none;stroke:url(#progGrad);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .7s cubic-bezier(.22,1,.36,1);}
.prog-ring-text{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--fh);font-size:0.9rem;font-weight:700;color:var(--white);
  text-align:center;line-height:1.1;
}
.prog-ring-text.new{color:var(--soft);font-size:0.78rem;}

/* ── Enhanced subject cards ── */
.ap-subj-section{padding:1.5rem 6% 0;}
.ap-subj-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem;margin-bottom:2rem;}
.ap-subj-card{
  background:var(--n2);border:1px solid var(--line);border-radius:20px;
  padding:1.6rem 1.5rem 1.4rem;cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;gap:.75rem;
}
.ap-subj-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);opacity:0;transition:opacity .25s;}
.ap-subj-card:hover{border-color:rgba(124,140,86,.35);transform:translateY(-4px);box-shadow:0 14px 36px rgba(124,140,86,.1);}
.ap-subj-card:hover::before{opacity:1;}
.ap-subj-card.has-progress{border-color:rgba(124,140,86,.2);}
.ap-subj-card.has-progress::before{opacity:.6;}
.ap-subj-card-top{display:flex;align-items:center;justify-content:space-between;}
.ap-subj-card-icon{font-size:1.7rem;line-height:1;}
.ap-subj-card h3{font-family:var(--fh);font-size:1.18rem;font-weight:700;line-height:1.2;color:var(--white);}
.ap-subj-card-desc{font-size:0.98rem;color:var(--soft);line-height:1.55;flex:1;}
.ap-subj-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;}
.ap-subj-card-meta{font-family:var(--fh);font-size:0.9rem;color:var(--soft);}
.ap-subj-card-meta span{color:var(--teal);}
.ap-subj-cta{
  font-family:var(--fh);font-size:0.98rem;font-weight:700;
  color:var(--teal);display:flex;align-items:center;gap:.3rem;
  transition:gap .2s;
}
.ap-subj-card:hover .ap-subj-cta{gap:.55rem;}

/* SAT section cards */
.ap-sat-card{background:rgba(94,107,62,.06);}
.ap-sat-card::before{background:var(--purple);}

/* ── Achievement toast ── */
.ach-toast{
  position:fixed;bottom:2rem;right:2rem;z-index:9999;
  background:var(--n2);border:1px solid rgba(124,140,86,.35);border-radius:18px;
  padding:1rem 1.4rem;display:flex;align-items:center;gap:1rem;
  box-shadow:0 16px 44px rgba(0,0,0,.4);
  transform:translateX(140%);transition:transform .45s cubic-bezier(.22,1,.36,1);
  max-width:320px;
}
.ach-toast.show{transform:translateX(0);}
.ach-toast-icon{font-size:2rem;flex-shrink:0;line-height:1;}
.ach-toast-body{}
.ach-toast-label{font-family:var(--fh);font-size:0.88rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.15rem;}
.ach-toast-name{font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--white);margin-bottom:.1rem;}
.ach-toast-desc{font-size:0.96rem;color:var(--soft);line-height:1.45;}
.ach-toast-xp{font-family:var(--fh);font-size:0.98rem;font-weight:700;color:var(--teal);margin-top:.2rem;}

/* XP gain pop (floating text) */
.xp-pop{
  position:fixed;z-index:9999;
  font-family:var(--fh);font-size:1.33rem;font-weight:700;
  color:var(--teal);pointer-events:none;
  animation:xpFloat 1.1s cubic-bezier(.22,1,.36,1) forwards;
}
@keyframes xpFloat{
  0%{opacity:1;transform:translateY(0) scale(1);}
  60%{opacity:1;transform:translateY(-42px) scale(1.12);}
  100%{opacity:0;transform:translateY(-70px) scale(.9);}
}

/* ── Score summary screen ── */
.ap-summary-wrap{max-width:640px;margin:0 auto;padding:2rem 0;}
.ap-summary-score-ring{display:flex;justify-content:center;margin-bottom:2rem;position:relative;}
.ap-score-big-ring{width:160px;height:160px;}
.ap-score-big-track{fill:none;stroke:rgba(124,140,86,.1);stroke-width:10;}
.ap-score-big-fill{fill:none;stroke-width:10;stroke-linecap:round;transition:stroke-dashoffset 1s cubic-bezier(.22,1,.36,1);}
.ap-score-big-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;}
.ap-score-big-num{font-family:var(--fh);font-size:2.5rem;font-weight:700;line-height:1;display:block;}
.ap-score-big-denom{font-family:var(--fh);font-size:1.13rem;color:var(--soft);display:block;}
.ap-summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.85rem;margin-bottom:2rem;}
.ap-sum-stat{background:var(--n2);border:1px solid var(--line);border-radius:14px;padding:1.1rem;text-align:center;}
.ap-sum-stat-val{font-family:var(--fh);font-size:1.5rem;font-weight:700;display:block;margin-bottom:.2rem;}
.ap-sum-stat-val.xp{color:var(--teal);}
.ap-sum-stat-val.streak{color:#f59e0b;}
.ap-sum-stat-val.mastery{color:var(--purple);}
.ap-sum-stat-lbl{font-family:var(--fh);font-size:0.9rem;color:var(--soft);text-transform:uppercase;letter-spacing:.08em;}
.ap-summary-ach{background:rgba(124,140,86,.07);border:1px solid rgba(124,140,86,.22);border-radius:16px;padding:1.2rem 1.5rem;display:flex;align-items:center;gap:1rem;margin-bottom:2rem;}
.ap-summary-ach-icon{font-size:2rem;flex-shrink:0;}
.ap-summary-ach h4{font-family:var(--fh);font-size:1.13rem;font-weight:700;margin-bottom:.15rem;}
.ap-summary-ach p{font-size:0.98rem;color:var(--soft);line-height:1.5;}
.ap-summary-actions{display:flex;flex-direction:column;gap:.75rem;}
.ap-sum-btn{width:100%;padding:1rem;border-radius:14px;font-family:var(--fh);font-size:1.18rem;font-weight:700;cursor:pointer;transition:transform .2s,box-shadow .2s;border:none;}
.ap-sum-btn.primary{background:var(--teal);color:#F4EFE2;box-shadow:0 4px 18px rgba(94,107,62,.3);}
.ap-sum-btn.primary:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(124,140,86,.3);}
.ap-sum-btn.secondary{background:var(--n2);border:1px solid var(--line);color:var(--white);}
.ap-sum-btn.secondary:hover{border-color:rgba(124,140,86,.3);background:rgba(124,140,86,.04);}

/* ── Enhanced practice, timer + progress bar ── */
.ap-practice-header{display:flex;align-items:center;justify-content:flex-start;margin-bottom:1.8rem;flex-wrap:nowrap;gap:1rem;}
.ap-practice-header > div{min-width:0;flex:1;}
.ap-q-progress{display:flex;align-items:center;gap:.75rem;flex:1;}
.ap-q-count{font-family:var(--fh);font-size:1.08rem;font-weight:700;color:var(--soft);white-space:nowrap;}
.ap-q-track{flex:1;height:5px;background:rgba(124,140,86,.1);border-radius:99px;overflow:hidden;min-width:80px;}
.ap-q-fill{height:100%;background:var(--teal);border-radius:99px;transition:width .4s cubic-bezier(.22,1,.36,1);}
.ap-timer-wrap{display:flex;align-items:center;gap:.45rem;font-family:var(--fh);font-size:1.08rem;font-weight:700;color:var(--soft);background:var(--n3);border:1px solid var(--line);border-radius:50px;padding:.35rem .85rem;transition:all .25s;}
.ap-timer-wrap.warn{color:#f59e0b;border-color:rgba(245,158,11,.3);background:rgba(245,158,11,.05);}
.ap-timer-wrap.danger{color:#e85b3d;border-color:rgba(232,91,61,.35);background:rgba(232,91,61,.07);animation:timerPulse .6s ease-in-out infinite;}
@keyframes timerPulse{0%,100%{transform:scale(1);}50%{transform:scale(1.04);}}

/* ── Timed exam mode selector ── */
.ap-exam-opts{display:grid;grid-template-columns:repeat(2,1fr);gap:.85rem;margin-bottom:1.8rem;}
.ap-exam-opt{background:var(--n2);border:1.5px solid var(--line);border-radius:16px;padding:1.4rem;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;position:relative;overflow:hidden;}
.ap-exam-opt::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);opacity:0;transition:opacity .2s;}
.ap-exam-opt:hover{border-color:rgba(124,140,86,.35);transform:translateY(-2px);box-shadow:0 8px 24px rgba(124,140,86,.09);}
.ap-exam-opt:hover::before{opacity:1;}
.ap-exam-opt.selected{border-color:rgba(124,140,86,.5);background:rgba(124,140,86,.05);}
.ap-exam-opt.selected::before{opacity:1;}
.ap-exam-opt h4{font-family:var(--fh);font-size:1.18rem;font-weight:700;margin-bottom:.3rem;}
.ap-exam-opt p{font-size:0.98rem;color:var(--soft);line-height:1.5;}
.ap-exam-opt-badge{display:inline-flex;font-family:var(--fh);font-size:0.86rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.08em;background:rgba(124,140,86,.08);border:1px solid rgba(124,140,86,.18);border-radius:50px;padding:.15rem .55rem;margin-bottom:.6rem;}

/* ── Achievements page (inside subject dashboard) ── */
.ap-ach-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.8rem;margin-top:1.2rem;}
.ap-ach-card{background:var(--n2);border:1px solid var(--line);border-radius:14px;padding:1.1rem;text-align:center;transition:border-color .2s,transform .2s;}
.ap-ach-card.earned{border-color:rgba(124,140,86,.28);background:rgba(124,140,86,.05);}
.ap-ach-card:hover.earned{transform:translateY(-3px);}
.ap-ach-icon{font-size:1.8rem;line-height:1;margin-bottom:.5rem;filter:grayscale(1);opacity:.35;transition:filter .2s,opacity .2s;}
.ap-ach-card.earned .ap-ach-icon{filter:none;opacity:1;}
.ap-ach-name{font-family:var(--fh);font-size:1.03rem;font-weight:700;margin-bottom:.2rem;color:var(--soft);}
.ap-ach-card.earned .ap-ach-name{color:var(--white);}
.ap-ach-desc{font-size:0.9rem;color:var(--soft);line-height:1.45;}

/* ── Flashcards enhanced (knew/learning buttons) ── */
.ap-fc-verdict{display:flex;gap:.75rem;justify-content:center;margin-top:1.4rem;}
.ap-fc-knew{background:rgba(61,232,150,.1);border:1.5px solid rgba(61,232,150,.3);color:#3de896;font-family:var(--fh);font-size:1.08rem;font-weight:700;border-radius:50px;padding:.65rem 1.8rem;cursor:pointer;transition:all .2s;}
.ap-fc-knew:hover{background:rgba(61,232,150,.18);transform:scale(1.03);}
.ap-fc-learning{background:rgba(232,91,61,.07);border:1.5px solid rgba(232,91,61,.25);color:#e85b3d;font-family:var(--fh);font-size:1.08rem;font-weight:700;border-radius:50px;padding:.65rem 1.8rem;cursor:pointer;transition:all .2s;}
.ap-fc-learning:hover{background:rgba(232,91,61,.13);transform:scale(1.03);}

/* ── Quick stats inline ── */
.ap-inline-stats{display:flex;gap:.6rem;flex-wrap:wrap;margin-bottom:1.8rem;}
.ap-inline-stat{background:var(--n3);border:1px solid var(--line);border-radius:50px;padding:.38rem 1rem;font-family:var(--fh);font-size:1.0rem;font-weight:700;display:flex;align-items:center;gap:.35rem;}
.ap-inline-stat .ais-icon{font-size:1.13rem;}
.ap-inline-stat .ais-val{color:var(--white);}
.ap-inline-stat .ais-lbl{color:var(--soft);font-weight:400;}

/* ── Recommendation card ── */
.ap-rec-card{background:rgba(94,107,62,.07);border:1px solid rgba(94,107,62,.22);border-radius:18px;padding:1.3rem 1.6rem;margin:1.5rem 6% 0;display:flex;align-items:center;gap:1.2rem;transition:border-color .2s;}
.ap-rec-card:hover{border-color:rgba(94,107,62,.4);}
.ap-rec-icon{font-size:1.6rem;flex-shrink:0;}
.ap-rec-body{flex:1;}
.ap-rec-label{font-family:var(--fh);font-size:0.88rem;font-weight:700;color:var(--purple);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.2rem;}
.ap-rec-title{font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--white);margin-bottom:.15rem;}
.ap-rec-sub{font-size:0.98rem;color:var(--soft);}
.ap-rec-btn{font-family:var(--fh);font-size:1.03rem;font-weight:700;color:var(--purple);white-space:nowrap;background:none;border:1px solid rgba(94,107,62,.3);border-radius:50px;padding:.4rem 1rem;cursor:pointer;transition:all .2s;flex-shrink:0;}
.ap-rec-btn:hover{background:rgba(94,107,62,.1);border-color:rgba(94,107,62,.5);}

/* ── Mastery breakdown bar ── */
.mastery-bar-wrap{margin:1.4rem 0;}
.mastery-bar-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;}
.mastery-bar-label{font-family:var(--fh);font-size:0.96rem;font-weight:600;color:var(--soft);width:110px;flex-shrink:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.mastery-bar-track{flex:1;height:7px;background:rgba(124,140,86,.08);border-radius:99px;overflow:hidden;}
.mastery-bar-fill{height:100%;border-radius:99px;background:var(--teal);transition:width .7s cubic-bezier(.22,1,.36,1);}
.mastery-bar-pct{font-family:var(--fh);font-size:0.93rem;font-weight:700;color:var(--teal);width:32px;text-align:right;flex-shrink:0;}

/* ── Mode card improvements ── */
.ap-mode-grid{grid-template-columns:repeat(2,1fr);}
.ap-mode-card-new{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:1.7rem 1.5rem;cursor:pointer;transition:border-color .25s,transform .25s,box-shadow .25s;position:relative;overflow:hidden;display:flex;flex-direction:column;}
.ap-mode-card-new::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);opacity:0;transition:opacity .25s;}
.ap-mode-card-new:hover{border-color:rgba(124,140,86,.3);transform:translateY(-4px);box-shadow:0 12px 32px rgba(124,140,86,.09);}
.ap-mode-card-new:hover::before{opacity:1;}
.ap-mode-icon-new{font-size:2rem;margin-bottom:.75rem;display:block;}
.ap-mode-card-new h3{font-family:var(--fh);font-size:1.23rem;font-weight:700;margin-bottom:.3rem;}
.ap-mode-card-new p{font-size:1.0rem;color:var(--soft);line-height:1.6;flex:1;margin-bottom:.8rem;}
.ap-mode-badge-row{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:auto;}
.ap-mode-tag{display:inline-flex;align-items:center;gap:.2rem;background:rgba(124,140,86,.07);border:1px solid rgba(124,140,86,.15);border-radius:50px;padding:.15rem .6rem;font-family:var(--fh);font-size:0.86rem;font-weight:700;color:var(--teal);text-transform:uppercase;letter-spacing:.06em;}
.ap-mode-tag.purple{background:rgba(94,107,62,.07);border-color:rgba(94,107,62,.18);color:var(--purple);}

@media(max-width:860px){
  .ap-subj-grid{grid-template-columns:1fr 1fr;}
  .ap-prog-overview{top:0;gap:1rem;}
  .ap-summary-stats{grid-template-columns:1fr 1fr;}
  .ap-mode-grid{grid-template-columns:1fr;}
  .ap-exam-opts{grid-template-columns:1fr;}
  .ap-ach-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:480px){
  .ap-subj-grid{grid-template-columns:1fr;}
  .ap-summary-stats{grid-template-columns:repeat(3,1fr);}
}


/* ══════════════════════════════════════════════════
   GRANTS PAGE, step cards
══════════════════════════════════════════════════ */
.fcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.1rem;max-width:900px;margin:2rem auto;}
.fcard{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:2rem 1.75rem;display:flex;flex-direction:column;gap:.75rem;position:relative;overflow:hidden;transition:border-color .25s,transform .25s;text-align:left;}
.fcard::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--teal);}
.fcard:hover{border-color:rgba(124,140,86,.3);transform:translateY(-3px);}
.fcard-ic{width:44px;height:44px;border-radius:12px;background:rgba(124,140,86,.08);border:1px solid rgba(124,140,86,.15);display:flex;align-items:center;justify-content:center;font-size:1.58rem;flex-shrink:0;}
.fcard h3{font-family:var(--fh);font-size:1.2rem;font-weight:700;color:var(--white);margin:0;text-align:left;line-height:1.35;}
.fcard p{font-family:var(--fb);font-size:1.04rem;color:var(--soft);line-height:1.72;margin:0;text-align:left;}

/* ══════════════════════════════════════════════════
   AP SUBJECT CARDS, enhanced layout
══════════════════════════════════════════════════ */
.ap-subj-card{
  background:var(--n2);border:1px solid var(--line);border-radius:20px;
  padding:1.6rem 1.5rem 1.4rem;cursor:pointer;position:relative;overflow:hidden;
  transition:border-color .25s,transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;gap:.75rem;
}
.ap-subj-card:hover{border-color:rgba(124,140,86,.35);transform:translateY(-4px);box-shadow:0 16px 40px rgba(0,0,0,.28);}
.ap-subj-card:hover .ap-subj-arrow{opacity:1;transform:translateX(3px);}
.ap-subj-arrow{font-size:1.03rem;color:var(--teal);opacity:0;transition:all .2s;margin-left:auto;}

/* ══════════════════════════════════════════════════
   AP RECOMMENDATION, inline card (not popup)
══════════════════════════════════════════════════ */
.ap-rec-card{
  background:rgba(124,140,86,.06);
  border:1px solid rgba(124,140,86,.2);border-radius:20px;
  padding:1.1rem 1.5rem;margin:0 6% 1.25rem;
  display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap;
  position:relative;
}
.ap-rec-card.intro{
  background:rgba(124,140,86,.03);border-color:rgba(124,140,86,.1);
  border-style:dashed;
}

/* ══════════════════════════════════════════════════
   UNIT LIST VIEW
══════════════════════════════════════════════════ */
.ap-unit-grid{display:flex;flex-direction:column;gap:.7rem;max-width:680px;}
.ap-unit-row{
  background:var(--n2);border:1.5px solid var(--line);border-radius:16px;
  padding:1.1rem 1.4rem;cursor:pointer;
  display:flex;align-items:center;gap:1.1rem;
  transition:border-color .2s,transform .2s,background .2s;
}
.ap-unit-row:hover{border-color:rgba(124,140,86,.38);background:rgba(124,140,86,.03);transform:translateX(4px);}
.ap-unit-row.mastered{border-color:rgba(61,232,150,.3);background:rgba(61,232,150,.04);}
.ap-unit-num{width:32px;height:32px;border-radius:50%;background:rgba(124,140,86,.1);border:1.5px solid rgba(124,140,86,.2);display:flex;align-items:center;justify-content:center;font-family:var(--fh);font-size:0.98rem;font-weight:700;color:var(--teal);flex-shrink:0;}
.ap-unit-row.mastered .ap-unit-num{background:rgba(61,232,150,.1);border-color:rgba(61,232,150,.3);color:#3de896;}
.ap-unit-info{flex:1;min-width:0;}
.ap-unit-name{font-family:var(--fh);font-size:1.13rem;font-weight:700;color:var(--white);}
.ap-unit-meta{font-family:var(--fb);font-size:0.96rem;color:var(--soft);margin-top:.15rem;}
.ap-unit-status{font-family:var(--fh);font-size:0.93rem;font-weight:700;padding:.22rem .65rem;border-radius:50px;white-space:nowrap;flex-shrink:0;}
.ap-unit-status.new{background:rgba(124,140,86,.1);color:var(--teal);border:1px solid rgba(124,140,86,.2);}
.ap-unit-status.progress{background:rgba(245,158,11,.1);color:#f59e0b;border:1px solid rgba(245,158,11,.2);}
.ap-unit-status.done{background:rgba(61,232,150,.1);color:#3de896;border:1px solid rgba(61,232,150,.2);}

/* ══════════════════════════════════════════════════
   UNIT LEARN VIEW, explanations + examples
══════════════════════════════════════════════════ */
.ap-learn-section{background:var(--n2);border:1px solid var(--line);border-radius:20px;padding:1.75rem;margin-bottom:1rem;}
.ap-learn-section.highlight{border-color:rgba(124,140,86,.25);background:rgba(124,140,86,.03);}
.ap-learn-label{font-family:var(--fb);font-size:0.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--teal);margin-bottom:.65rem;}
.ap-learn-intro{font-family:var(--fb);font-size:1.13rem;color:var(--soft);line-height:1.8;margin:0;}
.ap-concept-list{display:flex;flex-direction:column;gap:.7rem;}
.ap-concept-item{background:var(--n3);border:1px solid var(--line);border-radius:13px;padding:1rem 1.2rem;display:flex;gap:.9rem;}
.ap-concept-term{font-family:var(--fh);font-size:1.08rem;font-weight:700;color:var(--white);min-width:140px;flex-shrink:0;}
.ap-concept-def{font-family:var(--fb);font-size:1.02rem;color:var(--soft);line-height:1.65;}
.ap-example-card{background:var(--n3);border:1.5px solid rgba(94,107,62,.2);border-radius:16px;padding:1.5rem;margin-bottom:.75rem;}
.ap-example-card:last-child{margin-bottom:0;}
.ap-example-problem{font-family:var(--fh);font-size:1.18rem;font-weight:700;color:var(--white);margin-bottom:.9rem;line-height:1.5;}
.ap-example-solution{font-family:var(--fb);font-size:1.06rem;color:var(--teal);font-weight:600;margin-bottom:.5rem;}
.ap-example-exp{font-family:var(--fb);font-size:1.02rem;color:var(--soft);line-height:1.7;}
.ap-learn-cta{display:flex;align-items:center;gap:1rem;flex-wrap:wrap;padding:1.5rem 0 .5rem;}
.ap-learn-cta-sub{font-family:var(--fb);font-size:1.02rem;color:var(--soft);}

/* ══════════════════════════════════════════════════
   PRACTICE EXAM (full AP test) MODE
══════════════════════════════════════════════════ */
.ap-exam-banner{
  background:rgba(124,140,86,.08);
  border:1px solid rgba(124,140,86,.2);border-radius:20px;padding:1.5rem 1.75rem;
  margin-bottom:1.5rem;display:flex;align-items:center;gap:1.25rem;flex-wrap:wrap;
}
.ap-exam-banner-icon{font-size:2.2rem;flex-shrink:0;}
.ap-exam-banner-body{flex:1;}
.ap-exam-banner-title{font-family:var(--fh);font-size:1.28rem;font-weight:700;color:var(--white);margin-bottom:.2rem;}
.ap-exam-banner-sub{font-family:var(--fb);font-size:1.02rem;color:var(--soft);}
.ap-exam-lock{opacity:.5;cursor:not-allowed;}


.ap-subj-icon-lg, .ap-subj-icon, .amc-icon, .ap-rec-icon, .ap-exam-banner-icon {
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
  -webkit-text-stroke: 0;
  color: var(--white);
  background: none !important;
  -webkit-text-fill-color: initial !important;
  background-clip: initial !important;
}

.hero-wordmark{
  font-family:var(--fh);
  font-size:clamp(3.8rem,9vw,8.6rem);
  font-weight:700;line-height:1.04;letter-spacing:-.03em;
  display:block;margin-bottom:.15rem;
  background:linear-gradient(110deg,
    var(--foil-deep) 0%,
    var(--foil-mid) 22%,
    var(--foil-pale) 36%,
    var(--foil-hot) 42%,
    var(--foil-pale) 48%,
    var(--foil-mid) 64%,
    var(--foil-deep) 80%,
    var(--foil-mid) 92%,
    var(--foil-deep) 100%);
  background-size:220% auto;
  -webkit-background-clip:text;background-clip:text;
  color:var(--lilac);-webkit-text-fill-color:transparent;
  filter:drop-shadow(0 0 2px rgba(61,47,122,.45))
         drop-shadow(0 4px 8px rgba(44,51,38,.18))
         drop-shadow(0 14px 32px var(--lilac-soft));
  animation:hi .8s cubic-bezier(.22,1,.36,1) both, foilShine 9s linear infinite;
}
@keyframes foilShine{
  0%{background-position:0% center}
  100%{background-position:-220% center}
}
/* --- v39 distinctive elements: lilac accent + editorial detailing --- */
.grain-overlay{position:fixed;inset:0;pointer-events:none;z-index:1;opacity:.5;mix-blend-mode:multiply;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='0.2'/%3E%3C/svg%3E");}
:root[data-theme="dark"] .grain-overlay{mix-blend-mode:overlay;opacity:.09;}
/* lilac bar relocated to the nav's bottom edge (separator between tablist and content) */
.ey::before{content:'';display:inline-block;width:26px;height:2px;background:var(--lilac);border-radius:1px;vertical-align:middle;margin-right:.7rem;margin-bottom:.18em;}
::selection{background:var(--lilac);color:#FBF8FF;}
:root[data-theme="dark"] ::selection{color:#181425;}
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:2px solid var(--lilac);outline-offset:3px;border-radius:3px;}
.btn-grad:hover,.btn-outline:hover{box-shadow:0 0 0 3px var(--lilac-soft);}
/* --- v40: depth (drop shadows) + stronger lilac bias --- */
.pcard,.fcard,.acard,.scard,.tcard{box-shadow:0 4px 18px rgba(44,51,38,.06),0 1px 3px rgba(44,51,38,.05);}
.pcard:hover,.fcard:hover,.acard:hover,.scard:hover,.tcard:hover{border-color:var(--lilac);box-shadow:0 20px 46px rgba(44,51,38,.14),0 3px 10px rgba(44,51,38,.07),0 0 0 1px var(--lilac-soft);transform:translateY(-4px);}
.fchip,.pchip{box-shadow:0 8px 24px rgba(44,51,38,.12),0 2px 6px rgba(44,51,38,.07);}
.btn-grad{box-shadow:0 10px 26px var(--lilac-soft),0 4px 14px rgba(44,51,38,.12);}
.btn-grad:hover{box-shadow:0 16px 38px var(--lilac-soft),0 6px 18px rgba(44,51,38,.16);transform:translateY(-2px);}
.btn-outline{box-shadow:0 4px 14px rgba(44,51,38,.07);}
nav{box-shadow:0 2px 16px rgba(44,51,38,.05);}
nav.scrolled{box-shadow:0 10px 36px rgba(44,51,38,.14) !important;}
.modal{box-shadow:0 40px 90px rgba(44,51,38,.34),0 8px 24px rgba(44,51,38,.18);}
.ey::before{width:36px;height:3px;margin-right:.85rem;}
:root[data-theme="dark"] .pcard,:root[data-theme="dark"] .fcard,:root[data-theme="dark"] .acard,:root[data-theme="dark"] .scard,:root[data-theme="dark"] .tcard{box-shadow:0 8px 26px rgba(0,0,0,.4);}
:root[data-theme="dark"] nav.scrolled{box-shadow:0 12px 38px rgba(0,0,0,.55) !important;}

/* ── MEET THE TEAM ── */
.tm-wrap{max-width:1100px;margin:0 auto;}
.tm-note{max-width:680px;margin:0 auto 3.6rem;text-align:center;font-size:1.23rem;color:var(--soft);line-height:1.85;}
.tm-note strong{color:var(--white);}
.tm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.9rem;}
.tmcard{background:var(--n2);border:1px solid var(--line);border-radius:22px;padding:3.2rem 2.1rem 2.6rem;position:relative;overflow:hidden;text-align:center;transition:border-color .3s,transform .3s,box-shadow .3s;}
.tmcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:var(--teal);}
.tmcard:hover{border-color:rgba(124,140,86,.3);transform:translateY(-4px);box-shadow:0 14px 34px rgba(124,140,86,.10);}
.tmcard.founder{background:linear-gradient(180deg,var(--lilac-soft) 0%,var(--n2) 44%);}
.tmcard.founder::before{background:linear-gradient(90deg,var(--wm1),var(--wm2),var(--wm3));}
.tm-avatar{width:150px;height:150px;border-radius:50%;margin:0 auto 1.4rem;display:flex;align-items:center;justify-content:center;overflow:hidden;border:1px solid var(--line);box-shadow:0 8px 22px rgba(44,51,38,.12);transition:border-color .3s,transform .3s;}
.tm-avatar img{width:100%;height:100%;object-fit:cover;display:block;}
.tm-avatar.mono{background:linear-gradient(145deg,var(--n3) 0%,var(--lilac-soft) 130%);font-family:var(--fh);font-weight:700;font-size:2.6rem;color:var(--purple);}
.tmcard:hover .tm-avatar{border-color:rgba(124,140,86,.32);transform:scale(1.04);}
.tm-tag{display:inline-block;font-family:var(--fb);font-size:0.92rem;font-weight:700;text-transform:uppercase;letter-spacing:.11em;color:var(--lilac);background:var(--lilac-soft);border-radius:50px;padding:.35rem .9rem;margin-bottom:.95rem;}
.tm-name{font-family:var(--fh);font-size:1.45rem;font-weight:700;margin-bottom:.3rem;color:var(--white);}
.tm-role{font-size:1.06rem;font-weight:700;text-transform:uppercase;letter-spacing:.085em;color:var(--teal);margin-bottom:1rem;}
.tm-bio{font-size:1.2rem;color:var(--soft);line-height:1.7;}
.tm-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:1.2rem;font-size:1.1rem;font-weight:700;color:var(--label);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s;}
.tm-link:hover{border-bottom-color:var(--label);}
@media(max-width:860px){.tm-grid{grid-template-columns:repeat(2,1fr);}}
@media(max-width:480px){.tm-grid{grid-template-columns:1fr;}}
:root[data-theme="dark"] .tmcard{box-shadow:0 8px 26px rgba(0,0,0,.4);}

/* Pricing comparison + Refer a friend (v67) */
@media(max-width:680px){
  .pricing-table .pt-row{grid-template-columns:1fr !important;gap:.3rem !important;padding:1.1rem 1.3rem !important;}
  .pricing-table .pt-head{display:none !important;}
  .pricing-table .pt-row > div:nth-child(2){font-weight:700 !important;}
  .refer-box{padding:2.4rem 1.6rem !important;}
}

/* What-happens-next stepper inside enroll modal */
@media(max-width:480px){
  .mnext{grid-template-columns:1fr !important;gap:.5rem !important;padding:1rem !important;}
  .mnext > div{display:flex !important;align-items:center !important;gap:.85rem !important;text-align:left !important;}
  .mnext > div > div:first-child{margin:0 !important;flex-shrink:0;}
  .mnext > div > p{text-align:left !important;}
}

/* Lucide icon defaults (v67-icons) */
.pcard-icon svg, .scard-p-icon svg, .vcrit-icon svg, .fcard-ic svg{
  stroke-width:1.6;color:var(--teal);
}
.pcard-icon svg{width:32px;height:32px;}
.scard-p-icon svg{width:26px;height:26px;}
.vcrit-icon svg{width:22px;height:22px;}
.fcard-ic svg{width:22px;height:22px;}
:root[data-theme="dark"] .pcard-icon svg,
:root[data-theme="dark"] .scard-p-icon svg,
:root[data-theme="dark"] .vcrit-icon svg,
:root[data-theme="dark"] .fcard-ic svg{color:var(--teal);}

/* ══════════════════════════════════════════════════
   MOBILE OPTIMIZATIONS, v5.00 audit
   Order matters: more specific (narrower) queries
   live further down and override broader ones.
══════════════════════════════════════════════════ */

/* Tablet & smaller phones ≤860px */
@media(max-width:860px){
  /* Default section padding */
  section{padding:3.8rem 5%;}
  .cta-sec{padding:4rem 5%;}

  /* Mobile nav: scrollable from top, tighter type so all items are reachable */
  .mobile-nav a{font-size:1.5rem!important;padding:.4rem 1.2rem!important;}
  .mobile-nav{gap:1.1rem!important;padding-top:5.5rem!important;}

  /* Headings: tighten clamp ceilings */
  .st{font-size:clamp(2.2rem,6.5vw,3rem)!important;line-height:1.1;}
  .sd{font-size:1.18rem;margin-bottom:2rem;}
  .ey{font-size:1.05rem;}

  /* ── Stem-program intro (text + logo) ── */
  .stem-intro-row{grid-template-columns:1fr!important;align-items:start!important;gap:1.8rem!important;}
  .stem-intro-text{flex:1 1 100%!important;}
  .stem-intro-logo{width:min(280px,72vw)!important;justify-self:center!important;}

  /* ── Schedule timeline: stack subjects vertically on mobile ── */
  /* Hide the day strip, week labels, and separate specialist strip, show all
     info inline on each subject card instead via data attributes below. */
  .schedule-sec{padding:3.5rem 5%;}
  .sched-card{padding:1.2rem 1rem!important;overflow:hidden!important;border-radius:18px!important;}
  .sched-weeks{display:none!important;}
  .sched-days{display:none!important;}
  .sched-specialists{display:none!important;}
  /* Stack subject blocks to a single column, each block becomes a small card */
  .sched-subjects{grid-template-columns:1fr!important;gap:.7rem!important;}
  .sched-subjects > div{
    grid-column:1/-1!important;
    display:grid!important;
    grid-template-columns:auto 1fr!important;
    grid-template-rows:auto auto!important;
    column-gap:.95rem!important;
    padding:1rem 1.1rem!important;
    text-align:left!important;
    align-items:center!important;
  }
  .sched-subjects > div > svg{grid-row:1/3;grid-column:1;align-self:center;flex-shrink:0;}
  .sched-subjects > div > div{grid-column:2;grid-row:1;align-self:end;font-size:1.15rem!important;text-align:left!important;line-height:1.1!important;}
  /* Days + specialist meta line, sourced from data attributes */
  .sched-subjects > div::after{
    content:attr(data-days) ", with " attr(data-specialist);
    grid-column:2;grid-row:2;align-self:start;
    font-family:var(--fh);font-size:.78rem;font-weight:700;
    text-transform:uppercase;letter-spacing:.05em;
    color:var(--soft);margin-top:.2rem;
    line-height:1.3;
  }
  /* Notes below timeline stack */
  .sched-notes{grid-template-columns:1fr!important;gap:1rem!important;}
  .sched-notes > div{font-size:1.08rem!important;}

  /* ── Pricing comparison table: turn rows into stacked cards ── */
  .pricing-table{border-radius:16px;}
  .pricing-table .pt-row{grid-template-columns:1fr!important;gap:.4rem!important;padding:1.2rem 1.3rem!important;font-size:1.1rem!important;}
  .pricing-table .pt-head{display:none!important;}
  .pricing-table .pt-row > div:nth-child(1){font-size:1.18rem!important;font-weight:700;color:var(--white)!important;}
  .pricing-table .pt-row > div:nth-child(2){color:var(--teal)!important;font-weight:700;font-size:1.13rem!important;}
  .pricing-table .pt-row > div:nth-child(3){color:var(--soft)!important;font-size:1.02rem!important;}
  .pricing-table .pt-featured > div:nth-child(2){font-size:1.3rem!important;}

  /* ── Track cards (Foundations / Applied) ── */
  .tcard{padding:2rem 1.5rem!important;}
  .tcard-bg-num{font-size:1.65rem!important;top:1.1rem!important;right:1.2rem!important;}

  /* ── SS feature cards padding refinement ── */
  .sfeat{padding:1.9rem 1.5rem!important;}
  .sfeat h4{font-size:1.4rem!important;}
  .sfeat p{font-size:1.08rem!important;}

  /* ── Modal: enrollment form ── */
  .modal{padding:2.2rem 1.5rem!important;border-radius:18px;max-height:94vh;}
  .modal h2{font-size:clamp(1.7rem,5.5vw,2.2rem)!important;}
  .modal .msubhead{font-size:1.1rem;margin-bottom:1.4rem;}
  .modal-close{width:44px!important;height:44px!important;font-size:1.7rem!important;top:.7rem!important;right:.7rem!important;}

  /* mpricetag: let "See the program" link wrap below price */
  .mpricetag{flex-wrap:wrap;font-size:1.25rem!important;padding:1rem 1.2rem!important;gap:.5rem!important;}
  .mpricetag .price{font-size:1.85rem!important;}
  .mpricetag .mprice-link{margin-left:0!important;width:100%;padding-top:.5rem;margin-top:.2rem;border-bottom:none!important;border-top:1px solid rgba(94,107,62,.2);font-size:1.05rem!important;}

  /* mnext (3-step graphic): stack vertically with horizontal step layout */
  .mnext{grid-template-columns:1fr!important;gap:.85rem!important;padding:1rem!important;}
  .mnext > div{display:flex!important;align-items:flex-start!important;gap:.85rem!important;text-align:left!important;}
  .mnext > div > div:first-child{margin:0!important;flex-shrink:0;width:30px!important;height:30px!important;font-size:1.05rem!important;}
  .mnext > div > p{text-align:left!important;font-size:1.02rem!important;line-height:1.45!important;}

  /* mform: prevent iOS zoom on focus (16px min), bigger tap targets */
  .mfield input,.mfield select{font-size:16px!important;padding:.9rem 1rem!important;}
  .mfield label{font-size:1.1rem!important;}
  .mrow{grid-template-columns:1fr!important;gap:1rem!important;}

  /* FAQ tap targets */
  .faq-q{padding:1.3rem 1.2rem!important;font-size:1.08rem!important;}
  .faq-q-text{font-size:1.08rem!important;}

  /* Hero text refinements */
  .home-hero{padding:4rem 5% 1rem!important;}
  .home-hero h1{font-size:clamp(2.2rem,8.5vw,3.4rem)!important;}
  .home-hero .sub{font-size:1.18rem!important;margin-bottom:2rem!important;}
  .hero-dates{font-size:1.15rem!important;}

  /* Community block tighter */
  .comm-inner{gap:2rem!important;}
  .pct-badge{margin-bottom:1.2rem!important;}

  /* Refer-a-friend box */
  .refer-box{padding:2.5rem 1.5rem!important;}
}

/* Phones ≤600px */
@media(max-width:600px){
  section{padding:3rem 5%;}
  .cta-sec{padding:3.5rem 5%;}

  .st{font-size:clamp(1.95rem,7.5vw,2.5rem)!important;}
  .sd{font-size:1.1rem;}

  .modal-backdrop{padding:.5rem;}
  .modal{padding:1.8rem 1.2rem!important;border-radius:14px!important;}
  .mpricetag{font-size:1.15rem!important;padding:.9rem 1.05rem!important;}
  .mpricetag .price{font-size:1.7rem!important;}

  .home-hero h1{font-size:clamp(2rem,9vw,2.9rem)!important;}

  .tcard-bg-num{font-size:1.45rem!important;}

  /* Reduce the giant about-grid headings */
  .acard{padding:2rem 1.5rem!important;}
  .acard h3{font-size:1.3rem!important;}

  /* Steps numbering */
  .step{padding:1.5rem 1.3rem!important;}

  /* Footer */
  footer{padding:3rem 5%!important;}

  /* Reveal block reset for tiny screens */
  .reveal{transform:none;}
}

/* Tiny screens ≤380px */
@media(max-width:380px){
  section{padding:2.6rem 4%;}
  .modal{padding:1.4rem 1rem!important;}
  .st{font-size:clamp(1.75rem,8.5vw,2.2rem)!important;}
  .home-hero h1{font-size:clamp(1.85rem,9.5vw,2.6rem)!important;}
  .btn-grad,.btn-outline{font-size:1.1rem!important;padding:.95rem 1.6rem!important;}
  .sched-card{padding:1rem .9rem!important;}
  .mobile-nav a{font-size:1.35rem!important;}
}

/* Short viewports (landscape phones, small phones): shrink mobile nav further */
@media(max-height:720px) and (max-width:860px){
  .mobile-nav a{font-size:1.3rem!important;padding:.3rem 1rem!important;}
  .mobile-nav{gap:.85rem!important;padding-top:4.5rem!important;}
}

/* ══════════════════════════════════════════════════
   GLOBAL OVERFLOW GUARDS: everything below clamps
   anything that could push past the viewport edge.
══════════════════════════════════════════════════ */

/* Images and embedded media never wider than their container */
img,svg,video,iframe{max-width:100%;height:auto;}
img{height:auto;}

/* Word breaking: paragraphs and headings shouldn't push past the viewport
   because of long URLs, hashes, or compound words. */
p,h1,h2,h3,h4,h5,h6,li,dd{overflow-wrap:break-word;word-wrap:break-word;}

/* Footer: allow paragraph + link list to wrap cleanly on every screen */
footer p{max-width:100%;word-wrap:break-word;overflow-wrap:break-word;}
.fl{flex-wrap:wrap;}
.fl a{white-space:nowrap;}

@media(max-width:860px){
  /* Footer specifically tuned for mobile */
  footer{padding:2.5rem 5%!important;}
  footer p{font-size:.95rem!important;line-height:1.65;}
  .fl{justify-content:center!important;gap:.75rem 1.4rem!important;}
  .fl a{font-size:1rem!important;}
}

@media(max-width:480px){
  .fl{gap:.6rem 1.1rem!important;}
  .fl a{font-size:.96rem!important;}
}