/* =============================================================
   cyb.aijoo — cyb.css v1
   Tokens du brandkit + structure Holo + tiroirs + copilote
   ============================================================= */

:root{
  --cyb-orange:#EF6C4D; --cyb-bleu:#4D8CEF; --cyb-anthracite:#5C616D;
  --cyb-jaune:#F0C84D;  --cyb-vert:#36C26E;
  --cyb-nuit:#15171C;   --cyb-creme:#FBF7F2;
  --cyb-rayon:16px;
  --cyb-titres:'Gabarito',sans-serif;
  --cyb-code:'JetBrains Mono',monospace;
  --cyb-signature:'Nothing You Could Do',cursive;
  --verre:rgba(255,255,255,.55);
  --verre-bord:rgba(255,255,255,.8);
  --ombre:0 14px 40px rgba(21,23,28,.22);
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:var(--cyb-titres);height:100vh;overflow:hidden;color:var(--cyb-nuit);
  background:linear-gradient(125deg,var(--cyb-orange) 0%,#F2987F 30%,#BFD4F7 62%,var(--cyb-bleu) 100%);
  background-size:200% 200%;animation:derive 18s ease-in-out infinite alternate}
@keyframes derive{from{background-position:0% 0%}to{background-position:100% 100%}}
@media (prefers-reduced-motion: reduce){*{animation:none !important;transition:none !important}}
button{font-family:var(--cyb-titres)}
:focus-visible{outline:3px solid var(--cyb-nuit);outline-offset:2px}

/* étoile pixel (forme de marque) */
.etoile-fond{position:fixed;width:12px;height:12px;opacity:.5;pointer-events:none;background:#fff;
  clip-path:polygon(33% 0,66% 0,66% 33%,100% 33%,100% 66%,66% 66%,66% 100%,33% 100%,33% 66%,0 66%,0 33%,33% 33%)}
.etoile-px{display:inline-grid;grid-template-columns:repeat(3,4px);grid-template-rows:repeat(3,4px)}
.etoile-px i{background:transparent}
.etoile-px i:nth-child(2),.etoile-px i:nth-child(4),.etoile-px i:nth-child(5),
.etoile-px i:nth-child(6),.etoile-px i:nth-child(8){background:var(--cyb-jaune)}
.gemme{width:11px;height:11px;flex-shrink:0;
  clip-path:polygon(33% 0,66% 0,66% 33%,100% 33%,100% 66%,66% 66%,66% 100%,33% 100%,33% 66%,0 66%,0 33%,33% 33%)}
.gemme.verte{background:var(--cyb-vert)}

/* ===== barre ===== */
.barre{position:fixed;top:12px;left:16px;right:16px;height:48px;display:flex;align-items:center;gap:12px;
  background:var(--verre);backdrop-filter:blur(14px);border:1px solid var(--verre-bord);
  border-radius:14px;padding:0 10px;z-index:40}
.logo-cyb{width:30px;height:30px}
.mark{font-weight:900;font-size:19px;letter-spacing:-.5px;display:flex;align-items:center;gap:4px}
.mark .c{color:var(--cyb-orange)}
.mark .a{color:var(--cyb-bleu)}
.direct{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:800;color:var(--cyb-anthracite);letter-spacing:1px}
.direct i{width:9px;height:9px;border-radius:50%;background:var(--cyb-vert);animation:pulse 1.6s infinite}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(54,194,110,.55)}50%{box-shadow:0 0 0 6px rgba(54,194,110,0)}}
.titre-projet{flex:0 1 220px;min-width:90px;font-family:var(--cyb-titres);font-weight:700;font-size:14px;
  border:none;border-radius:10px;background:rgba(255,255,255,.5);padding:8px 12px;color:var(--cyb-nuit)}
