/**
 * v0.42 — Mobile-first command density, safe-area breathing, desktop tension refinements.
 * Loads after v41; uses #app.screen-* for scope where needed.
 */

:root {
  --v42-safe-bottom: max(20px, env(safe-area-inset-bottom, 0px));
  --v42-safe-top: max(8px, env(safe-area-inset-top, 0px));
}

/* --- Scroll / chrome breathing (all in-game screens) --- */
#app.screen-game-screen > .v42-main,
#app.screen-night-prep-screen > .v42-main,
#app.screen-summary-screen > .v42-main,
#app.screen-failure-screen > .v42-main,
#app.screen-run-ending-screen > .v42-main {
  padding-bottom: max(var(--v42-safe-bottom), 16px);
}

/* --- Mobile: command density (≤920px) --- */
@media (max-width: 920px) {
  .app-shell {
    padding-left: max(12px, env(safe-area-inset-left, 0px));
    padding-right: max(12px, env(safe-area-inset-right, 0px));
    padding-bottom: max(14px, calc(env(safe-area-inset-bottom, 0px) + 8px));
  }

  /* Topbar: less header before play */
  #app.screen-game-screen .v42-topbar {
    margin-bottom: 10px;
    gap: 8px;
    padding-bottom: 4px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  }

  #app.screen-game-screen .topbar-brand .topbar-subtitle {
    display: none;
  }

  #app.screen-game-screen .topbar-brand h1 {
    font-size: clamp(1.15rem, 4.8vw, 1.45rem);
    margin: 0.1rem 0 0;
  }

  #app.screen-game-screen .topbar-stats {
    width: 100%;
    max-width: none;
    gap: 6px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }

  #app.screen-game-screen .stat-box {
    padding: 7px 5px 8px;
    border-radius: 10px;
  }

  #app.screen-game-screen .stat-box .label {
    font-size: 0.55rem;
    letter-spacing: 0.08em;
  }

  #app.screen-game-screen .stat-box strong {
    font-size: 0.88rem;
    margin-top: 3px;
    line-height: 1.1;
  }

  #app.screen-game-screen .topbar-context-strip {
    font-size: 0.78rem;
    line-height: 1.35;
    margin: 2px 0 0;
  }

  #app.screen-game-screen .topbar-upgrades {
    font-size: 0.72rem;
    margin: 2px 0 0;
  }

  #app.screen-game-screen .topbar-toolbar {
    gap: 6px;
  }

  #app.screen-game-screen .topbar-toolbar .button {
    min-height: 40px;
    padding: 6px 10px;
    font-size: 0.76rem;
  }

  /* Tab bar: shorter, clearer active */
  #app.screen-game-screen .v41-panel-tabs {
    padding: 0.28rem;
    gap: 0.35rem;
    margin-bottom: 10px;
    border-radius: 12px;
  }

  #app.screen-game-screen .v41-panel-tabs .tab-button {
    min-height: 44px;
    padding: 0.35rem 0.45rem;
    font-size: 0.78rem;
    border-radius: 10px;
  }

  #app.screen-game-screen .v41-panel-tabs .tab-button.active {
    box-shadow: inset 0 0 0 1px rgba(148, 163, 184, 0.45), 0 4px 14px rgba(0, 0, 0, 0.35);
    font-weight: 650;
  }

  /* Shift ribbon */
  #app.screen-game-screen .v41-shift-ribbon {
    margin-top: 0.45rem;
    padding: 0.55rem 0.62rem;
    gap: 0.45rem;
  }

  #app.screen-game-screen .shift-primary-block,
  #app.screen-game-screen .shift-secondary-block {
    padding: 0.5rem 0.55rem;
  }

  #app.screen-game-screen .shift-status-title {
    font-size: 0.82rem;
  }

  #app.screen-game-screen .shift-pressure-label {
    font-size: 0.78rem;
  }

  /* Panels */
  #app.screen-game-screen .panel {
    padding: 12px 12px 14px;
  }

  #app.screen-game-screen .panel-header h3 {
    font-size: 1.02rem;
  }

  #app.screen-game-screen .panel-header .section-tag {
    font-size: 0.62rem;
  }

  #app.screen-game-screen .microcopy-line {
    font-size: 0.78rem;
    line-height: 1.35;
    margin: 0.2rem 0 0.35rem;
  }

  /* Front desk: sticky reception strip */
  #app.screen-game-screen #frontdesk-panel > .panel-header {
    position: sticky;
    top: 0;
    z-index: 5;
    margin: -4px -4px 8px;
    padding: 8px 8px 10px;
    background: linear-gradient(180deg, rgba(8, 11, 18, 0.97), rgba(8, 11, 18, 0.88));
    border-bottom: 1px solid rgba(255, 255, 255, 0.07);
    border-radius: 10px 10px 0 0;
  }

  /* Guest cards */
  #app.screen-game-screen #guest-queue.card-list {
    gap: 0.55rem;
  }

  #app.screen-game-screen .guest-card {
    padding: 10px 10px 11px;
  }

  #app.screen-game-screen .action-group-label {
    font-size: 0.62rem;
    margin: 0.35rem 0 0.28rem;
    letter-spacing: 0.1em;
  }

  /* Primary desk row: full-width Check In, Flag + Reject paired */
  #app.screen-game-screen .v42-guest-action-stack .action-group-decide .guest-action-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }

  #app.screen-game-screen .v42-guest-action-stack .action-group-decide .guest-action-row .button.button-primary {
    grid-column: 1 / -1;
  }

  /* Investigation: 2-up wrap */
  #app.screen-game-screen .v42-guest-action-stack .action-group-investigate .guest-action-row-secondary {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }

  #app.screen-game-screen .v42-guest-action-stack .guest-action-row .button,
  #app.screen-game-screen .v42-guest-action-stack .guest-action-row-secondary .button {
    width: 100%;
    min-height: 44px;
    padding: 0.4rem 0.55rem;
    font-size: 0.82rem;
  }

  /* Room detail (expanded) */
  #app.screen-game-screen .v42-room-overview {
    gap: 0.35rem;
    padding: 0.45rem 0.5rem;
  }

  #app.screen-game-screen .v42-room-detail .v42-room-body {
    padding-top: 0.35rem;
  }

  #app.screen-game-screen .room-pressure-row {
    gap: 0.28rem;
    flex-wrap: wrap;
  }

  #app.screen-game-screen .room-state-chip {
    font-size: 0.62rem;
    padding: 0.12rem 0.38rem;
  }

  #app.screen-game-screen .v42-room-action-stack .room-service-row,
  #app.screen-game-screen .v42-room-action-stack .room-tactical-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }

  #app.screen-game-screen .v42-room-action-stack .room-service-row .button,
  #app.screen-game-screen .v42-room-action-stack .room-tactical-row .button {
    width: 100%;
    min-height: 44px;
    font-size: 0.8rem;
  }

  /* Camera wall: denser grid, shorter preview */
  #app.screen-game-screen #camera-grid.v42-camera-grid.camera-grid {
    grid-template-columns: repeat(auto-fill, minmax(132px, 1fr));
    gap: 6px;
    padding: 4px;
  }

  #app.screen-game-screen #camera-grid .camera-preview {
    height: 56px;
  }

  #app.screen-game-screen #camera-grid .camera-card h4 {
    padding: 0.22rem 0.45rem 0.05rem;
    font-size: 0.68rem;
  }

  #app.screen-game-screen #camera-grid .camera-meta {
    padding: 0 0.45rem 0.35rem;
    font-size: 0.6rem;
    line-height: 1.25;
  }

  #app.screen-game-screen #camera-grid .camera-investigate-btn,
  #app.screen-game-screen #camera-grid .camera-card .button {
    min-height: 40px;
    margin: 0 0.45rem 0.45rem;
    font-size: 0.78rem;
  }

  /* Shared spaces board */
  #app.screen-game-screen .v42-shared-board.shared-space-grid {
    gap: 0.55rem;
  }

  #app.screen-game-screen .v42-shared-board .shared-space-head {
    gap: 0.35rem;
  }

  #app.screen-game-screen .v42-shared-board .shared-space-headline {
    font-size: 0.88rem;
    line-height: 1.3;
  }

  #app.screen-game-screen .v42-shared-board .shared-space-why,
  #app.screen-game-screen .v42-shared-board .shared-space-route-line {
    font-size: 0.76rem;
    margin: 0.15rem 0 0;
  }

  #app.screen-game-screen .v42-shared-board .room-card {
    padding: 10px 10px 11px;
  }

  /* Power */
  #app.screen-game-screen .v42-breaker-tight .v32-breaker-header {
    padding-bottom: 0.25rem;
  }

  #app.screen-game-screen .v42-breaker-tight .v32-circuit-grid {
    gap: 0.35rem;
  }

  #app.screen-game-screen .v42-breaker-tight .v32-circuit-btn {
    min-height: 40px;
    font-size: 0.72rem;
    padding: 0.28rem 0.35rem;
  }

  #app.screen-game-screen .v42-breaker-tight .v32-neon-strip,
  #app.screen-game-screen .v42-breaker-tight .v32-operator-strip {
    gap: 0.35rem;
    flex-wrap: wrap;
  }

  #app.screen-game-screen #power-panel .button-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }

  #app.screen-game-screen #power-panel .button-row .button {
    min-height: 44px;
    width: 100%;
    font-size: 0.82rem;
  }

  #app.screen-game-screen #power-panel .meter-block {
    margin-bottom: 0.45rem;
  }

  /* Report */
  #app.screen-game-screen .v42-report-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 0.45rem;
  }

  #app.screen-game-screen .v42-report-actions .button {
    width: 100%;
    min-height: 44px;
    font-size: 0.82rem;
  }

  #app.screen-game-screen .v42-report-actions .button.button-primary {
    grid-column: 1 / -1;
  }

  #app.screen-game-screen #report-panel #incident-log.log-list {
    gap: 0.35rem;
  }

  #app.screen-game-screen #report-panel #incident-log .log-item {
    padding: 8px 10px;
    font-size: 0.82rem;
    gap: 0.38rem;
  }

  #app.screen-game-screen .v41-report-strip {
    margin-top: 0.35rem;
    padding-top: 0.42rem;
    font-size: 0.8rem;
    line-height: 1.35;
  }

  /* Command board micro-tighten */
  #app.screen-game-screen .motel-command-board .v41-mcb-core {
    padding: 0.4rem 0.5rem 0.45rem;
  }
}

