:root{
  --bg0:#071013;
  --bg1:#0b1b1f;
  --glass: rgba(10, 18, 22, .58);
  --stroke: rgba(255,255,255,.10);
  --shadow: 0 26px 90px rgba(0,0,0,.55);

  --accent:#c7ff9b;
  --accent2:#ffe58f;
  --danger:#ff6b7d;

  --txt: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.74);
  --muted2: rgba(255,255,255,.60);

  --radius: 18px;
  --radius2: 22px;
  --dialogH: min(28vh, 260px);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  color: var(--txt);
  background: linear-gradient(180deg, var(--bg1), var(--bg0) 70%);
  overflow:hidden;
}

.scene{
  position:relative;
  height:100vh;
  width:100vw;
  isolation:isolate;
  overflow:hidden;
}

.bg{
  position:absolute;
  inset:-3%;
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(244,231,180,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,16,19,.18), rgba(7,16,19,.90)),
    url("images/bg-mystere.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(1.05) contrast(1.05);
  transform: scale(1.06);
  will-change: transform;
  z-index:-5;
  animation: slowZoom 14s ease-in-out infinite;
}

@keyframes slowZoom{
  0%,100%{ transform: scale(1.06); }
  50%{ transform: scale(1.10); }
}

.vignette{
  position:absolute;
  inset:-2px;
  background: radial-gradient(1200px 700px at 50% 35%, transparent 45%, rgba(0,0,0,.55) 78%, rgba(0,0,0,.80));
  z-index:-4;
  pointer-events:none;
}

.fog{
  position:absolute;
  inset:0;
  z-index:-3;
  pointer-events:none;
  opacity:.55;
  mix-blend-mode: screen;
  background:
    radial-gradient(650px 280px at 20% 65%, rgba(180,255,210,.07), transparent 60%),
    radial-gradient(720px 320px at 70% 70%, rgba(160,230,255,.06), transparent 60%),
    radial-gradient(800px 360px at 50% 85%, rgba(255,255,255,.04), transparent 60%);
  filter: blur(2px);
  animation: fogDrift 18s ease-in-out infinite;
}

@keyframes fogDrift{
  0%,100%{ transform: translate3d(-1.2%,0,0); opacity:.45; }
  50%{ transform: translate3d(1.2%,0,0); opacity:.65; }
}

.fireflies{ position:absolute; inset:0; pointer-events:none; z-index:-2; }

.fly{
  position:absolute;
  width:6px;
  height:6px;
  border-radius:999px;
  background: radial-gradient(circle at 30% 30%, var(--accent2), rgba(255,229,143,.0) 60%);
  box-shadow: 0 0 18px rgba(255,229,143,.35);
  opacity:0;
  animation: fly 8s ease-in-out infinite;
}

.fly::after{
  content:"";
  position:absolute;
  inset:-8px;
  background: radial-gradient(circle, rgba(255,229,143,.22), rgba(255,229,143,0) 62%);
  border-radius:999px;
  filter: blur(1px);
}

@keyframes fly{
  0%{ transform: translate3d(0,0,0) scale(.8); opacity:0; }
  15%{ opacity:.85; }
  50%{ transform: translate3d(18px,-22px,0) scale(1.15); opacity:.9; }
  80%{ opacity:.65; }
  100%{ transform: translate3d(-10px,-8px,0) scale(.9); opacity:0; }
}

.topRight{
  position:absolute;
  top:18px;
  right:18px;
  z-index:10;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
}

.navBtn{
  text-decoration:none;
  color: rgba(255,255,255,.90);
  font-weight:900;
  font-size: 13.5px;
  padding: 10px 12px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
  display:inline-flex;
  gap:8px;
  align-items:center;
  white-space:nowrap;
}

.navBtn:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.24);
  background: rgba(0,0,0,.32);
}

.navBtn.primary{
  border-color: rgba(199,255,155,.35);
  background: rgba(199,255,155,.12);
}

.navBtn.primary:hover{
  background: rgba(199,255,155,.18);
  border-color: rgba(199,255,155,.48);
}

.brandBadge{
  position:absolute;
  top:18px;
  left:18px;
  z-index:10;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 9px 12px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.24);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:12px;
  color: rgba(255,255,255,.82);
  user-select:none;
}

.brandBadgeStatic{
  position:static;
  margin:0;
}

.dot{
  width:10px;
  height:10px;
  border-radius:50%;
  background: var(--danger);
  box-shadow: 0 0 18px rgba(255,107,125,.55);
  animation: pulse 2.4s ease-in-out infinite;
}

@keyframes pulse{
  0%,100%{ transform:scale(.85); opacity:.7; }
  50%{ transform:scale(1.15); opacity:1; }
}

.character{
  position:absolute;
  right:min(5vw, 70px);
  bottom:0;
  width:min(40vw, 520px);
  max-width:520px;
  min-width:240px;
  z-index:5;
  pointer-events:none;
  filter: drop-shadow(0 26px 60px rgba(0,0,0,.55));
  animation: floatChar 6.5s ease-in-out infinite;
}

.character img{
  width:100%;
  height:auto;
  display:block;
}

