/* ============================================================
   LessonEye — Design System
   ============================================================ */
:root{
  --ink:#0a1628; --ink-2:#0f1e36; --ink-3:#152945;
  --teal:#2dd4bf; --gold:#d4af37; --gold-soft:#e9c76a;
  --cream:#f5efe6; --mute:#8a95a8;
  --line:rgba(212,175,55,.18); --line-strong:rgba(212,175,55,.38);
  --danger:#f87171; --ok:#4ade80;
  --font-display:'Cormorant Garamond','Tajawal',serif;
  --font-body:'Tajawal','Inter',sans-serif;
  --font-latin:'Inter','Tajawal',sans-serif;
  --font-mono:'JetBrains Mono',monospace;
  --max:1280px; --radius:18px; --radius-sm:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--ink);color:var(--cream);line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
html[data-lang="en"] body{font-family:var(--font-latin);direction:ltr}
html[data-lang="en"]{direction:ltr}
img,svg{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,textarea,select{font:inherit;color:inherit}
.skip-link{position:absolute;top:-100px;left:0;background:var(--gold);color:var(--ink);padding:10px 16px;z-index:1000;font-weight:700}
.skip-link:focus{top:0}
.atmosphere{position:fixed;inset:0;z-index:-2;background:radial-gradient(1200px 600px at 80% -10%,rgba(45,212,191,.08),transparent 60%),radial-gradient(900px 500px at 10% 20%,rgba(212,175,55,.06),transparent 60%),radial-gradient(700px 400px at 50% 110%,rgba(45,212,191,.05),transparent 60%),linear-gradient(180deg,#081226 0%,#0a1628 50%,#0b172b 100%)}

/* Cookie banner */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;z-index:200;background:rgba(8,18,35,.96);backdrop-filter:blur(20px);border-top:1px solid var(--line-strong);padding:20px 28px;transform:translateY(100%);transition:transform .5s cubic-bezier(.2,.8,.2,1)}
.cookie-banner.show{transform:none}
.cookie-inner{max-width:var(--max);margin:0 auto;display:flex;gap:20px;align-items:center;flex-wrap:wrap;justify-content:space-between}
.cookie-text{flex:1;min-width:260px;font-size:.92rem;color:rgba(245,239,230,.85);line-height:1.6}
.cookie-text a{color:var(--gold-soft);text-decoration:underline;text-underline-offset:3px}
.cookie-actions{display:flex;gap:10px;flex-wrap:wrap}
.cookie-actions button{padding:10px 18px;border-radius:999px;font-size:.88rem;font-weight:500;transition:.25s;white-space:nowrap}
.cookie-accept{background:var(--gold);color:var(--ink);font-weight:700}
.cookie-accept:hover{background:var(--gold-soft)}
.cookie-decline{border:1px solid var(--line-strong);color:var(--cream)}

/* Nav */
.nav{position:sticky;top:0;z-index:100;backdrop-filter:blur(20px) saturate(1.4);background:rgba(10,22,40,.72);border-bottom:1px solid var(--line)}
.nav-inner{max-width:var(--max);margin:0 auto;padding:18px 28px;display:flex;align-items:center;gap:28px;justify-content:space-between}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{width:38px;height:38px;background:radial-gradient(circle at 30% 30%,var(--gold-soft),var(--gold) 60%,#8a6d18);border-radius:50%;position:relative;box-shadow:0 0 0 2px rgba(212,175,55,.15),inset 0 -4px 10px rgba(0,0,0,.3);flex-shrink:0}
.brand-mark::before{content:"";position:absolute;inset:0;border-radius:50%;background:radial-gradient(ellipse 60% 40% at 50% 50%,var(--ink) 0%,var(--ink) 38%,transparent 40%)}
.brand-mark::after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:10px;height:10px;border-radius:50%;background:var(--cream);box-shadow:0 0 12px rgba(245,239,230,.6)}
.brand-name{font-family:var(--font-display);font-size:1.35rem;font-weight:600;letter-spacing:.04em}
.brand-tag{font-size:.72rem;color:var(--mute);letter-spacing:.15em;text-transform:uppercase;display:block;margin-top:-4px}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-size:.92rem;color:var(--cream);opacity:.78;transition:.3s;padding:4px 0}
.nav-links a:hover{opacity:1;color:var(--gold-soft)}
.nav-cta{padding:10px 22px;border:1px solid var(--line-strong);border-radius:999px;font-size:.9rem;font-weight:500;background:linear-gradient(135deg,rgba(212,175,55,.12),rgba(45,212,191,.08));transition:.3s}
.nav-cta:hover{border-color:var(--gold);background:linear-gradient(135deg,rgba(212,175,55,.24),rgba(45,212,191,.18))}
.lang-toggle{display:flex;gap:4px;background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:999px;padding:3px}
.lang-toggle button{padding:5px 12px;border-radius:999px;font-size:.78rem;opacity:.6;transition:.3s;font-family:var(--font-latin)}
.lang-toggle button.active{background:var(--gold);color:var(--ink);opacity:1}
.menu-btn{display:none;font-size:1.4rem;padding:6px 10px;border-radius:8px;background:rgba(255,255,255,.05)}
@media(max-width:1000px){.nav-links{display:none;position:absolute;top:100%;right:0;left:0;flex-direction:column;padding:20px 28px;background:rgba(8,18,35,.98);border-bottom:1px solid var(--line);gap:18px}.nav-links.open{display:flex}.menu-btn{display:block}}

/* Hero */
.hero{max-width:var(--max);margin:0 auto;padding:100px 28px 80px;position:relative;min-height:85vh;display:grid;grid-template-columns:1.1fr .9fr;gap:60px;align-items:center}
@media(max-width:900px){.hero{grid-template-columns:1fr;padding:60px 24px 40px;gap:40px}}
.eyebrow{display:inline-flex;align-items:center;gap:10px;font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold-soft);font-weight:500;padding:8px 18px;border:1px solid var(--line);border-radius:999px;background:rgba(212,175,55,.05);margin-bottom:28px;font-family:var(--font-latin)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 12px var(--teal);animation:pulse 2s ease-in-out infinite}
@keyframes pulse{50%{opacity:.4}}
.hero h1{font-family:var(--font-display);font-size:clamp(2.8rem,6vw,5rem);line-height:1.02;font-weight:500;margin-bottom:28px}
html[data-lang="ar"] .hero h1{font-family:'Tajawal',sans-serif;font-weight:700;line-height:1.15}
.hero h1 .gold{color:var(--gold-soft);font-style:italic}
html[data-lang="ar"] .hero h1 .gold{font-style:normal;color:var(--gold)}
.hero h1 .teal{color:var(--teal)}
.hero h1 em{font-style:italic;font-weight:400;color:var(--cream);opacity:.8}
.hero p.lead{font-size:1.15rem;color:rgba(245,239,230,.75);max-width:56ch;margin-bottom:38px}
html[data-lang="ar"] .hero p.lead{font-size:1.12rem;line-height:1.9}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:10px;padding:14px 28px;border-radius:999px;font-weight:500;font-size:.95rem;transition:.35s cubic-bezier(.2,.8,.2,1);border:1px solid transparent}
.btn-primary{background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--ink);font-weight:700;box-shadow:0 10px 30px -8px rgba(212,175,55,.5)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 18px 40px -10px rgba(212,175,55,.7)}
.btn-ghost{border:1px solid var(--line-strong);color:var(--cream);background:rgba(255,255,255,.02)}
.btn-ghost:hover{background:rgba(212,175,55,.08);border-color:var(--gold)}
.btn:disabled{opacity:.6;cursor:not-allowed}
.hero-stats{display:flex;gap:40px;margin-top:56px;padding-top:32px;border-top:1px solid var(--line);flex-wrap:wrap}
.hero-stat strong{font-family:var(--font-display);font-size:2.2rem;color:var(--gold-soft);display:block;font-weight:600}
.hero-stat span{font-size:.78rem;color:var(--mute);letter-spacing:.12em;text-transform:uppercase;font-family:var(--font-latin)}

