/* ============================================================
   ImobiP — Estilos por página (FASE 5.19 D-15)
   Consolidado de blocks <style> que estavam inline em templates.
   Cada seção é scoped por seletores específicos da página, então
   não há colisões. Dividir em arquivos separados é trade-off ruim
   (cache miss extra, complexidade no layout).
   ============================================================ */

/* ─── DASHBOARD (dashboard.html) ─── */
.kpi-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
      gap: 16px;
      margin-bottom: 24px;
    }
    .kpi-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: 16px 18px;
      box-shadow: var(--shadow-sm);
    }
    .kpi-label {
      font-size: 12px; font-weight: 600;
      color: var(--color-text-muted);
      text-transform: uppercase;
      letter-spacing: 0.05em;
      margin-bottom: 4px;
    }
    .kpi-value {
      font-family: var(--font-display);
      font-size: 28px; font-weight: 800;
      letter-spacing: -0.02em;
      color: var(--color-text);
    }
    .kpi-icon {
      width: 36px; height: 36px;
      border-radius: 10px;
      display: inline-flex; align-items: center; justify-content: center;
      font-size: 18px;
      margin-bottom: 10px;
    }
    .kpi-icon.is-brand { background: var(--color-brand-soft); color: var(--color-brand); }
    .kpi-icon.is-info  { background: var(--color-info-soft);  color: var(--color-info); }
    .kpi-icon.is-pink  { background: var(--color-instagram-soft, #fde8f0); color: var(--color-instagram); }
    .kpi-icon.is-success { background: var(--color-success-soft); color: var(--color-success); }

    .dash-row {
      display: grid;
      grid-template-columns: 2fr 1fr;
      gap: 16px;
      margin-bottom: 16px;
    }
    @media (max-width: 1024px) { .dash-row { grid-template-columns: 1fr; } }

    .top-post {
      display: grid;
      grid-template-columns: 36px 50px 1fr auto;
      gap: 12px; align-items: center;
      padding: 10px 0;
      border-bottom: 1px solid var(--color-border-soft);
    }
    .top-post:last-child { border-bottom: none; }
    .top-post-rank {
      width: 28px; height: 28px;
      border-radius: 50%;
      background: var(--color-brand-soft);
      color: var(--color-brand);
      display: inline-flex; align-items: center; justify-content: center;
      font-weight: 700; font-size: 13px;
    }
    /* Cores escurecidas pra atingir contraste AA (D-6 / FASE 5.19). */
    .top-post-rank.is-1 { background: linear-gradient(135deg, #b88600, #8a6300); color: #fff; }
    .top-post-rank.is-2 { background: linear-gradient(135deg, #707070, #555555); color: #fff; }
    .top-post-rank.is-3 { background: linear-gradient(135deg, #8a4f1c, #663713); color: #fff; }
    .top-post-thumb {
      width: 50px; height: 50px;
      border-radius: var(--radius-sm);
      background: #ddd;
      background-size: cover; background-position: center;
    }
    .top-post-meta { font-size: 13px; }
    .top-post-ref { font-weight: 700; }
    .top-post-stats { font-size: 12px; color: var(--color-text-muted); margin-top: 2px; }
    .top-post-score {
      font-family: var(--font-display);
      font-weight: 800;
      font-size: 16px;
      color: var(--color-brand);
    }

    .upcoming-row {
      display: grid;
      grid-template-columns: 40px 1fr auto;
      gap: 10px; align-items: center;
      padding: 8px 0;
      border-bottom: 1px solid var(--color-border-soft);
    }
    .upcoming-row:last-child { border-bottom: none; }
    .upcoming-thumb { width: 40px; height: 40px; border-radius: var(--radius-sm); background: #ddd; background-size: cover; background-position: center; }

    .plan-bar {
      height: 8px;
      background: var(--color-surface-2);
      border-radius: 4px;
      overflow: hidden;
      margin-top: 8px;
    }
    .plan-bar-fill {
      height: 100%;
      background: linear-gradient(90deg, var(--color-brand), var(--color-info));
      border-radius: 4px;
      transition: width .4s ease;
    }
    .plan-bar-fill.is-warning { background: var(--color-warning); }
    .plan-bar-fill.is-danger  { background: var(--color-danger); }

    #engagement-chart { max-height: 240px; }

/* ─── LISTINGS (listings.html) ─── */
/* ─── Grid responsivo de cards 4:5 ─── */
    .cards-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
      gap: 16px;
    }

    .listing-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      overflow: hidden;
      display: flex;
      flex-direction: column;
      transition: transform .12s, box-shadow .15s;
    }
    .listing-card:hover {
      transform: translateY(-2px);
      box-shadow: var(--shadow);
    }

    .listing-photo {
      aspect-ratio: 4/5;
      background: var(--color-surface-2);
      position: relative;
      overflow: hidden;
    }
    .listing-photo img {
      width: 100%; height: 100%;
      object-fit: cover;
      display: block;
    }
    .listing-photo .freshness {
      position: absolute;
      top: 10px; left: 10px;
      backdrop-filter: blur(6px);
      background: rgba(255,255,255,.85);
    }
    :root[data-theme="dark"] .listing-photo .freshness {
      background: rgba(20,30,42,.85);
      color: var(--color-text);
    }

    .listing-body {
      padding: 12px 14px;
      display: flex;
      flex-direction: column;
      gap: 4px;
    }
    .listing-meta {
      font-size: 12px;
      color: var(--color-text-soft);
      letter-spacing: 0.02em;
      text-transform: uppercase;
      font-weight: 600;
    }
    .listing-price {
      font-size: 18px;
      font-weight: 700;
      letter-spacing: -0.01em;
      color: var(--color-text);
    }
    .listing-title {
      font-size: 13px;
      color: var(--color-text-muted);
      overflow: hidden;
      text-overflow: ellipsis;
      white-space: nowrap;
    }

    .listing-actions {
      display: flex;
      gap: 4px;
      padding: 0 10px 10px;
    }
    .listing-actions .btn {
      flex: 1;
      padding: 6px 0;
      font-size: 12px;
    }

    /* Chip "stale" ativo */
    label.badge:has(input:checked) {
      background: var(--color-brand-soft);
      color: var(--color-brand);
      border-color: var(--color-brand);
    }

/* ─── LISTING DETAIL (listing_detail.html) ─── */
.ld-shell { max-width: 1200px; margin: 0 auto; padding: 24px; }
  .ld-back  { display:inline-flex; gap:6px; align-items:center; color:var(--color-text-muted);
              font-size: 13px; text-decoration: none; margin-bottom: 16px; }
  .ld-back:hover { color: var(--color-brand); }
  .ld-grid { display: grid; grid-template-columns: 7fr 5fr; gap: 32px; align-items:start; }
  @media (max-width: 900px) { .ld-grid { grid-template-columns: 1fr; } }

  .ld-photo  { aspect-ratio: 4/5; border-radius: 12px; overflow: hidden; background: var(--color-surface-2);
               box-shadow: 0 8px 24px rgba(15,30,60,.10); }
  .ld-photo img { width: 100%; height: 100%; object-fit: cover; display:block; }
  .ld-thumbs { display: grid; grid-template-columns: repeat(5, 1fr); gap: 8px; margin-top: 12px; }
  .ld-thumb  { aspect-ratio: 1; border-radius: 6px; overflow: hidden; cursor: pointer; opacity:.65; transition: opacity 120ms; }
  .ld-thumb.is-active, .ld-thumb:hover { opacity: 1; }
  .ld-thumb img { width:100%; height:100%; object-fit:cover; }

  .ld-info { background: var(--color-surface); border:1px solid var(--color-border);
             border-radius: 12px; padding: 24px; box-shadow: var(--shadow-sm); }
  .ld-headline { font-family: var(--font-display); font-size: 28px; font-weight: 700;
                 letter-spacing: -.01em; margin-bottom: 4px; }
  .ld-loc      { color: var(--color-text-muted); font-size: 15px; margin-bottom: 16px; }
  .ld-price    { font-family: var(--font-display); font-size: 36px; font-weight: 800;
                 color: var(--color-brand); letter-spacing: -.02em; margin-bottom: 16px; }
  .ld-tags     { display:flex; flex-wrap:wrap; gap:8px; margin-bottom: 24px; }
  .ld-tag      { background: var(--color-surface-2); padding: 6px 12px; border-radius: 999px;
                 font-size: 13px; color: var(--color-text-muted); display:inline-flex; gap:6px; align-items:center; }

  .ld-cta-row { display:flex; gap:8px; margin-top: 24px; }
  .ld-section { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--color-border-soft); }
  .ld-section h3 { font-size: 14px; font-weight: 700; text-transform: uppercase; letter-spacing: .8px;
                   color: var(--color-text-muted); margin-bottom: 12px; }
  .ld-desc { font-size: 14px; color: var(--color-text); line-height: 1.55; white-space: pre-wrap; }
  .ld-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 16px; font-size: 13px; }
  .ld-meta dt { color: var(--color-text-muted); }
  .ld-meta dd { font-weight: 600; }

  .ld-posts li { display:flex; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--color-border-soft);
                 align-items: center; font-size: 13px; }
  .ld-posts li:last-child { border-bottom: 0; }
  .ld-status-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
  .ld-status-dot.s-published { background: var(--color-success); }
  .ld-status-dot.s-scheduled { background: var(--color-warning); }
  .ld-status-dot.s-failed    { background: var(--color-danger); }
  .ld-status-dot.s-draft     { background: var(--color-text-muted); }

/* ─── LISTING MANUAL FORM (listing_manual_form.html) ─── */
.form-grid {
      display: grid;
      grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
      gap: 12px 16px;
    }
    .form-grid-2 { grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); }

    .photo-grid {
      display: grid;
      grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
      gap: 8px;
      margin-top: 12px;
    }
    .photo-thumb-card {
      position: relative;
      aspect-ratio: 4/5;
      border-radius: var(--radius);
      overflow: hidden;
      background: var(--color-surface-2);
    }
    .photo-thumb-card img { width: 100%; height: 100%; object-fit: cover; display: block; }
    .photo-thumb-card .thumb-num {
      position: absolute; top: 4px; left: 4px;
      background: rgba(0,0,0,.7); color: #fff;
      padding: 2px 6px; border-radius: 6px; font-size: 11px; font-weight: 600;
    }
    .photo-thumb-card .thumb-remove {
      position: absolute; top: 4px; right: 4px;
      background: rgba(0,0,0,.7); color: #fff;
      border: none; border-radius: 50%;
      width: 26px; height: 26px;
      cursor: pointer;
      display: flex; align-items: center; justify-content: center;
    }
    .photo-thumb-card .thumb-remove:hover { background: var(--color-danger); }

    .upload-drop {
      border: 2px dashed var(--color-border);
      border-radius: var(--radius);
      padding: 24px;
      text-align: center;
      background: var(--color-surface-2);
      cursor: pointer;
      transition: border-color .15s;
    }
    .upload-drop:hover { border-color: var(--color-brand); }
    .upload-drop.is-dragover { border-color: var(--color-brand); background: var(--color-brand-soft); }

    .pending-thumb {
      position: relative; aspect-ratio: 4/5;
      border-radius: var(--radius); overflow: hidden;
      background: var(--color-surface-2);
      border: 2px solid var(--color-info);
    }
    .pending-thumb img { width: 100%; height: 100%; object-fit: cover; }
    .pending-thumb .pending-tag {
      position: absolute; bottom: 0; left: 0; right: 0;
      background: var(--color-info); color: #fff;
      font-size: 10px; padding: 2px 4px; text-align: center;
      font-weight: 600;
    }

/* ─── CALENDAR (calendar.html) ─── */
/* ─── Toolbar ──────────────────────────────────────── */
    .cal-toolbar {
      display: flex; align-items: center; justify-content: space-between;
      flex-wrap: wrap; gap: 12px;
      margin-bottom: 16px;
    }
    .cal-month-nav {
      display: flex; align-items: center; gap: 8px;
    }
    .cal-month-title {
      font-family: var(--font-display);
      font-size: 22px; font-weight: 800;
      letter-spacing: -0.01em;
      min-width: 200px;
    }

    /* Toggle Mês / Lista */
    .cal-view-toggle {
      display: flex;
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      padding: 2px;
      background: var(--color-surface);
    }
    .cal-view-toggle button {
      padding: 6px 14px; border: none; background: transparent;
      font-size: 13px; font-weight: 600;
      color: var(--color-text-muted);
      cursor: pointer; border-radius: 6px;
      display: inline-flex; align-items: center; gap: 6px;
    }
    .cal-view-toggle button.is-active {
      background: var(--color-brand);
      color: #fff;
    }

    /* Filtros chips */
    .cal-chips { display: flex; gap: 6px; flex-wrap: wrap; }
    .cal-chip {
      padding: 5px 12px;
      border: 1px solid var(--color-border);
      border-radius: var(--radius-pill);
      font-size: 12px; font-weight: 600;
      cursor: pointer; user-select: none;
      background: var(--color-surface);
      color: var(--color-text-muted);
      display: inline-flex; align-items: center; gap: 4px;
    }
    .cal-chip:hover { border-color: var(--color-brand); }
    .cal-chip input { display: none; }
    .cal-chip:has(input:checked) {
      background: var(--color-brand-soft);
      color: var(--color-brand);
      border-color: var(--color-brand);
    }
    .cal-chip[data-color="success"]:has(input:checked) { background: var(--color-success-soft); color: var(--color-success); border-color: var(--color-success); }
    .cal-chip[data-color="warning"]:has(input:checked) { background: var(--color-warning-soft); color: var(--color-warning); border-color: var(--color-warning); }
    .cal-chip[data-color="danger"]:has(input:checked)  { background: var(--color-danger-soft);  color: var(--color-danger);  border-color: var(--color-danger); }
    .cal-chip[data-color="info"]:has(input:checked)    { background: var(--color-info-soft);    color: var(--color-info);    border-color: var(--color-info); }

    /* ─── Modal overlay ──────────────────────────────── */
    .modal-backdrop {
      position: fixed; inset: 0;
      background: rgba(0,0,0,.5);
      display: flex; align-items: center; justify-content: center;
      z-index: 1000;
    }
    .modal-panel {
      background: var(--color-surface);
      border-radius: var(--radius-lg);
      max-width: 560px; width: calc(100vw - 40px);
      max-height: 85vh; overflow-y: auto;
      box-shadow: var(--shadow-lg);
    }

/* ─── CALENDAR MONTH (_calendar_month.html) ─── */
.month-grid {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    overflow: hidden;
    background: var(--color-surface);
  }
  .month-weekday {
    padding: 10px 12px;
    background: var(--color-surface-2);
    border-bottom: 1px solid var(--color-border);
    font-size: 11px; font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--color-text-muted);
  }
  .month-cell {
    border-right: 1px solid var(--color-border-soft);
    border-bottom: 1px solid var(--color-border-soft);
    padding: 8px; min-height: 110px;
    background: var(--color-surface);
  }
  .month-cell:nth-child(7n) { border-right: none; }
  .month-cell.is-out {
    background: var(--color-surface-2);
    opacity: .55;
  }
  .month-cell.is-today .month-day-num {
    background: var(--color-brand);
    color: #fff;
    border-radius: 50%;
    width: 24px; height: 24px;
    display: inline-flex; align-items: center; justify-content: center;
    font-weight: 700;
  }
  .month-day-num {
    font-size: 12px; font-weight: 600;
    color: var(--color-text-muted);
    margin-bottom: 4px;
    display: inline-block;
  }
  .month-posts { display: flex; flex-direction: column; gap: 3px; }
  .month-post {
    display: flex; align-items: center; gap: 6px;
    padding: 3px 6px;
    border-radius: 4px;
    font-size: 11px;
    cursor: pointer;
    background: var(--color-surface-2);
    border-left: 3px solid var(--color-info);
    color: var(--color-text);
    overflow: hidden;
  }
  .month-post:hover { background: var(--color-brand-soft); }
  .month-post.is-success { border-left-color: var(--color-success); }
  .month-post.is-warning { border-left-color: var(--color-warning); }
  .month-post.is-danger  { border-left-color: var(--color-danger); }
  .month-post-thumb {
    width: 16px; height: 16px; border-radius: 2px; flex-shrink: 0;
    background: #ddd; background-size: cover; background-position: center;
  }
  .month-post-time {
    font-size: 10px; opacity: .7; margin-left: auto;
  }
  .month-post-more {
    text-align: center; font-size: 11px;
    color: var(--color-text-muted);
    padding: 2px;
  }

/* ─── CALENDAR LIST (_calendar_list.html) ─── */
.list-row {
    display: grid;
    grid-template-columns: 64px 1fr auto auto;
    gap: 16px; align-items: center;
    padding: 12px 16px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    margin-bottom: 8px;
    cursor: pointer;
    transition: border-color .12s, transform .12s;
  }
  .list-row:hover { border-color: var(--color-brand); transform: translateX(2px); }
  .list-thumb { width: 64px; height: 64px; border-radius: var(--radius-sm); background: #ddd; background-size: cover; background-position: center; flex-shrink: 0; }
  .list-meta-ref { font-weight: 700; font-size: 14px; }
  .list-meta-caption { font-size: 12px; color: var(--color-text-muted); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; max-width: 380px; }
  .list-when { font-size: 13px; color: var(--color-text-muted); text-align: right; min-width: 110px; }
  .list-when-time { font-weight: 700; color: var(--color-text); font-size: 14px; }

/* ─── SETTINGS (settings.html) ─── */
.settings-grid {
      display: grid;
      grid-template-columns: 240px 1fr;
      gap: 24px;
      align-items: start;
    }
    @media (max-width: 900px) {
      .settings-grid { grid-template-columns: 1fr; }
    }

    /* Tabs verticais */
    .v-tabs {
      display: flex;
      flex-direction: column;
      gap: 2px;
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius);
      padding: 8px;
      position: sticky; top: 80px;
    }
    .v-tab {
      display: flex; align-items: center; gap: 10px;
      padding: 10px 12px;
      border-radius: var(--radius);
      color: var(--color-text-muted);
      font-weight: 500;
      cursor: pointer;
      transition: background .12s;
      font-size: 14px;
    }
    .v-tab:hover { background: var(--color-surface-2); color: var(--color-text); }
    .v-tab.is-active {
      background: var(--color-brand-soft);
      color: var(--color-brand);
      font-weight: 600;
    }
    .v-tab i { font-size: 16px; width: 18px; }
    .v-tab .v-tab-badge {
      margin-left: auto;
      width: 8px; height: 8px; border-radius: 50%;
    }
    .v-tab-badge.is-warn { background: var(--color-warning); }
    .v-tab-badge.is-bad  { background: var(--color-danger); }

    /* Painéis */
    .panel { display: none; }
    .panel.is-active { display: block; }
    .panel-section {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: 24px;
      margin-bottom: 16px;
    }

    .conn-card {
      display: flex; gap: 16px; align-items: flex-start;
      padding: 16px;
      border-radius: var(--radius);
      border: 1px solid var(--color-border);
      background: var(--color-surface-2);
    }
    .conn-card.is-ok      { border-color: var(--color-success); background: var(--color-success-soft); }
    .conn-card.is-warn    { border-color: var(--color-warning); background: var(--color-warning-soft); }
    .conn-card.is-missing { border-color: var(--color-danger);  background: var(--color-danger-soft); }
    .conn-icon {
      width: 44px; height: 44px;
      border-radius: 10px;
      background: var(--color-surface);
      display: flex; align-items: center; justify-content: center;
      font-size: 22px;
      flex-shrink: 0;
    }
    .conn-meta { flex: 1; }
    .conn-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }

    .color-input-wrap { display: flex; gap: 8px; align-items: center; }
    .color-input-wrap input[type="color"] {
      width: 40px; height: 40px; border: 1px solid var(--color-border);
      border-radius: var(--radius-sm); padding: 0; cursor: pointer; background: none;
    }

/* ─── ONBOARDING (onboarding.html) ─── */
/* Esconde sidebar e topbar no onboarding (foco total) */
    .app-shell { grid-template-columns: 1fr !important; grid-template-rows: 1fr !important;
                 grid-template-areas: "main" !important; }
    .app-sidebar, .app-topbar { display: none !important; }
    .app-main { padding: 0 !important; overflow: auto; background: var(--color-bg); }

    .onb-shell {
      max-width: 720px;
      margin: 0 auto;
      padding: 48px 24px;
      min-height: 100vh;
      display: flex;
      flex-direction: column;
    }

    /* Header com logo Imobip */
    .onb-header {
      text-align: center;
      margin-bottom: 32px;
    }
    .onb-header img {
      height: 180px;
      width: auto;
      margin: 0 auto 8px;
      display: block;
    }
    @media (max-width: 768px) {
      .onb-header img { height: 140px; }
    }
    .onb-skip {
      position: absolute;
      top: 24px; right: 24px;
      font-size: 13px;
      color: var(--color-text-soft);
      cursor: pointer;
    }

    /* Stepper */
    .onb-stepper {
      display: flex;
      justify-content: space-between;
      gap: 4px;
      margin-bottom: 32px;
      position: relative;
    }
    .onb-step {
      flex: 1;
      display: flex; flex-direction: column; align-items: center; gap: 8px;
      position: relative;
    }
    .onb-step-num {
      width: 36px; height: 36px; border-radius: 50%;
      display: inline-flex; align-items: center; justify-content: center;
      background: var(--color-surface);
      border: 2px solid var(--color-border);
      color: var(--color-text-muted);
      font-weight: 700;
      font-size: 14px;
      transition: all .2s;
      z-index: 2;
    }
    .onb-step.is-active .onb-step-num {
      background: var(--color-brand);
      border-color: var(--color-brand);
      color: #fff;
    }
    .onb-step.is-done .onb-step-num {
      background: var(--color-success);
      border-color: var(--color-success);
      color: #fff;
    }
    .onb-step-label {
      font-size: 11px;
      font-weight: 600;
      text-transform: uppercase;
      letter-spacing: 0.04em;
      color: var(--color-text-muted);
    }
    .onb-step.is-active .onb-step-label,
    .onb-step.is-done .onb-step-label   { color: var(--color-text); }

    /* Linha conectando os steps */
    .onb-stepper::before {
      content: '';
      position: absolute;
      top: 17px; left: 18px; right: 18px;
      height: 2px;
      background: var(--color-border);
      z-index: 1;
    }

    /* Card do passo */
    .onb-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: 32px;
      box-shadow: var(--shadow);
    }
    .onb-card h2 {
      font-size: 24px;
      letter-spacing: -0.02em;
      margin-bottom: 8px;
    }
    .onb-title { font-size: 28px; letter-spacing: -0.02em; }
    .onb-card .subtitle {
      color: var(--color-text-muted);
      margin-bottom: 24px;
    }
    .onb-actions {
      display: flex;
      justify-content: space-between;
      margin-top: 24px;
      padding-top: 24px;
      border-top: 1px solid var(--color-border-soft);
    }

    .onb-feature {
      display: flex; gap: 12px; align-items: flex-start;
      padding: 12px 0;
    }
    .onb-feature-icon {
      width: 36px; height: 36px; border-radius: 8px;
      background: var(--color-brand-soft);
      color: var(--color-brand);
      display: flex; align-items: center; justify-content: center;
      flex-shrink: 0;
      font-size: 16px;
    }
    .onb-feature h4 { font-size: 14px; margin-bottom: 2px; }
    .onb-feature p  { font-size: 13px; color: var(--color-text-muted); }

