/* ============================================================
   Spy Agency UI — dark HUD + dossier + terminal
   Author: you
   File: spy-agency.css (vUnified)
   ============================================================ */

/* -------------------- Design tokens -------------------- */
:root {
  /* Palette principale */
  --bg-0:#0b0f14;        /* fond global */
  --bg-1:#0e141b;        /* niveau 1 */
  --bg-2:#141b23;        /* cartes/panneaux */
  --ink:#e6edf3;         /* texte principal */
  --muted:#9aa6b2;       /* texte secondaire */
  --border:#27313b;      /* bordures HUD */

  /* Effets HUD */
  --fx-grid:rgba(255,255,255,.035);
  --accent:#1e9a7c;      /* vert-teal */
  --accent-2:#2f80ff;    /* bleu azure */
  --warn:#f0b354;        /* jaune dossier */
  --danger:#ff5353;      /* rouge alerte */

  /* UI */
  --radius:14px;
  --shadow:0 10px 32px rgba(0,0,0,.45);
  --ring:0 0 0 3px rgba(47,128,255,.25);

  /* Rythme & typo */
  --s-1:4px; --s-2:8px; --s-3:12px; --s-4:16px; --s-5:24px; --s-6:32px;
  --w-max:1200px;
  --font-ui:"Rajdhani", ui-sans-serif, system-ui, "Segoe UI", Roboto, Arial, sans-serif;
  --font-mono:ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;

  /* Glows */
  --glow-az:0 0 12px rgba(47,128,255,.35);
  --glow-gr:0 0 12px rgba(30,154,124,.35);
}

/* -------------------- Reset & structure -------------------- */
*,*::before,*::after{box-sizing:border-box}
html,body{height:100%}
body {
  margin:0; color:var(--ink); background:var(--bg-0);
  font:400 16px/1.5 var(--font-ui);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

/* Blueprint + scanlines */
body::before {
  content:""; position:fixed; inset:0; z-index:-1; pointer-events:none;
  background:
    radial-gradient(1400px 900px at 20% -10%, #0a0e13 0%, var(--bg-0) 60%) fixed,
    repeating-linear-gradient(0deg, rgba(255,255,255,.018) 0 1px, transparent 1px 3px),
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.04) 1px, transparent 1px) 0 0/24px 24px,
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.03) 1px, transparent 1px) 0 0/6px 6px;
  opacity:.9;
}

/* -------------------- Typo & liens -------------------- */
h1,h2,h3{line-height:1.18;margin:0 0 var(--s-4)}
p{margin:0 0 var(--s-4)}
.muted{color:var(--muted)}
.small{font-size:.875rem}
a{color:var(--ink);text-decoration:none}
a:hover{color:var(--accent-2);text-shadow:var(--glow-az)}

/* -------------------- Layout -------------------- */
.container{width:min(var(--w-max),100% - 32px);margin-inline:auto}
.stack>*+*{margin-top:var(--s-4)}
.center{display:grid;place-items:center}
.grid{display:grid;gap:var(--s-4)}
@media (max-width:1024px){.grid{grid-template-columns:1fr}}
.hr{height:1px;background:var(--border);border:0;margin:var(--s-5) 0}

/* -------------------- Header HUD -------------------- */
.header{
  position:sticky;top:0;z-index:100;
  backdrop-filter:saturate(130%) blur(6px);
  background:rgba(11,15,20,.9);
  border-bottom:1px solid #1b2a35;
  box-shadow:0 1px 0 rgba(47,128,255,.12) inset,0 6px 18px rgba(0,0,0,.35);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;gap:16px;
  padding:10px 16px;
}
.brand{
  display:flex;align-items:center;gap:10px;font-weight:900;letter-spacing:.6px;
  text-shadow:var(--glow-az);
}
.brand img{
  width:34px;height:34px;border-radius:50%;
  box-shadow:0 0 0 1px rgba(47,128,255,.18) inset;border:1px solid var(--border);
}
.nav{display:flex;gap:8px;flex-wrap:wrap}

/* -------------------- Panneau Agent -------------------- */
.user-panel{display:flex;align-items:center;gap:12px}
.user-avatar{
  width:44px;height:44px;border-radius:50%;display:grid;place-items:center;
  font-weight:800;text-transform:uppercase;color:#0b0f14;
  background:linear-gradient(135deg,var(--accent-2),var(--accent));
  border:1px solid var(--border);
}
.user-meta .user-stats{display:flex;gap:12px;flex-wrap:wrap}
.user-panel .tl-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:10px;font-weight:700;
  background:rgba(47,128,255,.10);color:#cfe3ff;border:1px solid rgba(47,128,255,.25);
}
.tl-badge{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 10px;border-radius:10px;font-weight:700;
  background:rgba(47, 127, 255, 0.038);color:#cfe3ff7a;border:1px solid rgba(47, 127, 255, 0.082);
  font-size:12px;
  margin-bottom:10px;
}