/* Eye */
.eye-stage{position:relative;aspect-ratio:1;max-width:520px;margin:0 auto;display:flex;align-items:center;justify-content:center}
.eye-orbit{position:absolute;inset:0;border:1px dashed var(--line);border-radius:50%;animation:spin 60s linear infinite}
.eye-orbit.inner{inset:12%;animation-duration:40s;animation-direction:reverse;border-color:var(--line-strong)}
.eye-orbit.outer{inset:-8%;animation-duration:80s}
@keyframes spin{to{transform:rotate(360deg)}}
.eye-orbit .node{position:absolute;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 16px var(--gold)}
.eye-orbit.outer .node:nth-child(1){top:-5px;left:20%}
.eye-orbit.outer .node:nth-child(2){top:30%;right:-5px;background:var(--teal);box-shadow:0 0 16px var(--teal)}
.eye-orbit.outer .node:nth-child(3){bottom:10%;left:60%}
.eye-orbit.inner .node:nth-child(1){top:15%;right:-4px;background:var(--teal)}
.eye-orbit.inner .node:nth-child(2){bottom:-4px;left:40%}
.eye{width:72%;aspect-ratio:2/1.1;background:radial-gradient(ellipse at center,#fef9e7 0%,#fff 40%,#cfc5a6 70%,#8a7a4a 100%);border-radius:50%;position:relative;box-shadow:0 0 80px rgba(212,175,55,.25),inset 0 -10px 30px rgba(0,0,0,.3),inset 0 10px 20px rgba(255,255,255,.5);overflow:hidden}
.iris{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:45%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle at 35% 35%,#5eead4 0%,#14b8a6 25%,#0d9488 55%,#0a1628 90%);box-shadow:inset 0 0 30px rgba(0,0,0,.6),0 0 40px rgba(45,212,191,.3)}
.pupil{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40%;aspect-ratio:1;border-radius:50%;background:#0a0a0a;box-shadow:inset 2px 2px 6px rgba(0,0,0,.8)}
.pupil::before{content:"";position:absolute;top:20%;left:20%;width:25%;height:25%;border-radius:50%;background:rgba(255,255,255,.9);filter:blur(1px)}

/* Sections */
.section{padding:120px 28px;max-width:var(--max);margin:0 auto}
@media(max-width:900px){.section{padding:80px 24px}}
.section-head{margin-bottom:64px;max-width:780px}
.section-label{font-size:.75rem;letter-spacing:.3em;text-transform:uppercase;color:var(--teal);font-family:var(--font-latin);font-weight:500;margin-bottom:16px;display:block}
.section-title{font-family:var(--font-display);font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.08;font-weight:500}
html[data-lang="ar"] .section-title{font-family:'Tajawal',sans-serif;font-weight:700;line-height:1.25}
.section-title em{font-style:italic;color:var(--gold-soft)}
html[data-lang="ar"] .section-title em{font-style:normal;color:var(--gold)}
.section-sub{color:rgba(245,239,230,.65);margin-top:18px;font-size:1.05rem;max-width:62ch}

/* Ads */
.ad-slot{max-width:var(--max);margin:40px auto;padding:0 28px}
.ad-inner{border:1px dashed var(--line);border-radius:var(--radius-sm);padding:24px;text-align:center;background:rgba(255,255,255,.02);position:relative;min-height:90px;display:flex;align-items:center;justify-content:center}
.ad-label{position:absolute;top:8px;right:12px;font-size:.62rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);font-family:var(--font-latin)}
html[data-lang="en"] .ad-label{right:auto;left:12px}
.ad-placeholder{color:var(--mute);font-size:.85rem;font-family:var(--font-latin)}

/* Subjects */
.subjects-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.subject{padding:32px 26px;background:var(--ink-2);transition:.4s;display:flex;flex-direction:column;gap:12px;min-height:160px}
.subject:hover{background:var(--ink-3);transform:translateY(-1px)}
.subject-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,rgba(212,175,55,.15),rgba(45,212,191,.1));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:1.4rem}
.subject-name{font-weight:700;font-size:1.05rem}
.subject-en{font-size:.78rem;color:var(--mute);font-family:var(--font-latin);letter-spacing:.05em;text-transform:uppercase}

/* Generator */
.generator{background:linear-gradient(160deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-strong);border-radius:var(--radius);padding:48px;box-shadow:0 0 0 1px var(--line-strong),0 20px 60px -20px rgba(212,175,55,.25);position:relative;overflow:hidden}
.generator::before{content:"";position:absolute;top:-100px;right:-100px;width:300px;height:300px;background:radial-gradient(circle,rgba(212,175,55,.15),transparent 70%);pointer-events:none}
@media(max-width:700px){.generator{padding:28px 22px}}
.gen-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:36px;gap:20px;flex-wrap:wrap;position:relative;z-index:1}
.gen-head h3{font-family:var(--font-display);font-size:2rem;font-weight:600}
html[data-lang="ar"] .gen-head h3{font-family:'Tajawal',sans-serif;font-weight:700}
.gen-head p{color:var(--mute);font-size:.95rem;margin-top:6px}
.gen-badge{padding:8px 16px;border-radius:999px;background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.3);color:var(--teal);font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;font-family:var(--font-latin);font-weight:500}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;position:relative;z-index:1}
@media(max-width:700px){.form-grid{grid-template-columns:1fr}}
.form-grid .full{grid-column:1/-1}
.field label{display:block;font-size:.82rem;color:var(--gold-soft);margin-bottom:8px;letter-spacing:.04em;font-weight:500}
.field input,.field select,.field textarea{width:100%;padding:14px 16px;background:rgba(8,18,35,.7);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--cream);font-size:.95rem;transition:.3s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(8,18,35,1);box-shadow:0 0 0 3px rgba(212,175,55,.1)}
.field textarea{resize:vertical;min-height:100px;font-family:inherit}
.field select{cursor:pointer;appearance:none}
.chip-group{display:flex;flex-wrap:wrap;gap:8px}
.chip{padding:8px 14px;border:1px solid var(--line);border-radius:999px;font-size:.82rem;background:rgba(255,255,255,.02);cursor:pointer;transition:.25s;user-select:none}
.chip:hover{border-color:var(--gold-soft)}
.chip.on{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:600}
.gen-actions{display:flex;gap:12px;margin-top:28px;flex-wrap:wrap;position:relative;z-index:1}
.gen-actions .btn{padding:16px 32px}

