/* ═══════════════════════════════════════════════════════════════
   ESTÚDIO LASER PRO — UI PRIMITIVES  v1.1
   Componentes canônicos do sistema. Toda feature usa estas classes.
   Carregar SEMPRE depois de design-tokens.css.

   Regras (ver CLAUDE.md):
   - Hover muda só cor. Sem translate, sem mudança de sombra animada.
   - Tudo herda dos tokens. Nada hardcoded aqui.
   ═══════════════════════════════════════════════════════════════ */


/* ───────────────────────────────────────────────────────────────
   BOTÕES
   .btn é a base. Variantes alteram apenas cor e ênfase.
   ─────────────────────────────────────────────────────────────── */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  height: 40px;
  padding: 0 16px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-mid);
  background: rgba(255, 255, 255, .04);
  color: var(--text);
  font-family: var(--ui-font);
  font-size: var(--text-md);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  transition:
    background-color var(--ease-hover),
    border-color var(--ease-hover),
    color var(--ease-hover),
    opacity var(--ease-hover);
}

.btn:hover {
  background: rgba(255, 255, 255, .08);
  border-color: var(--border-hi);
}

.btn:active {
  filter: brightness(.92);
}

.btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.btn:disabled,
.btn[aria-disabled="true"] {
  opacity: .5;
  pointer-events: none;
}

/* — Tamanhos — */

.btn--sm {
  height: 32px;
  padding: 0 12px;
  font-size: var(--text-sm);
  border-radius: var(--radius-sm);
}

.btn--lg {
  height: 48px;
  padding: 0 22px;
  font-size: var(--text-lg);
}

/* Botão de ícone puro (quadrado) */
.btn--icon {
  width: 40px;
  padding: 0;
}
.btn--icon.btn--sm { width: 32px; }
.btn--icon.btn--lg { width: 48px; }


/* — Variantes (cor / ênfase) — */

/* Primária: ouro sólido. CTA único do contexto. Brilho interno estático. */
.btn--primary {
  background: var(--gold);
  border-color: var(--gold);
  color: #1a130a;
  font-weight: 700;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .22);
}
.btn--primary:hover {
  background: var(--gold-2);
  border-color: var(--gold-2);
}

/* Gold-soft: dourado tintado. Para ações importantes mas não únicas. */
.btn--gold-soft {
  background: rgba(var(--gold-rgb), .12);
  border-color: rgba(var(--gold-rgb), .42);
  color: var(--gold-hi);
}
.btn--gold-soft:hover {
  background: rgba(var(--gold-rgb), .20);
  border-color: rgba(var(--gold-rgb), .60);
}

/* Acento: teal. Confirmar, aplicar, ativar. */
.btn--accent {
  background: rgba(var(--accent-rgb), .14);
  border-color: rgba(var(--accent-rgb), .42);
  color: var(--accent-hi);
}
.btn--accent:hover {
  background: rgba(var(--accent-rgb), .22);
  border-color: rgba(var(--accent-rgb), .60);
}

/* Acento tracejado: convite secundario para criar outro item no contexto. */
.btn--accent-dashed {
  background: rgba(var(--accent-rgb), .10);
  border-color: rgba(var(--accent-rgb), .42);
  border-style: dashed;
  color: var(--accent-hi);
}
.btn--accent-dashed:hover {
  background: rgba(var(--accent-rgb), .18);
  border-color: rgba(var(--accent-rgb), .60);
}

/* Ghost: transparente. Cancelar, terciárias. */
.btn--ghost {
  background: transparent;
  border-color: transparent;
  color: var(--muted);
}
.btn--ghost:hover {
  background: rgba(255, 255, 255, .05);
  color: var(--text);
}

/* Danger: vermelho discreto. Excluir, remover. */
.btn--danger {
  background: rgba(212, 85, 85, .12);
  border-color: rgba(212, 85, 85, .40);
  color: #ed8a8a;
}
.btn--danger:hover {
  background: rgba(212, 85, 85, .20);
  border-color: rgba(212, 85, 85, .60);
}

/* Estado ativo persistente (toggle ligado, aba selecionada) */
.btn.is-active,
.btn[aria-pressed="true"] {
  background: rgba(var(--accent-rgb), .14);
  border-color: rgba(var(--accent-rgb), .42);
  color: var(--accent-hi);
}


