
/* =========================================================
   ZOMZILLA.COM — GLOBAL EVENT ARCHIVE (MVP)
   Mobile-first • cinematic • gesture-native
   ========================================================= */

:root{
  --bg:#07080a;
  --bg2:#0b0c10;
  --fg:#e9f0ea;
  --muted:#a7b1aa;
  --line:rgba(255,255,255,.10);

  --green:#9BFF3D;        /* contamination */
  --greenDim:#6fd51f;
  --violet:#7a4cff;       /* plasma */
  --indigo:#22133f;
  --danger:#ff4c4c;

  --shadow: rgba(0,0,0,.55);

  --radius:18px;
  --radius2:26px;

  --max: 1040px;

  --tiltX: 0px;
  --tiltY: 0px;

  --safeTop: env(safe-area-inset-top, 0px);
  --safeBottom: env(safe-area-inset-bottom, 0px);
}

/* Reset */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  background: radial-gradient(1200px 900px at 50% 10%, rgba(122,76,255,.11), transparent 55%),
              radial-gradient(1200px 900px at 50% 80%, rgba(155,255,61,.10), transparent 55%),
              var(--bg);
  color:var(--fg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  letter-spacing:.2px;
  overflow-x:hidden;
}

a{color:inherit}
button, input{font:inherit}
img{max-width:100%; height:auto; display:block}

.skip{
  position:absolute; left:-999px; top:0;
  background:#000; color:#fff;
  padding:10px 12px; border-radius:10px;
  z-index:9999;
}
.skip:focus{left:12px; top:12px}

.no-js .gate{display:none}

/* Persistent film look */
.fx-grain, .fx-scanlines{
  position:fixed; inset:0;
  pointer-events:none;
  z-index:40;
}
.fx-grain{
  opacity:.10;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.18) 0 1px, transparent 2px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.12) 0 1px, transparent 2px),
    radial-gradient(circle at 30% 80%, rgba(255,255,255,.10) 0 1px, transparent 2px);
  background-size: 220px 220px, 300px 300px, 260px 260px;
  mix-blend-mode: overlay;
  filter: blur(.4px);
  animation: grainDrift 7s linear infinite;
}
@keyframes grainDrift{0%{transform:translate3d(0,0,0)} 100%{transform:translate3d(-24px, 18px, 0)}}
.fx-scanlines{
  opacity:.14;
  background: repeating-linear-gradient(
    to bottom,
    rgba(0,0,0,.0) 0px,
    rgba(0,0,0,.0) 2px,
    rgba(0,0,0,.55) 3px
  );
  mix-blend-mode: multiply;
}

/* Topbar */
.topbar{
  position:fixed;
  top:0; left:0; right:0;
  padding: calc(10px + var(--safeTop)) 12px 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  z-index:60;
  background: linear-gradient(to bottom, rgba(7,8,10,.85), rgba(7,8,10,.35), transparent);
  backdrop-filter: blur(10px);
}
.topbar__left, .topbar__right{display:flex; align-items:center; gap:10px}
.brand img{
  height:36px; width:auto;
  filter: drop-shadow(0 10px 20px rgba(0,0,0,.35));
}

.ghost{
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color:var(--fg);
  padding:10px 12px;
  border-radius: 999px;
  letter-spacing:.7px;
  text-transform: uppercase;
  font-size:12px;
}
.ghost:active{transform: translateY(1px)}
.ghost--dots{min-width:52px}

.chip{
  display:flex; align-items:center; gap:8px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.24);
  border-radius: 999px;
  padding:8px 10px;
  user-select:none;
}
.chip__label{
  font-size:11px;
  letter-spacing:1px;
  color:var(--muted);
  text-transform:uppercase;
}
.chip__value{
  font-family: "Space Mono", ui-monospace, Menlo, Consolas, monospace;
  font-size:12px;
  color:var(--green);
}

