/* ============================================================
   OPERATION SAALEFALKE — Main Stylesheet
   ============================================================ */

:root {
  --black:   #0b0c0e;
  --panel:   #14161a;
  --panel-2: #1b1e23;
  --doc:     #e7e1d2;
  --doc-line:#cfc7b2;
  --amber:   #f0a92b;
  --amber-d: #c98512;
  --red:     #d8392f;
  --steel:   #7f93a6;
  --green:   #3db87a;
  --line:    rgba(231,225,210,.12);
  --shadow:  0 22px 60px -22px rgba(0,0,0,.85);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  background: var(--black);
  color: var(--doc);
  font-family: 'Saira', system-ui, sans-serif;
  font-weight: 300;
  font-size: 17px;
  line-height: 1.65;
  overflow-x: hidden;
  background-image:
    radial-gradient(1100px 700px at 85% -8%, rgba(216,57,47,.10), transparent 60%),
    radial-gradient(900px 600px at -8% 25%, rgba(240,169,43,.07), transparent 55%);
  min-height: 100vh;
}

/* Scanlines overlay */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  background: repeating-linear-gradient(0deg, rgba(0,0,0,.14) 0 1px, transparent 1px 3px);
  mix-blend-mode: overlay;
  opacity: .45;
}

.wrap { max-width: 1060px; margin: 0 auto; padding: 0 24px; }

a { color: var(--amber); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ---- Typography ---- */
.mono  { font-family: 'Space Mono', monospace; }
.type  { font-family: 'Special Elite', monospace; }
.amber { color: var(--amber); }
.red   { color: var(--red); }
.steel { color: var(--steel); }

/* ---- Classification Bar ---- */
.classbar {
  background: var(--red);
  color: #fff;
  text-align: center;
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: 5px;
  font-weight: 700;
  padding: 6px 10px;
  text-transform: uppercase;
  position: relative;
  z-index: 50;
}

/* ---- Top Nav ---- */
.topnav {
  background: rgba(11,12,14,.92);
  border-bottom: 1px solid var(--line);
  position: sticky;
  top: 0;
  z-index: 40;
  backdrop-filter: blur(8px);
}

.nav-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: 12px;
  padding-bottom: 12px;
  gap: 16px;
  flex-wrap: wrap;
}

.nav-brand {
  font-size: 13px;
  letter-spacing: 3px;
  color: var(--steel);
  text-decoration: none;
  font-weight: 700;
}
.nav-brand:hover { color: var(--doc); text-decoration: none; }
.nav-brand .amber { color: var(--amber); }

.nav-links {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.nav-link {
  font-family: 'Space Mono', monospace;
  font-size: 11px;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--steel);
  padding: 6px 12px;
  border-radius: 5px;
  text-decoration: none;
  transition: .15s;
  border: 1px solid transparent;
}
.nav-link:hover, .nav-link.active {
  color: var(--amber);
  border-color: rgba(240,169,43,.35);
  background: rgba(240,169,43,.07);
  text-decoration: none;
}
.nav-logout { color: rgba(127,147,166,.6); }
.nav-logout:hover { color: var(--red); border-color: rgba(216,57,47,.35); background: rgba(216,57,47,.07); }

.nav-status {
  font-family: 'Space Mono', monospace;
  font-size: 10px;
  letter-spacing: 2px;
  text-transform: uppercase;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border-radius: 5px;
  border: 1px solid var(--line);
}
.nav-status.status-active { color: var(--amber); border-color: rgba(240,169,43,.3); }
.nav-status.status-completed { color: var(--green); border-color: rgba(61,184,122,.3); }
.nav-status.status-failed { color: var(--red); border-color: rgba(216,57,47,.3); }
.nav-status.status-planning { color: var(--steel); }

/* ---- Dots / Blink ---- */
.dot, .status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--red);
  box-shadow: 0 0 8px var(--red);
  display: inline-block;
  animation: blink 1.1s steps(2) infinite;
}
.status-active .status-dot { background: var(--amber); box-shadow: 0 0 8px var(--amber); }
.status-completed .status-dot { background: var(--green); box-shadow: 0 0 8px var(--green); }

@keyframes blink { 50% { opacity: .15; } }