/* ───────────────────────────────────────────────────────────────
   TILE  (menu do topo, menu lateral; "ícone em cima, label embaixo")
   ─────────────────────────────────────────────────────────────── */

.tile {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  width: auto;
  min-width: 76px;
  max-width: 140px;
  min-height: 60px;
  padding: 6px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-mid);
  background: rgba(255, 255, 255, .035);
  color: var(--gold-2);
  font-family: var(--ui-font);
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  user-select: none;
  transition:
    background-color var(--ease-hover),
    border-color var(--ease-hover),
    color var(--ease-hover);
}

.tile__icon {
  width: 26px;
  height: 26px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: inherit;
  flex: 0 0 auto;
}

.tile__icon svg {
  width: 100%;
  height: 100%;
  display: block;
  fill: currentColor;
}

.tile__icon img {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

/* Chip: pillow claro atrás do ícone — usado quando o SVG vem como <img>
   com cores embutidas e precisa de um fundo claro para ser legível. */
.tile__icon--chip {
  width: 30px;
  height: 30px;
  padding: 4px;
  border-radius: 9px;
  background: linear-gradient(160deg, #ffffff 0%, #ede8df 100%);
  border: 1px solid rgba(255, 255, 255, .18);
  color: #1a1a1a;
}
.tile--sm .tile__icon--chip {
  width: 24px;
  height: 24px;
  padding: 3px;
  border-radius: 7px;
}

.tile__label {
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.15;
  color: var(--text);
  /* Nome SEMPRE visível: nunca truncar, nunca esconder com ellipsis. */
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
  word-break: break-word;
  max-width: 100%;
}

.tile:hover {
  background: rgba(var(--gold-rgb), .08);
  border-color: rgba(var(--gold-rgb), .35);
}

.tile:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.tile:disabled,
.tile[aria-disabled="true"] {
  opacity: .5;
  pointer-events: none;
}

/* Tile ativo (rota atual, ferramenta ligada) */
.tile.is-active,
.tile[aria-pressed="true"] {
  background: rgba(var(--accent-rgb), .14);
  border-color: rgba(var(--accent-rgb), .42);
  color: var(--accent-hi);
}
.tile.is-active .tile__label,
.tile[aria-pressed="true"] .tile__label {
  color: var(--accent-hi);
}

/* Variantes tintadas — ênfase visual para ações destacadas. */
.tile--accent {
  border-color: rgba(var(--accent-rgb), .35);
  background: rgba(var(--accent-rgb), .10);
}
.tile--accent:hover {
  background: rgba(var(--accent-rgb), .18);
  border-color: rgba(var(--accent-rgb), .55);
}

.tile--gold {
  border-color: rgba(var(--gold-rgb), .42);
  background: rgba(var(--gold-rgb), .14);
}
.tile--gold:hover {
  background: rgba(var(--gold-rgb), .22);
  border-color: rgba(var(--gold-rgb), .60);
}

.tile--gold-soft {
  border-color: rgba(var(--gold-rgb), .30);
  background: rgba(var(--gold-rgb), .08);
}
.tile--gold-soft:hover {
  background: rgba(var(--gold-rgb), .14);
  border-color: rgba(var(--gold-rgb), .48);
}

/* Tamanhos */
.tile--sm {
  width: auto;
  min-width: 56px;
  max-width: 100px;
  min-height: 48px;
  padding: 4px 8px;
  gap: 4px;
}
.tile--sm .tile__icon { width: 20px; height: 20px; }
.tile--sm .tile__label { font-size: var(--text-2xs); }

.tile--lg {
  width: auto;
  min-width: 96px;
  max-width: 160px;
  min-height: 76px;
  padding: 8px 12px;
  gap: 8px;
}
.tile--lg .tile__icon { width: 32px; height: 32px; }

/* Tile "full": preenche a largura do contêiner pai (menus laterais verticais). */
.tile--full {
  width: 100%;
  min-width: 0;
  max-width: none;
  min-height: 76px;
  padding: 8px 6px;
  gap: 8px;
}


/* ───────────────────────────────────────────────────────────────
   CAMPOS DE FORMULÁRIO
   ─────────────────────────────────────────────────────────────── */

.input,
.select,
.textarea {
  display: block;
  width: 100%;
  height: 40px;
  padding: 0 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-mid);
  background: rgba(255, 255, 255, .04);
  color: var(--text);
  font-family: var(--ui-font);
  font-size: var(--text-md);
  font-weight: 400;
  line-height: 1;
  outline: none;
  transition:
    background-color var(--ease-hover),
    border-color var(--ease-hover),
    box-shadow var(--ease-hover);
}

.textarea {
  height: auto;
  min-height: 88px;
  padding: 10px 12px;
  line-height: 1.45;
  resize: vertical;
}

.input::placeholder,
.textarea::placeholder {
  color: var(--muted-2);
}

.input:hover,
.select:hover,
.textarea:hover {
  border-color: var(--border-hi);
}

.input:focus-visible,
.select:focus-visible,
.textarea:focus-visible {
  border-color: rgba(var(--accent-rgb), .65);
  box-shadow: 0 0 0 3px rgba(var(--accent-rgb), .15);
}

.input:disabled,
.select:disabled,
.textarea:disabled {
  opacity: .5;
  pointer-events: none;
}

/* Tamanho compacto */
.input--sm,
.select--sm {
  height: 32px;
  padding: 0 10px;
  font-size: var(--text-sm);
  border-radius: var(--radius-sm);
}

/* Wrapper label+input para espaçamento consistente */
.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}


