/* ===================================================================
   Yusr Arabic — shared landing layout (Future Forward)
   Palette + Arabic voice are set per page via :root tokens + body class.
   Tokens expected:
     --page --panel --panel-2 --hair
     --fg --fg-2 --fg-muted --fg-faint
     --accent --on-accent --brand --on-brand
     --g1 --g2 --g3   (mark gradient stops)
     --stage-1 --stage-2 (hero stage bg)
   Body classes: voice-ruqaa | voice-naskh | voice-kufi ; mark-grad | mark-solid ; theme-dark
   =================================================================== */
:root{
  --serif:'Cormorant Garamond',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  --caps:'Cinzel',serif;
  --grad:linear-gradient(115deg,var(--g1) 0%,var(--g2) 50%,var(--g3) 100%);
  --maxw:1200px; --gut:44px; --r:18px; --ease:cubic-bezier(.22,1,.36,1);
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;scroll-padding-top:96px;}
body{margin:0;background:var(--page);color:var(--fg-2);font-family:var(--sans);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;}
h1,h2,h3,h4{margin:0;font-family:var(--serif);font-weight:600;letter-spacing:-.015em;color:var(--fg);}
p{margin:0;}a{color:inherit;text-decoration:none;}
::selection{background:color-mix(in srgb,var(--accent) 30%,transparent);}
.container{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut);}
section{padding:clamp(64px,9vw,116px) 0;position:relative;}

/* ---------- Arabic mark + voices ---------- */
.ar{direction:rtl;line-height:1.15;}
.mark{line-height:1.22;}/* room for harakat above + raa tail below — never clip the logo */
.voice-ruqaa .ar,.ar.ruqaa{font-family:'Aref Ruqaa',serif;}
.voice-naskh .ar,.ar.naskh{font-family:'Amiri',serif;}
.voice-kufi .ar,.ar.kufi{font-family:'Reem Kufi',sans-serif;font-weight:600;}
.mark-grad .mark,.mark.grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
.mark-solid .mark,.mark.solid{color:var(--mark-color,var(--accent));}
.grad-t{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;}
/* real logo mark (SVG paths via CSS mask → pixel-perfect, themes via --mark-color) */
.logomark{display:inline-block;aspect-ratio:462/399;background:var(--mark-color,var(--accent));-webkit-mask:url(yusr-mark-navy.svg) center/contain no-repeat;mask:url(yusr-mark-navy.svg) center/contain no-repeat;}

/* ---------- logo: primary lockup ---------- */
.lockup{display:flex;flex-direction:column;align-items:center;text-align:center;}
.lockup .mark{font-size:clamp(96px,13vw,150px);}
.lockup .swash{display:block;width:64%;height:24px;margin:4px auto 0;}
.lockup .swash path{fill:none;stroke-width:3.2;stroke-linecap:round;}
.lockup .wordmark{font-family:var(--caps);font-weight:600;color:var(--fg);font-size:clamp(28px,3.4vw,42px);letter-spacing:.13em;margin-top:16px;}
.lockup .rule{display:flex;align-items:center;justify-content:center;gap:13px;width:min(300px,70%);margin:15px 0 12px;}
.lockup .rule .ln{flex:1;height:1px;background:linear-gradient(90deg,transparent,var(--accent) 40%,var(--accent) 60%,transparent);}
.lockup .rule .dia{width:7px;height:7px;background:var(--accent);transform:rotate(45deg);flex:none;}
.lockup .tag{font-family:var(--caps);font-weight:500;color:var(--accent);font-size:clamp(14px,1.5vw,18px);letter-spacing:.34em;text-transform:uppercase;padding-left:.34em;}
.lockup .tag-ar{direction:rtl;font-family:'Amiri',serif;color:var(--fg-muted);font-size:21px;margin-top:13px;opacity:.92;}
.voice-kufi .lockup .tag-ar{font-family:'Reem Kufi',sans-serif;}