.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}

/* ─── PRECOS (PRICING) (precos.html) ─── */
.precos-shell { max-width: 1180px; margin: 0 auto; padding: 56px 24px; }
  .precos-header { text-align: center; margin-bottom: 48px; }
  .precos-header h1 {
    font-family: 'Montserrat', sans-serif;
    font-size: clamp(34px, 4.5vw, 48px); font-weight: 800;
    letter-spacing: -.02em; margin-bottom: 12px;
  }
  .precos-header .lead { color: var(--color-text-muted); font-size: 17px; max-width: 60ch; margin: 0 auto; }
  /* Layout: 5 cards em 1 linha em telas largas, 3+2 em médias, 1 em mobile.
     `repeat(auto-fit, minmax(...))` daria 5 cards apertados em 1100px. */
  .plans-grid {
    display: grid;
    gap: 16px;
    margin-bottom: 48px;
    grid-template-columns: repeat(5, minmax(0, 1fr));
  }
  @media (max-width: 1180px) {
    .plans-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  }
  @media (max-width: 800px) {
    .plans-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  }
  @media (max-width: 520px) {
    .plans-grid { grid-template-columns: 1fr; }
  }
  .plan-card {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    padding: 28px 22px;
    display: flex; flex-direction: column;
    transition: transform .15s, box-shadow .15s, border-color .15s;
  }
  .plan-card:hover { transform: translateY(-3px); box-shadow: 0 16px 30px rgba(15,30,60,.08); }
  /* Featured "Pro" — diferenciação tipográfica reforçada (D-11) */
  .plan-card.is-featured {
    border-color: var(--color-brand); border-width: 2px;
    position: relative;
    box-shadow: 0 16px 32px rgba(11, 72, 129, 0.18);
  }
  .plan-card.is-featured .plan-price { font-size: 34px; }
  .plan-featured-badge {
    position: absolute; top: -14px; left: 50%; transform: translateX(-50%);
    background: var(--color-brand); color: #fff; padding: 5px 14px; border-radius: 999px;
    font-size: 13px; font-weight: 800; letter-spacing: .04em; text-transform: uppercase;
  }
  .plan-name { font-family: 'Montserrat', sans-serif; font-size: 18px; font-weight: 700; }
  .plan-desc { color: var(--color-text-muted); font-size: 13px; min-height: 36px; margin: 6px 0 14px; }
  .plan-price { font-family: 'Montserrat', sans-serif; font-size: 32px; font-weight: 800; letter-spacing: -.02em; }
  .plan-price small { font-size: 13px; font-weight: 500; color: var(--color-text-muted); }
  .plan-price-custom { font-size: 18px; font-weight: 700; color: var(--color-text-muted); }
  .plan-features { list-style: none; padding: 0; margin: 18px 0; flex: 1; font-size: 13px; }
  .plan-features li { padding: 5px 0; display:flex; gap: 8px; align-items: flex-start; }
  .plan-features li i { color: var(--color-success); flex-shrink: 0; margin-top: 2px; }
  .plan-cta { width: 100%; height: 40px; font-size: 13px; font-weight: 700; }

  .precos-comparativo { color: var(--color-text-muted); text-align: center; font-size: 14px; margin-bottom: 48px; }
  .precos-comparativo a { color: var(--color-brand); font-weight: 600; }

  .precos-faq { max-width: 720px; margin: 0 auto; }
  .precos-faq h2 { font-family: 'Montserrat', sans-serif; font-size: 26px; margin-bottom: 24px; text-align: center; font-weight: 800; letter-spacing: -.01em; }
  .precos-faq details {
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 14px 18px;
    margin-bottom: 10px;
    background: var(--color-surface);
  }
  .precos-faq summary {
    font-weight: 600; cursor: pointer; list-style: none;
    display:flex; justify-content:space-between; align-items:center;
  }
  .precos-faq summary::after { content:'+'; color: var(--color-brand); font-size: 22px; font-weight: 300; transition: transform .2s; }
  .precos-faq details[open] summary::after { transform: rotate(45deg); }
  .precos-faq p { color: var(--color-text-muted); font-size: 14px; margin-top: 10px; line-height: 1.55; }

  .contact-banner {
    background: var(--color-info-soft); color: var(--color-info);
    padding: 14px 18px; border-radius: 10px;
    margin-bottom: 24px; text-align: center; font-size: 14px;
  }