/* ---- Sections ---- */
.sec { padding: 60px 0; border-bottom: 1px solid var(--line); }
.sec-no {
  font-family: 'Space Mono', monospace;
  color: var(--red);
  font-size: 12px;
  letter-spacing: 3px;
  text-transform: uppercase;
  margin-bottom: 6px;
}
h2 {
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: clamp(28px,5vw,52px);
  line-height: .98;
  letter-spacing: .5px;
  margin-bottom: 20px;
}
.page-title {
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 800;
  text-transform: uppercase;
  font-size: clamp(32px,5vw,56px);
  line-height: .95;
  letter-spacing: .5px;
  margin-bottom: 24px;
}
.page-title em { color: var(--red); font-style: normal; }
.lead { color: #cfc8b6; max-width: 740px; font-size: 18px; font-weight: 300; margin-bottom: 20px; }
.panel-text { color: #c7c0b0; font-weight: 300; line-height: 1.7; margin-top: 8px; }

/* ---- Hero ---- */
.hero {
  position: relative;
  padding: 60px 0 52px;
  border-bottom: 1px solid var(--line);
  overflow: hidden;
}
.hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 42%, transparent 118px, rgba(240,169,43,.08) 119px, transparent 121px),
    radial-gradient(circle at 50% 42%, transparent 178px, rgba(240,169,43,.05) 179px, transparent 181px);
  pointer-events: none;
}
.reticle { position: absolute; left: 50%; top: 42%; width: 1px; height: 1px; pointer-events: none; }
.reticle::before, .reticle::after { content: ""; position: absolute; background: rgba(240,169,43,.14); }
.reticle::before { left: -130px; top: 0; width: 260px; height: 1px; }
.reticle::after  { left: 0; top: -130px; width: 1px; height: 260px; }

.stamp {
  position: absolute; top: 70px; right: 24px;
  border: 3px solid var(--red); color: var(--red);
  font-family: 'Special Elite', monospace; font-size: 14px; letter-spacing: 3px;
  padding: 8px 14px; transform: rotate(8deg); border-radius: 4px;
  text-transform: uppercase; text-align: center; line-height: 1.25; opacity: .9; z-index: 2;
}

.file-no { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 3px; color: var(--steel); text-transform: uppercase; }
.kicker  { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 5px; text-transform: uppercase; color: var(--amber); margin: 14px 0 12px; }

.hero-title {
  font-family: 'Saira Condensed', sans-serif;
  font-weight: 800;
  font-size: clamp(44px,9vw,106px);
  line-height: .88;
  letter-spacing: 1px;
  text-transform: uppercase;
  margin-bottom: 18px;
}
.hero-title em { color: var(--red); font-style: normal; }
.hero-sub { max-width: 680px; font-size: 19px; color: #d8d2c2; font-weight: 300; margin-bottom: 28px; }

/* ---- HUD cells ---- */
.hud { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 28px; }
.hud-cell {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px 16px;
  min-width: 140px;
}
.hud-l { font-family: 'Space Mono', monospace; font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--amber); opacity: .8; }
.hud-v { font-family: 'Saira Condensed', sans-serif; font-weight: 600; font-size: 18px; margin-top: 4px; letter-spacing: .5px; }
.hud-cell.pulse { animation: hud-pulse 2s ease-in-out infinite; }
@keyframes hud-pulse {
  0%, 100% { border-color: rgba(216,57,47,.15); }
  50%       { border-color: rgba(216,57,47,.6); box-shadow: 0 0 20px rgba(216,57,47,.15); }
}
.live { display: inline-flex; align-items: center; gap: 8px; }

