
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');
:root{--bg:#0c0c0e;--surface:#111114;--surface2:#18181d;--surface3:#1f1f26;--border:rgba(255,255,255,0.07);--gold:#d4af37;--gold-dim:#a88a20;--gold-glow:rgba(212,175,55,0.15);--gold-subtle:rgba(212,175,55,0.06);--green:#4ade80;--red:#f87171;--text:#e2e8f0;--text-dim:#7a8ba0;--text-muted:#3d4f63;--captured-bg:#0d1a0f;--dim-glow:0 0 8px rgba(212,175,55,0.08);}
*{box-sizing:border-box;margin:0;padding:0;}
body{background:var(--bg);color:var(--text);font-family:"Inter",sans-serif;font-size:13px;min-height:100vh;}
header{background:linear-gradient(180deg,#08080a 0%,#0e0e12 50%,#111114 100%);border-bottom:1px solid rgba(212,175,55,0.15);padding:0 32px;display:flex;align-items:center;justify-content:space-between;height:74px;position:sticky;top:0;z-index:100;box-shadow:0 2px 24px rgba(0,0,0,0.6);}
.logo-block{display:flex;align-items:center;gap:16px;}
.logo-text{font-size:16px;font-weight:700;letter-spacing:2.5px;color:var(--gold);text-transform:uppercase;}
.logo-sub{font-size:10px;color:var(--gold-dim);letter-spacing:3px;margin-top:3px;text-transform:uppercase;}
.header-right{display:flex;align-items:center;gap:24px;}
.cs-wrap{display:flex;align-items:center;gap:10px;background:rgba(212,175,55,0.03);border:1px solid rgba(212,175,55,0.12);border-radius:8px;padding:6px 14px;}
.cs-wrap label{font-size:10px;color:var(--gold-dim);letter-spacing:2.5px;font-weight:600;}
#callsign{background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:"JetBrains Mono",monospace;font-size:13px;padding:6px 10px;border-radius:6px;width:140px;outline:none;}
#callsign:focus{border-color:var(--gold-dim);}
.score-pill{display:flex;align-items:baseline;gap:6px;background:linear-gradient(135deg,rgba(212,175,55,0.08),rgba(212,175,55,0.03));border:1px solid rgba(212,175,55,0.2);border-radius:20px;padding:8px 18px;}
.score-num{font-size:20px;font-weight:700;color:var(--gold);font-family:"JetBrains Mono",monospace;}
.score-denom{font-size:13px;color:var(--text-dim);font-family:"JetBrains Mono",monospace;}
.score-label{font-size:10px;color:var(--gold-dim);letter-spacing:2.5px;margin-left:6px;font-weight:600;text-transform:uppercase;}
.tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;overflow-x:auto;justify-content:center;gap:2px;}
.tab{display:flex;align-items:center;gap:8px;padding:14px 20px;cursor:pointer;font-size:12px;font-weight:600;letter-spacing:1.5px;color:var(--text-dim);border-bottom:3px solid transparent;white-space:nowrap;transition:all .25s;user-select:none;text-transform:uppercase;}
.tab:hover{color:var(--text);background:rgba(255,255,255,0.02);}
.tab.active{color:var(--gold);border-bottom-color:var(--gold);background:rgba(212,175,55,0.04);}
.tab-badge{background:var(--surface3);border-radius:10px;padding:2px 8px;font-size:11px;font-family:"JetBrains Mono",monospace;min-width:36px;text-align:center;}
.tab.active .tab-badge{background:var(--gold-subtle);color:var(--gold);}
.main-layout{display:grid;grid-template-columns:250px minmax(0,640px) 300px;gap:0;min-height:calc(100vh - 140px);max-width:1440px;margin:0 auto;justify-content:center;}
.tracker-sidebar{position:sticky;top:145px;height:calc(100vh - 190px);overflow-y:auto;background:rgba(17,17,20,0.6);border-right:1px solid var(--border);padding:16px 12px;scrollbar-width:thin;scrollbar-color:var(--surface3) transparent;}
.tracker-sidebar::-webkit-scrollbar{width:4px;}
.tracker-sidebar::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px;}
.tracker-title{font-size:10px;color:var(--gold-dim);letter-spacing:2.5px;font-weight:700;margin-bottom:14px;text-align:center;}
.tracker-phase{padding:7px 10px;border:1px solid var(--border);border-radius:6px;margin-bottom:5px;cursor:pointer;transition:all .2s;}
.tracker-phase:hover{border-color:rgba(212,175,55,0.2);}
.tracker-phase.tp-active{border-color:rgba(212,175,55,0.3);background:rgba(212,175,55,0.04);}
.tracker-phase.tp-done{border-color:rgba(74,222,128,0.2);background:rgba(74,222,128,0.03);}
.tp-label{font-size:10px;font-weight:600;color:var(--text);letter-spacing:0.5px;margin-bottom:4px;}
.tp-bar{height:3px;background:var(--surface3);border-radius:2px;overflow:hidden;margin-bottom:3px;}
.tp-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s;}
.tp-done .tp-fill{background:var(--green);}
.tp-meta{display:flex;justify-content:space-between;align-items:center;}
.tp-count{font-size:10px;color:var(--text-dim);font-family:"JetBrains Mono",monospace;}
.tp-date{font-size:10px;color:var(--green);font-family:"JetBrains Mono",monospace;}
.tracker-divider{height:1px;background:var(--border);margin:12px 0;}
.tracker-section-title{font-size:10px;color:var(--gold-dim);letter-spacing:2px;font-weight:600;margin-bottom:8px;text-align:center;}
.comp-item{display:flex;align-items:center;gap:7px;padding:3px 0;font-size:10px;color:var(--text-dim);text-shadow:var(--dim-glow);}
.comp-dot{width:6px;height:6px;border-radius:50%;background:var(--surface3);flex-shrink:0;}
.comp-dot.comp-done{background:var(--green);}
.comp-dot.comp-partial{background:var(--gold);}
.main-content{padding:24px 28px;overflow-y:auto;max-height:calc(100vh - 145px);}
.page{display:none;}
.page.active{display:block;}
.briefing-sidebar{position:sticky;top:145px;height:calc(100vh - 190px);overflow-y:auto;border-left:1px solid var(--border);padding:20px 18px;scrollbar-width:thin;scrollbar-color:var(--surface3) transparent;}
.briefing-sidebar::-webkit-scrollbar{width:4px;}
.briefing-sidebar::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:2px;}
.phase-header{padding:0;border:none;margin-bottom:0;background:none;}
.phase-title{font-size:16px;font-weight:700;letter-spacing:1px;margin-bottom:10px;color:var(--gold);}
.phase-briefing{color:var(--text-dim);font-size:14px;line-height:1.85;margin-bottom:16px;text-shadow:var(--dim-glow);}
.phase-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:0;}
.phase-tag{background:var(--surface2);border:1px solid var(--border);border-radius:4px;padding:2px 7px;font-size:9px;color:var(--text-dim);letter-spacing:.5px;font-family:"JetBrains Mono",monospace;text-decoration:none;transition:all .2s;}
a.mitre-tag{background:rgba(212,175,55,0.06);border-color:rgba(212,175,55,0.15);color:var(--gold-dim);cursor:pointer;}
a.mitre-tag:hover{background:rgba(212,175,55,0.12);border-color:rgba(212,175,55,0.3);color:var(--gold);}
.phase-progress{display:flex;align-items:center;gap:10px;}
.progress-bar{flex:1;height:4px;background:var(--surface3);border-radius:2px;overflow:hidden;}
.progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .4s;}
.progress-label{font-size:11px;color:var(--text-dim);font-family:"JetBrains Mono",monospace;}
.cards-list{display:flex;flex-direction:column;gap:12px;}
@media(max-width:1100px){.main-layout{grid-template-columns:1fr;max-width:100%;}.tracker-sidebar,.briefing-sidebar{position:static;height:auto;border:none;border-bottom:1px solid var(--border);}}
/* P4c (2026-05-07): tablet portrait + phone breakpoints. Below 1100px the
   sidebar already collapses (above); these tighten header padding, scale
   the operator menu trigger, stack the quickstart panel vertically, and
   shrink the bottom-right floating control buttons. The score pill hides
   on phones (it's still accessible from the competency-modal trigger). */
