/* ============================================================================
   ParkFácil — app.css
   Design tokens + tema claro/escuro automático + responsivo (mobile-first).
   ============================================================================ */

/* ---------- Tokens (light) ---------- */
:root {
  /* Cores */
  --c-bg:           #f5f7fb;
  --c-surface:      #ffffff;
  --c-surface-2:    #f0f2f7;
  --c-border:       #e4e8f0;
  --c-text:         #0f172a;
  --c-text-muted:   #64748b;
  --c-text-soft:    #94a3b8;
  --c-primary:      #2563eb;
  --c-primary-600:  #1d4ed8;
  --c-primary-soft: #dbeafe;
  --c-success:      #16a34a;
  --c-success-soft: #dcfce7;
  --c-warning:      #d97706;
  --c-warning-soft: #fef3c7;
  --c-danger:       #dc2626;
  --c-danger-soft:  #fee2e2;
  --c-info:         #0891b2;
  --c-info-soft:    #cffafe;
  --c-focus:        rgba(37, 99, 235, .35);

  /* Tipografia */
  --ff-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --ff-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;

  /* Espaçamento */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 20px; --sp-6: 24px; --sp-8: 32px; --sp-10: 40px;

  /* Radii */
  --r-sm: 6px; --r-md: 10px; --r-lg: 14px; --r-xl: 20px; --r-pill: 999px;

  /* Sombras */
  --shadow-sm: 0 1px 2px rgba(15, 23, 42, .05);
  --shadow-md: 0 4px 12px rgba(15, 23, 42, .08);
  --shadow-lg: 0 12px 32px rgba(15, 23, 42, .12);

  /* Layout */
  --container: 1100px;
  --topbar-h: 60px;
}

/* ---------- Tokens (dark) ---------- */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --c-bg:           #0b0f17;
    --c-surface:      #131826;
    --c-surface-2:    #1a2031;
    --c-border:       #232b3d;
    --c-text:         #e5e9f0;
    --c-text-muted:   #94a3b8;
    --c-text-soft:    #64748b;
    --c-primary:      #60a5fa;
    --c-primary-600:  #3b82f6;
    --c-primary-soft: #1e3a8a;
    --c-success:      #4ade80;
    --c-success-soft: #14532d;
    --c-warning:      #fbbf24;
    --c-warning-soft: #78350f;
    --c-danger:       #f87171;
    --c-danger-soft:  #7f1d1d;
    --c-info:         #22d3ee;
    --c-info-soft:    #155e75;
    --c-focus:        rgba(96, 165, 250, .5);

    --shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);
    --shadow-md: 0 4px 12px rgba(0, 0, 0, .35);
    --shadow-lg: 0 12px 32px rgba(0, 0, 0, .5);
  }
}

[data-theme="dark"] {
  --c-bg:           #0b0f17;
  --c-surface:      #131826;
  --c-surface-2:    #1a2031;
  --c-border:       #232b3d;
  --c-text:         #e5e9f0;
  --c-text-muted:   #94a3b8;
  --c-text-soft:    #64748b;
  --c-primary:      #60a5fa;
  --c-primary-600:  #3b82f6;
  --c-primary-soft: #1e3a8a;
  --c-success:      #4ade80;
  --c-success-soft: #14532d;
  --c-warning:      #fbbf24;
  --c-warning-soft: #78350f;
  --c-danger:       #f87171;
  --c-danger-soft:  #7f1d1d;
  --c-info:         #22d3ee;
  --c-info-soft:    #155e75;
  --c-focus:        rgba(96, 165, 250, .5);
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, .4);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, .35);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, .5);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
/* O atributo HTML `hidden` SEMPRE deve esconder, mesmo quando regras CSS
   definem `display: flex/grid/etc`. Sem isso, elementos como .banner e
   .user-menu__dropdown ficavam visíveis mesmo com [hidden] no markup. */
[hidden] { display: none !important; }
html { -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--ff-sans);
  background: var(--c-bg);
  color: var(--c-text);
  line-height: 1.5;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
button { font: inherit; cursor: pointer; }
input, select, textarea, button { font: inherit; color: inherit; }
a { color: var(--c-primary); }

:focus-visible {
  outline: 2px solid var(--c-focus);
  outline-offset: 2px;
}

.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--c-primary); color: #fff;
  padding: var(--sp-2) var(--sp-3); border-radius: var(--r-sm);
  z-index: 100;
}
.skip-link:focus { left: var(--sp-3); top: var(--sp-3); }

/* ---------- Layout ---------- */
.container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 var(--sp-4);
}

.main {
  padding-top: var(--sp-6);
  padding-bottom: var(--sp-10);
}

/* ---------- Topbar ---------- */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--c-surface) 92%, transparent);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--c-border);
}
.topbar__inner {
  display: flex; align-items: center; justify-content: space-between;
  height: var(--topbar-h); gap: var(--sp-4);
}
/* ---------- Brand mark (ParkFácil) ---------- */
@property --brand-angle {
  syntax: '<angle>';
  initial-value: 135deg;
  inherits: false;
}

.brand {
  display: inline-flex; align-items: center; gap: var(--sp-3);
  font-weight: 700;
  user-select: none;
  /* O logo agora é um <button> que volta pra home (#schedule). Resetamos os
     estilos nativos de botão e damos cursor de link. O topbar tem 60px de
     altura, então o alvo de toque já passa dos 44px da regra mobile. */
  background: none; border: 0; padding: 0; margin: 0;
  font-family: inherit; cursor: pointer;
}
.brand:focus-visible {
  outline: 2px solid var(--c-primary); outline-offset: 4px;
  border-radius: var(--r-sm);
}

.brand__mark {
  position: relative;
  width: 36px; height: 36px;
  border-radius: 11px;
  background: linear-gradient(var(--brand-angle), var(--c-primary), var(--c-info));
  box-shadow:
    0 2px 8px color-mix(in srgb, var(--c-primary) 30%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, .28),
    inset 0 -1px 0 rgba(0, 0, 0, .10);
  transform-origin: center;
  transition:
    transform .35s cubic-bezier(.34, 1.56, .64, 1),
    box-shadow .35s cubic-bezier(.65, 0, .35, 1);
  animation:
    brand-enter .65s cubic-bezier(.34, 1.56, .64, 1) backwards,
    brand-breathe 9s ease-in-out 1.6s infinite;
  will-change: transform;
}

.brand__mark:hover {
  transform: scale(1.07);
  box-shadow:
    0 8px 22px color-mix(in srgb, var(--c-primary) 50%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, .38),
    inset 0 -1px 0 rgba(0, 0, 0, .10);
}
.brand__mark:active {
  transform: scale(.95);
  transition-duration: .12s;
}

.brand__glow {
  position: absolute;
  inset: -6px;
  border-radius: 16px;
  background: radial-gradient(closest-side,
    color-mix(in srgb, var(--c-primary) 45%, transparent) 0%,
    transparent 75%);
  filter: blur(8px);
  opacity: 0;
  z-index: -1;
  animation: brand-glow-in 1.2s ease 1.1s backwards;
}

.brand__svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  overflow: visible;
}

.brand__p {
  stroke-dasharray: 100;
  stroke-dashoffset: 100;
  animation: brand-draw 1.15s cubic-bezier(.65, 0, .35, 1) .35s forwards;
  filter: drop-shadow(0 1px 0 rgba(0, 0, 0, .14));
}

.brand__dot {
  transform: scale(0);
  transform-origin: 30.5px 11px;
  opacity: 0;
  animation: brand-dot-pop .42s cubic-bezier(.34, 1.56, .64, 1) 1.35s forwards;
}

.brand__name {
  font-size: 1.05rem;
  letter-spacing: -.015em;
  background: linear-gradient(90deg, var(--c-text) 0%, var(--c-text-muted) 130%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  animation: brand-name-in .55s cubic-bezier(.65, 0, .35, 1) .25s backwards;
}

@keyframes brand-enter {
  from { opacity: 0; transform: scale(.55) rotate(-14deg); }
  60%  { opacity: 1; }
  to   { opacity: 1; transform: scale(1) rotate(0deg); }
}

@keyframes brand-draw {
  to { stroke-dashoffset: 0; }
}

@keyframes brand-dot-pop {
  0%   { transform: scale(0); opacity: 0; }
  55%  { transform: scale(1.55); opacity: 1; }
  100% { transform: scale(1); opacity: 1; }
}

@keyframes brand-breathe {
  0%, 100% { --brand-angle: 135deg; }
  50%      { --brand-angle: 205deg; }
}

@keyframes brand-glow-in {
  from { opacity: 0; }
  to   { opacity: .55; }
}

@keyframes brand-name-in {
  from { opacity: 0; transform: translateX(-6px); filter: blur(2px); }
  to   { opacity: 1; transform: translateX(0); filter: blur(0); }
}

@media (prefers-reduced-motion: reduce) {
  .brand__mark,
  .brand__p,
  .brand__dot,
  .brand__name,
  .brand__glow {
    animation: none !important;
  }
  .brand__p   { stroke-dashoffset: 0; }
  .brand__dot { transform: scale(1); opacity: 1; }
  .brand__name { opacity: 1; transform: none; filter: none; }
  .brand__glow { opacity: .35; }
}

.topbar__meta { display: flex; align-items: center; gap: var(--sp-3); }
.meta-time { color: var(--c-text-muted); font-size: .85rem; font-variant-numeric: tabular-nums; }
@media (max-width: 520px) { .meta-time { display: none; } }

.icon-btn {
  width: 38px; height: 38px;
  display: grid; place-items: center;
  background: transparent; border: 1px solid var(--c-border);
  color: var(--c-text); border-radius: var(--r-md);
  transition: background .15s, border-color .15s;
}
.icon-btn:hover { background: var(--c-surface-2); }
.icon-btn .icon--sun { display: none; }
.icon-btn .icon--moon { display: block; }
:root[data-theme="dark"] .icon-btn .icon--sun,
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) .icon-btn .icon--sun { display: block; }
  :root:not([data-theme="light"]) .icon-btn .icon--moon { display: none; }
}
:root[data-theme="dark"] .icon-btn .icon--moon { display: none; }
:root[data-theme="dark"] .icon-btn .icon--sun { display: block; }


/* ---------- Cards & Panels ---------- */
.panel { display: none; }
.panel.is-active { display: block; }

.grid { display: grid; gap: var(--sp-4); }
.grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
@media (max-width: 760px) { .grid--2 { grid-template-columns: 1fr; } }

/* Card = superfície base de TODA página. Material "liquid glass" leve: surface
   quase opaco (texto continua nítido) + um leve blur pra atmosfera de fundo
   (body::before) vazar nas bordas + fio de luz no topo. Cantos generosos (22px)
   alinham com o redesign do "Meu perfil". Junior: NÃO deixe a superfície muito
   translúcida — abaixo de ~88% o texto perde contraste em telas densas (admin). */
.card {
  background: color-mix(in srgb, var(--c-surface) 92%, transparent);
  backdrop-filter: blur(10px) saturate(125%);
  -webkit-backdrop-filter: blur(10px) saturate(125%);
  border: 1px solid color-mix(in srgb, var(--c-border) 85%, transparent);
  border-radius: 22px;
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm), inset 0 1px 0 rgba(255, 255, 255, .06);
}
.card--block { margin-top: var(--sp-4); }
.card__header { margin-bottom: var(--sp-4); }
.card__header--row {
  display: flex; align-items: flex-start; justify-content: space-between; gap: var(--sp-3);
  flex-wrap: wrap;
}
.card__title { font-size: 1.1rem; font-weight: 600; margin: 0; letter-spacing: -.01em; }
.card__hint { margin: 4px 0 0; color: var(--c-text-muted); font-size: .875rem; }
/* Nota secundária dentro de um hint (ex.: detalhe técnico discreto): vira uma
   segunda linha menor e mais apagada, sem competir com a mensagem principal. */
.hint-note { display: block; margin-top: 4px; font-size: .8rem; color: var(--c-text-soft); }

/* ---------- Forms ---------- */
.form { display: flex; flex-direction: column; gap: var(--sp-4); }
.field { display: flex; flex-direction: column; gap: 6px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-4); }
@media (max-width: 480px) { .field-row { grid-template-columns: 1fr; } }

.label { font-size: .85rem; font-weight: 500; color: var(--c-text-muted); }

.input {
  width: 100%;
  padding: 10px 12px;
  background: var(--c-surface);
  color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  transition: border-color .15s, box-shadow .15s, background .15s;
  appearance: none;
}
.input:hover { border-color: color-mix(in srgb, var(--c-border) 60%, var(--c-text-muted) 40%); }
.input:focus { border-color: var(--c-primary); box-shadow: 0 0 0 3px var(--c-focus); outline: none; }
.input[aria-invalid="true"] { border-color: var(--c-danger); }

