/**
 * app.css — Sistema de Roteiros de Criativos (Uélicon)
 * @dev-frontend · consome tokens.css (contrato do @dev-designer, NÃO editar tokens)
 *
 * Camadas (definidas em tokens.css):  @layer tokens, base, components, utilities;
 * Aqui declaramos `components` e `utilities`.
 *
 * Regra de ouro: componente NUNCA usa primitive nem valor literal de cor/tipo/espaço.
 * Sempre var(--color-*), var(--space-*), var(--badge-*), etc.
 */

/* Fontes self-host (woff2). Inter no app todo; Atkinson SÓ no teleprompter (P7). */
@font-face {
  font-family: "Inter";
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
  src: url("/assets/fonts/inter-var.woff2") format("woff2");
}

@layer components {
  /* =========================================================
     RESET base — box-sizing border-box + body sem margin.
     Sem isso, width:100% + padding (content-box) estourava a
     viewport no mobile (P1-4 do audit: scrollWidth 422 > 390 no
     dashboard, padding do .admin-content vazando). Reset universal
     mata essa classe inteira de bug.
     ========================================================= */
  *, *::before, *::after { box-sizing: border-box; }
  body { margin: 0; }

  /* =========================================================
     PRIMITIVOS DE UI — botões, campos, badges, chips
     ========================================================= */

  /* ---- Botões ---- */
  .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--space-2);
    min-height: var(--tap-min);
    padding: 0 var(--space-4);
    border: 1px solid transparent;
    border-radius: var(--radius-md);
    background: var(--color-surface);
    color: var(--color-text);
    font-family: inherit;
    font-size: var(--text-base);
    font-weight: 600;
    line-height: 1;
    cursor: pointer;
    transition: background var(--dur-fast), border-color var(--dur-fast),
      color var(--dur-fast);
    text-decoration: none;
    white-space: nowrap;
  }
  .btn:hover { background: var(--color-bg-subtle); }
  .btn[disabled],
  .btn[aria-busy="true"] { opacity: 0.6; cursor: not-allowed; }

  .btn--primary {
    background: var(--color-primary);
    color: var(--color-on-primary);
    border-color: var(--color-primary);
  }
  .btn--primary:hover { background: var(--color-primary-hover); border-color: var(--color-primary-hover); }
  .btn--primary:active { background: var(--color-primary-active); }

  .btn--ghost { background: transparent; border-color: transparent; color: var(--color-text-muted); }
  .btn--ghost:hover { background: var(--color-bg-subtle); color: var(--color-text); }

  .btn--outline { background: transparent; border-color: var(--color-border-strong); color: var(--color-text); }
  .btn--outline:hover { background: var(--color-bg-subtle); }

  .btn--danger { background: transparent; border-color: var(--color-border-strong); color: var(--color-danger); }
  .btn--danger:hover { background: color-mix(in oklch, var(--color-danger) 8%, transparent); }

  .btn--full { width: 100%; }
  .btn--sm { min-height: 32px; padding: 0 var(--space-3); font-size: var(--text-sm); }
  /* P1-5: no gravador (uso de pé, no tripé, com pressa) TODO toque é >=44px.
     Mantém a fonte pequena do --sm, só cresce a área de toque. Admin segue 32px (mouse). */
  [data-surface="gravador"] .btn--sm { min-height: var(--tap-min); }

  /* Botão ícone-only: garante 44px de área (F27) */
  .btn--icon {
    width: var(--tap-min);
    height: var(--tap-min);
    min-height: var(--tap-min);
    padding: 0;
    border-radius: var(--radius-md);
    background: transparent;
    border: 1px solid transparent;
    color: var(--color-text-muted);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
  }
  .btn--icon:hover { background: var(--color-bg-subtle); color: var(--color-text); }

  .icon { width: 18px; height: 18px; stroke-width: 2; flex-shrink: 0; }
  .icon--sm { width: 16px; height: 16px; }

  /* ---- Campos de formulário ---- */
  .field { display: flex; flex-direction: column; gap: var(--space-2); margin-bottom: var(--space-4); }
  .field__label { font-size: var(--text-sm); font-weight: 600; color: var(--color-text); }
  .field__hint { font-size: var(--text-xs); color: var(--color-text-subtle); }

  .input,
  .textarea,
  .select {
    width: 100%;
    min-height: var(--tap-min);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-md);
    background: var(--color-surface);
    color: var(--color-text);
    font-family: inherit;
    font-size: var(--text-base);
    line-height: var(--leading-base);
  }
  .textarea { min-height: 96px; resize: vertical; }
  .input:focus-visible,
  .textarea:focus-visible,
  .select:focus-visible { border-color: var(--color-primary); }
  .input--error { border-color: var(--color-danger); }
  .input::placeholder, .textarea::placeholder { color: var(--color-text-subtle); }

  /* ---- Badges de ESTADO (vocabulário ubíquo — tokens --badge-*) ---- */
  .badge {
    display: inline-flex;
    align-items: center;
    gap: var(--space-1);
    padding: 2px 8px;
    border-radius: var(--radius-pill);
    font-size: var(--text-sm);
    font-weight: 500;
    line-height: 1.4;
    white-space: nowrap;
    border: 1px solid transparent;
  }
  .badge .icon { width: 13px; height: 13px; }
  .badge--rascunho   { color: var(--badge-rascunho-text);   background: var(--badge-rascunho-bg); }
  .badge--disponivel { color: var(--badge-disponivel-text); background: var(--badge-disponivel-bg); }
  .badge--arquivado  { color: var(--badge-arquivado-text);  background: var(--badge-arquivado-bg); border-color: var(--badge-arquivado-border); }
  .badge--na-fila    { color: var(--badge-na-fila-text);    background: var(--badge-na-fila-bg); }
  .badge--gravado    { color: var(--badge-gravado-text);    background: var(--badge-gravado-bg); }
  .badge--pulado     { color: var(--badge-pulado-text);     background: var(--badge-pulado-bg); }
  .badge--editado    { color: var(--badge-editado-text);    background: var(--badge-editado-bg); }

  /* Chip Tipo (COMPLETO/COMPACTO) — outline informativo */
  .chip-tipo {
    display: inline-flex;
    align-items: center;
    padding: 1px 7px;
    border: 1px solid var(--color-border-strong);
    border-radius: var(--radius-sm);
    font-size: var(--text-xs);
    font-weight: 600;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    color: var(--color-text-muted);
  }

  /* Dot de tema (sempre com nome ao lado — P4) */
  .tema-dot {
    display: inline-block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
    background: var(--_tema-cor, var(--color-text-subtle));
  }
  .tema-label { display: inline-flex; align-items: center; gap: var(--space-2); }

  .modalidade { color: var(--color-text-subtle); font-size: var(--text-xs); }

  /* =========================================================
     ADMIN — shell, sidebar, conteúdo
     ========================================================= */
  .admin-shell { display: grid; grid-template-columns: 220px 1fr; min-height: 100vh; min-height: 100svh; }

  .sidebar {
    position: sticky;
    top: 0;
    align-self: start;
    height: 100vh;
    height: 100svh;
    background: var(--color-surface);
    border-right: 1px solid var(--color-border);
    padding: var(--space-5) var(--space-3);
    display: flex;
    flex-direction: column;
    gap: var(--space-1);
    overflow-y: auto;
  }
  .sidebar__brand { padding: 0 var(--space-3) var(--space-5); }
  .sidebar__brand-title { font-size: var(--text-lg); font-weight: 700; letter-spacing: -0.01em; }
  .sidebar__brand-sub { font-size: var(--text-xs); color: var(--color-text-subtle); }

  .nav-item {
    display: flex;
    align-items: center;
    gap: var(--space-3);
    min-height: var(--tap-min);
    padding: 0 var(--space-3);
    border-radius: var(--radius-md);
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: var(--text-base);
    font-weight: 500;
  }
  .nav-item:hover { background: var(--color-bg-subtle); color: var(--color-text); }
  .nav-item[aria-current="page"] { background: var(--color-bg-subtle); color: var(--color-text); font-weight: 600; }
  .nav-item[aria-current="page"] .icon { color: var(--color-primary); }

  .admin-main { display: flex; flex-direction: column; min-width: 0; }
  .topbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--space-4);
    padding: var(--space-5) var(--space-8);
    border-bottom: 1px solid var(--color-border);
    background: var(--color-bg);
    position: sticky;
    top: 0;
    z-index: 5;
  }
  .topbar__title { font-size: var(--text-xl); font-weight: 700; letter-spacing: -0.01em; }
  .admin-content { padding: var(--space-8); max-width: 1280px; width: 100%; }

  /* Dropdown user (topbar) — inline, ancorado, nunca modal central */
  .user-menu { position: relative; }
  .user-menu__panel {
    position: absolute;
    right: 0;
    top: calc(100% + var(--space-2));
    min-width: 200px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-md);
    padding: var(--space-2);
    z-index: 20;
  }
  .user-menu__item {
    display: flex; align-items: center; gap: var(--space-2);
    width: 100%; min-height: var(--tap-min); padding: 0 var(--space-3);
    border: none; background: transparent; border-radius: var(--radius-sm);
    color: var(--color-text); font: inherit; cursor: pointer; text-align: left;
  }
  .user-menu__item:hover { background: var(--color-bg-subtle); }

  /* ---- Toolbar de filtros ---- */
  .toolbar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--space-3);
    margin-bottom: var(--space-5);
  }
  .toolbar .input, .toolbar .select { width: auto; min-width: 160px; }
  .toolbar__search { flex: 1; min-width: 220px; }
  .toolbar__spacer { flex: 1; }

  /* =========================================================
     Tabela (admin) → vira cards <768px
     ========================================================= */
  .table-wrap { border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; background: var(--color-surface); }
  /* Mesmo visual da table-wrap, mas SEM o display:none de <768px — o dashboard de
     cobertura é a feature central e reorganiza (não some) no mobile (P1-3 audit). */
  .cobertura-wrap { border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); }
  .table { width: 100%; border-collapse: collapse; font-size: var(--text-base); }
  .table th {
    text-align: left;
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-xs);
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--color-text-subtle);
    background: var(--color-bg-subtle);
    border-bottom: 1px solid var(--color-border);
  }
  .table td { padding: var(--space-3) var(--space-4); border-bottom: 1px solid var(--color-border); vertical-align: middle; }
  .table tr:last-child td { border-bottom: none; }
  .table tbody tr { cursor: pointer; transition: background var(--dur-fast); }
  .table tbody tr:hover { background: var(--color-bg-subtle); }
  .table tbody tr:focus-visible { background: var(--color-bg-subtle); }
  td.num, th.num { font-variant-numeric: tabular-nums; white-space: nowrap; }
  .cell-gancho { max-width: 360px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .cell-estados { display: flex; flex-wrap: wrap; gap: var(--space-2); }

  .pagination { display: flex; align-items: center; justify-content: space-between; gap: var(--space-4); padding: var(--space-4); border-top: 1px solid var(--color-border); }
  .pagination__nav { display: flex; gap: var(--space-2); }
  .pagination__info { font-size: var(--text-sm); color: var(--color-text-muted); }

  /* Cards (mobile da tabela) */
  .roteiro-cards { display: none; flex-direction: column; gap: var(--space-3); }
  .roteiro-card-row {
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    padding: var(--space-4);
    cursor: pointer;
  }
  .roteiro-card-row__top { display: flex; align-items: center; gap: var(--space-3); margin-bottom: var(--space-2); }
  .roteiro-card-row__gancho { font-size: var(--text-base); color: var(--color-text); margin-bottom: var(--space-2); }
  .roteiro-card-row__badges { display: flex; flex-wrap: wrap; gap: var(--space-2); }

  /* =========================================================
     DRAWER lateral (admin) — NUNCA modal central (P6)
     ========================================================= */
  .drawer-overlay {
    position: fixed;
    inset: 0;
    background: oklch(0 0 0 / 0.32);
    z-index: 40;
    opacity: 0;
    transition: opacity var(--dur-base) var(--ease-out);
  }
  .drawer-overlay[data-open="true"] { opacity: 1; }
  .drawer {
    position: fixed;
    top: 0;
    right: 0;
    height: 100vh;
    height: 100svh;
    width: min(480px, 100vw);
    background: var(--color-surface);
    border-left: 1px solid var(--color-border);
    box-shadow: var(--shadow-md);
    z-index: 41;
    display: flex;
    flex-direction: column;
    transform: translateX(100%);
    transition: transform var(--dur-base) var(--ease-out);
  }
  .drawer[data-open="true"] { transform: translateX(0); }
  .drawer__head {
    display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
    padding: var(--space-5) var(--space-6); border-bottom: 1px solid var(--color-border);
  }
  .drawer__title { font-size: var(--text-lg); font-weight: 700; }
  .drawer__body { flex: 1; overflow-y: auto; padding: var(--space-6); }
  .drawer__foot {
    display: flex; flex-wrap: wrap; gap: var(--space-2);
    padding: var(--space-4) var(--space-6);
    border-top: 1px solid var(--color-border);
    background: var(--color-bg);
  }

  .meta-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); margin-bottom: var(--space-5); }
  .meta-item__label { font-size: var(--text-xs); color: var(--color-text-subtle); text-transform: uppercase; letter-spacing: 0.04em; }
  .meta-item__value { font-size: var(--text-base); color: var(--color-text); }

  .roteiro-corpo { white-space: pre-wrap; font-size: var(--text-base); line-height: var(--leading-base); color: var(--color-text); }

  /* =========================================================
     Banners e alertas
     ========================================================= */
  .banner {
    display: flex; align-items: flex-start; gap: var(--space-3);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    background: var(--color-bg-subtle);
    border: 1px solid var(--color-border);
    font-size: var(--text-base);
    margin-bottom: var(--space-5);
  }
  .banner__icon { color: var(--color-text-muted); margin-top: 2px; }
  .banner--alerta { background: var(--badge-pulado-bg); border-color: transparent; color: var(--badge-pulado-text); }
  .banner--alerta .banner__icon { color: var(--badge-pulado-text); }

  /* Erro inline em 3 partes (F26) */
  .inline-error {
    display: flex; align-items: flex-start; gap: var(--space-2);
    padding: var(--space-3) var(--space-4);
    border-radius: var(--radius-md);
    background: color-mix(in oklch, var(--color-danger) 8%, transparent);
    color: var(--color-danger);
    font-size: var(--text-sm);
    line-height: var(--leading-base);
    margin: var(--space-3) 0;
  }
  .inline-error a { color: inherit; font-weight: 600; }

  /* =========================================================
     Estados de fetch (skeleton / empty / error) — F21
     ========================================================= */
  .skeleton { background: linear-gradient(90deg, var(--color-bg-subtle) 25%, var(--color-border) 50%, var(--color-bg-subtle) 75%); background-size: 200% 100%; animation: sk 1.4s ease-in-out infinite; border-radius: var(--radius-sm); }
  @keyframes sk { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }
  .skeleton-row { height: 44px; margin-bottom: var(--space-2); }

  .state-empty, .state-error {
    display: flex; flex-direction: column; align-items: center; justify-content: center;
    gap: var(--space-3); text-align: center;
    padding: var(--space-12) var(--space-6);
    color: var(--color-text-muted);
  }
  .state-empty__title, .state-error__title { font-size: var(--text-lg); font-weight: 600; color: var(--color-text); }
  .state-empty__hint, .state-error__hint { font-size: var(--text-base); max-width: 38ch; }

  /* =========================================================
     Dashboard de cobertura — barras CSS puras (sem chart lib)
     ========================================================= */
  .resumo-cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: var(--space-4); margin-bottom: var(--space-6); }
  .resumo-card { border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); padding: var(--space-4) var(--space-5); }
  .resumo-card__valor { font-size: var(--text-2xl); font-weight: 700; font-variant-numeric: tabular-nums; }
  .resumo-card__label { font-size: var(--text-sm); color: var(--color-text-muted); }

  .cobertura-tema { display: grid; grid-template-columns: 200px 1fr 120px; align-items: center; gap: var(--space-4); padding: var(--space-3) 0; border-bottom: 1px solid var(--color-border); }
  .cobertura-tema__label { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-base); }
  .cobertura-bar { height: 18px; border-radius: var(--radius-pill); background: var(--color-bg-subtle); overflow: hidden; display: flex; }
  .cobertura-seg { height: 100%; transform-origin: left; transition: width var(--dur-base) var(--ease-out); }
  .cobertura-seg--gravado { background: var(--bar-gravado); }
  .cobertura-seg--na-fila { background: var(--bar-na-fila); }
  .cobertura-seg--disponivel { background: var(--bar-disponivel); }
  .cobertura-nums { font-size: var(--text-sm); font-variant-numeric: tabular-nums; color: var(--color-text-muted); text-align: right; white-space: nowrap; }
  .cobertura-legenda { display: flex; flex-wrap: wrap; gap: var(--space-4); margin-top: var(--space-5); font-size: var(--text-sm); color: var(--color-text-muted); }
  .legenda-item { display: inline-flex; align-items: center; gap: var(--space-2); }
  .legenda-swatch { width: 12px; height: 12px; border-radius: 3px; }

  /* =========================================================
     Fila builder (2 colunas)
     ========================================================= */
  .fila-builder { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
  .fila-col { border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: var(--color-surface); display: flex; flex-direction: column; min-height: 320px; }
  .fila-col__head { padding: var(--space-4); border-bottom: 1px solid var(--color-border); display: flex; flex-direction: column; gap: var(--space-3); }
  .fila-col__title { font-size: var(--text-base); font-weight: 600; }
  .fila-col__body { padding: var(--space-3); overflow-y: auto; display: flex; flex-direction: column; gap: var(--space-2); }

  .fila-row {
    display: flex; align-items: center; gap: var(--space-3);
    padding: var(--space-2) var(--space-3);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    background: var(--color-bg);
    font-size: var(--text-base);
  }
  .fila-row__handle { cursor: grab; color: var(--color-text-subtle); touch-action: none; }
  .fila-row__ordem { font-variant-numeric: tabular-nums; color: var(--color-text-subtle); min-width: 1.5em; }
  .fila-row__num { font-variant-numeric: tabular-nums; font-weight: 600; }
  .fila-row__spacer { flex: 1; }
  .fila-row[data-status="pulado"] { opacity: 0.8; border-style: dashed; }
  .fila-row[data-status="gravado"] { opacity: 0.6; }
  .fila-group-label { font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.04em; color: var(--color-text-subtle); margin: var(--space-3) 0 var(--space-1); }

  /* =========================================================
     GRAVADOR (mobile-first, dark) — fila + cards
     ========================================================= */
  .grav-app { max-width: 640px; margin: 0 auto; min-height: 100vh; min-height: 100svh; display: flex; flex-direction: column; }
  .grav-header { padding: var(--space-6) var(--space-5) var(--space-4); }
  .grav-header__ola { font-size: var(--text-lg); font-weight: 700; }
  .grav-header__contador { font-size: var(--text-md); color: var(--color-text-muted); font-variant-numeric: tabular-nums; margin-top: var(--space-1); }
  .progress-geral { height: 6px; border-radius: var(--radius-pill); background: var(--color-bg-subtle); overflow: hidden; margin-top: var(--space-3); }
  .progress-geral__fill { height: 100%; background: var(--color-primary); transition: width var(--dur-base) var(--ease-out); }
  .progress-label { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-2); font-variant-numeric: tabular-nums; }

  .grav-body { flex: 1; padding: 0 var(--space-5) var(--space-12); }
  .tema-group__head {
    position: sticky; top: 0; z-index: 2;
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-3) 0;
    background: var(--color-bg);
    font-size: var(--text-sm); font-weight: 700; text-transform: uppercase; letter-spacing: 0.03em;
  }
  .grav-card {
    display: block;
    width: 100%;
    text-align: left;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-surface);
    padding: var(--space-4);
    margin-bottom: var(--space-3);
    min-height: 72px;
    color: inherit;
    cursor: pointer;
    font: inherit;
  }
  .grav-card:hover { background: var(--color-bg-subtle); }
  .grav-card__meta { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-2); font-variant-numeric: tabular-nums; }
  .grav-card__gancho { font-size: var(--text-md); line-height: var(--leading-tight); display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
  .grav-card__badges { margin-top: var(--space-2); display: flex; gap: var(--space-2); flex-wrap: wrap; }

  /* Acordeões (pulados / já gravados) */
  .acordeon { border-top: 1px solid var(--color-border); }
  .acordeon__trigger {
    display: flex; align-items: center; gap: var(--space-2);
    width: 100%; min-height: var(--tap-min);
    background: transparent; border: none; color: var(--color-text-muted);
    font: inherit; font-weight: 600; cursor: pointer; padding: var(--space-3) 0;
  }
  .acordeon__chevron { transition: transform var(--dur-fast); }
  .acordeon[data-open="true"] .acordeon__chevron { transform: rotate(90deg); }
  .acordeon__body { padding-bottom: var(--space-4); display: flex; flex-direction: column; gap: var(--space-2); }
  .acordeon-item { display: flex; align-items: center; gap: var(--space-3); padding: var(--space-2) var(--space-3); border: 1px solid var(--color-border); border-radius: var(--radius-md); }

  /* =========================================================
     TELEPROMPTER — o coração
     ========================================================= */
  .tp { display: flex; flex-direction: column; min-height: 100vh; min-height: 100svh; background: var(--tp-bg); }
  .tp-header {
    position: sticky; top: 0; z-index: 3;
    display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
    min-height: 48px; padding: var(--space-2) var(--space-4);
    background: var(--tp-bg); color: var(--tp-muted);
    border-bottom: 1px solid var(--color-border);
    transition: transform var(--dur-base) var(--ease-out);
  }
  .tp-header[data-hidden="true"] { transform: translateY(-100%); }
  .tp-header__back { display: inline-flex; align-items: center; gap: var(--space-1); color: var(--tp-muted); text-decoration: none; min-height: var(--tap-min); min-width: var(--tap-min); }
  .tp-header__meta { font-size: var(--text-sm); font-variant-numeric: tabular-nums; text-align: center; flex: 1; }
  .tp-header__meta small { display: block; font-size: var(--text-xs); }
  .tp-stepper { display: flex; align-items: center; gap: var(--space-1); }
  .tp-stepper__btn {
    width: var(--tap-min); height: var(--tap-min);
    border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
    background: transparent; color: var(--tp-muted); font: inherit; font-weight: 700; font-size: var(--text-base);
    cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
  }
  .tp-stepper__btn:hover { background: var(--color-bg-subtle); }
  .tp-stepper__btn[disabled] { opacity: 0.4; cursor: not-allowed; }

  /* Faixa "Editado após enviado" (G1) */
  .tp-editado {
    display: flex; align-items: center; gap: var(--space-2);
    padding: var(--space-2) var(--space-4);
    background: var(--badge-editado-bg); color: var(--badge-editado-text);
    font-size: var(--text-sm); font-weight: 500;
  }

  /* padding-bottom 140px: cobre a barra fixa de 2 linhas (~112px) + safe-area (P0-2) */
  .tp-scroll { flex: 1; overflow-y: auto; scroll-behavior: smooth; padding: var(--space-8) var(--space-5) 140px; }
  .tp-content { max-width: var(--tp-measure); margin: 0 auto; }

  .tp-gancho {
    font-family: var(--tp-font);
    font-size: calc(var(--tp-size) * var(--tp-gancho-scale));
    line-height: var(--tp-leading);
    font-weight: 700;
    color: var(--tp-gancho);
    border-left: 3px solid var(--tp-gancho);
    padding-left: var(--space-4);
    margin-bottom: var(--space-8);
  }
  .tp-corpo {
    font-family: var(--tp-font);
    font-size: var(--tp-size);
    line-height: var(--tp-leading);
    color: var(--tp-text);
  }
  .tp-corpo p { margin-block: 0.6em; }
  /* Compacto = bullets de fala-guia */
  .tp-corpo--compacto { list-style: none; padding: 0; }
  .tp-corpo--compacto li {
    position: relative;
    padding-left: 1.2em;
    margin-block: var(--tp-bullet-gap);
  }
  .tp-corpo--compacto li::before { content: "–"; position: absolute; left: 0; color: var(--tp-gancho); font-weight: 700; }

  /* Pill [ pausa ] — inserida via DOM (textContent), nunca innerHTML (F16) */
  .tp-pausa {
    display: inline-flex; align-items: center;
    background: var(--tp-pausa-bg); color: var(--tp-pausa-text);
    border-radius: var(--radius-pill);
    font-size: 0.55em; letter-spacing: 0.05em; font-variant-caps: small-caps;
    padding: 0.1em 0.6em; margin: 0 0.2em; vertical-align: middle; white-space: nowrap;
  }

  /* Bloco CTA do roteiro */
  .tp-cta {
    margin-top: var(--space-8);
    border: 1.5px dashed var(--tp-cta-border);
    border-radius: var(--radius-lg);
    padding: var(--space-5);
  }
  .tp-cta__eyebrow { font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; color: var(--tp-muted); margin-bottom: var(--space-2); }
  .tp-cta__text { font-family: var(--tp-font); font-size: var(--tp-size); line-height: var(--tp-leading); color: var(--tp-text); }

  /* Barra de ação fixa (✓ Gravei / Pular) */
  .tp-actions {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 4;
    display: flex; gap: var(--space-3);
    padding: var(--space-3) var(--space-5);
    padding-bottom: max(var(--space-3), env(safe-area-inset-bottom));
    background: var(--tp-bg);
    border-top: 1px solid var(--color-border);
    max-width: 640px; margin: 0 auto;
  }

  /* Erro inline das ações (P1-6) — faixa acima da barra fixa, fundo opaco escuro.
     z-index 6 > barras de ação (4) pra ficar sempre legível. */
  .tp-erro-acao {
    position: fixed; left: 0; right: 0; z-index: 6;
    bottom: calc(72px + env(safe-area-inset-bottom));
    max-width: 640px; margin: 0 auto;
    display: flex; align-items: flex-start; gap: var(--space-2);
    padding: var(--space-3) var(--space-5);
    background: color-mix(in oklch, var(--color-danger) 22%, var(--tp-bg));
    color: oklch(0.985 0.002 150);
    font-size: var(--text-md); line-height: var(--leading-base);
    border-top: 1px solid color-mix(in oklch, var(--color-danger) 45%, transparent);
  }
  .tp-erro-acao .icon { flex: none; margin-top: 2px; color: var(--color-danger); }
  .btn-gravei {
    flex: 1;
    min-height: var(--tap-cta);
    border: none; border-radius: var(--radius-md);
    background: var(--color-primary); color: var(--color-on-primary);
    font: inherit; font-size: var(--text-lg); font-weight: 700;
    display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
    cursor: pointer;
  }
  .btn-gravei[aria-busy="true"] { opacity: 0.7; }
  .btn-pular {
    min-height: var(--tap-cta); min-width: 88px;
    border: 1px solid var(--color-border-strong); border-radius: var(--radius-md);
    background: transparent; color: var(--color-text-muted);
    font: inherit; font-weight: 600; cursor: pointer;
  }

  /* Barra inline pós-gravado.
     P0-2 (audit 2026-06-12): a barra é position:fixed, então o fundo NÃO pode
     ser translúcido (--badge-gravado-bg tem alpha 0.14 no dark) — o corpo do
     roteiro em 32px vazava por trás e deixava "✓ Gravado!" ilegível. Fix do
     designer: tom do badge composto OPACO sobre o fundo do teleprompter. */
  .tp-gravado-bar {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 4;
    max-width: 640px; margin: 0 auto;
    padding: var(--space-4) var(--space-5);
    padding-bottom: max(var(--space-4), env(safe-area-inset-bottom));
    background: color-mix(in oklch, oklch(0.840 0.155 150) 14%, var(--tp-bg));
    border-top: 1px solid var(--color-border);
  }
  .tp-gravado-bar__top { display: flex; align-items: center; justify-content: space-between; gap: var(--space-3); margin-bottom: var(--space-3); }
  .tp-gravado-bar__msg { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--badge-gravado-text); font-weight: 700; }

  /* =========================================================
     BOTTOM-SHEET (gravador) — pular, nunca modal central (P6)
     ========================================================= */
  .sheet-overlay {
    position: fixed; inset: 0; background: oklch(0 0 0 / 0.5);
    z-index: 50; opacity: 0; transition: opacity var(--dur-base) var(--ease-out);
  }
  .sheet-overlay[data-open="true"] { opacity: 1; }
  .bottom-sheet {
    position: fixed; left: 0; right: 0; bottom: 0; z-index: 51;
    max-width: 640px; margin: 0 auto;
    background: var(--color-surface);
    border-radius: var(--radius-lg) var(--radius-lg) 0 0;
    box-shadow: var(--shadow-sheet);
    padding: var(--space-5);
    padding-bottom: max(var(--space-5), env(safe-area-inset-bottom));
    transform: translateY(100%);
    transition: transform var(--dur-base) var(--ease-out);
  }
  .bottom-sheet[data-open="true"] { transform: translateY(0); }
  .bottom-sheet__handle { width: 36px; height: 4px; border-radius: var(--radius-pill); background: var(--color-border-strong); margin: 0 auto var(--space-4); }
  .bottom-sheet__title { font-size: var(--text-lg); font-weight: 700; margin-bottom: var(--space-2); }
  .bottom-sheet__sub { color: var(--color-text-muted); margin-bottom: var(--space-5); }
  .bottom-sheet__actions { display: flex; gap: var(--space-3); }

  /* =========================================================
     LOGIN (admin) + tela de erro (gravador)
     ========================================================= */
  .login-shell { display: flex; align-items: center; justify-content: center; min-height: 100vh; min-height: 100svh; padding: var(--space-5); }
  .login-card { width: 100%; max-width: 380px; background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); box-shadow: var(--shadow-md); padding: var(--space-8); }
  .login-brand { text-align: center; margin-bottom: var(--space-6); }
  .login-brand__mark { display: inline-flex; align-items: center; justify-content: center; width: 44px; height: 44px; border-radius: var(--radius-md); background: var(--color-primary); color: var(--color-on-primary); font-weight: 700; font-size: var(--text-lg); margin-bottom: var(--space-3); }
  .login-brand__title { font-size: var(--text-xl); font-weight: 700; }
  .login-brand__sub { font-size: var(--text-sm); color: var(--color-text-subtle); }
  .login-foot { text-align: center; font-size: var(--text-xs); color: var(--color-text-subtle); margin-top: var(--space-6); }

  .tela-mensagem { display: flex; flex-direction: column; align-items: center; justify-content: center; text-align: center; min-height: 100vh; min-height: 100svh; padding: var(--space-8); gap: var(--space-4); }
  .tela-mensagem__titulo { font-size: var(--text-xl); font-weight: 700; }
  .tela-mensagem__texto { color: var(--color-text-muted); max-width: 34ch; }
}