@keyframes floatChar{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}

.dialog{
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  bottom:16px;
  width:min(1200px, calc(100% - 24px));
  height: var(--dialogH);
  z-index:8;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(0,0,0,.42), rgba(0,0,0,.24));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  overflow:hidden;
  display:grid;
  grid-template-rows: auto 1fr auto;
}

.dialogTop{
  padding:14px 16px 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid rgba(255,255,255,.06);
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
}

.namePlate{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight:1000;
  letter-spacing:.02em;
}

.nameTag{
  padding: 7px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.88);
  font-size: 12.5px;
  user-select:none;
}

.hint{
  color: var(--muted2);
  font-size: 12.5px;
}

.dialogBody{
  padding:14px 16px;
  font-size: 15px;
  line-height: 1.6;
  color: rgba(255,255,255,.88);
  overflow:auto;
}

.dialogActions{
  padding:12px 16px 14px;
  border-top:1px solid rgba(255,255,255,.06);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  flex-wrap:wrap;
}

.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.92);
  padding: 10px 12px;
  border-radius: 14px;
  cursor:pointer;
  font-weight:950;
  letter-spacing:.01em;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
  user-select:none;
}

.btn:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.24);
  background: rgba(0,0,0,.30);
}

.btn.primary{
}

.btn.primary:hover{
  background: rgba(199,255,155,.18);
  border-color: rgba(199,255,155,.48);
}

.gate{
  position:fixed;
  inset:0;
  z-index:9999;
  display:grid;
  place-items:center;
  padding:24px;
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(244,231,180,.12), transparent 60%),
    linear-gradient(180deg, rgba(5,10,12,.92), rgba(5,10,12,.98));
}

.gate.hidden{ display:none; }

.gatePanel{
  width:min(720px, 100%);
  border-radius:18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  box-shadow: 0 20px 60px rgba(0,0,0,.6);
  overflow:hidden;
  position:relative;
}

.scanline{
  position:absolute;
  inset:-40% 0;
  background: linear-gradient(to bottom, transparent 0%, rgba(199,255,155,.08) 48%, transparent 100%);
  animation: scan 1.8s ease-in-out infinite;
  pointer-events:none;
  mix-blend-mode: screen;
  opacity:.7;
}

@keyframes scan{
  0%{ transform: translateY(-35%); opacity:.2; }
  50%{ opacity:.75; }
  100%{ transform: translateY(35%); opacity:.2; }
}

.gateHead{
  padding:18px 18px 12px;
  border-bottom:1px solid rgba(255,255,255,.07);
  display:flex;
  justify-content:space-between;
  gap:12px;
  align-items:center;
}

.gateTitle{
  margin:0;
  font-size:13px;
  letter-spacing:.10em;
  text-transform:uppercase;
  color: rgba(255,255,255,.78);
}

.gateBody{ padding:16px 18px 18px; }

.boot{
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size:13px;
  line-height:1.55;
  color: rgba(255,255,255,.80);
  margin:0 0 12px;
  white-space:pre-wrap;
  min-height:70px;
}

.row{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.input{
  flex:1 1 240px;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.26);
  color: rgba(255,255,255,.92);
  outline:none;
  font-size:14.5px;
}

.input:focus{
  border-color: rgba(199,255,155,.55);
  background: rgba(0,0,0,.34);
}

.msg{
  margin-top:10px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.78);
  font-size:13px;
  min-height:40px;
  display:flex;
  align-items:center;
  gap:10px;
}

.msg.bad{
  border-color: rgba(255,107,125,.35);
  background: rgba(255,107,125,.10);
}

.msg.ok{
  border-color: rgba(199,255,155,.35);
  background: rgba(199,255,155,.10);
}

.gateHint{ margin:10px 0 0; }

.overlay{
  position:fixed;
  inset:0;
  z-index:999;
  background: rgba(0,0,0,.55);
  display:none;
  align-items:center;
  justify-content:center;
  padding:18px;
}

.overlay.open{ display:flex; }

.modal{
  width:min(1120px, 100%);
  max-height:min(86vh, 900px);
  overflow:hidden;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(10,18,22,.72), rgba(10,18,22,.46));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: var(--shadow);
  animation: pop .16s ease-out;
}

@keyframes pop{
  from{ transform: translateY(10px); opacity:0; }
  to{ transform: translateY(0); opacity:1; }
}

.modalHead{
  padding:16px 18px;
  border-bottom:1px solid rgba(255,255,255,.07);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,0));
}

.modalHead h2{
  margin:0;
  font-size:15px;
  letter-spacing:.06em;
  text-transform:uppercase;
  color: rgba(255,255,255,.86);
}