/* ─── SIGNUP (signup.html) ─── */
.signup-shell {
      max-width: 980px;
      margin: 0 auto;
      padding: 48px 24px;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 48px;
      align-items: start;
    }
    @media (max-width: 768px) {
      .signup-shell { grid-template-columns: 1fr; padding: 32px 16px; }
    }

    .signup-form-card {
      background: var(--color-surface);
      border: 1px solid var(--color-border);
      border-radius: var(--radius-lg);
      padding: 32px;
      box-shadow: var(--shadow);
    }
    .signup-cta-btn { height: 48px; font-size: 15px; }

    .signup-side {
      padding: 16px;
    }
    .signup-side h2 { font-size: 22px; letter-spacing: -0.01em; margin-bottom: 12px; }
    .signup-feature { display: flex; gap: 10px; padding: 8px 0; align-items: flex-start; }
    .signup-feature i { color: var(--color-success); font-size: 18px; margin-top: 2px; }
    .signup-feature p  { font-size: 13px; color: var(--color-text-muted); }

    .plan-tabs {
      display: flex; gap: 4px;
      background: var(--color-surface-2);
      border-radius: var(--radius);
      padding: 4px;
      margin-bottom: 24px;
    }
    .plan-tab {
      flex: 1; padding: 8px 12px;
      text-align: center;
      border-radius: var(--radius-sm);
      cursor: pointer;
      font-weight: 600;
      font-size: 13px;
      color: var(--color-text-muted);
    }
    .plan-tab.is-active {
      background: var(--color-surface);
      color: var(--color-brand);
      box-shadow: var(--shadow-sm);
    }
    .plan-price { font-family: var(--font-display); font-size: 40px; font-weight: 800; letter-spacing: -0.02em; }
    .plan-price small { font-size: 14px; font-weight: 500; color: var(--color-text-muted); }

    .signup-error {
      background: var(--color-danger-soft);
      color: var(--color-danger);
      padding: 10px 14px;
      border-radius: var(--radius);
      font-size: 13px;
      margin-bottom: 16px;
    }

