*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#132573;--navy-dark:#0b1a50;--navy-light:#1e3a9e;
  --coral:#FF8D8D;--slate:#2A3D53;--light:#F5F7FF;
  --white:#ffffff;--text:#2E3031;--muted:#6b7280;
  --border:rgba(19,37,115,0.12);--radius:14px;
  --shadow:0 4px 24px rgba(19,37,115,0.10);
  --purple:#7c3aed;--purple-light:#a78bfa;--purple-bg:rgba(124,58,237,0.08);
  --green:#16a34a;--amber:#b45309;
}
html{scroll-behavior:smooth}

/* ══ LOGIN PAGE ══ */
#auth-gate{
  position:fixed;inset:0;z-index:99999;
  background:linear-gradient(135deg,#0f1e6b 0%,#1e3a9e 50%,#2A3D53 100%);
  display:flex;align-items:center;justify-content:center;padding:1rem;
}
#auth-gate.hidden{display:none}
.auth-card{
  background:#fff;border-radius:24px;padding:2.5rem 2.2rem;
  width:100%;max-width:420px;
  box-shadow:0 24px 80px rgba(0,0,0,0.35);
  animation:loginIn .4s cubic-bezier(.22,1,.36,1);
}
@keyframes loginIn{from{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}
.auth-logo{display:flex;align-items:center;justify-content:center;gap:8px;margin-bottom:0.5rem;font-size:1.75rem;font-weight:800;color:var(--navy);font-family:'Sora',sans-serif;}
.auth-logo i{color:var(--coral)}.auth-logo span{color:var(--coral)}
.auth-subtitle{text-align:center;color:var(--muted);font-size:0.85rem;margin-bottom:1.5rem;}
.auth-tabs{display:flex;background:var(--light);border-radius:10px;padding:4px;margin-bottom:1.5rem;gap:4px;}
.auth-tab{flex:1;padding:0.55rem 1rem;border:none;border-radius:8px;font-family:'Sora',sans-serif;font-size:0.88rem;font-weight:600;cursor:pointer;transition:all .2s;background:transparent;color:var(--muted);}
.auth-tab.active{background:#fff;color:var(--navy);box-shadow:0 1px 4px rgba(0,0,0,0.1);}
.auth-form{display:flex;flex-direction:column;gap:0.9rem;}
.auth-label{font-size:0.8rem;font-weight:600;color:var(--text);margin-bottom:4px;display:block;}
.auth-input{border:1.5px solid var(--border);border-radius:10px;padding:0.65rem 0.9rem;font-size:0.9rem;font-family:'Sora',sans-serif;outline:none;transition:border-color .2s;width:100%;box-sizing:border-box;}
.auth-input:focus{border-color:var(--navy);}
.auth-btn{width:100%;background:var(--navy);color:#fff;border:none;border-radius:10px;padding:0.75rem;font-size:0.95rem;font-weight:700;font-family:'Sora',sans-serif;cursor:pointer;transition:opacity .2s,transform .15s;margin-top:0.25rem;}
.auth-btn:hover{opacity:.9;transform:translateY(-1px);}
.auth-btn.secondary{background:var(--light);color:var(--navy);border:1.5px solid var(--border);margin-top:0;}
.auth-btn.secondary:hover{background:#e8ecf8;}
.auth-error{background:rgba(220,38,38,.09);border:1px solid rgba(220,38,38,.2);border-radius:8px;padding:.6rem .9rem;font-size:.82rem;color:#b91c1c;display:none;}
.auth-error.show{display:block;}
.auth-success{background:rgba(22,163,74,.09);border:1px solid rgba(22,163,74,.2);border-radius:8px;padding:.6rem .9rem;font-size:.82rem;color:#15803d;display:none;}
.auth-success.show{display:block;}
/* ═══ COMPTE DROPDOWN ═══ */
.compte-dropdown{position:relative}
.compte-btn{display:inline-flex;align-items:center;gap:6px}
.compte-menu{position:fixed;right:1.5%;top:72px;background:#fff;border:1.5px solid var(--border);border-radius:18px;box-shadow:0 16px 48px rgba(19,37,115,0.16),0 2px 8px rgba(19,37,115,0.08);min-width:260px;z-index:99999;padding:0.5rem 0.5rem 0.6rem;animation:loginIn .25s ease}
.compte-info{display:flex;align-items:center;gap:12px;padding:0.75rem 0.8rem 0.7rem;background:linear-gradient(135deg,rgba(19,37,115,0.04),rgba(124,58,237,0.04));border-radius:12px;margin-bottom:0.2rem}
.compte-avatar{width:44px;height:44px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--navy));color:#fff;font-weight:800;font-size:1.1rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px rgba(19,37,115,0.25)}
.compte-name{font-weight:800;color:var(--navy);font-size:0.94rem;line-height:1.2}
.compte-email{color:var(--muted);font-size:0.75rem;margin-top:3px;word-break:break-all}
.compte-sep{border:none;border-top:1px solid var(--border);margin:0.4rem 0.3rem}
.compte-item{display:flex;align-items:center;gap:9px;width:100%;background:none;border:none;border-radius:9px;padding:0.55rem 0.8rem;font-size:0.86rem;font-weight:600;color:var(--text);font-family:'Sora',sans-serif;cursor:pointer;transition:background .15s,color .15s,transform .1s;text-align:left}
.compte-item:hover{background:var(--light);color:var(--navy);transform:translateX(2px)}
.compte-item i{opacity:0.7}
.compte-item:hover i{opacity:1}
.compte-item.compte-danger{color:#b91c1c;margin-top:1px}
.compte-item.compte-danger:hover{background:#fef2f2;color:#991b1b;transform:translateX(2px)}
/* Mobile compte info */
.mob-compte-info{display:flex;align-items:center;gap:10px;padding:0.7rem 1.2rem;background:var(--light);border-radius:10px;margin:0.3rem 0}
.mob-compte-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--navy));color:#fff;font-weight:700;font-size:0.9rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.mob-compte-name{font-weight:700;color:var(--navy);font-size:0.88rem}
.mob-compte-email{color:var(--muted);font-size:0.74rem;word-break:break-all}
/* Confirm modal */
.delete-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:2000;display:flex;align-items:center;justify-content:center}
.delete-modal{background:#fff;border-radius:16px;padding:2rem 1.75rem;max-width:360px;width:90%;box-shadow:0 12px 48px rgba(0,0,0,0.18);animation:loginIn .3s ease}
.delete-modal h3{font-size:1.15rem;font-weight:800;color:var(--navy);margin-bottom:0.5rem}
.delete-modal p{color:var(--muted);font-size:0.88rem;line-height:1.55;margin-bottom:1.25rem}
.delete-modal-btns{display:flex;gap:0.7rem}
.delete-modal-btns button{flex:1;padding:0.65rem;border-radius:10px;border:none;font-family:'Sora',sans-serif;font-weight:700;font-size:0.9rem;cursor:pointer;transition:opacity .2s}
.delete-modal-btns .del-cancel{background:var(--light);color:var(--navy);border:1.5px solid var(--border)}
.delete-modal-btns .del-confirm{background:#dc2626;color:#fff}
.delete-modal-btns button:hover{opacity:.88}
.plan-badges{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:1.25rem;}
.plan-badge{font-size:0.75rem;font-weight:600;padding:5px 14px;border-radius:50px;display:inline-flex;align-items:center;gap:6px;}
.plan-badge.free{background:rgba(22,163,74,.12);color:#15803d;border:1px solid rgba(22,163,74,.25);}
.plan-badge.premium{background:rgba(245,158,11,.12);color:#b45309;border:1px solid rgba(245,158,11,.25);}

body{font-family:'Sora',sans-serif;color:var(--text);background:var(--white);line-height:1.6;overflow-x:hidden}
mjx-container{color:inherit}
.adv-msg-bubble mjx-container{color:rgba(255,255,255,0.88)}

/* Lucide icon sizing */
.icon-sm { width:16px;height:16px;display:inline-block;vertical-align:middle;flex-shrink:0; }
.icon-md { width:20px;height:20px;display:inline-block;vertical-align:middle;flex-shrink:0; }
.icon-lg { width:28px;height:28px;display:inline-block;vertical-align:middle;flex-shrink:0; }
.icon-xl { width:36px;height:36px;display:inline-block;vertical-align:middle;flex-shrink:0; }
.icon-2xl { width:48px;height:48px;display:inline-block;vertical-align:middle;flex-shrink:0; }
i[data-lucide] { display:inline-flex;align-items:center;justify-content:center; }

nav.main-nav{position:sticky;top:0;z-index:200;background:var(--white);border-bottom:1px solid var(--border);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-logo{font-size:1.5rem;font-weight:800;color:var(--navy);text-decoration:none;letter-spacing:-0.5px;cursor:pointer;background:none;border:none;font-family:'Sora',sans-serif;display:flex;align-items:center;gap:8px}
.nav-logo img.logo-img{width:36px;height:36px;object-fit:contain;border-radius:6px}
.nav-logo span{color:var(--coral)}
.nav-links{display:flex;align-items:center;gap:1.2rem}
.nav-links a,.nav-links button{text-decoration:none;color:var(--text);font-size:0.88rem;font-weight:500;transition:color .2s;background:none;border:none;cursor:pointer;font-family:'Sora',sans-serif;display:inline-flex;align-items:center;gap:5px}
.nav-links a:hover,.nav-links button:hover{color:var(--navy)}
.nav-talaba-btn{display:inline-flex;align-items:center;gap:6px;background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff!important;border-radius:8px;padding:0.38rem 0.95rem;font-size:0.8rem;font-weight:700;border:none;cursor:pointer;font-family:'Sora',sans-serif;transition:transform .15s,box-shadow .15s,opacity .15s;box-shadow:0 3px 12px rgba(239,68,68,0.4)}
.nav-talaba-btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(239,68,68,0.55);opacity:.93}

.btn{display:inline-block;padding:0.5rem 1.3rem;border-radius:8px;font-size:0.85rem;font-weight:600;text-decoration:none;cursor:pointer;transition:transform .15s,box-shadow .15s;border:none;font-family:'Sora',sans-serif}
.btn:hover{transform:translateY(-1px);box-shadow:0 6px 20px rgba(19,37,115,0.18)}
.btn-primary{background:var(--navy);color:#fff}
.btn-outline{background:transparent;color:var(--navy);border:1.5px solid var(--navy)}
.btn-coral{background:var(--coral);color:#fff}
.btn-purple{background:var(--purple);color:#fff}

.page{display:none}
.page.active{display:block}

.hero{min-height:92vh;background:linear-gradient(135deg,#0f1e6b 0%,#1e3a9e 50%,#2A3D53 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5rem 5%;position:relative;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% 30%,rgba(255,141,141,0.12) 0%,transparent 70%)}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.12);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.2);border-radius:50px;padding:0.4rem 1rem;color:rgba(255,255,255,0.9);font-size:0.8rem;font-weight:500;letter-spacing:0.04em;text-transform:uppercase;margin-bottom:1.5rem}
.hero h1{font-size:clamp(2.5rem,6vw,4.5rem);font-weight:800;color:#fff;line-height:1.1;letter-spacing:-1px;max-width:850px;margin-bottom:1.25rem}
.hero h1 em{color:var(--coral);font-style:normal}
.hero p{font-size:1.1rem;color:rgba(255,255,255,0.75);max-width:580px;margin-bottom:2.5rem}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;justify-content:center}
.hero-btn-coral{background:var(--coral);color:#fff;border:none;border-radius:8px;padding:0.7rem 1.6rem;font-size:0.95rem;font-weight:700;cursor:pointer;font-family:'Sora',sans-serif;transition:transform .15s,box-shadow .15s,opacity .15s;box-shadow:0 4px 18px rgba(255,141,141,0.35);display:inline-flex;align-items:center;gap:8px}
.hero-btn-coral:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(255,141,141,0.5);opacity:0.95}
.hero-btn-ghost{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,0.4);border-radius:8px;padding:0.7rem 1.6rem;font-size:0.95rem;font-weight:600;cursor:pointer;font-family:'Sora',sans-serif;transition:background .2s,border-color .2s,transform .15s;display:inline-flex;align-items:center;gap:8px}
.hero-btn-ghost:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.7);transform:translateY(-2px)}
.hero-stats{display:flex;gap:2.5rem;margin-top:4rem;flex-wrap:wrap;justify-content:center}
.hero-stat .num{font-size:2rem;font-weight:800;color:#fff;line-height:1}
.hero-stat .label{font-size:0.78rem;color:rgba(255,255,255,0.6);margin-top:4px}

section{padding:5rem 5%}
.section-inner{max-width:1200px;margin:0 auto}
.section-label{font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--navy);margin-bottom:0.75rem}
h2{font-size:clamp(1.8rem,4vw,2.8rem);font-weight:800;color:var(--slate);line-height:1.2;letter-spacing:-0.5px;margin-bottom:1rem}
h2 em{color:var(--navy);font-style:normal}
.section-desc{color:var(--muted);font-size:1rem;max-width:560px;margin-bottom:3rem}

#ecoles{background:var(--light)}
.schools-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1.25rem}
.school-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem 1.25rem;text-align:center;color:var(--text);transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column;align-items:center;gap:0.85rem;cursor:pointer}
.school-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:rgba(19,37,115,0.25)}
.school-logo-wrap{width:72px;height:72px;border-radius:12px;background:var(--light);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}
.school-logo-wrap img{width:100%;height:100%;object-fit:contain;padding:6px}
.school-icon-wrap{width:72px;height:72px;border-radius:12px;background:var(--light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.school-name{font-size:0.95rem;font-weight:700;color:var(--navy)}
.school-tag{font-size:0.72rem;color:var(--muted);background:var(--light);border-radius:50px;padding:3px 10px}

.features-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:1.5rem}
.feature-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:1.75rem 1.5rem}
.feature-icon{width:44px;height:44px;background:rgba(19,37,115,0.08);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1rem;color:var(--navy)}
.feature-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:0.5rem}
.feature-card p{font-size:0.88rem;color:var(--muted)}

.arabic-banner{background:var(--navy);color:#fff;text-align:center;padding:4rem 5%;direction:rtl}
.arabic-banner h2{font-family:'Noto Kufi Arabic',sans-serif;color:#fff;font-size:clamp(1.5rem,4vw,2.5rem);margin-bottom:1.5rem}
.arabic-banner p{font-family:'Noto Kufi Arabic',sans-serif;color:rgba(255,255,255,0.75);font-size:1rem;max-width:560px;margin:0 auto 2rem}
.btn-arabic{background:var(--coral);color:#fff;border-radius:8px;padding:0.6rem 1.6rem;font-family:'Noto Kufi Arabic',sans-serif;font-size:0.9rem;font-weight:700;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:transform .15s}
.btn-arabic:hover{transform:translateY(-1px)}

.blog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.75rem}
.article-card{border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;text-decoration:none;color:var(--text);transition:transform .2s,box-shadow .2s;background:#fff;display:flex;flex-direction:column}
.article-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.article-card-header{padding:1.5rem 1.5rem 1rem;background:linear-gradient(135deg,#0f1e6b,#1e3a9e);position:relative;min-height:110px;display:flex;flex-direction:column;justify-content:flex-end}
.article-school-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(255,255,255,0.15);border:1px solid rgba(255,255,255,0.25);border-radius:50px;padding:3px 10px;font-size:0.7rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:0.06em;margin-bottom:0.6rem;width:fit-content}
.article-card-header h3{font-size:1.05rem;font-weight:700;color:#fff;line-height:1.35}
.article-card-body{padding:1.2rem 1.5rem;flex:1;display:flex;flex-direction:column;gap:0.85rem}
.article-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.article-pill{display:inline-flex;align-items:center;gap:5px;background:var(--light);border:1px solid var(--border);border-radius:50px;padding:3px 10px;font-size:0.72rem;font-weight:600;color:var(--navy)}
.article-pill.green{background:rgba(22,163,74,0.1);border-color:rgba(22,163,74,0.2);color:#166534}
.article-pill.amber{background:rgba(245,158,11,0.1);border-color:rgba(245,158,11,0.2);color:#b45309}
.article-pill.red{background:rgba(220,38,38,0.1);border-color:rgba(220,38,38,0.2);color:#991b1b}
.article-desc{font-size:0.84rem;color:var(--muted);line-height:1.55}
.article-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.article-info-item{background:var(--light);border-radius:8px;padding:0.6rem 0.8rem}
.article-info-item .label{font-size:0.68rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:0.06em}
.article-info-item .value{font-size:0.82rem;font-weight:700;color:var(--navy);margin-top:2px}
.article-card-footer{padding:0.9rem 1.5rem;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.article-source{font-size:0.72rem;color:var(--muted);display:flex;align-items:center;gap:5px}
.article-cta{font-size:0.78rem;font-weight:600;color:var(--navy);text-decoration:none;display:flex;align-items:center;gap:4px;transition:gap .15s}
.article-cta:hover{gap:8px}
.article-links-row{display:flex;gap:6px;flex-wrap:wrap;padding:0 1.5rem 0.85rem}
.art-link-btn{display:inline-flex;align-items:center;gap:5px;background:var(--light);border:1.5px solid var(--border);border-radius:6px;padding:4px 10px;font-size:0.7rem;font-weight:600;color:var(--navy);text-decoration:none;transition:background .15s,border-color .15s;cursor:pointer}
.art-link-btn:hover{background:rgba(19,37,115,0.08);border-color:rgba(19,37,115,0.3)}
.art-link-btn.yt{background:rgba(255,0,0,0.06);border-color:rgba(255,0,0,0.18);color:#c00}
.art-link-btn.yt:hover{background:rgba(255,0,0,0.12)}

#videos{background:var(--slate)}
.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(440px,1fr));gap:1.75rem}
.video-wrap{border-radius:var(--radius);overflow:hidden;border:1px solid rgba(255,255,255,0.1)}
.video-label{padding:0.75rem 1rem;background:rgba(255,255,255,0.06);font-size:0.82rem;font-weight:600;color:rgba(255,255,255,0.8);display:flex;align-items:center;gap:10px}
.video-play-dot{width:22px;height:22px;border-radius:50%;background:var(--coral);color:#fff;display:flex;align-items:center;justify-content:center;font-size:0.55rem;flex-shrink:0}
.video-wrap iframe{width:100%;aspect-ratio:16/9;display:block;border:none}

.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.contact-info h3{font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:1rem}
.contact-info p{color:var(--muted);font-size:0.9rem;margin-bottom:0.5rem;display:flex;align-items:center;gap:8px}
.contact-info a{color:var(--navy)}
.contact-form{display:flex;flex-direction:column;gap:1rem}
.form-group{display:flex;flex-direction:column;gap:5px}
label{font-size:0.82rem;font-weight:600;color:var(--text)}
input,textarea{padding:0.6rem 0.9rem;font-size:0.9rem;border:1px solid var(--border);border-radius:8px;font-family:'Sora',sans-serif;color:var(--text);background:#fff;width:100%;transition:border-color .2s;outline:none}
input:focus,textarea:focus{border-color:var(--navy)}
textarea{resize:vertical;min-height:120px}

footer{background:var(--navy-dark);color:rgba(255,255,255,0.7);padding:3rem 5%}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr;gap:2.5rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(255,255,255,0.1)}
.footer-brand p{font-size:0.85rem;margin-top:0.75rem;max-width:340px}
.footer-logo{font-size:1.4rem;font-weight:800;color:#fff;text-decoration:none;background:none;border:none;cursor:pointer;font-family:'Sora',sans-serif;display:flex;align-items:center;gap:8px}
.footer-logo img{width:30px;height:30px;object-fit:contain;border-radius:4px}
.footer-logo span{color:var(--coral)}
.footer-col h4{font-size:0.82rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:1rem}
.footer-col a,.footer-col button{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,0.6);text-decoration:none;font-size:0.85rem;margin-bottom:0.5rem;transition:color .2s;background:none;border:none;cursor:pointer;font-family:'Sora',sans-serif;text-align:left}
.footer-col a:hover,.footer-col button:hover{color:#fff}
.footer-socials{display:flex;gap:10px;margin-top:1rem;flex-wrap:wrap}
.social-icon{width:34px;height:34px;border-radius:8px;background:rgba(255,255,255,0.08);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,0.7);text-decoration:none;font-size:0.85rem;transition:background .2s,color .2s}
.social-icon:hover{background:var(--coral);color:#fff}
.footer-bottom{max-width:1200px;margin:1.5rem auto 0;font-size:0.8rem;color:rgba(255,255,255,0.4);text-align:center}

#leaderboard-page{background:var(--light);min-height:100vh}
.lb-hero{background:linear-gradient(135deg,#0f1e6b,#1e3a9e);padding:3rem 5%;text-align:center}
.lb-hero h1{color:#fff;font-size:2.2rem;font-weight:800;margin-bottom:0.5rem}
.lb-hero p{color:rgba(255,255,255,0.7);font-size:0.95rem}
.lb-podium{display:flex;align-items:flex-end;justify-content:center;gap:1rem;margin:2.5rem auto 1rem;max-width:600px}
.lb-podium-item{flex:1;text-align:center;display:flex;flex-direction:column;align-items:center}
.lb-avatar{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;margin:0 auto 8px;border:3px solid transparent}
.lb-podium-item.rank-1 .lb-avatar{background:linear-gradient(135deg,#FFD700,#FFA500);border-color:#FFD700;width:80px;height:80px;font-size:1.6rem}
.lb-podium-item.rank-2 .lb-avatar{background:linear-gradient(135deg,#C0C0C0,#888);border-color:#C0C0C0}
.lb-podium-item.rank-3 .lb-avatar{background:linear-gradient(135deg,#CD7F32,#8B4513);border-color:#CD7F32}
.lb-stand{border-radius:8px 8px 0 0;width:100%;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:800;color:#fff;padding:1rem 0.5rem}
.rank-1 .lb-stand{background:linear-gradient(180deg,#FFD700,#FFA500);min-height:90px}
.rank-2 .lb-stand{background:linear-gradient(180deg,#C0C0C0,#888);min-height:70px}
.rank-3 .lb-stand{background:linear-gradient(180deg,#CD7F32,#8B4513);min-height:55px}
.lb-name{font-size:0.82rem;font-weight:700;color:rgba(255,255,255,0.9);margin-bottom:4px}
.lb-score-badge{font-size:0.72rem;color:rgba(255,255,255,0.6);background:rgba(255,255,255,0.1);border-radius:50px;padding:2px 8px}
.lb-table-wrap{max-width:900px;margin:0 auto;padding:0 5% 4rem}
.lb-table{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.lb-table thead tr{background:var(--navy);color:#fff}
.lb-table thead th{padding:1rem 1.2rem;text-align:left;font-size:0.82rem;font-weight:600;letter-spacing:0.06em;text-transform:uppercase}
.lb-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s}
.lb-table tbody tr:hover{background:rgba(19,37,115,0.04)}
.lb-table tbody td{padding:0.9rem 1.2rem;font-size:0.88rem}
.lb-rank-cell{font-weight:800;color:var(--navy);font-size:1rem}
.lb-user-cell{display:flex;align-items:center;gap:10px}
.lb-mini-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--navy));color:#fff;font-weight:700;display:flex;align-items:center;justify-content:center;font-size:0.8rem;flex-shrink:0}
.lb-bar-wrap{flex:1;background:var(--light);border-radius:50px;height:8px;overflow:hidden}
.lb-bar{height:100%;background:linear-gradient(90deg,var(--navy),var(--navy-light));border-radius:50px}
.lb-badge{font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:50px}
.badge-gold{background:rgba(255,215,0,0.15);color:#b8860b}
.badge-silver{background:rgba(192,192,192,0.2);color:#666}
.badge-bronze{background:rgba(205,127,50,0.15);color:#8b4513}
.badge-normal{background:rgba(19,37,115,0.08);color:var(--navy)}

.overlay{display:none;position:fixed;inset:0;z-index:500;background:rgba(10,18,60,0.55);backdrop-filter:blur(4px);align-items:center;justify-content:center}
.overlay.open{display:flex}
.modal-box{background:#fff;border-radius:20px;padding:2.5rem;max-width:520px;width:90%;text-align:center;animation:modalIn .3s ease;position:relative;max-height:90vh;overflow-y:auto}
@keyframes modalIn{from{transform:scale(0.9);opacity:0}to{transform:scale(1);opacity:1}}
.modal-close{position:absolute;top:1rem;right:1rem;background:rgba(0,0,0,0.06);border:none;color:var(--muted);font-size:1.1rem;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center}
.choice-buttons{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.choice-btn{border:2px solid var(--border);border-radius:var(--radius);padding:1.5rem 1rem;cursor:pointer;transition:all .2s;text-align:center;background:#fff}
.choice-btn:hover{border-color:var(--navy);background:rgba(19,37,115,0.04);transform:translateY(-2px);box-shadow:var(--shadow)}
.choice-btn .c-icon{display:flex;justify-content:center;margin-bottom:0.6rem;color:var(--navy)}
.choice-btn h3{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:0.3rem}
.choice-btn p{font-size:0.78rem;color:var(--muted);margin:0}

.subpage-header{background:linear-gradient(135deg,#0f1e6b,#1e3a9e);padding:1.5rem 5%}
.back-btn{background:rgba(255,255,255,0.15);border:none;color:#fff;padding:0.4rem 0.9rem;border-radius:8px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.82rem;margin-bottom:0.75rem;display:inline-flex;align-items:center;gap:6px;transition:background .15s}
.back-btn:hover{background:rgba(255,255,255,0.25)}
.subpage-header h1{color:#fff;font-size:1.5rem;font-weight:800}
.subpage-header p{color:rgba(255,255,255,0.65);font-size:0.85rem;margin-top:0.25rem}
.subpage-meta{display:flex;gap:8px;margin-top:0.75rem;flex-wrap:wrap}
.meta-pill{background:rgba(255,255,255,0.15);color:rgba(255,255,255,0.9);font-size:0.75rem;padding:4px 12px;border-radius:50px;font-weight:500}

#maitrise-page{background:var(--light);min-height:100vh}
.maitrise-choices{max-width:900px;margin:2.5rem auto;padding:0 5%;display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}
.maitrise-choice-card{background:#fff;border:2px solid var(--border);border-radius:20px;padding:2.5rem 2rem;cursor:pointer;transition:all .25s;text-align:center;position:relative;overflow:hidden}
.maitrise-choice-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;opacity:0;transition:opacity .25s}
.maitrise-choice-card.c-drive::after{background:linear-gradient(90deg,var(--navy),var(--navy-light))}
.maitrise-choice-card.c-yt::after{background:linear-gradient(90deg,#ff0000,#ff6b6b)}
.maitrise-choice-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,0.12);border-color:transparent}
.maitrise-choice-card:hover::after{opacity:1}
.maitrise-choice-icon{display:flex;justify-content:center;margin-bottom:1rem;color:var(--navy)}
.maitrise-choice-card h3{font-size:1.2rem;font-weight:800;color:var(--navy);margin-bottom:0.5rem}
.maitrise-choice-card p{font-size:0.85rem;color:var(--muted);line-height:1.5}

#modules-page{background:var(--light);min-height:100vh}
.modules-body{max-width:1100px;margin:2rem auto;padding:0 5%}
.modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.module-card{background:#fff;border:2px solid var(--border);border-radius:20px;overflow:hidden;cursor:pointer;transition:all .25s;position:relative}
.module-card:hover{transform:translateY(-5px);box-shadow:0 16px 48px rgba(0,0,0,0.13);border-color:transparent}
.module-card-img{width:100%;height:180px;object-fit:cover;display:block}
.module-card-img-placeholder{width:100%;height:180px;display:flex;align-items:center;justify-content:center;color:#fff}
.module-card-body{padding:1.5rem}
.module-card h3{font-size:1.05rem;font-weight:800;color:var(--navy);margin-bottom:0.4rem}
.module-card p{font-size:0.82rem;color:var(--muted);line-height:1.5;margin-bottom:1rem}
.module-card-btn{width:100%;padding:0.6rem;border:none;border-radius:10px;font-family:'Sora',sans-serif;font-size:0.82rem;font-weight:700;cursor:pointer;transition:all .15s}

#module-video-page{background:#1a1a2e;min-height:100vh}
.mv-layout{display:grid;grid-template-columns:1fr 360px;height:calc(100vh - 120px)}
.mv-main{display:flex;flex-direction:column;background:#0f0f1a;overflow-y:auto}
.mv-player-wrap{background:#000;width:100%;aspect-ratio:16/9;position:relative;flex-shrink:0}
.mv-player-wrap iframe{width:100%;height:100%;border:none;display:block}
.mv-info{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.mv-lesson-title{font-size:1rem;font-weight:700;color:#fff;margin-bottom:0.5rem}
.mv-pill{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-size:0.72rem;padding:3px 10px;border-radius:50px;margin-right:6px;display:inline-block}
.mv-sidebar{background:#12122a;border-left:1px solid rgba(255,255,255,0.06);overflow-y:auto}
.mv-sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.mv-sidebar-title{font-size:0.88rem;font-weight:700;color:#fff}
.mv-sidebar-sub{font-size:0.72rem;color:rgba(255,255,255,0.4);margin-top:2px}
.mv-playlist-section{border-bottom:1px solid rgba(255,255,255,0.06)}
.mv-playlist-header{padding:0.7rem 1.25rem;background:rgba(255,255,255,0.04);cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .15s}
.mv-playlist-header:hover{background:rgba(255,255,255,0.07)}
.mv-playlist-name{font-size:0.78rem;font-weight:700;color:rgba(255,255,255,0.7);text-transform:uppercase;letter-spacing:0.05em}
.mv-playlist-count{font-size:0.68rem;color:rgba(255,255,255,0.35)}
.mv-playlist-arrow{font-size:0.65rem;color:rgba(255,255,255,0.4);transition:transform .2s}
.mv-playlist-arrow.open{transform:rotate(180deg)}
.mv-playlist-videos{display:none}
.mv-playlist-videos.open{display:block}
.mv-video-row{display:flex;align-items:center;gap:10px;padding:0.7rem 1.25rem;border-bottom:1px solid rgba(255,255,255,0.03);cursor:pointer;transition:background .15s}
.mv-video-row:hover{background:rgba(255,255,255,0.04)}
.mv-video-row.active{background:rgba(124,58,237,0.15);border-left:3px solid var(--purple)}
.mv-video-thumb{width:56px;height:36px;border-radius:5px;background:rgba(255,255,255,0.05);display:flex;align-items:center;justify-content:center;font-size:1rem;flex-shrink:0;overflow:hidden}
.mv-video-thumb img{width:100%;height:100%;object-fit:cover}
.mv-video-info{flex:1;min-width:0}
.mv-video-name{font-size:0.75rem;font-weight:500;color:rgba(255,255,255,0.8);line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}
.mv-video-dur{font-size:0.65rem;color:rgba(255,255,255,0.35);margin-top:2px}

#maitrise-docs-page{background:var(--light);min-height:100vh}
.maitrise-docs-body{max-width:1100px;margin:2rem auto;padding:0 5%}
.doc-type-choices{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.25rem;margin-bottom:2.5rem}
.doc-type-card{background:#fff;border:2px solid var(--border);border-radius:16px;padding:2rem 1.25rem;cursor:pointer;transition:all .2s;text-align:center;position:relative;overflow:hidden}
.doc-type-card::before{content:'';position:absolute;top:0;left:0;right:0;height:4px}
.doc-type-card.c-cours::before{background:linear-gradient(90deg,var(--navy),var(--navy-light))}
.doc-type-card.c-astuces::before{background:linear-gradient(90deg,var(--coral),#ff6b6b)}
.doc-type-card.c-drives::before{background:linear-gradient(90deg,var(--purple),var(--purple-light))}
.doc-type-card:hover{transform:translateY(-4px);box-shadow:0 10px 30px rgba(0,0,0,0.1);border-color:transparent}
.doc-type-icon{display:flex;justify-content:center;margin-bottom:0.75rem;color:var(--navy)}
.doc-type-card h3{font-size:0.95rem;font-weight:800;color:var(--navy);margin-bottom:0.3rem}
.doc-type-card p{font-size:0.76rem;color:var(--muted)}

#fiches-doc-page{background:var(--light);min-height:100vh}
.fiches-doc-body{max-width:1200px;margin:0 auto;padding:2.5rem 5%}
.fiches-doc-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.fiche-doc-item{background:#fff;border:1.5px solid rgba(19,37,115,0.12);border-radius:14px;padding:1.25rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.fiche-doc-item::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy),var(--navy-light))}
.fiche-doc-item:hover{transform:translateY(-3px);box-shadow:0 6px 24px rgba(19,37,115,0.12);border-color:rgba(19,37,115,0.3)}
.fiche-doc-num{width:34px;height:34px;background:rgba(19,37,115,0.08);border-radius:8px;color:var(--navy);font-weight:800;font-size:0.9rem;display:flex;align-items:center;justify-content:center;margin-bottom:0.75rem}
.fiche-doc-item h4{font-size:0.85rem;font-weight:700;color:var(--text);margin-bottom:0.25rem}
.fiche-doc-item .meta{font-size:0.72rem;color:var(--muted);margin-bottom:0.75rem}
.fiche-doc-open-btn{width:100%;padding:0.4rem;background:rgba(19,37,115,0.06);border:1.5px solid rgba(19,37,115,0.15);border-radius:6px;color:var(--navy);font-family:'Sora',sans-serif;font-size:0.75rem;font-weight:600;cursor:pointer;transition:all .15s}
.fiche-doc-open-btn:hover{background:var(--navy);color:#fff}
.fiche-add-section{background:#fff;border-radius:14px;border:2px dashed var(--border);padding:1.5rem;text-align:center;margin-bottom:1.5rem}
.fiche-add-section h3{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:1rem}
.fiche-add-form{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.fiche-add-form input{flex:1;min-width:150px;max-width:300px;padding:0.5rem 0.8rem;border:1px solid var(--border);border-radius:8px;font-family:'Sora',sans-serif;font-size:0.83rem;outline:none}
.fiche-add-form button{background:var(--navy);color:#fff;border:none;padding:0.5rem 1rem;border-radius:8px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.83rem;font-weight:600}

#drives-page{background:var(--light);min-height:100vh}
.drives-body{max-width:1100px;margin:2rem auto;padding:0 5%}
.drives-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem}
.drive-item{background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s;cursor:pointer}
.drive-item:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(19,37,115,0.25)}
.drive-item-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:var(--navy);flex-shrink:0}
.drive-item h4{font-size:0.88rem;font-weight:700;color:var(--navy);margin-bottom:3px}
.drive-item p{font-size:0.75rem;color:var(--muted)}
.drive-add-section{background:#fff;border-radius:14px;border:2px dashed var(--border);padding:1.5rem;text-align:center;margin-bottom:1.5rem}
.drive-add-form{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.drive-add-form input{flex:1;min-width:200px;max-width:400px;padding:0.5rem 0.8rem;border:1px solid var(--border);border-radius:8px;font-family:'Sora',sans-serif;font-size:0.83rem;outline:none}
.drive-add-form button{background:var(--purple);color:#fff;border:none;padding:0.5rem 1rem;border-radius:8px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.83rem;font-weight:600}

#fiches-page{background:var(--light);min-height:100vh}
.fiches-body{max-width:1200px;margin:0 auto;padding:2.5rem 5%}
.fiches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1.25rem}
.fiche-item{background:#fff;border:1.5px solid rgba(124,58,237,0.18);border-radius:16px;padding:1.5rem 1.25rem;cursor:pointer;transition:all .2s;position:relative;overflow:hidden}
.fiche-item::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--purple),var(--navy))}
.fiche-item:hover{transform:translateY(-4px);box-shadow:0 8px 32px rgba(124,58,237,0.15);border-color:var(--purple)}
.fiche-num{width:38px;height:38px;background:var(--purple-bg);border-radius:10px;color:var(--purple);font-weight:800;font-size:1rem;display:flex;align-items:center;justify-content:center;margin-bottom:1rem}
.fiche-item h3{font-size:0.95rem;font-weight:700;color:var(--text);margin-bottom:0.25rem}
.fiche-item .fiche-meta{font-size:0.75rem;color:var(--muted);margin-bottom:0.75rem}
.fiche-level{display:inline-block;font-size:0.7rem;font-weight:700;padding:3px 10px;border-radius:50px;margin-bottom:0.75rem}
.level-debutant{background:rgba(34,197,94,0.12);color:#16a34a}
.level-intermediaire{background:rgba(245,158,11,0.12);color:#b45309}
.level-avance{background:rgba(239,68,68,0.12);color:#dc2626}
.fiche-stars{color:#fbbf24;font-size:0.9rem;margin-bottom:0.75rem}
.fiche-start-btn{width:100%;padding:0.5rem;background:var(--purple-bg);border:1.5px solid rgba(124,58,237,0.25);border-radius:8px;color:var(--purple);font-family:'Sora',sans-serif;font-size:0.8rem;font-weight:600;cursor:pointer;transition:all .15s}
.fiche-start-btn:hover{background:var(--purple);color:#fff}

.mode-modal{background:#fff;border-radius:20px;padding:2.5rem 2rem;max-width:580px;width:92%;text-align:center;animation:modalIn .3s ease;position:relative}
.mode-modal-icon{margin-bottom:0.75rem;display:flex;justify-content:center;color:var(--navy)}
.mode-modal h2{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:0.3rem}
.mode-modal .mode-sub{font-size:0.85rem;color:var(--muted);margin-bottom:1.25rem}
.mode-tags{display:flex;gap:8px;justify-content:center;margin-bottom:1.75rem;flex-wrap:wrap}
.mode-tag{background:var(--light);border:1px solid var(--border);border-radius:50px;padding:4px 14px;font-size:0.78rem;font-weight:500;color:var(--text)}
.modes-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}
.mode-card{border:2px solid var(--border);border-radius:14px;padding:1.25rem 1rem;cursor:pointer;transition:all .2s;text-align:left;position:relative;background:#fff}
.mode-card:hover{border-color:var(--navy);background:rgba(19,37,115,0.03)}
.mode-card.selected{border-color:var(--navy);background:rgba(19,37,115,0.06)}
.mode-card.disabled{opacity:0.55;cursor:not-allowed}
.mode-xp-badge{position:absolute;top:10px;right:10px;background:rgba(245,158,11,0.12);color:#b45309;font-size:0.68rem;font-weight:700;padding:2px 8px;border-radius:50px}
.mode-card-icon{margin-bottom:0.5rem;color:var(--navy)}
.mode-card h3{font-size:0.95rem;font-weight:700;color:var(--text);margin-bottom:0.3rem}
.mode-card p{font-size:0.78rem;color:var(--muted);margin-bottom:0.6rem}
.mode-chips{display:flex;gap:5px;flex-wrap:wrap}
.mode-chip{background:var(--light);border:1px solid var(--border);border-radius:50px;padding:2px 9px;font-size:0.68rem;color:var(--muted);font-weight:500}
.soon-badge{font-size:0.65rem;background:var(--light);border:1px solid var(--border);color:var(--muted);padding:2px 8px;border-radius:50px;margin-top:6px;display:inline-block}
.mode-modal-footer{display:flex;gap:0.75rem}
.mode-start-btn{flex:1;padding:0.8rem;background:var(--navy);color:#fff;border:none;border-radius:12px;font-family:'Sora',sans-serif;font-size:1rem;font-weight:700;cursor:pointer;transition:all .15s}
.mode-start-btn:hover{background:var(--navy-light);transform:translateY(-1px)}
.mode-cancel-btn{padding:0.8rem 1.5rem;background:var(--light);color:var(--muted);border:1px solid var(--border);border-radius:12px;font-family:'Sora',sans-serif;font-size:0.9rem;font-weight:600;cursor:pointer}

#exams-page{background:#fff;min-height:100vh}
.exams-body{max-width:1000px;margin:0 auto;padding:3rem 5%}
.exams-page-title{font-size:2rem;font-weight:800;color:var(--text);text-align:center;margin-bottom:0.5rem}
.exams-page-sub{text-align:center;color:var(--muted);font-size:0.9rem;margin-bottom:2.5rem}
.exams-legend{display:flex;gap:1.5rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:8px;font-size:0.82rem;color:var(--muted)}
.legend-dot{width:20px;height:20px;border-radius:50%;flex-shrink:0}
.exams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1.25rem}
.exam-item{text-align:center;cursor:pointer;transition:transform .2s}
.exam-item:hover{transform:translateY(-3px)}
.exam-circle{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 0.75rem;font-size:1.6rem;transition:transform .2s}
.exam-item:hover .exam-circle{transform:scale(1.08)}
.exam-label{font-size:0.82rem;font-weight:600;color:var(--text)}

#zone-pratique-page{background:var(--light);min-height:100vh}
.zp-layout{max-width:1200px;margin:0 auto;padding:2rem 5%;display:grid;grid-template-columns:300px 1fr;gap:1.5rem;align-items:start}
.pomodoro-widget{background:#fff;border-radius:var(--radius);padding:1.5rem;border:1px solid var(--border);text-align:center}
.pomodoro-widget h3{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:1rem;display:flex;align-items:center;justify-content:center;gap:6px}
.pomodoro-ring{width:120px;height:120px;margin:0 auto 1rem;position:relative}
.pomodoro-ring svg{transform:rotate(-90deg)}
.ring-bg{fill:none;stroke:var(--light);stroke-width:8}
.ring-fill{fill:none;stroke:var(--coral);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset 1s linear}
.pomodoro-time{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;color:var(--navy)}
.pomo-phase{font-size:0.75rem;font-weight:600;color:var(--muted);margin-bottom:0.75rem;text-transform:uppercase;letter-spacing:0.06em}
.pomo-btns{display:flex;gap:8px;justify-content:center}
.pomo-btn{padding:0.4rem 0.85rem;border-radius:8px;border:1.5px solid var(--border);background:#fff;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.78rem;font-weight:600;color:var(--navy);transition:all .15s}
.pomo-btn:hover{background:var(--navy);color:#fff;border-color:var(--navy)}
.pomo-sessions{font-size:0.72rem;color:var(--muted);margin-top:0.75rem}
.stats-widget{background:#fff;border-radius:var(--radius);padding:1.5rem;border:1px solid var(--border)}
.stats-widget h3{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:1rem;display:flex;align-items:center;gap:6px}
.stat-row{display:flex;align-items:center;justify-content:space-between;padding:0.5rem 0;border-bottom:1px solid var(--border);font-size:0.82rem}
.stat-row:last-child{border-bottom:none}
.stat-label{color:var(--muted)}
.stat-val{font-weight:700;color:var(--navy)}
.fiches-side{background:#fff;border-radius:var(--radius);padding:1.5rem;border:1px solid var(--border)}
.fiches-side h3{font-size:0.95rem;font-weight:700;color:var(--navy);margin-bottom:1rem}
.fiche-mini{background:var(--light);border-radius:8px;padding:0.75rem;border-left:3px solid var(--purple);margin-bottom:0.6rem}
.fiche-mini h4{font-size:0.8rem;font-weight:700;color:var(--navy);margin-bottom:0.3rem}
.fiche-mini p{font-size:0.74rem;color:var(--muted);line-height:1.4}
.qcm-zone{background:#fff;border-radius:var(--radius);padding:1.75rem;border:1px solid var(--border)}
.qcm-mode-tabs{display:flex;gap:6px;margin-bottom:1.5rem}
.qcm-mode-tab{flex:1;padding:0.55rem 0.5rem;border:1.5px solid var(--border);border-radius:8px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.75rem;font-weight:600;color:var(--muted);background:#fff;transition:all .15s;text-align:center}
.qcm-mode-tab.active{border-color:var(--navy);background:rgba(19,37,115,0.06);color:var(--navy)}
.mode-xp{display:block;font-size:0.65rem;font-weight:700;color:var(--coral);margin-top:2px}
.qcm-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.25rem;gap:1rem}
.qcm-progress-wrap{flex:1}
.qcm-progress-label{font-size:0.72rem;color:var(--muted);margin-bottom:4px}
.qcm-progress-bar{height:6px;background:var(--light);border-radius:50px;overflow:hidden}
.qcm-progress-fill{height:100%;background:linear-gradient(90deg,var(--purple),var(--navy));border-radius:50px;transition:width .4s}
.qcm-level-badge{font-size:0.72rem;font-weight:700;padding:4px 10px;border-radius:50px;background:rgba(245,158,11,0.12);color:#b45309;white-space:nowrap}
.qcm-question{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:1.5rem;line-height:1.55}
.qcm-options{display:flex;flex-direction:column;gap:0.75rem;margin-bottom:1.25rem}
.qcm-option{display:flex;align-items:center;gap:12px;border:1.5px solid var(--border);border-radius:12px;padding:0.85rem 1rem;cursor:pointer;transition:all .15s}
.qcm-option:hover{border-color:var(--purple);background:rgba(124,58,237,0.03)}
.qcm-option.selected{border-color:var(--purple);background:rgba(124,58,237,0.07)}
.qcm-option.correct{border-color:#16a34a;background:rgba(22,163,74,0.08)}
.qcm-option.wrong{border-color:#dc2626;background:rgba(220,38,38,0.08)}
.opt-letter{width:30px;height:30px;border-radius:8px;background:rgba(124,58,237,0.1);color:var(--purple);font-weight:700;font-size:0.85rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.qcm-option.selected .opt-letter{background:var(--purple);color:#fff}
.qcm-option.correct .opt-letter{background:#16a34a;color:#fff}
.qcm-option.wrong .opt-letter{background:#dc2626;color:#fff}
.opt-text{font-size:0.88rem;color:var(--text)}
.qcm-footer{display:flex;align-items:center;justify-content:space-between}
.hint-btn{background:none;border:1.5px solid var(--border);border-radius:8px;padding:0.45rem 0.9rem;font-family:'Sora',sans-serif;font-size:0.78rem;font-weight:600;color:var(--muted);cursor:pointer;display:flex;align-items:center;gap:6px}
.validate-btn{background:var(--navy);color:#fff;border:none;border-radius:10px;padding:0.65rem 1.5rem;font-family:'Sora',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer;transition:all .15s}
.validate-btn:hover{background:var(--navy-light);transform:translateY(-1px)}
.validate-btn:disabled{opacity:0.4;cursor:not-allowed;transform:none}
.qcm-feedback{border-radius:10px;padding:1rem 1.2rem;font-size:0.85rem;margin-top:1rem;display:none}
.qcm-feedback.show{display:block}
.correct-fb{background:rgba(22,163,74,0.1);border:1px solid rgba(22,163,74,0.3);color:#166534}
.wrong-fb{background:rgba(220,38,38,0.1);border:1px solid rgba(220,38,38,0.3);color:#991b1b}
.next-btn{background:var(--coral);color:#fff;border:none;border-radius:8px;padding:0.55rem 1.2rem;font-family:'Sora',sans-serif;font-size:0.85rem;font-weight:600;cursor:pointer;transition:all .15s}
.next-btn:hover{opacity:0.9;transform:translateY(-1px)}
.open-q-zone{background:#fff;border-radius:var(--radius);padding:1.75rem;border:1px solid var(--border)}
.open-q-question{font-size:1rem;font-weight:600;color:var(--text);margin-bottom:1.25rem;line-height:1.55;background:var(--light);padding:1rem;border-radius:10px;border-left:4px solid var(--purple)}
.open-q-area{width:100%;min-height:120px;border:1.5px solid var(--border);border-radius:10px;padding:0.85rem;font-family:'Sora',sans-serif;font-size:0.88rem;resize:vertical;outline:none;transition:border-color .2s;margin-bottom:1rem}
.open-q-area:focus{border-color:var(--purple)}
.open-q-actions{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:0.75rem}
.show-correction-btn{background:var(--navy);color:#fff;border:none;border-radius:10px;padding:0.65rem 1.5rem;font-family:'Sora',sans-serif;font-size:0.9rem;font-weight:700;cursor:pointer;transition:all .15s}
.correction-box{margin-top:1rem;background:rgba(22,163,74,0.07);border:1px solid rgba(22,163,74,0.25);border-radius:10px;padding:1rem 1.2rem;font-size:0.85rem;color:#166534;display:none}
.correction-box.show{display:block}

#bacplus2-page{background:var(--navy-dark);min-height:100vh}
.bp2-nav{position:sticky;top:0;z-index:200;background:rgba(11,26,80,0.95);backdrop-filter:blur(10px);border-bottom:1px solid rgba(255,255,255,0.08);padding:0 5%;display:flex;align-items:center;justify-content:space-between;height:68px}
.bp2-hero{min-height:80vh;background:linear-gradient(135deg,#050d2e 0%,#0f1e6b 50%,#1a0a3d 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:5rem 5%;position:relative;overflow:hidden}
.bp2-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 50% at 50% 40%,rgba(124,58,237,0.18) 0%,transparent 70%)}
.bp2-eyebrow{display:inline-flex;align-items:center;gap:8px;background:rgba(124,58,237,0.15);border:1px solid rgba(124,58,237,0.3);border-radius:50px;padding:0.4rem 1.1rem;color:rgba(255,255,255,0.85);font-size:0.78rem;font-weight:600;letter-spacing:0.08em;text-transform:uppercase;margin-bottom:1.5rem}
.bp2-hero h1{font-size:clamp(2.5rem,6vw,5rem);font-weight:800;color:#fff;line-height:1.05;letter-spacing:-1.5px;max-width:900px;margin-bottom:1rem}
.bp2-hero h1 .accent{background:linear-gradient(135deg,#a78bfa,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.bp2-hero h1 .accent2{color:var(--coral)}
.bp2-hero-sub{font-size:1.05rem;color:rgba(255,255,255,0.6);max-width:600px;margin-bottom:3rem;line-height:1.65}
.bp2-packs{display:grid;grid-template-columns:1fr 1fr;gap:2rem;max-width:900px;margin:0 auto;width:100%;position:relative;z-index:1}
.pack-card{border:1.5px solid rgba(255,255,255,0.1);border-radius:20px;padding:2rem;cursor:pointer;transition:all .3s;text-align:left;position:relative;overflow:hidden;background:rgba(255,255,255,0.04);backdrop-filter:blur(8px)}
.pack-card::before{content:'';position:absolute;inset:0;opacity:0;transition:opacity .3s}
.pack-card.pack-ing::before{background:linear-gradient(135deg,rgba(124,58,237,0.15),rgba(19,37,115,0.2))}
.pack-card.pack-lic::before{background:linear-gradient(135deg,rgba(255,141,141,0.1),rgba(124,58,237,0.1))}
.pack-card:hover{border-color:rgba(255,255,255,0.3);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,0.4)}
.pack-card:hover::before{opacity:1}
.pack-icon{font-size:2.8rem;margin-bottom:1rem}
.pack-card h2{font-size:1.4rem;font-weight:800;color:#fff;margin-bottom:0.5rem}
.pack-card .pack-sub{font-size:0.85rem;color:rgba(255,255,255,0.55);margin-bottom:1.25rem;line-height:1.5}
.pack-schools{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:1.5rem}
.pack-school-tag{background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:50px;padding:4px 12px;font-size:0.72rem;font-weight:600;color:rgba(255,255,255,0.75)}
.pack-cta{display:inline-flex;align-items:center;gap:8px;background:linear-gradient(135deg,var(--purple),#4f46e5);color:#fff;padding:0.7rem 1.4rem;border-radius:10px;font-size:0.88rem;font-weight:700;transition:transform .15s,opacity .15s;border:none;cursor:pointer;font-family:'Sora',sans-serif}
.pack-cta:hover{transform:translateY(-1px);opacity:0.9}
.bp2-video-section{padding:5rem 5%;text-align:center}
.bp2-video-title{font-size:1.8rem;font-weight:800;color:#fff;margin-bottom:0.5rem}
.bp2-video-sub{color:rgba(255,255,255,0.5);font-size:0.9rem;margin-bottom:2rem}
.bp2-video-wrap{max-width:800px;margin:0 auto;border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,0.1);box-shadow:0 24px 80px rgba(0,0,0,0.5)}
.bp2-video-wrap iframe{width:100%;aspect-ratio:16/9;display:block;border:none}

#pack-detail-page{background:var(--light);min-height:100vh}
.pack-detail-nav{position:sticky;top:0;z-index:200;background:#fff;border-bottom:1px solid var(--border);padding:0 5%;display:flex;align-items:center;gap:1rem;height:64px}
.pd-branches{max-width:1200px;margin:2.5rem auto;padding:0 5%;display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.branch-card{background:#fff;border:2px solid var(--border);border-radius:20px;padding:2rem;cursor:pointer;transition:all .25s;text-align:center;position:relative;overflow:hidden}
.branch-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:4px;opacity:0;transition:opacity .25s}
.branch-card.b-cours::after{background:linear-gradient(90deg,var(--navy),var(--navy-light))}
.branch-card.b-videos::after{background:linear-gradient(90deg,var(--purple),var(--purple-light))}
.branch-card.b-exams::after{background:linear-gradient(90deg,var(--coral),#ff6b6b)}
.branch-card:hover{transform:translateY(-5px);box-shadow:0 12px 40px rgba(0,0,0,0.12);border-color:transparent}
.branch-card:hover::after{opacity:1}
.branch-icon{display:flex;justify-content:center;margin-bottom:1rem;color:var(--navy)}
.branch-card h3{font-size:1.15rem;font-weight:800;color:var(--navy);margin-bottom:0.5rem}
.branch-card p{font-size:0.85rem;color:var(--muted);line-height:1.5}

#cours-page{background:var(--light);min-height:100vh}
.cours-body{max-width:1100px;margin:2rem auto;padding:0 5%}
.drive-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;margin-bottom:2rem}
.drive-card{background:#fff;border:1px solid var(--border);border-radius:14px;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s;cursor:pointer}
.drive-card:hover{transform:translateY(-2px);box-shadow:var(--shadow);border-color:rgba(19,37,115,0.25)}
.drive-icon{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--navy)}
.drive-card h4{font-size:0.88rem;font-weight:700;color:var(--navy)}
.drive-card p{font-size:0.75rem;color:var(--muted)}
.cours-upload-section{background:#fff;border-radius:var(--radius);border:2px dashed var(--border);padding:2rem;text-align:center;margin-bottom:1.5rem;transition:border-color .2s}
.cours-upload-section:hover{border-color:var(--navy)}
.upload-icon{margin-bottom:0.75rem;display:flex;justify-content:center;color:var(--navy)}
.cours-upload-section h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:0.4rem}
.cours-upload-section p{font-size:0.82rem;color:var(--muted);margin-bottom:1rem}
.upload-btn{background:var(--navy);color:#fff;border:none;padding:0.6rem 1.4rem;border-radius:8px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.85rem;font-weight:600}

#video-course-page{background:#1a1a2e;min-height:100vh}
.vc-layout{display:grid;grid-template-columns:1fr 360px;height:calc(100vh - 64px)}
.vc-main{display:flex;flex-direction:column;background:#0f0f1a;overflow-y:auto}
.vc-player-wrap{background:#000;width:100%;aspect-ratio:16/9;position:relative}
.vc-player-wrap iframe{width:100%;height:100%;border:none;display:block}
.vc-info{padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.vc-lesson-title{font-size:1.05rem;font-weight:700;color:#fff;margin-bottom:0.5rem}
.vc-lesson-meta{display:flex;gap:10px;flex-wrap:wrap}
.vc-pill{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-size:0.72rem;padding:3px 10px;border-radius:50px}
.vc-tabs{display:flex;gap:0;border-bottom:1px solid rgba(255,255,255,0.06)}
.vc-tab{padding:0.75rem 1.25rem;font-family:'Sora',sans-serif;font-size:0.8rem;font-weight:600;color:rgba(255,255,255,0.45);background:none;border:none;cursor:pointer;border-bottom:2px solid transparent;transition:all .15s}
.vc-tab.active{color:#fff;border-bottom-color:var(--purple)}
.vc-tab-content{padding:1.25rem 1.5rem;flex:1}
.vc-overview{font-size:0.85rem;color:rgba(255,255,255,0.65);line-height:1.7}
.vc-sidebar{background:#12122a;border-left:1px solid rgba(255,255,255,0.06);overflow-y:auto}
.vc-sidebar-header{padding:1rem 1.25rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.vc-sidebar-title{font-size:0.88rem;font-weight:700;color:#fff}
.vc-sidebar-sub{font-size:0.72rem;color:rgba(255,255,255,0.4);margin-top:2px}
.vc-section{margin-bottom:0}
.vc-section-hdr{padding:0.75rem 1.25rem;background:rgba(255,255,255,0.03);border-bottom:1px solid rgba(255,255,255,0.05);font-size:0.78rem;font-weight:700;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.06em}
.vc-lesson-row{display:flex;align-items:center;gap:10px;padding:0.75rem 1.25rem;border-bottom:1px solid rgba(255,255,255,0.04);cursor:pointer;transition:background .15s}
.vc-lesson-row:hover{background:rgba(255,255,255,0.04)}
.vc-lesson-row.active{background:rgba(124,58,237,0.12);border-left:3px solid var(--purple)}
.vc-check{width:18px;height:18px;border-radius:50%;border:2px solid rgba(255,255,255,0.2);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:0.55rem;transition:all .15s}
.vc-check.done{background:#16a34a;border-color:#16a34a;color:#fff}
.vc-lesson-info{flex:1}
.vc-lesson-name{font-size:0.8rem;font-weight:500;color:rgba(255,255,255,0.8);line-height:1.35}
.vc-lesson-dur{font-size:0.68rem;color:rgba(255,255,255,0.35);margin-top:2px}
.vc-dl-btn{background:rgba(255,255,255,0.06);border:none;color:rgba(255,255,255,0.4);border-radius:6px;width:24px;height:24px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:0.65rem;flex-shrink:0;transition:all .15s}
.vc-dl-btn:hover{background:rgba(124,58,237,0.2);color:#a78bfa}

#pack-exams-page{background:#fff;min-height:100vh}

.advisor-fab{position:fixed;bottom:28px;right:28px;z-index:1000;width:62px;height:62px;border-radius:50%;background:linear-gradient(135deg,var(--navy) 0%,#1e3a9e 100%);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 28px rgba(19,37,115,0.45);transition:transform .2s,box-shadow .2s;color:#fff}
.advisor-fab:hover{transform:scale(1.1);box-shadow:0 10px 36px rgba(19,37,115,0.55)}
.fab-badge{position:absolute;top:-4px;right:-4px;background:var(--coral);color:#fff;font-size:0.55rem;font-weight:700;padding:2px 5px;border-radius:50px;letter-spacing:0.04em}
.advisor-overlay{position:fixed;inset:0;z-index:1001;background:rgba(10,18,60,0.45);opacity:0;pointer-events:none;transition:opacity .3s}
.advisor-overlay.open{opacity:1;pointer-events:all}
.advisor-panel{position:fixed;bottom:0;right:0;z-index:1002;width:min(480px,100vw);height:min(680px,100dvh);background:#0f1630;border-radius:20px 20px 0 0;display:flex;flex-direction:column;transform:translateY(110%);transition:transform .35s cubic-bezier(.32,1,.5,1);overflow:hidden;box-shadow:0 -8px 48px rgba(0,0,0,0.5)}
.advisor-panel.open{transform:translateY(0)}
.adv-loading-overlay{position:absolute;inset:0;z-index:10;background:rgba(15,22,48,0.85);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;opacity:0;pointer-events:none;transition:opacity .2s}
.adv-loading-overlay.show{opacity:1;pointer-events:all}
.adv-loading-spinner{width:36px;height:36px;border-radius:50%;border:3px solid rgba(255,255,255,0.15);border-top-color:#a78bfa;animation:spin .7s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.adv-loading-text{color:rgba(255,255,255,0.6);font-size:0.82rem}
.adv-header{display:flex;align-items:center;gap:12px;padding:14px 16px 12px;background:rgba(255,255,255,0.04);border-bottom:1px solid rgba(255,255,255,0.07);flex-shrink:0}
.adv-logo{font-size:1.6rem}
.adv-header-text{flex:1}
.adv-header-title{font-size:0.95rem;font-weight:700;color:#fff}
.adv-header-sub{font-size:0.68rem;color:rgba(255,255,255,0.45);margin-top:2px}
.adv-header-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.adv-free-badge{background:rgba(0,184,122,0.18);color:#4ade80;font-size:0.65rem;font-weight:700;padding:3px 8px;border-radius:50px;border:1px solid rgba(74,222,128,0.25);white-space:nowrap}
.adv-status-dot{width:8px;height:8px;border-radius:50%;background:#4ade80;box-shadow:0 0 6px #4ade80;animation:pulse-dot 2s ease-in-out infinite}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}
.adv-close{background:rgba(255,255,255,0.08);border:none;color:rgba(255,255,255,0.6);font-size:0.85rem;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s}
.adv-close:hover{background:rgba(255,255,255,0.15);color:#fff}
.adv-filters{display:flex;align-items:center;gap:6px;padding:10px 14px;overflow-x:auto;flex-shrink:0;border-bottom:1px solid rgba(255,255,255,0.06);scrollbar-width:none}
.adv-filters::-webkit-scrollbar{display:none}
.adv-filter-label{font-size:0.7rem;color:rgba(255,255,255,0.35);white-space:nowrap}
.adv-chip{background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-size:0.72rem;font-weight:500;padding:4px 10px;border-radius:50px;cursor:pointer;white-space:nowrap;transition:all .15s;font-family:'Sora',sans-serif}
.adv-chip.active{background:rgba(167,139,250,0.18);border-color:#a78bfa;color:#c4b0ff}
.adv-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:14px;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,0.1) transparent}
.adv-msg{display:flex;gap:10px;align-items:flex-start}
.adv-msg.user{flex-direction:row-reverse}
.adv-msg-avatar{width:30px;height:30px;border-radius:50%;flex-shrink:0;background:rgba(167,139,250,0.2);color:#c4b0ff;display:flex;align-items:center;justify-content:center;font-size:0.8rem;font-weight:700}
.adv-msg.user .adv-msg-avatar{background:rgba(255,141,141,0.2);color:#FF8D8D}
.adv-msg-bubble{max-width:320px;padding:10px 13px;border-radius:14px;font-size:0.83rem;line-height:1.65;color:rgba(255,255,255,0.88);background:rgba(255,255,255,0.07)}
.adv-msg.user .adv-msg-bubble{background:var(--navy);border-radius:14px 14px 4px 14px}
.adv-msg.bot .adv-msg-bubble{border-radius:14px 14px 14px 4px}
.adv-msg-bubble strong{color:#c4b0ff}
.adv-msg-bubble code{background:rgba(167,139,250,0.15);padding:1px 5px;border-radius:4px;font-size:0.8rem;color:#c4b0ff}
.adv-msg-time{font-size:0.65rem;color:rgba(255,255,255,0.25);margin-top:4px;padding:0 2px}
.adv-msg.user .adv-msg-time{text-align:right}
.adv-welcome{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);border-radius:14px;padding:13px 15px;max-width:340px}
.adv-welcome-title{font-size:0.88rem;font-weight:700;color:#fff;margin-bottom:6px}
.adv-welcome-sub{font-size:0.78rem;color:rgba(255,255,255,0.65);line-height:1.5}
.adv-welcome-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}
.adv-welcome-tag{background:rgba(167,139,250,0.12);border:1px solid rgba(167,139,250,0.2);color:#c4b0ff;font-size:0.66rem;padding:2px 8px;border-radius:50px}
.adv-quick-prompts{padding:0 14px 10px;display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0}
.adv-quick{background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);color:rgba(255,255,255,0.6);font-size:0.72rem;padding:5px 11px;border-radius:50px;cursor:pointer;font-family:'Sora',sans-serif;transition:all .15s}
.adv-quick:hover{background:rgba(167,139,250,0.12);border-color:#a78bfa;color:#c4b0ff}
.adv-input-area{padding:10px 14px 14px;border-top:1px solid rgba(255,255,255,0.07);flex-shrink:0}
.adv-input-row{display:flex;gap:8px;align-items:flex-end}
.adv-textarea{flex:1;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);color:#fff;border-radius:12px;padding:9px 13px;font-family:'Sora',sans-serif;font-size:0.83rem;line-height:1.5;resize:none;outline:none;max-height:120px;transition:border-color .15s}
.adv-textarea::placeholder{color:rgba(255,255,255,0.3)}
.adv-textarea:focus{border-color:rgba(167,139,250,0.5)}
.adv-send{width:38px;height:38px;border-radius:10px;flex-shrink:0;background:linear-gradient(135deg,#7c3aed,#4f46e5);border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s,opacity .15s}
.adv-send:hover{transform:scale(1.06)}
.adv-send:disabled{opacity:0.4;cursor:not-allowed;transform:none}
.adv-input-hint{font-size:0.62rem;color:rgba(255,255,255,0.2);margin-top:6px;text-align:center}
.toast{position:fixed;bottom:108px;right:28px;z-index:9999;background:#1a1a2e;color:#fff;padding:10px 18px;border-radius:10px;font-size:0.82rem;font-weight:500;box-shadow:0 6px 24px rgba(0,0,0,0.4);transform:translateY(20px);opacity:0;pointer-events:none;transition:all .3s}
.toast.show{transform:translateY(0);opacity:1}

.hamburger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px;border-radius:8px;transition:background .2s}
.hamburger:hover{background:rgba(19,37,115,0.08)}
.hamburger span{display:block;width:22px;height:2px;background:var(--navy);border-radius:2px;transition:transform .3s,opacity .3s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-menu{display:none;position:fixed;top:68px;left:0;right:0;background:#fff;border-bottom:1px solid var(--border);z-index:199;padding:1rem 5%;flex-direction:column;gap:0.2rem;box-shadow:0 8px 24px rgba(19,37,115,0.1)}
.mobile-menu.open{display:flex}
.mobile-menu a,.mobile-menu button{text-decoration:none;color:var(--text);font-size:0.95rem;font-weight:500;background:none;border:none;cursor:pointer;font-family:'Sora',sans-serif;padding:0.7rem 0.5rem;border-radius:8px;display:flex;align-items:center;gap:8px;transition:background .15s,color .15s;width:100%;text-align:left}
.mobile-menu a:hover,.mobile-menu button:hover{background:var(--light);color:var(--navy)}
.mobile-menu .mob-talaba{background:linear-gradient(135deg,#f59e0b,#ef4444);color:#fff!important;border-radius:8px;padding:0.6rem 1rem;justify-content:center;margin-bottom:0.5rem;font-weight:700}
.mobile-menu-overlay{display:none;position:fixed;inset:0;top:68px;z-index:198;background:rgba(0,0,0,0.3)}
.mobile-menu-overlay.open{display:block}
@media(max-width:768px){
  .nav-links{display:none}
  .hamburger{display:flex}
  .contact-layout,.bp2-packs,.pd-branches,.maitrise-choices,.modules-grid,.doc-type-choices{grid-template-columns:1fr}
  .footer-inner{grid-template-columns:1fr;gap:1.5rem}
  .videos-grid{grid-template-columns:1fr}
  .zp-layout{grid-template-columns:1fr}
  .modes-grid{grid-template-columns:1fr}
  .vc-layout,.mv-layout{grid-template-columns:1fr}
  .vc-sidebar,.mv-sidebar{display:none}
}
@media(max-width:480px){
  .schools-grid{grid-template-columns:repeat(2,1fr)}
  .fiches-grid,.fiches-doc-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:1fr}
}
/* ══════════════════════════════════════════════════════════════
   NOUVEAUX COMPOSANTS DYNAMIQUES & PROFESSIONNELS
   ══════════════════════════════════════════════════════════════ */

/* 1. News Ticker */
.news-ticker {
  background: linear-gradient(135deg, var(--navy), #1e3a9e);
  color: #fff; padding: 0; overflow: hidden; height: 36px;
  display: flex; align-items: center; position: relative; z-index: 300;
}
.ticker-label {
  background: var(--coral); color: #fff; font-weight: 800; font-size: 0.72rem;
  padding: 0.25rem 0.9rem; white-space: nowrap; flex-shrink: 0; letter-spacing: .5px;
  height: 100%; display: flex; align-items: center;
}
.ticker-track {
  display: flex; gap: 0; align-items: center; animation: ticker-scroll 40s linear infinite;
  white-space: nowrap;
}
.ticker-track:hover { animation-play-state: paused; }
.ticker-item {
  font-size: 0.78rem; font-weight: 500; padding: 0 2.5rem;
  display: inline-flex; align-items: center; gap: 6px;
}
.ticker-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--coral); flex-shrink: 0; }
@keyframes ticker-scroll { 0% { transform: translateX(0); } 100% { transform: translateX(-50%); } }

/* 2. Progression Bar (Lab de l'Élève) */
.lab-banner {
  background: linear-gradient(135deg, #132573 0%, #1e3a9e 50%, #7c3aed 100%);
  color: #fff; padding: 1.25rem 5%;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  flex-wrap: wrap;
}
.lab-left { display: flex; flex-direction: column; gap: 4px; }
.lab-title { font-weight: 800; font-size: 1rem; display: flex; align-items: center; gap: 7px; }
.lab-subtitle { font-size: 0.78rem; color: rgba(255,255,255,0.7); }
.lab-progress-wrap { flex: 1; max-width: 320px; min-width: 180px; }
.lab-progress-label { font-size: 0.72rem; color: rgba(255,255,255,0.7); margin-bottom: 4px; display: flex; justify-content: space-between; }
.lab-progress-bar-bg { background: rgba(255,255,255,0.2); border-radius: 99px; height: 10px; overflow: hidden; }
.lab-progress-bar-fill { background: linear-gradient(90deg, #4ade80, #a3e635); height: 100%; border-radius: 99px; transition: width 0.8s cubic-bezier(.22,1,.36,1); }
.lab-actions { display: flex; align-items: center; gap: 0.7rem; }
.lab-filter-select {
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25);
  color: #fff; border-radius: 8px; padding: 0.4rem 0.75rem; font-family: 'Sora', sans-serif;
  font-size: 0.8rem; cursor: pointer; outline: none;
}
.lab-filter-select option { color: var(--text); background: #fff; }
.lab-reset-btn {
  background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.2);
  color: #fff; border-radius: 8px; padding: 0.4rem 0.75rem; font-size: 0.78rem;
  cursor: pointer; font-family: 'Sora', sans-serif; transition: background .2s;
}
.lab-reset-btn:hover { background: rgba(255,255,255,0.2); }

/* 3. Stats Live Widget */
.live-stats-bar {
  background: var(--light); border-bottom: 1px solid var(--border);
  padding: 0.5rem 5%; display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap;
}
.live-stat { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--muted); }
.live-stat strong { color: var(--navy); font-weight: 700; }
.live-dot { width: 7px; height: 7px; border-radius: 50%; background: #4ade80; animation: pulse-dot 2s infinite; }
@keyframes pulse-dot { 0%, 100% { box-shadow: 0 0 0 0 rgba(74,222,128,0.4); } 50% { box-shadow: 0 0 0 5px rgba(74,222,128,0); } }

/* 4. Keyword Search */
.search-hero {
  padding: 1.5rem 5%; background: #fff; border-bottom: 1px solid var(--border);
  position: sticky; top: 68px; z-index: 190;
}
.search-bar-wrap { display: flex; gap: 0.75rem; align-items: center; max-width: 640px; margin: 0 auto; }
.search-input-wrap { position: relative; flex: 1; }
.search-input-icon { position: absolute; left: 12px; top: 50%; transform: translateY(-50%); color: var(--muted); pointer-events: none; }
.search-input {
  width: 100%; padding: 0.65rem 0.9rem 0.65rem 2.4rem;
  border: 2px solid var(--border); border-radius: 12px;
  font-family: 'Sora', sans-serif; font-size: 0.9rem; outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.search-input:focus { border-color: var(--navy); box-shadow: 0 0 0 3px rgba(19,37,115,0.08); }
.search-clear { position: absolute; right: 10px; top: 50%; transform: translateY(-50%); background: none; border: none; cursor: pointer; color: var(--muted); display: none; }
.search-count-badge { background: var(--navy); color: #fff; font-size: 0.75rem; font-weight: 700; padding: 0.3rem 0.7rem; border-radius: 99px; }

/* 5. Concours Simulator */
#quiz { padding: 2.5rem 5%; background: var(--light); }
.quiz-hero { text-align: center; max-width: 700px; margin: 0 auto 2rem; }
.quiz-hero h2 { font-size: 1.7rem; font-weight: 800; color: var(--navy); }
.timer-widget { display: flex; align-items: center; gap: 8px; background: #fff; border: 1.5px solid var(--border); border-radius: 12px; padding: 0.5rem 1rem; }
.timer-display { font-size: 1.3rem; font-weight: 800; color: var(--navy); min-width: 55px; }
.quiz-card { background: #fff; border-radius: var(--radius); padding: 1.75rem 2rem; max-width: 700px; margin: 0 auto; box-shadow: var(--shadow); border: 1.5px solid var(--border); }
.quiz-option { background: var(--light); border: 2px solid var(--border); border-radius: 10px; padding: 0.75rem 1rem; margin-bottom: 0.6rem; cursor: pointer; transition: all .2s; }
.quiz-option:hover { background: #e8ecf8; border-color: var(--navy); }

/* 6. Animations & Helpers */
@keyframes fadeInUp { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
.fade-in-section { opacity: 0; transform: translateY(20px); transition: opacity .5s ease, transform .5s ease; }
.fade-in-section.visible { opacity: 1; transform: none; }

/* Responsive adjustments */
@media(max-width:700px){
  .lab-banner { flex-direction: column; align-items: flex-start; }
  .quiz-bar { flex-direction: column; align-items: stretch; }
  .search-bar-wrap { flex-direction: column; }
}

/* ══════════════════════════════════════════════════════════════
   TABLEAU DE BORD
   ══════════════════════════════════════════════════════════════ */

/* Hero header */
.db-hero-header {
  background: linear-gradient(135deg, #132573 0%, #1e3a9e 60%, #7c3aed 100%);
  color: #fff; padding: 2rem 5%; display: flex; align-items: center;
  justify-content: space-between; gap: 1.5rem; flex-wrap: wrap;
}
.db-greeting { font-size: 1.35rem; font-weight: 800; line-height: 1.3; margin-bottom: 6px; }
.db-subline { font-size: 0.85rem; color: rgba(255,255,255,0.7); }
.db-streak-badge {
  display: flex; align-items: center; gap: 12px;
  background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.2);
  border-radius: 14px; padding: 0.9rem 1.2rem;
}
.db-streak-num { font-size: 1.7rem; font-weight: 800; line-height: 1; color: #fbbf24; }
.db-streak-label { font-size: 0.72rem; color: rgba(255,255,255,0.65); margin-top: 2px; }

/* Grid */
.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 20px; padding: 24px 5%;
}

/* Cards */
.stat-card {
  background: var(--white); border-radius: var(--radius);
  padding: 1.6rem 1.75rem; box-shadow: var(--shadow);
  border: 1px solid var(--border); display: flex; flex-direction: column; gap: 1rem;
}
.stat-card-head { display: flex; align-items: center; gap: 12px; }
.stat-card-icon {
  width: 40px; height: 40px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.stat-card-title { font-size: 0.95rem; font-weight: 800; color: var(--navy); }
.stat-card-sub { font-size: 0.74rem; color: var(--muted); margin-top: 2px; }

/* Focus ring */
.focus-ring-wrap {
  display: flex; align-items: center; justify-content: center; position: relative;
}
.focus-ring-svg { width: 140px; height: 140px; }
.focus-ring-inner {
  position: absolute; text-align: center;
}
.focus-ring-time { font-size: 1.5rem; font-weight: 800; color: var(--navy); }
.focus-ring-label { font-size: 0.7rem; color: var(--muted); }
.focus-sessions { display: flex; gap: 6px; flex-wrap: wrap; }
.focus-session-pill {
  background: var(--light); border: 1.5px solid var(--border);
  border-radius: 50px; padding: 5px 12px; font-size: 0.75rem; font-weight: 600;
  color: var(--text); display: flex; gap: 6px; align-items: center;
}
.focus-session-pill.active { background: rgba(19,37,115,0.07); border-color: var(--navy); color: var(--navy); }
.focus-session-pill span { color: var(--muted); font-weight: 400; }

/* Predict */
.predict-estimation {
  background: rgba(124,58,237,0.06); border: 1px solid rgba(124,58,237,0.15);
  border-radius: 10px; padding: 0.65rem 0.9rem; font-size: 0.83rem; color: var(--text);
  display: flex; gap: 8px; align-items: flex-start; line-height: 1.5;
}
.gauge-wrap { display: flex; flex-direction: column; gap: 6px; }
.gauge-label { display: flex; justify-content: space-between; font-size: 0.78rem; color: var(--muted); font-weight: 600; }
.gauge-pct { color: var(--navy); font-weight: 800; font-size: 0.9rem; }
.gauge-bg { background: var(--light); border-radius: 99px; height: 12px; overflow: hidden; }
.gauge-fill {
  height: 100%; border-radius: 99px;
  background: linear-gradient(90deg, #ef4444 0%, #f59e0b 45%, #22c55e 100%);
  transition: width 1.5s cubic-bezier(.22,1,.36,1);
}
.gauge-ticks { display: flex; justify-content: space-between; font-size: 0.65rem; color: var(--muted); }
.predict-reco {
  display: flex; gap: 10px; background: rgba(251,191,36,0.08);
  border: 1px solid rgba(251,191,36,0.25); border-radius: 10px;
  padding: 0.65rem 0.9rem; font-size: 0.8rem; line-height: 1.5; color: var(--text);
}
.predict-reco-icon { font-size: 1.1rem; flex-shrink: 0; }
.predict-module-btn {
  display: inline-flex; align-items: center; gap: 7px;
  background: var(--purple); color: #fff; border: none; border-radius: 9px;
  padding: 0.55rem 1.1rem; font-family: 'Sora', sans-serif; font-size: 0.83rem;
  font-weight: 700; cursor: pointer; transition: opacity .2s, transform .15s; margin-top: 2px;
}
.predict-module-btn:hover { opacity: .88; transform: translateY(-1px); }

/* Progress chart row */
.progress-stats-row {
  display: flex; justify-content: space-around; gap: 10px;
  border-top: 1px solid var(--border); padding-top: 0.8rem;
}
.progress-stat-item { text-align: center; }
.progress-stat-val { font-size: 1.15rem; font-weight: 800; color: var(--navy); }
.progress-stat-lbl { font-size: 0.7rem; color: var(--muted); margin-top: 2px; }

/* Radar legend & upgrade */
.radar-legend { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }
.radar-legend-item { display: flex; align-items: center; gap: 6px; font-size: 0.78rem; color: var(--muted); font-weight: 600; }
.radar-dot { width: 10px; height: 10px; border-radius: 50%; display: inline-block; flex-shrink: 0; }
.upgrade-teaser {
  background: linear-gradient(135deg, rgba(245,158,11,0.07), rgba(239,68,68,0.07));
  border: 1.5px solid rgba(245,158,11,0.2); border-radius: 11px;
  padding: 0.8rem 1rem; display: flex; align-items: center;
  justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.upgrade-teaser-text { font-size: 0.8rem; color: var(--text); line-height: 1.45; flex: 1; }
.btn-upgrade {
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  color: #fff; border: none; border-radius: 9px;
  padding: 0.5rem 1rem; font-family: 'Sora', sans-serif;
  font-size: 0.8rem; font-weight: 700; cursor: pointer;
  display: inline-flex; align-items: center; gap: 6px;
  transition: opacity .2s, transform .15s; white-space: nowrap;
  box-shadow: 0 3px 12px rgba(239,68,68,0.3);
}
.btn-upgrade:hover { opacity: .88; transform: translateY(-1px); }

@media(max-width:700px){
  .dashboard-grid { grid-template-columns: 1fr; padding: 16px 5%; }
  .db-hero-header { flex-direction: column; align-items: flex-start; }
}

/* ══ SETTINGS PAGE ══ */
.settings-layout{display:flex;min-height:calc(100vh - 68px);gap:0;max-width:1100px;margin:0 auto;padding:2rem 5% 4rem;}
.settings-sidebar{width:220px;flex-shrink:0;}
.settings-sidebar-inner{position:sticky;top:88px;display:flex;flex-direction:column;gap:4px;}
.settings-tab{display:flex;align-items:center;gap:8px;padding:0.65rem 1rem;border:none;border-radius:10px;background:none;color:var(--muted);font-family:'Sora',sans-serif;font-weight:600;font-size:0.88rem;cursor:pointer;text-align:left;transition:background .15s,color .15s;}
.settings-tab:hover{background:var(--light);color:var(--navy);}
.settings-tab.active{background:var(--navy);color:#fff;}
.settings-content{flex:1;padding-left:2.5rem;min-width:0;}
.settings-pane{display:none;}
.settings-pane.active{display:block;animation:fadeInUp .3s ease;}
.settings-pane-header{margin-bottom:1.5rem;}
.settings-pane-title{font-size:1.4rem;font-weight:800;color:var(--navy);margin-bottom:4px;}
.settings-pane-sub{font-size:0.87rem;color:var(--muted);}
.settings-card{background:#fff;border:1.5px solid var(--border);border-radius:16px;padding:1.25rem 1.4rem;margin-bottom:1.25rem;box-shadow:0 2px 10px rgba(19,37,115,0.06);}
.settings-card-title{display:flex;align-items:center;gap:7px;font-weight:800;color:var(--navy);font-size:0.93rem;margin-bottom:1.1rem;}
.settings-field-group{margin-bottom:1rem;}
.settings-label{display:block;font-weight:700;color:var(--navy);font-size:0.82rem;margin-bottom:5px;}
.settings-input{width:100%;border:1.5px solid var(--border);border-radius:10px;padding:0.6rem 0.9rem;font-size:0.88rem;font-family:'Sora',sans-serif;outline:none;transition:border-color .2s;background:#fff;color:var(--text);}
.settings-input:focus{border-color:var(--navy);}
.settings-textarea{resize:vertical;min-height:80px;}
.settings-hint{font-size:0.76rem;color:var(--muted);margin-top:4px;display:block;}
.settings-btn-save{display:inline-flex;align-items:center;gap:7px;background:var(--navy);color:#fff;border:none;border-radius:10px;padding:0.65rem 1.3rem;font-family:'Sora',sans-serif;font-weight:700;font-size:0.88rem;cursor:pointer;transition:opacity .2s,transform .15s;}
.settings-btn-save:hover{opacity:0.88;transform:translateY(-1px);}
.settings-btn-save:disabled{opacity:0.55;cursor:not-allowed;transform:none;}
.settings-btn-outline{display:inline-flex;align-items:center;gap:7px;background:var(--light);color:var(--navy);border:1.5px solid var(--border);border-radius:10px;padding:0.6rem 1.1rem;font-family:'Sora',sans-serif;font-weight:700;font-size:0.85rem;cursor:pointer;transition:background .15s;}
.settings-btn-outline:hover{background:#eaf0ff;}
/* Profile progress */
.profile-progress-card{background:linear-gradient(135deg,rgba(19,37,115,0.04),rgba(255,141,141,0.08));border:1.5px solid var(--border);border-radius:16px;padding:1.1rem 1.4rem;margin-bottom:1.25rem;}
.progress-bar-bg{width:100%;height:8px;background:var(--border);border-radius:99px;overflow:hidden;margin-bottom:6px;}
.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--navy),var(--coral));border-radius:99px;transition:width .5s ease;}
.progress-hint{font-size:0.78rem;color:var(--muted);}
/* Avatar */
.avatar-preview-row{display:flex;align-items:center;gap:18px;}
.settings-avatar-big{width:70px;height:70px;border-radius:50%;background:linear-gradient(135deg,var(--navy-light),var(--navy));color:#fff;font-weight:800;font-size:1.6rem;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 16px rgba(19,37,115,0.22);overflow:hidden;}
.settings-avatar-big img{width:100%;height:100%;object-fit:cover;border-radius:50%;}
/* Password strength */
.pwd-strength-bar{width:100%;height:5px;background:var(--border);border-radius:99px;overflow:hidden;margin-top:6px;}
.pwd-strength-fill{height:100%;border-radius:99px;transition:width .3s,background .3s;}
.pwd-strength-label{font-size:0.76rem;font-weight:700;margin-top:3px;display:block;}
/* Theme selector */
.theme-selector-row{display:flex;gap:14px;}
.theme-option{display:flex;flex-direction:column;align-items:center;gap:7px;padding:12px;border:2px solid var(--border);border-radius:12px;cursor:pointer;font-family:'Sora',sans-serif;font-size:0.82rem;font-weight:700;color:var(--muted);transition:border-color .2s,color .2s;min-width:90px;}
.theme-option.active{border-color:var(--navy);color:var(--navy);}
.theme-preview{width:60px;height:40px;border-radius:8px;border:1px solid var(--border);}
.light-preview{background:linear-gradient(135deg,#f5f7ff 60%,#fff);}
.dark-preview{background:linear-gradient(135deg,#132573 60%,#1e3a9e);}
/* Notifications toggles */
.notif-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:0.75rem 0;border-bottom:1px solid var(--border);}
.notif-row:last-child{border-bottom:none;}
.notif-label{font-weight:700;color:var(--navy);font-size:0.87rem;}
.notif-sub{font-size:0.77rem;color:var(--muted);margin-top:2px;}
.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--border);border-radius:24px;transition:.3s;}
.toggle-slider:before{position:absolute;content:'';width:18px;height:18px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.3s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
input:checked+.toggle-slider{background:var(--navy);}
input:checked+.toggle-slider:before{transform:translateX(20px);}
/* Badges */
.badge-disabled{display:inline-block;background:#fef3c7;color:#b45309;font-size:0.72rem;font-weight:700;border-radius:99px;padding:2px 9px;margin-top:4px;}
.badge-active{display:inline-block;background:#dcfce7;color:#16a34a;font-size:0.72rem;font-weight:700;border-radius:99px;padding:2px 9px;}
/* Login history */
.login-history-item{display:flex;align-items:center;justify-content:space-between;padding:0.6rem 0;border-bottom:1px solid var(--border);}
.login-history-item:last-child{border-bottom:none;}
/* Skeleton */
.settings-skeleton-wrap{max-width:700px;margin:2.5rem auto;padding:0 5%;}
.skel-line{background:linear-gradient(90deg,#eef2ff 25%,#e0e7ff 50%,#eef2ff 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:10px;}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
/* Visitor preview modal */
.visitor-preview-card{background:#fff;border-radius:20px;padding:1.8rem;max-width:380px;width:90%;box-shadow:0 24px 64px rgba(19,37,115,0.2);}
/* Responsive */
@media(max-width:700px){
  .settings-layout{flex-direction:column;padding:1rem 4% 3rem;}
  .settings-sidebar{width:100%;}
  .settings-sidebar-inner{flex-direction:row;flex-wrap:wrap;gap:6px;position:static;}
  .settings-tab{font-size:0.78rem;padding:0.5rem 0.8rem;}
  .settings-content{padding-left:0;margin-top:1.5rem;}
  .theme-selector-row{flex-wrap:wrap;}
}

/* ══ DARK MODE ══ */
[data-theme="dark"] {
  --navy:#a8b8f8;
  --navy-dark:#c5d0fa;
  --navy-light:#7b91ed;
  --coral:#ff9f9f;
  --slate:#b0bec5;
  --light:#1e2235;
  --white:#12151f;
  --text:#e8eaf0;
  --muted:#8892a4;
  --border:rgba(168,184,248,0.18);
  --shadow:0 4px 24px rgba(0,0,0,0.35);
  --purple:#b197fc;
  --purple-light:#c4b0ff;
  --purple-bg:rgba(177,151,252,0.12);
  --green:#4ade80;
  --amber:#fbbf24;
}
[data-theme="dark"] body,
[data-theme="dark"] {
  background:#0e1120;
  color:#e8eaf0;
}
[data-theme="dark"] nav.main-nav,
[data-theme="dark"] nav[style*="background:#fff"],
[data-theme="dark"] nav[style*="background: #fff"] {
  background:#13172a !important;
  border-bottom-color:rgba(168,184,248,0.15) !important;
}
[data-theme="dark"] .page {
  background:#0e1120;
}
/* Auth gate stays readable */
[data-theme="dark"] #auth-gate {
  background:rgba(10,12,25,0.97);
}
[data-theme="dark"] .auth-card {
  background:#13172a;
  border-color:rgba(168,184,248,0.15);
}
[data-theme="dark"] .auth-input {
  background:#1a1f35;
  border-color:rgba(168,184,248,0.2);
  color:#e8eaf0;
}
[data-theme="dark"] .auth-input::placeholder { color:#596275; }
[data-theme="dark"] .auth-tab { color:#8892a4; }
[data-theme="dark"] .auth-tabs { background:#1a1f35; }
[data-theme="dark"] .auth-tab.active { background:#232843; color:#a8b8f8; }
/* Cards */
[data-theme="dark"] .stat-card,
[data-theme="dark"] .settings-card,
[data-theme="dark"] .profile-progress-card,
[data-theme="dark"] .visitor-preview-card,
[data-theme="dark"] .delete-modal,
[data-theme="dark"] .db-hero-header {
  background:#13172a !important;
  border-color:rgba(168,184,248,0.15) !important;
}
[data-theme="dark"] .compte-menu {
  background:#13172a;
  border-color:rgba(168,184,248,0.18);
  box-shadow:0 16px 48px rgba(0,0,0,0.5);
}
[data-theme="dark"] .compte-item:hover { background:#1e2235; }
[data-theme="dark"] .compte-sep { border-top-color:rgba(168,184,248,0.12); }
/* Inputs */
[data-theme="dark"] .settings-input {
  background:#1a1f35;
  border-color:rgba(168,184,248,0.2);
  color:#e8eaf0;
}
[data-theme="dark"] .settings-input::placeholder { color:#596275; }
[data-theme="dark"] .settings-input:focus { border-color:#a8b8f8; }
[data-theme="dark"] .settings-input[readonly] { background:#13172a; }
/* Sidebar */
[data-theme="dark"] .settings-sidebar-inner .settings-tab { color:#8892a4; }
[data-theme="dark"] .settings-tab:hover { background:#1e2235; color:#a8b8f8; }
[data-theme="dark"] .settings-tab.active { background:#a8b8f8; color:#0e1120; }
/* Buttons */
[data-theme="dark"] .settings-btn-outline {
  background:#1a1f35;
  border-color:rgba(168,184,248,0.25);
  color:#a8b8f8;
}
[data-theme="dark"] .settings-btn-outline:hover { background:#232843; }
[data-theme="dark"] .back-btn {
  background:#1a1f35 !important;
  border-color:rgba(168,184,248,0.2) !important;
  color:#a8b8f8 !important;
}
/* Theme options */
[data-theme="dark"] .theme-option { border-color:rgba(168,184,248,0.2); color:#8892a4; }
[data-theme="dark"] .theme-option.active { border-color:#a8b8f8; color:#a8b8f8; }
/* Notif rows */
[data-theme="dark"] .notif-row { border-bottom-color:rgba(168,184,248,0.1); }
/* Progress bar */
[data-theme="dark"] .progress-bar-bg { background:rgba(168,184,248,0.15); }
/* Skeleton */
[data-theme="dark"] .skel-line {
  background:linear-gradient(90deg,#1a1f35 25%,#232843 50%,#1a1f35 75%);
  background-size:200% 100%;
}
/* Mobile menu */
[data-theme="dark"] #mobileMenu {
  background:#13172a;
  border-bottom-color:rgba(168,184,248,0.15);
}
[data-theme="dark"] #mobileMenu button { color:#a8b8f8 !important; }
/* Hero section */
[data-theme="dark"] .hero { background:#0e1120; }
[data-theme="dark"] .hero-badge { background:#1a1f35; color:#a8b8f8; border-color:rgba(168,184,248,0.2); }
[data-theme="dark"] .hero h1, [data-theme="dark"] .hero p { color:#e8eaf0; }
/* Sections */
[data-theme="dark"] section { background:#0e1120; }
[data-theme="dark"] #features { background:#0e1120; }
[data-theme="dark"] #videos { background:#13172a !important; }
[data-theme="dark"] #contact { background:#0e1120; }
[data-theme="dark"] .feature-card {
  background:#13172a;
  border-color:rgba(168,184,248,0.15);
}
/* Footer */
[data-theme="dark"] footer, [data-theme="dark"] .footer-main {
  background:#080a14 !important;
  border-top-color:rgba(168,184,248,0.1) !important;
}
[data-theme="dark"] footer button, [data-theme="dark"] footer a { color:#8892a4 !important; }
/* Leaderboard */
[data-theme="dark"] .lb-card, [data-theme="dark"] .lb-row {
  background:#13172a;
  border-color:rgba(168,184,248,0.15);
}
/* Dashboard */
[data-theme="dark"] .db-hero-header { background:linear-gradient(135deg,#13172a,#1a1f35) !important; }
[data-theme="dark"] .dashboard-grid .stat-card { background:#13172a; }
/* Scrollbar */
[data-theme="dark"] ::-webkit-scrollbar-track { background:#13172a; }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background:#2d3454; border-radius:99px; }
/* Toggle slider checked in dark mode */
[data-theme="dark"] input:checked+.toggle-slider { background:#a8b8f8; }
/* Badge */
[data-theme="dark"] .badge-disabled { background:#2d2210; color:#fbbf24; }
[data-theme="dark"] .badge-active { background:#0f2a1a; color:#4ade80; }
/* Login history */
[data-theme="dark"] .login-history-item { border-bottom-color:rgba(168,184,248,0.1); }
/* Advisor panel */
[data-theme="dark"] #advisorPanel {
  background:#13172a;
  border-color:rgba(168,184,248,0.15);
}
[data-theme="dark"] .adv-msg-bubble {
  background:#1a1f35;
  color:#e8eaf0;
}
[data-theme="dark"] .adv-msg.user .adv-msg-bubble {
  background:#232843;
}