/* ---- Dossier ---- */
.dossier {
  background: var(--doc); color: #241f14;
  border-radius: 6px; padding: 28px 30px;
  box-shadow: var(--shadow);
  position: relative;
  border-left: 5px solid var(--red);
  background-image: repeating-linear-gradient(0deg, transparent 0 31px, rgba(36,31,20,.06) 31px 32px);
}
.dossier::before {
  content: "AKTE // SAALEFALKE";
  position: absolute; top: 12px; right: 16px;
  font-family: 'Special Elite', monospace; font-size: 10px; letter-spacing: 2px; color: #9a8f72;
}
.dossier p { font-family: 'Special Elite', monospace; font-size: 15px; line-height: 1.95; color: #2e2718; }
.dossier p + p { margin-top: 12px; }
.doc-label {
  display: inline-block;
  font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px;
  background: #241f14; color: var(--doc); padding: 3px 8px; border-radius: 3px;
  margin-bottom: 8px; text-transform: uppercase;
}

/* ---- Loop grid ---- */
.loop-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px,1fr)); gap: 12px; margin-top: 22px; }
.loop-step { background: var(--panel); border: 1px solid var(--line); border-radius: 12px; padding: 18px; }
.loop-n    { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; color: var(--amber); }
.loop-step h4 { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 17px; margin: 7px 0 5px; }
.loop-step p  { font-size: 14.5px; color: #bcb6a6; }

/* ---- Road / Stations ---- */
.road { position: relative; margin-top: 16px; padding-left: 54px; }
.road::before {
  content: ""; position: absolute; left: 20px; top: 8px; bottom: 8px; width: 2px;
  background: repeating-linear-gradient(180deg, var(--amber) 0 10px, transparent 10px 22px);
  opacity: .55;
}
.stn { position: relative; margin-bottom: 22px; }
.stn-dot {
  position: absolute; left: -42px; top: 4px;
  width: 36px; height: 36px; border-radius: 6px; transform: rotate(45deg);
  background: var(--panel); border: 2px solid var(--amber);
  display: grid; place-items: center;
  box-shadow: 0 0 0 4px var(--black);
}
.stn-dot span { transform: rotate(-45deg); font-family: 'Space Mono', monospace; font-weight: 700; font-size: 11px; color: var(--amber); }
.stn.finish .stn-dot { border-color: var(--red); background: var(--red); }
.stn.finish .stn-dot span { color: #fff; }
.stn.done .stn-dot { border-color: var(--green); background: rgba(61,184,122,.15); }
.stn.done .stn-dot span { color: var(--green); }

.case { background: var(--panel); border: 1px solid var(--line); border-radius: 10px; padding: 18px 20px; box-shadow: var(--shadow); }
.case-header { display: flex; justify-content: space-between; align-items: baseline; flex-wrap: wrap; gap: 6px; }
.case-place { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 22px; letter-spacing: .5px; }
.case-cf { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--steel); letter-spacing: 1px; }
.case-geo { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--amber); opacity: .85; margin-top: 2px; letter-spacing: 1px; }
.case-role { font-size: 15px; color: #c7c0b0; font-weight: 300; margin-top: 10px; }

/* ---- Badges ---- */
.badges { display: flex; flex-wrap: wrap; gap: 6px; margin: 10px 0; }
.badge {
  font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 1px;
  text-transform: uppercase; padding: 4px 8px; border-radius: 4px; border: 1px solid;
}
.b-far   { color: var(--amber); border-color: rgba(240,169,43,.4);   background: rgba(240,169,43,.07); }
.b-site  { color: var(--red);   border-color: rgba(216,57,47,.45);  background: rgba(216,57,47,.08); }
.b-done  { color: var(--green); border-color: rgba(61,184,122,.4); background: rgba(61,184,122,.07); }
.b-pending { color: var(--steel); border-color: rgba(127,147,166,.35); background: rgba(127,147,166,.07); }

/* ---- Puzzle Box ---- */
.puzzle-box {
  border-left: 3px solid var(--amber); padding: 9px 0 9px 14px;
  background: rgba(240,169,43,.06); border-radius: 0 6px 6px 0;
  margin-top: 10px;
}
.puzzle-t { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--amber); margin-bottom: 4px; }
.puzzle-box p { font-size: 14.5px; color: #cfc8b6; }

/* ---- Access Cards ---- */
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 680px) { .grid2 { grid-template-columns: 1fr; } }

.access-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 28px 24px; text-decoration: none; display: block;
  transition: .2s; color: var(--doc);
}
.access-card:hover { border-color: rgba(240,169,43,.4); background: var(--panel-2); text-decoration: none; transform: translateY(-2px); }
.access-card.access-agent:hover { border-color: rgba(216,57,47,.4); }
.access-icon { font-size: 32px; margin-bottom: 12px; }
.access-title { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 22px; letter-spacing: .5px; margin-bottom: 6px; }
.access-sub { font-size: 15px; color: var(--steel); font-weight: 300; }

/* ---- Login ---- */
.login-wrap { min-height: 70vh; display: flex; align-items: center; justify-content: center; padding: 40px 20px; }
.login-card { width: 100%; max-width: 420px; text-align: center; }
.login-icon { font-size: 40px; margin-bottom: 12px; }
.login-kicker { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 4px; text-transform: uppercase; color: var(--red); margin-bottom: 12px; }
.login-title { font-family: 'Saira Condensed', sans-serif; font-weight: 800; font-size: 56px; line-height: .9; text-transform: uppercase; margin-bottom: 12px; }
.login-sub { color: var(--steel); font-size: 15px; margin-bottom: 28px; }
.login-form { text-align: left; }
.login-back { margin-top: 20px; font-size: 14px; }

