/* ===========================================================
   LearnarooHub — 2026 theme matched to the homepage hero
   Royal purple · grid texture · sunny yellow · coral CTA
   =========================================================== */
@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Nunito:ital,wght@0,400;0,600;0,700;0,800;1,600&display=swap');

:root{
  /* Brand purple (sampled from hero) */
  --brand:#6D28D9; --brand-deep:#43159E; --brand-bright:#8B43E8; --grape:#9D34D6;
  --purple-night:#2C0E63;     /* footer / deep surfaces */

  /* Accents */
  --yellow:#FFD23F; --yellow-deep:#E0A700; --yellow-ink:#5b4500;
  --coral:#FF3D5A; --coral-deep:#D11E45;
  --mint:#28C76F;

  /* Key-stage journey colours */
  --eyfs:#28C76F;  --eyfs-soft:#DDF8EA;
  --ks1:#3DA5F4;   --ks1-soft:#DCEEFF;
  --ks2:#FF9F1C;   --ks2-soft:#FFEFD6;
  --ks3:#FF5D7D;   --ks3-soft:#FFE1E9;
  --gcse:#B57BFF;  --gcse-soft:#EEE3FF;

  /* Neutrals — lilac-tinted, never pure black/white */
  --ink:#2A2150; --ink-2:#5C5488; --ink-3:#938BBA;
  --paper:#F6F2FF; --card:#FFFFFF; --line:#E7E0F7; --cream:#EFE9FF;

  --r-sm:12px; --r-md:18px; --r-lg:28px; --r-xl:40px; --r-pill:999px;
  --shadow-sm:0 2px 8px rgba(58,30,120,.08);
  --shadow:0 12px 32px rgba(58,30,120,.14);
  --shadow-lg:0 26px 60px rgba(40,14,99,.30);
  --maxw:1180px; --space:clamp(16px,4vw,28px);

  /* reusable grid texture + purple wash for brand bands */
  --grid:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),
         linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);
  --purplewash:
     radial-gradient(circle at 10% 16%, rgba(255,165,60,.30) 0, transparent 30%),
     radial-gradient(circle at 50% 60%, rgba(255,90,120,.22) 0, transparent 34%),
     radial-gradient(circle at 88% 14%, rgba(181,123,255,.30) 0, transparent 32%),
     linear-gradient(165deg,#5A1AC4 0%, #7A28D6 45%, #8E2FD0 70%, #5D1CC6 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0; font-family:'Nunito',system-ui,sans-serif; color:var(--ink); background:var(--paper);
  font-size:17px; line-height:1.65; -webkit-font-smoothing:antialiased;}
h1,h2,h3,h4,.display{font-family:'Baloo 2',cursive,sans-serif; line-height:1.12; margin:0 0 .4em; color:var(--ink); letter-spacing:-.01em}
h1{font-size:clamp(2.2rem,5vw,3.7rem); font-weight:800}
h2{font-size:clamp(1.7rem,3.5vw,2.5rem); font-weight:700}
h3{font-size:1.25rem; font-weight:700}
p{margin:0 0 1rem}
a{color:var(--brand); text-decoration:none}
img{max-width:100%}
.container{max-width:var(--maxw); margin:0 auto; padding:0 var(--space)}
.section{padding:clamp(48px,8vw,90px) 0}
.center{text-align:center}
.muted{color:var(--ink-2)}
.eyebrow{display:inline-flex; align-items:center; gap:.5rem; font-weight:800; font-size:.8rem;
  text-transform:uppercase; letter-spacing:.08em; color:var(--brand); background:#fff;
  border:1px solid var(--line); padding:.4rem .9rem; border-radius:var(--r-pill); box-shadow:var(--shadow-sm)}

/* ---------- Buttons ---------- */
.btn{display:inline-flex; align-items:center; gap:.55rem; font-family:'Baloo 2',sans-serif; font-weight:700;
  font-size:1.04rem; border:none; cursor:pointer; padding:.9rem 1.6rem; border-radius:var(--r-pill);
  transition:transform .12s ease, box-shadow .2s ease; text-decoration:none; min-height:50px}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--coral); color:#fff; box-shadow:0 6px 0 var(--coral-deep)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 8px 0 var(--coral-deep)}