/* ───────────────────────────────────────────────────────────────
   LABEL  (rótulo acima de campo)
   KICKER (uppercase pequeno, categoria/seção)
   ─────────────────────────────────────────────────────────────── */

.label {
  display: block;
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--muted);
  letter-spacing: 0;
}

.kicker {
  font-size: var(--text-2xs);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--gold-2);
}


/* ───────────────────────────────────────────────────────────────
   CARD  (container de conteúdo elevado)
   ─────────────────────────────────────────────────────────────── */

.card {
  background: var(--panel);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}

.card--elevated {
  background: var(--panel-2);
  box-shadow: var(--shadow-md);
}

.card__header {
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--border-lo);
}

.card__body {
  padding: 16px 20px;
}

.card__footer {
  padding: 12px 20px;
  border-top: 1px solid var(--border-lo);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.card__title {
  margin: 0;
  font-family: var(--ui-font);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0;
}

/* Variante display: usa serif. Só para títulos editoriais. */
.card__title--display {
  font-family: var(--title-font);
}

.card__subtitle {
  margin: 4px 0 0;
  font-size: var(--text-sm);
  font-weight: 400;
  color: var(--muted);
}


/* ───────────────────────────────────────────────────────────────
   BADGE / PILL
   ─────────────────────────────────────────────────────────────── */

.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 22px;
  padding: 0 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-mid);
  background: rgba(255, 255, 255, .04);
  color: var(--muted);
  font-size: var(--text-2xs);
  font-weight: 600;
  letter-spacing: 0;
  white-space: nowrap;
}

.badge--gold    { color: var(--gold-hi);   border-color: rgba(var(--gold-rgb), .42);   background: rgba(var(--gold-rgb), .12); }
.badge--accent  { color: var(--accent-hi); border-color: rgba(var(--accent-rgb), .42); background: rgba(var(--accent-rgb), .12); }
.badge--success { color: var(--success);   border-color: rgba(76, 175, 80, .42);       background: rgba(76, 175, 80, .12); }
.badge--danger  { color: #ed8a8a;          border-color: rgba(212, 85, 85, .42);       background: rgba(212, 85, 85, .12); }


/* ───────────────────────────────────────────────────────────────
   MODAL SHELL  (container; conteúdo livre)
   ─────────────────────────────────────────────────────────────── */

.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--overlay-medium);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
}

.modal-shell {
  background: var(--panel-3);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-lg);
  max-width: min(960px, calc(100vw - 32px));
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.modal-shell__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 20px 24px;
  border-bottom: 1px solid var(--border-lo);
}

.modal-shell__title {
  margin: 0;
  font-family: var(--ui-font);
  font-size: var(--text-xl);
  font-weight: 700;
  letter-spacing: 0;
  color: var(--text);
}

.modal-shell__body {
  padding: 20px 24px;
  overflow: auto;
}

