/* ============================================================
   Voyager Academy — subject page design system (sp-)
   Used by: hsc-chemistry.html / ucat.html / interviews.html
   Loaded after styles.css; everything is scoped under .sp
   ============================================================ */

/* Per-subject accent tokens */
.sp{--acc2:#2fbf71;--acc2s:rgba(47,191,113,.13);position:relative}
.sp[data-subject=chem]{--acc2:#2fbf71;--acc2s:rgba(47,191,113,.13)}
.sp[data-subject=ucat]{--acc2:#2f7fd6;--acc2s:rgba(47,127,214,.13)}
.sp[data-subject=med]{--acc2:#f5853c;--acc2s:rgba(245,133,60,.13)}

/* ---------- Reading progress bar ---------- */
.sp-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:1300;pointer-events:none}
.sp-progress-bar{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--teal),var(--acc2));border-radius:0 3px 3px 0}

/* ---------- Hero (layered) ---------- */
.sp-hero{position:relative;overflow:hidden;padding:150px 24px 70px;min-height:580px;display:flex;align-items:center}
.sp-hero-bg{position:absolute;inset:0;pointer-events:none}
.sp-mesh{position:absolute;inset:0;background:radial-gradient(46% 42% at 16% 18%,rgba(26,175,160,.17),transparent 70%),radial-gradient(38% 36% at 86% 12%,var(--acc2s),transparent 72%),radial-gradient(54% 46% at 72% 92%,rgba(26,175,160,.1),transparent 70%),linear-gradient(180deg,#e9f6f3 0%,var(--bg) 100%)}
.sp-canvas{position:absolute;inset:0;width:100%;height:100%}
.sp-pattern{position:absolute;inset:0;background-image:radial-gradient(rgba(12,40,69,.055) 1px,transparent 1.4px);background-size:26px 26px;mask-image:linear-gradient(180deg,transparent,#000 20%,#000 68%,transparent);-webkit-mask-image:linear-gradient(180deg,transparent,#000 20%,#000 68%,transparent)}
.sp-orb{position:absolute;border-radius:50%;will-change:transform}
.sp-orb::after{content:'';position:absolute;inset:0;border-radius:50%;animation:spOrbPulse 9s ease-in-out infinite}
.sp-orb-a{width:320px;height:320px;top:-100px;right:-80px;background:radial-gradient(circle at 32% 32%,var(--acc2s),rgba(26,175,160,.05) 72%)}
.sp-orb-b{width:180px;height:180px;bottom:-50px;left:5%;background:radial-gradient(circle at 60% 40%,rgba(26,175,160,.13),transparent 72%)}
.sp-ring{position:absolute;width:400px;height:400px;top:10%;left:-140px;will-change:transform}
.sp-ring::before{content:'';position:absolute;inset:0;border:1.5px dashed rgba(26,175,160,.22);border-radius:50%;animation:spSpin 70s linear infinite}
@keyframes spOrbPulse{0%,100%{box-shadow:0 0 0 0 rgba(26,175,160,.06)}50%{box-shadow:0 0 0 26px rgba(26,175,160,0)}}
@keyframes spSpin{to{transform:rotate(360deg)}}
.sp-hero-in{position:relative;z-index:1;max-width:1140px;margin:0 auto;display:grid;grid-template-columns:minmax(0,1.06fr) minmax(0,.94fr);gap:48px;align-items:center;width:100%}
.sp-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.74);border:1px solid rgba(26,175,160,.28);border-radius:999px;padding:7px 16px;font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--navy);box-shadow:0 8px 20px rgba(11,39,69,.05);margin-bottom:18px;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.sp-eyebrow em{font-style:normal;color:var(--teal)}
.sp-hero h1{font-size:clamp(2.2rem,5vw,3.3rem);font-weight:800;line-height:1.08;letter-spacing:-.025em;margin-bottom:16px}
.sp-grad{background:linear-gradient(115deg,var(--teal) 12%,var(--acc2) 92%);-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-lead{font-size:clamp(1rem,2vw,1.15rem);line-height:1.7;color:var(--body);max-width:540px;margin-bottom:26px}
.sp-hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:28px}
.sp-chips{list-style:none;display:flex;flex-wrap:wrap;gap:10px;margin:0;padding:0}
.sp-chips li{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,.78);border:1px solid rgba(12,40,69,.09);border-radius:999px;padding:8px 14px;font-size:.82rem;font-weight:600;color:var(--navy);box-shadow:0 6px 16px rgba(11,39,69,.05);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:transform .25s,border-color .25s,box-shadow .25s}
.sp-chips li:hover{transform:translateY(-2px);border-color:rgba(26,175,160,.45);box-shadow:0 10px 22px rgba(11,39,69,.08)}
.sp-chips svg{width:15px;height:15px;color:var(--teal);flex:0 0 auto}
.sp-hero-art{position:relative;display:flex;justify-content:center;align-items:center;will-change:transform;transition:transform .25s ease-out}
.sp-hero-art > svg{width:min(100%,400px);height:auto;filter:drop-shadow(0 26px 40px rgba(11,39,69,.13));animation:spArtFloat 7s ease-in-out infinite}
@keyframes spArtFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
.sp-scroll-cue{position:absolute;left:50%;bottom:16px;transform:translateX(-50%);width:26px;height:42px;border:2px solid rgba(12,40,69,.22);border-radius:14px;display:flex;justify-content:center;z-index:1}
.sp-scroll-cue span{width:4px;height:8px;border-radius:2px;background:var(--teal);margin-top:7px;animation:spCue 1.8s ease-in-out infinite}
@keyframes spCue{0%{transform:translateY(0);opacity:1}70%{transform:translateY(14px);opacity:0}100%{transform:translateY(14px);opacity:0}}

/* Hero / illustration micro-animations (SVG internals) */
.sp-rot{transform-box:view-box;transform-origin:50% 50%;animation:spSpin 55s linear infinite}
.sp-hand{transform-box:view-box;transform-origin:50% 50%;animation:spSpin 10s linear infinite}
.sp-arc{animation:spArc 5.5s ease-in-out infinite}
@keyframes spArc{0%,100%{stroke-dasharray:16 100}50%{stroke-dasharray:76 100}}
.sp-fl1,.sp-fl2,.sp-fl3{transform-box:fill-box;animation:spArtFloat 5.4s ease-in-out infinite}
.sp-fl2{animation-delay:1.1s;animation-duration:6.4s}
.sp-fl3{animation-delay:.5s;animation-duration:7.2s}
.sp-td{transform-box:fill-box;transform-origin:center;animation:spTd 1.25s ease-in-out infinite}
.sp-td2{animation-delay:.18s}
.sp-td3{animation-delay:.36s}
@keyframes spTd{0%,60%,100%{transform:translateY(0);opacity:.5}30%{transform:translateY(-6px);opacity:1}}
.sp-bub{transform-box:fill-box;animation:spBub 3.6s ease-in infinite}
.sp-bub.b2{animation-delay:1.2s;animation-duration:4.3s}
.sp-bub.b3{animation-delay:2.1s;animation-duration:3.9s}
@keyframes spBub{0%{transform:translateY(0);opacity:0}14%{opacity:.95}82%{opacity:.55}100%{transform:translateY(-72px);opacity:0}}
.sp-pulse{stroke-dasharray:150 850;animation:spPulse 4.2s linear infinite}
@keyframes spPulse{to{stroke-dashoffset:-1000}}

/* ---------- Sticky section nav + scrollspy ---------- */
.sp-subnav{position:sticky;top:87px;z-index:900;background:rgba(255,255,255,.84);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid rgba(12,40,69,.07);border-top:1px solid rgba(12,40,69,.04)}
.sp-subnav-in{max-width:1140px;margin:0 auto;display:flex;gap:6px;padding:0 18px;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}
.sp-subnav-in::-webkit-scrollbar{display:none}
.sp-subnav a{position:relative;flex:0 0 auto;padding:14px;font-family:'Poppins',sans-serif;font-size:.82rem;font-weight:600;color:var(--body);text-decoration:none;transition:color .2s;white-space:nowrap}
.sp-subnav a::after{content:'';position:absolute;left:14px;right:14px;bottom:0;height:2.5px;border-radius:2px;background:linear-gradient(90deg,var(--teal),var(--acc2));transform:scaleX(0);transform-origin:left;transition:transform .28s cubic-bezier(.22,.9,.3,1)}
.sp-subnav a:hover{color:var(--navy)}
.sp-subnav a.act{color:var(--teal)}
.sp-subnav a.act::after{transform:scaleX(1)}
.sp [id]{scroll-margin-top:152px}

/* ---------- Generic section scaffold + layered backgrounds ---------- */
.sp-sec{position:relative;padding:84px 24px;overflow:hidden}
.sp-ct{position:relative;z-index:1;max-width:1140px;margin:0 auto}
.sp-head{text-align:center;max-width:720px;margin:0 auto 46px}
.sp-sec-eyebrow{display:block;font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:800;letter-spacing:1.6px;text-transform:uppercase;color:var(--teal);margin-bottom:8px}
.sp-head h2{font-size:clamp(1.6rem,3.2vw,2.2rem);letter-spacing:-.02em}
.sp-head-sub{margin-top:12px;font-size:.98rem;line-height:1.7;color:var(--body)}
.sp-bglayer{position:absolute;inset:0;pointer-events:none;z-index:0;will-change:transform;backface-visibility:hidden}
.sp-bg-diag{background:repeating-linear-gradient(135deg,rgba(26,175,160,.045) 0 1px,transparent 1px 26px);mask-image:linear-gradient(90deg,transparent,#000 15%,#000 85%,transparent);-webkit-mask-image:linear-gradient(90deg,transparent,#000 15%,#000 85%,transparent);animation:bgDriftSoftA 26s ease-in-out infinite}
.sp-bg-grid{background-image:linear-gradient(rgba(12,40,69,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(12,40,69,.04) 1px,transparent 1px);background-size:44px 44px;mask-image:radial-gradient(70% 85% at 50% 42%,#000 32%,transparent 88%);-webkit-mask-image:radial-gradient(70% 85% at 50% 42%,#000 32%,transparent 88%);animation:bgDriftSoftB 28s ease-in-out infinite}
.sp-bg-dots{background-image:radial-gradient(rgba(26,175,160,.12) 1px,transparent 1.4px);background-size:22px 22px;mask-image:linear-gradient(180deg,#000 10%,transparent 85%);-webkit-mask-image:linear-gradient(180deg,#000 10%,transparent 85%);animation:bgDriftSoftC 30s ease-in-out infinite}
.sp-blob{position:absolute;border-radius:50%;background:radial-gradient(circle at 35% 35%,var(--acc2s),transparent 70%);pointer-events:none;z-index:0;animation:bgDriftSoftD 24s ease-in-out infinite}

/* Section background tints (alternating rhythm) */
.sp-overview{background:linear-gradient(180deg,var(--w) 0%,#fbffff 100%)}
.sp-method{background:linear-gradient(180deg,var(--bg) 0%,#e7f4f1 100%)}
.sp-tools,.sp-mocks{background:linear-gradient(180deg,var(--w) 0%,#f6fcfb 100%)}
.sp-tutors{background:linear-gradient(180deg,var(--w) 0%,#fbffff 100%)}
.sp-medify-s{padding:26px 24px;background:transparent}
.sp-pricing{background:linear-gradient(180deg,var(--bg) 0%,#e7f4f1 100%)}
.sp-resources{background:linear-gradient(180deg,var(--w) 0%,#fbffff 100%)}
.sp-faq{background:linear-gradient(180deg,var(--bg) 0%,#e7f4f1 100%)}
.sp-faq .faq-accordion{max-width:780px;margin:22px auto 0}

/* ---------- Scroll-reveal system (active only once JS adds .sp-ready) ---------- */
.sp-ready [data-reveal]{opacity:0;transform:translateY(24px);transition:opacity .65s cubic-bezier(.22,.9,.3,1),transform .65s cubic-bezier(.22,.9,.3,1)}
.sp-ready [data-reveal=left]{transform:translateX(-28px)}
.sp-ready [data-reveal=right]{transform:translateX(28px)}
.sp-ready [data-reveal=zoom]{transform:scale(.93)}
.sp-ready [data-reveal].rv{opacity:1;transform:none}
.sp-ready [data-stagger]>*{opacity:0;transform:translateY(22px);transition:opacity .6s cubic-bezier(.22,.9,.3,1),transform .6s cubic-bezier(.22,.9,.3,1)}
.sp-ready [data-stagger].rv>*{opacity:1;transform:none}

/* ---------- Overview ---------- */
.sp-cols{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:48px;align-items:start}
.sp-prose p{font-size:.99rem;line-height:1.78;margin-bottom:16px}
.sp-prose p:last-child{margin-bottom:0}
.sp-features{display:flex;flex-direction:column;gap:16px}
.sp-feature{display:flex;gap:16px;align-items:flex-start;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:18px;padding:20px;box-shadow:var(--sh);transition:box-shadow .3s,border-color .3s;will-change:transform}
.sp-feature:hover{border-color:rgba(26,175,160,.4);box-shadow:var(--sh-lg)}
.sp-feature h3{font-size:.98rem;margin-bottom:4px}
.sp-feature p{font-size:.86rem;line-height:1.55;color:var(--body)}
.sp-fi{flex:0 0 auto;width:50px;height:50px;border-radius:14px;background:linear-gradient(135deg,rgba(26,175,160,.13),var(--acc2s));border:1px solid rgba(26,175,160,.2);display:flex;align-items:center;justify-content:center;color:var(--teal);transition:transform .35s cubic-bezier(.34,1.56,.64,1)}
.sp-fi svg{width:24px;height:24px}
.sp-feature:hover .sp-fi,.sp-res:hover .sp-fi{transform:scale(1.1) rotate(-4deg)}

/* ---------- "How it works" timeline (scroll-driven) ---------- */
.sp-timeline{position:relative;max-width:780px;margin:0 auto}
.sp-tl-track{position:absolute;left:27px;top:10px;bottom:10px;width:3px;border-radius:3px;background:rgba(12,40,69,.09);overflow:hidden}
.sp-tl-fill{display:block;width:100%;height:0;background:linear-gradient(180deg,var(--teal),var(--acc2));border-radius:3px}
.sp-steps{list-style:none;display:flex;flex-direction:column;gap:26px;margin:0;padding:0}
.sp-step{position:relative;display:grid;grid-template-columns:56px minmax(0,1fr);gap:22px;align-items:flex-start}
.sp-step-dot{position:relative;z-index:1;width:56px;height:56px;border-radius:50%;background:var(--w);border:2px solid rgba(12,40,69,.13);display:flex;align-items:center;justify-content:center;font-family:'Poppins',sans-serif;font-weight:800;font-size:1.05rem;color:var(--body);box-shadow:0 8px 20px rgba(11,39,69,.06);transition:background .45s,border-color .45s,color .45s,transform .45s cubic-bezier(.34,1.56,.64,1),box-shadow .45s}
.sp-step.on .sp-step-dot{background:linear-gradient(135deg,var(--teal),var(--acc2));border-color:transparent;color:var(--w);transform:scale(1.1);box-shadow:0 12px 26px rgba(26,175,160,.32)}
.sp-step-card{background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:18px;padding:22px 26px;box-shadow:var(--sh);transition:transform .3s,box-shadow .3s,border-color .45s}
.sp-step.on .sp-step-card{border-color:rgba(26,175,160,.32)}
.sp-step-card:hover{transform:translateY(-3px);box-shadow:var(--sh-lg)}
.sp-step-card h3{font-size:1.05rem;margin-bottom:6px}
.sp-step-card p{font-size:.95rem;line-height:1.68}

/* ---------- Success-rate comparison (interviews overview) ---------- */
.sp-compare{max-width:600px;margin:0 auto;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:24px;padding:36px 30px 26px;box-shadow:var(--sh-lg)}
.sp-compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:end}
.sp-compare-col{display:flex;flex-direction:column;align-items:center;min-width:0}
.sp-compare-track{position:relative;width:100%;height:240px;display:flex;align-items:flex-end;justify-content:center;border-bottom:2px solid rgba(12,40,69,.13);background:linear-gradient(rgba(12,40,69,.05) 1px,transparent 1px);background-size:100% 48px;background-position:0 100%}
.sp-compare-bar{position:relative;width:108px;max-width:74%;height:0;border-radius:14px 14px 0 0;transition:height 1.5s cubic-bezier(.22,.9,.3,1) .05s}
.sp-compare.rv .sp-compare-bar{height:var(--h)}
.sp-compare-bar.is-base{background:linear-gradient(180deg,#cdd8e2,#a7b6c4)}
.sp-compare-bar.is-voy{background:linear-gradient(180deg,var(--teal),var(--acc2));box-shadow:0 -2px 26px rgba(26,175,160,.28)}
.sp-compare-bar.is-voy::after{content:'';position:absolute;inset:0;border-radius:14px 14px 0 0;background:linear-gradient(180deg,rgba(255,255,255,.34),transparent 42%);pointer-events:none}
.sp-compare-val{position:absolute;left:50%;top:0;transform:translate(-50%,-118%);font-family:'Poppins',sans-serif;font-weight:800;white-space:nowrap;line-height:1}
.sp-compare-val i,.sp-compare-val em{font-style:normal}
.sp-compare-bar.is-base .sp-compare-val{font-size:1.5rem;color:var(--navy2)}
.sp-compare-bar.is-voy .sp-compare-val{font-size:2.3rem;background:linear-gradient(120deg,var(--teal),var(--acc2));-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-compare-cap{margin-top:16px;text-align:center;line-height:1.3}
.sp-compare-cap strong{display:block;font-family:'Poppins',sans-serif;font-size:.95rem;color:var(--navy)}
.sp-compare-cap span{display:block;font-size:.8rem;color:var(--body);margin-top:2px}
@media(max-width:540px){
.sp-compare{padding:28px 16px 22px}
.sp-compare-grid{gap:16px}
.sp-compare-track{height:200px}
.sp-compare-bar{width:78px}
.sp-compare-bar.is-voy .sp-compare-val{font-size:1.85rem}
.sp-compare-bar.is-base .sp-compare-val{font-size:1.25rem}
.sp-compare-cap strong{font-size:.86rem}
.sp-compare-cap span{font-size:.74rem}
}

/* ---------- Mock interview matrix (interviews page) ---------- */
.sp-mock-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;max-width:940px;margin:0 auto}
.sp-mock{position:relative;background:var(--w);border:1px solid rgba(12,40,69,.09);border-radius:16px;padding:18px 14px 16px;text-align:center;box-shadow:var(--sh);overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.sp-mock::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,175,160,.09),transparent 62%);opacity:0;transition:opacity .25s}
.sp-ready [data-stagger].rv>.sp-mock:hover,.sp-mock:hover{transform:translateY(-4px);border-color:rgba(26,175,160,.45);box-shadow:0 14px 30px rgba(11,39,69,.1)}
.sp-mock:hover::before{opacity:1}
.sp-mock b{display:block;font-family:'Poppins',sans-serif;font-size:1.5rem;font-weight:800;line-height:1.1;background:linear-gradient(120deg,var(--teal),var(--acc2));-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-mock b i{font-style:normal}
.sp-mock span{display:block;margin-top:4px;font-size:.85rem;font-weight:600;color:var(--navy)}
.sp-mock-note{text-align:center;margin:24px auto 0;max-width:640px;font-size:.92rem;line-height:1.65;color:var(--body)}

/* ---------- Free tools (UCAT page) ---------- */
.sp-tool-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.sp-tool{position:relative;display:flex;flex-direction:column;gap:12px;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:20px;padding:28px 24px;text-decoration:none;color:inherit;box-shadow:var(--sh);overflow:hidden;transition:transform .28s,box-shadow .28s,border-color .28s}
.sp-tool::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--teal),var(--acc2));opacity:0;transition:opacity .28s}
.sp-ready [data-stagger].rv>.sp-tool:hover,.sp-tool:hover{transform:translateY(-6px);border-color:rgba(26,175,160,.4);box-shadow:0 18px 42px rgba(11,39,69,.11)}
.sp-tool:hover::before{opacity:1}
.sp-tool:hover .sp-fi{transform:scale(1.1) rotate(-4deg)}
.sp-tool h3{font-size:1.02rem}
.sp-tool p{font-size:.88rem;line-height:1.6;color:var(--body);flex:1}
.sp-tool-badge{position:absolute;top:18px;right:18px;background:rgba(26,175,160,.12);color:var(--teal-h);font-family:'Poppins',sans-serif;font-size:.66rem;font-weight:800;letter-spacing:1px;text-transform:uppercase;padding:4px 10px;border-radius:999px}
.sp-tool-go{display:inline-flex;align-items:center;gap:6px;color:var(--teal);font-family:'Poppins',sans-serif;font-weight:600;font-size:.9rem;transition:gap .25s}
.sp-tool:hover .sp-tool-go{gap:11px}
.sp-tool-go i{font-style:normal}

/* ---------- Tutor advert (UCAT + interviews pages) — horizontal split card ---------- */
.sp-tutor-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:24px;max-width:920px;margin:0 auto}
.sp-tutor{position:relative;display:flex;align-items:stretch;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:22px;box-shadow:var(--sh);overflow:hidden;transition:transform .28s,box-shadow .28s,border-color .28s}
.sp-ready [data-stagger].rv>.sp-tutor:hover,.sp-tutor:hover{transform:translateY(-5px);border-color:rgba(26,175,160,.4);box-shadow:0 18px 42px rgba(11,39,69,.11)}
.sp-tutor-photo-panel{position:relative;flex:0 0 128px;align-self:stretch;overflow:hidden;background:linear-gradient(160deg,rgba(26,175,160,.16),var(--acc2s))}
.sp-tutor-photo-panel img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.sp-tutor-photo-panel::after{content:'';position:absolute;inset:0;background:linear-gradient(120deg,transparent 58%,rgba(12,40,69,.15));pointer-events:none}
.sp-tutor-photo-panel::before{content:'';position:absolute;top:0;bottom:0;right:0;width:3px;background:linear-gradient(180deg,var(--teal),var(--acc2));z-index:1}
.sp-tutor-body{flex:1 1 auto;min-width:0;display:flex;flex-direction:column;gap:16px;padding:24px 24px 26px}
.sp-tutor-name{font-family:'Poppins',sans-serif;font-size:1.14rem;font-weight:700;color:var(--navy);line-height:1.2}
.sp-tutor-role{font-size:.82rem;font-weight:600;color:var(--teal);margin-top:5px}
.sp-tutor-stats{display:flex;gap:12px;flex-wrap:wrap;margin-top:auto}
.sp-tutor-stat{flex:1 1 120px;min-width:0;background:linear-gradient(135deg,rgba(26,175,160,.08),var(--acc2s));border:1px solid rgba(26,175,160,.18);border-radius:14px;padding:14px 16px}
.sp-tutor-stat b{display:block;font-family:'Poppins',sans-serif;font-size:1.7rem;font-weight:800;line-height:1;background:linear-gradient(120deg,var(--teal),var(--acc2));-webkit-background-clip:text;background-clip:text;color:transparent}
.sp-tutor-stat b i{font-style:normal}
.sp-tutor-stat span{display:block;margin-top:6px;font-size:.77rem;font-weight:600;color:var(--navy)}
.sp-tutor-cta{display:inline-flex;align-items:center;justify-content:center;gap:9px;width:100%;text-decoration:none;background:linear-gradient(135deg,#1fb8a8,var(--teal) 55%,#129488);color:var(--w)!important;font-family:'Poppins',sans-serif;font-weight:600;font-size:.95rem;padding:13px 22px;border-radius:50px;box-shadow:0 8px 20px rgba(26,175,160,.22);transition:transform .2s,box-shadow .2s}
.sp-tutor-cta svg{width:18px;height:18px;flex-shrink:0}
.sp-tutor-cta:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(26,175,160,.32)}
.sp-tutor-cta:focus-visible{outline:3px solid rgba(26,175,160,.4);outline-offset:3px}
.sp-tutor-offers{display:flex;flex-direction:column;gap:10px}
.sp-tutor-offers-label{display:inline-flex;align-items:center;gap:6px;font-family:'Poppins',sans-serif;font-size:.68rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--teal)}
.sp-tutor-offers-label svg{width:14px;height:14px}
.sp-tutor-tags{display:flex;flex-wrap:wrap;gap:6px}
.sp-tutor-tags span{display:inline-flex;align-items:center;background:var(--acc2s);border:1px solid rgba(26,175,160,.22);color:var(--navy);font-size:.72rem;font-weight:600;line-height:1.1;padding:5px 10px;border-radius:999px;white-space:nowrap}

/* ---------- Medify partner strip (UCAT page) ---------- */
.sp-medify{display:grid;grid-template-columns:auto minmax(0,1fr) auto;gap:26px;align-items:center;background:var(--w);border:1px solid rgba(31,91,232,.12);border-radius:24px;padding:30px 34px;box-shadow:var(--sh)}
.sp-medify-eyebrow{font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:800;color:#1f5be8;text-transform:uppercase;letter-spacing:1px;margin-bottom:5px}
.sp-medify h2{font-size:clamp(1.25rem,2.2vw,1.6rem);margin-bottom:8px}
.sp-medify p{font-size:.94rem;line-height:1.65;color:var(--body);max-width:660px}
.sp-medify .cb{white-space:nowrap;justify-self:end}

/* ---------- Pricing ---------- */
.sp-price-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(265px,1fr));gap:26px;max-width:1140px;margin:0 auto;align-items:stretch}
.sp-price-grid.sp-price-1{max-width:440px}
.sp-price-grid.sp-price-2{max-width:780px}
.sp-price{position:relative;display:flex;flex-direction:column;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:22px;padding:34px 26px 28px;box-shadow:var(--sh);transition:box-shadow .3s,border-color .3s;will-change:transform}
.sp-price:hover{border-color:rgba(26,175,160,.4);box-shadow:0 20px 46px rgba(11,39,69,.12)}
.sp-price h3{font-size:1.08rem;text-align:center;margin-bottom:12px}
.sp-price-pill{display:block;width:max-content;margin:0 auto 10px;background:rgba(26,175,160,.12);color:var(--teal-h);font-family:'Poppins',sans-serif;font-size:.72rem;font-weight:800;letter-spacing:.6px;text-transform:uppercase;padding:4px 12px;border-radius:999px}
.sp-price-old{display:block;text-align:center;text-decoration:line-through;color:#9aa9b8;font-family:'Poppins',sans-serif;font-weight:600;font-size:1.02rem}
.sp-price-val{font-family:'Poppins',sans-serif;font-size:2.15rem;font-weight:800;color:var(--navy);line-height:1.1;text-align:center}
.sp-price-val span{font-size:1rem;color:var(--body);font-weight:600}
.sp-price ul{list-style:none;margin:18px 0 24px;padding:0;flex:1}
.sp-price li{position:relative;padding:9px 0 9px 28px;font-size:.91rem;line-height:1.55;border-bottom:1px dashed rgba(12,40,69,.09)}
.sp-price li:last-child{border-bottom:none}
.sp-price li::before{content:'';position:absolute;left:0;top:13px;width:17px;height:17px;border-radius:50%;background:rgba(26,175,160,.13) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23128e82' stroke-width='3.6' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E") center/9px no-repeat}
.sp-price-cta{align-self:center;margin-top:auto}
.sp-price.feat{border-color:transparent;box-shadow:0 24px 52px rgba(26,175,160,.16);z-index:0}
.sp-price.feat::before{content:'';position:absolute;inset:0;border-radius:22px;padding:2px;background:linear-gradient(120deg,var(--teal),var(--acc2),var(--teal)) border-box;background-size:240% 100%;-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);mask-composite:exclude;animation:spBorder 5s linear infinite;pointer-events:none}
@keyframes spBorder{to{background-position:240% 0}}
.sp-price.feat::after{content:attr(data-flag);position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:linear-gradient(120deg,var(--teal),var(--acc2));color:var(--w);padding:5px 16px;border-radius:999px;font-family:'Poppins',sans-serif;font-size:.74rem;font-weight:700;letter-spacing:.4px;white-space:nowrap;box-shadow:0 8px 18px rgba(26,175,160,.3)}

/* ---------- Resources ---------- */
.sp-res-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(330px,1fr));gap:20px;max-width:920px;margin:0 auto}
.sp-res{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:var(--w);border:1px solid rgba(12,40,69,.08);border-radius:18px;padding:24px 22px;box-shadow:var(--sh);transition:transform .25s,border-color .25s,box-shadow .25s}
.sp-ready [data-stagger].rv>.sp-res:hover,.sp-res:hover{transform:translateY(-4px);border-color:rgba(26,175,160,.4);box-shadow:0 14px 32px rgba(11,39,69,.1)}
.sp-res-body{flex:1 1 200px;min-width:0}
.sp-res-tag{display:inline-block;font-family:'Poppins',sans-serif;font-size:.64rem;font-weight:800;color:var(--teal-h);letter-spacing:1px;text-transform:uppercase;background:rgba(26,175,160,.1);border-radius:999px;padding:3px 9px;margin-bottom:7px}
.sp-res h3{font-size:.98rem;line-height:1.4;margin-bottom:3px}
.sp-res p{font-size:.82rem;color:var(--body);line-height:1.5}
.sp-dl{display:inline-flex;align-items:center;gap:8px;background:var(--teal);color:var(--w);padding:11px 22px;border-radius:50px;border:none;font-weight:600;cursor:pointer;font-size:.88rem;font-family:'Poppins',sans-serif;text-decoration:none;box-shadow:0 6px 16px rgba(26,175,160,.22);transition:background-color .2s,box-shadow .2s,transform .2s;-webkit-appearance:none;touch-action:manipulation}
.sp-dl:hover{background:var(--teal-h);transform:translateY(-2px);box-shadow:0 10px 24px rgba(26,175,160,.32)}
.sp-dl svg{width:16px;height:16px;flex:0 0 auto}
.sp-dl:hover svg{animation:spDlNudge .55s ease}
@keyframes spDlNudge{0%,100%{transform:translateY(0)}45%{transform:translateY(4px)}}

/* ---------- Final CTA band ---------- */
.sp-cta{position:relative;width:min(1140px,calc(100% - 48px));margin:34px auto 74px;border-radius:28px;overflow:hidden;background:radial-gradient(480px 300px at 86% -90px,rgba(26,175,160,.4),transparent 70%),linear-gradient(135deg,var(--navy) 0%,var(--navy2) 100%);padding:64px 28px;text-align:center;color:var(--w);box-shadow:0 30px 60px rgba(11,39,69,.22)}
.sp-cta-bg{position:absolute;inset:0;pointer-events:none}
.sp-cta-bg::before{content:'';position:absolute;left:-80px;bottom:-100px;width:230px;height:230px;border-radius:50%;background:rgba(26,175,160,.13)}
.sp-cta-bg::after{content:'';position:absolute;right:10%;top:-60px;width:160px;height:160px;border-radius:50%;border:1.5px dashed rgba(255,255,255,.14);animation:spSpin 60s linear infinite}
.sp-cta-boat{position:absolute;bottom:18px;right:7%;width:92px;opacity:.14;animation:fl 4.5s ease-in-out infinite}
.sp-cta-in{position:relative;z-index:1;max-width:640px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:14px}
.sp-cta-icon{width:56px;height:56px;border-radius:50%;background:rgba(26,175,160,.2);display:flex;align-items:center;justify-content:center}
.sp-cta-icon svg{width:26px;height:26px;color:var(--teal)}
.sp-cta h2{color:var(--w);font-size:clamp(1.45rem,3vw,1.95rem)}
.sp-cta p{font-size:.98rem;color:rgba(255,255,255,.82);line-height:1.7;max-width:520px}
.sp-cta .cb{margin-top:8px;animation:pulseGlow 2.2s infinite}
.sp-btn-lg{padding:14px 34px!important;font-size:1.02rem!important}

/* ---------- Button shine micro-interaction ---------- */
.sp-btn{position:relative;overflow:hidden}
.sp-btn::before{content:'';position:absolute;top:0;left:-90%;width:55%;height:100%;background:linear-gradient(100deg,transparent,rgba(255,255,255,.38),transparent);transform:skewX(-20deg);transition:left .5s ease;pointer-events:none}
.sp-btn:hover::before{left:135%}
.sp-btn:active{transform:translateY(0) scale(.97)}

/* ---------- Responsive ---------- */
@media(max-width:1020px){
.sp-hero-in{gap:34px}
.sp-hero-art > svg{width:min(100%,330px)}
.sp-cols{gap:34px}
}
@media(max-width:900px){
.sp-hero{padding:132px 22px 64px;min-height:0}
.sp-hero-in{grid-template-columns:1fr;text-align:center;gap:28px}
.sp-lead{margin-left:auto;margin-right:auto}
.sp-hero-cta,.sp-chips{justify-content:center}
.sp-hero-art > svg{width:min(72%,300px)}
.sp-cols{grid-template-columns:1fr}
.sp-features{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.sp-feature{flex-direction:column;align-items:center;text-align:center}
.sp-tool-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
.sp-medify{grid-template-columns:1fr;justify-items:center;text-align:center;gap:18px}
.sp-medify .cb{justify-self:center}
.sp-medify p{margin-left:auto;margin-right:auto}
}
@media(max-width:768px){
.sp-subnav{top:79px}
.sp [id]{scroll-margin-top:144px}
.sp-sec{padding:62px 20px}
.sp-head{margin-bottom:34px}
.sp-scroll-cue{display:none}
.sp-eyebrow{font-size:.62rem;letter-spacing:.8px;padding:6px 13px}
.sp-timeline{max-width:100%}
.sp-tl-track{left:21px}
.sp-step{grid-template-columns:44px minmax(0,1fr);gap:14px}
.sp-step-dot{width:44px;height:44px;font-size:.92rem}
.sp-step-card{padding:18px 18px}
.sp-step-card p{font-size:.9rem}
.sp-cta{width:calc(100% - 40px);padding:50px 22px}
.sp-mock-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.sp-orb-a{width:230px;height:230px}
.sp-ring{width:280px;height:280px;left:-120px}
}
@media(max-width:640px){
.sp-features{grid-template-columns:1fr;max-width:380px;margin:0 auto}
.sp-feature{flex-direction:row;align-items:flex-start;text-align:left}
.sp-price-grid{grid-template-columns:1fr;max-width:420px}
.sp-res-grid{grid-template-columns:1fr;max-width:420px}
.sp-tutor-grid{grid-template-columns:1fr;max-width:440px}
.sp-dl{width:100%;justify-content:center}
.sp-hero h1{font-size:clamp(1.95rem,9vw,2.45rem)}
.sp-hero-cta .cb{padding-left:22px;padding-right:22px}
}
@media(max-width:420px){
.sp-chips li{font-size:.76rem;padding:7px 11px}
.sp-mock-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
}

/* Stack tutor cards (photo banner on top) on narrow phones */
@media(max-width:480px){
.sp-tutor{flex-direction:column}
.sp-tutor-photo-panel{flex:0 0 300px;width:100%;align-self:auto}
.sp-tutor-photo-panel img{object-position:50% 18%}
.sp-tutor-photo-panel::before{top:auto;left:0;right:0;bottom:0;width:auto;height:3px;background:linear-gradient(90deg,var(--teal),var(--acc2))}
.sp-tutor-photo-panel::after{background:linear-gradient(180deg,transparent 62%,rgba(12,40,69,.15))}
.sp-tutor-body{padding:20px 20px 22px}
}

/* ---------- Reduced motion ---------- */
@media(prefers-reduced-motion:reduce){
.sp *,.sp *::before,.sp *::after{animation:none!important;transition:none!important}
.sp-ready [data-reveal],.sp-ready [data-stagger]>*{opacity:1!important;transform:none!important}
.sp-tl-fill{height:100%!important}
.sp-step .sp-step-dot{background:linear-gradient(135deg,var(--teal),var(--acc2));border-color:transparent;color:var(--w)}
}