/* ---------- logo: secondary short (nav) ---------- */
.brand{display:flex;align-items:center;gap:13px;}
.brand .b-mark{font-size:32px;line-height:1;}
.brand .b-div{width:1px;height:34px;background:var(--hair);}
.brand .b-stack .w{font-family:var(--caps);font-weight:600;color:var(--fg);font-size:15px;letter-spacing:.12em;line-height:1.12;}
.brand .b-stack .tg{font-family:var(--caps);font-weight:500;color:var(--accent);font-size:8.5px;letter-spacing:.2em;text-transform:uppercase;margin-top:3px;}

/* ---------- logo: app icon tile ---------- */
.appicon{width:74px;height:74px;border-radius:18px;background:var(--brand);display:flex;align-items:center;justify-content:center;box-shadow:0 14px 30px -14px rgba(8,12,24,.5),inset 0 1px 0 rgba(255,255,255,.07);flex:none;}
.appicon .m{font-size:42px;}
.appicon.lg{width:104px;height:104px;border-radius:26px;}
.appicon.lg .m{font-size:58px;}

/* ---------- buttons (NO gradient — gold/brand carry) ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:15px;padding:14px 26px;border-radius:11px;border:1px solid transparent;cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s,background .3s,color .3s,border-color .3s;}
.btn-primary{background:var(--brand);color:var(--on-brand);}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 16px 36px -14px color-mix(in srgb,var(--brand) 70%,transparent);}
.btn-gold{background:var(--accent);color:var(--on-accent);}
.btn-gold:hover{transform:translateY(-2px);box-shadow:0 16px 38px -14px color-mix(in srgb,var(--accent) 70%,transparent);}
.btn-out{background:transparent;color:var(--fg);border-color:var(--hair);}
.btn-out:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px);}
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;}

.kicker{font-family:var(--caps);font-weight:600;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);}
.h2{font-size:clamp(32px,4.4vw,50px);line-height:1.07;}
.h2 em{font-style:italic;}
.lead{font-family:var(--sans);font-size:clamp(17px,1.6vw,19px);color:var(--fg-muted);line-height:1.62;}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s var(--ease),border-color .4s;border-bottom:1px solid transparent;}
.nav.scrolled{background:color-mix(in srgb,var(--page) 82%,transparent);backdrop-filter:blur(16px);border-bottom-color:var(--hair);}
.nav-in{max-width:var(--maxw);margin:0 auto;padding:15px var(--gut);display:flex;align-items:center;justify-content:space-between;}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a.l{font-size:14.5px;font-weight:500;color:var(--fg-muted);transition:color .2s;}
.nav-links a.l:hover{color:var(--fg);}
.nav-cta{padding:10px 20px;font-size:14px;}
.nav-toggle{display:none;background:none;border:0;cursor:pointer;padding:8px;}.nav-toggle span{display:block;width:24px;height:2px;border-radius:2px;background:var(--fg);margin:5px 0;}

/* ---------- hero (split) ---------- */
.hero{padding-top:150px;padding-bottom:clamp(56px,8vw,92px);overflow:hidden;}
.hero-grid{display:grid;grid-template-columns:1.04fr .96fr;gap:clamp(32px,5vw,64px);align-items:center;}
.eyebrow{display:inline-flex;align-items:center;gap:8px;font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 26%,transparent);padding:7px 14px;border-radius:100px;}
.eyebrow .d{width:6px;height:6px;border-radius:50%;background:var(--accent);}
.hero h1{font-size:clamp(42px,5.6vw,72px);line-height:1.03;margin:24px 0 0;}
.hero h1 em{font-style:italic;}
.hero .sub{font-family:var(--sans);font-size:clamp(17px,1.7vw,20px);color:var(--fg-muted);line-height:1.6;margin:22px 0 0;max-width:35ch;}
.hero-cta{display:flex;gap:13px;margin-top:32px;flex-wrap:wrap;}
.hero-chips{display:flex;flex-wrap:wrap;gap:10px 18px;margin-top:32px;}
.hero-chips .c{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:500;color:var(--fg-muted);}
.hero-chips .c svg{width:16px;height:16px;color:var(--accent);}
/* hero stage holds the PRIMARY LOCKUP */
.stage{position:relative;aspect-ratio:1/1.04;border-radius:26px;background:linear-gradient(160deg,var(--stage-1),var(--stage-2));border:1px solid var(--hair);overflow:hidden;display:flex;align-items:center;justify-content:center;box-shadow:0 50px 100px -52px rgba(8,12,24,.45);}
.stage::before{content:"";position:absolute;inset:0;background-image:linear-gradient(var(--hair) 1px,transparent 1px),linear-gradient(90deg,var(--hair) 1px,transparent 1px);background-size:40px 40px;opacity:.5;}
.stage::after{content:"";position:absolute;width:440px;height:440px;border-radius:50%;background:radial-gradient(closest-side,color-mix(in srgb,var(--accent) 22%,transparent),transparent 72%);}
.stage .lockup{position:relative;transform:scale(.92);}
.chip-float{position:absolute;background:color-mix(in srgb,var(--panel) 86%,transparent);backdrop-filter:blur(8px);border:1px solid var(--hair);border-radius:14px;padding:12px 15px;box-shadow:0 20px 40px -22px rgba(8,12,24,.5);}
.chip-float .v{font-family:var(--serif);font-weight:600;font-size:22px;line-height:1;color:var(--fg);}
.chip-float .k{font-size:11px;color:var(--fg-muted);margin-top:3px;font-weight:500;}
.chip-float.a{top:26px;right:22px;}