/* ---- Forms ---- */
.field-wrap { margin-bottom: 16px; }
.field-row  { display: flex; gap: 12px; }
.field-row .field-wrap { flex: 1; }
.field-label {
  display: block;
  font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--amber); opacity: .8;
  margin-bottom: 6px;
}
input[type="text"], input[type="password"], input[type="number"],
textarea, select {
  width: 100%;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--doc);
  font-family: 'Space Mono', monospace;
  font-size: 14px;
  padding: 10px 14px;
  outline: none;
  transition: .15s;
  -webkit-appearance: none;
}
input:focus, textarea:focus, select:focus {
  border-color: rgba(240,169,43,.5);
  box-shadow: 0 0 0 3px rgba(240,169,43,.1);
}
textarea { min-height: 100px; resize: vertical; }
select { cursor: pointer; }
input[type="file"] {
  background: var(--panel-2);
  border: 1px dashed rgba(240,169,43,.3);
  border-radius: 7px;
  color: var(--doc);
  font-family: 'Saira', sans-serif;
  font-size: 14px;
  padding: 12px;
  width: 100%;
  cursor: pointer;
}

/* ---- Buttons ---- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 10px 18px; border-radius: 8px; border: 1px solid;
  cursor: pointer; text-decoration: none; transition: .15s;
  white-space: nowrap;
}
.btn-primary { background: var(--amber); color: #0b0c0e; border-color: var(--amber); font-weight: 700; }
.btn-primary:hover { background: var(--amber-d); border-color: var(--amber-d); text-decoration: none; color: #0b0c0e; }
.btn-danger  { background: var(--red); color: #fff; border-color: var(--red); font-weight: 700; }
.btn-danger:hover { background: #b82e26; border-color: #b82e26; text-decoration: none; color: #fff; }
.btn-outline { background: transparent; color: var(--amber); border-color: rgba(240,169,43,.4); }
.btn-outline:hover { background: rgba(240,169,43,.08); text-decoration: none; color: var(--amber); }
.btn-ghost   { background: transparent; color: var(--steel); border-color: var(--line); }
.btn-ghost:hover { color: var(--doc); border-color: rgba(231,225,210,.3); text-decoration: none; }
.btn-done    { background: rgba(61,184,122,.12); color: var(--green); border-color: rgba(61,184,122,.35); }
.btn-xs      { padding: 4px 10px; font-size: 10px; }
.btn-full    { width: 100%; justify-content: center; }
.btn-large   { padding: 14px 24px; font-size: 14px; }

/* ---- Alerts ---- */
.alert-error {
  background: rgba(216,57,47,.12); border: 1px solid rgba(216,57,47,.4);
  border-radius: 8px; padding: 14px 18px; color: var(--doc);
  font-size: 15px; margin-bottom: 20px;
}

/* ---- Control Bar ---- */
.control-bar { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 24px; }

/* ---- Station Cards (HQ Dashboard) ---- */
.station-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 12px; margin-top: 16px; }
.station-card {
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  display: flex; flex-direction: column; align-items: stretch;
  overflow: hidden; transition: .15s;
}
.station-card:hover { border-color: rgba(240,169,43,.35); background: var(--panel-2); }
.station-card.done  { border-color: rgba(61,184,122,.25); }
.station-card.done:hover { border-color: rgba(61,184,122,.45); }
.station-card.type-final { border-color: rgba(216,57,47,.25); }
.scard-order {
  font-size: 11px; letter-spacing: 2px;
  color: var(--amber); background: rgba(240,169,43,.1); border: 1px solid rgba(240,169,43,.2);
  border-radius: 5px; padding: 4px 8px; white-space: nowrap; flex-shrink: 0;
  align-self: flex-start;
}
.station-card.done .scard-order { color: var(--green); background: rgba(61,184,122,.1); border-color: rgba(61,184,122,.2); }
.scard-inner {
  display: flex; flex-direction: row; align-items: flex-start; gap: 12px;
  padding: 16px; text-decoration: none; color: var(--doc);
  flex: 1; width: 100%; box-sizing: border-box;
}
.scard-inner:hover { text-decoration: none; color: var(--doc); }
.scard-content { flex: 1; min-width: 0; }
.scard-name { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 16px; line-height: 1.2; }
.scard-cf   { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--steel); margin-top: 3px; }
.scard-fragment { font-size: 12px; margin-top: 6px; }
.scard-footer {
  display: flex; flex-direction: row; align-items: center;
  justify-content: space-between; flex-wrap: wrap; gap: 6px;
  padding: 8px 14px; width: 100%;
  border-top: 1px solid var(--line);
  background: rgba(0,0,0,.15);
}
.scard-status  { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.scard-actions { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

/* ---- Panel ---- */
.panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 22px; box-shadow: var(--shadow);
}
.panel h3 {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase;
  font-size: 20px; letter-spacing: .5px; margin-bottom: 10px;
}

/* ---- Photo Strip ---- */
.photo-strip { display: flex; gap: 10px; overflow-x: auto; padding-bottom: 8px; margin-top: 12px; }
.photo-thumb {
  flex: 0 0 100px; height: 80px; border-radius: 7px; overflow: hidden;
  position: relative; border: 2px solid transparent; transition: .15s;
}
.photo-thumb:hover { border-color: var(--amber); }
.photo-thumb.verified { border-color: var(--green); }
.photo-thumb img { width: 100%; height: 100%; object-fit: cover; }
.photo-thumb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(transparent 40%, rgba(0,0,0,.75));
  display: flex; align-items: flex-end; justify-content: space-between;
  padding: 4px 6px; font-size: 10px;
}
.verified-badge   { color: var(--green); font-weight: 700; }
.unverified-badge { color: var(--amber); font-weight: 700; }
.photo-more {
  flex: 0 0 auto; display: flex; align-items: center;
  font-family: 'Space Mono', monospace; font-size: 11px; color: var(--steel); padding: 0 8px;
  text-decoration: none; white-space: nowrap;
}
.photo-more:hover { color: var(--amber); }