.modalHeadActions{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.close{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  color: rgba(255,255,255,.92);
  border-radius: 12px;
  padding: 10px 12px;
  cursor:pointer;
  font-weight:900;
}

.close:hover{ background: rgba(0,0,0,.32); }

.modalBody{
  padding:16px 18px 18px;
  overflow:auto;
  max-height: calc(min(86vh, 900px) - 62px);
}

.card{
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  border-radius: var(--radius);
  padding:14px;
}

.card h3{
  margin:0 0 8px;
  font-size:14px;
  letter-spacing:.02em;
}

.p{
  margin:0;
  color: var(--muted);
  font-size:14px;
  line-height:1.5;
}

.missionIntro{
  margin-bottom:12px;
}

.dashboardList{
  display:grid;
  gap:12px;
}

.missionCard{
  width:100%;
  text-align:left;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  border-radius:18px;
  padding:16px;
  color: var(--txt);
  cursor:pointer;
  transition: transform .12s ease, background .12s ease, border-color .12s ease, opacity .12s ease;
}

.missionCard:hover{
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.20);
  background: rgba(0,0,0,.28);
}

.missionCard.locked{
  opacity:.45;
  pointer-events:none;
}

.missionTitle{
  font-size:18px;
  font-weight:900;
  margin:0 0 6px;
}

.missionMeta{
  color: var(--muted2);
  font-size:13px;
  margin:0;
}

.susLayout{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:14px;
  align-items:start;
}

.susGrid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:12px;
}

.susCard{
  border-radius:16px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.16);
  overflow:hidden;
  box-shadow: 0 18px 40px rgba(0,0,0,.30);
  transition: transform .14s ease, box-shadow .14s ease, border-color .14s ease;
  cursor:pointer;
  position:relative;
}

.susCard:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 22px 52px rgba(0,0,0,.40);
}

.susCard.active{
  border-color: rgba(199,255,155,.45);
  box-shadow: 0 22px 52px rgba(0,0,0,.45), 0 0 0 1px rgba(199,255,155,.12) inset;
}

.susCard img{
  width:100%;
  height:auto;
  display:block;
}

.ribbon{
  position:absolute;
  top:10px;
  left:10px;
  padding: 6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.30);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  font-size:11px;
  font-weight:900;
  color: rgba(255,255,255,.88);
  user-select:none;
}

.ribbon[data-status="suspect"]{
  border-color: rgba(255,107,125,.35);
  background: rgba(255,107,125,.12);
}

.ribbon[data-status="innocent"]{
  border-color: rgba(199,255,155,.35);
  background: rgba(199,255,155,.12);
}

.susDetailsTop{
  display:flex;
  gap:12px;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
  margin-bottom:12px;
}

.susTitle{
  margin:0;
  font-size:16px;
  letter-spacing:.02em;
}

.susSub{
  margin:6px 0 0;
  color: var(--muted2);
  font-size:12.5px;
  line-height:1.35;
}

.statusRow{
  display:flex;
  gap:10px;
  align-items:center;
  flex-wrap:wrap;
}

.statusRow label{
  color: var(--muted2);
  font-size:12.5px;
}

.statusRow select{
  width:auto;
  min-width:170px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.20);
  color: rgba(255,255,255,.90);
  outline:none;
  font-weight:900;
  cursor:pointer;
}

.proofs{
  display:grid;
  gap:8px;
  padding:12px;
  border-radius:14px;
  border:1px dashed rgba(255,255,255,.14);
  background: rgba(0,0,0,.12);
}

.proofs legend{
  padding:0 6px;
  color: rgba(255,255,255,.78);
  font-weight:900;
  letter-spacing:.06em;
  text-transform:uppercase;
  font-size:11px;
}

.proof{
  display:flex;
  gap:10px;
  align-items:flex-start;
  color: rgba(255,255,255,.82);
  font-size:13px;
  line-height:1.35;
}

.proof input{
  margin-top:2px;
  accent-color: var(--accent);
  transform: scale(1.05);
}

.notes{
  margin-top:12px;
  display:grid;
  gap:8px;
}

textarea{
  width:100%;
  min-height:110px;
  resize: vertical;
  padding:11px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.90);
  outline:none;
  font-size:14px;
  line-height:1.5;
}

textarea:focus{
  border-color: rgba(199,255,155,.55);
  background: rgba(0,0,0,.28);
}

.smallLine{
  margin-top:10px;
  color: var(--muted2);
  font-size:12.5px;
}

/* mission pages */
.mission-page{ overflow:hidden; }

.missionBg{
  position:absolute;
  inset:-3%;
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(255,214,120,.12), transparent 60%),
    linear-gradient(180deg, rgba(12,10,8,.35), rgba(7,16,19,.90)),
    url("images/bg-mission-1.jpg");
  background-size: cover;
  background-position: center;
  filter: saturate(1.02) contrast(1.02);
  transform: scale(1.06);
  will-change: transform;
  z-index:-5;
  animation: slowZoom 14s ease-in-out infinite;
}

.missionBg.bgMission2{
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(180,220,255,.12), transparent 60%),
    linear-gradient(180deg, rgba(8,12,18,.35), rgba(7,16,19,.90)),
    url("images/bg-mission-2.jpg");
  background-size: cover;
  background-position: center;
}

.missionCharacter{
  right:min(2vw, 30px);
  width:min(28vw, 360px);
  opacity:.88;
}

.missionFolder{
  position:relative;
  z-index:9;
  width:min(1050px, calc(100% - 48px));
  margin:90px auto 24px;
}

.folderTabs{
  display:flex;
  gap:10px;
  margin-left:18px;
}