/* ---------- trust ---------- */
.trust{border-top:1px solid var(--hair);border-bottom:1px solid var(--hair);background:var(--panel);}
.trust .container{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:12px 24px;padding-top:18px;padding-bottom:18px;}
.trust span.i{font-size:13.5px;font-weight:500;color:var(--fg-muted);}
.trust .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);}

/* ---------- about ---------- */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,5vw,72px);align-items:center;}
.about-art{position:relative;aspect-ratio:1/1.05;border-radius:22px;background:var(--grad);padding:2px;box-shadow:0 40px 90px -50px color-mix(in srgb,var(--g2) 70%,transparent);}
.about-art .inner{width:100%;height:100%;border-radius:20px;background:linear-gradient(160deg,var(--stage-1),var(--stage-2));display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;}
.about-art .inner .mark{font-size:clamp(110px,17vw,180px);}
.about-art .inner .stamp{position:absolute;bottom:16px;right:18px;font-family:var(--caps);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-faint);}
.about-body .h2{margin-top:14px;}
.about-body p{font-family:var(--sans);color:var(--fg-muted);font-size:17px;line-height:1.66;margin-top:16px;}
.pullquote{font-family:var(--serif);font-style:italic;font-size:clamp(21px,2.6vw,27px);line-height:1.32;color:var(--fg);margin:26px 0 0;padding-left:22px;border-left:3px solid var(--accent);}