/* ---- Photo Gallery ---- */
.photo-gallery { display: grid; grid-template-columns: repeat(auto-fill, minmax(160px,1fr)); gap: 12px; margin-top: 10px; }
.gallery-item { border-radius: 8px; overflow: hidden; border: 2px solid var(--line); background: var(--panel-2); }
.gallery-item.verified { border-color: rgba(61,184,122,.4); }
.gallery-item img { width: 100%; height: 120px; object-fit: cover; display: block; }
.gallery-meta { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; padding: 8px 10px; font-size: 12px; color: var(--steel); }
.gallery-item .btn { margin: 0 8px 8px; }
.photos-full .photo-section { margin-bottom: 32px; }

/* ---- Messages ---- */
.message-list { display: flex; flex-direction: column; gap: 10px; }
.message-list.scrollable { max-height: 400px; overflow-y: auto; }
.msg-item {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px; padding: 12px 14px;
}
.msg-item.sender-hq { border-left: 3px solid var(--amber); }
.msg-item.sender-agent { border-left: 3px solid var(--steel); }
.msg-meta { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; flex-wrap: wrap; }
.msg-content { font-size: 15px; line-height: 1.6; }
.msg-encoded { font-size: 13px; color: var(--amber); background: rgba(240,169,43,.06); padding: 8px 10px; border-radius: 5px; margin-top: 6px; word-break: break-all; }
.msg-decoded { font-size: 15px; color: var(--doc); background: rgba(61,184,122,.06); border: 1px solid rgba(61,184,122,.2); padding: 8px 10px; border-radius: 5px; margin-top: 6px; }
.decode-btn { margin-top: 8px; }

/* ---- Encode Preview ---- */
.encode-preview {
  background: rgba(240,169,43,.06); border: 1px solid rgba(240,169,43,.25);
  border-radius: 8px; padding: 12px 14px; margin-top: 12px;
}
.preview-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--amber); margin-bottom: 6px; }
.preview-text  { font-size: 14px; color: var(--amber); word-break: break-all; line-height: 1.6; }

/* ---- Timer ---- */
.big-timer-wrap {
  text-align: center; padding: 28px 20px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  margin-bottom: 24px;
}
.big-timer-label { font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--steel); margin-bottom: 8px; }
.big-timer { font-size: clamp(40px,12vw,80px); letter-spacing: 4px; color: var(--amber); line-height: 1; }
.timer-bar { height: 3px; background: var(--line); border-radius: 2px; margin-top: 14px; overflow: hidden; }
.timer-bar-fill { height: 100%; background: var(--amber); transition: width 1s linear; border-radius: 2px; }

/* ---- Status Banners ---- */
.status-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 18px; border-radius: 10px;
  border: 1px solid var(--line); margin-bottom: 20px;
  font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 1.5px;
  text-transform: uppercase; color: var(--steel);
}
.status-banner.status-success { border-color: rgba(61,184,122,.4); color: var(--green); background: rgba(61,184,122,.06); }
.status-banner.status-danger  { border-color: rgba(216,57,47,.4); color: var(--red); background: rgba(216,57,47,.06); }

/* ---- Notification Banner ---- */
.notif-banner {
  display: flex; align-items: center; gap: 10px;
  background: rgba(240,169,43,.08); border: 1px solid rgba(240,169,43,.35);
  border-radius: 10px; padding: 12px 18px; margin-bottom: 20px;
  text-decoration: none; color: var(--doc); transition: .15s;
}
.notif-banner:hover { background: rgba(240,169,43,.14); text-decoration: none; }
.notif-banner .arrow { margin-left: auto; color: var(--amber); }