/* Nav panel */
.navpanel{
  position:fixed; inset:0;
  display:none;
  z-index:80;
  background: rgba(0,0,0,.60);
  backdrop-filter: blur(10px);
}
.navpanel.is-open{display:block}
.navpanel__inner{
  position:absolute;
  right:12px;
  top: calc(58px + var(--safeTop));
  width:min(360px, calc(100vw - 24px));
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.14);
  background: rgba(8,9,12,.92);
  box-shadow: 0 30px 80px rgba(0,0,0,.65);
  padding: 14px;
}
.navpanel__title{
  font-family: "Space Mono", ui-monospace, Menlo, Consolas, monospace;
  color: var(--muted);
  font-size:12px;
  letter-spacing:1px;
  margin-bottom:10px;
}
.navpanel__link{
  display:block;
  padding:12px 10px;
  border-radius: 12px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.15);
  margin-bottom:10px;
  font-family: "Space Mono", ui-monospace, Menlo, Consolas, monospace;
}
.navpanel__link:hover{border-color: rgba(155,255,61,.35)}
.navpanel__close{
  width:100%;
  border-radius: 12px;
  padding:12px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(155,255,61,.12);
  color: var(--fg);
}

/* Gate overlay */
.gate{
  position:fixed; inset:0;
  z-index:120;
  background:
    radial-gradient(900px 700px at 50% 30%, rgba(122,76,255,.14), transparent 55%),
    radial-gradient(900px 700px at 50% 70%, rgba(155,255,61,.10), transparent 55%),
    #000;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
}
.gate__inner{
  width:min(640px, calc(100vw - 24px));
  padding: 22px;
}
.gate__label{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  letter-spacing:2px;
  color: var(--muted);
  font-size:12px;
}
.gate__title{
  font-family: Antonio, Impact, Haettenschweiler, 'Arial Narrow Bold', sans-serif;
  font-size: clamp(40px, 10vw, 86px);
  letter-spacing: 2px;
  margin: 12px 0 10px;
  color: var(--fg);
  text-shadow: 0 0 40px rgba(155,255,61,.10);
}
.gate__sub{
  color: var(--muted);
  font-size: 14px;
  line-height:1.5;
  margin-bottom: 18px;
}
.gate__btn{
  border:1px solid rgba(255,255,255,.18);
  background: rgba(155,255,61,.12);
  color: var(--fg);
  padding: 14px 16px;
  width: min(360px, 100%);
  border-radius: 14px;
  font-family: Antonio, Impact, sans-serif;
  letter-spacing: 1px;
}
.gate__btn:active{transform: translateY(1px)}
.gate__micro{
  margin-top: 18px;
  font-size: 12px;
  color: rgba(233,240,234,.70);
}
.gate.is-hidden{
  opacity:0;
  pointer-events:none;
  transition: opacity 520ms ease;
}

/* Scroll container */
.scroll{
  position:relative;
  min-height:100vh;
  scroll-snap-type: y mandatory;
  overflow-x:hidden;
}
@media (prefers-reduced-motion: reduce){
  .scroll{scroll-snap-type: none}
}

/* Modules */
.module{
  position:relative;
  height: 100svh;
  min-height: 640px;
  scroll-snap-align: start;
  overflow:hidden;
  display:flex;
  align-items:flex-end;
}
.module__bg{
  position:absolute; inset:0;
  background: #000;
  background-size: cover;
  background-position: center;
  transform: translate3d(calc(var(--tiltX)*.10), calc(var(--tiltY)*.10), 0) scale(1.08);
  filter: saturate(1.05) contrast(1.05);
}
.module__bg::after{
  content:"";
  position:absolute; inset:0;
  background: linear-gradient(to top, rgba(7,8,10,.94) 0%, rgba(7,8,10,.45) 45%, rgba(7,8,10,.18) 70%, rgba(7,8,10,.02) 100%);
}
.module__content{
  position:relative;
  width: min(var(--max), calc(100vw - 24px));
  margin: 0 auto;
  padding: 94px 0 calc(26px + var(--safeBottom));
}
.kicker{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  color: var(--muted);
  font-size: 12px;
  letter-spacing: 2px;
  text-transform: uppercase;
}
.h1{
  font-family: Antonio, Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 10px 0 8px;
  font-size: clamp(34px, 8.2vw, 72px);
  line-height: .92;
}
.lead{
  max-width: 62ch;
  color: rgba(233,240,234,.82);
  font-size: 15px;
  line-height: 1.6;
  margin: 0 0 18px;
}
.mono{font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace}
.faint{color: rgba(233,240,234,.62)}
.big{font-size: 20px; letter-spacing: 1px}

/* Cards / pills */
.pill{
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.24);
  color: var(--fg);
  border-radius: 999px;
  padding: 10px 14px;
  font-family: Antonio, Impact, sans-serif;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: 12px;
}
.pill--ghost{
  background: rgba(122,76,255,.14);
}
.pill:active{transform: translateY(1px)}