/* ─── SIGNUP SUCCESS (signup_success.html) ─── */
.center-card {
      max-width: 520px; margin: 0 auto; padding: 64px 24px;
      text-align: center;
    }
    .center-card img { height: 180px; margin: 0 auto 16px; display: block; }
    .center-card .check {
      width: 80px; height: 80px; margin: 0 auto 16px;
      border-radius: 50%;
      background: var(--color-success-soft);
      color: var(--color-success);
      display: flex; align-items: center; justify-content: center;
      font-size: 40px;
    }
    .check.is-pending {
      background: var(--color-warning-soft);
      color: var(--color-warning);
    }

/* ─── TEAM ACCEPT (team_accept.html) ─── */
.ta-shell { min-height:70vh; display:flex; align-items:center; justify-content:center; padding:48px 24px }
  .ta-card  { max-width:520px; width:100%; text-align:center; padding:40px;
              background:var(--color-surface); border:1px solid var(--color-border);
              border-radius:12px; box-shadow:var(--shadow); }
  .ta-icon  { font-size:64px; margin-bottom:18px; }
  .ta-icon.ok    { color:var(--color-success); }
  .ta-icon.error { color:var(--color-danger); }
  .ta-icon.info  { color:var(--color-brand); }
  .ta-title { font-size:24px; font-weight:700; margin-bottom:10px; letter-spacing:-.01em; }
  .ta-msg   { font-size:15px; color:var(--color-text-muted); line-height:1.5; margin-bottom:28px; }