.modal-shell__footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 16px 24px;
  border-top: 1px solid var(--border-lo);
}


/* ───────────────────────────────────────────────────────────────
   TOOLBAR  (barra horizontal de ações)
   ─────────────────────────────────────────────────────────────── */

.toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-mid);
  background: var(--panel);
}

.toolbar__sep {
  width: 1px;
  height: 24px;
  background: var(--border-mid);
  margin: 0 4px;
}

.toolbar__spacer { flex: 1; }


/* ───────────────────────────────────────────────────────────────
   DIVIDERS / SCROLLBAR  (consistência fina)
   ─────────────────────────────────────────────────────────────── */

.divider {
  height: 1px;
  background: var(--border-lo);
  margin: 16px 0;
}

/* Scrollbar padrão para contêineres com .scroll-y */
.scroll-y {
  overflow-y: auto;
  /* Firefox */
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, .12) transparent;
}
/* WebKit (Chrome / Edge / Safari) */
.scroll-y::-webkit-scrollbar { width: 8px; }
.scroll-y::-webkit-scrollbar-track { background: transparent; }
.scroll-y::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, .12);
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
}
.scroll-y::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, .20);
  background-clip: padding-box;
}

/* ─────────────────────────────────────────────────────────────────
   .lp-mini-uploader — primitiva compacta de upload
   ─────────────────────────────────────────────────────────────────
   Variante reduzida da drop-zone do módulo Remover Fundo, dimensionada
   para caber dentro de sidebars estreitas (sidebar Upload e Elementos
   no painel de conteúdo de 320px). Mesma família visual: zona tracejada
   teal, ícone teal centralizado, badge "PNG, JPG OU WEBP ATÉ X MB",
   divisor "OU", botão "Colar Imagem da Área de Transferência".

   Estrutura HTML esperada:
   <div class="lp-mini-uploader" data-uploader-target="...">
     <div class="lp-mini-uploader-zone" data-uploader-zone tabindex="0" role="button">
       <span class="lp-mini-uploader-icon">[svg]</span>
       <strong>Carregar Imagem</strong>
       <span class="lp-mini-uploader-badge">PNG, JPG OU WEBP ATÉ 12 MB</span>
       <small>Arraste e solte aqui ou clique para selecionar.</small>
     </div>
     <div class="lp-mini-uploader-divider">ou</div>
     <button class="lp-mini-uploader-paste" type="button" data-uploader-paste>
       [svg] <span>Colar Imagem da Área de Transferência</span>
     </button>
   </div>
   ───────────────────────────────────────────────────────────────── */

.lp-mini-uploader {
  display: grid;
  gap: 8px;
}

.lp-mini-uploader-zone {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 6px;
  padding: 16px 12px;
  border-radius: var(--radius-lg);
  border: 1.5px dashed rgba(var(--accent-rgb), .3);
  background: linear-gradient(180deg, rgba(255, 255, 255, .05), rgba(255, 255, 255, .025));
  text-align: center;
  cursor: pointer;
  transition: background-color var(--ease-hover), border-color var(--ease-hover);
}

.lp-mini-uploader-zone:hover {
  background-color: rgba(var(--accent-rgb), .07);
  border-color: rgba(var(--accent-rgb), .6);
}

.lp-mini-uploader-zone:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.lp-mini-uploader-zone.is-drag {
  border-color: rgba(var(--accent-rgb), .85);
  background: linear-gradient(180deg, rgba(var(--accent-rgb), .14), rgba(var(--gold-rgb), .06));
}

.lp-mini-uploader-icon {
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  display: grid;
  place-items: center;
  color: var(--accent-hi);
  background: rgba(var(--accent-rgb), .12);
  border: 1px solid rgba(var(--accent-rgb), .22);
  margin-bottom: 2px;
}

.lp-mini-uploader-zone strong {
  color: var(--text);
  font-size: var(--text-md);
  font-weight: 700;
  letter-spacing: 0;
}

.lp-mini-uploader-badge {
  color: var(--accent-hi);
  text-transform: uppercase;
  letter-spacing: .10em;
  font-size: 9px;
  font-weight: 700;
}

.lp-mini-uploader-zone small {
  color: var(--muted);
  font-size: var(--text-sm);
  line-height: 1.35;
}