/* ---- Progress ---- */
.progress-section { margin-bottom: 20px; }
.progress-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--steel); margin-bottom: 6px; }
.progress-bar  { height: 4px; background: var(--line); border-radius: 2px; overflow: hidden; }
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--amber), var(--red)); border-radius: 2px; transition: width .6s; }

/* ---- Current Station (Agent) ---- */
.current-station { margin-bottom: 24px; }
.current-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--red); margin-bottom: 8px; }
.current-card {
  background: var(--panel); border: 1px solid rgba(240,169,43,.3); border-radius: 12px;
  padding: 18px 20px; display: flex; align-items: center; gap: 16px;
  text-decoration: none; color: var(--doc); transition: .15s;
}
.current-card:hover { background: var(--panel-2); border-color: rgba(240,169,43,.5); text-decoration: none; }
.current-order { font-size: 22px; letter-spacing: 2px; }
.current-info  { flex: 1; }
.current-name  { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 20px; }
.current-cf    { font-size: 11px; color: var(--steel); margin-top: 2px; }
.current-loc   { font-size: 11px; color: var(--steel); margin-top: 2px; }
.current-arrow { color: var(--amber); font-size: 20px; }

/* ---- Agent Stations List ---- */
.agent-stations { display: flex; flex-direction: column; gap: 8px; }
.agent-stn {
  display: flex; align-items: center; gap: 14px;
  background: var(--panel); border: 1px solid var(--line); border-radius: 10px;
  padding: 12px 16px; text-decoration: none; color: var(--doc); transition: .15s;
}
.agent-stn:hover { border-color: rgba(240,169,43,.3); text-decoration: none; }
.agent-stn.done  { opacity: .65; }
.agent-stn.done:hover { opacity: .85; }
.agent-stn.current { border-color: rgba(240,169,43,.45); background: var(--panel-2); }
.astn-order { font-family: 'Space Mono', monospace; font-size: 11px; color: var(--amber); min-width: 28px; }
.astn-info  { flex: 1; }
.astn-name  { font-family: 'Saira Condensed', sans-serif; font-weight: 700; text-transform: uppercase; font-size: 17px; }
.astn-fragment { font-size: 12px; color: var(--steel); margin-top: 2px; }
.astn-icon  { color: var(--amber); font-size: 16px; }
.agent-stn.done .astn-icon { color: var(--green); }

/* ---- Fragments ---- */
.fragments-panel {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 20px; margin-top: 24px;
}
.fragments-row { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.fragment-box  {
  background: var(--panel-2); border: 1px solid var(--line); border-radius: 8px;
  padding: 12px 16px; min-width: 64px; text-align: center;
}
.fragment-box.filled { border-color: rgba(240,169,43,.4); }
.frag-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--steel); margin-bottom: 4px; }
.frag-val   { font-size: 24px; letter-spacing: 2px; }
.fragment-reveal { margin-top: 14px; }
.fragment-val { font-size: 28px; color: var(--amber); letter-spacing: 3px; }
.fragment-val.redacted { color: var(--steel); }
.assembled-code { margin-top: 12px; font-size: 15px; }

/* ---- Fragment Reveal (Agent Station) ---- */
.fragment-reveal-agent {
  text-align: center;
  background: rgba(240,169,43,.08); border: 2px solid rgba(240,169,43,.4);
  border-radius: 12px; padding: 20px;
  margin-bottom: 24px;
}
.frag-reveal-label { font-family: 'Space Mono', monospace; font-size: 10px; letter-spacing: 3px; text-transform: uppercase; color: var(--amber); margin-bottom: 8px; }
.frag-reveal-val   { font-family: 'Space Mono', monospace; font-size: 48px; color: var(--amber); letter-spacing: 8px; line-height: 1; }

/* ---- Upload Section ---- */
.upload-section {
  background: var(--panel); border: 1px solid var(--line); border-radius: 12px;
  padding: 20px; margin-top: 24px;
}

