@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --v:#2D1B69;--v2:#4A2D9C;--vl:#EDE9FD;--vm:#C4B8F8;
  --mint:#00C9A7;--mintl:#D6F7F1;
  --amb:#F5A623;--ambl:#FFF0D6;
  --rose:#FF6B8A;--rosel:#FFE8EE;
  --sky:#4DAEE8;--skyl:#E0F3FC;
  --ink:#1A0A00;--ink2:#5B3A1F;--ink3:#A08060;
  --bg:#F7F3FF;--card:#FFFFFF;--bdr:rgba(45,27,105,0.13);
  --r:18px;--rs:12px;--rxs:8px;
}
html,body{min-height:100%;height:100%}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;overflow-x:hidden}
#app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;max-width:480px;margin:0 auto;background:var(--bg);position:relative}
.screen{display:none;flex-direction:column;min-height:100vh;min-height:100dvh;width:100%}
.screen.active{display:flex}

/* MODE BANNER */
.mode-banner{display:flex;align-items:center;gap:10px;padding:8px 14px;flex-shrink:0;font-size:11px;font-weight:700}
.mode-banner.dev{background:#1A1033;color:#F5A623}
.mode-banner.beta{background:#0F6E56;color:#D6F7F1}
.mode-banner.prod{background:#185FA5;color:#E0F3FC}
.mode-dot{width:7px;height:7px;border-radius:50%;background:currentColor;animation:pulse2 1.5s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:0.4}}
.mode-label{flex:1}
.mode-btn{padding:3px 8px;border:1px solid currentColor;border-radius:10px;cursor:pointer;background:transparent;color:inherit;font-family:'Plus Jakarta Sans',sans-serif;font-size:10px;font-weight:700}

/* HEADER — collé en haut */
.hdr{
  background:var(--v);padding:14px 16px 18px;
  border-radius:0 0 24px 24px;
  display:flex;align-items:center;gap:12px;
  flex-shrink:0;
  position:sticky;top:0;
  overflow:hidden;z-index:5;
  padding-top:calc(14px + env(safe-area-inset-top));
}
.hdr::before{content:'';position:absolute;top:-40px;right:-30px;width:130px;height:130px;border-radius:50%;background:rgba(255,255,255,0.07)}
.hdr-logo{flex-shrink:0;z-index:1}
.hdr-brand{flex:1;z-index:1}
.hdr-brand h1{font-size:22px;font-weight:800;color:#fff;letter-spacing:-0.5px;line-height:1}
.hdr-brand p{font-size:10px;color:rgba(255,255,255,0.6);margin-top:2px}
.hdr-right{z-index:1;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.plan-pill{font-size:9px;font-weight:800;padding:3px 9px;border-radius:14px}
.plan-dev{background:#F5A623;color:#412402}
.plan-beta{background:#00C9A7;color:#04342C}
.plan-family{background:#F5A623;color:#412402}
.grade-pill{display:flex;align-items:center;gap:5px;background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.25);border-radius:20px;padding:4px 10px 4px 8px}
.grade-dot{width:7px;height:7px;border-radius:50%;background:var(--mint);flex-shrink:0}
.grade-pill select{background:transparent;border:none;color:white;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;cursor:pointer;outline:none;-webkit-appearance:none}
.grade-pill select option{color:var(--ink);background:white}
.xp-val{font-size:14px;font-weight:800;color:var(--amb)}

/* SCROLL — chaque panel se comporte comme une page normale */
.scroll{
  flex:1 1 auto;
  width:100%;
  padding:12px 14px 110px;          /* espace pour la nav + safe area iPhone */
  -webkit-overflow-scrolling:touch;
}
/* Pas de scroll forcé sur .scroll — c'est la page entière qui scrolle */
body.modal-open{overflow:hidden;position:fixed;width:100%}

/* NAV — fixée en bas de l'écran */
.nav-bar{
  background:var(--card);
  border-top:1px solid var(--bdr);
  display:flex;padding:8px 4px;gap:2px;
  padding-bottom:calc(8px + env(safe-area-inset-bottom));
  position:fixed;bottom:0;left:0;right:0;
  max-width:480px;margin:0 auto;
  z-index:10;
}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;padding:6px 2px;border-radius:var(--rxs);cursor:pointer;border:none;background:transparent;font-family:'Plus Jakarta Sans',sans-serif;transition:all 0.15s}
.ni.active{background:var(--vl)}
.ni svg{width:19px;height:19px;stroke:#A08060;fill:none;stroke-width:2;stroke-linecap:round}
.ni.active svg{stroke:var(--v2)}
.ni span{font-size:9px;font-weight:700;color:#A08060}
.ni.active span{color:var(--v2)}

/* CARDS */
.card{background:var(--card);border-radius:var(--r);border:1.5px solid var(--bdr);padding:15px;margin-bottom:10px}
.card-title{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:10px}
.sec-lbl{font-size:10px;font-weight:700;color:var(--ink3);text-transform:uppercase;letter-spacing:0.9px;margin-bottom:9px;display:block}

/* BUTTONS */
.btn{padding:11px 16px;border-radius:var(--rs);font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;cursor:pointer;border:none;transition:all 0.18s;display:inline-flex;align-items:center;gap:7px;justify-content:center;width:100%}
.btn-v{background:var(--v2);color:#fff}
.btn-v:hover{background:#3A2282}
.btn-ghost{background:transparent;color:var(--ink2);border:1.5px solid var(--bdr)}
.btn-mint{background:var(--mint);color:#04342C}
.btn-sm{padding:6px 12px;font-size:11px;border-radius:20px;width:auto}

/* FORM */
.field{margin-bottom:12px}
.field label{font-size:11px;font-weight:700;color:var(--ink2);display:block;margin-bottom:5px}
.field input,.field select,.field textarea{width:100%;padding:10px 13px;border:1.5px solid var(--bdr);border-radius:var(--rxs);font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;color:var(--ink);background:var(--bg);outline:none;transition:border-color 0.18s}
.field input:focus,.field select:focus{border-color:var(--v2)}
.field input::placeholder{color:var(--ink3)}
.field textarea{resize:none;height:76px}

/* CHAT */
.chat-wrap{display:flex;flex-direction:column;flex:1;overflow:hidden}
.chat-msgs{flex:1 1 auto;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:9px;min-height:60vh;-webkit-overflow-scrolling:touch}
.chat-msgs::-webkit-scrollbar{display:none}
.brow{display:flex;gap:7px;align-items:flex-end}
.brow.me{flex-direction:row-reverse}
.bav{width:28px;height:28px;border-radius:50%;background:var(--vl);overflow:hidden;flex-shrink:0;display:flex;align-items:center;justify-content:center}
.bbl{max-width:74%;padding:9px 13px;font-size:12px;line-height:1.55;border-radius:16px}
.brow.owl .bbl{background:var(--vl);color:var(--ink);border-radius:3px 16px 16px 16px}
.brow.me .bbl{background:var(--v2);color:#fff;border-radius:16px 3px 16px 16px}
.chat-foot{padding:9px 11px 11px;border-top:1px solid var(--bdr);display:flex;gap:7px;align-items:center;flex-shrink:0;background:var(--card);position:sticky;bottom:calc(64px + env(safe-area-inset-bottom));z-index:8}
.cin{flex:1;background:var(--bg);border:1.5px solid transparent;border-radius:22px;padding:9px 13px;font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;transition:border-color 0.18s}
.cin:focus{border-color:var(--v2)}
.cin::placeholder{color:var(--ink3)}
.ibtn{width:34px;height:34px;border-radius:50%;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.send-btn{background:var(--v2)}
.mic-btn{background:var(--mintl)}
.mic-btn.rec{background:var(--rosel);animation:micp 1s infinite}
@keyframes micp{0%,100%{box-shadow:0 0 0 0 rgba(255,107,138,0.3)}50%{box-shadow:0 0 0 7px rgba(255,107,138,0)}}
.chip-row{display:flex;gap:6px;flex-wrap:wrap;padding:6px 10px 8px}
.cb{padding:5px 10px;border:none;border-radius:16px;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;cursor:pointer}
.tdots{display:flex;gap:4px;padding:5px 2px}
.tdot{width:6px;height:6px;border-radius:50%;background:var(--v2);opacity:0.5;animation:bop 1.1s infinite}
.tdot:nth-child(2){animation-delay:.2s}
.tdot:nth-child(3){animation-delay:.4s}
@keyframes bop{0%,60%,100%{transform:translateY(0);opacity:0.5}30%{transform:translateY(-5px);opacity:1}}

/* QUICK GRID */
.quick-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-bottom:10px}
.qcard{background:var(--card);border-radius:var(--r);border:1.5px solid var(--bdr);padding:13px;cursor:pointer;transition:all 0.15s}
.qcard:hover{border-color:var(--v2);transform:translateY(-2px)}
.qi{width:36px;height:36px;border-radius:11px;display:flex;align-items:center;justify-content:center;margin-bottom:7px}
.ql{font-size:12px;font-weight:800;color:var(--ink)}
.qd{font-size:10px;color:var(--ink3);margin-top:1px}

/* LESSONS */
.lscroll{display:flex;gap:9px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}
.lscroll::-webkit-scrollbar{display:none}
.lchip{flex-shrink:0;min-width:118px;background:var(--card);border:1.5px solid var(--bdr);border-radius:var(--rs);padding:11px 13px;cursor:pointer;transition:all 0.13s}
.lchip:hover{border-color:var(--v2)}
.ls{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.6px;margin-bottom:4px}
.lt{font-size:11px;font-weight:700;color:var(--ink);line-height:1.3}
.lb{height:3px;border-radius:2px;background:rgba(0,0,0,0.07);margin-top:7px}
.lf{height:100%;border-radius:2px}
.lr{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--card);border-radius:var(--rs);border:1.5px solid var(--bdr);margin-bottom:7px;cursor:pointer;transition:all 0.13s}
.lr:hover{border-color:var(--v2)}
.lr-ic{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* UPLOAD */
.upload-z{border:2px dashed var(--vm);border-radius:var(--r);padding:26px 16px;text-align:center;cursor:pointer;transition:all 0.18s;background:var(--vl);margin-bottom:11px}
.upload-z:hover{border-color:var(--v2);background:rgba(74,45,156,0.1)}
.upload-z p{font-size:12px;color:var(--v2);font-weight:700;margin-top:7px}
.upload-z span{font-size:10px;color:var(--ink3)}

/* RECITE */
.prog-row{display:flex;align-items:center;gap:9px;margin-bottom:10px}
.prog-t{flex:1;height:7px;background:var(--bg);border-radius:4px;overflow:hidden}
.prog-f{height:100%;background:var(--mint);border-radius:4px;transition:width 0.4s}
.prog-p{font-size:12px;font-weight:800;color:var(--mint)}
.qbox{background:var(--vl);border-radius:13px;padding:13px;margin-bottom:10px;font-size:12px;color:var(--ink);line-height:1.6;min-height:54px}
.kchips{display:flex;flex-wrap:wrap;gap:5px}
.kc{padding:4px 9px;border-radius:16px;font-size:10px;font-weight:700}
.kc-ok{background:var(--mintl);color:#085041}
.kc-w{background:var(--ambl);color:#633806}
.kc-f{background:var(--rosel);color:#72243E}

/* STATS */
.stat-g{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:10px}
.stat-b{background:var(--card);border-radius:var(--rs);border:1.5px solid var(--bdr);padding:12px;text-align:center}
.stat-n{font-size:20px;font-weight:800;color:var(--v2)}
.stat-l{font-size:10px;color:var(--ink3);margin-top:2px}
.bar-c{display:flex;flex-direction:column;gap:7px}
.bar-r{display:flex;align-items:center;gap:8px}
.bar-lb{font-size:10px;color:var(--ink3);width:54px;flex-shrink:0;text-align:right}
.bar-tr{flex:1;height:7px;background:rgba(45,27,105,0.08);border-radius:4px;overflow:hidden}
.bar-fl{height:100%;border-radius:4px;background:var(--v2);transition:width 0.5s}
.bar-vl{font-size:10px;font-weight:700;color:var(--ink2);width:34px;flex-shrink:0}

/* PLANS */
.pc{background:var(--card);border-radius:var(--r);border:1.5px solid var(--bdr);padding:14px;margin-bottom:9px;position:relative;cursor:pointer;transition:all 0.15s}
.pc:hover{border-color:var(--v2)}
.pc.feat{border:2px solid var(--v2)}
.pbdg{position:absolute;top:-1px;right:13px;background:var(--v2);color:#fff;font-size:9px;font-weight:800;padding:3px 8px;border-radius:0 0 7px 7px}
.pn{font-size:13px;font-weight:800;color:var(--ink);margin-bottom:3px}
.pa{display:flex;align-items:baseline;gap:3px;margin-bottom:3px}
.pe{font-size:22px;font-weight:800;color:var(--ink)}
.pp{font-size:11px;color:var(--ink3)}
.pd{font-size:11px;color:var(--ink3);margin-bottom:10px}
.pf{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.pfi{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--ink2)}
.pfck{width:14px;height:14px;border-radius:50%;background:var(--mintl);display:flex;align-items:center;justify-content:center;flex-shrink:0}

/* REPORT */
.freq-tog{display:flex;gap:3px;background:var(--bg);border-radius:var(--rxs);padding:3px;margin-bottom:11px}
.fb{flex:1;padding:7px;border:none;border-radius:6px;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:700;cursor:pointer;background:transparent;color:var(--ink3)}
.fb.on{background:var(--v2);color:#fff}
.rp{background:var(--vl);border-radius:var(--rs);padding:11px;margin-bottom:10px}
.rprow{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px solid rgba(45,27,105,0.1);font-size:11px}
.rprow:last-child{border:none}
.rpk{color:var(--ink2)}
.rpv{font-weight:700;color:var(--v2)}

/* CHILDREN */
.child-c{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--card);border-radius:var(--rs);border:1.5px solid var(--bdr);margin-bottom:7px;cursor:pointer;transition:all 0.13s}
.child-c:hover{border-color:var(--v2)}
.av{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;flex-shrink:0}
.add-c{display:flex;align-items:center;gap:8px;padding:10px 12px;border:2px dashed var(--vm);border-radius:var(--rs);cursor:pointer;color:var(--v2);font-size:12px;font-weight:700;background:transparent;font-family:'Plus Jakarta Sans',sans-serif;width:100%;transition:all 0.13s;margin-bottom:7px}
.add-c:hover{background:var(--vl)}
.online-dot{width:6px;height:6px;border-radius:50%;background:var(--mint);display:inline-block;margin-right:3px}

/* AUTH */
.auth-wrap{padding:28px 20px;overflow-y:auto;flex:1}
.auth-logo{display:flex;align-items:center;gap:13px;margin-bottom:28px}
.auth-logo h2{font-size:24px;font-weight:800;color:var(--ink)}
.auth-logo p{font-size:11px;color:var(--ink3)}
.auth-title{font-size:18px;font-weight:800;color:var(--ink);margin-bottom:16px}
.auth-sw{text-align:center;font-size:12px;color:var(--ink3);margin-top:13px}
.auth-sw a{color:var(--v2);font-weight:700;cursor:pointer}
.ibox{border-radius:var(--rxs);padding:9px 11px;font-size:11px;margin-bottom:12px}
.ibox-b{background:var(--skyl);color:#0C447C}
.ibox-a{background:var(--ambl);color:#633806}
.ibox-g{background:var(--mintl);color:#085041}

/* SHARE */
.share-url{background:var(--bg);border-radius:var(--rxs);padding:8px 10px;font-size:10px;color:var(--ink2);font-family:monospace;word-break:break-all;margin-bottom:10px;border:1px solid var(--bdr)}

/* MODAL — scroll iOS fix */
.modal-ov{
  display:none;
  position:fixed;inset:0;          /* couvre tout l'écran */
  background:rgba(26,10,0,0.62);
  z-index:200;
  overflow-y:auto;                  /* scroll de la modale elle-même */
  -webkit-overflow-scrolling:touch;
  padding:24px 14px 40px;           /* espace en bas pour le safe area */
  align-items:flex-start;           /* ne pas coller en bas — permet le scroll */
  justify-content:center;
}
.modal-ov.open{display:flex}
.modal-box{
  background:var(--card);
  border-radius:22px;
  padding:18px;
  width:100%;
  max-width:460px;
  /* PAS de max-height ici — on laisse le contenu dicter la taille */
}
.modal-box h3{font-size:14px;font-weight:800;color:var(--ink);margin-bottom:13px}
.modal-btns{display:flex;gap:7px;margin-top:12px}
.mbc{flex:1;padding:10px;border-radius:var(--rxs);border:1.5px solid var(--bdr);background:var(--bg);font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:600;color:var(--ink3);cursor:pointer}
.mbo{flex:2;padding:10px;border-radius:var(--rxs);border:none;background:var(--v2);color:#fff;font-family:'Plus Jakarta Sans',sans-serif;font-size:12px;font-weight:700;cursor:pointer}

/* SAFETY */
.safety{display:flex;align-items:center;gap:6px;background:var(--mintl);border-radius:var(--rxs);padding:7px 10px;font-size:10px;color:#085041;margin-bottom:10px}

/* TOAST */
#toast{position:fixed;top:14px;left:50%;transform:translateX(-50%) translateY(-70px);background:var(--ink);color:#fff;padding:9px 18px;border-radius:18px;font-size:12px;font-weight:700;white-space:nowrap;z-index:9999;transition:transform 0.28s;pointer-events:none}
#toast.show{transform:translateX(-50%) translateY(0)}

/* INSTALL BANNER */
#install-banner{display:none;background:var(--v);color:#fff;padding:11px 14px;align-items:center;gap:10px;flex-shrink:0}
#install-banner.show{display:flex}
#install-banner p{flex:1;font-size:12px;font-weight:600}
#install-banner button{background:white;color:var(--v2);border:none;border-radius:var(--rxs);padding:6px 13px;font-family:'Plus Jakarta Sans',sans-serif;font-size:11px;font-weight:800;cursor:pointer}
#install-dismiss{background:transparent!important;color:rgba(255,255,255,0.6)!important;font-size:15px!important}

@media(min-width:480px){#app{box-shadow:0 0 40px rgba(45,27,105,0.15)}}
.screen.active{animation:fadein 0.2s ease}
@keyframes fadein{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
::-webkit-scrollbar{display:none}

/* ── SELECTOR SCREEN (qui veut travailler ?) ── */
.selector-wrap{padding:20px 16px;flex:1;width:100%}
.selector-header{text-align:center;margin-bottom:24px;margin-top:14px}
.selector-header h2{font-size:20px;font-weight:800;color:var(--ink);margin-bottom:4px}
.selector-header p{font-size:13px;color:var(--ink3)}
.selector-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px}
.selector-card{background:var(--card);border-radius:18px;padding:16px;cursor:pointer;transition:all 0.18s;text-align:center;border:1.5px solid var(--bdr)}
.selector-card:hover{transform:translateY(-2px);border-color:var(--v2);box-shadow:0 6px 18px rgba(45,27,105,0.1)}
.selector-card:active{transform:scale(0.97)}
.selector-avatar{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 10px}
.selector-name{font-size:14px;font-weight:800;color:var(--ink)}
.selector-grade{font-size:11px;color:var(--ink3);margin-top:2px}
.selector-parent{background:#1A0A00;color:white;border-color:#1A0A00}
.selector-parent .selector-name{color:white}
.selector-parent .selector-grade{color:rgba(255,255,255,0.6)}
.selector-add{background:var(--bg);border:1.5px dashed var(--vm)}

.selector-footer{text-align:center;padding-top:14px;border-top:1px solid var(--bdr);margin-top:14px}
.btn-logout{background:transparent;border:none;color:var(--ink3);font-size:11px;cursor:pointer;font-family:inherit}

/* ── AVATAR PICKER (modal) ── */
.avatar-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;max-height:200px;overflow-y:auto;padding:4px;margin-bottom:12px}
.av-pick{padding:8px;border-radius:10px;border:1.5px solid var(--bdr);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all 0.15s;background:var(--bg);min-height:50px}
.av-pick:hover{transform:scale(1.08)}
.av-pick.selected{border:2.5px solid var(--v2);transform:scale(1.05)}

/* ── BACK BUTTON child header ── */
.back-btn{background:rgba(255,255,255,0.18);border:1px solid rgba(255,255,255,0.25);color:white;border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;cursor:pointer;flex-shrink:0;z-index:1}
.back-btn:hover{background:rgba(255,255,255,0.28)}

/* ── PIN MODAL ── */
.pin-input{width:100%;padding:14px;font-size:24px;font-weight:800;text-align:center;letter-spacing:14px;border:2px solid var(--bdr);border-radius:12px;background:var(--bg);color:var(--v2);outline:none;font-family:'Plus Jakarta Sans',sans-serif}
.pin-input:focus{border-color:var(--v2)}

/* ── CHILD CARD with avatar in selector context ── */
.child-card-v6{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--card);border-radius:var(--rs);border:1.5px solid var(--bdr);margin-bottom:8px;transition:all 0.15s}
.child-card-v6 .av-emoji{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}