.btn-sun{background:var(--yellow); color:var(--yellow-ink); box-shadow:0 6px 0 var(--yellow-deep)}
.btn-sun:hover{transform:translateY(-2px); box-shadow:0 8px 0 var(--yellow-deep)}
.btn-purple{background:var(--brand); color:#fff; box-shadow:0 6px 0 var(--brand-deep)}
.btn-purple:hover{transform:translateY(-2px); box-shadow:0 8px 0 var(--brand-deep)}
.btn-ghost{background:#fff; color:var(--brand); border:2px solid var(--line); box-shadow:var(--shadow-sm)}
.btn-ghost:hover{border-color:var(--brand)}
.btn-on-dark{background:rgba(255,255,255,.12); color:#fff; border:2px solid rgba(255,255,255,.55)}
.btn-on-dark:hover{background:rgba(255,255,255,.2)}
.btn-sm{padding:.55rem 1rem; font-size:.92rem; min-height:42px}

/* ---------- Top marquee (pink → orange, like hero) ---------- */
.topbar{background:linear-gradient(90deg,#FF4D8D,#FF7A3D); color:#fff; font-weight:800; font-size:.85rem; padding:.55rem; overflow:hidden; white-space:nowrap}
.topbar .track{display:inline-block; animation:scroll 32s linear infinite}
.topbar span{margin:0 1.6rem}
@keyframes scroll{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Header (purple, matches hero) ---------- */
/* (header.site bar styles consolidated into the MODERN HEADER block below) */
.nav{display:flex; align-items:center; gap:1.2rem; padding:.7rem var(--space); max-width:var(--maxw); margin:0 auto}
.logo{display:flex; align-items:center; gap:.55rem; font-family:'Baloo 2',sans-serif; font-weight:800; font-size:1.4rem; color:#fff}
.logo .hub{color:var(--yellow)}
.logo .mark{width:40px;height:40px;border-radius:12px;background:linear-gradient(135deg,var(--yellow),#FF8A3D); display:grid;place-items:center;font-size:1.35rem;box-shadow:var(--shadow-sm)}
.nav .links{display:flex; gap:.2rem; margin-left:.6rem}
.nav .links a{color:#fff; font-weight:700; padding:.5rem .8rem; border-radius:var(--r-pill); font-size:.97rem; opacity:.92}
.nav .links a:hover{background:rgba(255,255,255,.16); opacity:1}
.nav .spacer{flex:1}
.nav .auth{display:flex; gap:.6rem; align-items:center}
.nav .auth a.login{font-weight:700; color:#fff; padding:.5rem .8rem; opacity:.92}
@media(max-width:900px){ .nav .links{display:none} }

/* ---------- Cards & layout ---------- */
.card{background:var(--card); border:1px solid var(--line); border-radius:var(--r-lg); padding:1.4rem; box-shadow:var(--shadow-sm); transition:transform .15s, box-shadow .2s}
.card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.grid{display:grid; gap:1.2rem}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-5{grid-template-columns:repeat(5,1fr)}
@media(max-width:900px){ .g-3,.g-4,.g-5{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .g-2,.g-3,.g-4,.g-5{grid-template-columns:1fr} }

.pill{display:inline-block; padding:.3rem .8rem; border-radius:var(--r-pill); font-weight:800; font-size:.78rem}
.badge-eyfs{background:var(--eyfs-soft); color:#0f8f4d}
.badge-ks1{background:var(--ks1-soft); color:#1f6fd6}
.badge-ks2{background:var(--ks2-soft); color:#b06a00}
.badge-ks3{background:var(--ks3-soft); color:#c43c5e}
.badge-gcse{background:var(--gcse-soft); color:#7a2fd0}

.ks-eyfs{--c:var(--eyfs);--cs:var(--eyfs-soft)}
.ks-ks1{--c:var(--ks1);--cs:var(--ks1-soft)}
.ks-ks2{--c:var(--ks2);--cs:var(--ks2-soft)}
.ks-ks3{--c:var(--ks3);--cs:var(--ks3-soft)}
.ks-gcse{--c:var(--gcse);--cs:var(--gcse-soft)}

/* ---------- Brand band (purple hero strip reused on inner pages) ---------- */
.brandband{position:relative; overflow:hidden; background:var(--purplewash); color:#fff; border-bottom:4px solid var(--yellow)}
.brandband:before{content:""; position:absolute; inset:0; background-image:var(--grid); background-size:38px 38px; opacity:.9; pointer-events:none}
.brandband .container{position:relative; z-index:1}
.brandband h1,.brandband h2,.brandband h3{color:#fff}
.brandband .muted{color:#E7DEFF}
.brandband a{color:#fff}
.brandband .crumbs{color:#D9CCFF}
.brandband .crumbs a{color:#fff;opacity:.85}

/* ---------- Footer (deep purple) ---------- */
footer.site{background:var(--purple-night); color:#cdc4ee; padding:56px 0 28px; margin-top:40px}
footer.site h4{color:#fff; font-size:1rem; margin-bottom:.8rem}
footer.site a{color:#cdc4ee; display:block; padding:.18rem 0; font-weight:600; font-size:.92rem}
footer.site a:hover{color:var(--yellow)}
footer .fgrid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:2rem}
@media(max-width:780px){ footer .fgrid{grid-template-columns:1fr 1fr} }
.foot-bottom{border-top:1px solid rgba(255,255,255,.12); margin-top:28px; padding-top:18px; font-size:.85rem; color:#9a8fc8; display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem}

/* ---------- Bits ---------- */
.bar{height:12px; border-radius:99px; background:var(--line); overflow:hidden}
.bar>span{display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,var(--brand-bright),var(--grape))}
.chip{display:inline-flex;align-items:center;gap:.4rem; color:var(--ink); background:#fff; border:1px solid var(--line); border-radius:var(--r-pill); padding:.35rem .8rem; font-weight:700; font-size:.85rem; box-shadow:var(--shadow-sm)}


.flex{display:flex} .ac{align-items:center} .jc{justify-content:center} .jb{justify-content:space-between}
.gap{gap:1rem} .gap-sm{gap:.5rem} .wrap{flex-wrap:wrap}
.mt{margin-top:1rem}.mt2{margin-top:2rem}.mb0{margin-bottom:0}
.soft{background:var(--cream)}
.tick{color:var(--mint); font-weight:800}

/* ===========================================================
   ADVANCED COMPONENTS (v2) — richer, contentful category pages
   =========================================================== */

/* section heading block */
.shead{max-width:64ch}
.shead.center{margin-left:auto;margin-right:auto;text-align:center}
.shead p{color:var(--ink-2);font-size:1.05rem}

/* decorative soft blobs behind sections */
.has-blob{position:relative;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(60px);opacity:.5;z-index:0;pointer-events:none}
.has-blob>.container{position:relative;z-index:1}

/* in-page sticky sub-nav for long category pages */
.subnav{position:sticky;top:64px;z-index:40;background:rgba(246,242,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.subnav .in{display:flex;gap:.4rem;overflow-x:auto;max-width:var(--maxw);margin:0 auto;padding:.7rem var(--space)}
.subnav a{white-space:nowrap;font-weight:800;font-size:.9rem;color:var(--ink-2);padding:.45rem .9rem;border-radius:var(--r-pill)}
.subnav a:hover{background:#fff;color:var(--brand);box-shadow:var(--shadow-sm)}

/* hero stat ribbon */
.statribbon{display:grid;grid-template-columns:repeat(4,1fr);gap:0;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:var(--r-lg);overflow:hidden;backdrop-filter:blur(6px)}
.statribbon>div{padding:1rem 1.1rem;border-right:1px solid rgba(255,255,255,.18)}
.statribbon>div:last-child{border-right:0}
.statribbon .n{font-family:'Baloo 2';font-weight:800;font-size:1.6rem;line-height:1;color:#fff}
.statribbon .l{font-size:.82rem;color:#E7DEFF;font-weight:700}
@media(max-width:680px){.statribbon{grid-template-columns:repeat(2,1fr)}.statribbon>div:nth-child(2){border-right:0}}

/* rich subject card */
.subjx{position:relative;display:flex;flex-direction:column;border-radius:var(--r-lg);overflow:hidden;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);transition:.18s}
.subjx:hover{transform:translateY(-6px);box-shadow:var(--shadow-lg);border-color:transparent}
.subjx .head{display:flex;align-items:center;gap:.8rem;padding:1.1rem 1.2rem;border-top:5px solid var(--c);background:linear-gradient(180deg,var(--cs),#fff)}
.subjx .emoji{width:52px;height:52px;border-radius:15px;display:grid;place-items:center;font-size:1.7rem;background:#fff;box-shadow:var(--shadow-sm);flex:none}
.subjx .body{padding:0 1.2rem 1.1rem}
.subjx .tlist{list-style:none;padding:0;margin:.4rem 0 .8rem;font-size:.9rem}
.subjx .tlist li{padding:.18rem 0 .18rem 1.3rem;position:relative;color:var(--ink-2);font-weight:600}
.subjx .tlist li:before{content:'›';position:absolute;left:.2rem;color:var(--c);font-weight:800}
.subjx .foot{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding:.8rem 1.2rem;border-top:1px solid var(--line);font-weight:800;font-size:.85rem;color:var(--ink-2)}
.subjx .go{color:var(--brand)}

/* help / guidance card */
.help{position:relative;border-radius:var(--r-lg);padding:1.5rem;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm);border-left:6px solid var(--c,var(--brand))}
.help .hic{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:var(--cs,var(--brand-soft));margin-bottom:.6rem}
.help h3{margin-bottom:.3rem}
.help ul{list-style:none;padding:0;margin:.5rem 0 0}
.help li{padding:.3rem 0 .3rem 1.6rem;position:relative;font-weight:600;color:var(--ink-2);font-size:.95rem}
.help li:before{content:'💡';position:absolute;left:0;font-size:.9rem}

/* assessment callout */
.assess{display:flex;gap:1rem;align-items:flex-start;border-radius:var(--r-lg);padding:1.2rem;background:linear-gradient(135deg,var(--cs),#fff);border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.assess .ic{width:50px;height:50px;border-radius:14px;display:grid;place-items:center;font-size:1.5rem;background:#fff;box-shadow:var(--shadow-sm);flex:none}
.assess .tag{display:inline-block;font-weight:800;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;color:var(--brand);background:var(--brand-soft,#EDE7FF);padding:.15rem .6rem;border-radius:99px;margin-top:.4rem}

/* coverage checklist */
.cover{columns:2;column-gap:2rem}
@media(max-width:640px){.cover{columns:1}}
.cover li{list-style:none;padding:.4rem 0 .4rem 1.8rem;position:relative;font-weight:600;break-inside:avoid;border-bottom:1px dashed var(--line)}
.cover li:before{content:'✓';position:absolute;left:0;color:var(--mint);font-weight:800;background:var(--eyfs-soft);width:1.2rem;height:1.2rem;border-radius:50%;display:grid;place-items:center;font-size:.7rem}

/* SEO popular-search cloud */
.searchcloud{display:flex;flex-wrap:wrap;gap:.6rem}
.searchcloud a{font-weight:700;font-size:.92rem;padding:.5rem 1rem;border-radius:var(--r-pill);background:#fff;border:1px solid var(--line);color:var(--ink-2);box-shadow:var(--shadow-sm)}
.searchcloud a:hover{color:var(--brand);border-color:var(--brand)}
.searchcloud a b{color:var(--brand)}

/* FAQ accordion */
.faq details{background:#fff;border:1px solid var(--line);border-radius:var(--r-md);margin-bottom:.7rem;box-shadow:var(--shadow-sm);overflow:hidden}
.faq summary{cursor:pointer;list-style:none;padding:1rem 1.2rem;font-family:'Baloo 2';font-weight:700;font-size:1.05rem;display:flex;justify-content:space-between;align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary:after{content:'+';font-size:1.4rem;color:var(--brand);transition:.2s}
.faq details[open] summary:after{transform:rotate(45deg)}
.faq .ans{padding:0 1.2rem 1.1rem;color:var(--ink-2)}

/* testimonial */
.quote{border-radius:var(--r-lg);padding:1.4rem;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.quote .stars{color:var(--yellow);font-size:1.1rem}
.quote .who{display:flex;align-items:center;gap:.6rem;margin-top:.8rem;font-weight:800;font-size:.9rem}
.quote .av{width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--brand-soft,#EDE7FF)}

/* related stage cards */
.relx{display:flex;align-items:center;gap:.8rem;border-radius:var(--r-md);padding:.9rem 1rem;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm);font-weight:800;transition:.15s;color:var(--ink)}
.relx:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.relx .d{width:14px;height:14px;border-radius:50%;background:var(--c);flex:none}

/* utility */
.divider{height:1px;background:var(--line);margin:0}
.kicker{font-weight:800;color:var(--brand);font-size:.85rem;text-transform:uppercase;letter-spacing:.06em}
.g-2-1{display:grid;grid-template-columns:1.6fr 1fr;gap:1.6rem}
@media(max-width:860px){.g-2-1{grid-template-columns:1fr}}
.prose p{color:var(--ink-2);font-size:1.05rem}
.prose h3{margin-top:1.4rem}

/* ===========================================================
   GAME-STUDIO POLISH (v3) — make sections POP
   =========================================================== */

/* glossy highlight on every button */
.btn{position:relative; overflow:hidden}
.btn:before{content:"";position:absolute;top:2px;left:8px;right:8px;height:42%;background:linear-gradient(rgba(255,255,255,.45),rgba(255,255,255,0));border-radius:99px;pointer-events:none}
.btn{font-weight:800}
.btn-lg{padding:1.05rem 2rem;font-size:1.15rem;min-height:58px}

/* highlighter swoosh behind headings */
.pop-h{position:relative;display:inline-block;z-index:0}
.pop-h:after{content:"";position:absolute;left:-.1em;right:-.1em;bottom:.06em;height:.34em;background:var(--yellow);opacity:.6;border-radius:99px;z-index:-1;transform:rotate(-1deg)}
.grad-text{background:linear-gradient(100deg,var(--brand),var(--grape),var(--coral));-webkit-background-clip:text;background-clip:text;color:transparent}

/* section panel (floating menu-style card) */
.panel{background:#fff;border-radius:var(--r-xl);box-shadow:var(--shadow);border:1px solid var(--line);padding:clamp(26px,4vw,52px);position:relative;overflow:hidden}
.panel.tint-eyfs{background:linear-gradient(180deg,var(--eyfs-soft),#fff)}
.panel.tint-ks1{background:linear-gradient(180deg,var(--ks1-soft),#fff)}
.panel.tint-ks2{background:linear-gradient(180deg,var(--ks2-soft),#fff)}
.panel.tint-gcse{background:linear-gradient(180deg,var(--gcse-soft),#fff)}

/* sticker card — coloured hard drop-shadow = instant pop */
.sticker{background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);padding:1.4rem;position:relative;
  box-shadow:7px 8px 0 -1px var(--cs,#EEE6FF), 0 16px 34px rgba(58,30,120,.12); transition:transform .16s, box-shadow .16s}
.sticker:hover{transform:translate(-2px,-3px) rotate(-.4deg); box-shadow:10px 12px 0 -1px var(--cs,#EEE6FF), 0 22px 44px rgba(58,30,120,.18)}
.sticker .ic-badge{width:60px;height:60px;border-radius:18px;display:grid;place-items:center;font-size:1.9rem;background:var(--cs,var(--cream));box-shadow:inset 0 -3px 0 rgba(0,0,0,.06);margin-bottom:.7rem}

/* corner ribbon */
.has-ribbon{position:relative}
.ribbon{position:absolute;top:14px;right:-4px;background:var(--coral);color:#fff;font-family:'Baloo 2';font-weight:800;font-size:.72rem;letter-spacing:.03em;padding:.32rem .8rem;border-radius:8px 2px 8px 8px;box-shadow:0 4px 0 var(--coral-deep);text-transform:uppercase;z-index:3}
.ribbon.green{background:var(--mint);box-shadow:0 4px 0 #0f8f4d}
.ribbon.yellow{background:var(--yellow);color:var(--yellow-ink);box-shadow:0 4px 0 var(--yellow-deep)}

/* glow */
.glow{box-shadow:0 18px 50px var(--glow,rgba(141,79,232,.45))}

/* 3D press tiles (key stages) */
.tile3d{border:none;border-radius:var(--r-lg);padding:1.1rem .8rem;text-align:center;font-family:'Baloo 2';font-weight:800;color:#fff;
  box-shadow:0 7px 0 var(--sh,rgba(0,0,0,.22)), 0 14px 26px rgba(58,30,120,.22); transition:transform .12s, box-shadow .12s; display:block}
.tile3d:hover{transform:translateY(-3px);box-shadow:0 10px 0 var(--sh,rgba(0,0,0,.22)),0 18px 32px rgba(58,30,120,.28)}
.tile3d:active{transform:translateY(4px);box-shadow:0 3px 0 var(--sh,rgba(0,0,0,.22))}
.tile3d small{display:block;font-weight:700;opacity:.9;font-size:.78rem}

/* achievement / XP chips */
.ach{display:flex;align-items:center;gap:.7rem;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:.7rem .9rem;box-shadow:var(--shadow-sm)}
.ach .medal{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-size:1.5rem;background:radial-gradient(circle at 35% 30%,#FFF1B8,var(--yellow));box-shadow:inset 0 -3px 0 rgba(0,0,0,.08),0 4px 10px rgba(224,167,0,.4);flex:none}
.xpbar{height:16px;border-radius:99px;background:#EEE6FF;overflow:hidden;box-shadow:inset 0 2px 4px rgba(58,30,120,.15)}
.xpbar>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--mint),#7CE6B0);box-shadow:inset 0 2px 0 rgba(255,255,255,.4)}

/* steps (how it works) */
.step{position:relative;text-align:center;padding:1.4rem 1.1rem 1.2rem}
.step .circle{width:84px;height:84px;border-radius:26px;display:grid;place-items:center;font-size:2.4rem;margin:0 auto .8rem;background:#fff;box-shadow:0 10px 0 var(--cs,#eee),0 16px 30px rgba(58,30,120,.16);transform:rotate(-3deg)}
.step .stepn{position:absolute;top:8px;left:50%;margin-left:18px;width:30px;height:30px;border-radius:50%;background:var(--coral);color:#fff;font-family:'Baloo 2';font-weight:800;display:grid;place-items:center;box-shadow:0 4px 0 var(--coral-deep)}

/* confetti overlay for dark/brand bands */
.confetti:before{content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.9;
  background-image:
   radial-gradient(circle, #FFD23F 50%, transparent 52%),
   radial-gradient(circle, #FF6B6B 50%, transparent 52%),
   radial-gradient(circle, #21C7B6 50%, transparent 52%),
   radial-gradient(circle, #4DA8FF 50%, transparent 52%);
  background-size:120px 120px,160px 160px,200px 200px,140px 140px;
  background-position:0 0,60px 30px,30px 80px,90px 50px;
  background-repeat:repeat; -webkit-mask-image:linear-gradient(180deg,rgba(0,0,0,.4),transparent 70%); mask-image:linear-gradient(180deg,rgba(0,0,0,.4),transparent 70%)}
.confetti>*{position:relative;z-index:1}

/* wave divider (place between sections) */
.wave{display:block;width:100%;height:46px;margin:0;line-height:0;color:#fff}
.wave svg{display:block;width:100%;height:100%}

/* animations */
@keyframes floaty{50%{transform:translateY(-12px)}}
@keyframes wiggle{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
@keyframes pop{0%{transform:scale(.8);opacity:0}100%{transform:scale(1);opacity:1}}
.floaty{animation:floaty 5s ease-in-out infinite}
.wiggle{animation:wiggle 3s ease-in-out infinite}

/* enrich base cards a touch more */
.card{border-radius:var(--r-lg)}
.card:hover{box-shadow:var(--shadow-lg)}

/* big section eyebrow chip */
.eyebrow.solid{background:var(--brand);color:#fff;border-color:var(--brand)}

/* pricing pop */
.price.pop{transform:scale(1.03)}
.price.pop:hover{transform:scale(1.05)}

/* logos strip */
.logos{display:flex;gap:2rem;flex-wrap:wrap;justify-content:center;align-items:center;opacity:.9}
.logos .lg{display:flex;align-items:center;gap:.5rem;font-family:'Baloo 2';font-weight:800;color:var(--ink-2);font-size:1.05rem;background:#fff;border:1px solid var(--line);padding:.6rem 1.1rem;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)}

/* ===========================================================
   DASHBOARD UI (v4) — tabs, tables, assign, records
   =========================================================== */
.dtabs{display:flex;gap:.4rem;flex-wrap:wrap;margin:1.2rem 0}
.dtab{font-family:'Baloo 2';font-weight:800;padding:.55rem 1.1rem;border-radius:var(--r-pill);border:1px solid var(--line);background:#fff;color:var(--ink-2);cursor:pointer;box-shadow:var(--shadow-sm);font-size:.92rem}
.dtab:hover{color:var(--brand)}
.dtab.on{background:var(--brand);color:#fff;border-color:var(--brand)}
.dpane{display:none}
.dpane.on{display:block;animation:pop .2s ease}

table.lh{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-sm);border:1px solid var(--line)}
table.lh th,table.lh td{padding:.7rem .8rem;text-align:left;border-bottom:1px solid var(--line);font-size:.92rem;color:var(--ink)}
table.lh th{background:var(--cream);font-family:'Baloo 2';font-weight:700;color:var(--ink-2);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}
table.lh tr:last-child td{border-bottom:0}
table.lh tbody tr:hover{background:var(--cream)}
.tnum{font-family:'Baloo 2';font-weight:800}

.assignbox{background:#fff;border:2px dashed var(--brand);border-radius:var(--r-lg);padding:1.4rem;box-shadow:var(--shadow-sm)}
.fieldrow{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin:.55rem 0}
.fieldrow label{font-weight:800;color:var(--ink-2);min-width:96px}
.fakeinput{flex:1;min-width:180px;background:var(--cream);border:1px solid var(--line);border-radius:var(--r-pill);padding:.6rem 1rem;font-weight:700;color:var(--ink-2);display:flex;align-items:center;justify-content:space-between}
.fakeinput .cv{color:var(--ink)}

.badgecard{position:relative;text-align:center;border-radius:var(--r-lg);padding:1rem .6rem;background:#fff;border:1px solid var(--line);box-shadow:var(--shadow-sm)}
.badgecard.lock{opacity:.5;filter:grayscale(.7)}
.badgecard .bemoji{width:62px;height:62px;border-radius:50%;display:grid;place-items:center;font-size:1.9rem;margin:0 auto .4rem;background:radial-gradient(circle at 35% 30%,#FFF7DA,var(--cs,var(--ks1-soft)))}
.badgecard .pts{position:absolute;top:8px;right:8px;background:var(--brand);color:#fff;font-family:'Baloo 2';font-weight:800;font-size:.72rem;padding:.1rem .5rem;border-radius:99px}
.badgecard b{font-size:.9rem}

.status{display:inline-flex;align-items:center;gap:.35rem;font-weight:800;font-size:.82rem;padding:.2rem .6rem;border-radius:99px}
.s-done{background:var(--eyfs-soft);color:#0f8f4d}
.s-prog{background:var(--ks1-soft);color:#1f6fd6}
.s-due{background:var(--ks3-soft);color:#c43c5e}
.s-todo{background:var(--cream);color:var(--ink-3)}

/* contrast fixes for dark/brand bands */
.gamify{color:#fff}
.gamify .gcard,.gamify .gcard b,.gamify .gcard strong{color:#fff}
.statbig{color:#fff}
.brandband .chip{color:var(--ink)} /* white pills keep dark text */

/* contrast safety net: muted text stays light on dark wrappers */
.gamify .muted,.statbig .muted,.cta-band .muted,.welcome .muted,.brandband .muted{color:#E7DEFF}
.gamify a:not(.btn),.cta-band a:not(.btn){color:#fff}

/* ===========================================================
   LAYOUT WIDTH (v5) — wider body, full-bleed header & footer
   =========================================================== */
:root{--maxw:1340px}                     /* wider body content */
.nav{max-width:100%; padding-left:clamp(20px,3.2vw,52px); padding-right:clamp(20px,3.2vw,52px)}
footer.site>.container{max-width:100%; padding-left:clamp(20px,3.2vw,52px); padding-right:clamp(20px,3.2vw,52px)}
.subnav .in{max-width:100%; padding-left:clamp(20px,3.2vw,52px); padding-right:clamp(20px,3.2vw,52px)}

/* ===========================================================
   MODERN HEADER (v6) + animated SVG logo
   =========================================================== */
/* Single source of truth for the sticky header bar (consolidated — was
   previously redefined in v6/v7/v9 blocks). */
header.site{position:sticky !important; top:0 !important; z-index:60 !important; border:0;
  background:linear-gradient(100deg,rgba(91,31,196,.82) 0%,rgba(122,40,214,.80) 55%,rgba(106,35,206,.82) 100%);
  -webkit-backdrop-filter:saturate(150%) blur(12px); backdrop-filter:saturate(150%) blur(12px);
  box-shadow:0 10px 30px rgba(40,14,99,.30)}
@keyframes hdrDrop{from{transform:translateY(-100%);opacity:.4}to{transform:translateY(0);opacity:1}}
/* animated rainbow accent line = the KS journey colours */
header.site:after{content:"";display:block;height:3px;
  background:linear-gradient(90deg,var(--eyfs),var(--ks1),var(--ks2),var(--ks3),var(--gcse),var(--eyfs));
  background-size:200% 100%; animation:hdrShimmer 6s linear infinite}
@keyframes hdrShimmer{to{background-position:200% 0}}
/* glossy sheen sweeping across the bar */
header.site .nav{position:relative; overflow:hidden}
header.site .nav:before{content:"";position:absolute;top:0;bottom:0;left:-40%;width:30%;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.14),transparent);
  transform:skewX(-18deg); animation:hdrSheen 7s ease-in-out infinite}
@keyframes hdrSheen{0%{left:-40%}28%,100%{left:130%}}
.nav>*{position:relative;z-index:1}

/* logo */
.logo{display:flex;align-items:center;gap:.6rem}
.logo-svg{display:block;filter:drop-shadow(0 4px 8px rgba(0,0,0,.25));transition:transform .2s}
.logo-word{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:1.4rem;color:#fff;letter-spacing:-.01em;line-height:1}
.logo-word .hub{color:var(--yellow)}
.logo:hover .logo-svg{transform:scale(1.06) rotate(-3deg)}
@keyframes rooBob{0%,100%{transform:translateY(0)}50%{transform:translateY(-2.5px)}}
@keyframes earWiggle{0%,100%{transform:rotate(0deg)}50%{transform:rotate(-8deg)}}
@keyframes twinkle{0%,100%{opacity:.15;transform:scale(.5)}50%{opacity:1;transform:scale(1)}}
@keyframes tailSwish{0%,100%{transform:rotate(0)}50%{transform:rotate(-6deg)}}
.logo-svg .lg-roo{animation:rooBob 2.6s ease-in-out infinite;transform-origin:50% 70%}
.logo-svg .lg-ear{animation:earWiggle 2.6s ease-in-out infinite;transform-box:fill-box;transform-origin:bottom center}
.logo-svg .lg-tail{animation:tailSwish 2.6s ease-in-out infinite;transform-box:fill-box;transform-origin:top right}
.logo-svg .lg-spark{transform-box:fill-box;transform-origin:center;animation:twinkle 2s ease-in-out infinite}
.footer-logo .logo-svg{width:36px;height:36px}
.footer-logo .logo-word{font-size:1.25rem}

/* nav links with sliding underline + caret */
.nav .links{display:flex;gap:.15rem;margin-left:.8rem}
.nav .links a{position:relative;display:inline-flex;align-items:center;gap:.25rem;color:#fff;font-weight:700;font-size:.98rem;padding:.55rem .85rem;border-radius:var(--r-pill);opacity:.94;transition:background .15s,opacity .15s}
.nav .links a .cv{font-size:.7rem;opacity:.8}
.nav .links a:hover{background:rgba(255,255,255,.12);opacity:1}
.nav .links a:after{content:"";position:absolute;left:.85rem;right:.85rem;bottom:.32rem;height:3px;border-radius:9px;background:var(--yellow);transform:scaleX(0);transform-origin:left;transition:transform .22s ease}
.nav .links a:hover:after{transform:scaleX(1)}
@media(max-width:900px){.nav .links{display:none}}

/* auth: refined login + glowing signup */
.nav .auth{display:flex;gap:.7rem;align-items:center}
.nav .auth a.login{color:#fff;font-weight:700;padding:.55rem .9rem;border-radius:var(--r-pill);opacity:.92}
.nav .auth a.login:hover{background:rgba(255,255,255,.12);opacity:1}
.nav .auth .signup{box-shadow:0 6px 0 var(--coral-deep),0 0 0 0 rgba(255,61,90,.6);animation:signupGlow 2.6s ease-in-out infinite}
@keyframes signupGlow{0%,100%{box-shadow:0 6px 0 var(--coral-deep),0 0 0 0 rgba(255,61,90,.55)}50%{box-shadow:0 6px 0 var(--coral-deep),0 0 22px 4px rgba(255,61,90,.45)}}
.nav .auth .signup:hover{transform:translateY(-2px)}

/* respect reduced motion */
@media(prefers-reduced-motion:reduce){
  header.site,header.site:after,.nav:before,.logo-svg *,.signup{animation:none!important}
}

/* ===== production additions: mobile menu + a11y skip link ===== */
.screen-reader-text{position:absolute!important;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus{position:fixed;left:10px;top:10px;z-index:9999;background:#fff;color:var(--brand);padding:.6rem 1rem;border-radius:10px;box-shadow:var(--shadow)}
.lh-burger{display:none;font-size:1.6rem;line-height:1;color:#fff;cursor:pointer;padding:.25rem .55rem;border-radius:10px;margin-left:.2rem}
.lh-burger:hover{background:rgba(255,255,255,.14)}
@media(max-width:900px){
  header.site .nav{position:relative;flex-wrap:wrap}
  .lh-burger{display:inline-flex}
  .lh-burger-cb:checked ~ .links{display:flex;flex-direction:column;align-items:flex-start;gap:.15rem;position:absolute;top:100%;left:0;right:0;background:#6320C6;padding:1rem clamp(20px,3.2vw,52px);box-shadow:var(--shadow);z-index:40}
}

/* ===========================================================
   v7 — showcased animated logo (hop + wind trails + sparkles),
   forced sticky header, flashing animated border
   =========================================================== */
header.site:after{animation:hdrShimmer 6s linear infinite, hdrFlash 1.8s ease-in-out infinite}
@keyframes hdrFlash{0%,100%{opacity:1}50%{opacity:.45}}

.logo-svg{overflow:visible}
.logo-svg .lg-roo{animation:none}              /* hop now drives motion */
.logo-svg .lg-hop{transform-box:fill-box;transform-origin:50% 82%;animation:lgHop 1.6s ease-in-out infinite}
@keyframes lgHop{0%,100%{transform:translateY(0) rotate(0)}40%{transform:translateY(-3px) rotate(-2deg)}62%{transform:translateY(-1.5px) rotate(1.5deg)}}
.logo-svg .lg-wind line{opacity:0;transform-box:fill-box;transform-origin:center;animation:lgWhoosh 1.6s ease-out infinite}
.logo-svg .lg-wind .w1{animation-delay:.04s}
.logo-svg .lg-wind .w2{animation-delay:.12s}
.logo-svg .lg-wind .w3{animation-delay:.2s}
@keyframes lgWhoosh{0%{opacity:0;transform:translateX(10px)}35%{opacity:.95}100%{opacity:0;transform:translateX(-9px)}}
.logo-svg .sp{transform-box:fill-box;transform-origin:center;animation:lgTwinkle 1.9s ease-in-out infinite}
.logo-svg .sp2{animation-delay:.55s}
.logo-svg .sp3{animation-delay:1.1s}
@keyframes lgTwinkle{0%,100%{opacity:.1;transform:scale(.4) rotate(0)}50%{opacity:1;transform:scale(1) rotate(45deg)}}
.logo:hover .lg-hop{animation-duration:.85s}
.logo:hover .lg-wind line{animation-duration:.85s}
@media(prefers-reduced-motion:reduce){.logo-svg .lg-hop,.logo-svg .lg-wind line,.logo-svg .sp,header.site:after{animation:none}.logo-svg .lg-wind line{opacity:.6}}

/* ===========================================================
   v8 — real brand kangaroo PNG fused into animated badge
   =========================================================== */
.logo-mark{position:relative;display:inline-block;width:66px;height:50px;flex:none}
.logo-mark .lm-roo{position:absolute;right:-3px;bottom:0;height:48px;width:auto;z-index:3;
  transform-origin:62% 80%;
  animation:lmHop 1.6s ease-in-out infinite}
@keyframes lmHop{0%,100%{transform:translateY(0) rotate(0)}40%{transform:translateY(-4px) rotate(-3deg)}62%{transform:translateY(-2px) rotate(2deg)}}
.logo-mark .lm-wind{position:absolute;left:0;top:10px;width:20px;height:30px;z-index:1}
.logo-mark .lm-wind i{position:absolute;left:0;height:3px;border-radius:2px;opacity:0;animation:lmWhoosh 1.6s ease-out infinite}
.logo-mark .lm-wind i:nth-child(1){top:2px;width:15px;background:#FFD23F;animation-delay:.04s}
.logo-mark .lm-wind i:nth-child(2){top:12px;width:11px;background:#FF8A3D;animation-delay:.12s}
.logo-mark .lm-wind i:nth-child(3){top:22px;width:13px;background:#fff;animation-delay:.2s}
@keyframes lmWhoosh{0%{opacity:0;transform:translateX(11px)}35%{opacity:.95}100%{opacity:0;transform:translateX(-9px)}}
.logo-mark .lm-sparks i{position:absolute;width:8px;height:8px;background:#fff;opacity:.1;
  clip-path:polygon(50% 0,59% 41%,100% 50%,59% 59%,50% 100%,41% 59%,0 50%,41% 41%);
  animation:lmTwinkle 1.9s ease-in-out infinite}
.logo-mark .lm-sparks i:nth-child(1){right:3px;top:-2px}
.logo-mark .lm-sparks i:nth-child(2){right:32px;bottom:-2px;width:6px;height:6px;animation-delay:.6s}
.logo-mark .lm-sparks i:nth-child(3){right:-4px;top:19px;width:6px;height:6px;animation-delay:1.1s}
.logo-mark .lm-sparks i:nth-child(4){right:16px;top:-4px;width:5px;height:5px;animation-delay:.35s}
.logo-mark .lm-sparks i:nth-child(5){right:46px;top:7px;width:7px;height:7px;animation-delay:.85s}
.logo-mark .lm-sparks i:nth-child(6){right:-2px;bottom:7px;width:5px;height:5px;animation-delay:1.4s}
@keyframes lmTwinkle{0%,100%{opacity:.1;transform:scale(.4) rotate(0)}50%{opacity:1;transform:scale(1) rotate(45deg)}}
.logo:hover .lm-roo{animation-duration:.85s}
.logo:hover .lm-wind i{animation-duration:.85s}
/* footer smaller */
.footer-logo .logo-mark{width:52px;height:42px}
.footer-logo .lm-roo{height:40px}
@media(prefers-reduced-motion:reduce){.lm-roo,.lm-wind i,.lm-sparks i{animation:none}.lm-wind i{opacity:.6}.lm-sparks i{opacity:.85}}

/* ===========================================================
   v9 — robust mobile drawer (JS-driven) + sticky nav
   =========================================================== */
.lh-burger{background:transparent;border:none;cursor:pointer}
.lh-burger[aria-expanded="true"]{background:rgba(255,255,255,.18)}
@media(max-width:900px){
  header.site .nav{position:relative;flex-wrap:nowrap}
  .nav .links{display:none}
  .nav.lh-open .links{display:flex;flex-direction:column;align-items:stretch;gap:.15rem;
    position:absolute;top:100%;left:0;right:0;z-index:70;
    background:linear-gradient(180deg,#6A23CE,#5B1FC4);
    padding:.6rem clamp(16px,4vw,28px) 1rem;
    box-shadow:0 18px 40px rgba(40,14,99,.42);border-top:1px solid rgba(255,255,255,.14);
    max-height:calc(100vh - 64px);overflow:auto;animation:lhDrawer .18s ease}
  .nav.lh-open .links a{padding:.85rem .6rem;font-size:1.05rem;border-radius:12px;opacity:1}
  .nav.lh-open .links a:after{display:none}
  .lh-burger{display:inline-flex;align-items:center;justify-content:center;font-size:1.6rem;line-height:1;padding:.2rem .55rem;border-radius:10px;color:#fff}
}
@keyframes lhDrawer{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}


/* ===== Learn mega menu (interactive left-rail) — child of header.site ===== */
.lh-mega{position:absolute !important;top:100%;left:50%;transform:translateX(-50%) translateY(10px);width:min(1080px,94vw);
  background:#fff;border-radius:24px;box-shadow:0 30px 70px rgba(30,10,70,.35);z-index:80;overflow:hidden;
  border:1px solid var(--line);display:grid;grid-template-columns:248px 1fr 200px;
  opacity:0;visibility:hidden;pointer-events:none;transition:opacity .18s,transform .18s}
.lh-mega.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.lhm-rail{background:#FBF7FF;border-right:1px solid var(--line);padding:1rem .8rem}
.lhm-rail h4,.lhm-fmt h4{font-family:'Baloo 2',sans-serif;font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);margin:.2rem .4rem .7rem}
.lhm-ri{display:flex;align-items:center;gap:.7rem;padding:.6rem .65rem;border-radius:14px;text-decoration:none;color:var(--ink);transition:background .14s}
.lhm-ri .lhm-dot{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;font-size:1.05rem;color:#fff;flex:none;box-shadow:inset 0 -3px 0 rgba(0,0,0,.15)}
.lhm-ri b{font-family:'Baloo 2',sans-serif;font-size:1rem;display:block;line-height:1;color:var(--ink)}
.lhm-ri small{color:var(--ink-3);font-weight:700;font-size:.73rem;display:block}
.lhm-ri:hover,.lhm-ri.on{background:var(--cs)}
.lhm-ri.on{box-shadow:inset 4px 0 0 var(--c)}
.lhm-arr{margin-left:auto;color:var(--c);font-weight:800;opacity:0;transition:opacity .14s}
.lhm-ri.on .lhm-arr{opacity:1}
.lhm-ri:hover .lhm-arr{opacity:1}
.lhm-pane{padding:1.1rem 1.3rem;position:relative}
.lhm-pn{display:none}
.lhm-pn.on{display:block;animation:lhmFade .2s ease}
@keyframes lhmFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.lhm-head{display:flex;align-items:center;gap:.6rem}
.lhm-badge{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;font-size:1.3rem;color:#fff}
.lhm-pn h3{font-family:'Baloo 2',sans-serif;font-size:1.25rem;margin:0;line-height:1;color:var(--ink)}
.lhm-age{color:var(--ink-3);font-weight:700;font-size:.8rem}
.lhm-lead{color:var(--ink-2);font-size:.9rem;margin:.5rem 0 .8rem}
.lhm-sg{display:grid;grid-template-columns:repeat(3,1fr);gap:.3rem;margin-bottom:.8rem}
.lhm-sg a{display:flex;align-items:center;gap:.45rem;text-decoration:none;color:var(--ink);font-weight:700;font-size:.85rem;padding:.4rem .5rem;border-radius:11px;transition:background .14s}
.lhm-sg a:hover{background:var(--cs)}
.lhm-sg .lhm-i{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.9rem;background:var(--cs)}
.lhm-tlab{font-family:'Baloo 2',sans-serif;font-weight:800;font-size:.78rem;color:var(--c);margin:.2rem 0 .4rem}
.lhm-tchips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.9rem}
.lhm-tchips a{text-decoration:none;background:var(--cs);color:var(--ci);font-weight:700;font-size:.8rem;border-radius:999px;padding:.28rem .65rem;transition:transform .12s}
.lhm-tchips a:hover{transform:translateY(-2px)}
.lhm-goall{display:inline-flex;align-items:center;gap:.4rem;background:var(--c);color:#fff;font-family:'Baloo 2',sans-serif;font-weight:800;text-decoration:none;border-radius:999px;padding:.5rem 1rem;font-size:.88rem;box-shadow:0 4px 0 rgba(0,0,0,.18)}
.lhm-fmt{background:linear-gradient(180deg,#FBF7FF,#F3EEFC);border-left:1px solid var(--line);padding:1rem .7rem}
.lhm-fr{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--ink);font-weight:700;font-size:.84rem;padding:.42rem .5rem;border-radius:11px;transition:background .14s}
.lhm-fr:hover{background:#fff}
.lhm-fr .lhm-fi{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.9rem}
.lhm-seeall{display:inline-block;margin:.5rem .4rem;font-family:'Baloo 2',sans-serif;font-weight:800;font-size:.8rem;color:var(--brand);text-decoration:none}
.lh-mlearn .lhm-cv{display:inline-block;transition:transform .2s}
.lh-mlearn[aria-expanded="true"] .lhm-cv{transform:rotate(180deg)}
@media(max-width:980px){.lh-mega{display:none!important}}


/* ===== Free Stuff mega menu ===== */
.lh-mega--free{grid-template-columns:1fr 1fr 1fr 232px}
.lhm-fcol{padding:1.05rem .9rem;border-right:1px solid var(--line)}
.lhm-fcol h4{font-family:'Baloo 2',sans-serif;font-size:.72rem;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-3);margin:.2rem .4rem .7rem}
.lhm-fcol a{display:flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--ink);font-weight:700;font-size:.86rem;padding:.4rem .5rem;border-radius:11px;transition:background .14s}
.lhm-fcol a:hover{background:#f3eefc}
.lhm-fd{width:11px;height:11px;border-radius:50%;flex:none;box-shadow:0 0 0 3px rgba(0,0,0,.04)}
.lhm-fi{width:26px;height:26px;border-radius:8px;display:grid;place-items:center;font-size:.9rem;flex:none}
.lhm-ccol{background:linear-gradient(160deg,#6A23CE,#3A1B86);color:#fff;padding:1.1rem;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.lhm-ccol:before{content:"";position:absolute;inset:0;background-image:var(--grid);background-size:24px 24px;opacity:.5}
.lhm-ccol>*{position:relative;z-index:1}
.lhm-cta-ic{font-size:1.8rem;line-height:1}
.lhm-ccol h5{font-family:'Baloo 2',sans-serif;color:#fff;font-size:1.05rem;margin:.3rem 0 .2rem}
.lhm-ccol p{color:#E7DCFF;font-size:.82rem;margin:0 0 .7rem;line-height:1.4}
.lhm-cta-btn{background:var(--yellow);color:var(--yellow-ink);font-family:'Baloo 2',sans-serif;font-weight:800;text-decoration:none;border-radius:999px;padding:.5rem .9rem;font-size:.85rem;text-align:center;box-shadow:0 4px 0 var(--yellow-deep);transition:transform .12s}
.lhm-cta-btn:hover{transform:translateY(-1px)}
.lhm-allfree{display:inline-block;margin-top:.75rem;color:#fff;font-weight:800;font-size:.82rem;text-decoration:underline}
@media(max-width:980px){.lh-mega--free{display:none!important}}

/* clickable format sticker cards on the homepage */
a.sticker{color:var(--ink);text-decoration:none;display:block}
a.sticker h3{color:var(--ink)}
a.sticker:hover h3{color:var(--brand)}

/* ===== "Who is it for" mega menu (3 role columns + CTA) ===== */
.lh-mega--who{grid-template-columns:1fr 1fr 1fr 240px}
.lhm-rolecol{padding:1.15rem 1rem;border-right:1px solid var(--line)}
.lhm-rolehd{display:flex;align-items:center;gap:.6rem;margin-bottom:.55rem}
.lhm-roleic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;font-size:1.35rem;color:#fff;flex:none;box-shadow:inset 0 -3px 0 rgba(0,0,0,.14)}
.lhm-rolehd b{font-family:'Baloo 2',sans-serif;font-size:1.04rem;display:block;line-height:1.05;color:var(--ink)}
.lhm-rolehd small{color:var(--ink-3);font-weight:700;font-size:.72rem}
.lhm-roledesc{color:var(--ink-2);font-size:.84rem;margin:0 0 .7rem;line-height:1.4}
.lhm-roleprime{display:inline-block;font-family:'Baloo 2',sans-serif;font-weight:800;font-size:.86rem;color:var(--brand);text-decoration:none;margin-bottom:.5rem}
.lhm-roleprime:hover{text-decoration:underline}
.lhm-rolelnk{display:flex;align-items:center;gap:.55rem;text-decoration:none;color:var(--ink);font-weight:700;font-size:.85rem;padding:.42rem .5rem;border-radius:11px;transition:background .14s,color .14s}
.lhm-rolelnk span{width:22px;text-align:center;flex:none}
.lhm-rolelnk:hover{background:var(--cs,#f3eefc);color:var(--brand)}
.lhm-whocta{background:linear-gradient(160deg,#6A23CE,#3A1B86);color:#fff;padding:1.1rem;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}
.lhm-whocta:before{content:"";position:absolute;inset:0;background-image:var(--grid);background-size:24px 24px;opacity:.5}
.lhm-whocta>*{position:relative;z-index:1}
.lhm-whocta h5{font-family:'Baloo 2',sans-serif;color:#fff;font-size:1.05rem;margin:.3rem 0 .2rem}
.lhm-whocta p{color:#E7DCFF;font-size:.82rem;margin:0 0 .7rem;line-height:1.4}
@media(max-width:980px){.lh-mega--who{display:none!important}}

/* ===== social icons in the nav (subtle, right-aligned) ===== */
.nav .auth .lh-social{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;color:#fff;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);transition:background .15s,transform .12s;text-decoration:none}
.nav .auth .lh-social:hover{background:rgba(255,255,255,.24);transform:translateY(-1px)}
.nav .auth .lh-social svg{width:17px;height:17px;display:block}
.nav .auth .lh-social+.lh-social{margin-left:-2px}
@media(max-width:1180px){.nav .auth .lh-social{display:none}}