/* Carousel */
.carousel{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  box-shadow: 0 30px 80px rgba(0,0,0,.55);
}
.carousel__track{
  display:flex;
  transition: transform 420ms ease;
  will-change: transform;
  touch-action: pan-y;
}
.carousel__slide{
  flex: 0 0 100%;
  padding: 12px;
}
.frame{
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
}
.frame img{
  width:100%;
  height: min(46svh, 420px);
  object-fit: cover;
}
.frame__meta{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  padding: 10px 12px;
  border-top:1px solid rgba(255,255,255,.10);
}
.carousel__controls{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 12px;
  border-top:1px solid rgba(255,255,255,.10);
}
.carousel--micro .frame img{height: min(42svh, 360px)}
.layer--uv img{filter: hue-rotate(-25deg) saturate(1.45) contrast(1.1)}
.layer--thermal img{filter: hue-rotate(75deg) saturate(1.35) contrast(1.2)}

/* Redactions */
.redactions{display:grid; gap:12px; margin-top:14px}
.redaction{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 12px;
  max-width: 520px;
}
.redaction__lines{display:grid; gap:8px; margin: 10px 0 6px}
.blk{display:block; height:14px; background:#000; border-radius:8px; opacity:.9}
.blk.w2{width: 72%}
.blk.w3{width: 55%}
.redaction:active{transform: translateY(1px)}
.redaction.is-decrypted .blk{background: rgba(155,255,61,.18); border:1px solid rgba(155,255,61,.35)}
.callout{
  border-left: 3px solid rgba(155,255,61,.55);
  padding: 10px 12px;
  background: rgba(0,0,0,.18);
  border-radius: 12px;
  max-width: 720px;
}

/* Broadcast module */
.broadcast{display:grid; gap:10px; margin-top: 10px}
.broadcast__strip{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(135deg, rgba(0,0,0,.35), rgba(0,0,0,.15));
}
.broadcast__tag{color: rgba(155,255,61,.85); font-size: 12px; letter-spacing:1px}
.broadcast__hold{
  min-width: 110px;
  border-radius: 14px;
  padding: 10px 12px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(122,76,255,.14);
  color: var(--fg);
  font-family: Antonio, Impact, sans-serif;
  letter-spacing:1px;
  text-transform: uppercase;
  font-size:12px;
}
.broadcast__hold.is-holding{background: rgba(155,255,61,.14); border-color: rgba(155,255,61,.45)}
.broadcast__hold.is-done{background: rgba(155,255,61,.20); border-color: rgba(155,255,61,.55)}

/* Analysis panels */
.analysis{
  margin-top: 14px;
  display:grid;
  gap:12px;
  grid-template-columns: 1fr;
}
.analysis__panel{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 12px;
}
.analysis__row{
  display:flex;
  justify-content:space-between;
  gap:10px;
  padding: 8px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.analysis__row:last-child{border-bottom:none}

@media (min-width: 860px){
  .analysis{grid-template-columns: 1fr 1fr}
}

/* Scrub viewer */
.scrub{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  max-width: 860px;
}
.scrub__viewer{
  position:relative;
  height: min(46svh, 420px);
  overflow:hidden;
  touch-action: pan-y;
}
.scrub__viewer img{
  width:100%;
  height:100%;
  object-fit: cover;
  filter: contrast(1.08) saturate(1.04);
}
.scrub__hud{
  position:absolute;
  left:12px; bottom:12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.38);
  border:1px solid rgba(255,255,255,.12);
  font-size: 12px;
}
.scrub__meta{padding: 10px 12px}

/* Locked overlays */
.locked{
  position:absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  backdrop-filter: blur(14px);
  background: rgba(0,0,0,.72);
}
.locked__inner{
  width:min(560px, calc(100vw - 24px));
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background: rgba(8,9,12,.92);
  padding: 18px;
  text-align:center;
  box-shadow: 0 30px 80px rgba(0,0,0,.65);
}
.locked__title{
  font-family: Antonio, Impact, sans-serif;
  letter-spacing: 2px;
  text-transform: uppercase;
  margin: 10px 0 10px;
  font-size: 34px;
}
.locked.is-hidden{display:none}

/* Harbor pan */
.harbor__pan{
  margin-top: 16px;
  height: min(24svh, 210px);
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(90deg, rgba(0,0,0,.0), rgba(0,0,0,.35)),
              rgba(0,0,0,.10);
  overflow:hidden;
  position:relative;
}
.harbor__pan::before{
  content:"";
  position:absolute; inset:-10% -30%;
  background: radial-gradient(500px 200px at 30% 60%, rgba(155,255,61,.18), transparent 60%),
              radial-gradient(700px 300px at 70% 40%, rgba(122,76,255,.18), transparent 60%),
              linear-gradient(0deg, rgba(0,0,0,.65), rgba(0,0,0,.10));
  animation: panDrift 12s linear infinite;
}
@keyframes panDrift{
  0%{transform: translate3d(-8%,0,0)}
  100%{transform: translate3d(8%,0,0)}
}
.harbor__caption{
  position:absolute;
  left:12px; bottom:12px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(0,0,0,.38);
  border:1px solid rgba(255,255,255,.12);
  font-size: 12px;
}

/* Map card */
.mapcard{
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  max-width: 860px;
}
.mapcard__grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  padding: 12px;
}
.region{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
  color: var(--fg);
  padding: 12px;
  font-family: Antonio, Impact, sans-serif;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: 12px;
}
.region.is-active{border-color: rgba(155,255,61,.55); background: rgba(155,255,61,.10)}
.mapcard__result{padding: 12px; border-top:1px solid rgba(255,255,255,.10)}
.mapcard__actions{
  display:flex; gap:10px; padding: 0 12px 12px;
}
.mapcard__actions .pill{flex:1}
.mapcard__actions .pill:disabled{opacity:.55}

