/**
 * Mobile-only UI (narrow viewports). Desktop layouts are unchanged — all rules are
 * wrapped in max-width media queries.
 *
 * v2: streamer dashboard header/toolbars, browse hub, modals, safe-area, tables.
 */

@media (max-width: 768px) {
  html {
    -webkit-text-size-adjust: 100%;
  }

  body {
    overflow-x: hidden;
  }

  .container {
    width: 100%;
    max-width: 100%;
    padding: 12px 14px;
    padding-left: max(14px, env(safe-area-inset-left));
    padding-right: max(14px, env(safe-area-inset-right));
    padding-bottom: max(12px, env(safe-area-inset-bottom));
    box-sizing: border-box;
  }

  .card {
    min-width: 0;
    padding: 14px;
  }

  .container h1,
  .card h1 {
    font-size: 1.35rem;
    line-height: 1.25;
    word-wrap: break-word;
  }

  /* iOS: 16px+ on text fields avoids automatic zoom on focus */
  input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]),
  select,
  textarea {
    font-size: 16px !important;
    max-width: 100%;
  }

  .row {
    gap: 8px;
  }

  .codebox,
  pre {
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Primary dashboard / profile tab strips: horizontal scroll, no clipped tabs */
  .dashboard-tabs,
  .profile-dashboard-tabs {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 8px;
    padding-bottom: 8px;
    margin-left: -2px;
    margin-right: -2px;
    padding-left: 2px;
    padding-right: 2px;
    scroll-snap-type: x proximity;
    scrollbar-width: thin;
  }

  .dashboard-tabs .dashboard-tab,
  .profile-dashboard-tabs .dashboard-tab {
    flex: 0 0 auto;
    min-height: 44px;
    padding: 10px 16px;
    scroll-snap-align: start;
    white-space: nowrap;
  }

  /* Setup sub-tabs (streamer dashboard) */
  #tab-panel-setup .setup-subtabs {
    flex-wrap: nowrap !important;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 8px;
    padding-bottom: 8px;
  }

  #tab-panel-setup .setup-subtab {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .control-btn-grid {
    grid-template-columns: 1fr !important;
  }

  .dashboard-grid,
  .dashboard-grid-v2 {
    gap: 12px;
  }

  .dashboard-tab-panel {
    min-width: 0;
  }

  .dashboard-tab-panel.is-active {
    gap: 12px;
  }

  .table {
    font-size: 12px;
  }

  .table th,
  .table td {
    padding: 8px 6px;
    word-break: break-word;
  }

  .alert-preset-grid {
    justify-content: flex-start;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    flex-wrap: nowrap;
    padding-bottom: 6px;
  }

  .alert-preset-item {
    flex: 0 0 auto;
  }

  /* Touch: remove legacy 300ms tap delay where supported */
  button,
  .btn,
  .dashboard-tab,
  a.secondary {
    touch-action: manipulation;
  }

  button:not(.dashboard-tab):not(.setup-subtab),
  .btn {
    min-height: 44px;
    padding-left: 14px;
    padding-right: 14px;
  }

  /* Global header (terminal) — slightly tighter */
  .scc-terminal-body {
    padding: 16px !important;
  }

  .scc-terminal-brand-row {
    flex-direction: column;
    align-items: flex-start !important;
  }

  .scc-terminal-name {
    font-size: 22px !important;
  }

  .scc-terminal-ascii {
    font-size: 11px !important;
    overflow-x: auto;
    max-width: 100%;
  }

  .scc-header-links {
    margin-top: 12px !important;
  }

  .scc-link-group a {
    min-height: 40px;
    display: inline-flex;
    align-items: center;
  }

  /* Viewer / streamer license mini cards: stack on phone */
  .scc-mini-main {
    flex-direction: column !important;
    height: auto !important;
  }

  .scc-mini-photo {
    width: 100% !important;
    max-width: 100%;
    padding: 12px !important;
  }

  .scc-mini-photo-box {
    width: min(220px, 80vw) !important;
    height: min(220px, 80vw) !important;
  }

  .scc-mini-info {
    padding: 12px !important;
  }

  .scc-mini-name {
    font-size: 22px !important;
    white-space: normal !important;
  }

  .scc-mini-actions {
    width: 100% !important;
    border-left: none !important;
    border-top: 1px solid rgba(255, 255, 255, 0.08);
    flex-direction: row !important;
    flex-wrap: wrap;
    justify-content: center !important;
    padding: 12px !important;
  }

  .scc-mini-actions.scc-mini-actions--wide {
    width: 100% !important;
  }

  .scc-profile-license {
    max-width: 100%;
  }

  .scc-license-hero-outer {
    margin-left: -4px;
    margin-right: -4px;
  }

  .value-period-bar {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  .shoutout-two-col {
    grid-template-columns: 1fr !important;
  }

  /* Streamer dashboard: title + primary actions */
  .dashboard-header-top {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .dashboard-header-actions {
    width: 100%;
    justify-content: stretch;
  }

  .dashboard-header-actions > .secondary {
    flex: 1 1 calc(50% - 4px);
    min-width: 0;
  }

  /* My Account / viewer links: stack copy rows */
  .dashboard-link-block .row {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .dashboard-link-block .row > .secondary {
    width: 100%;
  }

  #viewerPageUrlField,
  #streamerProfileUrlField,
  #modSigninLinkField {
    max-width: 100% !important;
  }

  /* Section toolbars (search rows, filters) */
  .card .row[style*="flex-wrap"]:not(.dashboard-pager) {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .card .row[style*="flex-wrap"] input[type="search"],
  .card .row[style*="flex-wrap"] select[style*="min-width"] {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  #modTwitchUserId {
    min-width: 0 !important;
    width: 100% !important;
  }

  /* Pager (Prev/Next) stays one row */
  .row.dashboard-pager {
    flex-direction: row !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .dashboard-pager-actions {
    display: flex;
    flex-wrap: nowrap;
    gap: 8px;
  }

  /* Event alert OBS preview */
  #eventAlertPreviewFrame {
    height: min(45vh, 320px) !important;
    min-height: 220px !important;
    max-width: 100% !important;
  }

  /* Browse hub (viewer.html) */
  #viewerBrowseHub .row {
    flex-direction: column !important;
    align-items: stretch !important;
  }

  #viewerBrowseHub input[type="search"],
  #viewerBrowseHub select {
    min-width: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  /* Wide tables: horizontal scroll inside card */
  .card:has(table) {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  /* Full-screen modals: edge padding (notch / home indicator) */
  #marketplaceTestModal,
  #sccReportModal {
    padding: 12px !important;
    padding-left: max(12px, env(safe-area-inset-left)) !important;
    padding-right: max(12px, env(safe-area-inset-right)) !important;
    padding-bottom: max(12px, env(safe-area-inset-bottom)) !important;
  }

  .marketplace-test-card {
    max-height: 92vh !important;
  }

  /* Screen effect cards (viewer shop) */
  .screen-fx-item {
    min-width: 0 !important;
  }

  .screen-fx-item-actions {
    justify-content: flex-start;
  }

}

@media (max-width: 480px) {
  .container {
    padding: 10px 12px;
    padding-left: max(12px, env(safe-area-inset-left));
    padding-right: max(12px, env(safe-area-inset-right));
    padding-bottom: max(10px, env(safe-area-inset-bottom));
  }

  .dashboard-tabs .dashboard-tab,
  .profile-dashboard-tabs .dashboard-tab {
    padding: 8px 12px;
    font-size: 13px;
  }
}
