/**
 * Painéis secundários (Nuvem, Relatórios, Jornal, confirmações, calendário):
 * branding J2CA reutilizando `.mesa-guest-brand` e, em ≤768px, tela cheia com slide horizontal.
 * Espaçamentos: apenas tokens existentes (`--panel-pad-x`, `--panel-header-gap-after`, `--panel-pad-y-top`,
 * `--panel-inset-radius`, `--field-h`, `--ui-form-kicker-*`, `--text-muted`, `--bg-root`, etc.).
 * Carregar por último (após mesa-mobile-rebuild / mesa-mobile-system).
 */

@keyframes mesaSecPanelIn {
  from {
    transform: translateX(100%);
  }
  to {
    transform: translateX(0);
  }
}

@keyframes mesaSecPanelOut {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(100%);
  }
}

/* ── Branding (mesmo bloco visual da entrada, sem depender de #mesaGuestShell) ── */
.mesa-app-panel-brand {
  margin: 0 0 14px;
  padding-bottom: 12px;
  border-bottom: 1px solid color-mix(in srgb, var(--border) 72%, var(--gold) 8%);
}

.mesa-app-panel-brand .mesa-guest-brand {
  margin: 0;
  min-width: 0;
  text-align: left;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}

.mesa-app-panel-brand .mesa-guest-brand__crest {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: 14px;
  margin: 0;
  max-width: none;
}

.mesa-app-panel-brand .mesa-guest-brand__mark {
  width: 44px;
  height: 44px;
  margin: 0;
  flex-shrink: 0;
  box-shadow: none;
  border-radius: 0;
}

.mesa-app-panel-brand .mesa-guest-brand__kicker {
  font-family: 'DM Sans', 'Inter', system-ui, sans-serif;
  font-size: 9px;
  letter-spacing: 0.36em;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--label-accent);
  margin: 0;
  padding: 0;
  line-height: 1;
  opacity: 0.95;
}

.mesa-app-panel-brand .mesa-guest-brand__title {
  font-family: 'DM Serif Display', 'Cormorant Garamond', serif;
  font-size: clamp(1.45rem, 4.2vw, 1.85rem);
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1.15;
  color: var(--gold-soft);
  margin: 0;
  padding: 0;
  border: none;
  max-width: 22ch;
  text-align: left;
  text-shadow: 0 0 20px rgba(212, 175, 55, 0.08);
}

[data-theme='clean'] .mesa-app-panel-brand {
  border-bottom-color: var(--border);
}

[data-theme='clean'] .mesa-app-panel-brand .mesa-guest-brand__kicker {
  color: var(--text-dim);
  letter-spacing: 0.34em;
}

[data-theme='clean'] .mesa-app-panel-brand .mesa-guest-brand__title {
  font-family: 'DM Serif Display', 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.35rem, 3.8vw, 1.65rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: 0.02em;
  color: var(--text);
  text-shadow: none;
  max-width: none;
}

[data-theme='clean'] .mesa-app-panel-brand .mesa-guest-brand__mark rect {
  fill: var(--text) !important;
  stroke: color-mix(in srgb, var(--border) 55%, var(--text-mid) 45%) !important;
}

[data-theme='clean'] .mesa-app-panel-brand .mesa-guest-brand__mark path {
  stroke: var(--accent) !important;
}

