@import url('https://fonts.googleapis.com/css2?family=Share+Tech+Mono&display=swap');
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --g:#33ff33;--gdim:#1a5c1a;--ghi:#afffaf;
  --amb:#ffb833;--red:#ff4040;--blue:#33aaff;
  --bg:#050505;--panel:#0a0f0a;--border:#1a3a1a;
}
html,body{width:100%;height:100%;background:var(--bg);color:var(--g);
  font-family:'Share Tech Mono','Courier New',monospace;
  font-size:clamp(10px,1.3vw,13px);overflow:hidden;user-select:none;}
body::before{content:'';position:fixed;inset:0;
  background:repeating-linear-gradient(to bottom,transparent 0px,transparent 3px,rgba(0,0,0,0.08) 3px,rgba(0,0,0,0.08) 4px);
  pointer-events:none;z-index:900;}
body::after{content:'';position:fixed;inset:0;
  background:radial-gradient(ellipse at center,transparent 50%,rgba(0,0,0,0.72) 100%);
  pointer-events:none;z-index:899;}
#layout{width:100%;height:100%;display:grid;grid-template-rows:58% 42%;animation:crtFlicker 14s infinite;}
#topRow{display:grid;grid-template-columns:63% 37%;border-bottom:1px solid var(--border);min-height:0;}
#camPanel{position:relative;background:var(--bg);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
#camFrame{flex:1;position:relative;display:flex;align-items:center;justify-content:center;background:#000;overflow:hidden;}
#camFrame::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(to bottom,transparent 0px,transparent 2px,rgba(0,0,0,0.22) 2px,rgba(0,0,0,0.22) 3px);pointer-events:none;z-index:30;}
#camFrame::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 45%,rgba(0,0,0,0.65) 100%);pointer-events:none;z-index:31;}
#camFeed{width:100%;height:100%;object-fit:cover;display:none;
  filter:grayscale(1) brightness(0.82) contrast(1.18) sepia(0.5) hue-rotate(76deg) saturate(1.6);}
#camFeed.active{display:block;}
#camFeed.degraded{filter:grayscale(1) brightness(0.65) contrast(1.3) sepia(0.4) hue-rotate(76deg) saturate(1.4);
  animation:camFlicker 0.11s steps(1) infinite,degradeTear 4.8s ease-in-out infinite;}
#camFeed.surge{filter:grayscale(1) brightness(1.8) contrast(3) sepia(0.2) hue-rotate(76deg) saturate(2);
  animation:surgeFlicker 0.08s steps(1) infinite;}