select.input {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>");
  background-repeat: no-repeat;
  background-position: right 10px center;
  background-size: 18px;
  padding-right: 36px;
}

.range-wrap { display: flex; align-items: center; gap: var(--sp-3); }
.range {
  -webkit-appearance: none; appearance: none;
  flex: 1; height: 4px; border-radius: var(--r-pill);
  background: var(--c-surface-2); outline: none;
}
.range::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--c-primary); cursor: pointer;
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-primary) 18%, transparent);
}
.range::-moz-range-thumb {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--c-primary); cursor: pointer; border: 0;
}
.range__out {
  min-width: 2.5ch; text-align: right;
  font-variant-numeric: tabular-nums;
  color: var(--c-text-muted);
  font-size: .9rem;
}

/* ---------- Card "Agendar recorrência" (visual Apple-like) ---------- */

/* Segmented control de dias da semana. Radios escondidos; o <label> vira o
   chip clicável (touch ≥44px). Grid de 7 colunas iguais — cabe a 375px. */
.day-picker {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}
.day-chip {
  position: relative;
  display: flex; align-items: center; justify-content: center;
  min-height: 44px;
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: var(--c-surface);
  color: var(--c-text-muted);
  font-size: .82rem; font-weight: 600;
  cursor: pointer;
  user-select: none;
  transition: background .15s, color .15s, border-color .15s, transform .05s;
}
/* O input radio fica invisível mas continua no fluxo do form (FormData). */
.day-chip input {
  position: absolute; opacity: 0; width: 0; height: 0; margin: 0;
}
.day-chip:hover { border-color: color-mix(in srgb, var(--c-primary) 40%, var(--c-border)); }
.day-chip:active { transform: scale(.94); }
/* Dia selecionado: pílula primária preenchida. */
.day-chip:has(input:checked) {
  background: var(--c-primary);
  border-color: var(--c-primary);
  color: #fff;
  box-shadow: 0 2px 8px color-mix(in srgb, var(--c-primary) 30%, transparent);
}
/* Acessibilidade: foco de teclado visível no chip. */
.day-chip:has(input:focus-visible) {
  outline: 2px solid var(--c-primary); outline-offset: 2px;
}

/* Horário em destaque: número grande, tabular, fácil de ler. */
.input--time {
  font-size: 1.15rem; font-weight: 600;
  font-variant-numeric: tabular-nums;
}

/* Bolha com o valor atual do slider, ao lado do label. */
.range__bubble {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 2.4ch; height: 1.5rem; padding: 0 8px;
  margin-left: 6px;
  border-radius: var(--r-pill);
  background: color-mix(in srgb, var(--c-primary) 14%, transparent);
  color: var(--c-primary);
  font-size: .82rem; font-weight: 700;
  font-variant-numeric: tabular-nums;
}

/* Slider com a trilha PREENCHIDA até o thumb (var --range-pct vem do JS). */
.range--filled {
  height: 6px;
  background: linear-gradient(
    to right,
    var(--c-primary) 0, var(--c-primary) var(--range-pct, 100%),
    var(--c-surface-2) var(--range-pct, 100%), var(--c-surface-2) 100%
  );
}

.field__error {
  color: var(--c-danger);
  font-size: .8rem;
  min-height: 1em;
}


.form__actions {
  display: flex;
  gap: var(--sp-4);          /* 16px entre botões — separação clara */
  flex-wrap: wrap;
  align-items: center;
}
/* Quando a linha de ações é filha DIRETA de um card (sub-abas admin, EULA),
   não há o gap do .form pra separá-la dos campos acima — adicionamos margem. */
.card > .form__actions { margin-top: var(--sp-5); }

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--sp-2);
  padding: 10px 16px;
  background: var(--c-surface-2); color: var(--c-text);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  font-weight: 500;
  transition: background .15s, border-color .15s, transform .05s, color .15s;
  white-space: nowrap;
  text-decoration: none; /* botões renderizados como <a> não devem sublinhar */
  user-select: none;
}
.btn:hover { background: color-mix(in srgb, var(--c-surface-2) 70%, var(--c-text) 8%); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .55; cursor: not-allowed; }

.btn--primary { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.btn--primary:hover { background: var(--c-primary-600); border-color: var(--c-primary-600); }

.btn--danger { background: var(--c-danger); border-color: var(--c-danger); color: #fff; }
.btn--danger:hover { filter: brightness(.92); }

.btn--ghost { background: transparent; }
.btn--sm { padding: 6px 10px; font-size: .85rem; }

.btn .icon { width: 16px; height: 16px; }

/* ---------- Calendário de reservas (14 dias, semana-alinhada) ---------- */
/* Cabeçalho de dias da semana (Dom..Sáb) — mesma grade de 7 colunas. */
.cal-head {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--sp-2);
  margin-bottom: var(--sp-2);
}
.cal-head__cell {
  text-align: center;
  font-size: .72rem; font-weight: 700; letter-spacing: .5px;
  color: var(--c-text-muted); text-transform: uppercase;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);   /* 7 colunas, sempre (calendário real) */
  gap: var(--sp-2);
}

.cal-cell {
  /* é um <button> — reset + layout de cartão */
  display: flex; flex-direction: column; gap: var(--sp-1);
  min-height: 88px;
  padding: var(--sp-2);
  text-align: left;
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  color: var(--c-text);
  cursor: pointer;
  font: inherit;
  transition: border-color .12s ease, background .12s ease, transform .06s ease;
}
.cal-cell:hover { border-color: var(--c-primary); }
.cal-cell:active { transform: scale(.98); }
.cal-cell:focus-visible { outline: 2px solid var(--c-primary); outline-offset: 2px; }

.cal-cell__head { display: flex; align-items: baseline; gap: 6px; }
.cal-cell__day { font-size: 1.05rem; font-weight: 700; line-height: 1; }
.cal-cell__today {
  margin-left: auto;
  font-size: .58rem; font-weight: 700; letter-spacing: .5px;
  background: var(--c-primary); color: #fff;
  padding: 2px 6px; border-radius: 999px;
}
.cal-cell__body { display: flex; align-items: center; flex: 1; min-width: 0; }

/* Dia reservado: empilha o chip e o nome do polo um sobre o outro, encostados
   à esquerda. Sem isso, o nome do polo fica LADO A LADO com o chip e, quando é
   longo (ex.: "CENTRO TECNOLÓGICO"), estoura a largura da célula. Empilhando +
   truncando, o card mantém o tamanho padrão e o nome vira reticências. */
.cal-cell--booked .cal-cell__body {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 2px;
}

/* Hoje: borda destacada */
.cal-cell--today { border-color: var(--c-primary); box-shadow: inset 0 0 0 1px var(--c-primary); }
/* Fim de semana: fundo levemente esmaecido */
.cal-cell--weekend { background: color-mix(in srgb, var(--c-surface-2) 60%, var(--c-bg)); }

/* Fora da janela de 14 dias: só completa a semana — esmaecido, sem interação */
.cal-cell--out {
  cursor: default;
  background: transparent;
  border-color: transparent;
  opacity: .35;
}
.cal-cell--out:hover { border-color: transparent; }

/* Dia livre: "+" discreto centralizado */
.cal-cell--free .cal-cell__body { justify-content: center; flex-direction: column; gap: 2px; color: var(--c-text-muted); }
.cal-plus { font-size: 1.4rem; line-height: 1; color: var(--c-text-soft); }
.cal-free-label { font-size: .7rem; color: var(--c-text-soft); }
.cal-cell--free:hover .cal-plus,
.cal-cell--free:hover .cal-free-label { color: var(--c-primary); }

/* Chip de reserva */
.cal-chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: .8rem; font-weight: 600;
  max-width: 100%;
}
.cal-chip--booked { background: color-mix(in srgb, var(--c-success) 16%, transparent); color: var(--c-success); }
.cal-chip--pending { background: color-mix(in srgb, var(--c-warning) 18%, transparent); color: var(--c-warning); }
.cal-chip__lot { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
/* Código do polo abaixo do chip — um badge curto ("CT", "FL3500") em vez do
   nome cru. JS já abrevia (abbreviatePolo); aqui é só o visual de pílula
   discreta. max-width + ellipsis seguram qualquer código fora do padrão pra
   nunca estourar a célula. */
.cal-chip__polo {
  display: inline-block; margin-top: 3px; max-width: 100%;
  padding: 1px 6px;
  font-size: .6rem; font-weight: 700; letter-spacing: .3px;
  line-height: 1.4;
  color: var(--c-text-soft);
  background: color-mix(in srgb, var(--c-text) 8%, transparent);
  border-radius: 999px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.cal-rec { font-size: .85rem; opacity: .85; }
.cal-extra { font-size: .7rem; opacity: .8; }

.cal-dot { width: 9px; height: 9px; border-radius: 50%; flex-shrink: 0; }
.cal-dot--booked { background: var(--c-success); }
.cal-dot--pending { background: var(--c-warning); }

/* Mobile: mantém as 7 colunas (calendário de verdade), mas compacta as
   células — esconde o "Estac." (fica só o número), reduz fontes e altura
   pra caber em ~48px de largura no iPhone SE. */
@media (max-width: 640px) {
  .cal-head, .cal-grid { gap: 4px; }
  .cal-head__cell { font-size: .6rem; }
  .cal-cell { min-height: 64px; padding: 5px 4px; gap: 2px; }
  .cal-cell__day { font-size: .9rem; }
  .cal-cell__today {
    /* vira um pontinho no mobile pra não estourar a célula estreita */
    margin-left: auto; padding: 0; width: 6px; height: 6px;
    border-radius: 50%; font-size: 0; overflow: hidden;
  }
  .cal-chip { padding: 2px 5px; font-size: .72rem; gap: 3px; }
  .cal-chip__pre { display: none; }          /* "Estac." some; sobra o número */
  .cal-free-label { display: none; }         /* só o "+" no mobile */
  .cal-plus { font-size: 1.1rem; }
}

/* Legenda */
.cal-legend {
  display: flex; flex-wrap: wrap; gap: var(--sp-3) var(--sp-4);
  margin-top: var(--sp-4);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--c-border);
  font-size: .78rem; color: var(--c-text-muted);
}
.cal-legend__item { display: inline-flex; align-items: center; gap: 6px; }
.cal-legend__plus { color: var(--c-text-soft); font-weight: 700; }
.cal-legend__rec { font-weight: 700; }

/* Skeleton de carregamento */
.cal-grid--skeleton { margin-top: var(--sp-3); }
.cal-cell--skeleton {
  min-height: 92px;
  background: linear-gradient(90deg, var(--c-surface-2) 25%, var(--c-surface) 50%, var(--c-surface-2) 75%);
  background-size: 200% 100%;
  animation: cal-shimmer 1.2s infinite;
  border: 1px solid var(--c-border); border-radius: var(--r-md);
}
@keyframes cal-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }
@media (prefers-reduced-motion: reduce) { .cal-cell--skeleton { animation: none; } }