/* Output */
.output-block{margin-top:32px;background:rgba(8,18,35,.6);border:1px solid var(--line);border-radius:var(--radius);position:relative;z-index:1;display:none;overflow:hidden}
.output-block.show{display:block}
.output-header{padding:24px 32px;border-bottom:1px solid var(--line);background:rgba(0,0,0,.15)}
.output-header strong{font-family:var(--font-display);font-size:1.35rem;color:var(--gold-soft);font-weight:600}
html[data-lang="ar"] .output-header strong{font-family:'Tajawal',sans-serif;font-weight:700}
.output-meta{color:var(--mute);font-size:.85rem;margin-top:4px}
.format-tabs{display:flex;border-bottom:1px solid var(--line);overflow-x:auto;background:rgba(0,0,0,.1)}
.format-tab{padding:14px 20px;font-size:.88rem;border-bottom:2px solid transparent;transition:.25s;color:var(--mute);white-space:nowrap;display:flex;align-items:center;gap:8px;font-weight:500}
.format-tab:hover{color:var(--cream)}
.format-tab.on{color:var(--gold-soft);border-bottom-color:var(--gold);background:rgba(212,175,55,.04)}
.format-pane{padding:32px;display:none}
.format-pane.on{display:block}
.output-content{white-space:pre-wrap;line-height:1.9;color:rgba(245,239,230,.92);font-size:.98rem;max-height:600px;overflow-y:auto;padding-right:8px}
.output-content h1,.output-content h2,.output-content h3{font-family:var(--font-display);color:var(--gold-soft);margin:18px 0 10px;font-weight:600}
html[data-lang="ar"] .output-content h1,html[data-lang="ar"] .output-content h2,html[data-lang="ar"] .output-content h3{font-family:'Tajawal',sans-serif;font-weight:700}
.output-content h1{font-size:1.6rem}
.output-content h2{font-size:1.3rem;color:var(--teal);border-bottom:1px solid var(--line);padding-bottom:6px;margin-top:24px}
.output-content h3{font-size:1.1rem}
.output-content ul,.output-content ol{margin:10px 0;padding-inline-start:24px}
.output-content li{margin:6px 0}
.output-content strong{color:var(--cream);font-weight:700}
.export-card{padding:32px;border:1px solid var(--line);border-radius:var(--radius-sm);background:rgba(255,255,255,.02);margin-bottom:16px;display:flex;gap:20px;align-items:center;flex-wrap:wrap}
.export-icon{width:64px;height:64px;border-radius:12px;background:linear-gradient(135deg,rgba(212,175,55,.2),rgba(45,212,191,.15));border:1px solid var(--line);display:flex;align-items:center;justify-content:center;font-size:1.8rem;flex-shrink:0}
.export-info{flex:1;min-width:200px}
.export-info h5{font-size:1.1rem;font-weight:700;margin-bottom:4px}
.export-info p{font-size:.88rem;color:var(--mute);line-height:1.6}
.loader{display:inline-block;width:18px;height:18px;border:2px solid rgba(212,175,55,.2);border-top-color:var(--gold);border-radius:50%;animation:rot 1s linear infinite}
@keyframes rot{to{transform:rotate(360deg)}}
.status-msg{padding:12px 16px;border-radius:8px;font-size:.9rem;margin-top:14px;display:none}
.status-msg.err{display:block;background:rgba(248,113,113,.12);border:1px solid rgba(248,113,113,.4);color:#fca5a5}
.status-msg.ok{display:block;background:rgba(74,222,128,.12);border:1px solid rgba(74,222,128,.4);color:#86efac}
.status-msg.info{display:block;background:rgba(45,212,191,.1);border:1px solid rgba(45,212,191,.3);color:var(--teal)}

/* Frameworks */
.frameworks{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:40px}
.framework{padding:32px 28px;background:linear-gradient(180deg,var(--ink-2),var(--ink));border:1px solid var(--line);border-radius:var(--radius);transition:.35s;position:relative;overflow:hidden}
.framework:hover{border-color:var(--gold-soft);transform:translateY(-4px)}
.framework::before{content:"";position:absolute;top:0;right:0;width:80px;height:80px;background:radial-gradient(circle at top right,rgba(212,175,55,.2),transparent 70%)}
.framework .attribution{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);font-family:var(--font-latin);margin-bottom:6px;display:block}
.framework h4{font-size:1.2rem;margin:6px 0 10px;font-weight:700}
.framework .phases{display:flex;flex-wrap:wrap;gap:6px;margin-top:12px}
.framework .phase-tag{font-size:.7rem;padding:4px 9px;border-radius:999px;background:rgba(212,175,55,.08);border:1px solid var(--line);font-family:var(--font-latin)}
.framework p{color:var(--mute);font-size:.9rem;line-height:1.75;margin-top:12px}

/* Templates */
.tpl-tabs{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:28px;border-bottom:1px solid var(--line);padding-bottom:2px}
.tpl-tab{padding:10px 18px;font-size:.88rem;border-bottom:2px solid transparent;margin-bottom:-1px;transition:.25s;color:var(--mute)}
.tpl-tab.on{color:var(--gold-soft);border-bottom-color:var(--gold)}
.tpl-tab:hover{color:var(--cream)}
.tpl-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px}
.tpl-card{padding:24px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);transition:.3s;cursor:pointer;display:flex;flex-direction:column;gap:10px}
.tpl-card:hover{border-color:var(--gold);background:var(--ink-3);transform:translateY(-2px)}
.tpl-card h5{font-size:1rem;font-weight:700;color:var(--gold-soft)}
.tpl-card p{font-size:.88rem;color:var(--mute);line-height:1.6}
.tpl-card .tag{font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--teal);font-family:var(--font-latin);margin-top:auto}