#camNoFeed{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;color:var(--gdim);letter-spacing:0.12em;z-index:5;}
#camNoFeed .nf-box{border:1px solid var(--gdim);padding:18px 32px;text-align:center;}
#camNoFeed.hidden{display:none;}
#camHUD{position:absolute;inset:0;pointer-events:none;z-index:32;display:flex;flex-direction:column;justify-content:space-between;padding:6px 10px;font-size:clamp(8px,0.95vw,11px);letter-spacing:0.07em;color:var(--g);text-shadow:0 0 5px var(--g);opacity:0;transition:opacity 0.3s;}
#camHUD.active{opacity:1;}
.hud-row{display:flex;justify-content:space-between;align-items:center;}
#hudRec{color:var(--red);animation:blink 1.6s step-end infinite;}
#hudSig.weak{color:var(--amb);}
#hudSig.lost{color:var(--red);}
#hudAlert{color:var(--amb);text-shadow:0 0 6px var(--amb);animation:blink 0.65s step-end infinite;letter-spacing:0.14em;opacity:0;}
#hudAlert.show{opacity:1;}
#camFrame.signal-loss #camFeed{animation:signalLoss 0.75s ease-in forwards !important;}
#camAcquire{position:absolute;inset:0;display:none;align-items:center;justify-content:center;background:#000;z-index:20;color:var(--g);letter-spacing:0.14em;text-shadow:0 0 8px var(--g);animation:blink 0.85s step-end infinite;}
#camAcquire.active{display:flex;}
#camLabel{flex-shrink:0;background:var(--panel);border-bottom:1px solid var(--border);padding:3px 10px;font-size:clamp(8px,0.9vw,10px);letter-spacing:0.1em;color:var(--gdim);display:flex;justify-content:space-between;}
#camBar{flex-shrink:0;background:var(--panel);border-top:1px solid var(--border);padding:3px 8px;display:flex;gap:6px;flex-wrap:wrap;font-size:clamp(7px,0.85vw,10px);letter-spacing:0.06em;min-height:22px;}
.cam-btn{color:var(--gdim);padding:1px 4px;border:1px solid transparent; cursor:pointer;}
.cam-btn.online{color:var(--g);}
.cam-btn.active{color:var(--ghi);border-color:var(--g);text-shadow:0 0 6px var(--g);}
.cam-btn.offline{color:var(--red);}
#commsPanel{background:var(--panel);display:flex;flex-direction:column;overflow:hidden;}
#commsLabel{flex-shrink:0;border-bottom:1px solid var(--border);padding:3px 10px;font-size:clamp(8px,0.9vw,10px);letter-spacing:0.1em;color:var(--gdim);display:flex;justify-content:space-between;}
#commsBody{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;padding:8px 10px;display:flex;flex-direction:column;gap:8px;}
#commsBody::-webkit-scrollbar{display:none;}
#phoneDisplay,#tapeDisplay{border:1px solid var(--border);padding:8px 10px;}
.comm-title{color:var(--gdim);font-size:0.85em;letter-spacing:0.1em;margin-bottom:5px;}
#phoneNumber{font-size:1.35em;letter-spacing:0.18em;color:var(--ghi);text-shadow:0 0 8px var(--g);min-height:1.4em;}
#phoneStatus{font-size:0.85em;letter-spacing:0.1em;margin-top:3px;min-height:1em;}
#phoneStatus.ringing{color:var(--amb);animation:blink 1s step-end infinite;}
#phoneStatus.connected{color:var(--g);}
#phoneStatus.dead{color:var(--red);}
#tapeName{color:var(--ghi);letter-spacing:0.07em;min-height:1em;font-size:0.92em;}
#tapeStatus{font-size:0.82em;color:var(--gdim);margin-top:3px;min-height:1em;}
#tapeBar{margin-top:5px;height:2px;background:var(--gdim);width:0%;transition:width 0.5s linear;}
#transcript{border:1px solid var(--border);padding:8px 10px;flex:1;font-size:0.88em;line-height:1.55;color:var(--gdim);overflow-y:auto;scrollbar-width:none;min-height:50px;}
#transcript::-webkit-scrollbar{display:none;}
#transcript.active{color:var(--g);}
#commsHelp{font-size:0.8em;color:var(--gdim);letter-spacing:0.05em;line-height:1.7;border-top:1px solid var(--border);padding:5px 10px;flex-shrink:0;}
#termPanel{background:var(--bg);border-top:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;}
#termLabel{flex-shrink:0;border-bottom:1px solid var(--border);padding:2px 10px;font-size:clamp(7px,0.85vw,9px);letter-spacing:0.1em;color:var(--gdim);display:flex;justify-content:space-between;}
#termOutput{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:var(--gdim) transparent;padding:4px 10px 2px;}
.ln{line-height:1.58;letter-spacing:0.022em;white-space:pre-wrap;word-break:break-word;text-shadow:0 0 3px rgba(51,255,51,0.18);}
.dim{color:var(--gdim);text-shadow:none;}.hi{color:var(--ghi);text-shadow:0 0 6px rgba(51,255,51,0.45);}
.warn{color:var(--amb);text-shadow:0 0 4px rgba(255,184,51,0.35);}.err{color:var(--red);text-shadow:0 0 4px rgba(255,64,64,0.35);}
.echo{color:var(--ghi);}.sys{color:var(--blue);text-shadow:0 0 4px rgba(51,170,255,0.35);}
#termInputRow{flex-shrink:0;display:flex;align-items:center;padding:2px 10px 4px;border-top:1px solid var(--border);opacity:0;pointer-events:none;min-height:22px;}
#termInputRow.on{opacity:1;pointer-events:auto;}
#termPrompt{white-space:pre;}.cur{display:inline-block;width:0.55em;height:0.92em;background:var(--g);box-shadow:0 0 5px var(--g),0 0 12px rgba(51,255,51,0.35);margin-left:1px;vertical-align:middle;position:relative;top:-1px;animation:blink 1.1s step-end infinite;}
#termTyped{white-space:pre;min-width:1px;}
/* #ghost{position:fixed;opacity:0;width:1px;height:1px;top:-400px;border:none;outline:none;font-size:1px;pointer-events:none;} */
#ghost {
  position: fixed;
  opacity: 0;
  width: 10px;
  height: 10px;
  left: -100px;
  border: none;
  outline: none;
  font-size: 16px; /* CRITICAL: Prevents iOS Safari from auto-zooming */
  pointer-events: none;
}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
@keyframes crtFlicker{0%,100%{opacity:1}91%{opacity:1}91.3%{opacity:.80}91.7%{opacity:1}96.8%{opacity:1}97.1%{opacity:.87}97.4%{opacity:1}}
@keyframes camFlicker{0%{opacity:1}50%{opacity:0.88}100%{opacity:1}}
@keyframes surgeFlicker{0%{opacity:1}33%{opacity:0.6}66%{opacity:1}100%{opacity:0.7}}
@keyframes degradeTear{0%,100%{transform:translateX(0) scaleY(1);}93%{transform:translateX(0) scaleY(1);}93.4%{transform:translateX(-4px) scaleY(1.007);}93.8%{transform:translateX(3px) scaleY(0.994);}94.2%{transform:translateX(0) scaleY(1);}}
@keyframes signalLoss{0%{opacity:1;transform:none;}15%{opacity:1;transform:translateY(-4px) scaleX(1.02);filter:grayscale(1) brightness(2.5) contrast(4) sepia(0) saturate(0);}35%{opacity:1;transform:translateY(3px);filter:grayscale(1) brightness(0.04) contrast(8);}60%{opacity:0.6;transform:translateX(-3px);filter:grayscale(1) brightness(1.3) contrast(2) sepia(0.5) hue-rotate(76deg) saturate(2);}85%{opacity:0.3;filter:grayscale(1) brightness(0.08) contrast(5);}100%{opacity:0;filter:grayscale(1) brightness(0);}}