/* Money shot */
.moneyshot{display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px}
.endcap{
  margin-top: 16px;
  padding: 12px;
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
}

/* Generic pages */
.page{
  padding-top: calc(74px + var(--safeTop));
  padding-bottom: calc(22px + var(--safeBottom));
  width:min(var(--max), calc(100vw - 24px));
  margin: 0 auto;
}
.page__hero{padding: 10px 0 16px}
.vault__grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap:10px;
}
@media(min-width: 860px){
  .vault__grid{grid-template-columns: repeat(4, minmax(0,1fr))}
}
.card{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.25);
  min-height: 160px;
}
.card img{width:100%; height: 160px; object-fit:cover}
.card__meta{
  padding: 10px;
  border-top:1px solid rgba(255,255,255,.10);
  font-size: 12px;
}
.card__title{font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace}
.card__tier{color: rgba(155,255,61,.85); font-size: 11px; letter-spacing:1px; margin-top:6px}
.card__lock{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(10px);
  text-align:center;
  padding: 14px;
}
.card__lock .mono{font-size: 12px}
.card.is-locked img{filter: blur(8px) saturate(.7)}

/* Timeline */
.timeline__list{display:grid; gap:10px; max-width: 900px}
.titem{
  border-radius: var(--radius);
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  padding: 12px;
}
.titem__top{display:flex; gap:12px; align-items:flex-start; justify-content:space-between}
.titem__date{color: rgba(155,255,61,.85); letter-spacing:1px; font-size: 11px}
.titem__title{font-family: Antonio, Impact, sans-serif; letter-spacing:1px; font-size: 18px; text-transform: uppercase}
.titem__loc{color: rgba(233,240,234,.68); font-size: 12px}
.titem__excerpt{margin-top: 8px; color: rgba(233,240,234,.78); font-size: 14px; line-height:1.6}
.titem__actions{margin-top: 10px; display:flex; gap:10px; flex-wrap:wrap}