.folderTab{
  display:inline-flex;
  align-items:center;
  padding: 10px 16px;
  border-radius:16px 16px 0 0;
  background: rgba(35, 29, 18, .82);
  color: rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.10);
  border-bottom:none;
  font-size:13px;
  font-weight:800;
  letter-spacing:.03em;
}

.folderTab.active{
  background: rgba(214, 194, 147, .92);
  color:#241b0d;
}

.folderPaper{
  position:relative;
  background: linear-gradient(180deg, rgba(238,229,205,.96), rgba(220,208,178,.96));
  color:#221c14;
  border-radius:22px;
  border:1px solid rgba(70,55,28,.25);
  box-shadow: 0 30px 80px rgba(0,0,0,.45);
  overflow:hidden;
}

.folderPaper::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 20% 20%, rgba(255,255,255,.18), transparent 30%),
    radial-gradient(circle at 80% 30%, rgba(120,90,30,.06), transparent 26%),
    radial-gradient(circle at 40% 80%, rgba(120,90,30,.05), transparent 26%);
  pointer-events:none;
}

.folderHeader{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
  padding:28px 28px 18px;
  border-bottom:1px solid rgba(60,46,22,.16);
}

.folderKicker{
  margin:0 0 6px;
  font-size:12px;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
  color: rgba(34,28,20,.68);
}

.folderHeader h1{
  margin:0;
  font-size: clamp(28px, 4vw, 42px);
  line-height:1.05;
  color:#1f170d;
}

.folderStamp{
  flex-shrink:0;
  padding:12px 16px;
  border:2px solid rgba(120,35,20,.45);
  color: rgba(120,35,20,.75);
  border-radius:12px;
  font-weight:900;
  letter-spacing:.12em;
  transform: rotate(-6deg);
}

.folderContent{
  position:relative;
  z-index:1;
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap:22px;
  padding:24px 28px 28px;
}

.folderBlock{
  background: rgba(255,255,255,.22);
  border:1px solid rgba(60,46,22,.14);
  border-radius:18px;
  padding:18px;
}

.folderBlock h2{
  margin:0 0 10px;
  font-size:18px;
  color:#1f170d;
}

.missionDialogue{
  min-height:140px;
  font-size:18px;
  line-height:1.65;
  color:#2d2417;
}

.missionDialogue p{ margin:0 0 14px; }
.missionDialogue p:last-child{ margin-bottom:0; }

.folderValidate .p{
  color: rgba(34,28,20,.78);
}

.folderValidate .input{
  background: rgba(255,255,255,.50);
  color:#1e170f;
  border:1px solid rgba(60,46,22,.18);
}

.folderValidate .input:focus{
  background: rgba(255,255,255,.68);
  border-color: rgba(110,90,40,.42);
}

.folderValidate .msg{
  background: rgba(255,255,255,.32);
  color:#2d2417;
  border:1px solid rgba(60,46,22,.14);
}

.folderValidate .msg.ok{
  border-color: rgba(83,125,52,.35);
  background: rgba(183,219,150,.30);
}

.folderValidate .msg.bad{
  border-color: rgba(170,70,70,.28);
  background: rgba(225,180,180,.28);
}

.folderValidate .btn{ color:#fff; }

.missionResult{
  margin-top:16px;
  padding-top:16px;
  border-top:1px dashed rgba(60,46,22,.18);
}

@media (max-width: 1100px){
  .susGrid{ grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 980px){
  .susLayout{ grid-template-columns: 1fr; }

  .missionFolder{
    width:min(94vw, 900px);
    margin-top:80px;
  }

  .folderContent{
    grid-template-columns:1fr;
  }

  .missionCharacter{
    display:none;
  }
}

@media (max-width: 620px){
  .susGrid{ grid-template-columns:1fr; }
}

@media (prefers-reduced-motion: reduce){
  .fog,.fly,.dot,.bg,.scanline,.character{ animation:none !important; }
  .navBtn,.btn,.missionCard{ transition:none; }
  .susCard{ transition:none; }
  .susCard:hover{ transform:none; }
}

.missionBg--2{
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(170,220,255,.12), transparent 60%),
    linear-gradient(180deg, rgba(10,14,18,.35), rgba(7,16,19,.90)),
    url("images/bg-mission-2.jpg");
  background-size: cover;
  background-position: center;
}

.missionBg--4{
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(255,214,120,.10), transparent 60%),
    linear-gradient(180deg, rgba(12,10,8,.35), rgba(7,16,19,.90)),
    url("images/bg-mission-4.jpg");
  background-size: cover;
  background-position: center;
}


/* ==========================
   ACCUSATION FINALE
========================== */

.accuseWrap{
  margin-top: 16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.btn.accuseBtn{
  border-color: rgba(255,107,125,.38);
  background: rgba(255,107,125,.12);
}

.btn.accuseBtn:hover{
  background: rgba(255,107,125,.18);
  border-color: rgba(255,107,125,.52);
}

.finalModal{
  width: min(980px, 100%);
}

.finalBody{
  display:grid;
  grid-template-columns: 420px 1fr;
  gap: 22px;
  align-items:center;
}

.finalCapture{
  position:relative;
  border-radius: 20px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  min-height: 520px;
  box-shadow: 0 18px 50px rgba(0,0,0,.35);
}

.finalCapture img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}