/* ─── STUDIO FEED (pages/studio_feed.html) ─── */
.spin { animation: spin 1s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }

/* ─── STUDIO BOTH (pages/studio_both.html) ─── */
.spin { animation: spin 1s linear infinite; }
  @keyframes spin { to { transform: rotate(360deg); } }

/* ─── STUDIO FEED INNER (pages/_studio_feed_inner.html) ─── */
/* IG mockup styles — replicado de studio_feed.html */
  .ig-mockup { max-width: 420px; margin: 0 auto; background: #fff; color: #000; border: 1px solid #dbdbdb; border-radius: 8px; box-shadow: 0 4px 24px rgba(0,0,0,.10); overflow: hidden; font-family: -apple-system, "Segoe UI", Roboto, sans-serif; }
  .ig-header { display: flex; align-items: center; gap: 10px; padding: 10px 12px; border-bottom: 1px solid #efefef; }
  .ig-avatar-ring { width: 32px; height: 32px; border-radius: 50%; background: linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888); padding: 2px; }
  .ig-avatar-inner { width: 100%; height: 100%; border-radius: 50%; background: #fff; border: 2px solid #fff; display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--color-brand); font-size: 11px; }
  .ig-username { font-weight: 700; font-size: 13px; flex: 1; }
  .ig-media { position: relative; aspect-ratio: 4/5; background: #efefef; overflow: hidden; }
  .ig-media img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .ig-counter { position: absolute; top: 10px; right: 10px; background: rgba(0,0,0,.6); color: #fff; font-size: 12px; padding: 2px 8px; border-radius: 10px; }
  .ig-actions { display: flex; gap: 12px; padding: 8px 12px; font-size: 22px; color: #262626; }
  .ig-caption-area { padding: 0 12px 12px; font-size: 13px; line-height: 1.4; max-height: 280px; overflow-y: auto; white-space: pre-wrap; }
  .ig-caption-user { font-weight: 700; color: #000; }
  .ig-caption-text { color: #262626; }
  .ig-caption-hashtags { color: #00376b; font-weight: 500; margin-top: 6px; }
  .photo-strip { display: flex; gap: 6px; padding: 8px; overflow-x: auto; background: var(--color-surface-2); border-radius: var(--radius); }
  .photo-thumb { position: relative; width: 64px; height: 80px; border-radius: 6px; overflow: hidden; flex-shrink: 0; border: 2px solid transparent; cursor: grab; background: #ddd; }
  .photo-thumb img { width: 100%; height: 100%; object-fit: cover; }
  .photo-thumb-remove { position: absolute; top: 2px; right: 2px; background: rgba(0,0,0,.6); color: #fff; border: none; border-radius: 50%; width: 18px; height: 18px; font-size: 11px; cursor: pointer; display: flex; align-items: center; justify-content: center; }
  .variant-tabs { display: flex; gap: 0; border-bottom: 1px solid var(--color-border); margin-bottom: 12px; }
  .variant-tab { padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--color-text-muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; }
  .variant-tab.is-active { color: var(--color-brand); border-color: var(--color-brand); }
  .hashtag-chip { display: inline-block; padding: 4px 10px; margin: 0 4px 4px 0; background: var(--color-info-soft); color: var(--color-info); border-radius: var(--radius-pill); font-size: 12px; font-weight: 600; cursor: pointer; }
  .schedule-options { display: flex; flex-direction: column; gap: 8px; }
  .schedule-option { display: flex; align-items: center; gap: 8px; padding: 10px 12px; border: 1px solid var(--color-border); border-radius: var(--radius); cursor: pointer; }
  .schedule-option.is-selected { border-color: var(--color-brand); background: var(--color-brand-soft); }
  .studio-grid { display: grid; grid-template-columns: 60% 40%; gap: 24px; align-items: start; }
  @media (max-width: 1024px) { .studio-grid { grid-template-columns: 1fr; } }

/* ─── STUDIO STORY INNER (pages/_studio_story_inner.html) ─── */
.story-mockup { width: 320px; margin: 0 auto; aspect-ratio: 9/16; background: #000; border-radius: 28px; overflow: hidden; position: relative; box-shadow: 0 8px 32px rgba(0,0,0,.25); border: 8px solid #0d0d0d; }
  .story-bg { position: absolute; inset: 0; background-size: cover; background-position: center; }
  .story-bg.has-photo::after { content: ''; position: absolute; inset: 0; background: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0.05) 30%, rgba(0,0,0,0.05) 60%, rgba(0,0,0,0.7) 100%); }
  .story-progress { position: absolute; top: 8px; left: 8px; right: 8px; height: 2px; background: rgba(255,255,255,.3); border-radius: 2px; z-index: 4; }
  .story-progress::after { content: ''; display: block; width: 30%; height: 100%; background: #fff; border-radius: 2px; }
  .story-header { position: absolute; top: 18px; left: 12px; right: 12px; display: flex; align-items: center; gap: 8px; color: #fff; z-index: 4; font-size: 12px; }
  .story-avatar { width: 28px; height: 28px; border-radius: 50%; background: var(--color-brand); display: flex; align-items: center; justify-content: center; font-weight: 700; font-size: 11px; color: #fff; }
  .story-content { position: absolute; inset: 0; display: flex; flex-direction: column; justify-content: space-between; padding: 70px 20px 80px; color: #fff; z-index: 3; }
  .story-headline { font-family: var(--font-display); font-size: 24px; font-weight: 800; line-height: 1.15; text-shadow: 0 2px 8px rgba(0,0,0,.5); }
  .story-info { background: rgba(0,0,0,.5); backdrop-filter: blur(8px); border-radius: 12px; padding: 12px 14px; font-size: 13px; line-height: 1.4; }
  .story-ref { font-size: 11px; opacity: .8; text-transform: uppercase; letter-spacing: 0.06em; }
  .story-title { font-weight: 600; margin: 2px 0; }
  .story-price { font-weight: 800; font-size: 18px; }
  .story-subtitle { margin-top: 8px; font-size: 12px; display: flex; align-items: center; gap: 6px; }
  .story-cta-pill { position: absolute; bottom: 22px; left: 50%; transform: translateX(-50%); background: rgba(255,255,255,.95); color: #000; padding: 10px 18px; border-radius: 99px; font-size: 12px; font-weight: 700; display: flex; align-items: center; gap: 6px; z-index: 4; box-shadow: 0 4px 12px rgba(0,0,0,.3); }
  .story-photos { display: flex; gap: 8px; padding: 8px; overflow-x: auto; background: var(--color-surface-2); border-radius: var(--radius); }
  .story-photo { width: 54px; height: 96px; border-radius: 6px; flex-shrink: 0; overflow: hidden; cursor: pointer; border: 2px solid transparent; }
  .story-photo.is-selected { border-color: var(--color-brand); }
  .story-photo img { width: 100%; height: 100%; object-fit: cover; }
  .story-variant { border: 2px solid var(--color-border); border-radius: var(--radius); padding: 12px; cursor: pointer; transition: border-color .15s, background .15s; display: flex; flex-direction: column; gap: 4px; }
  .story-variant:hover { background: var(--color-surface-2); }
  .story-variant.is-selected { border-color: var(--color-brand); background: var(--color-brand-soft); }
  .trigger-badge { align-self: flex-start; padding: 2px 8px; border-radius: var(--radius-pill); font-size: 10px; text-transform: uppercase; font-weight: 700; letter-spacing: 0.05em; background: var(--color-info-soft); color: var(--color-info); }
  .variant-headline { font-weight: 700; font-size: 14px; }
  .variant-subtitle { font-size: 12px; color: var(--color-text-muted); }

/* ─── STORY EDITOR (pages/_story_editor.html) ─── */
.se-el { position:absolute; cursor:grab; padding:6px; box-sizing:border-box;
           color:#fff; font-family:'Montserrat',sans-serif; line-height:1.1;
           text-shadow:0 2px 8px rgba(0,0,0,.45); display:flex; align-items:center;
           border:1px dashed transparent; }
  .se-el.is-selected { border-color: var(--color-brand); background: rgba(11,72,129,.12); cursor:grabbing }
  .se-handle { position:absolute; right:-6px; bottom:-6px; width:14px; height:14px;
               background: var(--color-brand); border:2px solid #fff; border-radius:50%;
               cursor:nwse-resize; }

/* ─── SIGNUP CANCELED (pages/signup_canceled.html) ─── */
.center-card {
      max-width: 520px; margin: 0 auto; padding: 64px 24px;
      text-align: center;
    }
    .center-card img { height: 180px; margin: 0 auto 16px; display: block; }

/* ─── SUPER ADMIN LAYOUT (pages/super_admin/_layout.html) ─── */
.sa-shell { max-width: 1280px; margin: 0 auto; padding: 24px; }
  .sa-banner {
    background: var(--color-warning-soft, #fff4d6);
    color: #6b4500;
    border: 1px solid var(--color-warning);
    border-radius: 10px;
    padding: 12px 18px;
    font-size: 13px;
    display:flex; gap: 10px; align-items: center;
    margin-bottom: 20px;
  }
  .sa-nav {
    display:flex; gap: 4px;
    background: var(--color-surface-2);
    border-radius: 8px;
    padding: 4px;
    margin-bottom: 24px;
    width: fit-content;
  }
  .sa-nav a {
    padding: 8px 16px;
    border-radius: 6px;
    text-decoration: none;
    color: var(--color-text-muted);
    font-size: 14px;
    font-weight: 500;
  }
  .sa-nav a.is-active { background: var(--color-surface); color: var(--color-brand); box-shadow: var(--shadow-sm); }

  .sa-counts { display:flex; gap: 12px; flex-wrap: wrap; margin-bottom: 20px; }
  .sa-count {
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: 10px;
    padding: 12px 18px;
    font-size: 13px;
    color: var(--color-text-muted);
    min-width: 110px;
  }
  .sa-count strong { display:block; font-size: 22px; color: var(--color-text); font-weight: 700; }

  .sa-table { width: 100%; border-collapse: collapse; font-size: 14px; background: var(--color-surface); border-radius: 10px; overflow: hidden; }
  .sa-table th, .sa-table td { padding: 12px 14px; text-align: left; border-bottom: 1px solid var(--color-border-soft); }
  .sa-table th { background: var(--color-surface-2); font-size: 12px; text-transform: uppercase; letter-spacing: .5px; color: var(--color-text-muted); }
  .sa-table tr:hover td { background: var(--color-surface-2); }

  .sa-status { display:inline-flex; padding: 2px 10px; border-radius: 999px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; }
  .sa-status.active    { background: var(--color-success-soft); color: var(--color-success); }
  .sa-status.trial     { background: var(--color-info-soft);    color: var(--color-info); }
  .sa-status.past_due  { background: var(--color-warning-soft); color: var(--color-warning); }
  .sa-status.canceled  { background: var(--color-danger-soft);  color: var(--color-danger); }
  .sa-status.suspended { background: var(--color-surface-2);    color: var(--color-text-muted); }
  .sa-status.manual    { background: var(--color-brand-soft);   color: var(--color-brand); }
  .sa-status.failed    { background: var(--color-danger-soft);  color: var(--color-danger); }
  .sa-status.published { background: var(--color-success-soft); color: var(--color-success); }
  .sa-status.scheduled { background: var(--color-warning-soft); color: var(--color-warning); }
  .sa-status.draft     { background: var(--color-surface-2);    color: var(--color-text-muted); }
  .sa-status.publishing{ background: var(--color-info-soft);    color: var(--color-info); }

  .sa-churn { font-size: 11px; padding: 2px 8px; border-radius: 4px; font-weight: 700; text-transform: uppercase; }
  .sa-churn.baixo   { background: var(--color-success-soft); color: var(--color-success); }
  .sa-churn.médio   { background: var(--color-warning-soft); color: var(--color-warning); }
  .sa-churn.alto    { background: var(--color-danger-soft);  color: var(--color-danger); }
  .sa-churn.perdido { background: var(--color-surface-2);    color: var(--color-text-muted); }

  .sa-form-row { display: grid; grid-template-columns: 200px 1fr; gap: 16px; align-items: center; padding: 12px 0; border-bottom: 1px solid var(--color-border-soft); }
  .sa-form-row:last-child { border: 0; }
  .sa-form-row label { color: var(--color-text-muted); font-size: 13px; font-weight: 500; }

  .sa-card { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: 24px; margin-bottom: 20px; }
  .sa-card h2 { font-size: 16px; font-weight: 700; margin-bottom: 16px; }

  .sa-action-row { display:flex; gap: 8px; flex-wrap: wrap; }

/* ─── CHOOSE LISTING MODAL (_components/choose_listing_modal.html) ─── */
.cl-overlay {
    position: fixed; inset: 0;
    background: rgba(15, 30, 60, .55);
    z-index: 9990;
    display: flex; align-items: flex-start; justify-content: center;
    padding: 80px 16px 24px;
    animation: cl-fade .15s ease-out;
  }
  @keyframes cl-fade { from { opacity: 0; } to { opacity: 1; } }
  .cl-card {
    width: 100%; max-width: 560px;
    background: var(--color-surface);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-lg);
    display: flex; flex-direction: column;
    max-height: 70vh;
  }
  .cl-head {
    display: flex; align-items: center; justify-content: space-between;
    padding: 16px 20px; border-bottom: 1px solid var(--color-border-soft);
  }
  .cl-head h2 { font-size: 16px; font-weight: 700; }
  .cl-search { position: relative; padding: 12px 20px; border-bottom: 1px solid var(--color-border-soft); }
  .cl-type {
    display: flex; gap: 4px;
    padding: 8px 16px 10px; border-bottom: 1px solid var(--color-border-soft);
    background: var(--color-surface-2);
  }
  .cl-type button {
    flex: 1; display: inline-flex; align-items: center; justify-content: center; gap: 6px;
    padding: 7px 10px; font-size: 13px; font-weight: 600;
    color: var(--color-text-muted);
    background: transparent; border: 1px solid transparent; border-radius: var(--radius);
    cursor: pointer; transition: background .12s, color .12s, border-color .12s;
  }
  .cl-type button:hover { background: var(--color-surface); }
  .cl-type button.is-active {
    color: var(--color-brand); background: var(--color-surface);
    border-color: var(--color-brand-soft);
    box-shadow: 0 1px 3px rgba(0,0,0,.04);
  }
  .cl-search i.bi-search {
    position: absolute; left: 32px; top: 50%; transform: translateY(-50%);
    color: var(--color-text-soft);
  }
  .cl-search .input { padding-left: 36px; }
  .cl-list {
    list-style: none; padding: 4px; margin: 0;
    overflow-y: auto; flex: 1;
  }
  .cl-list li {
    display: grid; grid-template-columns: 40px 1fr auto;
    gap: 12px; align-items: center;
    padding: 10px 12px; border-radius: var(--radius);
    cursor: pointer; font-size: 14px;
  }
  .cl-list li.is-focused { background: var(--color-brand-soft); }
  .cl-list li small { color: var(--color-text-muted); display: block; font-size: 12px; }
  .cl-thumb {
    width: 40px; height: 40px; border-radius: var(--radius-sm);
    background: var(--color-surface-2); background-size: cover; background-position: center;
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--color-text-soft);
  }
  .cl-tag {
    font-family: var(--font-display); font-weight: 700;
    color: var(--color-brand); font-size: 13px;
  }
  .cl-empty { padding: 24px; text-align: center; color: var(--color-text-muted); cursor: default; }
  .cl-empty:hover { background: transparent; }
  .cl-foot {
    display: flex; justify-content: space-between; align-items: center;
    padding: 10px 16px; border-top: 1px solid var(--color-border-soft);
    color: var(--color-text-muted); font-size: 12px;
  }
  .cl-foot kbd {
    background: var(--color-surface-2); border: 1px solid var(--color-border);
    border-radius: 4px; padding: 1px 6px; font-family: ui-monospace, monospace;
    font-size: 11px; margin: 0 2px;
  }
  .spin { animation: spin 1s linear infinite; display: inline-block; }
  @keyframes spin { to { transform: rotate(360deg); } }

/* ─── TOPBAR (_components/topbar.html) ─── */
@media (max-width: 768px) {
    #mobileMenuBtn { display: inline-flex !important; }
  }
  /* Logo3-white fallback (FASE 5.15) — em tema dark, inverte o logo até existir
     o asset white dedicado. */
  [data-theme="dark"] .topbar-wordmark img {
    filter: brightness(0) invert(1);
  }

/* ─── ERROR PAGE (errors/_base.html) ─── */
.err-shell { min-height: 70vh; display:flex; align-items:center; justify-content:center; padding:48px 24px; }
    .err-card { max-width: 560px; text-align:center; }
    .err-code { font-family: var(--font-display); font-size: 96px; font-weight: 800;
                letter-spacing: -.02em; color: var(--color-brand); line-height: 1; margin-bottom: 8px; }
    .err-title { font-size: 26px; font-weight: 700; margin: 0 0 12px; letter-spacing: -.01em; }
    .err-text  { color: var(--color-text-muted); font-size: 15px; line-height:1.5; margin-bottom: 28px; }
    .err-cta   { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; }

/* ─── LOGIN (login.html) — tela de entrada ─── */
.login-shell {
  min-height: calc(100vh - 80px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px 16px;
  background: linear-gradient(180deg,
    var(--color-brand-soft) 0%,
    var(--color-bg) 60%);
}
.login-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border-soft);
  border-radius: 16px;
  box-shadow: 0 16px 40px rgba(11, 72, 129, 0.12);
  width: 100%;
  max-width: 440px;
  padding: 40px 36px 32px;
}
.login-logo {
  display: flex;
  justify-content: center;
  margin-bottom: 28px;
}
.login-logo img {
  height: auto;
  max-width: 100%;
}
.login-title {
  font-family: 'Montserrat', sans-serif;
  font-size: 26px;
  font-weight: 800;
  letter-spacing: -0.02em;
  text-align: center;
  margin: 0 0 6px;
  color: var(--color-text);
}
.login-subtitle {
  text-align: center;
  color: var(--color-text-muted);
  font-size: 14px;
  margin: 0 0 28px;
}
.login-form .form-group { margin-bottom: 16px; }
.login-form .input { font-size: 15px; height: 44px; }
.login-btn {
  height: 48px;
  font-size: 15px;
  font-weight: 700;
  margin-top: 8px;
}
.login-footer {
  text-align: center;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--color-border-soft);
  color: var(--color-text-muted);
}
.login-footer a {
  color: var(--color-brand);
  text-decoration: none;
}
.login-footer a:hover { text-decoration: underline; }

@media (max-width: 480px) {
  .login-card { padding: 28px 22px 24px; border-radius: 12px; }
  .login-logo img { max-width: 200px; }
}