@layer utilities {
  .visually-hidden {
    position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; border: 0;
  }
  .muted { color: var(--color-text-muted); }
  .subtle { color: var(--color-text-subtle); }
  .text-sm { font-size: var(--text-sm); }
  .mt-2 { margin-top: var(--space-2); }
  .mt-4 { margin-top: var(--space-4); }
  .mb-4 { margin-bottom: var(--space-4); }
  .flex { display: flex; }
  .gap-2 { gap: var(--space-2); }
  .gap-3 { gap: var(--space-3); }
  .items-center { align-items: center; }
  .between { justify-content: space-between; }
  .grow { flex: 1; }

  /* Responsivo: tabela admin vira cards <768px */
  @media (max-width: 768px) {
    .admin-shell { grid-template-columns: minmax(0, 1fr); }
    /* grid/flex item não pode estourar a viewport (min-width:auto é o default que vaza) */
    .admin-main, .admin-content { min-width: 0; max-width: 100%; }
    .sidebar {
      position: fixed; left: 0; top: 0; z-index: 45;
      width: 260px; transform: translateX(-100%);
      transition: transform var(--dur-base) var(--ease-out);
    }
    .sidebar[data-open="true"] { transform: translateX(0); box-shadow: var(--shadow-md); }
    .admin-content { padding: var(--space-5); }
    /* P1-4: topbar não comprime no 390 (min-content ~414px) e gera scroll lateral
       da página. Permite quebrar e dá ellipsis no título; nada sangra pra fora. */
    .topbar { padding: var(--space-4) var(--space-5); flex-wrap: wrap; }
    .topbar > * { min-width: 0; }
    .topbar__title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
    .topbar .select { max-width: 9rem; }
    .table-wrap { display: none; }
    .roteiro-cards { display: flex; }
    .fila-builder { grid-template-columns: 1fr; }
    /* P1-7: filtro da coluna "Disponíveis" não comprime no 390 (select + input,
       min-content ~410px) → scroll lateral. Mesma solução da topbar (P1-4):
       quebra e deixa os campos encolherem. Nenhum token/visual alterado. */
    .fila-col, .fila-col__head, .fila-col__body { min-width: 0; }
    .fila-col__head .flex { flex-wrap: wrap; min-width: 0; }
    .fila-col__head .input, .fila-col__head .select { flex: 1 1 8rem; min-width: 0; }
    .cobertura-tema { grid-template-columns: 1fr; gap: var(--space-2); }
    .cobertura-nums { text-align: left; }
    .meta-grid { grid-template-columns: 1fr; }
    .drawer { width: 100vw; }
  }
  @media (min-width: 769px) {
    .only-mobile { display: none; }
    .menu-toggle { display: none; }
  }
}