/* Terminal */
.terminal{
  position:fixed; inset:0;
  z-index:200;
  display:none;
  background:
    radial-gradient(1200px 900px at 50% 0%, rgba(155,255,61,.08), transparent 55%),
    radial-gradient(1200px 900px at 50% 100%, rgba(122,76,255,.08), transparent 55%),
    rgba(0,0,0,.92);
  backdrop-filter: blur(14px);
}
.terminal.is-open{display:flex; flex-direction:column}
.terminal__top{
  padding: calc(12px + var(--safeTop)) 12px 12px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  border-bottom:1px solid rgba(255,255,255,.12);
}
.terminal__title{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  font-size: 12px;
  letter-spacing: 2px;
  color: rgba(233,240,234,.78);
}
.terminal__meta{display:flex; align-items:center; gap:10px}
.terminal__badge{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  font-size: 12px;
  color: var(--green);
  border:1px solid rgba(155,255,61,.35);
  background: rgba(155,255,61,.10);
  padding:8px 10px;
  border-radius: 999px;
}
.terminal__close{
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.20);
  color: var(--fg);
  width:40px; height:40px;
}
.terminal__body{
  flex:1;
  padding: 12px;
  overflow:auto;
  scroll-behavior:smooth;
}
.termline{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  font-size: 13px;
  line-height: 1.55;
  white-space: pre-wrap;
  padding: 10px 12px;
  margin-bottom: 10px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.termline--user{
  border-color: rgba(122,76,255,.30);
  background: rgba(122,76,255,.10);
}
.termline--sys{
  border-color: rgba(155,255,61,.28);
  background: rgba(155,255,61,.08);
}
.terminal__form{
  display:flex; gap:10px;
  padding: 12px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-bottom: calc(12px + var(--safeBottom));
}
.terminal__prompt{
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  color: var(--green);
  padding: 12px 0 0;
}
.terminal__input{
  flex:1;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: var(--fg);
  padding: 12px;
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  outline:none;
}
.terminal__enter{
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(155,255,61,.12);
  color: var(--fg);
  padding: 12px 14px;
  font-family: Antonio, Impact, sans-serif;
  text-transform: uppercase;
  letter-spacing: 1px;
}
.terminal__hint{
  padding: 0 12px calc(10px + var(--safeBottom));
  color: rgba(233,240,234,.62);
  font-size: 12px;
}

/* Lightbox */
.lightbox{
  position:fixed; inset:0;
  z-index:210;
  display:none;
  background: rgba(0,0,0,.86);
  backdrop-filter: blur(10px);
}
.lightbox.is-open{display:block}
.lightbox__close{
  position:absolute;
  top: calc(10px + var(--safeTop));
  right: 10px;
  width:44px; height:44px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.30);
  color: var(--fg);
  z-index:2;
}
.lightbox__inner{
  position:absolute;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: calc(64px + var(--safeTop)) 12px calc(90px + var(--safeBottom));
}
.lightbox__inner img, .lightbox__inner video{
  max-width: 100%;
  max-height: 100%;
  border-radius: var(--radius2);
  border:1px solid rgba(255,255,255,.12);
  box-shadow: 0 30px 90px rgba(0,0,0,.75);
}
.lightbox__caption{
  position:absolute;
  left:12px; right:12px;
  bottom: calc(12px + var(--safeBottom));
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
  padding: 10px 12px;
  font-family:"Space Mono", ui-monospace, Menlo, Consolas, monospace;
  font-size: 12px;
  color: rgba(233,240,234,.82);
}

/* Flash overlay */
.overlay--flash{
  position:fixed; inset:0;
  z-index:220;
  display:none;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  align-items:center;
  justify-content:center;
}
.overlay--flash.is-on{display:flex}
.overlay__text{
  font-family: Antonio, Impact, sans-serif;
  letter-spacing: 3px;
  text-transform: uppercase;
  font-size: clamp(26px, 7vw, 72px);
  padding: 18px 22px;
  border-radius: var(--radius2);
  border:1px solid rgba(155,255,61,.40);
  background: rgba(155,255,61,.10);
  text-shadow: 0 0 30px rgba(155,255,61,.22);
  animation: glitchFlash 520ms steps(2,end) infinite;
}
@keyframes glitchFlash{
  0%{transform: translate3d(0,0,0)}
  30%{transform: translate3d(2px,-1px,0)}
  60%{transform: translate3d(-2px,1px,0)}
  100%{transform: translate3d(0,0,0)}
}

@media (prefers-reduced-motion: reduce){
  .fx-grain{animation:none}
  .carousel__track{transition:none}
  .overlay__text{animation:none}
}

/* Touch polish */
@supports(padding:max(0px)){
  .topbar{padding-left: max(12px, env(safe-area-inset-left)); padding-right: max(12px, env(safe-area-inset-right));}
  .terminal__body, .terminal__form, .lightbox__inner, .lightbox__caption{padding-left: max(12px, env(safe-area-inset-left)); padding-right: max(12px, env(safe-area-inset-right));}
}