@media(max-width:768px){
  header{padding:0 16px;height:64px;}
  .logo-text{font-size:14px;}
  .logo-sub{font-size:9px;}
  .score-pill{font-size:10px;padding:4px 10px;}
  #operator-menu-toggle{padding:5px 9px;font-size:11px;}
  #operator-menu-toggle .cs-display{font-size:11px;}
  #operator-menu{min-width:180px;font-size:11px;}
  .gate-overlay{padding:16px 12px;}
  .gate-container{max-width:100%;}
  .gate-title{font-size:22px;}
  .gate-unit{font-size:10px;letter-spacing:1.5px;}
  .gate-input{font-size:13px;padding:10px;}
  /* Quickstart panel: stack vertically, smaller text */
  #quickstart-panel{padding:8px 12px;}
  #quickstart-panel > div{flex-direction:column;align-items:stretch;}
  #quickstart-panel > div > div:first-child{flex-direction:column;align-items:flex-start;gap:6px;}
  #quickstart-panel > div > div:first-child > div[style*="height:24px"]{display:none;}
  #quickstart-panel > div > div:first-child > div[style*="display:flex;gap:20px"]{flex-direction:column;gap:4px;font-size:11px;}
  /* Bottom-right floating buttons: scale down */
  div[style*="bottom:20px"][style*="right:20px"] button{padding:8px 12px;font-size:11px;}
  /* Page-level cards padding shrinks slightly */
  .card{padding:16px;}
}
@media(max-width:480px){
  header{padding:0 12px;height:56px;}
  .logo-block img{height:36px!important;width:36px!important;}
  .logo-text{font-size:12px;}
  .logo-sub{font-size:8px;letter-spacing:0.5px;}
  /* Score pill hides on phones — stays available via the competency modal trigger inside the operator menu (when added in a future iteration) */
  .score-pill{display:none;}
  .tabs{font-size:9px;padding:4px 8px;overflow-x:auto;}
  .tabs > *{flex-shrink:0;}
  /* Operator menu trigger: more compact, hide chevron text label */
  #operator-menu-toggle{padding:4px 8px;gap:5px;}
  #operator-menu-toggle > span:first-child{display:none;}  /* hide "OPERATOR" label, keep callsign */
  #operator-menu{min-width:170px;right:0;}
  /* Gate page: full-bleed, no max-width constraint */
  .gate-container{padding:0 4px;}
  .gate-title{font-size:18px;letter-spacing:2px;}
  .gate-unit{font-size:9px;}
  .gate-briefing{padding:12px;font-size:12px;}
  .gate-input{font-size:13px;padding:9px;}
  /* Bottom-right floating buttons: stack vertically, even smaller */
  div[style*="bottom:20px"][style*="right:20px"]{
    flex-direction:column!important;
    bottom:10px!important;right:10px!important;gap:6px!important;
  }
  div[style*="bottom:20px"][style*="right:20px"] button{padding:6px 10px;font-size:10px;letter-spacing:0.5px;}
  /* Modal: full-width-ish on phone */
  #support-modal > div, #help-modal > div, #feedback-modal > div{padding:18px;width:96vw!important;}
  .card{padding:14px;}
  .card-title{font-size:13px;}
}
.card{background:rgba(17,17,20,0.92);border:1px solid var(--border);border-radius:12px;padding:20px;transition:border-color .2s;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);}
.card:hover{border-color:rgba(212,175,55,0.2);}
.card.captured{background:var(--captured-bg);border-color:rgba(74,222,128,0.2);}
.card.locked{opacity:0.45;background:rgba(0,0,0,0.25);border-color:rgba(255,255,255,0.03);cursor:not-allowed;}
.card.locked:hover{border-color:rgba(255,255,255,0.03);transform:none;}
.card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;}
.card-num{font-size:11px;color:var(--text-muted);font-family:"JetBrains Mono",monospace;letter-spacing:1px;}
.card-captured-badge{font-size:11px;color:var(--green);letter-spacing:1px;font-weight:600;}
.card-title{font-size:15px;font-weight:600;margin-bottom:8px;}
.scenario-box{background:rgba(212,175,55,0.05);border:1px solid rgba(212,175,55,0.12);border-radius:8px;padding:12px 14px;margin-bottom:12px;}
.scenario-label{font-size:10px;color:var(--gold-dim);letter-spacing:2px;margin-bottom:5px;font-weight:600;}
.scenario-box{font-size:13px;line-height:1.7;}
.scenario-box strong{color:#d4af37;}
.scenario-text{font-size:13px;color:var(--text-dim);line-height:1.7;text-shadow:var(--dim-glow);white-space:pre-wrap;}
.challenge-section-header{display:block;margin-top:16px;margin-bottom:8px;padding:4px 12px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border-left:3px solid #d4af37;background:rgba(212,175,55,0.05);color:#d4af37;}
.method-box{background:var(--surface2);border-radius:6px;padding:8px 11px;margin-bottom:12px;font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--text-dim);}
.input-row{display:flex;gap:8px;margin-bottom:10px;}
.flag-input{flex:1;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-family:"JetBrains Mono",monospace;font-size:13px;padding:9px 12px;border-radius:6px;outline:none;transition:border-color .2s;}
.flag-input:focus{border-color:var(--gold-dim);}
.flag-input.wrong{border-color:var(--red);animation:shake .3s;}
@keyframes shake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.submit-btn{background:var(--gold);color:#000;font-weight:700;font-size:12px;letter-spacing:1px;padding:9px 16px;border:none;border-radius:6px;cursor:pointer;transition:background .2s;white-space:nowrap;}
.submit-btn:hover{background:var(--gold-dim);}
.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.85);z-index:1000;display:none;align-items:center;justify-content:center;}
.modal-box{background:#111114;border:1px solid rgba(212,175,55,0.3);border-radius:16px;padding:40px;max-width:420px;width:90%;text-align:center;}
.modal-title{font-size:18px;font-weight:700;color:var(--gold);letter-spacing:1px;margin-bottom:8px;}
.modal-sub{font-size:13px;color:var(--text-dim);margin-bottom:24px;line-height:1.7;}
.modal-input{width:100%;background:var(--surface2);border:1px solid rgba(212,175,55,0.3);color:var(--text);font-family:"JetBrains Mono",monospace;font-size:14px;padding:12px 16px;border-radius:8px;outline:none;text-align:center;letter-spacing:2px;margin-bottom:16px;}
.modal-input:focus{border-color:var(--gold);}
.modal-btn{background:var(--gold);color:#000;font-weight:700;font-size:13px;letter-spacing:2px;padding:12px 32px;border:none;border-radius:8px;cursor:pointer;width:100%;}
.modal-btn:hover{background:var(--gold-dim);}
.cs-display{font-family:"JetBrains Mono",monospace;font-size:13px;color:var(--gold);cursor:pointer;padding:4px 10px;border:1px solid rgba(212,175,55,0.2);border-radius:6px;}
.cs-display:hover{border-color:var(--gold-dim);}
.reset-btn{background:none;border:1px solid rgba(248,113,113,0.2);color:#94525299;font-family:"Inter",sans-serif;font-size:10px;font-weight:600;letter-spacing:2px;padding:6px 14px;border-radius:6px;cursor:pointer;transition:all .2s;text-transform:uppercase;}
.reset-btn:hover{background:rgba(248,113,113,0.08);border-color:rgba(248,113,113,0.4);color:#f87171;}
.msg{font-size:12px;min-height:16px;margin-bottom:8px;}
.hint-btn{background:none;border:1px solid var(--border);color:var(--text-dim);font-family:"Inter",sans-serif;font-size:12px;cursor:pointer;padding:6px 12px;border-radius:5px;display:inline-flex;align-items:center;gap:6px;transition:all .2s;}
.hint-btn:hover{border-color:var(--gold-dim);color:var(--gold-dim);}
.hint-box{background:var(--surface2);border-left:2px solid var(--gold-dim);padding:10px 13px;border-radius:0 6px 6px 0;margin-top:8px;}
.hint-meta{font-size:10px;color:var(--gold-dim);letter-spacing:2px;margin-bottom:5px;font-weight:600;}
.hint-text{font-size:13px;color:var(--text-dim);line-height:1.7;text-shadow:var(--dim-glow);}
body::before{
  content:'';
  position:fixed;
  top:calc(50% + 58px);
  left:50%;
  transform:translate(-50%,-50%);
  width:88vh;
  height:88vh;
  background-image:url('/unit-logo.png');
  background-size:contain;
  background-repeat:no-repeat;
  background-position:center;
  opacity:0.06;
  pointer-events:none;
  z-index:0;
}
.page,.tabs,.header-right,.logo-block{position:relative;z-index:1;}
footer{text-align:center;padding:24px;font-size:10px;color:#718096;letter-spacing:2px;border-top:1px solid var(--border);margin-top:40px;}

/* ── CONFETTI ───────────────────────────────────────────────── */
.confetti-container{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:9999;overflow:hidden;}
.confetti-piece{position:absolute;top:-20px;width:10px;height:10px;opacity:0.9;animation:confetti-fall linear forwards;}
@keyframes confetti-fall{0%{transform:translateY(0) rotate(0deg) scale(1);opacity:1;}80%{opacity:1;}100%{transform:translateY(100vh) rotate(720deg) scale(0.3);opacity:0;}}

/* ── COMPETENCY PROGRESS BARS (sidebar) ─────────────────────── */
.comp-item-bar{display:flex;flex-direction:column;gap:3px;padding:5px 0;}
.comp-bar-header{display:flex;align-items:center;justify-content:space-between;}
.comp-bar-label{font-size:10px;color:var(--text-dim);letter-spacing:0.3px;}
.comp-bar-count{font-size:10px;font-family:"JetBrains Mono",monospace;color:var(--text-muted);}
.comp-bar-track{height:4px;background:var(--surface3);border-radius:2px;overflow:hidden;}
.comp-bar-fill{height:100%;border-radius:2px;transition:width .4s;}
.comp-bar-fill.comp-bar-done{background:var(--green);}
.comp-bar-fill.comp-bar-partial{background:var(--gold);}
.comp-bar-fill.comp-bar-empty{background:var(--surface3);}

/* ── CAPTIVE PORTAL ──────────────────────────────────────────── */
/* Static gate page: opaque, fills viewport, locks body scroll while open.
   Inner container handles overflow so tall content (registration form +
   SSH instructions + reconnect banner) stays usable on small viewports. */
/* Mobile gate-bypass fix (2026-05-08): four hardening changes against
   the iOS Safari keyboard-induced bleed-through where Tier 1 challenge
   content was visible underneath the gate-overlay when a registration
   field was focused (root causes: dashboard rendered behind the overlay,
   100vh winning over 100dvh on keyboard open, .gate-bg-logo at 60vh
   exceeding viewport width on tall phones).
   1. Hide all dashboard structural content while gate is locked — no
      bleed-through possible if there's nothing behind the overlay.
   2. height:100vh first then 100dvh — dvh wins on supporting browsers
      and shrinks with the soft keyboard; vh stays as the legacy fallback.
   3. overflow-x:hidden explicit on html+body when gate-locked — defense
      in depth against any other lateral overflow source.
   4. .gate-bg-logo size constrained below so it can't force horizontal
      page overflow on tall phones. */
html.gate-locked, body.gate-locked{overflow:hidden!important;overflow-x:hidden!important;height:100vh;height:100dvh;}
body.gate-locked > header,
body.gate-locked > nav.tabs,
body.gate-locked > #quickstart-panel,
body.gate-locked > .main-layout,
body.gate-locked > footer{display:none!important;}
.gate-overlay{position:fixed;inset:0;width:100vw;height:100vh;height:100dvh;background:#0c0c0e;z-index:2000;display:flex;align-items:flex-start;justify-content:center;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:24px 16px;}
.gate-container{max-width:560px;width:100%;text-align:center;position:relative;z-index:1;margin:auto;}
.gate-classification{background:#1a2e1a;border:1px solid rgba(74,222,128,0.3);padding:6px 0;text-align:center;width:100vw;position:fixed;top:0;left:0;z-index:2001;}
.gate-classification span{font-size:10px;font-weight:700;color:#4ade80;letter-spacing:4px;}
.gate-logo{width:80px;height:80px;object-fit:contain;margin-bottom:12px;opacity:0.9;}
.gate-title{font-size:22px;font-weight:700;color:var(--gold);letter-spacing:3px;margin-bottom:4px;font-family:"Inter",sans-serif;}
.gate-unit{font-size:11px;color:var(--gold-dim);letter-spacing:3px;margin-bottom:16px;}
.gate-restricted{font-size:12px;font-weight:700;color:var(--red);letter-spacing:4px;margin-bottom:16px;padding:6px 18px;border:1px solid rgba(248,113,113,0.3);display:inline-block;border-radius:4px;}
.gate-briefing{background:rgba(17,17,20,0.8);border:1px solid var(--border);border-radius:10px;padding:18px;margin-bottom:16px;text-align:left;}
.gate-briefing-label{font-size:9px;color:var(--gold-dim);letter-spacing:3px;font-weight:700;margin-bottom:10px;}
.gate-briefing p{font-size:13px;color:var(--text-dim);line-height:1.7;margin-bottom:10px;}
.gate-briefing code{background:var(--surface3);padding:2px 8px;border-radius:4px;font-family:"JetBrains Mono",monospace;font-size:11px;color:var(--gold);}
.gate-cmd{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px 18px;margin:12px 0;font-family:"JetBrains Mono",monospace;font-size:12px;color:var(--green);text-align:center;letter-spacing:0.5px;}
.gate-input-group{margin-top:12px;}
.gate-input-label{font-size:9px;color:var(--text-dim);letter-spacing:2px;margin-bottom:8px;text-align:left;}
.gate-input{width:100%;background:var(--surface2);border:1px solid rgba(212,175,55,0.3);color:var(--text);font-family:"JetBrains Mono",monospace;font-size:14px;padding:14px 18px;border-radius:8px;outline:none;text-align:center;letter-spacing:1px;margin-bottom:4px;}
.gate-input:focus{border-color:var(--gold);}
.gate-input.gate-error{border-color:var(--red);animation:shake .3s;}
.gate-submit{background:var(--gold);color:#000;font-weight:700;font-size:12px;letter-spacing:3px;padding:14px 32px;border:none;border-radius:8px;cursor:pointer;width:100%;margin-top:12px;transition:background .2s;}
.gate-submit:hover{background:var(--gold-dim);}
.gate-msg{font-size:11px;min-height:18px;margin-top:8px;color:var(--text-dim);}
.gate-footer{font-size:9px;color:#4a5568;letter-spacing:2px;margin-top:16px;}
.gate-bg-logo{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:min(60vh,80vw);height:min(60vh,80vw);max-width:80vw;max-height:80vh;opacity:0.04;pointer-events:none;z-index:0;object-fit:contain;}
/* In-app announcement modal severity colors (2026-05-06). Modal layout itself
   is inline-styled in the modal markup; only the severity chip color varies. */
.ann-severity{display:inline-block;}
.ann-sev-info{background:rgba(96,165,250,0.15);color:#60a5fa;}
.ann-sev-important{background:rgba(212,175,55,0.18);color:#d4af37;}
.ann-sev-warning{background:rgba(248,113,113,0.18);color:#f87171;}
.ann-sev-critical{background:rgba(248,113,113,0.25);color:#fff;border:1px solid #f87171;}
/* Compact gate for laptop/short viewports (1366x768, 1080p with browser chrome, etc) */
@media (max-height:820px){
  .gate-overlay{padding:14px 12px;}
  .gate-logo{width:56px;height:56px;margin-bottom:6px;}
  .gate-title{font-size:18px;letter-spacing:2.5px;margin-bottom:2px;}
  .gate-unit{margin-bottom:10px;}
  .gate-restricted{margin-bottom:10px;padding:4px 14px;font-size:11px;letter-spacing:3px;}
  .gate-briefing{padding:14px;margin-bottom:10px;}
  .gate-briefing p{font-size:12px;line-height:1.55;margin-bottom:8px;}
  .gate-briefing-label{margin-bottom:8px;}
  .gate-input-group{margin-top:8px;}
  .gate-input{padding:10px 14px;font-size:13px;}
  .gate-submit{padding:12px 28px;margin-top:8px;}
  .gate-footer{margin-top:10px;}
}