/* ---------- programme bento ---------- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:clamp(34px,5vw,48px);}
.tile{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:28px 26px;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s;display:flex;flex-direction:column;gap:12px;}
.tile:hover{transform:translateY(-3px);box-shadow:0 26px 50px -34px rgba(8,12,24,.4);border-color:color-mix(in srgb,var(--accent) 40%,var(--hair));}
.tile.wide{grid-column:span 2;}
.tile .ic{width:36px;height:36px;border-radius:10px;background:color-mix(in srgb,var(--accent) 12%,transparent);display:flex;align-items:center;justify-content:center;color:var(--accent);}
.tile .ic svg{width:19px;height:19px;}
.tile h4{font-family:var(--sans);font-weight:600;font-size:16.5px;letter-spacing:0;color:var(--fg);}
.tile p{font-size:14.5px;color:var(--fg-muted);line-height:1.5;}
/* 61% panel — accent number on clean brand panel (NO rainbow) */
.stat61{grid-column:span 2;background:var(--brand);border-radius:var(--r);padding:32px 30px;color:var(--on-brand);display:flex;align-items:center;gap:24px;position:relative;overflow:hidden;}
.stat61::after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;border-radius:50%;background:color-mix(in srgb,var(--accent) 18%,transparent);}
.stat61 .big{font-family:var(--serif);font-weight:700;font-size:clamp(64px,9vw,100px);line-height:.86;position:relative;color:var(--accent);}
.stat61 .txt{position:relative;}
.stat61 .txt b{font-family:var(--sans);font-weight:600;font-size:16px;display:block;color:var(--on-brand);}
.stat61 .txt span{font-size:14px;opacity:.82;}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,4vw,56px);align-items:center;margin-top:clamp(48px,7vw,84px);}
.feature-text h3{font-size:clamp(24px,3vw,34px);line-height:1.16;}
.feature-text h3 .ar{font-family:'Amiri',serif;}
.feature-text p{font-family:var(--sans);color:var(--fg-muted);font-size:16.5px;line-height:1.62;margin-top:14px;}
.ibadge{display:inline-flex;align-items:center;gap:8px;font-family:var(--caps);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent);margin-bottom:8px;}
.blocks{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:clamp(34px,5vw,52px);}
.block{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:32px 30px;}
.block h3{font-family:var(--sans);font-weight:700;font-size:18px;letter-spacing:0;color:var(--fg);margin-bottom:12px;}
.block p{font-family:var(--sans);color:var(--fg-muted);font-size:15.5px;line-height:1.6;margin-bottom:12px;}
.block p:last-child{margin-bottom:0;}

/* ---------- teach ---------- */
.teach-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:16px;}
.teach-tag{font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.6vw,28px);color:var(--fg);}
.teach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:clamp(34px,5vw,48px);}
.tcard{background:var(--panel);border:1px solid var(--hair);border-radius:var(--r);padding:28px 24px;transition:transform .35s var(--ease),box-shadow .35s;}
.tcard:hover{transform:translateY(-3px);box-shadow:0 26px 50px -34px rgba(8,12,24,.4);}
.tcard .n{display:inline-flex;width:30px;height:30px;border-radius:8px;background:var(--brand);color:var(--on-brand);align-items:center;justify-content:center;font-family:var(--caps);font-size:12px;}
.tcard h4{font-family:var(--sans);font-weight:700;font-size:17px;margin:14px 0 7px;letter-spacing:0;color:var(--fg);}
.tcard p{font-size:14.5px;color:var(--fg-muted);line-height:1.5;}
.video{margin-top:clamp(36px,5vw,56px);}
.video .vhead{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px;}
.video .vhead h3{font-size:clamp(21px,2.6vw,28px);font-style:italic;}
.video .vlink{font-family:var(--sans);font-weight:600;font-size:14px;color:var(--accent);}
.vframe{position:relative;aspect-ratio:16/9;border-radius:20px;overflow:hidden;border:1px solid var(--hair);cursor:pointer;background:linear-gradient(rgba(8,12,24,.34),rgba(8,12,24,.52)),url('https://i.ytimg.com/vi/4zt41ubpKLY/hqdefault.jpg');background-size:cover;background-position:center;display:flex;align-items:center;justify-content:center;}
.vframe .play{width:80px;height:80px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 20px 50px -16px color-mix(in srgb,var(--accent) 75%,transparent);transition:transform .4s var(--ease);}
.vframe:hover .play{transform:scale(1.08);}
.vframe iframe{position:absolute;inset:0;width:100%;height:100%;border:0;}