.lp-mini-uploader-divider {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--muted-2);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: .10em;
  font-weight: 700;
}

.lp-mini-uploader-divider::before,
.lp-mini-uploader-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: var(--border-lo);
}

.lp-mini-uploader-paste {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  height: 36px;
  padding: 0 12px;
  border-radius: var(--radius-md);
  border: 1px solid var(--border-mid);
  background: rgba(255, 255, 255, .04);
  color: var(--text);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0;
  cursor: pointer;
  transition: background-color var(--ease-hover), border-color var(--ease-hover), color var(--ease-hover);
}

.lp-mini-uploader-paste:hover {
  background-color: rgba(255, 255, 255, .07);
  border-color: var(--border-hi);
}

.lp-mini-uploader-paste:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

.lp-mini-uploader-paste:disabled {
  opacity: .5;
  pointer-events: none;
}

/* ── Variante compacta `--compact` ───────────────────────────────
   Para contextos onde o drop-zone padrão (vertical, ~140px de altura)
   ocupa espaço demais. Transforma o bloco em UMA LINHA horizontal:
   ícone à esquerda + label "Carregar Imagem", altura ~36px, mesma
   família visual do botão de paste logo abaixo. Mantém o
   comportamento de drag-and-drop e click → file picker.

   Uso atual: painel de Vetor (Elementos) na sidebar direita.
   ─────────────────────────────────────────────────────────────── */

.lp-mini-uploader--compact .lp-mini-uploader-zone {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 8px 14px;
  min-height: 52px;
  border-radius: var(--radius-md);
  text-align: left;
}

.lp-mini-uploader--compact .lp-mini-uploader-icon {
  width: 22px;
  height: 22px;
  margin-bottom: 0;
  background: transparent;
  border: none;
  flex: 0 0 auto;
}

.lp-mini-uploader--compact .lp-mini-uploader-icon svg {
  width: 16px;
  height: 16px;
}

/* Coluna vertical com título + badge de formatos. Estrutura HTML
   esperada: <strong>Carregar Imagem</strong><span class="..badge..">PNG, JPG, WEBP ou SVG</span> */
.lp-mini-uploader--compact .lp-mini-uploader-zone strong {
  font-size: var(--text-sm);
  font-weight: 700;
  color: var(--text);
  line-height: 1.1;
}

.lp-mini-uploader--compact .lp-mini-uploader-badge {
  display: inline-block;
  font-size: 9px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--accent-hi);
  font-weight: 700;
  line-height: 1.1;
  margin-top: 3px;
}

/* Wrapper de texto: faz strong+badge ficarem em coluna ao lado do ícone */
.lp-mini-uploader--compact .lp-mini-uploader-zone strong,
.lp-mini-uploader--compact .lp-mini-uploader-badge {
  display: block;
  text-align: left;
}

.lp-mini-uploader--compact .lp-mini-uploader-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
}

/* Helper "Arraste..." continua escondido no compacto */
.lp-mini-uploader--compact .lp-mini-uploader-zone small {
  display: none;
}

/* Reduz o gap entre drop-zone e paste-btn na variante compacta */
.lp-mini-uploader--compact {
  gap: 6px;
}

/* Divisor "OU" também perde proeminência — fonte menor */
.lp-mini-uploader--compact .lp-mini-uploader-divider {
  font-size: 9px;
}

/* Hint que aparece FORA do botão, abaixo do uploader inteiro.
   Convenção: pequeno texto explicativo do propósito da ferramenta. */
.lp-mini-uploader-hint {
  margin: 8px 0 0;
  padding: 0;
  color: var(--muted);
  font-size: var(--text-xs);
  line-height: 1.45;
  text-align: center;
}

/* ============================================================
   .popover — Primitivo reutilizavel para popovers flutuantes
   estilo Canva. Usado pela toolbar contextual de texto e por
   qualquer ferramenta futura que precise de painel compacto
   ancorado a um botao trigger.

   Posicionamento e abertura/fechamento sao tratados via
   shared/popover.js. Este arquivo cuida apenas do visual.
   ============================================================ */