.prisonBars{
  position:absolute;
  inset:0;
  display:flex;
  justify-content:space-evenly;
  pointer-events:none;
}

.prisonBars span{
  width: 18px;
  height: 100%;
  background: linear-gradient(180deg, rgba(210,210,220,.92), rgba(110,110,120,.96));
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.18),
    0 0 12px rgba(0,0,0,.35);
  transform: translateY(-120%);
  animation: barsDrop .55s ease forwards;
}

.prisonBars span:nth-child(1){ animation-delay: .05s; }
.prisonBars span:nth-child(2){ animation-delay: .12s; }
.prisonBars span:nth-child(3){ animation-delay: .19s; }
.prisonBars span:nth-child(4){ animation-delay: .26s; }
.prisonBars span:nth-child(5){ animation-delay: .33s; }

@keyframes barsDrop{
  from{ transform: translateY(-120%); }
  to{ transform: translateY(0); }
}

.finalText{
  display:grid;
  gap: 14px;
  align-content:center;
}

.finalBadge{
  display:inline-flex;
  width:max-content;
  align-items:center;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  border:1px solid rgba(199,255,155,.35);
  background: rgba(199,255,155,.10);
  color: rgba(255,255,255,.92);
  font-size: 12px;
  font-weight: 900;
  letter-spacing:.08em;
  text-transform: uppercase;
}

.finalText h3{
  margin:0;
  font-size: clamp(28px, 4vw, 42px);
  line-height:1.05;
}

.speechBubble{
  position:relative;
  padding: 18px 18px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.92);
  font-size: 18px;
  line-height:1.5;
  box-shadow: 0 14px 34px rgba(0,0,0,.18);
}

.speechBubble::after{
  content:"";
  position:absolute;
  left: 26px;
  bottom: -12px;
  width: 22px;
  height: 22px;
  background: rgba(255,255,255,.08);
  border-right:1px solid rgba(255,255,255,.14);
  border-bottom:1px solid rgba(255,255,255,.14);
  transform: rotate(45deg);
}

.finalText .p{
  font-size: 16px;
  line-height:1.65;
}

@media (max-width: 900px){
  .finalBody{
    grid-template-columns: 1fr;
  }

  .finalCapture{
    min-height: 360px;
  }
}











/* ==========================
   PAGE FINALE
========================== */

.finaleBg{
  background:
    radial-gradient(900px 520px at 50% 35%, rgba(255,214,140,.18), transparent 60%),
    linear-gradient(180deg, rgba(7,16,19,.20), rgba(7,16,19,.86)),
    url("images/bg-mystere.jpg");
  background-size: cover;
  background-position: center;
}

.finalePanel{
  position: relative;
  width: min(1380px, calc(100% - 40px));
  margin: 84px auto 30px;
  display: grid;
  grid-template-columns: minmax(420px, 1fr) minmax(380px, 1fr);
  gap: 26px;
  align-items: center;
}

.finaleTextCol{
  display: grid;
  gap: 18px;
}

.finaleHeader{
  color: rgba(255,255,255,.96);
}

.finaleKicker{
  margin: 0 0 10px;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(255,255,255,.65);
  font-weight: 900;
}

.finaleHeader h1{
  margin: 0 0 8px;
  font-size: clamp(44px, 7vw, 86px);
  line-height: .95;
}

.finaleSub{
  margin: 0;
  font-size: clamp(20px, 2.2vw, 34px);
  color: rgba(255,255,255,.82);
}

.agentCongrats{
  padding: 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 16px 40px rgba(0,0,0,.25);
}

.agentCongratsTitle{
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 900;
  color: rgba(255,255,255,.72);
  margin-bottom: 10px;
}

.agentCongrats p{
  margin: 0;
  color: rgba(255,255,255,.90);
  line-height: 1.7;
  font-size: 18px;
}

.culpritSpeech{
  position: relative;
  padding: 24px 26px;
  border-radius: 26px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  color: rgba(255,255,255,.96);
  font-size: clamp(22px, 2.3vw, 30px);
  line-height: 1.5;
}

.culpritSpeech::after{
  content: "";
  position: absolute;
  right: -10px;
  top: 50%;
  width: 24px;
  height: 24px;
  background: rgba(0,0,0,.28);
  border-right: 1px solid rgba(255,255,255,.14);
  border-top: 1px solid rgba(255,255,255,.14);
  transform: translateY(-50%) rotate(45deg);
}

.culpritSpeech p{
  margin: 0 0 12px;
}

.culpritSpeech p:last-child{
  margin-bottom: 0;
}

.finalHintCard{
  width: fit-content;
  max-width: 100%;
  padding: 14px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.28);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: rgba(255,255,255,.94);
  font-size: 18px;
}

.finalHintLabel{
  display: block;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: rgba(255,255,255,.62);
  font-weight: 900;
  margin-bottom: 6px;
}