/* ---------- for you (brand panel) ---------- */
.foryou .panel{background:var(--brand);border-radius:26px;padding:clamp(44px,6vw,72px);position:relative;overflow:hidden;text-align:center;color:var(--on-brand);border:1px solid var(--brand-edge,transparent);}
.foryou .panel::before{content:"";position:absolute;inset:0;background:radial-gradient(70% 90% at 50% 0%,color-mix(in srgb,var(--accent) 16%,transparent),transparent 60%);}
.foryou .panel>*{position:relative;}
.foryou .panel .kicker{color:var(--accent);}
.foryou .panel h2{color:var(--on-brand);font-size:clamp(27px,3.8vw,42px);line-height:1.18;font-style:italic;margin:14px auto 22px;max-width:20ch;}
.foryou .panel p{font-family:var(--sans);color:color-mix(in srgb,var(--on-brand) 80%,transparent);font-size:16.5px;line-height:1.66;margin:0 auto 16px;max-width:680px;}
.foryou .panel p:last-child{margin-bottom:0;}

/* ---------- pricing ---------- */
.price-head{text-align:center;max-width:640px;margin:0 auto clamp(38px,5vw,56px);}
.price-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:880px;margin:0 auto;}
.pcard{position:relative;background:var(--panel);border:1px solid var(--hair);border-radius:22px;padding:40px 36px;display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s;}
.pcard:hover{transform:translateY(-4px);box-shadow:0 40px 80px -50px rgba(8,12,24,.5);}
.pcard.feat{border-color:var(--accent);box-shadow:0 30px 64px -46px color-mix(in srgb,var(--accent) 60%,transparent);}
.pcard .tag{position:absolute;top:-12px;left:36px;background:var(--accent);color:var(--on-accent);font-family:var(--sans);font-weight:600;font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:6px 13px;border-radius:100px;}
.pcard .k{font-family:var(--sans);font-weight:600;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--accent);}
.pcard .pname{font-size:24px;margin:10px 0 0;}
.pcard .amt{font-family:var(--serif);font-weight:600;font-size:clamp(44px,5.5vw,58px);line-height:1;margin:16px 0 4px;color:var(--fg);}
.pcard .amt .per{font-family:var(--sans);font-size:15px;color:var(--fg-muted);font-weight:500;}
.pcard .first{display:inline-block;font-family:var(--sans);font-weight:600;font-size:12.5px;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);padding:5px 11px;border-radius:100px;}
.pcard .pdesc{font-family:var(--sans);color:var(--fg-muted);font-size:15.5px;line-height:1.55;margin-top:16px;flex:1;}
.pcard .btn{margin-top:26px;width:100%;}
.includes{max-width:880px;margin:20px auto 0;border:1px solid var(--hair);border-radius:22px;background:var(--panel);padding:28px 34px;}
.includes .ih{font-family:var(--caps);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);text-align:center;margin-bottom:16px;}
.includes ul{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:1fr 1fr;gap:11px 28px;}
.includes li{position:relative;padding-left:26px;font-family:var(--sans);color:var(--fg-2);font-size:15px;line-height:1.5;}
.includes li::before{content:"";position:absolute;left:0;top:6px;width:15px;height:15px;border-radius:50%;background:var(--accent);}
.includes li::after{content:"";position:absolute;left:5px;top:9.5px;width:5px;height:3px;border-left:1.5px solid var(--on-accent);border-bottom:1.5px solid var(--on-accent);transform:rotate(-45deg);}
.finep{text-align:center;font-family:var(--sans);color:var(--fg-faint);font-size:14.5px;margin:22px auto 0;max-width:680px;}

/* ---------- testimonials ---------- */
.ts-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;}
.tscard{border:1.5px dashed var(--hair);border-radius:var(--r);padding:30px 28px;background:var(--panel);min-height:190px;display:flex;flex-direction:column;justify-content:space-between;}
.tscard .q{font-family:var(--serif);font-size:40px;line-height:.5;color:var(--accent);height:22px;}
.tscard .ph{font-family:var(--sans);color:var(--fg-faint);font-size:15.5px;line-height:1.5;}
.tscard .by{font-family:var(--sans);font-weight:600;font-size:13px;color:var(--fg-faint);}
.ts-note{text-align:center;font-family:var(--sans);color:var(--fg-faint);font-size:14px;margin-top:22px;}