/* --- Narrow phones: slightly more camera columns --- */
@media (max-width: 520px) {
  #app.screen-game-screen #camera-grid.v42-camera-grid.camera-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* --- Desktop tension (≥921px) --- */
@media (min-width: 921px) {
  #app.screen-game-screen .v42-topbar {
    padding-bottom: 6px;
    border-bottom: 1px solid rgba(255, 255, 255, 0.08);
    margin-bottom: 18px;
  }

  #app.screen-game-screen .topbar-stats .stat-box {
    border-color: rgba(148, 163, 184, 0.22);
    box-shadow: 0 8px 22px rgba(0, 0, 0, 0.28);
  }

  #app.screen-game-screen .v41-panel-tabs {
    border-color: rgba(255, 255, 255, 0.1);
    background: rgba(2, 6, 23, 0.65);
  }

  #app.screen-game-screen .v41-shift-ribbon {
    border-color: rgba(148, 163, 184, 0.18);
    box-shadow: 0 14px 36px rgba(0, 0, 0, 0.38);
  }

  #app.screen-game-screen #frontdesk-panel.panel-v41--desk.active-panel {
    box-shadow: 0 0 0 1px rgba(110, 231, 255, 0.18), 0 26px 56px rgba(0, 0, 0, 0.55);
  }

  /* Surveillance: deeper monitor well */
  #app.screen-game-screen #camera-grid.v42-camera-grid.camera-grid {
    border-color: rgba(0, 220, 80, 0.16);
    background: radial-gradient(800px 240px at 50% 0%, rgba(0, 40, 24, 0.22), transparent 60%), var(--v22-camera-bg, #050a0e);
    box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.45);
  }

  #app.screen-game-screen #camera-grid .camera-card {
    border-color: rgba(0, 220, 80, 0.12);
    box-shadow: 0 6px 16px rgba(0, 0, 0, 0.35);
  }

  #app.screen-game-screen #camera-grid .camera-card.is-actionable {
    box-shadow: 0 0 0 1px rgba(248, 113, 113, 0.35), 0 8px 22px rgba(0, 0, 0, 0.45);
  }

  #app.screen-game-screen .motel-command-board .v41-mcb-core {
    border-color: rgba(255, 255, 255, 0.12);
    box-shadow: 0 16px 40px rgba(0, 0, 0, 0.42);
  }

  .app-shell {
    max-width: min(1440px, calc(100vw - 48px));
  }
}
