:root{
  --bg:#07060f; --panel:#13111f; --panel2:#1c1830; --txt:#eceaf5;
  --muted:#9890b5; --line:#2a2540;
  --neon1:#8b5cf6; --neon2:#3b82f6; --neon-pink:#c026d3;
  --grad:linear-gradient(120deg,#8b5cf6,#3b82f6);
  --grad-pink:linear-gradient(120deg,#c026d3,#8b5cf6,#3b82f6);
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--txt);overflow-x:hidden}
body::before{content:"";position:fixed;inset:0;z-index:-1;
  background:radial-gradient(1100px 600px at 12% -8%,rgba(139,92,246,.20),transparent 60%),
             radial-gradient(900px 600px at 100% 0%,rgba(59,130,246,.18),transparent 55%),
             radial-gradient(800px 500px at 50% 120%,rgba(192,38,211,.12),transparent 60%)}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@keyframes pulseGlow{0%,100%{box-shadow:0 0 22px rgba(139,92,246,.5)}50%{box-shadow:0 0 38px rgba(59,130,246,.75)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ---------- Écran de connexion ---------- */
.login-screen{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px}
.login-bg{position:absolute;inset:0;background:
  radial-gradient(900px 600px at 50% 20%,rgba(139,92,246,.25),transparent 60%),#07060f;
  animation:bgshift 14s ease-in-out infinite alternate}
@keyframes bgshift{from{filter:hue-rotate(0)}to{filter:hue-rotate(40deg)}}
.login-box{position:relative;width:100%;max-width:380px;background:rgba(19,17,31,.75);
  backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:22px;padding:38px 32px;
  text-align:center;animation:fadeUp .6s ease both;box-shadow:0 20px 60px rgba(0,0,0,.6)}
.login-logo{max-width:220px;margin-bottom:6px;animation:float 5s ease-in-out infinite}
.login-fallback{font-size:38px;font-weight:900;margin:0;letter-spacing:-1px}
.login-fallback span{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.login-sub{color:var(--muted);margin:6px 0 26px;font-size:14px}
#login-form{display:flex;flex-direction:column;gap:14px}
#login-form input{padding:14px 16px;border-radius:12px;border:1px solid var(--line);
  background:rgba(28,24,48,.7);color:var(--txt);font-size:15px;outline:none;transition:.2s}
#login-form input:focus{border-color:var(--neon1);box-shadow:0 0 0 3px rgba(139,92,246,.25)}
.lg-error{margin-top:16px;color:#ff6b6b;font-size:14px;animation:fadeUp .3s both}

/* ---------- Boutons ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--grad);color:#fff;border:none;
  padding:13px 24px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;
  transition:transform .15s,box-shadow .2s;background-size:160% 160%}
.btn:hover{transform:translateY(-2px);background-position:100% 0}
.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}
.btn.glow{animation:pulseGlow 3s ease-in-out infinite}
.btn.glow:hover{animation:none;box-shadow:0 0 34px rgba(139,92,246,.8)}
.btn.ghost{background:transparent;border:1px solid var(--line);color:var(--txt);animation:none}
.btn.ghost:hover{border-color:var(--neon2);box-shadow:0 0 18px rgba(59,130,246,.4)}

/* ---------- Header ---------- */
header{display:flex;align-items:center;gap:18px;padding:12px 24px;
  background:rgba(7,6,15,.7);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);position:sticky;top:0;z-index:30}
.brand{cursor:pointer;display:flex;align-items:center}
.brand-logo{height:42px}
.brand-text{font-size:22px;font-weight:900}
.brand-text b{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
#search{flex:1;max-width:600px;margin:0 auto;padding:12px 20px;border-radius:30px;
  border:1px solid var(--line);background:rgba(28,24,48,.6);color:var(--txt);font-size:15px;outline:none;transition:.2s}
#search:focus{border-color:var(--neon1);box-shadow:0 0 0 3px rgba(139,92,246,.22)}
.user-chip{display:flex;align-items:center;gap:14px;font-size:14px;color:var(--muted)}
.admin-link{color:var(--muted);text-decoration:none}.admin-link:hover{color:var(--txt)}
.logout{background:none;border:1px solid var(--line);color:var(--muted);width:34px;height:34px;
  border-radius:50%;cursor:pointer;transition:.2s;display:flex;align-items:center;justify-content:center}
.logout:hover{border-color:var(--neon-pink);color:#fff;box-shadow:0 0 16px rgba(192,38,211,.4)}

/* ---------- Onglets ---------- */
.tabs{display:flex;gap:6px;padding:14px 24px 0;position:sticky;top:67px;z-index:20;
  background:rgba(7,6,15,.7);backdrop-filter:blur(12px);border-bottom:1px solid var(--line)}
.tab{background:none;border:none;color:var(--muted);font-size:15px;font-weight:700;
  padding:10px 18px;cursor:pointer;position:relative;transition:color .2s}
.tab:hover{color:var(--txt)}
.tab.active{color:var(--txt)}
.tab.active::after{content:"";position:absolute;left:12px;right:12px;bottom:-1px;height:3px;
  border-radius:3px;background:var(--grad);box-shadow:0 0 12px rgba(139,92,246,.7)}

/* ---------- Contenu ---------- */
main{padding:24px}
h2{font-weight:700;margin:8px 4px 16px;font-size:20px}
h3{font-weight:700}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:18px}
.row-sec{margin-bottom:36px;animation:fadeUp .6s ease both}
.carousel{display:flex;gap:16px;overflow-x:auto;padding:4px 2px 14px;scroll-snap-type:x mandatory}
.carousel .card{flex:0 0 165px;scroll-snap-align:start}
.carousel::-webkit-scrollbar{height:8px}
.carousel::-webkit-scrollbar-thumb{background:var(--panel2);border-radius:4px}
.carousel::-webkit-scrollbar-thumb:hover{background:var(--neon1)}

.card{background:var(--panel);border-radius:14px;overflow:hidden;cursor:pointer;position:relative;
  border:1px solid transparent;transition:transform .2s,box-shadow .25s,border-color .25s}
.card:hover{transform:translateY(-6px) scale(1.02);border-color:rgba(139,92,246,.6);
  box-shadow:0 14px 40px rgba(139,92,246,.35)}
.card img{width:100%;aspect-ratio:2/3;object-fit:cover;display:block;background:var(--panel2)}
.card .noimg{width:100%;aspect-ratio:2/3;display:flex;align-items:center;justify-content:center;
  color:var(--muted);background:var(--panel2);font-size:13px;text-align:center;padding:10px}
.card .info{padding:10px 12px}
.card .t{font-size:14px;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.card .meta{display:flex;justify-content:space-between;margin-top:6px;font-size:12px;color:var(--muted)}
.badge{position:absolute;top:8px;left:8px;background:rgba(7,6,15,.8);backdrop-filter:blur(4px);
  padding:3px 9px;border-radius:7px;font-size:10px;text-transform:uppercase;letter-spacing:.5px;
  border:1px solid var(--line)}
.rating{font-weight:800}.rating.good{color:#34d399}.rating.mid{color:#fbbf24}.rating.bad{color:#f87171}
.empty{text-align:center;color:var(--muted);padding:60px}

/* ---------- Mes demandes ---------- */
.mine-list{display:flex;flex-direction:column;gap:12px;max-width:780px}
.mine-row{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);
  border-radius:14px;padding:10px 16px;animation:fadeUp .4s ease both;transition:border-color .2s}
.mine-row:hover{border-color:rgba(139,92,246,.5)}
.mine-row img{width:50px;border-radius:7px}
.mine-row .noimg.sm{width:50px;height:75px;font-size:10px;border-radius:7px}
.mine-info{flex:1}.mine-info .t{font-weight:700}
.note-line{margin-top:4px}
.muted{color:var(--muted);font-size:13px}

/* ---------- Modale ---------- */
.modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;padding:20px}
.modal-bg{position:absolute;inset:0;background:rgba(4,3,10,.75);backdrop-filter:blur(5px);animation:fadeUp .25s both}
.modal-card{position:relative;max-width:840px;width:100%;max-height:90vh;overflow:auto;
  background:var(--panel);border-radius:20px;border:1px solid var(--line);
  box-shadow:0 30px 80px rgba(0,0,0,.7);animation:fadeUp .35s cubic-bezier(.2,.8,.2,1) both}
.hero{position:relative;padding:30px;display:flex;gap:26px;background-size:cover;background-position:center top}
.hero::before{content:"";position:absolute;inset:0;background:linear-gradient(to right,rgba(11,10,22,.97),rgba(11,10,22,.78))}
.hero>*{position:relative}
.hero img{width:170px;border-radius:12px;flex-shrink:0;box-shadow:0 10px 30px rgba(0,0,0,.5)}
.hero .h-title{font-size:30px;font-weight:900;margin:0;line-height:1.1}
.hero .h-sub{color:var(--muted);margin:8px 0 12px}
.tagline{font-style:italic;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin:10px 0;font-weight:600}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin:14px 0}
.chip{background:var(--panel2);border:1px solid var(--line);padding:5px 13px;border-radius:20px;font-size:12px}
.body{padding:26px}
.body p{line-height:1.7;color:#d6d2e8}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.cast{display:grid;grid-template-columns:repeat(auto-fill,minmax(92px,1fr));gap:14px;margin-top:16px}
.cast .c{text-align:center;font-size:12px}
.cast img,.cast .ph{width:100%;aspect-ratio:1;border-radius:50%;object-fit:cover;background:var(--panel2);transition:.2s}
.cast .c:hover img{box-shadow:0 0 18px rgba(139,92,246,.5)}
.cast .nm{font-weight:600;margin-top:6px}.cast .ch{color:var(--muted)}
.close{position:absolute;top:14px;right:16px;z-index:5;background:rgba(7,6,15,.6);border:1px solid var(--line);
  color:#fff;width:36px;height:36px;border-radius:50%;font-size:18px;cursor:pointer;transition:.2s}
.close:hover{border-color:var(--neon-pink);box-shadow:0 0 16px rgba(192,38,211,.5)}

/* ---------- Toast ---------- */
.toast{position:fixed;bottom:26px;left:50%;transform:translateX(-50%);background:var(--grad);
  color:#fff;padding:14px 26px;border-radius:12px;z-index:300;font-weight:700;
  box-shadow:0 0 30px rgba(139,92,246,.6);animation:fadeUp .3s both}
.toast.err{background:linear-gradient(120deg,#ef4444,#b91c1c);box-shadow:0 0 30px rgba(239,68,68,.5)}

/* ---------- Admin ---------- */
table{width:100%;border-collapse:collapse;margin-top:16px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:14px}
th{color:var(--muted);font-weight:700}
tr{transition:background .15s}tbody tr:hover{background:rgba(139,92,246,.06)}
select.st{background:var(--panel2);color:var(--txt);border:1px solid var(--line);padding:7px;border-radius:8px}
.tag{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:700;white-space:nowrap}
.tag.attente{background:#3a2f00;color:#fbbf24}
.tag.cours{background:#0d1f33;color:#60a5fa}
.tag.traite{background:#06271a;color:#34d399}
.tag.refuse{background:#33161a;color:#f87171}
.login{max-width:360px;margin:80px auto;text-align:center}
.name{padding:12px 15px;border-radius:12px;border:1px solid var(--line);background:var(--panel2);color:var(--txt);font-size:14px;outline:none}
.name:focus{border-color:var(--neon1)}
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:16px 22px;
  min-width:110px;text-align:center;color:var(--muted);font-size:13px;transition:.2s;animation:fadeUp .4s both}
.stat:hover{transform:translateY(-3px);border-color:rgba(139,92,246,.5)}
.stat .n{font-size:28px;font-weight:900;color:var(--txt)}
.stat.attente .n{color:#fbbf24}.stat.cours .n{color:#60a5fa}
.stat.traite .n{color:#34d399}.stat.refuse .n{color:#f87171}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.toolbar .name{flex:1;min-width:200px}
.btn.xs{padding:7px 13px;font-size:13px}
input.note{width:150px;padding:8px 10px;border-radius:9px;border:1px solid var(--line);background:var(--panel2);color:var(--txt);font-size:13px;outline:none}
input.note:focus{border-color:var(--neon1)}
@media(max-width:600px){.hero{flex-direction:column}.hero img{width:130px}#search{max-width:none}}