/* ── INTRO OVERLAY ── */
#introOverlay{
  position:fixed;inset:0;background:#000;z-index:999;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:40px;
}
#introOverlay.done{display:none;}
#introText{
  max-width:560px;width:100%;
  font-family:'Share Tech Mono','Courier New',monospace;
  font-size:clamp(10px,1.3vw,13px);
  color:var(--gdim);
  line-height:2.0;
  letter-spacing:0.06em;
}
#introText .il{display:block;opacity:0;transition:opacity 0.4s;}
#introText .il.vis{opacity:1;}
#introText .il.hi{color:var(--g);text-shadow:0 0 6px var(--g);}
#introText .il.warn{color:var(--amb);}
#introText .il.err{color:var(--red);}
#introContinue{
  max-width:560px;width:100%;margin-top:28px;
  font-family:'Share Tech Mono','Courier New',monospace;
  font-size:clamp(9px,1.1vw,11px);
  color:var(--gdim);letter-spacing:0.1em;
  opacity:0;transition:opacity 0.5s;
  animation:blink 1.4s step-end infinite;
}
#introContinue.vis{opacity:1;}

/* ── SITE INTEGRITY PANEL ── */
#integrityPanel{
  border:1px solid var(--border);
  padding:7px 10px;
  font-size:clamp(8px,0.9vw,10px);
  letter-spacing:0.06em;
}
.int-title{color:var(--gdim);margin-bottom:5px;letter-spacing:0.1em;}
.int-row{
  display:flex;align-items:center;
  gap:6px;margin-bottom:3px;
  font-size:0.9em;
}
.int-label{color:var(--gdim);width:52px;flex-shrink:0;}
.int-bar-track{
  flex:1;height:6px;background:var(--gdim);
  position:relative;overflow:hidden;
}
.int-bar-fill{
  position:absolute;left:0;top:0;height:100%;
  background:var(--g);width:0%;
  transition:width 1.2s ease,background 0.8s ease;
}
.int-bar-fill.amber{background:var(--amb);}
.int-bar-fill.red{background:var(--red);}
.int-val{color:var(--gdim);width:18px;text-align:right;flex-shrink:0;}
.int-val.warn{color:var(--amb);}
.int-val.err{color:var(--red);}
#ewRow{display:none;}
#ewRow.show{display:flex;}