/* ---------- Icons ---------- */
.icon {
  width: 18px; height: 18px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.icon--sun, .icon--moon { width: 18px; height: 18px; }

/* ---------- Listas (cards de itens, com tabela em desktop "fake") ---------- */
.list { display: flex; flex-direction: column; gap: var(--sp-3); }

.item {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: var(--sp-3);
  align-items: center;
  padding: var(--sp-4);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
}
/* Variante de item com avatar (lista de usuários): coluna do avatar é fixa
   antes do conteúdo principal. Touch target = 56px (≥44px regra mobile). */
.item--with-avatar {
  grid-template-columns: auto 1fr auto;
}
/* Conta desabilitada: card esmaecido (avatar/nome/meta apagados), mas os
   botões de ação ficam legíveis pra o admin reativar. */
.item--disabled .item__avatar,
.item--disabled .item__name,
.item--disabled .item__meta { opacity: .5; }
.item__avatar {
  width: 56px; height: 56px;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
/* avatar-wrap: container relativo que sobrepõe foto sobre iniciais.
   Iniciais ficam atrás (sempre visíveis); foto cobre por cima quando carrega.
   Em erro de carregamento, JS remove o <img> e as iniciais aparecem. */
.avatar-wrap {
  position: relative;
  display: inline-block;
  width: 56px; height: 56px;
  flex-shrink: 0;
}
.avatar {
  position: absolute;
  inset: 0;
  width: 100%; height: 100%;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 1.1rem;
  color: white;
  user-select: none;
  object-fit: cover;
  background: var(--c-surface-3, var(--c-surface));
}
.avatar--photo { border: 1px solid var(--c-border); }
.avatar--initials { letter-spacing: 0.5px; }
/* topbar usa tamanho menor (32px) — sobrescreve só as dimensões */
.avatar-wrap--sm { width: 32px; height: 32px; }
.avatar-wrap--sm .avatar { font-size: .8rem; }

/* ============================================================================
   Meu perfil — redesign 2026 ("liquid glass" + bento grid)
   Estrutura (ver index.html): HERO (identidade) → BENTO (tiles-resumo que
   também navegam) → SEÇÕES (accordion, profile.js). Mobile-first.
   ============================================================================ */

/* Ângulo do anel do avatar — registrado como custom property animável. */
@property --ring-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

/* ---- HERO: vidro sobre um mesh de gradientes que "respira" ---- */
.profile-hero {
  position: relative;
  margin-top: var(--sp-4);
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--c-border) 70%, transparent);
  box-shadow: var(--shadow-md);
  /* isolation cria um stacking context próprio: o mesh (z-index -1) fica
     atrás do vidro mas NUNCA atrás do fundo da página. */
  isolation: isolate;
}
.profile-hero__mesh {
  position: absolute; inset: -45%;
  z-index: -1;
  background:
    radial-gradient(38% 42% at 22% 28%, color-mix(in srgb, var(--c-primary) 55%, transparent), transparent 70%),
    radial-gradient(34% 38% at 78% 20%, color-mix(in srgb, var(--c-info) 48%, transparent), transparent 70%),
    radial-gradient(42% 46% at 64% 84%, color-mix(in srgb, #8b5cf6 42%, transparent), transparent 72%),
    var(--c-surface);
  filter: blur(48px) saturate(135%);
  animation: hero-mesh 16s ease-in-out infinite alternate;
}
@keyframes hero-mesh {
  0%   { transform: translate3d(-3%, -2%, 0) rotate(0deg)  scale(1); }
  50%  { transform: translate3d( 3%,  2%, 0) rotate(4deg)  scale(1.06); }
  100% { transform: translate3d(-2%,  3%, 0) rotate(-3deg) scale(1.02); }
}
.profile-hero__inner {
  position: relative;
  display: flex; flex-direction: column; align-items: center;
  text-align: center;
  gap: var(--sp-4);
  padding: var(--sp-8) var(--sp-5) var(--sp-6);
  background: color-mix(in srgb, var(--c-surface) 55%, transparent);
  backdrop-filter: blur(26px) saturate(160%);
  -webkit-backdrop-filter: blur(26px) saturate(160%);
  /* fio de luz na borda superior — reforça a leitura de "vidro" */
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .22);
}
/* Desktop: identidade em linha, texto à esquerda. */
@media (min-width: 640px) {
  .profile-hero__inner {
    flex-direction: row;
    text-align: left;
    padding: var(--sp-6) var(--sp-6);
  }
}

/* Avatar com anel de gradiente girando (estilo Apple ID). O avatar-wrap
   interno (foto sobre iniciais) é o mesmo padrão da topbar/lista. */
.profile-hero__avatar {
  position: relative;
  width: 84px; height: 84px;
  flex-shrink: 0;
  border-radius: 50%;
}
.profile-hero__avatar::before {
  content: '';
  position: absolute; inset: -4px;
  border-radius: 50%;
  background: conic-gradient(from var(--ring-angle),
    var(--c-primary), var(--c-info), #8b5cf6, var(--c-primary));
  animation: ring-spin 8s linear infinite;
  z-index: -1;
  filter: saturate(120%);
}
@keyframes ring-spin {
  to { --ring-angle: 360deg; }
}
.profile-hero__avatar .avatar { font-size: 1.7rem; }

/* Coluna de identidade: centralizada no mobile (hero empilhado), alinhada à
   esquerda no desktop (hero em linha). */
.profile-hero__id { min-width: 0; display: flex; flex-direction: column; align-items: center; }
@media (min-width: 640px) {
  .profile-hero__id { align-items: flex-start; }
  .profile-hero__chips { justify-content: flex-start; }
}
.profile-hero__name {
  margin: 0;
  font-size: clamp(1.35rem, 5.5vw, 1.8rem);
  font-weight: 700;
  letter-spacing: -.02em;
  line-height: 1.15;
  color: var(--c-text);
}
.profile-hero__email {
  margin: 2px 0 0;
  font-size: .85rem;
  color: var(--c-text-muted);
  overflow-wrap: anywhere;
}
.profile-hero__meta {
  margin-top: var(--sp-3);
  display: flex; flex-direction: column;
  align-items: center;
  gap: var(--sp-2);
}
@media (min-width: 640px) { .profile-hero__meta { align-items: flex-start; } }
.profile-hero__chips { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px; }
/* Chips "de vidro": pílulas translúcidas sobre o hero. */
.profile-hero__chip {
  font-size: .74rem; font-weight: 600;
  color: var(--c-text);
  background: color-mix(in srgb, var(--c-surface) 60%, transparent);
  border: 1px solid color-mix(in srgb, var(--c-border) 80%, transparent);
  border-radius: 999px;
  padding: 3px 10px;
  white-space: nowrap;    /* "Func. 987303304" nunca racha */
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.profile-hero__chip--role {
  color: var(--c-primary);
  background: color-mix(in srgb, var(--c-primary) 14%, transparent);
  border-color: color-mix(in srgb, var(--c-primary) 35%, transparent);
  text-transform: lowercase;
}
.profile-hero__dates {
  margin: 0;
  font-size: .75rem;
  color: var(--c-text-muted);
}

/* ---- BENTO: grade de tiles-resumo (2 col mobile / 4 col desktop) ---- */
.profile-bento {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sp-3);
  margin-top: var(--sp-4);
}
@media (min-width: 760px) {
  .profile-bento { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.bento-tile {
  position: relative;
  display: flex; flex-direction: column; align-items: flex-start;
  gap: 2px;
  min-height: 112px;
  padding: var(--sp-4);
  text-align: left;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 22px;
  box-shadow: var(--shadow-sm);
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition:
    transform .22s cubic-bezier(.2, .8, .2, 1),
    box-shadow .22s ease,
    border-color .22s ease,
    background .22s ease;
}
.bento-tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
}
.bento-tile:active { transform: scale(.97); transition-duration: .08s; }
/* Tile da seção aberta: levemente tintado + chevron girado. */
.bento-tile[aria-expanded="true"] {
  border-color: color-mix(in srgb, var(--c-primary) 55%, var(--c-border));
  background: color-mix(in srgb, var(--c-primary) 6%, var(--c-surface));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--c-primary) 35%, transparent), var(--shadow-sm);
}
.bento-tile__top {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%;
  margin-bottom: var(--sp-2);
}
.bento-tile__icon {
  position: relative;
  width: 38px; height: 38px;
  display: grid; place-items: center;
  border-radius: 12px;
  background: color-mix(in srgb, var(--c-primary) 12%, transparent);
  color: var(--c-primary);
}
.bento-tile__icon svg {
  width: 20px; height: 20px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
/* Dot de status no canto do ícone (cores por estado, via profile.js). */
.bento-tile__dot {
  position: absolute; top: -3px; right: -3px;
  width: 11px; height: 11px;
  border-radius: 50%;
  background: var(--c-text-soft);
  border: 2px solid var(--c-surface);
  opacity: 0;
  transform: scale(.4);
  transition: opacity .25s ease, transform .25s cubic-bezier(.34, 1.56, .64, 1), background .25s ease;
}
.bento-tile__dot--ok   { background: var(--c-success); opacity: 1; transform: none; }
.bento-tile__dot--warn { background: var(--c-warning); opacity: 1; transform: none; }
.bento-tile__dot--err  { background: var(--c-danger);  opacity: 1; transform: none; }
.bento-tile__chevron {
  width: 18px; height: 18px;
  stroke: var(--c-text-soft); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  transition: transform .3s cubic-bezier(.2, .8, .2, 1), stroke .2s ease;
}
.bento-tile[aria-expanded="true"] .bento-tile__chevron {
  transform: rotate(180deg);
  stroke: var(--c-primary);
}
.bento-tile__label {
  font-size: .7rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--c-text-muted);
}
.bento-tile__value {
  max-width: 100%;
  font-size: 1.02rem; font-weight: 700; letter-spacing: -.01em;
  color: var(--c-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.bento-tile__sub {
  max-width: 100%;
  font-size: .75rem;
  color: var(--c-text-soft);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ---- SEÇÕES: accordion animado (grid-rows 0fr → 1fr) ---- */
.profile-section {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows .45s cubic-bezier(.2, .8, .2, 1);
  /* ao rolar até a seção, deixa folga pro topbar fixo (não há mais barra de tabs) */
  scroll-margin-top: calc(var(--topbar-h) + 16px);
}
.profile-section__inner {
  overflow: hidden;
  min-height: 0;
  /* invisível quando fechada (o inert do profile.js cuida do foco) */
  visibility: hidden;
  transition: visibility 0s .45s;
}
.profile-section.is-open { grid-template-rows: 1fr; }
.profile-section.is-open .profile-section__inner {
  visibility: visible;
  transition: visibility 0s;
}
/* O card da seção entra com um leve "rise" depois que a altura abre. */
.profile-card {
  margin-top: var(--sp-3);
  border-radius: 22px;
  opacity: 0;
  transform: translateY(10px);
  transition: opacity .35s ease .08s, transform .35s cubic-bezier(.2, .8, .2, 1) .08s;
}
.profile-section.is-open .profile-card { opacity: 1; transform: none; }

/* ---- Entrada escalonada ao abrir a aba (animação roda quando .is-active
        é aplicada e o panel sai de display:none) ---- */
.panel.is-active .profile-hero { animation: profile-rise .55s cubic-bezier(.2, .8, .2, 1) backwards; }
.panel.is-active .bento-tile { animation: profile-rise .5s cubic-bezier(.2, .8, .2, 1) backwards; }
.panel.is-active .bento-tile:nth-child(1) { animation-delay: .06s; }
.panel.is-active .bento-tile:nth-child(2) { animation-delay: .12s; }
.panel.is-active .bento-tile:nth-child(3) { animation-delay: .18s; }
.panel.is-active .bento-tile:nth-child(4) { animation-delay: .24s; }
@keyframes profile-rise {
  from { opacity: 0; transform: translateY(14px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Acessibilidade: quem pediu menos movimento ganha a página estática. */
@media (prefers-reduced-motion: reduce) {
  .profile-hero__mesh,
  .profile-hero::after,
  .profile-hero__avatar::before,
  .panel.is-active .profile-hero,
  .panel.is-active .bento-tile { animation: none !important; }
  .profile-section,
  .profile-section__inner,
  .profile-card,
  .bento-tile,
  .bento-tile__chevron,
  .bento-tile__dot { transition: none !important; }
  .profile-card { opacity: 1; transform: none; }
}

/* Veículos (texto de vazio dentro da seção) */
.account__no-vehicles {
  margin: 0;
  font-size: .85rem; color: var(--c-text-muted);
}

/* ---------- Sub-abas (Configurações ParkFácil) ---------- */
.subtabs {
  display: flex; flex-wrap: wrap; gap: 4px;
  margin-bottom: var(--sp-4);
  border-bottom: 1px solid var(--c-border);
  padding-bottom: 0;
}
.subtab {
  background: transparent; border: 0;
  border-bottom: 2px solid transparent;
  padding: 10px 14px;
  margin-bottom: -1px;            /* sobrepõe a borda do container */
  color: var(--c-text-muted);
  font-size: .9rem; font-weight: 600;
  cursor: pointer;
  white-space: nowrap;
  border-radius: var(--r-sm) var(--r-sm) 0 0;
}
.subtab:hover { color: var(--c-text); background: var(--c-surface-2); }
.subtab.is-active {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
}
.subpanel { display: none; }
.subpanel.is-active { display: block; }
/* cards dentro de um subpanel mantêm o espaçamento padrão entre si */
.subpanel > .card + .card { margin-top: var(--sp-4); }

/* ---------- Painel de saúde (admin) ---------- */
.health-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--sp-3);
}
.health-tile {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: var(--sp-3);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  background: var(--c-surface);
}
.health-tile__dot {
  width: 10px; height: 10px; border-radius: 50%;
  flex-shrink: 0;
  background: var(--c-text-muted);
}
.health-tile--ok .health-tile__dot { background: var(--c-success); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-success) 20%, transparent); }
.health-tile--bad .health-tile__dot { background: var(--c-danger); box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-danger) 20%, transparent); }
.health-tile--bad { border-color: color-mix(in srgb, var(--c-danger) 35%, var(--c-border)); }
/* Estado neutro (ex: VPN verificando / não configurada): dot cinza, sem alarme. */
.health-tile--muted .health-tile__value { color: var(--c-text-muted); }
.health-tile__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.health-tile__label { font-size: .76rem; color: var(--c-text-muted); }
.health-tile__value { font-size: .9rem; font-weight: 600; color: var(--c-text); }
.health-tile--overall .health-tile__value { font-size: 1rem; }
.health-tile--jobs, .health-tile--overall { grid-column: 1 / -1; }
.health-tile__jobs { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 4px; }
.health-job {
  font-size: .72rem; font-family: var(--ff-mono);
  background: color-mix(in srgb, var(--c-text) 7%, transparent);
  border-radius: 6px; padding: 2px 7px;
}

/* ---------- Ações de manutenção (admin) ---------- */
.maint-actions {
  display: flex; flex-wrap: wrap; gap: var(--sp-2);
}

/* ---------- Audit log (admin) ---------- */
.audit-filters { margin-bottom: var(--sp-3); }
.audit-list {
  display: flex; flex-direction: column;
  max-height: 480px; overflow-y: auto;
  border: 1px solid var(--c-border); border-radius: var(--r-md);
}
.audit-item {
  display: flex; flex-wrap: wrap; align-items: baseline; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  border-left: 3px solid transparent;
  border-bottom: 1px solid var(--c-border);
  font-size: .82rem;
}
.audit-item:last-child { border-bottom: 0; }
.audit-item--ok { border-left-color: var(--c-success); }
.audit-item--danger { border-left-color: var(--c-danger); }
.audit-item__action { font-weight: 600; color: var(--c-text); }
.audit-item__meta { display: inline-flex; flex-wrap: wrap; gap: var(--sp-2); color: var(--c-text-muted); }
.audit-item__ip { opacity: .7; }

/* ---------- Veículos (chips com ilustração SVG) ---------- */
.vehicle-list {
  display: flex; flex-wrap: wrap;
  gap: var(--sp-2);
  margin-top: var(--sp-3);
}
.vehicle-chip {
  display: flex; align-items: center; gap: var(--sp-2);
  padding: 6px var(--sp-3) 6px 6px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  min-width: 0;
}
.vehicle-chip__art {
  width: 44px; height: 44px;
  flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
  /* "Squircle" com fundo levemente tingido de primary — mesmo vocabulário
     visual dos bento-tile__icon. Dá profundidade e moldura ao ícone. */
  border-radius: 13px;
  background: color-mix(in srgb, var(--c-primary) 12%, transparent);
  color: var(--c-primary);   /* o SVG usa currentColor → herda este tom */
}
/* O ícone ocupa ~58% do squircle, centralizado, com respiro nas bordas. */
.vehicle-svg { width: 26px; height: 26px; display: block; }
.vehicle-chip__info {
  display: flex; flex-direction: column; gap: 1px; min-width: 0;
}
.vehicle-chip__name {
  font-size: .82rem; font-weight: 600;
  color: var(--c-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.vehicle-chip__plate {
  font-size: .72rem;
  color: var(--c-text-muted);
  letter-spacing: .5px;
}
.badge--neutral {
  background: color-mix(in srgb, var(--c-text) 8%, transparent);
  color: var(--c-text);
  border: 1px solid var(--c-border);
}
@media (max-width: 640px) {
  .item--with-avatar {
    grid-template-columns: auto 1fr;
    grid-template-areas: "avatar main" "actions actions";
  }
  .item--with-avatar .item__avatar { grid-area: avatar; }
  .item--with-avatar .item__main { grid-area: main; }
  .item--with-avatar .item__actions { grid-area: actions; justify-self: end; }
}
.item__main { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
/* Runs ("Tentativas em andamento"): badge + dados numa LINHA só. Escopado ao
   #runsList pra não mexer no layout empilhado da lista de agendamentos, que
   reusa as mesmas classes .item__main / .item__meta. */
#runsList .item__main {
  flex-direction: row; align-items: center;
  flex-wrap: wrap; gap: var(--sp-2) var(--sp-3);
}
#runsList .item__meta { margin-top: 0; }
.item__title {
  display: flex; align-items: center; gap: var(--sp-2);
  font-weight: 600; font-size: .95rem;
  min-width: 0;
  /* `anywhere` (não `break-all`): só quebra quando realmente não cabe, e nunca
     no meio de uma palavra curta. break-all rachava nomes tipo "Guilher|me". */
  overflow-wrap: anywhere;
}
.item__meta {
  display: flex; flex-wrap: wrap; gap: var(--sp-2) var(--sp-3);
  color: var(--c-text-muted);
  font-size: .82rem;
  margin-top: 4px;
}
.item__meta span { display: inline-flex; align-items: center; gap: 4px; }
.item__meta .mono { font-family: var(--ff-mono); font-variant-numeric: tabular-nums; }
.item__actions { display: flex; gap: var(--sp-2); }

/* ---- Lista de usuários (item--with-avatar): nome é o protagonista, badges
   viram uma "eyebrow" abaixo do nome, metadados ficam discretos. Tudo
   ESCOPADO em .item--with-avatar pra NÃO afetar as listas de runs/schedules
   que reusam .item / .item__title / .item__meta. ---- */
.item--with-avatar .item__name {
  display: -webkit-box; -webkit-box-orient: vertical; -webkit-line-clamp: 2;
  overflow: hidden;
  font-weight: 600; font-size: .95rem; color: var(--c-text);
  overflow-wrap: break-word;            /* quebra só em espaço, nunca no meio da palavra */
}
.item--with-avatar .item__badges {
  display: flex; flex-wrap: wrap; align-items: center; gap: 6px;
  margin-top: 4px;
}
.item--with-avatar .item__func { white-space: nowrap; }   /* matrícula nunca racha */
.item--with-avatar .item__meta {
  flex-direction: column; flex-wrap: nowrap; align-items: stretch;
  gap: 2px; margin-top: 6px;
}
.item--with-avatar .item__email {
  display: block; max-width: 100%;
  font-size: .8rem; color: var(--c-text-soft);
  /* 1 linha com reticências; valor completo no tooltip (title=) */
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.item--with-avatar .item__dates { display: block; font-size: .78rem; color: var(--c-text-muted); }

@media (max-width: 520px) {
  .item { grid-template-columns: 1fr; }
  .item__actions { width: 100%; }
  .item__actions .btn { flex: 1; }
}

/* ---------- Badges ---------- */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px;
  font-size: .75rem; font-weight: 600;
  border-radius: var(--r-pill);
  background: var(--c-surface); color: var(--c-text-muted);
  border: 1px solid var(--c-border);
  text-transform: lowercase;
  letter-spacing: .01em;
}
.badge--running    { background: var(--c-info-soft);    color: var(--c-info);    border-color: transparent; }
.badge--cancelling { background: var(--c-warning-soft); color: var(--c-warning); border-color: transparent; }
.badge--success    { background: var(--c-success-soft); color: var(--c-success); border-color: transparent; }
.badge--failed     { background: var(--c-danger-soft);  color: var(--c-danger);  border-color: transparent; }
.badge--cancelled  { background: var(--c-surface-2);    color: var(--c-text-soft); }
.badge--day        { background: var(--c-primary-soft); color: var(--c-primary); border-color: transparent; }

.dot {
  display: inline-block; width: 8px; height: 8px; border-radius: 50%;
  background: var(--c-text-soft);
  margin-left: 6px; vertical-align: middle;
}
.dot--live { background: var(--c-success); box-shadow: 0 0 0 4px color-mix(in srgb, var(--c-success) 25%, transparent); animation: pulse 1.6s infinite; }
.dot--idle { background: var(--c-text-soft); }
.dot--error { background: var(--c-danger); }

@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-success) 35%, transparent); }
  50%      { box-shadow: 0 0 0 6px color-mix(in srgb, var(--c-success) 0%, transparent); }
}