.finaleActions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.finaleSceneCard{
  position: relative;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  box-shadow: 0 26px 80px rgba(0,0,0,.42);
}

.finaleSceneCard img{
  display: block;
  width: 100%;
  height: auto;
}

@media (max-width: 980px){
  .finalePanel{
    grid-template-columns: 1fr;
  }

  .finaleImageCol{
    order: -1;
  }

  .culpritSpeech::after{
    display: none;
  }
}



/* ======================
   FINALE SCENE
====================== */

.finaleScene {
  position: relative;
}

/* RENARD GAUCHE */
.finalRenard {
  position: absolute;
  left: 5%;
  bottom: 0;
  width: min(32vw, 420px);
  z-index: 6;
  pointer-events: none;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,.6));
}

.finalRenard img {
  width: 100%;
}

/* AGENT DROITE */
.finalAgent {
  position: absolute;
  right: 5%;
  bottom: 0;
  width: min(32vw, 420px);
  z-index: 5;
  pointer-events: none;
  opacity: 0.9;
}

/* TEXTE CENTRE */
.finalDialog {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: min(900px, calc(100% - 30px));
  z-index: 10;
}

/* CARTE */
.finalCard {
  padding: 22px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
}

/* TEXTES */
.finalCard h2 {
  margin-top: 0;
  font-size: 26px;
}

.agentLine {
  color: #d7fcb2;
  font-weight: 600;
}

.foxLine {
  color: #ffd7a3;
  margin-top: 10px;
}

.foxLine.strong {
  font-size: 18px;
  font-weight: 700;
}

/* ACTIONS */
.finalActions {
  margin-top: 16px;
  display: flex;
  gap: 10px;
}


/* ======================
   FINALE SCENE VIVANTE
====================== */

.finaleScene{
  position: relative;
  overflow: hidden;
}

.finalGlow{
  position:absolute;
  left:50%;
  top:42%;
  transform:translate(-50%,-50%);
  width:min(38vw, 520px);
  height:min(38vw, 520px);
  border-radius:50%;
  background: radial-gradient(circle, rgba(255,230,150,.12), rgba(255,230,150,0) 68%);
  filter: blur(10px);
  z-index: 0;
  pointer-events:none;
  animation: finalGlowPulse 5.5s ease-in-out infinite;
}

@keyframes finalGlowPulse{
  0%,100%{ opacity:.45; transform:translate(-50%,-50%) scale(1); }
  50%{ opacity:.75; transform:translate(-50%,-50%) scale(1.08); }
}

/* RENARD */
.finalRenard{
  position:absolute;
  left: 4%;
  bottom: 0;
  width: min(30vw, 420px);
  z-index: 6;
  pointer-events:none;
  filter: drop-shadow(0 30px 60px rgba(0,0,0,.62));
  animation: renardFloat 4.8s ease-in-out infinite;
}

.finalRenard img{
  width:100%;
  display:block;
}

@keyframes renardFloat{
  0%,100%{ transform: translateY(0) rotate(0deg); }
  50%{ transform: translateY(-7px) rotate(-.4deg); }
}

/* AGENT */
.finalAgent{
  position:absolute;
  right: 4%;
  bottom: 0;
  width: min(30vw, 420px);
  z-index: 5;
  pointer-events:none;
  opacity: .94;
  filter: drop-shadow(0 28px 50px rgba(0,0,0,.6));
  animation: agentFloat 6.3s ease-in-out infinite;
}

.finalAgent img{
  width:100%;
  display:block;
}

@keyframes agentFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-8px); }
}

/* TEXTE */
.finalDialog{
  position:absolute;
  left:50%;
  bottom: 20px;
  transform: translateX(-50%);
  width:min(900px, calc(100% - 30px));
  z-index:10;
}

.finalCard{
  padding:22px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  opacity: 0;
  transform: translateY(24px);
  animation: finalCardIn .8s ease-out .18s forwards;
}

@keyframes finalCardIn{
  from{
    opacity:0;
    transform: translateY(24px);
  }
  to{
    opacity:1;
    transform: translateY(0);
  }
}

.finalCard h2{
  margin-top:0;
  font-size:26px;
}

.agentLine{
  color:#d7fcb2;
  font-weight:600;
}

.foxLine{
  color:#ffd7a3;
  margin-top:10px;
}

.foxLine.strong{
  font-size:18px;
  font-weight:700;
}