/* Contact */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:40px}
.contact-card{padding:26px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);transition:.35s;display:flex;flex-direction:column;gap:10px}
.contact-card:hover{border-color:var(--gold);background:var(--ink-3)}
.contact-card .purpose{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--teal);font-family:var(--font-latin);font-weight:500}
.contact-card h5{font-size:1.1rem;font-weight:700}
.contact-card .email{font-family:var(--font-mono);font-size:.88rem;color:var(--gold-soft);word-break:break-all}
.contact-card p{font-size:.85rem;color:var(--mute);line-height:1.6}
.contact-form{margin-top:48px;padding:40px;background:linear-gradient(160deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-strong);border-radius:var(--radius)}
@media(max-width:700px){.contact-form{padding:24px 20px}}

/* Footer */
.footer{margin-top:80px;padding:60px 28px 30px;border-top:1px solid var(--line);background:rgba(8,14,26,.4)}
.footer-inner{max-width:var(--max);margin:0 auto;display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px}
@media(max-width:800px){.footer-inner{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.footer-inner{grid-template-columns:1fr}}
.footer h6{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px;font-family:var(--font-latin);font-weight:600}
.footer ul{list-style:none;display:flex;flex-direction:column;gap:10px}
.footer a{color:rgba(245,239,230,.7);font-size:.9rem;transition:.25s}
.footer a:hover{color:var(--gold-soft)}
.footer-brand p{color:var(--mute);font-size:.9rem;line-height:1.7;margin-top:14px;max-width:30ch}
.footer-bottom{max-width:var(--max);margin:40px auto 0;padding-top:24px;border-top:1px solid var(--line);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;color:var(--mute);font-size:.82rem}

.config-notice{max-width:var(--max);margin:0 auto;padding:14px 28px;background:rgba(212,175,55,.06);border-bottom:1px solid var(--line);font-size:.82rem;color:var(--gold-soft);text-align:center}
.config-notice.hidden{display:none}
.reveal{opacity:0;transform:translateY(24px);transition:opacity .8s,transform .8s}
.reveal.in{opacity:1;transform:none}
.hidden{display:none!important}
@media print{.nav,.footer,.cookie-banner,.ad-slot,.config-notice{display:none!important}body{background:#fff;color:#000}}

/* ============================================================
   v2 ADDITIONS — Logo, Auth, Dashboard, Modals, etc.
   ============================================================ */

/* Animated logo replacement for old brand-mark */
.brand-mark{position:relative;width:42px;height:42px;flex-shrink:0;background:none;box-shadow:none;border-radius:0}
.brand-mark::before,.brand-mark::after{display:none}
.brand-mark svg{width:100%;height:100%;display:block}

/* Footer brand */
.footer-brand .brand-mark{width:48px;height:48px}

/* Login button */
.btn-login{padding:8px 18px;border:1px solid var(--line-strong);border-radius:999px;font-size:.88rem;background:rgba(212,175,55,.08);color:var(--cream);transition:.3s;display:inline-flex;align-items:center;gap:6px;font-family:var(--font-latin)}
.btn-login:hover{background:var(--gold);color:var(--ink);border-color:var(--gold)}
.btn-login svg{width:14px;height:14px}

/* User avatar (when logged in) */
.user-chip{display:inline-flex;align-items:center;gap:8px;padding:5px 14px 5px 5px;border:1px solid var(--line-strong);border-radius:999px;background:rgba(212,175,55,.08);cursor:pointer;transition:.3s}
.user-chip:hover{background:rgba(212,175,55,.18)}
.user-avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold-soft));color:var(--ink);font-weight:700;display:flex;align-items:center;justify-content:center;font-size:.82rem}
.user-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}
.user-name{font-size:.85rem;color:var(--cream);max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* Dropdown menu */
.user-menu{position:absolute;top:calc(100% + 8px);left:0;min-width:240px;background:rgba(8,18,35,.98);backdrop-filter:blur(20px);border:1px solid var(--line-strong);border-radius:14px;box-shadow:0 20px 60px -10px rgba(0,0,0,.6);padding:8px;z-index:200;display:none;animation:fadeInDown .25s}
html[dir="rtl"] .user-menu{left:auto;right:0}
.user-menu.show{display:block}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:none}}
.user-menu-header{padding:14px;border-bottom:1px solid var(--line);margin-bottom:6px}
.user-menu-header strong{display:block;color:var(--cream);font-size:.95rem;margin-bottom:2px}
.user-menu-header span{display:block;color:var(--mute);font-size:.78rem}
.user-menu-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:8px;font-size:.88rem;color:var(--cream);cursor:pointer;transition:.2s}
.user-menu-item:hover{background:rgba(212,175,55,.1);color:var(--gold-soft)}
.user-menu-item.danger:hover{background:rgba(248,113,113,.12);color:#fca5a5}
.user-menu-item svg{width:16px;height:16px;opacity:.7}

/* Modal overlay */
.modal-overlay{position:fixed;inset:0;background:rgba(8,18,35,.85);backdrop-filter:blur(8px);z-index:300;display:none;align-items:center;justify-content:center;padding:20px;animation:fadeIn .3s}
.modal-overlay.show{display:flex}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal{background:linear-gradient(160deg,var(--ink-2),var(--ink-3));border:1px solid var(--line-strong);border-radius:var(--radius);max-width:480px;width:100%;max-height:90vh;overflow-y:auto;animation:scaleIn .3s}
@keyframes scaleIn{from{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}
.modal-header{padding:24px 28px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center}
.modal-header h3{font-family:var(--font-display);font-size:1.6rem;color:var(--gold-soft);font-weight:600}
html[dir="rtl"] .modal-header h3{font-family:'Tajawal',sans-serif;font-weight:700}
.modal-close{width:32px;height:32px;border-radius:50%;background:rgba(255,255,255,.05);font-size:1.2rem;display:flex;align-items:center;justify-content:center;transition:.2s}
.modal-close:hover{background:rgba(248,113,113,.18);color:#fca5a5}
.modal-body{padding:28px}
.modal-footer{padding:0 28px 28px}

/* Auth tabs */
.auth-tabs{display:flex;border-bottom:1px solid var(--line);margin-bottom:24px}
.auth-tab{flex:1;padding:12px;font-weight:500;color:var(--mute);border-bottom:2px solid transparent;transition:.25s}
.auth-tab.on{color:var(--gold-soft);border-bottom-color:var(--gold)}
.auth-tab:hover{color:var(--cream)}

/* Google sign-in button */
.btn-google{width:100%;padding:14px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:rgba(255,255,255,.04);color:var(--cream);font-weight:500;display:flex;align-items:center;justify-content:center;gap:10px;transition:.25s}
.btn-google:hover{background:rgba(255,255,255,.08);border-color:var(--gold-soft)}
.btn-google svg{width:18px;height:18px}

.divider{display:flex;align-items:center;gap:14px;margin:20px 0;color:var(--mute);font-size:.78rem;text-transform:uppercase;letter-spacing:.15em;font-family:var(--font-latin)}
.divider::before,.divider::after{content:"";flex:1;height:1px;background:var(--line)}

.auth-switch{text-align:center;margin-top:18px;font-size:.88rem;color:var(--mute)}
.auth-switch a{color:var(--gold-soft);cursor:pointer;text-decoration:underline;text-underline-offset:3px}

/* Usage badge */
.usage-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 11px;border-radius:999px;background:rgba(45,212,191,.12);border:1px solid rgba(45,212,191,.3);font-size:.72rem;color:var(--teal);font-family:var(--font-latin);font-weight:500;letter-spacing:.05em}
.usage-badge.warn{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.4);color:#fca5a5}

/* Dashboard / My Lessons */
.dashboard{padding:60px 28px;max-width:var(--max);margin:0 auto;display:none}
.dashboard.show{display:block;animation:fadeIn .4s}
.dashboard-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px;flex-wrap:wrap;gap:16px}
.dashboard-head h2{font-family:var(--font-display);font-size:2rem;color:var(--gold-soft);font-weight:600}
html[dir="rtl"] .dashboard-head h2{font-family:'Tajawal',sans-serif;font-weight:700}
.stat-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:28px}
.stat-card{padding:20px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm)}
.stat-card .num{font-family:var(--font-display);font-size:2rem;color:var(--gold-soft);font-weight:600;line-height:1}
.stat-card .label{font-size:.78rem;color:var(--mute);text-transform:uppercase;letter-spacing:.1em;margin-top:6px;font-family:var(--font-latin)}
.lesson-list{display:grid;gap:12px}
.lesson-item{padding:18px 22px;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:space-between;gap:14px;transition:.25s;cursor:pointer}
.lesson-item:hover{background:var(--ink-3);border-color:var(--gold-soft)}
.lesson-info h5{font-size:1rem;font-weight:700;margin-bottom:4px}
.lesson-info span{font-size:.82rem;color:var(--mute)}
.lesson-actions{display:flex;gap:8px}
.lesson-actions button{padding:7px 12px;border-radius:8px;font-size:.78rem;border:1px solid var(--line);transition:.2s}
.lesson-actions button:hover{border-color:var(--gold);background:rgba(212,175,55,.08)}
.lesson-actions .danger:hover{border-color:#f87171;color:#fca5a5;background:rgba(248,113,113,.08)}

.empty-state{text-align:center;padding:60px 20px;color:var(--mute)}
.empty-state svg{width:64px;height:64px;opacity:.5;margin:0 auto 18px}

/* BYOK input */
.byok-section{background:rgba(45,212,191,.05);border:1px solid rgba(45,212,191,.25);border-radius:var(--radius-sm);padding:22px;margin-top:20px}
.byok-section h4{color:var(--teal);font-size:1.05rem;margin-bottom:8px}
.byok-section p{color:var(--mute);font-size:.85rem;line-height:1.7;margin-bottom:14px}
.byok-section a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}
.byok-input-row{display:flex;gap:8px}
.byok-input-row input{flex:1}
.byok-input-row button{padding:10px 18px;border-radius:var(--radius-sm);background:var(--teal);color:var(--ink);font-weight:600;white-space:nowrap}
.byok-input-row button:hover{background:#5eead4}

/* About page styles */
.about-hero{max-width:var(--max);margin:0 auto;padding:80px 28px 40px;text-align:center}
.about-hero .eyebrow{margin:0 auto 28px}
.about-hero h1{font-family:var(--font-display);font-size:clamp(2.4rem,5vw,3.8rem);line-height:1.1;font-weight:500;margin-bottom:22px}
html[dir="rtl"] .about-hero h1{font-family:'Tajawal',sans-serif;font-weight:700}
.about-hero h1 em{color:var(--gold-soft);font-style:italic}
html[dir="rtl"] .about-hero h1 em{font-style:normal;color:var(--gold)}
.about-hero p{font-size:1.18rem;color:rgba(245,239,230,.78);max-width:62ch;margin:0 auto;line-height:1.85}

.about-section{max-width:920px;margin:0 auto;padding:60px 28px}
.about-section h2{font-family:var(--font-display);font-size:2.2rem;color:var(--gold-soft);font-weight:600;margin-bottom:24px}
html[dir="rtl"] .about-section h2{font-family:'Tajawal',sans-serif;font-weight:700}
.about-section p{font-size:1.05rem;color:rgba(245,239,230,.82);line-height:1.95;margin-bottom:18px}
.about-section blockquote{border-inline-start:3px solid var(--gold);padding-inline-start:24px;margin:30px 0;font-style:italic;font-size:1.15rem;color:var(--cream);font-family:var(--font-display)}
html[dir="rtl"] .about-section blockquote{font-family:'Tajawal',sans-serif;font-style:normal}

.values-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-top:30px}
.value-card{padding:28px;background:linear-gradient(180deg,var(--ink-2),var(--ink-3));border:1px solid var(--line);border-radius:var(--radius);transition:.3s}
.value-card:hover{border-color:var(--gold-soft);transform:translateY(-3px)}
.value-card .icon{font-size:2rem;margin-bottom:14px;display:block}
.value-card h4{font-size:1.1rem;font-weight:700;margin-bottom:8px}
.value-card p{color:var(--mute);font-size:.92rem;line-height:1.7}