/* ---------- Empty / Skeleton ---------- */
.empty {
  padding: var(--sp-5) var(--sp-4);
  text-align: center;
  color: var(--c-text-muted);
  background: var(--c-surface-2);
  border: 1px dashed var(--c-border);
  border-radius: var(--r-md);
}
.empty .skeleton + .skeleton { margin-top: var(--sp-2); }
.skeleton {
  height: 14px; border-radius: var(--r-sm);
  background: linear-gradient(90deg,
    var(--c-surface-2) 0%,
    color-mix(in srgb, var(--c-surface-2) 60%, var(--c-text-soft) 20%) 50%,
    var(--c-surface-2) 100%);
  background-size: 200% 100%;
  animation: skeleton 1.4s infinite;
}
.skeleton--sm { width: 60%; margin-left: auto; margin-right: auto; }
@keyframes skeleton {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .skeleton, .dot--live { animation: none; }
}

/* ---------- Toast ---------- */
.toast-container {
  position: fixed; right: var(--sp-4); bottom: var(--sp-4);
  display: flex; flex-direction: column; gap: var(--sp-2);
  z-index: 100;
  max-width: min(380px, calc(100vw - 32px));
}
.toast {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  box-shadow: var(--shadow-lg);
  display: flex; align-items: flex-start; gap: var(--sp-3);
  animation: toast-in .25s ease;
}
.toast--success { border-left: 3px solid var(--c-success); }
.toast--error   { border-left: 3px solid var(--c-danger); }
.toast--info    { border-left: 3px solid var(--c-primary); }
.toast__body { flex: 1; font-size: .9rem; }
.toast__close {
  background: transparent; border: 0; color: var(--c-text-muted);
  padding: 2px 6px; border-radius: var(--r-sm);
}
.toast__close:hover { color: var(--c-text); background: var(--c-surface-2); }

@keyframes toast-in {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Modal ---------- */
.modal {
  position: fixed; inset: 0;
  display: grid; place-items: center;
  z-index: 200;
  padding: var(--sp-4);
}
.modal[hidden] { display: none; }
.modal__backdrop {
  position: absolute; inset: 0;
  background: rgba(0, 0, 0, .55);
  animation: fade-in .15s ease;
}
.modal__dialog {
  position: relative;
  /* Mesmo material de vidro das cards — translúcido + blur sobre o backdrop. */
  background: color-mix(in srgb, var(--c-surface) 90%, transparent);
  backdrop-filter: blur(24px) saturate(150%);
  -webkit-backdrop-filter: blur(24px) saturate(150%);
  border: 1px solid color-mix(in srgb, var(--c-border) 80%, transparent);
  border-radius: 24px;
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, .12);
  padding: var(--sp-6);
  width: 100%; max-width: 420px;
  animation: modal-in .2s ease;
}
.modal__title { margin: 0 0 var(--sp-2); font-size: 1.05rem; }
.modal__message { margin: 0 0 var(--sp-4); color: var(--c-text-muted); }
.modal__actions { display: flex; gap: var(--sp-2); justify-content: flex-end; flex-wrap: wrap; align-items: center; }

/* Modal de form (criar usuário, conceder plano): mais largo, com espaçamento
   ergonômico pros campos. Em mobile, ocupa toda a tela com margem segura. */
.modal__dialog--form {
  max-width: 480px;
}
.modal__dialog--form .form {
  margin-top: var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}
.modal__dialog--form .modal__actions {
  margin-top: var(--sp-2);
  padding-top: var(--sp-3);
  border-top: 1px solid var(--c-border);
}
.modal__actions--split {
  justify-content: space-between;
}
.modal__actions__right {
  display: inline-flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}
@media (max-width: 520px) {
  .modal__actions--split {
    flex-direction: column;
    align-items: stretch;
  }
  .modal__actions__right { justify-content: stretch; }
  .modal__actions__right .btn { flex: 1; }
}
@media (max-width: 520px) {
  .modal { padding: var(--sp-3); align-items: flex-end; }
  .modal__dialog--form {
    max-width: 100%;
    border-radius: var(--r-lg) var(--r-lg) 0 0;
    padding: var(--sp-4) var(--sp-4) calc(var(--sp-4) + env(safe-area-inset-bottom, 0));
  }
}

