@import url('https://fonts.googleapis.com/css2?family=Atkinson+Hyperlegible:wght@400;700&family=Nunito:wght@400;600;700;800&family=Sniglet:wght@400;800&display=swap');

:root{
  /* Brand palette */
  --amal-purple:#8A69E8; --amal-purple-2:#8A69E8;
  --amal-blue:#5281bf;   --amal-blue-2:#569BAF;
  --page-bg:#ffffff; --surface:#ffffff;
  --ink:#52627a; --ink-strong:#1a1730; --line:#e9e6f5;
  --soft-blue:#e7f6fb; --soft-purple:#f1ebfe;
  --cta-from:#f1ebfe; --cta-to:#e7f6fb;
  --header-bg:rgba(255,255,255,.94);
  --font-brand:"Sniglet", cursive;
  --font-body:"Sniglet","Atkinson Hyperlegible","Nunito",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-head:"Baloo 2","Nunito","Atkinson Hyperlegible",system-ui,sans-serif;
  --reading-spacing:0.01em;
  --reading-line:1.65;
  --header-h:74px;
}

/* Font strategy: Baloo 2 is used for headings, buttons and menus.
   Sniglet is used for normal body text and AMALearning playful brand text. */
h1,h2,h3,.eyebrow,.quiz-score-big{font-family:var(--font-head);font-weight:800;letter-spacing:.005em}
.amal-wordmark,.brand-playful,.sniglet-canva-style{font-family:var(--font-brand);font-weight:400;letter-spacing:.01em;line-height:1.15}

