/* watchtower-kiosk.css — Gate Kiosk (.gk-*) — item 12.
 * Full-screen, high-contrast, touch-first field self-enrollment station.
 * Command-dark but brighter than the dispatch console (public-facing). */

.gk-root {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; gap: 22px;
  padding: 28px 34px;
  background: radial-gradient(120% 80% at 50% -10%, #1b2a4a 0%, var(--bg-0, #070b13) 60%);
  color: var(--t-0, #f1f4fb);
  overflow: auto;
}

.gk-head { display: flex; align-items: center; gap: 24px; }
.gk-brand { display: flex; align-items: center; gap: 14px; flex: 1; }
.gk-title { font: 700 26px/1 var(--sans); letter-spacing: 0.01em; }
.gk-sub { font: 500 12px/1.2 var(--label); color: var(--t-2, #9aa6bf); margin-top: 4px; letter-spacing: 0.04em; text-transform: uppercase; }
.gk-stat { display: flex; align-items: center; gap: 24px; }
.gk-clock { font-size: 22px; color: var(--acc, #41b6e6); letter-spacing: 0.04em; }
.gk-count { text-align: right; }
.gk-count .n { display: block; font: 700 30px/1 var(--mono); color: var(--ok, #3fb56b); }
.gk-count .l { font: 600 10px/1 var(--label); text-transform: uppercase; letter-spacing: 0.08em; color: var(--t-3, #6b768f); }
.gk-exit { font: 600 12px/1 var(--sans); padding: 9px 14px; border-radius: 7px; border: 1px solid var(--l-2, #2a3148); background: transparent; color: var(--t-2, #9aa6bf); cursor: pointer; }
.gk-exit:hover { border-color: var(--acc, #41b6e6); color: var(--acc, #41b6e6); }

.gk-instructions { display: flex; gap: 14px; flex-wrap: wrap; }
.gk-step { display: flex; align-items: center; gap: 9px; font: 600 14px/1.2 var(--sans); color: var(--t-1, #c3ccdf); background: var(--bg-1, #0e1626); border: 1px solid var(--l-1, #1d2840); border-radius: 9px; padding: 11px 15px; flex: 1 1 220px; }
.gk-num { display: inline-flex; align-items: center; justify-content: center; width: 24px; height: 24px; border-radius: 50%; background: var(--acc, #41b6e6); color: #06121c; font: 800 13px/1 var(--mono); flex: none; }

.gk-banner { background: rgba(255,199,44,0.12); border: 1px solid var(--warn, #ffc72c); color: var(--warn, #ffc72c); border-radius: 9px; padding: 13px 16px; font: 600 15px/1.4 var(--sans); }
.gk-err { background: rgba(229,30,37,0.12); border: 1px solid var(--crit, #e51e25); color: var(--crit, #e51e25); border-radius: 9px; padding: 12px 16px; font: 600 14px/1.4 var(--sans); }

.gk-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 18px; }
.gk-tile { background: #ffffff; border-radius: 14px; padding: 16px; display: flex; flex-direction: column; gap: 12px; box-shadow: 0 8px 30px rgba(0,0,0,0.45); }
.gk-tile-head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.gk-tile-name { font: 800 18px/1.1 var(--sans); color: #06121c; }
.gk-lvl { font: 700 9px/1 var(--label); letter-spacing: 0.06em; text-transform: uppercase; padding: 4px 7px; border-radius: 5px; color: #06121c; } /* dark ink on DS accent */
.gk-lvl.vol { background: var(--sky); } .gk-lvl.staff { background: var(--violet); } .gk-lvl.lead { background: var(--gold); } .gk-lvl.cmd { background: var(--red); color: #fff; }
.gk-qr { background: #fff; border-radius: 8px; padding: 10px; display: flex; align-items: center; justify-content: center; }
.gk-qr svg { width: 100%; height: auto; max-width: 200px; display: block; }
.gk-tile-foot { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.gk-scan { font: 600 12px/1.2 var(--sans); color: #1b2a4a; }
.gk-on { font: 700 11px/1 var(--mono); color: #1b2a4a; }

.gk-empty { background: var(--bg-1, #0e1626); border: 1px dashed var(--l-2, #2a3148); border-radius: 12px; padding: 48px; text-align: center; font: 600 16px/1.5 var(--sans); color: var(--t-2, #9aa6bf); }
.gk-closed { font: 500 12px/1.4 var(--mono); color: var(--t-2, #9aa6bf); } /* which groups you can't join — AA (H4) */
.gk-footer { font-size: 11px; color: var(--t-2, #9aa6bf); text-align: center; margin-top: auto; padding-top: 8px; line-height: 1.5; } /* AA (H4) */