@keyframes fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-in {
  from { opacity: 0; transform: translateY(10px) scale(.98); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* ---------- Flatpickr ajustes ao tema ---------- */
.flatpickr-calendar {
  background: var(--c-surface) !important;
  color: var(--c-text) !important;
  border: 1px solid var(--c-border) !important;
  box-shadow: var(--shadow-lg) !important;
}
.flatpickr-day { color: var(--c-text) !important; }
.flatpickr-day.flatpickr-disabled,
.flatpickr-day.prevMonthDay,
.flatpickr-day.nextMonthDay { color: var(--c-text-soft) !important; }
.flatpickr-day.selected,
.flatpickr-day.selected:hover {
  background: var(--c-primary) !important;
  border-color: var(--c-primary) !important;
  color: #fff !important;
}
.flatpickr-day:hover { background: var(--c-surface-2) !important; }
.flatpickr-months .flatpickr-month,
.flatpickr-weekdays,
span.flatpickr-weekday {
  background: var(--c-surface) !important;
  color: var(--c-text-muted) !important;
}
.flatpickr-current-month .flatpickr-monthDropdown-months,
.flatpickr-current-month input.cur-year {
  color: var(--c-text) !important;
}
.flatpickr-months .flatpickr-prev-month,
.flatpickr-months .flatpickr-next-month { fill: var(--c-text) !important; color: var(--c-text) !important; }

/* ---------- User menu (dropdown na topbar) ---------- */
.user-menu { position: relative; }
.user-menu__trigger {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  height: 38px; padding: 0 12px;
  background: transparent; border: 1px solid var(--c-border);
  color: var(--c-text); border-radius: var(--r-md);
  font-size: .9rem; max-width: 200px;
  transition: background .15s, border-color .15s;
}
.user-menu__trigger:hover { background: var(--c-surface-2); }
.user-menu__avatar {
  width: 24px; height: 24px; border-radius: 50%;
  background: linear-gradient(135deg, var(--c-primary), var(--c-info));
  flex-shrink: 0;
}
.user-menu__name {
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.user-menu__caret { width: 14px; height: 14px; flex-shrink: 0; }

.user-menu__dropdown {
  position: absolute; right: 0; top: calc(100% + 6px);
  /* largura suficiente pra nome completo + e-mail corporativo + itens
     ("Configurações ParkFácil") caberem em UMA linha cada. */
  min-width: 300px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-lg);
  padding: 6px;
  z-index: 60;
  display: flex; flex-direction: column;
}
.user-menu__item {
  background: transparent; border: 0;
  padding: 8px 12px;
  text-align: left;
  border-radius: var(--r-sm);
  color: var(--c-text);
  font-size: .9rem;
  white-space: nowrap;        /* sem quebra de linha nos itens do menu */
}
.user-menu__item:hover { background: var(--c-surface-2); }
.user-menu__item--danger { color: var(--c-danger); }
.user-menu__separator {
  height: 1px; background: var(--c-border);
  margin: 4px 0;
}

@media (max-width: 520px) {
  .user-menu__trigger { padding: 0 8px; max-width: 140px; }
  .user-menu__name { font-size: .85rem; }
}

/* ---------- Input com botão lateral (revelar senha etc.) ---------- */
.input-row {
  display: flex; gap: var(--sp-2);
  align-items: stretch;
}
.input-row .input { flex: 1; }
.input-row .icon-btn { flex-shrink: 0; height: auto; }

/* ---------- Banner (warning/info) ---------- */
.banner {
  display: flex; gap: var(--sp-3);
  align-items: flex-start;
  padding: var(--sp-3) var(--sp-4);
  border-radius: var(--r-md);
  border: 1px solid var(--c-border);
  margin-bottom: var(--sp-4);
  font-size: .9rem;
}
.banner--warning {
  background: color-mix(in srgb, var(--c-warning) 14%, var(--c-surface));
  border-color: color-mix(in srgb, var(--c-warning) 35%, var(--c-border));
  color: var(--c-text);
}
.banner__icon {
  width: 20px; height: 20px;
  stroke: var(--c-warning); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 1px;
}
.banner__body { flex: 1; line-height: 1.45; }
.banner__link {
  background: transparent; border: 0; padding: 0;
  margin-left: var(--sp-2);
  color: var(--c-primary);
  font: inherit;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.banner__link:hover { color: var(--c-primary-600); }

/* ---------- Asterisco de campo obrigatório + form hint ---------- */
.label__req {
  color: var(--c-danger);
  font-weight: 700;
  margin-left: 2px;
}
.form__hint {
  color: var(--c-text-muted);
  font-size: .8rem;
  margin: 0;
}

/* ---------- Linha label + link "como obter?" ---------- */
.label-row {
  display: flex; align-items: baseline; justify-content: space-between;
  gap: var(--sp-2); flex-wrap: wrap;
}
.link-btn {
  background: transparent; border: 0; padding: 0;
  color: var(--c-primary);
  font: inherit; font-size: .8rem;
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.link-btn:hover { color: var(--c-primary-600); }

/* ---------- Help panel (tutorial inline) ---------- */
.help-panel {
  margin-top: var(--sp-3);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  font-size: .88rem;
  line-height: 1.5;
}
.help-panel__title {
  margin: 0 0 var(--sp-2);
  font-weight: 600;
  color: var(--c-text);
}
.help-panel__steps {
  margin: 0 0 var(--sp-3) var(--sp-4);
  padding: 0;
  color: var(--c-text);
}
.help-panel__steps li {
  margin-bottom: var(--sp-2);
}
.help-panel__steps li:last-child { margin-bottom: 0; }
.help-panel__steps code {
  font-family: var(--ff-mono);
  font-size: .85em;
  padding: 1px 6px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
}
.help-panel__steps a { color: var(--c-primary); }
.help-panel__note {
  margin: var(--sp-2) 0 0;
  color: var(--c-text-muted);
  font-size: .85rem;
}

/* ---------- Conexão Microsoft (states card) ---------- */
.ms-state {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-3);
  padding: var(--sp-4);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  margin-top: var(--sp-3);
}
.ms-state--linking {
  background: color-mix(in srgb, var(--c-primary) 10%, var(--c-surface));
  border-color: color-mix(in srgb, var(--c-primary) 35%, transparent);
}
.ms-state--error {
  background: color-mix(in srgb, var(--c-danger) 10%, var(--c-surface));
  border-color: color-mix(in srgb, var(--c-danger) 35%, transparent);
}
.ms-state__icon {
  width: 40px; height: 40px;
  flex-shrink: 0;
  display: grid; place-items: center;
  border-radius: 50%;
  background: var(--c-surface);
}
.ms-state__icon svg {
  width: 22px; height: 22px;
  stroke: currentColor; fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.ms-state__icon--neutral { color: var(--c-text-muted); }
.ms-state__icon--active  { color: var(--c-primary); }
.ms-state__icon--ok      { color: var(--c-success); }
.ms-state__icon--error   { color: var(--c-danger); }
.ms-state__spinner {
  width: 22px; height: 22px;
  border-radius: 50%;
  border: 3px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  border-top-color: var(--c-primary);
  animation: spin 1s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }
@media (prefers-reduced-motion: reduce) { .ms-state__spinner { animation: none; } }

/* Botão "Atualizar" (calendário) enquanto sincroniza: o ícone de setas gira.
   O atributo disabled já bloqueia novos cliques; isto é só o feedback visual. */
.btn.is-busy { cursor: progress; }
.btn.is-busy .icon { animation: spin 1s linear infinite; transform-origin: center; }
@media (prefers-reduced-motion: reduce) { .btn.is-busy .icon { animation: none; } }

.ms-state__body {
  flex: 1; min-width: 0;
}
.ms-state__title {
  margin: 0 0 4px;
  font-weight: 600;
  font-size: .95rem;
  color: var(--c-text);
}
.ms-state__desc {
  margin: 0;
  font-size: .85rem;
  color: var(--c-text-muted);
  line-height: 1.4;
  word-break: break-word;
}
.ms-state__steps {
  margin: var(--sp-2) 0 0 var(--sp-4);
  padding: 0;
  color: var(--c-text);
  font-size: .88rem;
  line-height: 1.5;
}
.ms-state__steps li { margin-bottom: 6px; }
.ms-state__steps li:last-child { margin-bottom: 0; }
.ms-state__steps a {
  color: var(--c-primary);
  word-break: break-all;
}
.ms-state__code {
  display: inline-block;
  padding: 4px 10px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  font-family: var(--ff-mono);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: .08em;
  color: var(--c-text);
  user-select: all;
}
.ms-state__expires {
  margin: var(--sp-3) 0 0;
  font-size: .8rem;
  color: var(--c-text-muted);
}

@media (max-width: 520px) {
  .ms-state { flex-direction: column; }
  .ms-state .btn { width: 100%; }
}

/* ---------- Form/buttons em estado disabled ---------- */
.form button[type="submit"]:disabled,
.form button[disabled] {
  opacity: .5;
  cursor: not-allowed;
  pointer-events: none;
}

/* ---------- Badge de tier no topbar + info no dropdown ---------- */
.user-menu__tier {
  font-size: .7rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: var(--r-pill);
  background: var(--c-primary-soft);
  color: var(--c-primary);
  letter-spacing: .02em;
  text-transform: uppercase;
}
.user-menu__tier--admin { background: color-mix(in srgb, var(--c-text) 8%, transparent); color: var(--c-text); }
.user-menu__tier--inactive { background: var(--c-danger-soft); color: var(--c-danger); }

.user-menu__identity {
  padding: 10px 12px 8px;
  display: flex;
  flex-direction: column;
  gap: 2px;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 4px;
}
.user-menu__identity-name {
  font-size: .92rem;
  font-weight: 600;
  color: var(--c-text);
  line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.user-menu__identity-email {
  font-size: .75rem;
  color: var(--c-text-muted);
  line-height: 1.3;
  /* sem break-all: e-mail fica em 1 linha; se estourar, vira reticências */
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

.user-menu__info {
  padding: 6px 12px 10px;
  border-bottom: 1px solid var(--c-border);
  margin-bottom: 4px;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4px 8px;
  align-items: baseline;
}
.user-menu__info-label {
  font-size: .7rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--c-text-soft);
}
.user-menu__info-value {
  font-size: .9rem;
  font-weight: 600;
  color: var(--c-text);
}
.user-menu__info-expires {
  grid-column: 1 / -1;
  font-size: .75rem;
  color: var(--c-text-muted);
}

/* ---------- Chip de uso (X/Y agendamentos) ---------- */
.usage-chip {
  display: inline-block;
  margin-left: var(--sp-2);
  padding: 2px 8px;
  border-radius: var(--r-pill);
  background: var(--c-surface-2);
  border: 1px solid var(--c-border);
  font-size: .75rem;
  font-weight: 600;
  color: var(--c-text-muted);
  font-variant-numeric: tabular-nums;
}
.usage-chip--limit {
  background: var(--c-warning-soft);
  border-color: transparent;
  color: var(--c-warning);
}


/* ---------- Auth pages (login + bootstrap + onboarding) ---------- */
/* Mesmo idioma do hero do "Meu perfil": um mesh de gradientes que respira
   atrás de um cartão de vidro. O mesh fica num ::before fixo (não rola e não
   captura toque); as cores vêm dos tokens, então acompanha claro/escuro. */
.auth-body {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: var(--c-bg);
  overflow: hidden;
}
.auth-body::before {
  content: '';
  position: fixed;
  inset: -30%;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(34% 38% at 26% 18%, color-mix(in srgb, var(--c-primary) 42%, transparent), transparent 70%),
    radial-gradient(30% 34% at 78% 12%, color-mix(in srgb, var(--c-info) 36%, transparent), transparent 70%),
    radial-gradient(40% 44% at 68% 88%, color-mix(in srgb, #8b5cf6 32%, transparent), transparent 72%);
  filter: blur(60px) saturate(135%);
  animation: hero-mesh 18s ease-in-out infinite alternate;
}
.auth-container {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 420px;
  padding: var(--sp-4);
}
/* Cartão de vidro: translúcido + blur deixa o mesh refratar nas bordas. */
.auth-card {
  background: color-mix(in srgb, var(--c-surface) 72%, transparent);
  backdrop-filter: blur(30px) saturate(165%);
  -webkit-backdrop-filter: blur(30px) saturate(165%);
  border: 1px solid color-mix(in srgb, var(--c-border) 70%, transparent);
  border-radius: 26px;
  padding: var(--sp-8) var(--sp-6);
  box-shadow: var(--shadow-lg), inset 0 1px 0 rgba(255, 255, 255, .14);
  animation: profile-rise .6s cubic-bezier(.2, .8, .2, 1) backwards;
}
@media (prefers-reduced-motion: reduce) {
  .auth-body::before { animation: none; }
  .auth-card { animation: none; }
}
.auth-brand {
  display: flex; align-items: center; gap: var(--sp-3);
  font-weight: 700;
  margin-bottom: var(--sp-6);
}
.auth-title {
  font-size: 1.4rem;
  font-weight: 600;
  margin: 0 0 var(--sp-3);
  letter-spacing: -.01em;
}
.auth-hint {
  margin: 0 0 var(--sp-5);
  color: var(--c-text-muted);
  font-size: .9rem;
  line-height: 1.5;
}
.field__hint {
  color: var(--c-text-muted);
  font-size: .8rem;
}
.auth-card .btn--primary {
  width: 100%;
  margin-top: var(--sp-2);
}

/* ---------- Utilitários ---------- */
.mono { font-family: var(--ff-mono); font-variant-numeric: tabular-nums; }
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0, 0, 0, 0); white-space: nowrap; border: 0;
}

/* ---------- Aba Admin (Configurações do sistema) ---------- */
.admin-sections {
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
}
.admin-section {
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4) var(--sp-4);
  margin: 0;
}
.admin-section__title {
  padding: 0 var(--sp-2);
  font-weight: 700;
  font-size: .92rem;
  color: var(--c-text);
  letter-spacing: .02em;
  text-transform: uppercase;
}
.admin-section__fields {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-3);
  margin-top: var(--sp-2);
}
@media (min-width: 720px) {
  .admin-section__fields { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.admin-field { margin: 0; }

/* Toggle on/off pros settings do tipo "bool" (ex.: Usar VPN) */
.admin-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  cursor: pointer;
  user-select: none;
}
.admin-toggle__input {
  position: absolute;
  opacity: 0;
  width: 0; height: 0;
}
.admin-toggle__track {
  position: relative;
  width: 44px; height: 26px;
  flex-shrink: 0;
  background: var(--c-border);
  border-radius: 999px;
  transition: background 180ms ease;
}
.admin-toggle__thumb {
  position: absolute;
  top: 3px; left: 3px;
  width: 20px; height: 20px;
  background: #fff;
  border-radius: 50%;
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
  transition: transform 180ms cubic-bezier(.2,.8,.2,1);
}
.admin-toggle__input:checked + .admin-toggle__track {
  background: var(--c-primary);
}
.admin-toggle__input:checked + .admin-toggle__track .admin-toggle__thumb {
  transform: translateX(18px);
}
.admin-toggle__input:focus-visible + .admin-toggle__track {
  outline: 2px solid var(--c-primary);
  outline-offset: 2px;
}
.admin-toggle__state {
  font-size: .85rem;
  font-weight: 600;
  color: var(--c-text);
}
@media (prefers-reduced-motion: reduce) {
  .admin-toggle__thumb, .admin-toggle__track { transition: none; }
}

.admin-field__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-2);
  margin-bottom: 4px;
}
.admin-field__badges {
  display: inline-flex;
  gap: 4px;
  flex-shrink: 0;
}
.admin-badge {
  display: inline-block;
  padding: 1px 6px;
  font-size: .7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  border-radius: 4px;
  border: 1px solid transparent;
}
.admin-badge--restart {
  background: rgba(217, 119, 6, .12);
  color: #b45309;
  border-color: rgba(217, 119, 6, .3);
}
.admin-badge--live {
  background: rgba(22, 163, 74, .12);
  color: #15803d;
  border-color: rgba(22, 163, 74, .3);
}
.admin-badge--override {
  background: rgba(59, 130, 246, .12);
  color: #1d4ed8;
  border-color: rgba(59, 130, 246, .3);
}
@media (prefers-color-scheme: dark) {
  .admin-badge--restart { color: #fbbf24; }
  .admin-badge--live { color: #4ade80; }
  .admin-badge--override { color: #60a5fa; }
}
.admin-field__key {
  font-family: var(--ff-mono);
  font-size: .72rem;
  opacity: .7;
}
.form__actions--split {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sp-3);
  flex-wrap: wrap;
}
.form__actions--split > div {
  display: inline-flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
}

/* ============================================================================
   Sessão Bookker — paste-JWT card (Apple-polish)
   ============================================================================ */

/* Ícone inline no título do card */
.card__title { display: inline-flex; align-items: center; gap: var(--sp-2); }
.card__title-icon {
  width: 20px; height: 20px;
  stroke: var(--c-primary); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  opacity: .9;
}

.token-card { position: relative; }

/* Variants extra do ms-state pra "ok" e "warn" -- complementam linking/error */
.ms-state--ok {
  background: color-mix(in srgb, var(--c-success) 10%, var(--c-surface));
  border-color: color-mix(in srgb, var(--c-success) 35%, transparent);
}
.ms-state--warn {
  background: color-mix(in srgb, var(--c-warning) 12%, var(--c-surface));
  border-color: color-mix(in srgb, var(--c-warning) 35%, transparent);
}
.ms-state__icon--warn { color: var(--c-warning); }

/* Animação de entrada do estado */
.token-state {
  opacity: 0;
  transform: translateY(-4px);
  transition: opacity 240ms cubic-bezier(.2,.8,.2,1), transform 240ms cubic-bezier(.2,.8,.2,1);
}
.token-state.is-active {
  opacity: 1;
  transform: translateY(0);
}
@media (prefers-reduced-motion: reduce) {
  .token-state { transition: none; }
}

/* Pulse "ao vivo" no título do estado linked */
.token-pulse {
  display: inline-block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--c-success);
  box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-success) 60%, transparent);
  margin-left: 6px;
  vertical-align: middle;
  animation: tokenPulse 2s ease-out infinite;
}
@keyframes tokenPulse {
  0%   { box-shadow: 0 0 0 0    color-mix(in srgb, var(--c-success) 60%, transparent); }
  70%  { box-shadow: 0 0 0 10px color-mix(in srgb, var(--c-success) 0%,  transparent); }
  100% { box-shadow: 0 0 0 0    color-mix(in srgb, var(--c-success) 0%,  transparent); }
}
@media (prefers-reduced-motion: reduce) { .token-pulse { animation: none; } }

/* Meta do estado linked: validade, fingerprint, CSRF chip */
.token-meta {
  display: inline-flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--sp-2);
  margin-top: 4px;
  font-size: .8rem;
}
.token-meta__item {
  display: inline-flex; align-items: center; gap: 4px;
  color: var(--c-text-muted);
}
.token-meta__item .icon { width: 14px; height: 14px; stroke-width: 2; }
.token-meta__item--csrf {
  background: color-mix(in srgb, var(--c-success) 14%, transparent);
  color: var(--c-success);
  padding: 1px 8px;
  border-radius: 99px;
  font-weight: 600;
  font-size: .72rem;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.token-fingerprint {
  font-family: var(--ff-mono);
  font-size: .78rem;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  color: var(--c-text);
  letter-spacing: .04em;
}

/* Botão ghost com tom danger pro Remover */
.btn--ghost-danger {
  color: var(--c-danger);
}
.btn--ghost-danger:hover {
  background: color-mix(in srgb, var(--c-danger) 10%, transparent);
}

/* Form de paste */
.token-form { margin-top: var(--sp-4); }

.label__hint {
  margin-left: 6px;
  font-weight: 400;
  font-size: .78rem;
  color: var(--c-text-muted);
}

.token-input-wrap { position: relative; }
.token-input {
  font-family: var(--ff-mono);
  font-size: .82rem;
  letter-spacing: .01em;
  line-height: 1.4;
  resize: vertical;
  min-height: 64px;
  word-break: break-all;
  white-space: pre-wrap;
  padding-right: 36px; /* espaço pro botão clear */
  transition: border-color 200ms ease, box-shadow 200ms ease, background 240ms ease;
}
.token-input.is-extracted {
  background: color-mix(in srgb, var(--c-success) 12%, var(--c-bg));
  border-color: var(--c-success);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--c-success) 18%, transparent);
}
@media (prefers-reduced-motion: reduce) { .token-input { transition: none; } }