.titre-projet:focus{background:#fff;outline:none}
.barre .droite{margin-left:auto;display:flex;align-items:center;gap:7px}
.score{display:flex;align-items:center;gap:6px;font-weight:800;font-size:14px;color:var(--cyb-anthracite);
  background:rgba(255,255,255,.6);border-radius:10px;padding:7px 12px}
.puce{font-weight:800;font-size:13px;border:none;border-radius:10px;padding:9px 13px;cursor:pointer;
  background:rgba(255,255,255,.65);color:var(--cyb-anthracite);transition:background .15s}
.puce:hover{background:#fff}
.puce.ia{background:var(--cyb-bleu);color:#fff}
.puce.ia:hover{background:#3a78dd}

/* ===== scène ===== */
.scene{position:fixed;inset:68px 16px 16px;border-radius:20px;overflow:hidden;background:#fff;
  box-shadow:0 24px 60px rgba(21,23,28,.28);z-index:1}
.scene iframe{width:100%;height:100%;border:none;display:block}

/* ===== panneaux holo ===== */
.holo{position:fixed;width:340px;max-width:42vw;display:flex;flex-direction:column;border-radius:var(--cyb-rayon);overflow:hidden;z-index:20;
  background:var(--verre);backdrop-filter:blur(18px) saturate(1.4);
  border:1px solid var(--verre-bord);box-shadow:var(--ombre)}
.holo-tete,.journal-tete{display:flex;align-items:center;gap:9px;padding:9px 14px;cursor:pointer;user-select:none;
  font-weight:900;font-size:12.5px;letter-spacing:1.5px}
.pli{margin-left:auto;font-size:15px;color:var(--cyb-anthracite);transition:transform .25s}
.plie .pli{transform:rotate(-90deg)}
.holo textarea{height:200px;resize:none;border:none;outline:none;background:rgba(255,255,255,.6);
  font-family:var(--cyb-code);font-size:12.5px;line-height:1.6;padding:12px 14px;color:var(--cyb-nuit);tab-size:2;
  transition:height .25s,padding .25s}
.holo.plie textarea{height:0;padding:0 14px}
.h-html{top:76px;left:24px}.h-html .gemme{background:var(--cyb-orange)}
.h-css{top:76px;right:24px}.h-css .gemme{background:var(--cyb-bleu)}
.h-js{bottom:24px;left:24px}.h-js .gemme{background:var(--cyb-jaune)}

/* ===== journal ===== */
.journal{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);width:380px;max-width:46vw;z-index:20;
  display:flex;flex-direction:column;border-radius:var(--cyb-rayon);overflow:hidden;
  background:var(--verre);backdrop-filter:blur(18px);border:1px solid var(--verre-bord);box-shadow:var(--ombre)}
.journal-corps{height:110px;overflow:auto;font-family:var(--cyb-code);font-size:12px;line-height:1.7;
  padding:8px 14px;background:rgba(255,255,255,.6);transition:height .25s,padding .25s}
.journal.plie .journal-corps{height:0;padding:0 14px}
.journal-corps .ok::before{content:'» ';color:var(--cyb-bleu)}
.journal-corps .err{color:#C0392B}
.journal-corps .err::before{content:'✖ '}
.mini{font-weight:800;font-size:11px;border:none;border-radius:8px;padding:5px 10px;cursor:pointer;
  background:var(--cyb-orange);color:#fff;margin-left:8px}

/* ===== tiroirs ===== */
.tiroir,.copilote-panneau{position:fixed;top:12px;bottom:12px;width:360px;max-width:92vw;z-index:50;
  display:flex;flex-direction:column;border-radius:18px;overflow:hidden;
  background:rgba(255,255,255,.78);backdrop-filter:blur(22px) saturate(1.4);
  border:1px solid var(--verre-bord);box-shadow:var(--ombre);
  transition:transform .3s cubic-bezier(.2,.8,.2,1)}
.tiroir{left:16px;transform:translateX(calc(-100% - 32px))}
.tiroir.ouvert{transform:translateX(0)}
.copilote-panneau{right:16px;transform:translateX(calc(100% + 32px))}
.copilote-panneau.ouvert{transform:translateX(0)}
.tiroir-tete{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(92,97,109,.15)}
.tiroir-tete h2{font-size:16px;font-weight:900;flex:1}
.fermer{border:none;background:rgba(92,97,109,.12);color:var(--cyb-anthracite);width:30px;height:30px;
  border-radius:50%;cursor:pointer;font-size:14px}
.fermer:hover{background:rgba(92,97,109,.25)}
.tiroir-sous{font-family:var(--cyb-signature);font-size:15px;color:var(--cyb-anthracite);padding:8px 16px 0}
.recherche{margin:10px 16px;border:1px solid rgba(92,97,109,.25);border-radius:10px;padding:9px 12px;
  font-family:var(--cyb-titres);font-size:14px;background:#fff;outline:none}
.recherche:focus{border-color:var(--cyb-bleu)}
.filtres{display:flex;flex-wrap:wrap;gap:6px;padding:0 16px 10px}
.filtre{font-weight:800;font-size:11.5px;border:1.5px solid rgba(92,97,109,.3);border-radius:999px;
  padding:5px 11px;cursor:pointer;background:#fff;color:var(--cyb-anthracite)}
.filtre.actif{background:var(--cyb-bleu);color:#fff;border-color:var(--cyb-bleu)}

/* briques & projets */
.briques{flex:1;min-height:0;overflow:auto;padding:4px 16px 16px;display:flex;flex-direction:column;gap:10px}
.brique{border:none;text-align:left;border-radius:12px;padding:12px 14px;background:#fff;cursor:pointer;
  box-shadow:0 3px 10px rgba(21,23,28,.08);transition:transform .12s,box-shadow .12s}
.brique:hover{transform:translateY(-2px);box-shadow:0 8px 18px rgba(77,140,239,.25)}
.brique b{display:block;font-size:14px;margin-bottom:2px}
.brique span{font-size:12.5px;color:var(--cyb-anthracite);display:block}
.brique .tag{display:inline-block;font-size:9.5px;font-weight:800;letter-spacing:1px;color:#fff;
  border-radius:5px;padding:2px 7px;margin-top:7px;margin-right:5px;background:var(--cyb-anthracite)}
.brique .tag.bib{background:var(--cyb-orange)}
.brique .tag.niv{background:var(--cyb-vert)}
.vide{font-size:13.5px;color:var(--cyb-anthracite);padding:10px 2px}

/* modèles */
.modeles{display:flex;flex-direction:column;gap:10px;padding:16px}
.modele{border:none;text-align:left;border-radius:14px;padding:16px;background:#fff;cursor:pointer;
  box-shadow:0 3px 10px rgba(21,23,28,.08)}
.modele:hover{box-shadow:0 8px 18px rgba(239,108,77,.3)}
.modele b{display:block;font-size:15px}
.modele span{font-size:12.5px;color:var(--cyb-anthracite)}

/* ===== copilote ===== */
.fil{flex:1;min-height:0;overflow:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.msg{max-width:92%;padding:10px 13px;border-radius:13px;font-size:14px;line-height:1.5;white-space:pre-wrap}
.msg.ia{background:#fff;border-bottom-left-radius:4px;box-shadow:0 2px 8px rgba(21,23,28,.08)}
.msg.moi{background:var(--cyb-bleu);color:#fff;align-self:flex-end;border-bottom-right-radius:4px}
.msg.attente{color:var(--cyb-anthracite);font-family:var(--cyb-signature);font-size:16px;background:transparent;box-shadow:none}
.msg .appliquer{display:block;margin-top:9px;border:none;border-radius:9px;padding:8px 13px;cursor:pointer;
  font-family:var(--cyb-titres);font-weight:800;font-size:12.5px;background:var(--cyb-vert);color:#fff}
.msg .appliquer:hover{filter:brightness(1.08)}
.saisie{display:flex;gap:8px;padding:12px;border-top:1px solid rgba(92,97,109,.15)}
.saisie input{flex:1;border:1px solid rgba(92,97,109,.25);border-radius:11px;padding:10px 13px;
  font-family:var(--cyb-titres);font-size:14px;outline:none;background:#fff}
.saisie input:focus{border-color:var(--cyb-bleu)}
.saisie button{width:44px;border:none;border-radius:11px;background:var(--cyb-orange);color:#fff;
  font-size:17px;cursor:pointer}

/* bulle d'appel */
.bulle-copilote{position:fixed;bottom:24px;right:24px;z-index:30;display:flex;align-items:center;gap:11px;
  border:none;cursor:pointer;background:var(--verre);backdrop-filter:blur(14px);
  border:1px solid var(--verre-bord);border-radius:999px;padding:8px 8px 8px 18px;box-shadow:var(--ombre)}
.bulle-copilote .mot{font-family:var(--cyb-signature);font-size:17px;color:var(--cyb-anthracite)}
.bulle-copilote img{width:44px;height:44px;padding:8px;border-radius:50%;background:var(--cyb-orange);
  box-shadow:0 6px 16px rgba(239,108,77,.45);transition:transform .15s}
.bulle-copilote:hover img{transform:scale(1.08)}

/* voile sous les tiroirs */
.voile{position:fixed;inset:0;background:rgba(21,23,28,.25);opacity:0;pointer-events:none;transition:opacity .25s;z-index:45}
.voile.actif{opacity:1;pointer-events:auto}

/* ===== mobile ===== */
@media (max-width:760px){
  .holo{max-width:84vw}
  .h-css{top:auto;bottom:96px}
  .journal{max-width:84vw;bottom:auto;top:76px}
  .score,.direct,.titre-projet{display:none}
  .puce{padding:9px 10px;font-size:12px}
  .bulle-copilote .mot{display:none}
}

/* =============================================================
   Thèmes de fond — au choix de l'enfant, mémorisé
   ============================================================= */
.theme-zone{position:relative}
.popover-themes{position:absolute;top:46px;left:50%;transform:translateX(-50%) scale(.9);display:flex;gap:8px;
  padding:10px;border-radius:14px;background:rgba(255,255,255,.85);backdrop-filter:blur(16px);
  border:1px solid var(--verre-bord);box-shadow:var(--ombre);
  opacity:0;pointer-events:none;transition:opacity .2s,transform .2s;z-index:60}
.popover-themes.ouvert{opacity:1;pointer-events:auto;transform:translateX(-50%) scale(1)}
.pastille-theme{width:34px;height:34px;border-radius:50%;border:2px solid #fff;cursor:pointer;
  box-shadow:0 3px 8px rgba(21,23,28,.25);transition:transform .12s}
.pastille-theme:hover{transform:scale(1.15)}
.pastille-theme.actif{outline:3px solid var(--cyb-nuit);outline-offset:2px}

/* ---- fonds ---- */
body[data-theme="nuit"]{background:linear-gradient(140deg,#15171C 0%,#1B2230 55%,#22304A 100%)}
body[data-theme="creme"]{background:#FBF7F2;animation:none}
body[data-theme="ocean"]{background:linear-gradient(140deg,#7FB0F5 0%,#4D8CEF 45%,#1D3A6E 100%);background-size:200% 200%}
body[data-theme="soleil"]{background:linear-gradient(140deg,#F6DD8C 0%,#F0C84D 40%,#EF6C4D 100%);background-size:200% 200%}
body[data-theme="menthe"]{background:linear-gradient(140deg,#8FE6B5 0%,#36C26E 50%,#1E7A52 100%);background-size:200% 200%}

/* ---- ajustements lisibilité ---- */
body[data-theme="creme"] .etoile-fond{background:var(--cyb-jaune);opacity:.8}
body[data-theme="creme"] .barre,body[data-theme="creme"] .holo,body[data-theme="creme"] .journal,
body[data-theme="creme"] .bulle-copilote{border-color:rgba(92,97,109,.18);box-shadow:0 10px 30px rgba(92,97,109,.14)}

body[data-theme="nuit"]{
  --verre:rgba(26,29,36,.62);--verre-bord:rgba(255,255,255,.14);
  --ombre:0 14px 40px rgba(0,0,0,.5)}
body[data-theme="nuit"] .holo-tete,body[data-theme="nuit"] .journal-tete,
body[data-theme="nuit"] .mark .a,body[data-theme="nuit"] .direct,
body[data-theme="nuit"] .bulle-copilote .mot{color:#E8E9EC}
body[data-theme="nuit"] .holo textarea,body[data-theme="nuit"] .journal-corps{
  background:rgba(13,15,19,.55);color:#E8E9EC}
body[data-theme="nuit"] .titre-projet{background:rgba(255,255,255,.12);color:#E8E9EC}
body[data-theme="nuit"] .puce{background:rgba(255,255,255,.14);color:#D7DAE0}
body[data-theme="nuit"] .puce:hover{background:rgba(255,255,255,.26)}
body[data-theme="nuit"] .puce.ia{background:var(--cyb-bleu);color:#fff}
body[data-theme="nuit"] .score{background:rgba(255,255,255,.12);color:#D7DAE0}
body[data-theme="nuit"] .pli{color:#9aa0ad}

/* =============================================================
   Connexion — le même compte qu'aijoo.me
   ============================================================= */
.connexion{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;
  background:rgba(21,23,28,.35);backdrop-filter:blur(10px)}
.connexion-carte{display:flex;flex-direction:column;align-items:center;gap:13px;width:340px;max-width:90vw;
  background:rgba(255,255,255,.88);backdrop-filter:blur(22px);border:1px solid var(--verre-bord);
  border-radius:22px;padding:34px 30px 24px;box-shadow:var(--ombre)}
.connexion-logo{width:64px;height:64px}
.mark.grand{font-size:27px}
.connexion-sous{font-size:14.5px;color:var(--cyb-anthracite);margin-bottom:4px}
.connexion-carte input{width:100%;border:1px solid rgba(92,97,109,.3);border-radius:12px;padding:12px 14px;
  font-family:var(--cyb-titres);font-size:15px;outline:none;background:#fff}
.connexion-carte input:focus{border-color:var(--cyb-bleu)}
.connexion-erreur{font-size:13px;font-weight:700;color:#C0392B;text-align:center}
.connexion-bouton{width:100%;border:none;border-radius:12px;padding:13px;cursor:pointer;
  font-family:var(--cyb-titres);font-weight:900;font-size:15px;background:var(--cyb-orange);color:#fff;
  box-shadow:0 8px 20px rgba(239,108,77,.4);transition:transform .12s}
.connexion-bouton:hover{transform:translateY(-2px)}
.connexion-bouton:disabled{opacity:.6;transform:none;cursor:wait}
.connexion-signature{font-family:var(--cyb-signature);font-size:15px;color:var(--cyb-anthracite);margin-top:4px}
.puce.membre{background:rgba(255,255,255,.85)}
body[data-theme="nuit"] .puce.membre{background:rgba(255,255,255,.2);color:#E8E9EC}

/* correctif : l'attribut hidden doit toujours gagner sur display:flex */
.connexion[hidden]{display:none}