/* ---- Deactivation Screen ---- */
.deact-screen {
  min-height: 80vh; display: flex; flex-direction: column;
  align-items: center; justify-content: center; text-align: center;
  padding: 40px 24px;
}
.deact-screen.success { color: var(--green); }
.deact-icon  { font-size: 72px; margin-bottom: 16px; opacity: 0; transform: scale(.5); transition: .6s cubic-bezier(.2,.7,.2,1); }
.deact-kicker { font-family: 'Space Mono', monospace; font-size: 12px; letter-spacing: 5px; text-transform: uppercase; opacity: 0; transition: .6s .2s; }
.deact-title  {
  font-family: 'Saira Condensed', sans-serif; font-weight: 800; font-size: 80px;
  line-height: .9; text-transform: uppercase; letter-spacing: 2px;
  opacity: 0; transform: translateY(20px); transition: .6s .3s;
}
.deact-sub { max-width: 500px; margin-top: 16px; color: #d8d2c2; font-size: 18px; opacity: 0; transition: .6s .5s; }
.success-details { font-size: 13px; margin-top: 24px; color: rgba(61,184,122,.7); line-height: 2; opacity: 0; transition: .6s .7s; }
.deact-screen.animate-in .deact-icon,
.deact-screen.animate-in .deact-kicker,
.deact-screen.animate-in .deact-title,
.deact-screen.animate-in .deact-sub,
.deact-screen.animate-in .success-details { opacity: 1; transform: none; }
.deact-form-wrap {
  background: var(--panel); border: 1px solid rgba(216,57,47,.35); border-radius: 12px;
  padding: 24px;
}
.code-input-wrap input {
  font-size: 28px; text-align: center; letter-spacing: 10px;
  font-weight: 700; color: var(--amber);
}

/* ---- Empty State ---- */
.empty-state { text-align: center; padding: 60px 24px; }
.empty-icon  { font-size: 48px; margin-bottom: 16px; opacity: .5; }

/* ---- Back Link ---- */
.back-link { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px; color: var(--steel); text-decoration: none; display: inline-block; margin-bottom: 20px; }
.back-link:hover { color: var(--amber); text-decoration: none; }

/* ---- Footer ---- */
.site-footer {
  padding: 32px 0 48px; border-top: 1px solid var(--line);
  font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 2px;
  text-transform: uppercase; color: var(--steel); text-align: center;
  margin-top: 60px;
}

/* ---- Scroll Reveal ---- */
.rv { opacity: 0; transform: translateY(20px); transition: .7s cubic-bezier(.2,.7,.2,1); }
.rv.in { opacity: 1; transform: none; }

/* ---- Responsive ---- */
@media (max-width: 680px) {
  .hero-title { font-size: 52px; }
  .stamp { top: 50px; right: 12px; font-size: 11px; }
  .loop-grid { grid-template-columns: 1fr; }
  .field-row { flex-direction: column; }
  .station-grid { grid-template-columns: 1fr; }
  .big-timer { font-size: 52px; }
}

/* ---- Agent body tweaks (mobile-first) ---- */
.agent-body { font-size: 16px; }
.agent-body .page-title { font-size: clamp(36px,8vw,56px); }

/* ---- New Badges ---- */
.b-locked { color: var(--steel); border-color: rgba(127,147,166,.2); background: rgba(127,147,166,.05); }
.b-danger  { color: var(--red);   border-color: rgba(216,57,47,.4);  background: rgba(216,57,47,.08); }

/* ---- Alerts ---- */
.alert-ok {
  background: rgba(61,184,122,.1); border: 1px solid rgba(61,184,122,.35);
  border-radius: 8px; padding: 12px 16px; color: var(--green); font-size: 14px;
}
.field-hint { font-size: 11px; color: var(--steel); margin-top: 4px; }

/* ---- Amber dot ---- */
.dot.amber { background: var(--amber); box-shadow: 0 0 8px var(--amber); animation: blink 1.1s steps(2) infinite; }

/* ---- HQ Approval Queue ---- */
.approval-card {
  background: rgba(240,169,43,.05); border: 1px solid rgba(240,169,43,.3);
  border-radius: 12px; padding: 16px; display: flex; align-items: flex-start;
  gap: 16px; margin-bottom: 12px; flex-wrap: wrap;
}
.approval-thumb {
  flex: 0 0 90px; height: 90px; border-radius: 8px; overflow: hidden;
  display: block; border: 1px solid rgba(240,169,43,.25);
}
.approval-thumb img { width: 100%; height: 100%; object-fit: cover; }
.approval-info { flex: 1; min-width: 120px; }
.approval-station {
  font-family: 'Saira Condensed', sans-serif; font-weight: 700;
  font-size: 18px; text-transform: uppercase; margin-bottom: 2px;
}
.approval-actions { display: flex; flex-direction: column; gap: 8px; justify-content: center; }
@media (max-width: 480px) { .approval-actions { flex-direction: row; width: 100%; } }

/* ---- Photo status on gallery items ---- */
.gallery-item.status-approved { border-color: rgba(61,184,122,.4); }
.gallery-item.status-rejected  { border-color: rgba(216,57,47,.35); opacity: .7; }
.photo-card.status-approved { border-color: rgba(61,184,122,.4); }
.photo-card.status-rejected  { border-color: rgba(216,57,47,.35); opacity: .7; }

/* ---- Photo Card (HQ Station) ---- */
.photo-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(140px,1fr)); gap: 12px; }
.photo-card {
  border-radius: 8px; overflow: hidden; border: 2px solid var(--line);
  background: var(--panel-2);
}
.photo-card img { width: 100%; height: 110px; object-fit: cover; display: block; }
.photo-meta { display: flex; flex-direction: column; gap: 3px; padding: 8px 10px; font-size: 12px; color: var(--steel); }