/* Quad language toggle */
.lang-toggle{flex-wrap:wrap}
.lang-toggle button{padding:5px 10px;font-size:.76rem;min-width:30px}

/* Lock icon for locked features */
.locked{position:relative;opacity:.6;pointer-events:none}
.locked::after{content:"🔒";position:absolute;top:8px;right:8px;font-size:.9rem}
html[dir="rtl"] .locked::after{right:auto;left:8px}

/* Toast notifications */
.toast-container{position:fixed;top:90px;right:20px;z-index:400;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}
html[dir="rtl"] .toast-container{right:auto;left:20px}
.toast{padding:14px 20px;border-radius:var(--radius-sm);background:rgba(8,18,35,.96);backdrop-filter:blur(10px);border:1px solid var(--line-strong);box-shadow:0 10px 30px -10px rgba(0,0,0,.6);font-size:.9rem;animation:slideInRight .35s;pointer-events:auto}
html[dir="rtl"] .toast{animation:slideInLeft .35s}
@keyframes slideInRight{from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:none}}
@keyframes slideInLeft{from{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:none}}
.toast.success{border-color:rgba(74,222,128,.5);background:rgba(20,40,28,.96)}
.toast.error{border-color:rgba(248,113,113,.5);background:rgba(40,20,20,.96)}
.toast.info{border-color:rgba(45,212,191,.5);background:rgba(20,30,40,.96)}