.finalActions{
  margin-top:16px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

/* Mobile */
@media (max-width: 980px){
  .finalRenard{
    left: -2%;
    width: min(42vw, 300px);
    opacity: .95;
  }

  .finalAgent{
    right: -4%;
    width: min(42vw, 300px);
    opacity: .85;
  }

  .finalDialog{
    width:min(94%, calc(100% - 20px));
    bottom: 14px;
  }

  .finalCard{
    padding:18px;
  }
}

@media (prefers-reduced-motion: reduce){
  .finalGlow,
  .finalRenard,
  .finalAgent,
  .finalCard{
    animation:none !important;
  }
}


/* ======================
   PAGE FINALE
====================== */

.finaleScene{
  position: relative;
  min-height: 100vh;
  overflow: hidden;
}

.finalRenard{
  position: absolute;
  left: 5%;
  bottom: 0;
  width: min(40vw, 550px);
  z-index: 6;
  pointer-events: none;
  filter: drop-shadow(0 24px 50px rgba(0,0,0,.55));
  animation: finalFoxFloat 4.8s ease-in-out infinite;
}

.finalRenard img{
  display: block;
  width: 100%;
  height: auto;
}

.finalAgent{
  position: absolute;
  right: 5%;
  bottom: 0;
  width: min(40vw, 500px);
  z-index: 5;
  pointer-events: none;
  filter: drop-shadow(0 24px 50px rgba(0,0,0,.55));
  animation: finalAgentFloat 6s ease-in-out infinite;
}

.finalAgent img{
  display: block;
  width: 100%;
  height: auto;
}

.finalDialogWrap{
  position: absolute;
  left: 50%;
  bottom: 28px;
  transform: translateX(-50%);
  width: min(860px, calc(100% - 480px));
  z-index: 12;
}

.finalDialogCard{
  padding: 24px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.34);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 20px 60px rgba(0,0,0,.45);
  animation: finalCardIn .6s ease-out forwards;
}

.finalDialogCard h2{
  margin: 0 0 18px;
  font-size: 22px;
  color: rgba(255,255,255,.95);
}

.finalSpeechRow{
  display: flex;
  margin-bottom: 12px;
}

.finalSpeechRow--agent{
  justify-content: flex-end;
}

.finalSpeechRow--fox{
  justify-content: flex-start;
}

.finalSpeechBubble{
  max-width: 76%;
  padding: 12px 16px;
  border-radius: 16px;
  font-size: 15px;
  line-height: 1.45;
  border: 1px solid rgba(255,255,255,.12);
}

.finalSpeechBubble--agent{
  background: linear-gradient(135deg, rgba(199,255,155,.16), rgba(199,255,155,.07));
  color: #dff7bf;
}

.finalSpeechBubble--fox{
  background: linear-gradient(135deg, rgba(255,215,163,.16), rgba(255,215,163,.07));
  color: #ffdcb5;
}

.finalSpeechBubble--strong{
  font-size: 17px;
  font-weight: 700;
}

.finalActions{
  margin-top: 18px;
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

@keyframes finalFoxFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-6px); }
}

@keyframes finalAgentFloat{
  0%,100%{ transform: translateY(0); }
  50%{ transform: translateY(-8px); }
}