.token-input__clear {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: 50%;
  cursor: pointer;
  color: var(--c-text-muted);
  transition: background 160ms ease, color 160ms ease, transform 160ms ease;
}
.token-input__clear:hover {
  background: var(--c-danger);
  border-color: var(--c-danger);
  color: #fff;
  transform: scale(1.06);
}
.token-input__clear .icon { width: 14px; height: 14px; stroke-width: 2.4; }

/* "Como obter o token" — collapsible refinado */
.token-howto {
  margin-top: var(--sp-3);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  background: color-mix(in srgb, var(--c-primary) 6%, var(--c-surface));
  overflow: hidden;
  transition: background 200ms ease;
}
.token-howto > summary {
  list-style: none;
  cursor: pointer;
  padding: var(--sp-3) var(--sp-4);
  display: flex; align-items: center; gap: var(--sp-2);
  font-weight: 600;
  font-size: .9rem;
  color: var(--c-text);
  user-select: none;
}
.token-howto > summary::-webkit-details-marker { display: none; }
.token-howto > summary > span { flex: 1; }
.token-howto > summary > .icon {
  width: 18px; height: 18px;
  stroke: var(--c-primary); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
}
.token-howto__caret {
  width: 16px; height: 16px;
  stroke: var(--c-text-muted); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  transition: transform 240ms cubic-bezier(.2,.8,.2,1);
  flex-shrink: 0;
}
.token-howto[open] .token-howto__caret { transform: rotate(180deg); }
@media (prefers-reduced-motion: reduce) {
  .token-howto__caret { transition: none; }
}

.token-steps {
  list-style: none;
  margin: 0;
  padding: 0 var(--sp-4) var(--sp-3);
  display: grid;
  gap: var(--sp-3);
}
.token-steps li {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 12px;
  align-items: start;
  font-size: .9rem;
  line-height: 1.55;
  color: var(--c-text);
}
.token-steps__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 24px; height: 24px;
  flex-shrink: 0;
  background: var(--c-primary);
  color: #fff;
  border-radius: 50%;
  font-size: .76rem;
  font-weight: 700;
  margin-top: 1px;
}
.token-steps__text { min-width: 0; }
.token-steps em {
  font-style: normal;
  font-weight: 600;
  color: var(--c-text);
  padding: 1px 6px;
  border-radius: 4px;
  background: color-mix(in srgb, var(--c-primary) 12%, transparent);
}

.token-howto__callout {
  display: flex;
  gap: var(--sp-2);
  align-items: flex-start;
  margin: 0 var(--sp-4) var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: color-mix(in srgb, var(--c-warning) 14%, transparent);
  border-left: 3px solid var(--c-warning);
  border-radius: var(--r-sm);
}
.token-howto__callout > .icon {
  width: 18px; height: 18px;
  stroke: var(--c-warning); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 1px;
}
.token-howto__callout p {
  margin: 0;
  font-size: .85rem;
  line-height: 1.45;
  color: var(--c-text);
}
.token-steps code,
.token-howto code {
  font-family: var(--ff-mono);
  font-size: .82rem;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--c-surface);
  border: 1px solid var(--c-border);
}
.token-steps kbd {
  font-family: var(--ff-mono);
  font-size: .72rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 4px;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-bottom-width: 2px;
  box-shadow: 0 1px 0 var(--c-border);
  color: var(--c-text);
}
.token-steps a { color: var(--c-primary); }

.token-howto__tip {
  display: flex; gap: var(--sp-2); align-items: flex-start;
  margin: 0 var(--sp-4) var(--sp-3);
  padding: var(--sp-2) var(--sp-3);
  background: var(--c-surface);
  border: 1px dashed color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
  border-radius: var(--r-sm);
  font-size: .82rem;
  color: var(--c-text-muted);
  line-height: 1.45;
}
.token-howto__tip > .icon {
  width: 16px; height: 16px;
  stroke: var(--c-success); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 2px;
}
.token-howto__tip strong { color: var(--c-text); }

/* Variant "info" (ícone azul) pro tip da rolling session */
.token-howto__tip--info {
  border-color: color-mix(in srgb, var(--c-primary) 35%, var(--c-border));
}
.token-howto__tip--info > .icon { stroke: var(--c-primary); }

/* ============================================================
   Fluxo "Conectar" (bookmarklet) — caminho principal, mobile-first.
   Reusa os tokens de cor/spacing/raio do resto do app.
   ============================================================ */
.token-connect {
  margin-top: var(--sp-3);
}

/* Passos numerados — mesmo idioma visual do .token-steps */
.connect-steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--sp-4);
}
.connect-step {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 12px;
  align-items: start;
}
.connect-step__num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px;
  flex-shrink: 0;
  background: var(--c-primary);
  color: #fff;
  border-radius: 50%;
  font-size: .82rem;
  font-weight: 700;
}
.connect-step__body { min-width: 0; }
.connect-step__title {
  margin: 2px 0 var(--sp-2);
  font-weight: 600;
  font-size: .95rem;
  color: var(--c-text);
}
.connect-step__desc {
  margin: 0 0 var(--sp-2);
  font-size: .88rem;
  line-height: 1.5;
  color: var(--c-text-muted);
}
.connect-step__desc a { color: var(--c-primary); }

/* Botão-atalho (bookmarklet) — visual de "favorito arrastável" */
.bookmarklet-btn {
  display: inline-flex; align-items: center; gap: var(--sp-2);
  padding: 10px var(--sp-4);
  border-radius: var(--r-md);
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--c-primary) 92%, #000),
    var(--c-primary));
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  text-decoration: none;
  border: 1px solid color-mix(in srgb, var(--c-primary) 60%, #000);
  box-shadow: 0 2px 8px color-mix(in srgb, var(--c-primary) 30%, transparent);
  cursor: grab;
  user-select: none;
  -webkit-user-drag: element;
}
.bookmarklet-btn:active { cursor: grabbing; }
.bookmarklet-btn > .icon {
  width: 18px; height: 18px;
  fill: #fff; stroke: none;
  flex-shrink: 0;
}

/* Ajuda "como guardar o atalho" — colapsável e por plataforma */
.connect-help { margin-top: var(--sp-2); }
.connect-help__body {
  margin-top: var(--sp-2);
  padding: var(--sp-3);
  background: color-mix(in srgb, var(--c-primary) 6%, var(--c-surface));
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
}
.connect-help__steps {
  margin: 0 0 var(--sp-2);
  padding-left: 1.2em;
  font-size: .85rem;
  line-height: 1.55;
  color: var(--c-text);
  display: grid;
  gap: 4px;
}
.connect-help__steps strong { color: var(--c-text); }