.popover {
  position: fixed;                 /* coordenadas viewport, set via JS */
  z-index: 1000;
  min-width: 220px;
  max-width: 340px;
  padding: 14px 16px;
  background: var(--surface-3);
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-lg);
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.42);
  color: var(--text);
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  opacity: 0;
  transform: translateY(-4px);
  pointer-events: none;
  transition:
    opacity var(--ease-hover),
    transform var(--ease-hover);
}

.popover[data-open="true"] {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.popover[hidden] { display: none; }

.popover__title {
  display: block;
  margin: 0 0 10px;
  font-size: var(--text-xs);
  font-weight: 700;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  color: var(--muted);
}

.popover__row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 10px;
}

.popover__row:last-child { margin-bottom: 0; }

.popover__row > label {
  flex: 1 1 auto;
  font-size: var(--text-sm);
  color: var(--text);
}

.popover__row > .popover__value {
  flex: 0 0 auto;
  min-width: 36px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--muted);
}

.popover__hr {
  border: 0;
  border-top: 1px solid var(--border-lo);
  margin: 10px -16px;
}

.popover__footer {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

/* Anchor — botao que abre o popover. Quando aberto, recebe estilo
   levemente pressed para indicar relacionamento visual. */
.popover-trigger[aria-expanded="true"] {
  background: rgba(var(--accent-rgb), 0.14);
  border-color: rgba(var(--accent-rgb), 0.42);
  color: var(--accent-hi);
}

/* ────────────────────────────────────────────────────────────────
   M2.5 — Auth Gate
   Elementos especificos do modal de login + indicador de usuario
   logado no header. Estilizado com tokens; sem hardcode de cor.
   ──────────────────────────────────────────────────────────────── */

#authGateModal .lp-modal-dialog {
  width: min(420px, 96vw);
}

#authGateForm .lp-photo-crop-panel + .lp-photo-crop-panel {
  margin-top: 12px;
}

#authGateForm .lp-photo-crop-panel .lp-select {
  width: 100%;
}

.lp-auth-error {
  margin: 12px 0 0;
  padding: 8px 10px;
  border-radius: var(--radius-md);
  border: 1px solid var(--danger);
  background: var(--surface-3);
  color: var(--danger);
  font-size: var(--text-sm);
  line-height: 1.4;
}

#btnAuthGateSubmit[aria-busy="true"] {
  opacity: 0.75;
  pointer-events: none;
}

.tb-auth-user {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px 0 10px;
  border: 1px solid var(--border-mid);
  border-radius: var(--radius-pill);
  height: 32px;
  background: var(--surface-2);
}

.tb-auth-user__name {
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
  max-width: 180px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Overlay de bloqueio: quando o gate esta aberto, impede interacao
   com o editor sem precisar reescrever bootstrap. Pointer-events
   no editor, sem alterar a renderizacao. */
body.is-auth-locked .lp-layout {
  pointer-events: none;
  filter: blur(2px) saturate(0.85);
  user-select: none;
}
body.is-auth-locked .lp-topbar {
  pointer-events: none;
}
/* Re-habilita o auth slot do header pra o usuario interagir com o gate. */
body.is-auth-locked .lp-topbar #authGateOpenBtn,
body.is-auth-locked .lp-topbar .tb-auth-user {
  pointer-events: auto;
}

/* ────────────────────────────────────────────────────────────────
   M2.6 — Estado vazio (modal "Meus Rascunhos" e similares)
   ──────────────────────────────────────────────────────────────── */

.lp-empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 40px 24px;
  text-align: center;
}

.lp-empty-state__title {
  margin: 0;
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text);
}

.lp-empty-state__hint {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--muted);
  max-width: 360px;
  line-height: 1.45;
}

/* ────────────────────────────────────────────────────────────────
   M3b — Lista de rascunhos/salvos (modal "Meus Rascunhos")
   ──────────────────────────────────────────────────────────────── */

.lp-drafts-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border-lo);
}

.lp-drafts-tab {
  appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  color: var(--muted);
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0;
  padding: 8px 14px;
  cursor: pointer;
  transition: color var(--ease-hover), border-color var(--ease-hover);
}

.lp-drafts-tab:hover {
  color: var(--text);
}

.lp-drafts-tab.is-active {
  color: var(--accent-hi);
  border-bottom-color: var(--accent);
}

.lp-drafts-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-height: 460px;
  overflow-y: auto;
  padding-right: 4px;
}