/* ── Mobile: tela cheia + slide (≤768px); desktop ≥769px inalterado pelas regras abaixo ── */
@media (max-width: 768px) {
  .mesa-secondary-shell.open {
    display: flex !important;
    flex-direction: column;
    align-items: stretch !important;
    justify-content: flex-start !important;
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: 100vh !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    padding: 0 !important;
    margin: 0 !important;
    overflow: hidden !important;
    box-sizing: border-box;
    background: var(--bg-root) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    box-shadow: none !important;
  }

  .mesa-secondary-shell > .mesa-secondary-panel__slide {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    width: 100%;
    height: 100%;
    min-height: 100dvh;
    margin: 0;
    border-radius: 0 !important;
    box-shadow: none !important;
    overflow: hidden;
    position: relative;
    background: var(--bg-root);
    animation: mesaSecPanelIn 250ms ease both;
  }

  .mesa-secondary-shell.open.mesa-secondary-shell--leave > .mesa-secondary-panel__slide {
    animation: mesaSecPanelOut 250ms ease both;
  }

  /* Cartões: superfície = ecrã, sem decoração de modal */
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .reports-card,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .seleto-modal__card,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .jornal-modal__card,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .confirm-modal__card,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .calendar-card {
    flex: 1 1 auto;
    min-height: 0;
    width: 100% !important;
    max-width: none !important;
    max-height: none !important;
    margin: 0 !important;
    border-radius: 0 !important;
    border: none !important;
    box-shadow: none !important;
    padding-top: 0 !important;
    animation: none !important;
    background: var(--bg-root) !important;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }

  .mesa-secondary-shell > .mesa-secondary-panel__slide > .reports-card::before,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .seleto-modal__card::before,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .confirm-modal__card::before {
    content: none !important;
    display: none !important;
  }

  /* Relatórios — rodapé fixo espelhando `.seleto-modal__footer-cta` (Nuvem) */
  #reportsModal.mesa-secondary-shell .reports-card__footer-sticky {
    display: none !important;
  }

  #reportsModal.mesa-secondary-shell > .mesa-secondary-panel__slide > .reports-modal__below-card {
    flex-shrink: 0;
    width: 100%;
    margin: 0;
    padding: var(--panel-pad-y-top) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    box-sizing: border-box;
    /* Contrasta com `.reports-card` / scroll (`--bg-root`); só nota J2CA — sem Fechar/Sair */
    background: var(--panel-inset-bg);
    border: none;
    box-shadow: none;
    gap: calc(var(--panel-header-gap-after) / 2);
    display: flex;
    flex-direction: column;
  }

  #reportsModal.mesa-secondary-shell .reports-modal__below-card .reports-close-action--mobile,
  #reportsModal.mesa-secondary-shell .reports-modal__below-card .mesa-reports-logout-btn--mobile {
    display: none !important;
  }

  #reportsModal.mesa-secondary-shell .reports-modal__footer-brand.mesa-app-panel-brand {
    display: flex !important;
    margin: 0;
    padding: 0 0 var(--panel-header-gap-after);
    border-bottom: 1px solid color-mix(in srgb, var(--border) 72%, var(--gold) 8%);
    border-top: none;
  }

  [data-theme='clean'] #reportsModal.mesa-secondary-shell .reports-modal__footer-brand.mesa-app-panel-brand {
    border-bottom-color: var(--border);
  }

  #reportsModal.mesa-secondary-shell .reports-modal__footer-brand .mesa-guest-brand__mark {
    width: 40px;
    height: 40px;
  }

  #reportsModal.mesa-secondary-shell .reports-modal__footer-brand .mesa-guest-brand__title {
    font-size: clamp(1.2rem, 3.8vw, 1.5rem);
    max-width: none;
  }

  #reportsModal.mesa-secondary-shell .reports-card__close {
    border-radius: var(--panel-inset-radius) !important;
  }

  #reportsModal.mesa-secondary-shell .reports-card__header {
    padding-top: calc(max(0px, env(safe-area-inset-top, 0px)) + 10px);
  }

  #reportsModal.mesa-secondary-shell .mesa-reports-tabs {
    padding-bottom: calc(var(--panel-header-gap-after) + 6px);
  }

  #reportsModal.mesa-secondary-shell .reports-card__scroll {
    padding-top: calc(var(--panel-header-gap-after) + 6px);
    padding-bottom: var(--panel-header-gap-after);
  }

  #reportsModal.mesa-secondary-shell .reports-modal__below-card .reports-card__footer-note--below-shell {
    margin-top: 0;
    padding-top: 0;
    border-top: none;
    text-align: center;
  }

  .mesa-secondary-shell.jornal-modal.open {
    overflow-y: hidden !important;
  }

  .mesa-secondary-shell.jornal-modal > .mesa-secondary-panel__slide > .jornal-modal__card {
    max-height: none !important;
  }

  .mesa-secondary-shell > .mesa-secondary-panel__slide > .seleto-modal__card::after,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .reports-card::after,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .jornal-modal__card::after,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .confirm-modal__card::after,
  .mesa-secondary-shell > .mesa-secondary-panel__slide > .calendar-card::after {
    content: none !important;
    display: none !important;
  }

  .mesa-secondary-shell .seleto-modal__close,
  .mesa-secondary-shell .reports-card__close,
  .mesa-secondary-shell .jornal-modal__close,
  .mesa-secondary-shell .confirm-modal__close,
  .mesa-secondary-shell .calendar-close {
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    flex-shrink: 0;
    border-radius: 999px;
    border: 1px solid var(--border2);
    background: var(--panel-inset-bg);
    color: var(--text-mid);
  }

  /* ── Zona 1 + 2: cabeçalho em grelha (kicker + fechar | título + subtítulo) ── */
  .mesa-secondary-shell .mesa-app-panel-brand {
    display: none !important;
  }

  .mesa-secondary-shell .reports-card__header,
  .mesa-secondary-shell .jornal-modal__header,
  .mesa-secondary-shell .seleto-modal__header,
  .mesa-secondary-shell .confirm-modal__header,
  .mesa-secondary-shell .calendar-topbar {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-rows: 64px auto;
    column-gap: var(--panel-pad-x);
    align-items: center;
    padding-left: var(--panel-pad-x);
    padding-right: var(--panel-pad-x);
    padding-top: max(0px, env(safe-area-inset-top, 0px));
    padding-bottom: 0;
    margin: 0;
    border: none;
    box-shadow: none;
    background: transparent;
    flex-shrink: 0;
    position: relative;
    z-index: 2;
  }

  .mesa-secondary-shell .reports-card__header > div:first-child,
  .mesa-secondary-shell .jornal-modal__header > div:first-child,
  .mesa-secondary-shell .seleto-modal__header > div:first-child,
  .mesa-secondary-shell .confirm-modal__header > div:first-child,
  .mesa-secondary-shell .calendar-topbar > div:first-child {
    display: contents;
  }

  .mesa-secondary-shell .reports-card__kicker,
  .mesa-secondary-shell .seleto-modal__kicker,
  .mesa-secondary-shell .confirm-modal__kicker {
    grid-column: 1;
    grid-row: 1;
    align-self: center;
    margin: 0;
    min-width: 0;
    padding: 0;
    font-size: var(--ui-form-kicker-size);
    font-weight: var(--ui-form-kicker-weight);
    letter-spacing: var(--ui-form-kicker-tracking);
    text-transform: uppercase;
    color: var(--text-muted);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    border: none;
  }

  .mesa-secondary-shell .reports-card__close,
  .mesa-secondary-shell .jornal-modal__close,
  .mesa-secondary-shell .seleto-modal__close,
  .mesa-secondary-shell .confirm-modal__close,
  .mesa-secondary-shell .calendar-close {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    justify-self: end;
  }

  .mesa-secondary-shell .reports-card__title,
  .mesa-secondary-shell .seleto-modal__title,
  .mesa-secondary-shell .confirm-modal__title,
  .mesa-secondary-shell .calendar-title {
    grid-column: 1 / -1;
    grid-row: 2;
    margin: 0;
    padding: 0 0 var(--panel-pad-x);
    max-width: none;
    box-sizing: border-box;
    font-family: 'Cormorant Garamond', 'DM Serif Display', serif;
    color: var(--text);
    line-height: 1.08;
    white-space: normal;
  }

  .mesa-secondary-shell .reports-card__title {
    font-size: clamp(1.65rem, 5.5vw, 2rem);
  }

  .mesa-secondary-shell .seleto-modal__title {
    font-size: clamp(1.75rem, 6vw, 2.25rem);
    line-height: 1.05;
  }

  /*
   * Nuvem (#seletoModal): mesa-seleto-modal-premium.css usa #seletoModal .seleto-modal__kicker { margin-bottom: 8px }
   * e fechar 40×40 — com maior especificidade que .mesa-secondary-shell.*; empurra o título e desalinha da linha do kicker.
   */
  #seletoModal.mesa-secondary-shell .seleto-modal__header {
    grid-template-rows: auto auto;
    row-gap: 0;
  }

  #seletoModal.mesa-secondary-shell .seleto-modal__kicker {
    margin-bottom: 0 !important;
    line-height: 1;
  }

  #seletoModal.mesa-secondary-shell .seleto-modal__close {
    width: 44px !important;
    height: 44px !important;
    min-width: 44px !important;
    min-height: 44px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 !important;
    margin: 0 !important;
    line-height: 1 !important;
    box-sizing: border-box !important;
  }

  #seletoModal.mesa-secondary-shell .seleto-modal__title {
    padding-top: 0 !important;
    margin-top: 0 !important;
  }

  .mesa-secondary-shell .confirm-modal__title {
    font-size: clamp(1.65rem, 5vw, 2rem);
    line-height: 1.1;
    padding-bottom: 0;
  }

  .mesa-secondary-shell .calendar-title {
    font-size: clamp(1.5rem, 5vw, 1.85rem);
    padding-bottom: var(--panel-pad-x);
  }

  .mesa-secondary-shell .reports-card__subtitle {
    grid-column: 1 / -1;
    grid-row: 3;
    margin: calc(var(--panel-header-gap-after) / 2) 0 0;
    padding: 0 0 var(--panel-pad-x);
    box-sizing: border-box;
    font-size: var(--ui-card-heading-size);
    color: var(--text-muted);
    line-height: 1.45;
    white-space: normal;
    border: none;
  }

  .mesa-secondary-shell .reports-card__header:has(.reports-card__subtitle) .reports-card__title {
    padding-bottom: 0;
  }

  .mesa-secondary-shell .jornal-modal__title {
    grid-column: 1 / -1;
    grid-row: 2;
    margin: 0;
    padding: 0 0 0;
    box-sizing: border-box;
    font-size: clamp(1.55rem, 5vw, 1.9rem);
    white-space: normal;
  }

  .mesa-secondary-shell .jornal-modal__subtitle {
    grid-column: 1 / -1;
    grid-row: 3;
    margin: calc(var(--panel-header-gap-after) / 2) 0 0;
    padding: 0;
    box-sizing: border-box;
    white-space: normal;
    color: var(--text-muted);
  }

  .mesa-secondary-shell .jornal-modal__lede {
    grid-column: 1 / -1;
    grid-row: 4;
    margin: calc(var(--panel-header-gap-after) / 2) 0 0;
    padding: 0 0 var(--panel-pad-x);
    box-sizing: border-box;
    white-space: normal;
    color: var(--text-muted);
    border: none;
  }

  /* ── Zona 3: scroll + padding ── */
  .mesa-secondary-shell .reports-card {
    min-height: 0;
  }

  .mesa-secondary-shell .mesa-reports-tabs {
    flex-shrink: 0;
    padding: 0 var(--panel-pad-x) var(--panel-header-gap-after);
    margin: 0;
    border: none;
    border-bottom: none;
    box-shadow: none;
    background: transparent;
  }

  .mesa-secondary-shell .reports-card__scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    margin: 0;
    border: none;
    background: transparent;
  }

  .mesa-secondary-shell .reports-card__footer-sticky {
    flex-shrink: 0;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-header-gap-after), env(safe-area-inset-bottom, 0px));
    border: none;
    box-shadow: none;
    background: var(--bg-root);
  }

  .mesa-secondary-shell .reports-card__footer-sticky .reports-actions-group {
    margin-top: 0;
    padding: 0;
    border: none;
    background: transparent;
  }

  .mesa-secondary-shell .reports-card__footer-note {
    margin-top: var(--panel-header-gap-after);
    padding: 0;
    border: none;
    color: var(--text-muted);
  }

  #reportsModal.mesa-secondary-shell .reports-card__body-actions {
    display: flex;
    flex-direction: column;
    gap: var(--panel-pad-y-top);
    margin-top: var(--panel-pad-y-top);
  }

  #reportsModal.mesa-secondary-shell .reports-card__body-actions > .reports-actions-group {
    margin-top: 0;
    padding: 0;
    border: none;
    background: transparent;
  }

  /* Vence `#reportsModal` em base.css (layout legado só quando não há shell) */
  #reportsModal.mesa-secondary-shell .reports-card__excel-mobile-slot {
    display: block;
    order: 2;
  }

  #reportsModal.mesa-secondary-shell #reportsJsonActionsGroup {
    order: 1;
  }

  #reportsModal.mesa-secondary-shell .reports-card__excel-mobile-slot .btn-seleto {
    width: 100%;
    min-height: 52px;
    box-sizing: border-box;
  }

  #reportsModal.mesa-secondary-shell .reports-card__desktop-footer-block {
    display: none !important;
  }

  #reportsModal.mesa-secondary-shell .reports-card__body-actions .json-actions {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    gap: calc(var(--panel-header-gap-after) / 2);
    align-items: stretch;
  }

  #reportsModal.mesa-secondary-shell .reports-card__body-actions .json-actions > * {
    flex: 1 1 0;
    min-height: 52px;
    width: auto;
    min-width: 0;
    box-sizing: border-box;
  }

  #reportsModal.mesa-secondary-shell #reportsJsonActionsGroup .reports-card__actions {
    display: flex;
    grid-template-columns: unset;
  }

  .mesa-secondary-shell .reports-section-kicker,
  .mesa-secondary-shell .seleto-cloud-profile__kicker {
    font-size: var(--ui-form-kicker-size);
    font-weight: var(--ui-form-kicker-weight);
    letter-spacing: var(--ui-form-kicker-tracking);
    color: var(--text-muted);
    margin: 0 0 calc(var(--panel-header-gap-after) / 2);
    white-space: nowrap;
  }

  .mesa-secondary-shell .reports-card__field {
    margin-bottom: var(--panel-header-gap-after);
  }

  .mesa-secondary-shell .reports-card__field > span {
    display: block;
    font-size: var(--ui-form-kicker-size);
    font-weight: var(--ui-form-kicker-weight);
    letter-spacing: var(--ui-form-kicker-tracking);
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: calc(var(--panel-header-gap-after) / 2);
    white-space: nowrap;
  }

  .mesa-secondary-shell .reports-select,
  .mesa-secondary-shell .app-select {
    min-height: max(52px, var(--field-h));
    border-radius: var(--panel-inset-radius);
    padding-left: var(--panel-header-gap-after);
    padding-right: var(--panel-pad-x);
  }

  .mesa-secondary-shell .reports-card__note {
    margin-top: var(--panel-header-gap-after);
    border: none;
    background: var(--panel-inset-bg);
    border-radius: var(--panel-inset-radius);
    padding: var(--panel-header-gap-after);
    color: var(--text-muted);
  }

  .mesa-secondary-shell .reports-card__actions {
    display: flex;
    flex-direction: column;
    gap: calc(var(--panel-header-gap-after) / 2);
    margin-top: var(--panel-header-gap-after);
  }

  .mesa-secondary-shell .reports-card__actions--excel {
    gap: calc(var(--panel-header-gap-after) / 2);
  }

  .mesa-secondary-shell .reports-card__actions.json-actions {
    flex-direction: row;
    flex-wrap: nowrap;
    gap: calc(var(--panel-header-gap-after) / 2);
  }

  .mesa-secondary-shell .reports-card__actions.json-actions > * {
    flex: 1 1 0;
    min-width: 0;
    white-space: nowrap;
    font-size: var(--ui-card-heading-size);
  }

  .mesa-secondary-shell .btn-seleto,
  .mesa-secondary-shell .btn-seleto-ghost,
  .mesa-secondary-shell .btn-ghost,
  .mesa-secondary-shell .confirm-modal__actions .btn-add,
  .mesa-secondary-shell .confirm-modal__actions .confirm-btn-danger {
    min-height: 52px;
    width: 100%;
    box-sizing: border-box;
    white-space: nowrap;
    font-size: var(--ui-card-heading-size);
    border-radius: var(--panel-inset-radius);
  }

  .mesa-secondary-shell .confirm-modal__scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
    background: transparent;
  }

  .mesa-secondary-shell .confirm-modal__footer {
    flex-shrink: 0;
    padding: var(--panel-pad-y-top) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
    box-shadow: none;
    background: var(--bg-root);
  }

  .mesa-secondary-shell .confirm-modal__actions {
    flex-direction: column;
    gap: calc(var(--panel-header-gap-after) / 2);
    margin-top: var(--panel-pad-y-top);
  }

  .mesa-secondary-shell .confirm-modal__text {
    margin: 0;
    color: var(--text-muted);
    white-space: normal;
  }

  .mesa-secondary-shell .confirm-modal__warn {
    margin-top: var(--panel-pad-y-top);
    border: none;
    background: var(--negative-bg);
    color: var(--negative);
    border-radius: var(--panel-inset-radius);
    padding: var(--panel-header-gap-after);
  }

  /* Jornal */
  .mesa-secondary-shell .jornal-modal__body {
    flex: 1 1 auto;
    min-height: 0;
    padding: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }

  .mesa-secondary-shell .jornal-modal__scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
  }

  .mesa-secondary-shell .jornal-modal__tabs {
    margin: 0 0 var(--panel-header-gap-after);
    padding: 0;
    border: none;
    gap: calc(var(--panel-header-gap-after) / 2);
  }

  .mesa-secondary-shell .jornal-modal__tab {
    white-space: nowrap;
  }

  .mesa-secondary-shell .jornal-modal__item-meta {
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .mesa-secondary-shell .seleto-plan__label {
    white-space: nowrap;
  }

  .mesa-secondary-shell .jornal-modal__disclaimer {
    flex-shrink: 0;
    margin: 0;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
    background: var(--bg-root);
    color: var(--text-muted);
    white-space: normal;
  }

  .mesa-secondary-shell .jornal-modal__disclaimer-kicker {
    white-space: nowrap;
  }

  /* Seleto / Nuvem */
  .mesa-secondary-shell .seleto-modal__body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
  }

  .mesa-secondary-shell .seleto-modal__body-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow-y: auto;
    padding: var(--panel-header-gap-after) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
  }

  .mesa-secondary-shell .seleto-modal__footer-cta {
    flex-shrink: 0;
    padding: var(--panel-pad-y-top) var(--panel-pad-x)
      max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
    border: none;
    box-shadow: none;
    background: var(--bg-root);
  }

  .mesa-secondary-shell .seleto-modal__footer-cta .seleto-modal__cta {
    display: flex;
    flex-direction: column;
    gap: calc(var(--panel-header-gap-after) / 2);
    margin-top: 0;
  }

  .mesa-secondary-shell .seleto-cloud-actions {
    display: flex;
    flex-direction: column;
    gap: calc(var(--panel-header-gap-after) / 2);
    margin-top: 0;
  }

  .mesa-secondary-shell .seleto-cloud-actions--stack {
    margin-top: var(--panel-header-gap-after);
  }

  .mesa-secondary-shell .seleto-modal__intro,
  .mesa-secondary-shell .seleto-modal__member-hint {
    margin-bottom: var(--panel-header-gap-after);
    color: var(--text-muted);
    white-space: normal;
  }

  .mesa-secondary-shell .seleto-modal__grid {
    display: flex;
    flex-direction: column;
    gap: var(--panel-pad-y-top);
    margin-top: var(--panel-header-gap-after);
  }

  .mesa-secondary-shell .seleto-plan {
    border: none;
    border-radius: var(--panel-inset-radius);
    background: var(--panel-inset-bg);
    padding: var(--panel-header-gap-after);
    box-shadow: none;
  }

  .mesa-secondary-shell .seleto-plan--premium {
    border: none;
    box-shadow: none;
    background: var(--panel-inset-bg);
  }

  .mesa-secondary-shell .seleto-cloud-panel__head {
    margin-bottom: var(--panel-pad-y-top);
    border: none;
    padding: 0;
  }

  .mesa-secondary-shell .seleto-cloud-panel__title {
    white-space: normal;
    color: var(--text);
  }

  .mesa-secondary-shell .seleto-cloud-panel__note {
    color: var(--text-muted);
    white-space: normal;
    margin-top: calc(var(--panel-header-gap-after) / 2);
  }

  .mesa-secondary-shell .seleto-cloud-panel .field.field--float,
  .mesa-secondary-shell .seleto-cloud-field.field.field--float {
    margin-bottom: var(--panel-header-gap-after);
  }

  .mesa-secondary-shell .seleto-cloud-panel .field.field--float input,
  .mesa-secondary-shell .seleto-cloud-panel .field.field--float .mesa-password-input,
  .mesa-secondary-shell .mesa-password-wrap {
    min-height: max(52px, var(--field-h));
    border-radius: var(--panel-inset-radius);
  }

  .mesa-secondary-shell .seleto-cloud-userline {
    display: flex;
    align-items: center;
    gap: calc(var(--panel-header-gap-after) / 2);
    margin-bottom: var(--panel-header-gap-after);
    min-width: 0;
  }

  .mesa-secondary-shell .seleto-cloud-userline__email {
    flex: 1 1 auto;
    min-width: 0;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    font-variant-numeric: tabular-nums;
  }

  .mesa-secondary-shell .seleto-cloud-userline .btn-seleto-ghost {
    flex: 0 0 auto;
    width: auto;
    min-height: 44px;
    padding-left: var(--panel-header-gap-after);
    padding-right: var(--panel-header-gap-after);
    white-space: nowrap;
  }

  .mesa-secondary-shell .seleto-cloud-profile {
    border: none;
    padding: 0;
    margin: 0;
    background: transparent;
  }

  .mesa-secondary-shell .seleto-cloud-profile__assist {
    margin: calc(var(--panel-header-gap-after) / 2) 0 var(--panel-header-gap-after);
    color: var(--text-muted);
    font-size: var(--ui-hint-size);
    white-space: normal;
  }

  .mesa-secondary-shell .seleto-cloud-msg {
    margin-top: var(--panel-header-gap-after);
    color: var(--text-muted);
    white-space: normal;
  }

  .mesa-secondary-shell .seleto-cta-note {
    margin-top: var(--panel-header-gap-after);
    padding: 0;
    border: none;
    color: var(--text-muted);
    font-size: var(--ui-hint-size);
    text-align: center;
    white-space: normal;
  }

  /* Calendário: corpo scrollável com topo fixo via sticky no topbar */
  .mesa-secondary-shell .calendar-card {
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    padding-left: 0;
    padding-right: 0;
    padding-bottom: max(var(--panel-pad-y-top), env(safe-area-inset-bottom, 0px));
  }

  .mesa-secondary-shell .calendar-topbar {
    position: sticky;
    top: 0;
    z-index: 3;
    background: var(--bg-root);
  }

  .mesa-secondary-shell .calendar-nav,
  .mesa-secondary-shell .calendar-weekdays,
  .mesa-secondary-shell .calendar-grid,
  .mesa-secondary-shell .calendar-footer {
    padding-left: var(--panel-pad-x);
    padding-right: var(--panel-pad-x);
  }

  .mesa-secondary-shell .calendar-nav-btn,
  .mesa-secondary-shell .calendar-footer-btn {
    min-height: max(44px, var(--field-h));
    border-radius: var(--panel-inset-radius);
    border: 1px solid var(--border2);
    background: var(--panel-inset-bg);
    color: var(--text-muted);
  }

  .mesa-secondary-shell .calendar-footer {
    display: flex;
    flex-direction: column;
    gap: calc(var(--panel-header-gap-after) / 2);
    padding-top: var(--panel-header-gap-after);
    padding-bottom: var(--panel-header-gap-after);
    border: none;
    background: transparent;
  }

  .mesa-secondary-shell .calendar-footer-btn {
    width: 100%;
    white-space: nowrap;
    font-size: var(--ui-card-heading-size);
  }

  /* Botões destrutivos: só espaço acima */
  .mesa-secondary-shell .mesa-reports-logout-btn,
  .mesa-secondary-shell .reports-logout-action {
    margin-top: var(--panel-pad-x);
  }
}

@media (max-width: 768px) and (prefers-reduced-motion: reduce) {
  .mesa-secondary-shell > .mesa-secondary-panel__slide {
    animation: none !important;
  }
}

/* Desktop: o wrapper de slide não participa do layout (cartão continua como antes). */
@media (min-width: 769px) {
  .mesa-secondary-shell > .mesa-secondary-panel__slide {
    display: contents;
  }
}