/* Onboarding iOS-Safari: dois métodos (Favorito / app Atalhos) em <details>. */
.connect-help__lead {
  margin: 0 0 var(--sp-2);
  font-size: .85rem;
  color: var(--c-text-muted);
}
.connect-method {
  margin-top: var(--sp-2);
  border: 1px solid var(--c-border);
  border-radius: var(--r-sm);
  background: var(--c-surface);
  overflow: hidden;
}
.connect-method > summary {
  list-style: none;
  cursor: pointer;
  display: flex; align-items: center; gap: var(--sp-2);
  padding: var(--sp-2) var(--sp-3);
  font-weight: 600; font-size: .88rem;
  color: var(--c-text);
  user-select: none;
}
.connect-method > summary::-webkit-details-marker { display: none; }
.connect-method > summary:hover { color: var(--c-primary); }
.connect-method[open] > summary { border-bottom: 1px solid var(--c-border); }
.connect-method__icon { font-size: 1rem; line-height: 1; }
.connect-method__body { padding: var(--sp-3); }
.connect-method__body .connect-help__steps { margin-bottom: var(--sp-3); }
/* Botão "Adicionar atalho ao iPhone" pode quebrar linha em telas estreitas em
   vez de cortar o texto (o `.btn` base é nowrap). */
.connect-method__body > .btn { margin-bottom: var(--sp-3); white-space: normal; }

/* Sub-método recolhido (fallback "montar na mão") dentro do método Atalhos. */
.connect-submethod {
  margin-top: var(--sp-2);
  border-top: 1px solid var(--c-border);
  padding-top: var(--sp-2);
}
.connect-submethod > summary {
  list-style: none;
  cursor: pointer;
  font-size: .82rem;
  color: var(--c-text-muted);
  user-select: none;
}
.connect-submethod > summary::-webkit-details-marker { display: none; }
.connect-submethod > summary:hover { color: var(--c-primary); }
.connect-submethod .connect-help__steps { margin-top: var(--sp-2); }

/* Aviso "abra no Safari" — iPhone fora do Safari, onde o atalho não roda. */
.connect-help__nudge {
  display: flex; gap: var(--sp-2); align-items: flex-start;
  font-size: .85rem; line-height: 1.5; color: var(--c-text);
}
.connect-help__nudge > .icon {
  width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px;
  stroke: var(--c-primary); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.connect-help__nudge p { margin: 0; }

/* --- Variante iPhone (token-connect--ios) ---------------------------------
   No iPhone o fluxo do app Atalhos é auto-suficiente, então escondemos o
   andaime genérico de 3 passos e mostramos a ajuda "Pelo app Atalhos" de cara.
   A classe é adicionada ao painel por bookker_token.js quando detecta iOS. */
/* Sem bolinhas numeradas: a ajuda já tem a própria lista numerada interna. */
.token-connect--ios .connect-step {
  grid-template-columns: 1fr;
}
.token-connect--ios .connect-step__num {
  display: none;
}
/* Passo 1: esconde o título e o botão arrastável (o "Conectar ParkFácil" é
   pra arrastar no desktop; no iPhone a conexão sai pelo app Atalhos). */
.token-connect--ios .connect-step--save .connect-step__title,
.token-connect--ios .connect-step--save .bookmarklet-btn {
  display: none;
}
/* A ajuda deixa de ser um colapsável dentro do passo: vira o conteúdo
   principal, sem moldura extra e sem o margin-top do toggle. */
.token-connect--ios .connect-step--save .connect-help { margin-top: 0; }
.token-connect--ios .connect-step--save .connect-help__body { margin-top: 0; }
/* Passo 2 ("Abra o Bookker e toque no atalho") é redundante: a última etapa
   das instruções do app Atalhos já cobre "Partilhar → Conectar ParkFácil". */
.token-connect--ios .connect-step--open {
  display: none;
}

/* Banner de auto-conexão: aparece ao voltar do atalho (#at=) enquanto a troca
   roda. Spinner + "Conectando como <usuário>…". */
.token-connecting {
  display: flex; align-items: center; gap: var(--sp-3);
  margin-bottom: var(--sp-3);
  padding: var(--sp-3) var(--sp-4);
  background: color-mix(in srgb, var(--c-primary) 8%, var(--c-surface));
  border: 1px solid color-mix(in srgb, var(--c-primary) 25%, var(--c-border));
  border-radius: var(--r-md);
}
.token-connecting__text {
  font-size: .9rem; font-weight: 600; color: var(--c-text);
}

/* Bloco do paste manual (fallback) dentro do passo 3 */
.token-manual {
  margin-top: var(--sp-3);
}
.token-manual > summary {
  list-style: none;
  cursor: pointer;
  font-size: .82rem;
  color: var(--c-text-muted);
  user-select: none;
}
.token-manual > summary::-webkit-details-marker { display: none; }
.token-manual > summary:hover { color: var(--c-primary); }
.token-manual .token-input { margin-top: var(--sp-2); }
.token-manual .btn { margin-top: var(--sp-2); }

/* Botão full-width (usado no fluxo Conectar, mobile-first) */
.btn--block { width: 100%; justify-content: center; }

/* Método avançado (DevTools) — mesmo visual do .token-howto */
.token-advanced {
  margin-top: var(--sp-4);
  border-top: 1px solid var(--c-border);
  padding-top: var(--sp-3);
}
.token-advanced > summary {
  list-style: none;
  cursor: pointer;
  display: flex; align-items: center; gap: var(--sp-2);
  font-weight: 600;
  font-size: .85rem;
  color: var(--c-text-muted);
  user-select: none;
}
.token-advanced > summary::-webkit-details-marker { display: none; }
.token-advanced > summary > span { flex: 1; }
.token-advanced > summary > .icon {
  width: 16px; height: 16px;
  stroke: var(--c-text-muted); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
}
.token-advanced > summary:hover { color: var(--c-primary); }
.token-advanced[open] .token-howto__caret { transform: rotate(180deg); }

/* Pulso de destaque no botão "Colar e conectar" quando o user volta do
   bookmarklet (?connect=1). Chama a atenção sem ser agressivo. */
@keyframes connect-pulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--c-primary) 45%, transparent); }
  50%      { box-shadow: 0 0 0 8px color-mix(in srgb, var(--c-primary) 0%, transparent); }
}
.btn.is-pulsing { animation: connect-pulse 1.2s ease-out 2; }
@media (prefers-reduced-motion: reduce) {
  .btn.is-pulsing { animation: none; }
}

/* Token state em layout responsivo: empilha em mobile */
@media (max-width: 520px) {
  .token-state { flex-wrap: wrap; }
  .token-state .btn { flex: 1; min-width: 0; }
  .token-meta { width: 100%; }
}

/* ============================================================================
   EULA + Onboarding
   ============================================================================ */

/* Padroniza textarea com `.token-input`: usa o mesmo padding do input regular
   pra que .token-input em <input> e <textarea> tenham mesma altura visual e
   alinhamento de caixa. */
textarea.token-input {
  min-height: 2.6rem;
  padding-top: 10px;
  padding-bottom: 10px;
}

/* Checkbox padronizado pra cadastros (EULA + flags admin). Toque ≥ 24px,
   alvo confortável em mobile. */
.field--checkbox { margin-top: var(--sp-3); }
.checkbox {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  font-size: .92rem;
  line-height: 1.5;
  color: var(--c-text);
}
.checkbox input[type="checkbox"] {
  appearance: none;
  width: 22px; height: 22px;
  border: 1.8px solid var(--c-border);
  border-radius: 6px;
  background: var(--c-surface);
  cursor: pointer;
  flex-shrink: 0;
  margin-top: 1px;
  position: relative;
  transition: background 160ms ease, border-color 160ms ease;
}
.checkbox input[type="checkbox"]:hover {
  border-color: var(--c-primary);
}
.checkbox input[type="checkbox"]:checked {
  background: var(--c-primary);
  border-color: var(--c-primary);
}
.checkbox input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  top: 3px; left: 7px;
  width: 5px; height: 10px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.checkbox input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--c-primary);
  outline-offset: 2px;
}
.checkbox a { color: var(--c-primary); text-decoration: underline; }

/* form__notice variants — info (azul) já existia; adicionamos pra contrast */
.form__notice {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  margin: var(--sp-3) 0 0;
  padding: 12px 14px;
  border-radius: var(--r-md);
  background: color-mix(in srgb, var(--c-primary) 8%, var(--c-surface));
  border-left: 3px solid var(--c-primary);
  font-size: .88rem;
  line-height: 1.5;
}
.form__notice .icon {
  width: 18px; height: 18px;
  stroke: var(--c-primary); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
  margin-top: 2px;
}
.form__notice p { margin: 0; color: var(--c-text); }
.form__notice strong { color: var(--c-text); }

/* ---- Página EULA standalone ---- */
.eula-body { background: var(--c-bg); }
.eula-topbar {
  background: var(--c-primary);
  color: #fff;
  padding: 14px 0;
}
.eula-topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
}
.eula-topbar .brand { color: #fff; text-decoration: none; display: inline-flex; align-items: center; gap: 8px; }
.eula-topbar .btn--ghost { color: #fff; border-color: rgba(255,255,255,.3); }
.eula-topbar .btn--ghost:hover { background: rgba(255,255,255,.12); }
.eula-main { padding: var(--sp-6) 0 var(--sp-8); }
.eula-content {
  background: var(--c-surface);
  border: 1px solid var(--c-border);
  border-radius: var(--r-lg);
  padding: var(--sp-6);
  max-width: 760px;
  margin: 0 auto;
  line-height: 1.65;
  color: var(--c-text);
}
.eula-content h1 { margin: 0 0 var(--sp-2); font-size: 1.5rem; }
.eula-content h2 { margin: var(--sp-5) 0 var(--sp-2); font-size: 1.2rem; color: var(--c-primary); }
.eula-content h3 { margin: var(--sp-4) 0 var(--sp-2); font-size: 1.02rem; }
.eula-content p { margin: 0 0 var(--sp-3); }
.eula-content ul { margin: 0 0 var(--sp-3) var(--sp-4); padding: 0; }
.eula-content li { margin-bottom: 6px; }
.eula-content hr { border: 0; border-top: 1px solid var(--c-border); margin: var(--sp-5) 0; }
.eula-content code { font-family: var(--ff-mono); font-size: .9em; background: var(--c-bg); padding: 1px 6px; border-radius: 4px; }

/* ---- Editor da EULA (admin) ---- */
.eula-editor {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}
@media (max-width: 860px) {
  .eula-editor { grid-template-columns: 1fr; }
}
.eula-editor__pane { min-width: 0; display: flex; flex-direction: column; gap: var(--sp-2); }
.eula-toolbar {
  display: flex; flex-wrap: wrap; gap: 4px;
  margin-bottom: var(--sp-2);
}
.eula-tool {
  min-width: 36px; height: 32px;
  padding: 0 8px;
  border: 1px solid var(--c-border);
  background: var(--c-surface);
  color: var(--c-text);
  border-radius: var(--r-sm, 6px);
  cursor: pointer;
  font-size: .8rem;
}
.eula-tool:hover { background: var(--c-surface-2); border-color: var(--c-primary); }

/* Altura IDÊNTICA nas duas caixas (mesma var) + mesma caixa de modelo, pra
   ficarem visualmente alinhadas e a rolagem sincronizada fazer sentido. */
.eula-editor__textarea,
.eula-preview {
  box-sizing: border-box;
  height: var(--eula-box-h, 460px);
  overflow-y: auto;
}
.eula-editor__textarea {
  font-family: var(--ff-mono);
  font-size: .82rem; line-height: 1.55;
  resize: none;            /* fixo pra não divergir da preview */
}
.eula-preview {
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-4);
  background: var(--c-surface);
  font-size: .85rem; line-height: 1.55;
}

/* ---- Onboarding ---- */
.auth-card--wide { max-width: 720px; }

.ob-steps {
  list-style: none;
  display: flex;
  gap: var(--sp-2);
  padding: 0;
  margin: var(--sp-4) 0;
  border-bottom: 1px solid var(--c-border);
}
.ob-steps__item {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  font-size: .88rem;
  font-weight: 500;
  color: var(--c-text-muted);
  border-bottom: 2px solid transparent;
  position: relative;
  bottom: -1px; /* alinha com o border-bottom do container */
}
.ob-steps__item.is-active {
  color: var(--c-primary);
  border-bottom-color: var(--c-primary);
}
.ob-steps__item.is-done {
  color: var(--c-success);
}
.ob-steps__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px; height: 24px;
  background: var(--c-surface);
  border: 1.5px solid currentColor;
  border-radius: 50%;
  font-size: .76rem;
  font-weight: 700;
}
.ob-steps__item.is-done .ob-steps__num::after {
  content: '✓';
  font-weight: 700;
}
.ob-steps__item.is-done .ob-steps__num > * { display: none; }