.lp-draft-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border-lo);
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .03);
  transition: background-color var(--ease-hover), border-color var(--ease-hover);
}

.lp-draft-card:hover {
  background: rgba(255, 255, 255, .06);
  border-color: var(--border-mid);
}

.lp-draft-card__body {
  flex: 1 1 auto;
  min-width: 0;
}

.lp-draft-card__title {
  margin: 0 0 2px 0;
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text);
  /* nome inteiro sempre visivel — regra do design system */
  word-break: break-word;
}

.lp-draft-card__meta {
  font-size: var(--text-xs);
  color: var(--muted);
  letter-spacing: 0;
}

.lp-draft-card__actions {
  display: flex;
  gap: 6px;
  flex: 0 0 auto;
}

.lp-draft-card__action {
  appearance: none;
  background: transparent;
  border: 1px solid var(--border-mid);
  color: var(--text);
  border-radius: var(--radius-sm);
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  font-weight: 600;
  height: 32px;
  padding: 0 12px;
  cursor: pointer;
  transition: background-color var(--ease-hover), border-color var(--ease-hover), color var(--ease-hover);
}

.lp-draft-card__action:hover {
  background: rgba(255, 255, 255, .06);
  border-color: var(--border-hi);
}

.lp-draft-card__action--danger:hover {
  background: rgba(212, 85, 85, .14);
  border-color: rgba(212, 85, 85, .60);
  color: #ed8a8a;
}

/* ────────────────────────────────────────────────────────────────
   M3b — Indicador de status de save (topbar)
   Cor sutil; nunca chama atenção do usuário. Só feedback discreto.
   ──────────────────────────────────────────────────────────────── */

.tb-save-status {
  display: inline-flex;
  align-items: center;
  font-family: var(--ui-font);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--muted);
  letter-spacing: 0;
  padding: 0 8px;
  white-space: nowrap;
  transition: color var(--ease-hover);
}

.tb-save-status:empty {
  display: none;
}

.tb-save-status[data-status="saving"] {
  color: var(--gold-hi);
}

.tb-save-status[data-status="saved"] {
  color: var(--accent-hi);
}

.tb-save-status[data-status="error"],
.tb-save-status[data-status="quota"],
.tb-save-status[data-status="forbidden"] {
  color: var(--danger);
}

/* M3c — thumbnail no card de rascunho/salvo */

.lp-draft-card__thumb {
  flex: 0 0 auto;
  width: 80px;
  height: 60px;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, .04);
  border: 1px solid var(--border-lo);
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.lp-draft-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.lp-draft-card__thumb--empty::before {
  content: "";
  display: block;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-xs);
  background: rgba(255, 255, 255, .08);
}

/* M3d — rodapé com quota no modal Meus Rascunhos */

.lp-drafts-footer {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 14px;
  padding-top: 12px;
  border-top: 1px solid var(--border-lo);
  font-family: var(--ui-font);
  font-size: var(--text-xs);
  color: var(--muted);
  letter-spacing: 0;
}

.lp-drafts-footer:empty {
  display: none;
}

.lp-drafts-footer__metric {
  font-weight: 600;
  color: var(--muted);
}

.lp-drafts-footer__sep {
  color: var(--border-mid);
}

.lp-drafts-footer__badge {
  margin-left: auto;
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: var(--text-2xs);
}

.lp-drafts-footer__badge--warn {
  background: rgba(var(--gold-rgb), .14);
  color: var(--gold-hi);
  border: 1px solid rgba(var(--gold-rgb), .42);
}

.lp-drafts-footer__badge--over {
  background: rgba(212, 85, 85, .14);
  color: #ed8a8a;
  border: 1px solid rgba(212, 85, 85, .55);
}

.lp-drafts-footer[data-level="warn"] .lp-drafts-footer__metric {
  color: var(--gold-hi);
}

.lp-drafts-footer[data-level="over"] .lp-drafts-footer__metric {
  color: #ed8a8a;
}

/* ─────────────────────────────────────────────────────────────────
   M4 — View "Meus Projetos"
   Substitui o modal nos casos de gerenciamento amplo. Grid maior,
   thumb 240x160, ações por card. Compartilha .lp-drafts-footer.
   ───────────────────────────────────────────────────────────────── */