/* ---- Reading themes (set on <html>) ---- */
html.bg-cream{--page-bg:#f5eede;--surface:#fffdf6;--ink:#4c4636;--ink-strong:#2d2a20;--line:#e9dfc9;--soft-blue:#eef2e3;--soft-purple:#f3ecdd;--cta-from:#f3ecdd;--cta-to:#eef2e3;--header-bg:rgba(255,253,246,.92)}
html.bg-blue{--page-bg:#e9f1fb;--surface:#ffffff;--ink:#41506a;--ink-strong:#0f223f;--line:#d7e2f2;--soft-blue:#dcebff;--soft-purple:#e7e0ff;--cta-from:#e7e0ff;--cta-to:#dcebff;--header-bg:rgba(255,255,255,.92)}
html.bg-dark{--page-bg:#0e1626;--surface:#19233a;--ink:#bcc8dc;--ink-strong:#ffffff;--line:#283450;--soft-blue:#1d2b46;--soft-purple:#241f3c;--cta-from:#241f3c;--cta-to:#1d2b46;--header-bg:rgba(14,22,38,.92)}

/* ---- Font modes ---- */
html.font-readable{--font-body:"Atkinson Hyperlegible","Nunito",-apple-system,Arial,sans-serif;--reading-spacing:.02em;--reading-line:1.8}
html.font-dyslexic{--font-body:"OpenDyslexic","Atkinson Hyperlegible","Nunito",Arial,sans-serif;--reading-spacing:.03em;--reading-line:1.85}
@font-face{font-family:"OpenDyslexic";src:url("https://cdn.jsdelivr.net/npm/@fontsource/opendyslexic@5.0.0/files/opendyslexic-latin-400-normal.woff2") format("woff2");font-weight:400;font-display:swap}
@font-face{font-family:"OpenDyslexic";src:url("https://cdn.jsdelivr.net/npm/@fontsource/opendyslexic@5.0.0/files/opendyslexic-latin-700-normal.woff2") format("woff2");font-weight:700;font-display:swap}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
html.text-large{font-size:112.5%}
body{margin:0;font-family:var(--font-body);font-weight:400;color:var(--ink);background:var(--page-bg);line-height:var(--reading-line);letter-spacing:var(--reading-spacing);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:geometricPrecision;transition:background .2s,color .2s}
a{color:inherit}
img{max-width:100%}
.amal-skip{position:absolute;left:-9999px;top:0;background:var(--amal-purple);color:#fff;padding:12px 18px;border-radius:0 0 10px 0;z-index:2000;font-weight:700;text-decoration:none}
.amal-skip:focus{left:0}
:focus-visible{outline:3px solid var(--amal-purple);outline-offset:2px;border-radius:4px}
.amal-container{width:min(1160px,calc(100% - 32px));margin:0 auto}

.amal-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:10px;padding:12px 20px;font-size:14px;font-weight:700;text-decoration:none;transition:.2s;border:1px solid transparent;cursor:pointer;font-family:var(--font-head)}
.amal-btn-primary{background:var(--amal-purple);color:#fff;box-shadow:0 10px 24px rgba(165,126,246,.30)}
.amal-btn-primary:hover{background:var(--amal-purple-2)}
.amal-btn-secondary{background:var(--surface);color:var(--amal-blue);border-color:var(--line)}
.amal-btn-secondary:hover{border-color:var(--amal-purple)}

.amal-header{position:sticky;top:0;z-index:1000;background:var(--header-bg);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--line)}
.amal-nav{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:16px}
.amal-logo{display:inline-flex;align-items:center;gap:10px;color:var(--ink-strong);text-decoration:none}
.amal-logo-img{width:42px;height:42px;display:block}
.amal-footer-logo .amal-logo-img,.amal-footer-logo img{width:40px;height:40px}
.amal-wordmark{font-family:var(--font-brand);font-weight:400;font-size:24px;letter-spacing:.02em;line-height:1}
.amal-logo .amal-wordmark{color:var(--ink-strong)}
.amal-nav-links{display:flex;align-items:center;gap:24px;list-style:none;margin:0;padding:0}
.amal-nav-links a{text-decoration:none;color:var(--ink-strong);font-weight:600;font-size:15px;font-family:var(--font-head)}
.amal-nav-links a:hover{color:var(--amal-purple)}
.amal-nav-actions{display:flex;align-items:center;gap:10px}
.amal-nav-login{font-weight:700;color:var(--ink-strong);text-decoration:none;font-size:15px;font-family:var(--font-head)}
.amal-burger{display:none;width:44px;height:44px;border:1px solid var(--line);background:var(--surface);border-radius:10px;cursor:pointer;align-items:center;justify-content:center;padding:0}
.amal-burger span,.amal-burger span::before,.amal-burger span::after{content:"";display:block;width:20px;height:2px;background:var(--ink-strong);border-radius:2px;position:relative}
.amal-burger span::before{position:absolute;top:-6px}.amal-burger span::after{position:absolute;top:6px}

/* Reading-settings control */
.a11y-wrap{position:relative}
.a11y-btn{width:44px;height:44px;border:1px solid var(--line);background:var(--surface);border-radius:10px;cursor:pointer;font-weight:800;font-size:15px;color:var(--ink-strong);font-family:var(--font-head)}
.a11y-btn:hover{border-color:var(--amal-purple);color:var(--amal-purple)}
.a11y-panel{position:absolute;right:0;top:calc(100% + 10px);background:var(--surface);border:1px solid var(--line);border-radius:14px;padding:16px 16px 6px;width:270px;box-shadow:0 18px 50px rgba(18,33,63,.16);display:none;z-index:1100}
.a11y-panel.open{display:block}
.a11y-panel h4{margin:0 0 12px;color:var(--ink-strong);font-size:15px}
.a11y-lbl{margin:0 0 6px;font-size:12px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.04em}
.a11y-row{display:flex;gap:6px;margin-bottom:14px;flex-wrap:wrap}
.a11y-opt{flex:1 1 auto;min-width:56px;border:1px solid var(--line);background:var(--surface);color:var(--ink-strong);border-radius:9px;padding:8px 6px;font-size:12px;font-weight:700;cursor:pointer;font-family:var(--font-head)}
.a11y-opt:hover{border-color:var(--amal-purple)}
.a11y-opt[aria-pressed="true"]{border-color:var(--amal-purple);background:var(--soft-purple);color:var(--amal-purple)}

.amal-crumbs{padding:18px 0 0;font-size:13px;color:var(--ink)}
.amal-crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:8px;margin:0;padding:0}
.amal-crumbs li{display:flex;gap:8px;align-items:center}
.amal-crumbs li+li::before{content:"›";color:var(--ink);opacity:.6}
.amal-crumbs a{text-decoration:none;color:var(--amal-blue);font-weight:600}
.amal-crumbs a:hover{text-decoration:underline}
.amal-crumbs span{color:var(--ink-strong);font-weight:700}

.amal-pagehead{padding:14px 0 34px}
.amal-pagehead .eyebrow{display:inline-flex;background:var(--soft-blue);color:var(--amal-blue);border-radius:999px;padding:6px 14px;font-size:13px;font-weight:700;margin-bottom:14px}
.amal-pagehead h1{margin:0 0 14px;color:var(--ink-strong);font-size:clamp(30px,3.4vw,44px);line-height:1.12;font-weight:800;letter-spacing:-.5px}
.amal-pagehead p{margin:0;max-width:680px;color:var(--ink);font-size:17px}

.amal-hero{background:var(--page-bg);padding:56px 0 60px;text-align:center}
.amal-hero h1{margin:0 0 18px;color:var(--ink-strong);font-size:clamp(34px,4vw,52px);line-height:1.1;font-weight:800;letter-spacing:-.5px}
.amal-hero h1 span{color:var(--amal-purple)}
.amal-hero p{margin:0 auto 26px;max-width:620px;font-size:18px;color:var(--ink)}
.amal-hero-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.amal-section{padding:56px 0}
.amal-section h2{color:var(--ink-strong);font-size:clamp(24px,2.4vw,32px);font-weight:800;margin:0 0 24px}

.amal-grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.amal-card{display:block;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px;text-decoration:none;box-shadow:0 10px 30px rgba(18,33,63,.05);transition:transform .2s,box-shadow .2s}
a.amal-card:hover{transform:translateY(-4px);box-shadow:0 18px 45px rgba(18,33,63,.09)}
.amal-card h3{margin:0 0 6px;color:var(--ink-strong);font-size:18px;font-weight:800}
.amal-card p{margin:0;color:var(--ink);font-size:14px}
.amal-card .meta{margin-top:12px;font-size:13px;color:var(--amal-blue);font-weight:700}
.amal-chip{display:inline-block;font-size:11px;font-weight:700;padding:3px 9px;border-radius:999px;margin-bottom:10px}
.chip-free{background:#dff6ec;color:#0e7a44}
.chip-pro{background:#f2edff;color:#5a3ff0}

.amal-sp{display:grid;grid-template-columns:1.6fr .9fr;gap:36px;align-items:start;padding-bottom:60px}
.amal-video{position:relative;width:100%;aspect-ratio:16/9;border-radius:16px;overflow:hidden;background:#0c1626;border:1px solid var(--line)}
.amal-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.amal-notes{margin-top:26px}
.amal-notes h2{font-size:22px;color:var(--ink-strong);margin:0 0 12px}
.amal-notes p{font-size:16px;margin:0 0 14px;color:var(--ink)}
html.text-large .amal-notes p{font-size:18px}
.amal-aside{position:sticky;top:calc(var(--header-h) + 16px);display:grid;gap:16px}
.amal-panel{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:22px;box-shadow:0 10px 30px rgba(18,33,63,.05)}
.amal-panel.locked{background:linear-gradient(135deg,var(--cta-from),var(--cta-to))}
.amal-panel h3{margin:0 0 8px;color:var(--ink-strong);font-size:17px;font-weight:800}
.amal-panel p{margin:0 0 16px;font-size:14px;color:var(--ink)}
.amal-panel .amal-btn{width:100%}
.amal-downloads{list-style:none;margin:0;padding:0;display:grid;gap:10px}
.amal-downloads a{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--ink-strong);font-weight:600;font-size:14px;border:1px solid var(--line);border-radius:10px;padding:12px 14px;font-family:var(--font-head)}
.amal-downloads a:hover{border-color:var(--amal-purple);color:var(--amal-purple)}

.amal-cta{background:linear-gradient(135deg,var(--cta-from),var(--cta-to));border-radius:24px;padding:46px;text-align:center;margin:20px 0 60px}
.amal-cta h2,.amal-cta h3{margin:0 0 10px;color:var(--ink-strong);font-weight:800}
.amal-cta h2{font-size:30px}
.amal-cta p{margin:0 auto 22px;max-width:560px;font-size:16px;color:var(--ink)}

.amal-tcard{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px;box-shadow:0 10px 30px rgba(18,33,63,.05)}
.amal-stars{color:#f5b50a;letter-spacing:2px;margin-bottom:10px}
.amal-tcard blockquote{margin:0 0 14px;color:var(--ink-strong);font-size:15px;font-weight:500}
.amal-tauthor strong{display:block;color:var(--ink-strong);font-size:14px}
.amal-tauthor span{color:var(--ink);font-size:13px}

.amal-footer{background:#071a33;padding:64px 0 28px;color:#c9d6ea}
.amal-footer-grid{display:grid;grid-template-columns:1.6fr repeat(4,1fr);gap:32px;align-items:start}
.amal-footer-logo{margin-bottom:16px;display:inline-flex;align-items:center;gap:10px;color:#fff;text-decoration:none}
.amal-footer-logo .amal-wordmark{color:#fff}
.amal-footer-banner{line-height:0}
.amal-footer-banner img{display:block;width:100%;height:auto}
.amal-footer-legal{color:#e6ddff;font-weight:700;margin:0 0 6px}
.amal-footer p{color:#c9d6ea;font-size:14px;margin:0}
.amal-socials{display:flex;gap:10px;margin-top:18px;flex-wrap:wrap}
.amal-socials a{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.08);display:inline-flex;align-items:center;justify-content:center;color:#fff;text-decoration:none;transition:background .18s}
.amal-socials a:hover{background:var(--amal-purple)}
.amal-footer h4{margin:0 0 14px;color:#fff;font-size:15px;font-weight:800}
.amal-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:9px}
.amal-footer-col a{color:#c9d6ea;text-decoration:none;font-size:14px;font-family:var(--font-head)}
.amal-footer-col a:hover{color:#fff}
.amal-footer-bottom{border-top:1px solid rgba(255,255,255,.14);margin-top:42px;padding-top:22px;font-size:13px;color:#c9d6ea}
.amal-footer-bottom p{margin:0 0 4px}

@media(max-width:1024px){.cols-4{grid-template-columns:repeat(2,1fr)}.cols-3{grid-template-columns:repeat(2,1fr)}.amal-sp{grid-template-columns:1fr}.amal-aside{position:static}.amal-footer-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:760px){.amal-nav-links{display:none}.amal-burger{display:inline-flex}.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}.amal-footer-grid{grid-template-columns:1fr}.amal-cta{padding:32px 22px}.a11y-panel{width:240px}}

/* ---- Explore mega-menu (AMAL look: header + tabs + subject cards) ---- */
.nav-mega{position:relative}
.nav-mega-btn{display:inline-flex;align-items:center;gap:6px;background:none;border:0;font-family:var(--font-head);font-weight:600;font-size:15px;color:var(--ink-strong);cursor:pointer;padding:0;font-family:var(--font-head)}
.nav-mega-btn:hover{color:var(--amal-purple)}
.nav-mega-btn svg{transition:transform .2s}
.nav-mega-btn[aria-expanded="true"] svg{transform:rotate(180deg)}
.nav-mega-panel{position:absolute;top:calc(100% + 16px);left:0;background:var(--surface);border:1px solid var(--line);border-radius:18px;box-shadow:0 26px 64px rgba(18,33,63,.18);width:430px;overflow:hidden;z-index:1100}
.nav-mega-head{background:linear-gradient(120deg,var(--amal-purple),var(--amal-blue));color:#fff;padding:16px 20px}
.nav-mega-head strong{display:block;font-size:16px}
.nav-mega-head span{font-size:12.5px;opacity:.9}
.nav-tabs{display:flex;gap:6px;padding:14px 16px 0;flex-wrap:wrap}
.nav-tab{border:1px solid var(--line);background:var(--surface);color:var(--ink-strong);font-family:var(--font-head);font-weight:700;font-size:13px;padding:8px 14px;border-radius:999px;cursor:pointer;font-family:var(--font-head)}
.nav-tab:hover{border-color:var(--amal-purple)}
.nav-tab.active{background:var(--amal-purple);border-color:var(--amal-purple);color:#fff}
.nav-tabpanel{display:none;padding:14px 16px 6px}
.nav-tabpanel.active{display:block}
.nav-subj-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.nav-subj-card{display:flex;flex-direction:column;gap:2px;text-decoration:none;border:1px solid var(--line);border-radius:12px;padding:12px 14px;color:var(--ink-strong);font-weight:700;font-size:14px;transition:border-color .15s,transform .15s;font-family:var(--font-head)}
.nav-subj-card small{font-weight:600;font-size:11.5px;color:var(--ink)}
.nav-subj-card:hover{border-color:var(--amal-purple);transform:translateY(-2px)}
.nav-subj-card.nav-subj-all{grid-column:1 / -1;background:var(--soft-purple);border-color:transparent;color:var(--amal-purple)}
.nav-subj-card.nav-subj-all small{color:var(--amal-purple);opacity:.8}
.nav-mega-foot{display:block;margin:6px 16px 16px;padding-top:12px;border-top:1px solid var(--line);font-size:13px;font-weight:700;color:var(--amal-blue);text-decoration:none;font-family:var(--font-head)}

/* ---- Home image carousel ---- */
.amal-show{position:relative;max-width:460px;margin:0 auto}
.amal-show-viewport{overflow:hidden;border-radius:18px;box-shadow:0 24px 60px rgba(18,33,63,.16);border:1px solid var(--line)}
.amal-show-track{display:flex;transition:transform .5s cubic-bezier(.25,.46,.45,.94)}
.amal-show-slide{flex:0 0 100%;margin:0}
.amal-show-slide img{display:block;width:100%;height:auto}
.amal-show-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--line);box-shadow:0 6px 20px rgba(18,33,63,.16);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-strong);z-index:5}
.amal-show-arrow:hover{background:var(--amal-purple);border-color:var(--amal-purple);color:#fff}
.amal-show-arrow.prev{left:-18px}
.amal-show-arrow.next{right:-18px}
.amal-show-dots{display:flex;justify-content:center;gap:8px;margin-top:16px}
.amal-show-dot{width:8px;height:8px;border-radius:4px;background:#d1d9e8;border:0;cursor:pointer;padding:0;transition:width .28s,background .28s}
.amal-show-dot.active{width:26px;background:var(--amal-purple)}

/* ---- Alternating feature rows ---- */
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center;padding:46px 0}
.feature-row.reverse .feature-text{order:2}
.feature-row.reverse .feature-media{order:1}
.feature-ico{width:64px;height:64px;border-radius:18px;display:flex;align-items:center;justify-content:center;margin-bottom:18px}
.feature-text h2{margin:0 0 12px;color:var(--ink-strong);font-size:clamp(24px,2.5vw,32px);font-weight:800;line-height:1.18}
.feature-text p{margin:0;color:var(--ink);font-size:17px;line-height:1.7;max-width:460px}
.feature-media{position:relative;aspect-ratio:4/3;border-radius:20px;border:1px solid var(--line);background:linear-gradient(135deg,var(--soft-purple),var(--soft-blue));display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;overflow:hidden}
.feature-media::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.45) 50%,transparent 70%);transform:translateX(-100%);animation:shimmer 2.8s infinite}
@keyframes shimmer{to{transform:translateX(100%)}}
@media (prefers-reduced-motion:reduce){.feature-media::after{animation:none}}
.feature-media .ph-ico{width:84px;height:84px;border-radius:22px;background:var(--surface);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(18,33,63,.1);z-index:1}
.feature-media .ph-label{font-size:12px;font-weight:700;color:var(--ink);text-transform:uppercase;letter-spacing:.06em;z-index:1}

@media(max-width:760px){
  .feature-row{grid-template-columns:1fr;gap:24px;padding:32px 0}
  .feature-row.reverse .feature-text{order:1}
  .feature-row.reverse .feature-media{order:2}
  .nav-mega-panel{width:auto}
  .nav-subj-grid{grid-template-columns:1fr}
  .amal-show-arrow.prev{left:4px}.amal-show-arrow.next{right:4px}
}

/* ---- Stats band ---- */
.amal-stats{background:var(--surface);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.amal-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center;padding:38px 0}
.amal-stat strong{display:block;color:var(--amal-purple);font-size:clamp(28px,3vw,36px);font-weight:800;line-height:1}
.amal-stat span{color:var(--ink);font-size:14px;font-weight:600;margin-top:8px;display:block}

/* ---- FAQ ---- */
.faq-list{max-width:820px;margin:0 auto;display:grid;gap:12px}
.faq-item{border:1px solid var(--line);border-radius:14px;background:var(--surface);overflow:hidden}
.faq-q{width:100%;text-align:left;background:none;border:0;cursor:pointer;padding:20px 22px;font-size:16px;font-weight:700;color:var(--ink-strong);display:flex;justify-content:space-between;gap:16px;font-family:var(--font-head)}
.faq-q::after{content:"+";font-size:22px;color:var(--amal-purple)}
.faq-item.open .faq-q::after{content:"\2013"}
.faq-a{display:none;padding:0 22px 20px;color:var(--ink);font-size:15px;line-height:1.7}
.faq-item.open .faq-a{display:block}

/* ---- Schools ---- */
.amal-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.amal-step{background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:24px}
.amal-step .num{width:34px;height:34px;border-radius:50%;background:var(--amal-purple);color:#fff;font-weight:800;display:flex;align-items:center;justify-content:center;margin-bottom:14px}
.amal-step h3{margin:0 0 8px;color:var(--ink-strong);font-size:16px}
.amal-step p{margin:0;color:var(--ink);font-size:14px}
.amal-price-band{display:grid;grid-template-columns:1fr 1fr;gap:18px;max-width:680px;margin:0 auto 10px}
.amal-price-box{background:var(--surface);border:2px solid var(--line);border-radius:18px;padding:28px;text-align:center}
.amal-price-box.lead{border-color:var(--amal-purple)}
.amal-price-box .amt{font-size:40px;font-weight:800;color:var(--ink-strong);line-height:1}
.amal-price-box .amt small{font-size:15px;font-weight:600;color:var(--ink)}
.amal-price-box h3{margin:0 0 10px;color:var(--ink-strong);font-size:18px}
.amal-price-box p{margin:8px 0 0;color:var(--ink);font-size:14px}

@media(max-width:1024px){.amal-steps{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){
  .amal-stats-grid{grid-template-columns:repeat(2,1fr)}
  .amal-steps{grid-template-columns:1fr}
  .amal-price-band{grid-template-columns:1fr}
  .amal-header.nav-open .amal-nav-links{display:flex;flex-direction:column;align-items:stretch;gap:0;position:absolute;top:var(--header-h);left:0;right:0;background:var(--surface);border-bottom:1px solid var(--line);box-shadow:0 20px 40px rgba(18,33,63,.12);padding:10px 16px 18px;max-height:82vh;overflow:auto}
  .amal-header.nav-open .amal-nav-links>li{width:100%}
  .amal-header.nav-open .amal-nav-links>li>a{display:block;padding:14px 6px}
  .nav-mega-panel{position:static;width:auto;box-shadow:none;border:0;padding:8px 0;border-radius:0}
  .nav-mega-btn{padding:14px 6px;width:100%;justify-content:space-between}
}

/* ---- Two-column hero (carousel left, copy right) ---- */
body{overflow-x:hidden}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-copy{text-align:left}
.hero-copy h1{margin:0 0 18px}
.hero-copy p{margin:0 0 26px;max-width:520px}
.hero-copy .amal-hero-actions{justify-content:flex-start}
.hero-media{display:flex;justify-content:center}
.hero-media .amal-show{margin:0;width:100%;max-width:480px}
@media(max-width:880px){
  .hero-grid{grid-template-columns:1fr;gap:30px}
  .hero-copy{order:1;text-align:center}
  .hero-media{order:2}
  .hero-copy p{margin-left:auto;margin-right:auto}
  .hero-copy .amal-hero-actions{justify-content:center}
}

/* ---- Practice section (quiz + flashcards) ---- */
.amal-practice{background:linear-gradient(180deg,var(--soft-purple),transparent 72%);padding:60px 0;margin:18px 0}
.amal-practice .amal-pagehead h2{font-size:clamp(24px,2.6vw,32px)}
.practice-tabs-wrap{max-width:760px;margin:0 auto}
.practice-tabs{display:flex;width:-moz-fit-content;width:fit-content;margin:0 auto 20px;gap:6px;background:var(--surface);border:1px solid var(--line);border-radius:999px;padding:5px}
.ptab{border:0;background:none;font:inherit;font-family:var(--font-head);font-weight:700;font-size:15px;color:var(--ink);padding:9px 22px;border-radius:999px;cursor:pointer;transition:.15s}
.ptab:hover{color:var(--amal-purple)}
.ptab.active{background:linear-gradient(120deg,var(--amal-purple),var(--amal-blue));color:#fff}
.ptab-panel{display:none}
.ptab-panel.active{display:block;animation:ptabIn .25s ease}
@keyframes ptabIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.practice-col{min-width:0}
.practice-h{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--amal-purple);margin:0 0 14px}

.quiz-widget,.flash-widget{background:var(--surface);border:1px solid var(--line);border-radius:20px;box-shadow:0 18px 50px rgba(18,33,63,.10)}

/* Quiz */
.quiz-card{padding:30px}
.quiz-top{margin-bottom:22px}
.quiz-bar{height:8px;border-radius:6px;background:var(--line);overflow:hidden}
.quiz-bar span{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--amal-purple),var(--amal-blue));transition:width .35s}
.quiz-meta{display:flex;justify-content:space-between;align-items:center;margin-top:11px;font-size:13px;font-weight:700;color:var(--ink)}
.quiz-score{color:var(--amal-purple)}
.quiz-stem{font-size:19px;font-weight:700;color:var(--ink-strong);line-height:1.45;margin-bottom:20px}
.quiz-options{display:grid;gap:11px}
.quiz-opt{display:block;width:100%;text-align:left;background:var(--surface);border:1.5px solid var(--line);border-radius:13px;padding:15px 18px;font-family:var(--font-head);font-weight:600;font-size:15.5px;color:var(--ink-strong);cursor:pointer;transition:border-color .15s,background .15s,transform .08s;font-family:var(--font-head)}
.quiz-opt:hover:not(:disabled){border-color:var(--amal-purple);background:var(--soft-purple)}
.quiz-opt:active:not(:disabled){transform:scale(.99)}
.quiz-opt:disabled{cursor:default}
.quiz-opt.correct{border-color:#18a058;background:#e8f7ee;color:#136c3c;font-weight:700}
.quiz-opt.wrong{border-color:#e0607a;background:#fdecf0;color:#a32742}
.quiz-feedback{margin-top:18px;padding-top:18px;border-top:1px solid var(--line);font-size:15px;color:var(--ink-strong)}
.quiz-feedback .ok{color:#18a058;font-size:16px}
.quiz-feedback .no{color:#e0607a;font-size:16px}
.quiz-exp{margin-top:10px;font-size:14px;color:var(--ink);background:var(--soft-blue);border-radius:10px;padding:12px 14px;line-height:1.55}
.quiz-next{display:block;width:100%;margin-top:18px}
.quiz-result{text-align:center;padding:22px 6px}
.quiz-score-big{font-size:46px;font-weight:800;color:var(--amal-purple);line-height:1;margin-bottom:10px}
.quiz-result p{max-width:430px;margin:0 auto 18px}
.quiz-result-actions{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* Flashcards */
.flash-wrap{padding:30px}
.flash-card{perspective:1300px;cursor:pointer;height:264px}
.flash-inner{position:relative;width:100%;height:100%;transition:transform .55s cubic-bezier(.2,.7,.2,1);transform-style:preserve-3d}
.flash-card.flipped .flash-inner{transform:rotateY(180deg)}
.flash-face{position:absolute;inset:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;display:flex;align-items:center;justify-content:center;text-align:center;padding:30px 28px;border-radius:16px;font-size:18px;line-height:1.5}
.flash-face::before{position:absolute;top:15px;left:20px;font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;opacity:.85}
.flash-front{background:linear-gradient(135deg,var(--amal-purple),var(--amal-blue));color:#fff;font-weight:600}
.flash-front::before{content:"Question";color:#fff}
.flash-back{background:var(--soft-blue);color:var(--ink-strong);transform:rotateY(180deg);font-weight:600}
.flash-back::before{content:"Answer";color:var(--amal-blue)}
.flash-tip{text-align:center;font-size:12px;color:var(--ink);margin-top:12px;opacity:.85}
.flash-controls{display:flex;align-items:center;justify-content:center;gap:22px;margin-top:16px}
.flash-nav{width:44px;height:44px;border-radius:50%;border:1px solid var(--line);background:var(--surface);font-size:22px;line-height:1;cursor:pointer;color:var(--ink-strong);display:flex;align-items:center;justify-content:center}
.flash-nav:hover{background:var(--amal-purple);border-color:var(--amal-purple);color:#fff}
.flash-count{font-weight:800;color:var(--ink-strong);font-size:15px;min-width:64px;text-align:center}
.flash-actions{display:flex;gap:10px;justify-content:center;margin-top:16px}

/* ---- Brand/practice mobile polish ---- */
@media(max-width:560px){
  .amal-wordmark{font-size:20px}
  .amal-logo-img{width:36px;height:36px}
}
@media(max-width:520px){
  .quiz-card,.flash-wrap{padding:20px}
  .flash-card{height:240px}
  .flash-face{font-size:16px;padding:24px 20px}
  .quiz-stem{font-size:17px}
  .practice-tabs{display:flex;width:100%}
  .ptab{flex:1;text-align:center;padding:10px 8px}
}

/* ---- Feature icon badges ---- */
.icon-purple{background:var(--soft-purple)}
.icon-blue{background:var(--soft-blue)}
.icon-green{background:#e8f7ee}
.icon-orange{background:#fbf0e4}
.icon-pink{background:#fdecf0}

/* ---- Logo colour fix + feature GIFs ---- */
.amal-logo-img{filter:invert(1)}            /* header logo file renders white; invert -> dark on white bg */
.feature-media{background:#fff;overflow:hidden}
.feature-media::after{display:none}         /* drop shimmer now that real GIFs load */
.feature-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:10px;display:block}

/* === Sniglet only at normal weight: all BOLD text uses the clean head font === */
strong, b,
.quiz-stem, .quiz-progress, .quiz-meta, .quiz-score, .quiz-feedback, .quiz-result,
.flash-face, .flash-count,
.amal-stat strong, .amal-tauthor strong, .amal-chip, .amal-card .meta,
.amal-crumbs span, .amal-footer-col h4, .amal-footer-legal{font-family:var(--font-head)}

/* Centre the practice section header */
.amal-practice .amal-pagehead{text-align:center}
.amal-practice .amal-pagehead .eyebrow{margin-left:auto;margin-right:auto}
.amal-practice .amal-pagehead p{margin-left:auto;margin-right:auto;max-width:560px}

/* ---- Testimonial carousel ---- */
.tcarousel{position:relative}
.tcar-track{display:flex;align-items:stretch;gap:20px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding:6px 2px 14px;scrollbar-width:none;-ms-overflow-style:none}
.tcar-track::-webkit-scrollbar{display:none}
.tcar-track .amal-tcard{flex:0 0 330px;scroll-snap-align:start;margin:0}
@media(max-width:560px){.tcar-track .amal-tcard{flex-basis:85%}}
.tcar-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:var(--surface);border:1px solid var(--line);box-shadow:0 6px 20px rgba(18,33,63,.14);cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink-strong);z-index:5}
.tcar-arrow:hover{background:var(--amal-purple);border-color:var(--amal-purple);color:#fff}
.tcar-arrow.prev{left:-18px}
.tcar-arrow.next{right:-18px}
@media(max-width:680px){.tcar-arrow{display:none}}