.ob-pane { padding-top: var(--sp-2); }
.ob-pane__title { margin: 0 0 var(--sp-2); font-size: 1.15rem; }
.ob-pane__hint { color: var(--c-text-muted); font-size: .92rem; margin: 0 0 var(--sp-3); }

.ob-eula-scroll {
  max-height: 360px;
  overflow-y: auto;
  background: var(--c-bg);
  border: 1px solid var(--c-border);
  border-radius: var(--r-md);
  padding: var(--sp-3) var(--sp-4);
  font-size: .88rem;
  line-height: 1.6;
  margin-bottom: var(--sp-3);
  /* Sombra interna sutil indica "tem mais conteúdo" */
  box-shadow: inset 0 -10px 12px -10px rgba(0,0,0,.08);
}
.ob-eula-scroll h1 { font-size: 1.1rem; margin: 0 0 var(--sp-2); }
.ob-eula-scroll h2 { font-size: 1rem; margin: var(--sp-3) 0 var(--sp-1); color: var(--c-primary); }
.ob-eula-scroll h3 { font-size: .95rem; margin: var(--sp-2) 0 var(--sp-1); }
.ob-eula-scroll p { margin: 0 0 var(--sp-2); }
.ob-eula-scroll ul { margin: 0 0 var(--sp-2) var(--sp-4); padding: 0; }
.ob-eula-scroll li { margin-bottom: 4px; }
.ob-eula-scroll hr { border: 0; border-top: 1px solid var(--c-border); margin: var(--sp-3) 0; }

.ob-checkbox { margin: var(--sp-3) 0; }

/* Mobile: stepper colapsa, EULA scroll fica mais alto pra leitura confortável */
@media (max-width: 520px) {
  .auth-card--wide { padding: var(--sp-4); }
  .ob-steps__item { padding: 8px 10px; font-size: .82rem; }
  .ob-eula-scroll { max-height: 50vh; }
  .form__actions { flex-direction: column-reverse; }
  .form__actions .btn { width: 100%; }
}

/* ===========================================================================
   Seletor de estacionamento (Preferências do robô): polo + andares ordenáveis.
   Mobile-first; touch targets ≥44px. Estados loading/vazio/erro reusam o
   mesmo container .parking__state.
   ======================================================================== */
.parking__state {
  display: flex; flex-direction: column; align-items: center; text-align: center;
  gap: var(--sp-3); padding: var(--sp-4); color: var(--c-text-muted);
}
.parking__state-icon { width: 40px; height: 40px; stroke: currentColor; fill: none;
  stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.parking__state--empty .parking__state-icon { color: var(--c-primary); }
.parking__state--error { color: var(--c-danger); }
.parking__state-title { margin: 0; font-size: 1rem; color: var(--c-text); }
.parking__state-text { margin: 0; max-width: 36ch; font-size: .9rem; line-height: 1.4; }

/* Spinner genérico (reusa o keyframe `spin` já definido). */
.spinner {
  width: 26px; height: 26px; border-radius: 50%;
  border: 3px solid color-mix(in srgb, var(--c-primary) 25%, transparent);
  border-top-color: var(--c-primary);
  animation: spin 1s linear infinite;
}
@media (prefers-reduced-motion: reduce) { .spinner { animation: none; } }

.parking__solo-name { margin: 0; font-weight: 600; color: var(--c-text); }

/* Lista de andares ordenáveis */
.parking-floors { list-style: none; margin: var(--sp-2) 0 0; padding: 0;
  display: flex; flex-direction: column; gap: var(--sp-2); }
.parking-floors--invalid { outline: 1px dashed var(--c-danger);
  outline-offset: 4px; border-radius: var(--r-sm); }

/* Disclaimer de andares desativados (reduz chance de vaga) */
.parking-floors__disclaimer {
  display: flex; align-items: center; gap: var(--sp-2);
  margin: var(--sp-2) 0 0; padding: 8px 10px;
  font-size: .82rem; color: var(--c-text);
  background: var(--c-warning-soft, color-mix(in srgb, var(--c-warning, #b9770e) 14%, transparent));
  border: 1px solid color-mix(in srgb, var(--c-warning, #b9770e) 40%, transparent);
  border-radius: var(--r-sm);
}
.parking-floors__disclaimer .icon {
  width: 18px; height: 18px; flex-shrink: 0;
  stroke: var(--c-warning, #b9770e); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}

.parking-floor {
  display: flex; align-items: center; gap: var(--sp-3);
  padding: 8px 10px; border: 1px solid var(--c-border); border-radius: 14px;
  background: var(--c-surface);
  transition: border-color .2s ease, opacity .2s ease, background .2s ease, box-shadow .2s ease;
}
.parking-floor--off { opacity: .55; }
.parking-floor--on {
  border-color: color-mix(in srgb, var(--c-primary) 45%, var(--c-border));
  box-shadow: 0 1px 4px color-mix(in srgb, var(--c-primary) 10%, transparent);
}

/* Toggle ativar/desativar: switch estilo iOS (área clicável ≥44px). */
.parking-floor__toggle {
  flex-shrink: 0; width: 46px; height: 44px; padding: 0;
  display: grid; place-items: center; background: transparent; border: 0; cursor: pointer;
}
/* Telas estreitas (iPhone SE): aperta gaps/padding pro nome do andar respirar. */
@media (max-width: 420px) {
  .parking-floor { gap: var(--sp-2); padding: 6px 8px; }
}
.parking-floor__check {
  width: 42px; height: 26px; border-radius: 999px;
  background: var(--c-border);
  position: relative;
  transition: background .22s ease;
}
/* Bolinha (thumb) do switch — desliza pra direita quando ativo. */
.parking-floor__check::after {
  content: "";
  position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .28);
  transition: transform .25s cubic-bezier(.2, .8, .2, 1);
}
.parking-floor__toggle[aria-pressed="true"] .parking-floor__check {
  background: var(--c-primary);
}
.parking-floor__toggle[aria-pressed="true"] .parking-floor__check::after {
  transform: translateX(16px);
}
@media (prefers-reduced-motion: reduce) {
  .parking-floor__check, .parking-floor__check::after { transition: none; }
}
/* Nome do andar: pode quebrar em 2 linhas (nunca clipar no meio da palavra —
   o número no fim, ex. "Estacionamento 13", é a parte mais importante). */
.parking-floor__name { flex: 1; min-width: 0; font-size: .9rem; line-height: 1.25;
  color: var(--c-text); overflow-wrap: anywhere; }

/* Campo "tentativas por andar": quantas vezes o robô insiste neste andar antes
   de ir pro próximo. Estilo de stepper compacto, ao lado das setas. Só faz
   diferença prática com 2+ andares ativos. */
.parking-floor__attempts {
  flex-shrink: 0;
  display: inline-flex; align-items: center; gap: 2px;
  padding: 0 6px 0 8px; height: 36px;
  border: 1px solid var(--c-border); border-radius: var(--r-sm);
  background: var(--c-bg);
  color: var(--c-text-muted);
  cursor: text;
}
.parking-floor__attempts-unit { font-size: .8rem; font-weight: 600; opacity: .7; }
.parking-floor__attempts-input {
  width: 2.2ch; min-width: 2.2ch;
  border: 0; background: transparent; padding: 0;
  color: var(--c-text); font-size: .95rem; font-weight: 600;
  font-variant-numeric: tabular-nums; text-align: right;
  -moz-appearance: textfield; appearance: textfield;
}
.parking-floor__attempts-input::-webkit-outer-spin-button,
.parking-floor__attempts-input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.parking-floor__attempts-input:focus { outline: none; }
.parking-floor__attempts:focus-within { border-color: var(--c-primary); box-shadow: 0 0 0 3px var(--c-focus); }
/* Andar desativado: o campo de tentativas perde o sentido — apaga. */
.parking-floor__attempts-input:disabled { color: var(--c-text-muted); cursor: not-allowed; }

.parking-floor__order { display: flex; gap: 2px; flex-shrink: 0; }
.parking-floor__arrow {
  width: 44px; height: 44px; padding: 0; display: grid; place-items: center;
  background: transparent; border: 1px solid var(--c-border); border-radius: var(--r-sm);
  color: var(--c-text-muted); cursor: pointer; transition: background .15s, color .15s;
}
.parking-floor__arrow:hover:not(:disabled) { background: var(--c-bg); color: var(--c-text); }
.parking-floor__arrow:disabled { opacity: .3; cursor: not-allowed; }
.parking-floor__arrow svg { width: 18px; height: 18px; stroke: currentColor; fill: none;
  stroke-width: 2.2; stroke-linecap: round; stroke-linejoin: round; }

/* ============================================================================
   Linguagem visual global ("liquid glass" 2026) — herdada por TODAS as páginas
   ----------------------------------------------------------------------------
   Nasceu no redesign do "Meu perfil" e aqui vira padrão do app inteiro:
     1. ATMOSFERA  — um mesh de gradientes fixo e lento atrás de tudo, pra o
                     blur das superfícies ter o que refratar.
     2. ENTRADA    — cards/tiles sobem escalonados quando a aba/subaba abre.
     3. MATERIAIS  — topbar/tabs mais "vidro"; health tiles viram bento.
   Tudo respeita prefers-reduced-motion (bloco no fim).
   ============================================================================ */

/* 1. Atmosfera global — só no app (as páginas de auth têm o próprio mesh).
   `position: fixed` + `z-index: -1` deixa atrás do conteúdo sem capturar toque;
   é bem sutil (opacidades baixas) pra não comprometer leitura de texto. */
body:not(.auth-body)::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(28% 32% at 8% 6%,  color-mix(in srgb, var(--c-primary) 14%, transparent), transparent 70%),
    radial-gradient(26% 30% at 92% 2%, color-mix(in srgb, var(--c-info) 12%, transparent), transparent 70%),
    radial-gradient(34% 38% at 80% 98%, color-mix(in srgb, #8b5cf6 10%, transparent), transparent 74%);
  filter: blur(70px) saturate(125%);
  animation: app-atmosphere 26s ease-in-out infinite alternate;
}
@keyframes app-atmosphere {
  0%   { transform: translate3d(-2%, -1%, 0) scale(1); }
  100% { transform: translate3d(2%, 1.5%, 0) scale(1.05); }
}

/* 2. Entrada escalonada das cards ao abrir cada aba/subaba. Escopada pra NÃO
   tocar o "Meu perfil" (que tem o próprio sistema hero/bento/accordion) nem os
   profile-card dentro das seções (eles revelam via .is-open). Reusa o keyframe
   `profile-rise`. nth-child cobre até a 6ª card; além disso entram sem delay. */
#panel-schedule.is-active > .card,
#panel-users.is-active > .card,
.subpanel.is-active > .card {
  animation: profile-rise .5s cubic-bezier(.2, .8, .2, 1) backwards;
}
#panel-schedule.is-active > .card:nth-child(1),
#panel-users.is-active > .card:nth-child(1),
.subpanel.is-active > .card:nth-child(1) { animation-delay: .04s; }
#panel-schedule.is-active > .card:nth-child(2),
.subpanel.is-active > .card:nth-child(2) { animation-delay: .10s; }
#panel-schedule.is-active > .card:nth-child(3),
.subpanel.is-active > .card:nth-child(3) { animation-delay: .16s; }
#panel-schedule.is-active > .card:nth-child(4),
.subpanel.is-active > .card:nth-child(4) { animation-delay: .22s; }
#panel-schedule.is-active > .card:nth-child(n+5) { animation-delay: .28s; }

/* 3a. Topbar: blur mais profundo = leitura de "vidro" sobre a atmosfera. */
.topbar {
  background: color-mix(in srgb, var(--c-surface) 78%, transparent);
  backdrop-filter: saturate(170%) blur(18px);
  -webkit-backdrop-filter: saturate(170%) blur(18px);
}

/* 3b. Health tiles (admin → Saúde) ganham o material e o hover dos bento-tiles:
   cantos generosos, leve elevação no hover, transição suave. */
.health-tile {
  border-radius: 18px;
  background: color-mix(in srgb, var(--c-surface) 92%, transparent);
  transition: transform .2s cubic-bezier(.2, .8, .2, 1), box-shadow .2s ease, border-color .2s ease;
}
.health-tile:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: color-mix(in srgb, var(--c-primary) 30%, var(--c-border));
}

/* 3c. EULA (página standalone) — cartão de conteúdo com os cantos novos. */
.eula-content { border-radius: 24px; }

/* Acessibilidade: sem movimento pra quem pediu. */
@media (prefers-reduced-motion: reduce) {
  body:not(.auth-body)::before { animation: none; }
  #panel-schedule.is-active > .card,
  #panel-users.is-active > .card,
  .subpanel.is-active > .card { animation: none; }
  .health-tile { transition: none; }
}