.lp-mp {
  /* Padrao das outras views especiais (.vt-view, .rf-view, .mf-view):
     position: relative + min-height reservando espaco pra topbar. Sem
     isso a view sobe atras do menu principal e o titulo fica oculto. */
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 24px 28px;
  min-height: calc(100vh - 184px);
  background: var(--surface-1);
}

.lp-mp__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.lp-mp__title {
  margin: 0 0 4px 0;
  font-family: var(--ui-font);
  font-size: var(--text-xl);
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0;
}

.lp-mp__subtitle {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--muted);
  line-height: 1.45;
}

.lp-mp__close {
  appearance: none;
  background: transparent;
  border: 1px solid transparent;
  color: var(--muted);
  width: 36px;
  height: 36px;
  font-size: 22px;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color var(--ease-hover), border-color var(--ease-hover), color var(--ease-hover);
}
.lp-mp__close:hover {
  background: rgba(255, 255, 255, .06);
  border-color: var(--border-mid);
  color: var(--text);
}

.lp-mp__tabs {
  display: flex;
  gap: 4px;
  border-bottom: 1px solid var(--border-lo);
}
.lp-mp__tab {
  appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  color: var(--muted);
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  font-weight: 600;
  padding: 10px 16px;
  cursor: pointer;
  transition: color var(--ease-hover), border-color var(--ease-hover);
}
.lp-mp__tab:hover { color: var(--text); }
.lp-mp__tab.is-active {
  color: var(--accent-hi);
  border-bottom-color: var(--accent);
}

.lp-mp__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 16px;
  overflow-y: auto;
  align-content: start;
  padding-right: 4px;
  flex: 1 1 auto;
  min-height: 0;
}

.lp-mp-card {
  display: flex;
  flex-direction: column;
  border: 1px solid var(--border-lo);
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, .03);
  overflow: hidden;
  transition: background-color var(--ease-hover), border-color var(--ease-hover);
}
.lp-mp-card:hover {
  background: rgba(255, 255, 255, .06);
  border-color: var(--border-mid);
}

.lp-mp-card__thumb {
  width: 100%;
  aspect-ratio: 4 / 3;
  background: rgba(255, 255, 255, .04);
  border-bottom: 1px solid var(--border-lo);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.lp-mp-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.lp-mp-card__thumb--empty::before {
  content: "";
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: rgba(255, 255, 255, .08);
  display: block;
}

.lp-mp-card__body {
  padding: 12px 14px;
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex: 1 1 auto;
}
.lp-mp-card__title {
  margin: 0;
  font-size: var(--text-md);
  font-weight: 600;
  color: var(--text);
  word-break: break-word;
}
.lp-mp-card__meta {
  font-size: var(--text-xs);
  color: var(--muted);
}

.lp-mp-card__actions {
  display: flex;
  gap: 6px;
  padding: 0 14px 12px 14px;
}
.lp-mp-card__action {
  flex: 1 1 auto;
  appearance: none;
  background: transparent;
  border: 1px solid var(--border-mid);
  color: var(--text);
  border-radius: var(--radius-sm);
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  font-weight: 600;
  height: 32px;
  cursor: pointer;
  transition: background-color var(--ease-hover), border-color var(--ease-hover), color var(--ease-hover);
}
.lp-mp-card__action:hover {
  background: rgba(255, 255, 255, .06);
  border-color: var(--border-hi);
}
.lp-mp-card__action--danger:hover {
  background: rgba(212, 85, 85, .14);
  border-color: rgba(212, 85, 85, .60);
  color: #ed8a8a;
}

/* M5 — Nome do projeto atual na topbar */
.tb-project-name {
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  max-width: 240px;
  font-family: var(--ui-font);
  font-size: var(--text-sm);
  font-weight: 600;
  color: var(--text);
  letter-spacing: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.tb-project-name[data-untitled="true"] {
  color: var(--muted);
  font-weight: 400;
  font-style: italic;
}

/* M5 — Botão de menu principal sem dropdown (Meus Projetos).
   Herda visual de .tb-dd-btn (style.css) e adiciona estado .is-active
   quando a view correspondente está aberta. */
.tb-dd-btn--solo.is-active {
  color: var(--accent-hi);
  border-bottom-color: var(--accent);
}