/* Donation widget (small) */
.donate-banner{margin:30px auto;max-width:var(--max);padding:0 28px}
.donate-inner{padding:18px 24px;background:linear-gradient(135deg,rgba(212,175,55,.08),rgba(45,212,191,.05));border:1px solid var(--line);border-radius:var(--radius-sm);display:flex;align-items:center;gap:16px;flex-wrap:wrap;justify-content:space-between}
.donate-inner .text{flex:1;min-width:200px}
.donate-inner h4{font-size:1rem;color:var(--gold-soft);font-weight:700;margin-bottom:4px}
.donate-inner p{font-size:.85rem;color:var(--mute);line-height:1.6}
.donate-inner a{padding:9px 18px;border-radius:999px;background:var(--gold);color:var(--ink);font-weight:700;font-size:.88rem;white-space:nowrap}

/* Privacy/Terms compact */
.legal-page{max-width:820px;margin:0 auto;padding:80px 28px}
.legal-page .lang-switch{margin-bottom:20px;display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}
.legal-page .lang-switch button{padding:6px 14px;border:1px solid var(--line);border-radius:999px;background:rgba(255,255,255,.04);color:var(--cream);cursor:pointer;font-size:.82rem;font-family:var(--font-latin)}
.legal-page .lang-switch button.on{background:var(--gold);color:var(--ink);border-color:var(--gold);font-weight:700}
.back-link{display:inline-block;margin-bottom:24px;color:var(--gold-soft);font-size:.9rem}
.section-en,.section-ar,.section-fr,.section-hi{display:none}
.section-ar.show,.section-en.show,.section-fr.show,.section-hi.show{display:block}

/* RTL fixes for Hindi (LTR) */
html[lang="hi"]{direction:ltr}
html[lang="hi"] body{direction:ltr;font-family:'Inter','Tajawal',sans-serif}
html[lang="fr"]{direction:ltr}
html[lang="fr"] body{direction:ltr;font-family:var(--font-latin)}