/* ---------- faq ---------- */
.faq{max-width:840px;margin:0 auto;display:grid;gap:12px;}
.faq details{background:var(--panel);border:1px solid var(--hair);border-radius:14px;overflow:hidden;transition:border-color .3s;}
.faq details[open]{border-color:color-mix(in srgb,var(--accent) 40%,var(--hair));}
.faq summary{list-style:none;cursor:pointer;padding:22px 56px 22px 26px;position:relative;font-family:var(--sans);font-weight:600;font-size:17px;color:var(--fg);}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";position:absolute;right:22px;top:50%;transform:translateY(-50%);color:var(--accent);font-size:24px;transition:transform .3s var(--ease);}
.faq details[open] summary::after{transform:translateY(-50%) rotate(45deg);}
.faq .a{font-family:var(--sans);color:var(--fg-muted);font-size:15.5px;line-height:1.62;padding:0 26px 24px;}
.faq .a a{color:var(--accent);font-weight:600;}

/* ---------- contact ---------- */
.contact .panel{background:var(--brand);border-radius:28px;text-align:center;padding:clamp(52px,7vw,84px) 36px;color:var(--on-brand);position:relative;overflow:hidden;border:1px solid var(--brand-edge,transparent);}
.contact .panel::before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(closest-side,color-mix(in srgb,var(--accent) 20%,transparent),transparent 70%);top:-170px;left:50%;transform:translateX(-50%);}
.contact .panel>*{position:relative;}
.contact .badge-wrap{display:flex;justify-content:center;margin-bottom:20px;}
.contact h2{color:var(--on-brand);font-size:clamp(32px,4.6vw,52px);}
.contact p{font-family:var(--sans);max-width:580px;margin:18px auto 0;color:color-mix(in srgb,var(--on-brand) 84%,transparent);font-size:17px;line-height:1.6;}
.contact-cta{display:flex;gap:13px;justify-content:center;margin-top:32px;flex-wrap:wrap;}
.btn-onbrand{background:var(--accent);color:var(--on-accent);}
.btn-onbrand:hover{transform:translateY(-2px);box-shadow:0 18px 40px -16px color-mix(in srgb,var(--accent) 70%,transparent);}
.btn-clear{background:transparent;color:var(--on-brand);border-color:color-mix(in srgb,var(--on-brand) 40%,transparent);}
.btn-clear:hover{background:color-mix(in srgb,var(--on-brand) 14%,transparent);transform:translateY(-2px);}

/* ---------- footer (circle badge) ---------- */
.footer{background:var(--brand);color:var(--on-brand);text-align:center;padding:62px 0 52px;}
.footer .badge-wrap{display:flex;justify-content:center;margin-bottom:8px;}
.footer .far{font-family:'Amiri',serif;direction:rtl;color:var(--accent);font-size:clamp(23px,3vw,30px);margin-top:10px;}
.footer .frule{width:40px;height:1px;background:color-mix(in srgb,var(--on-brand) 20%,transparent);margin:22px auto;}
.footer .f1{font-family:var(--caps);font-size:12.5px;letter-spacing:.13em;text-transform:uppercase;}
.footer .f2{font-family:var(--sans);color:color-mix(in srgb,var(--on-brand) 55%,transparent);font-size:14px;margin-top:9px;}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(20px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}html{scroll-behavior:auto;}}

@media(max-width:980px){
  :root{--gut:26px;}
  .hero-grid,.about-grid,.feature-row,.blocks,.price-grid{grid-template-columns:1fr;}
  .stage{order:-1;max-width:520px;margin:0 auto;width:100%;}
  .bento,.teach-grid{grid-template-columns:1fr 1fr;}
  .tile.wide,.stat61{grid-column:span 2;}
  .includes ul{grid-template-columns:1fr;}
  .nav-links{display:none;}.nav-toggle{display:block;}
}
@media(max-width:560px){
  .bento,.teach-grid,.ts-grid{grid-template-columns:1fr;}
  .tile.wide,.stat61{grid-column:span 1;}
  .stat61{flex-direction:column;text-align:center;gap:12px;}
  .brand .b-stack{display:none;}
}