@keyframes finalCardIn{
  from{
    opacity: 0;
    transform: translateY(16px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 1200px){
  .finalDialogWrap{
    width: min(820px, calc(100% - 360px));
  }

  .finalRenard,
  .finalAgent{
    width: min(24vw, 280px);
  }
}

@media (max-width: 900px){
  .finalDialogWrap{
    width: calc(100% - 24px);
    left: 50%;
    transform: translateX(-50%);
    bottom: 14px;
  }

  .finalRenard{
    left: -2%;
    width: min(38vw, 240px);
    opacity: .95;
  }

  .finalAgent{
    right: -2%;
    width: min(38vw, 240px);
    opacity: .9;
  }

  .finalSpeechBubble{
    max-width: 90%;
  }
}

@media (max-width: 640px){
  .finalRenard{
    width: 180px;
    left: -10px;
  }

  .finalAgent{
    width: 180px;
    right: -10px;
  }

  .finalDialogCard{
    padding: 18px;
  }

  .finalDialogCard h2{
    font-size: 20px;
  }

  .finalSpeechBubble--strong{
    font-size: 16px;
  }
}





.finalTitle{
  position: absolute;
  top: 22%;
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 9;
  pointer-events: none;
  animation: finalTitleIn 1s ease-out forwards;
}

.finalTitle h1{
  font-size: clamp(42px, 6vw, 90px);
  margin: 0;
  font-weight: 800;
  letter-spacing: 1px;

  color: #f5f5f5;

  text-shadow:
    0 0 20px rgba(255,255,255,0.15),
    0 0 60px rgba(255,230,150,0.08),
    0 10px 40px rgba(0,0,0,0.8);
}

.finalSubtitle{
  display: block;
  margin-top: 8px;
  font-size: 16px;
  letter-spacing: 4px;
  color: rgba(255,255,255,0.6);
}

@keyframes finalTitleIn{
  from{
    opacity: 0;
    transform: translateY(-20px);
  }
  to{
    opacity: 1;
    transform: translateY(0);
  }
}


.finalTitle{
  position: absolute;
  top: 18%; /* 👈 descend */
  left: 0;
  width: 100%;
  text-align: center;
  z-index: 9;
  pointer-events: none;
}

.finalTitle h1{
  font-size: clamp(42px, 6vw, 80px);
  margin: 0 0 14px;
  font-weight: 800;
  letter-spacing: 1px;
  color: #f5f5f5;
  text-shadow:
    0 0 20px rgba(255,255,255,0.15),
    0 0 60px rgba(255,230,150,0.08),
    0 10px 40px rgba(0,0,0,0.8);
}

.finalStamp{
  display: block;
  padding: 10px 28px;
  border: 4px solid rgba(168,126,108,.82);
  border-radius: 22px;
  color: rgba(168,126,108,.95);
  font-size: clamp(20px, 2vw, 30px);
  font-weight: 900;
  letter-spacing: .12em;
  text-transform: uppercase;
  transform: rotate(-6deg);
  background: rgba(255,255,255,.03);
  box-shadow: 0 8px 24px rgba(0,0,0,.16);
}

.finalTitleText{
  font-size: clamp(42px, 6vw, 90px);
  margin: 0;
  font-weight: 800;
  letter-spacing: 1px;
  color: #f5f5f5;
  text-align: center;

  text-shadow:
    0 0 20px rgba(255,255,255,0.15),
    0 0 60px rgba(255,230,150,0.08),
    0 10px 40px rgba(0,0,0,0.8);
}

/* MOT TAMPON */
.stampWord{
  display: block;
  margin: 0 auto;
  padding: 8px 22px;
max-width:fit-content;
  border: 4px solid rgba(168,126,108,.85);
  border-radius: 18px;

  color: #fff;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;

  transform: rotate(-6deg);

  background: rgba(168,126,108,.85);

  box-shadow:
    0 6px 18px rgba(0,0,0,.2),
    inset 0 0 8px rgba(255,255,255,.05);
}

.stampWord{
  animation: stampIn .6s ease-out;
}

@keyframes stampIn{
  0%{
    transform: scale(2) rotate(-10deg);
    opacity: 0;
  }
  60%{
    transform: scale(0.9) rotate(-4deg);
  }
  100%{
    transform: scale(1) rotate(-6deg);
    opacity: 1;
  }
}
.finalTitle h1{
  animation: titleGlow 4s ease-in-out infinite;
}

@keyframes titleGlow{
  0%,100%{
    text-shadow:
      0 0 20px rgba(255,255,255,0.15),
      0 0 60px rgba(255,230,150,0.08);
  }
  50%{
    text-shadow:
      0 0 30px rgba(255,255,255,0.25),
      0 0 90px rgba(255,230,150,0.15);
  }
}



.folderValidate.revealed-state {
  background: linear-gradient(180deg, #f3e2a7 0%, #ecd084 100%);
  border: 1px solid rgba(170, 128, 46, 0.28);
  box-shadow:
    0 16px 34px rgba(116, 84, 28, 0.14),
    inset 0 1px 0 rgba(255,255,255,0.45);
}

.folderValidate.revealed-state h2#missionPanelTitle {
  color: #6f471d;
}

.missionRevealCompact {
  margin-top: 10px;
  padding: 18px;
  border-radius: 24px;
  background: linear-gradient(180deg, #f7eabf 0%, #eed792 100%);
  border: 2px solid rgba(184, 142, 56, 0.30);
  box-shadow:
    0 10px 30px rgba(92, 67, 22, 0.12),
    inset 0 1px 0 rgba(255,255,255,0.45);
}

.missionRevealBannerCompact {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  text-align: center;
  padding: 14px 16px;
  margin-bottom: 16px;
  border-radius: 18px;
  background: linear-gradient(180deg, #e8d28b 0%, #dbbd67 100%);
  border: 1px solid rgba(160, 114, 34, 0.24);
  color: #6d451d;
  font-size: 1.35rem;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.35);
}

.missionRevealCardCompact {
  background: #fffaf0;
  border-radius: 20px;
  padding: 20px;
  border: 1px solid rgba(191, 156, 86, 0.22);
  box-shadow: 0 6px 18px rgba(88, 62, 18, 0.08);
}

.missionRevealTitleCompact {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 14px;
  font-size: 1.65rem;
  line-height: 1.2;
  color: #4f3418;
}

.missionRevealTextCompact {
  margin: 0;
  font-size: 1.22rem;
  line-height: 1.55;
  color: #5b4023;
}

.missionRevealActionsCompact {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
  margin-top: 22px;
}

.missionContinueBtn {
  min-width: 250px;
  text-align: center;
  background: linear-gradient(180deg, #7ea864 0%, #628a4c 100%);
  color: #fff;
  border: 0;
  box-shadow:
    0 8px 18px rgba(68, 101, 48, 0.22),
    inset 0 1px 0 rgba(255,255,255,0.22);
}

.missionSecondaryLink {
  color: #7a5a32;
  font-weight: 700;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.missionResult.is-revealed .missionRevealCompact {
  animation: revealFadeCompact 0.45s ease;
}

@keyframes revealFadeCompact {
  0% {
    opacity: 0;
    transform: translateY(14px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@media (max-width: 900px) {
  .missionRevealBannerCompact {
    font-size: 1.1rem;
  }

  .missionRevealTitleCompact {
    font-size: 1.3rem;
  }

  .missionRevealTextCompact {
    font-size: 1.05rem;
  }

  .missionContinueBtn {
    width: 100%;
    min-width: 0;
  }
}

.missionRevealSuccess {
  margin: 0 0 14px;
  padding: 10px 14px;
  border-radius: 14px;
  background: #e4f1d7;
  border: 1px solid #b9d29c;
  color: #42612b;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.4;
}