/* ---- Agent Mobile Layout ---- */
.agent-wrap {
  max-width: 480px; margin: 0 auto;
  padding: 0 16px 80px; min-height: 100vh;
}
.agent-topbar {
  padding: 16px 0 10px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 16px;
}
.agent-timer-row {
  display: flex; align-items: baseline;
  justify-content: space-between; margin-bottom: 4px;
}
.agent-timer-label { font-size: 9px; letter-spacing: 2px; text-transform: uppercase; color: var(--steel); }
.agent-timer-val   { font-size: 28px; color: var(--amber); letter-spacing: 3px; font-family: 'Space Mono', monospace; }

/* ---- Progress Dots ---- */
.agent-progress-row { display: flex; align-items: center; gap: 6px; margin-top: 10px; }
.prog-dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: rgba(127,147,166,.15); border: 1px solid rgba(127,147,166,.25);
  transition: .3s;
}
.prog-dot.done   { background: var(--green); border-color: var(--green); box-shadow: 0 0 5px var(--green); }
.prog-dot.active { background: var(--amber); border-color: var(--amber); box-shadow: 0 0 5px var(--amber); animation: blink 1.1s steps(2) infinite; }
.prog-label { font-size: 10px; color: var(--steel); margin-left: 6px; font-family: 'Space Mono', monospace; letter-spacing: 1px; }

/* ---- Agent State Cards ---- */
.agent-main { padding: 8px 0; }
.agent-state-card {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 16px; padding: 32px 24px; text-align: center; margin: 8px 0;
}
.agent-state-card.waiting { border-color: rgba(240,169,43,.3); background: rgba(240,169,43,.04); }
.agent-state-card.success  { border-color: rgba(61,184,122,.35); background: rgba(61,184,122,.05); }
.agent-state-card.danger   { border-color: rgba(216,57,47,.35); background: rgba(216,57,47,.05); }
.state-icon  { font-size: 48px; margin-bottom: 12px; display: block; }
.state-title {
  font-family: 'Saira Condensed', sans-serif; font-weight: 800;
  font-size: 26px; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 8px;
}
.state-desc { color: var(--steel); font-size: 15px; font-weight: 300; line-height: 1.6; }

/* ---- Waiting Animation ---- */
.waiting-pulse { animation: waiting-fade 1.6s ease-in-out infinite; }
@keyframes waiting-fade { 0%, 100% { opacity: 1; } 50% { opacity: .3; } }
.waiting-photo { margin: 16px auto 0; max-width: 240px; }
.waiting-photo img { width: 100%; border-radius: 8px; border: 2px solid rgba(240,169,43,.3); }
.waiting-meta { font-size: 11px; color: var(--steel); margin-top: 6px; text-align: center; font-family: 'Space Mono', monospace; }

/* ---- Current Station Card (Agent, big) ---- */
.current-station-card {
  background: var(--panel); border: 2px solid rgba(240,169,43,.4);
  border-radius: 16px; padding: 28px 24px; text-align: center; margin: 8px 0;
}
.cs-order { font-family: 'Space Mono', monospace; font-size: 11px; letter-spacing: 3px; color: var(--amber); margin-bottom: 4px; }
.cs-cf    { font-family: 'Space Mono', monospace; font-size: 10px; color: var(--steel); letter-spacing: 2px; margin-bottom: 12px; }
.cs-name  {
  font-family: 'Saira Condensed', sans-serif; font-weight: 800;
  font-size: clamp(26px, 7vw, 38px); text-transform: uppercase; line-height: 1; margin-bottom: 8px;
}
.cs-loc { font-size: 13px; color: var(--steel); margin-bottom: 4px; font-family: 'Space Mono', monospace; }

/* ---- Fragment Chips ---- */
.frag-row  { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; margin: 8px 0; }
.frag-chip {
  background: rgba(240,169,43,.1); border: 1px solid rgba(240,169,43,.35);
  border-radius: 8px; padding: 8px 14px;
  font-size: 22px; letter-spacing: 3px; font-family: 'Space Mono', monospace;
}
.agent-fragments {
  background: var(--panel); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px; margin-top: 24px; text-align: center;
}

/* ---- Extra-Large Button ---- */
.btn-xl { padding: 16px 24px; font-size: 14px; letter-spacing: 2px; }