/* -------------------- Cartes / panneaux -------------------- */
.card{
  border-radius:var(--radius);
  padding:var(--s-5);
  position:relative;
}
.info {
  background-color:#1e9a7c8a;
  border-radius:var(--radius);
  padding:var(--s-5);
  position:relative;
}
.card::before{
  content:"";position:absolute;left:0;right:0;top:0;height:3px;
  background:linear-gradient(90deg,rgba(47,128,255,.35),rgba(30,154,124,.35));
  opacity:.8;
}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--s-4)}
.card-header h2{letter-spacing:.3px;text-shadow:var(--glow-az)}
.badge{
  display:inline-block;padding:3px 8px;border:1px solid rgba(47,128,255,.25);
  border-radius:999px;font-size:.8rem;background:rgba(255,255,255,.06);
  color:#cfe3ff;
}

/* -------------------- Boutons -------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;border-radius:10px;cursor:pointer;
  background:var(--bg-2);color:var(--ink);border:1px solid var(--border);
  transition:transform .06s,box-shadow .18s,background .18s,color .18s;
}
.btn:hover{background:var(--accent);color:#0b0f14;box-shadow:var(--glow-gr)}
.btn.danger{background:var(--danger);border-color:transparent;color:#111}
.btn.icon{padding:8px 10px}

/* -------------------- Grille d’apps (icônes seules façon iPhone) -------------------- */
.apps-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(96px,1fr));
  gap:24px;
  justify-items:center;
  padding:16px 0;
}

.app-tile{
  position:relative;
  display:grid;
  place-items:center;
  padding:0;
  margin:0;
  background:transparent;
  border:none;
  box-shadow:none;
  cursor:pointer;
  transition:transform .18s ease, filter .18s ease;
}

/* suppression totale de la déco “carte” */
.app-tile::before,
.app-tile::after{
  content:none;
}

/* zoom au survol */
.app-tile:hover{
  transform:scale(1.12);
}

/* ancienne zone d’icon-wrap inutilisée, on la laisse neutre si jamais réutilisée */
.app-icon-wrap{
  display:grid;
  place-items:center;
  min-height:0;
  border-radius:0;
  background:transparent;
  border:none;
}

/* icônes (PNG) */
.app-icon-img,
.app-icon-desktop{
  width:96px;
  height:96px;
  object-fit:contain;
  filter:drop-shadow(0 0 8px rgba(0,0,0,.55));
}

@media (min-width:900px){
  .app-icon-img,
  .app-icon-desktop{
    width:112px;
    height:112px;
  }
}

/* on neutralise l’ancien texte de tuile (non utilisé sur le home) */
.app-title{
  display:none;
}

/* États app (sans bordures ni outlines) */
.app-tile[data-state="todo"]{
  filter:none;
}

.app-tile[data-state="done"],
.app-tile.is-finished{
  filter:grayscale(.7) opacity(.75);
}

.app-tile.disabled{
  pointer-events:none;
}

/* Overlay cadenas sans “box” rectangulaire */
.lock-overlay{
  position:absolute;
  inset:0;
  display:grid;
  place-items:center;
  pointer-events:none;
  background:radial-gradient(circle at 50% 50%, rgba(0,0,0,.78), transparent 60%);
  border-radius:50%;
  z-index:5;
}

.lock-overlay i{
  font-size:40px;
  color:#e6edf3;
  opacity:.95;
  text-shadow:0 0 18px rgba(0,0,0,.85);
}

/* rubans toujours dispo si utilisés ailleurs (pas sur le home) */
.ribbon{
  position:absolute;top:6px;left:6px;padding:3px 8px;border-radius:8px;
  font-weight:900;box-shadow:var(--shadow);z-index:10;
}
.ribbon.todo{background:linear-gradient(90deg,#66b1ff,#2f80ff);color:#06111a}
.ribbon.done{background:linear-gradient(90deg,#7be3cb,#2ccaa2);color:#031713}
.ribbon.locked{background:linear-gradient(90deg,#7a7a7a,#a1a1a1);color:#0b0f14}

/* -------------------- Bonus / lock note -------------------- */
.app-bonus-section.is-locked{opacity:.95}
.lock-note{
  display:flex;align-items:center;gap:10px;margin-bottom:12px;
  padding:10px 12px;border:1px dashed rgba(47,128,255,.35);border-radius:10px;
  background:linear-gradient(90deg,rgba(47,128,255,.08),rgba(30,154,124,.08));
  color:#bdd4ff;
}

/* -------------------- Fenêtres bureau (modal iframe) -------------------- */
.desk-window{
  border:1px solid #234055;
  box-shadow:0 24px 80px rgba(0,0,0,.55),0 0 0 1px rgba(47,128,255,.15) inset;
  border-radius:var(--radius);
  overflow:hidden;
}
.desk-titlebar{
  display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:8px 10px;border-bottom:1px solid #234055;
  background:linear-gradient(90deg,rgba(47,128,255,.22),rgba(30,154,124,.22));
  text-shadow:var(--glow-az);
}
.desk-titlebar .btn.ghost{
  border:1px solid rgba(255,255,255,.12);border-radius:8px;
}
.desk-titlebar .btn.ghost:hover{
  background:rgba(47,128,255,.16);box-shadow:0 0 0 2px rgba(47,128,255,.18) inset;
}

/* -------------------- Filigrane logo -------------------- */
.filigrane{
  position:fixed;inset:0;display:grid;place-items:center;
  z-index:-1;pointer-events:none;opacity:.065;filter:grayscale(1) contrast(.9);
}
.filigrane img{width:min(38vw,520px);max-width:90%}

/* -------------------- Responsive tweaks -------------------- */
@media (max-width:800px){
  .header-inner{gap:10px}
  .user-panel .user-stats{gap:8px}
  .apps-grid{gap:18px}
}
@media (max-width:520px){
  /* app-title déjà masqué */
}

/* ===== Header: opacité dynamique au scroll + retour clair au survol */
.header[data-scroll-opac]{
  transition: background .18s ease, opacity .18s ease, box-shadow .18s ease;
}
.header.is-scrolled{
  background: rgba(13,17,23,.72);
  box-shadow: 0 6px 24px rgba(0,0,0,.35);
}
.header.is-scrolled:hover{
  background: rgba(13,17,23,.88);
}

/* ===== Panneau agent repliable */
.user-panel .user-meta{ gap:8px }
.user-panel .user-details{
  margin-top:6px;
  padding:8px 10px;
  border:1px dashed var(--border);
  border-radius:10px;
  background: rgba(255,255,255,.04);
}
.user-panel .user-details[hidden]{ display:none }

/* ===== Micro feedback sur boutons du header */
.header .nav .btn.icon{
  border-radius:10px;
}
.header .nav .btn.icon:hover{
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,0,0,.28), 0 0 0 3px rgba(47,129,247,.18) inset;
}
.header .nav .btn.icon:active{ transform: translateY(0) scale(.98) }

.cafe{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:10px 14px;border-radius:10px;cursor:pointer;
  background:#bf7a0cb9;color:#ffffffe1;border:1px solid var(--border);
  transition:transform .06s,box-shadow .18s,background .18s,color .18s;
}
.cafe:hover{
  transform: translateY(-1px);
  background:#f9a012c2;
  box-shadow:0 6px 20px rgba(0,0,0,.28), 0 0 0 3px rgba(247,197,47,.18) inset;
}
.cafe:active{ transform: translateY(0) scale(.98) }

/* Icône caret animé pour l’agent */
.fa-caret-down{ transition: transform .15s ease }
.fa-rotate-180{ transform: rotate(180deg) }

/* ===== Desk modal: centrée + backdrop flouté + iframe plein-plein ===== */
.desk-modal{ position:fixed !important; inset:0 !important; display:grid !important; place-items:center !important; z-index:1000 !important; }
.desk-modal[hidden]{ display:none !important; }

.desk-backdrop{
  position:absolute; inset:0;
  background:rgba(0,0,0,.6);
  backdrop-filter:blur(3px);
}

.desk-window{
  position:relative; z-index:1;
  width:min(1100px, 100% - 32px);
  height:min(90vh, 900px);
  max-width:1200px; max-height:90vh;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:14px;
  box-shadow:0 24px 80px rgba(0,0,0,.55), 0 0 0 1px rgba(255,255,255,.04) inset;
  overflow:hidden;
  display:flex;
  flex-direction:column;
}

.desk-titlebar{
  flex:0 0 44px;
  display:flex; align-items:center; justify-content:space-between; gap:8px;
  padding:8px 10px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(90deg, rgba(47,129,247,.10), rgba(35,134,54,.10));
}
.desk-title{ font-weight:800; letter-spacing:.2px }
.desk-title i{ opacity:.9; }

.desk-frame{
  flex:1 1 auto;
  width:100%;
  height:100%;
  border:0;
  background:var(--bg-elev);
}

body.modal-open{ overflow:hidden; }

/* === Raretés === */
.rarity-common {
  box-shadow:0 0 12px rgba(115,133,155,.45);
}
.rarity-rare {
  box-shadow:0 0 18px rgba(61,104,255,.6);
}
.rarity-epic {
  box-shadow:0 0 22px rgba(176,67,255,.7);
}
.rarity-legendar {
  box-shadow:0 0 28px rgba(255,179,0,.8);
}

/* Particules brillantes */
.sparkle {
  position:absolute;
  width:4px;
  height:4px;
  background:white;
  border-radius:50%;
  opacity:.6;
  animation: sparkleMove 1.8s infinite;
}
@keyframes sparkleMove {
  0% { transform:translateY(0) scale(.8); opacity:.6; }
  50%{ transform:translateY(-16px) scale(1.3); opacity:1; }
  100%{ transform:translateY(0) scale(.8); opacity:.2; }
}
