:root {
  color-scheme: light;
  --font-ui: "Sora", "Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
  --topbar-height: 154px;
  --topbar-height-collapsed: 52px;
  --topbar-current-height: var(--topbar-height);
  --sidebar-expanded-width: 276px;
  --sidebar-collapsed-width: 64px;
  --sidebar-gap: 0px;
  /* Theme tokens */
  --bg-wine: #6a2a3a;
  --bg-wine-soft: #7e3c4a;
  --bg-gold: #d0b06d;
  --bg-gradient: linear-gradient(120deg, var(--bg-wine) 0%, var(--bg-wine-soft) 35%, var(--bg-gold) 100%);
  --card-bg: rgba(255, 255, 255, 0.82);
  --card-border: rgba(0, 0, 0, 0.06);
  --card-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  --card-blur: 6px;
  --card: rgba(255, 255, 255, 0.9);
  --card-alt: rgba(255, 255, 255, 0.78);
  --card-strong: rgba(255, 255, 255, 0.94);
  --card-border-strong: rgba(74, 31, 43, 0.18);
  --text: #231d1f;
  --muted: #6c6367;
  --heading: #37131e;
  --accent: #c9a461;
  --accent-hover: #b08b49;
  --accent-contrast: #2c2426;
  --accent-soft: rgba(195, 160, 91, 0.14);
  --accent-soft-border: rgba(195, 160, 91, 0.35);
  --link: #5c2b3b;
  --input-bg: rgba(255, 255, 255, 0.7);
  --input-border: rgba(0, 0, 0, 0.08);
  --input-placeholder: rgba(35, 29, 31, 0.45);
  --focus: #4b1f2c;
  --focus-ring: rgba(74, 31, 43, 0.18);
  --shadow: 0 8px 20px rgba(39, 23, 27, 0.08);
  --shadow-soft: 0 6px 14px rgba(39, 23, 27, 0.06);
  --shadow-hover: 0 10px 18px rgba(39, 23, 27, 0.1);
  --button-shadow: 0 10px 20px rgba(195, 160, 91, 0.22);
  --divider: rgba(74, 31, 43, 0.12);
  --divider-strong: rgba(74, 31, 43, 0.18);
  --warning-bg: rgba(195, 160, 91, 0.16);
  --warning-border: rgba(195, 160, 91, 0.35);
  --error-bg: rgba(146, 51, 51, 0.12);
  --error-border: rgba(146, 51, 51, 0.4);
  --success-bg: rgba(47, 143, 91, 0.08);
  --success-border: rgba(47, 143, 91, 0.26);
  --ghost-bg: var(--card-strong);
  --ghost-border: var(--card-border-strong);
  /* Dark mode palette (premium matte wine + champagne accent) */
  --dm-bg: #1a0f14;
  --dm-bg2: #23121b;
  --dm-card: #2a1520;
  --dm-surface: #341a27;
  --dm-border: rgba(255, 255, 255, 0.08);
  --dm-text: rgba(255, 255, 255, 0.92);
  --dm-muted: rgba(255, 255, 255, 0.7);
  --dm-placeholder: rgba(255, 255, 255, 0.48);
  --dm-accent: #d6b06b;
  --dm-accent-soft: rgba(214, 176, 107, 0.18);
  --dm-shadow: 0 8px 24px rgba(0, 0, 0, 0.22);
}

.theme-dark {
  color-scheme: dark;
  --bg-gradient: linear-gradient(135deg, var(--dm-bg) 0%, var(--dm-bg2) 100%);
  --card-bg: var(--dm-card);
  --card-border: var(--dm-border);
  --card-shadow: var(--dm-shadow);
  --card-blur: 2px;
  --card: var(--dm-card);
  --card-alt: color-mix(in srgb, var(--dm-card) 82%, var(--dm-surface) 18%);
  --card-strong: color-mix(in srgb, var(--dm-card) 75%, var(--dm-surface) 25%);
  --card-border-strong: rgba(255, 255, 255, 0.12);
  --text: var(--dm-text);
  --muted: var(--dm-muted);
  --heading: var(--dm-text);
  --accent: var(--dm-accent);
  --accent-hover: #e0bc7d;
  --accent-contrast: #1a1410;
  --accent-soft: var(--dm-accent-soft);
  --accent-soft-border: rgba(214, 176, 107, 0.34);
  --link: var(--dm-accent);
  --input-bg: var(--dm-surface);
  --input-border: var(--dm-border);
  --input-placeholder: var(--dm-placeholder);
  --focus: var(--dm-accent);
  --focus-ring: rgba(214, 176, 107, 0.26);
  --shadow: var(--dm-shadow);
  --shadow-soft: 0 4px 14px rgba(0, 0, 0, 0.2);
  --shadow-hover: 0 10px 24px rgba(0, 0, 0, 0.24);
  --button-shadow: 0 6px 14px rgba(0, 0, 0, 0.22);
  --divider: rgba(255, 255, 255, 0.12);
  --divider-strong: rgba(255, 255, 255, 0.16);
  --warning-bg: rgba(160, 120, 20, 0.18);
  --warning-border: rgba(160, 120, 20, 0.32);
  --error-bg: rgba(160, 40, 60, 0.18);
  --error-border: rgba(160, 40, 60, 0.32);
  --success-bg: rgba(40, 140, 80, 0.18);
  --success-border: rgba(40, 140, 80, 0.32);
  --ghost-bg: color-mix(in srgb, var(--dm-card) 86%, transparent);
  --ghost-border: var(--dm-border);
}

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
  font-family: var(--font-ui);
}

body {
  background: var(--bg-gradient);
  color: var(--text);
  min-height: 100vh;
}


.homeScreen {
  display: none;
  min-height: 100vh;
  padding: 24px;
  align-items: center;
  justify-content: center;
}

body.is-home .homeScreen {
  display: flex;
}

body.is-home #app-container {
  display: none;
}

body.is-home #floating-next {
  display: none;
}

body.is-guidelines #floating-next {
  display: none;
}

body.is-home .modal-backdrop {
  display: none;
}

.card.homeCard {
  width: min(520px, 100%);
  display: grid;
  justify-items: center;
  text-align: center;
  gap: 14px;
  padding: clamp(28px, 5vw, 42px);
  background: color-mix(in srgb, var(--wine-base, var(--bg-wine)) 95%, #fff 5%);
  border: 1px solid color-mix(in srgb, var(--accent) 18%, rgba(255, 255, 255, 0.2) 82%);
  backdrop-filter: blur(var(--card-blur));
  -webkit-backdrop-filter: blur(var(--card-blur));
  box-shadow: var(--shadow);
}

.homeBadge {
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  font-weight: 700;
  color: var(--heading);
  background: var(--accent-soft);
  border: 1px solid var(--accent-soft-border);
}

.homeLogo {
  width: clamp(112px, 22vw, 156px);
  height: auto;
  filter: drop-shadow(0 6px 18px rgba(0, 0, 0, 0.2));
}

.homeCard h1 {
  font-size: clamp(1.28rem, 2.5vw, 1.62rem);
  color: #fff;
}

.homeActions {
  width: 100%;
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: stretch;
  gap: 12px;
}

.homeActionGrid {
  width: 100%;
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.homeActionGrid button {
  width: 100%;
}

.homeActionGrid .is-disabled {
  cursor: not-allowed;
  opacity: 0.66;
}

.homeLoginCard {
  width: 100%;
  display: grid;
  gap: 10px;
  border: 1px solid var(--card-border-strong);
  border-radius: 14px;
  padding: 12px;
  background: color-mix(in srgb, var(--card-strong) 78%, transparent);
}

.homeLoginTitle {
  font-size: 0.9rem;
  color: var(--muted);
}

.homeLoginActions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.homeLoginFeedback {
  min-height: 1.1em;
  font-size: 0.9rem;
  color: var(--muted);
}

.homeLoginFeedback[data-tone="error"] {
  color: #b3261e;
}

.theme-dark .homeLoginFeedback[data-tone="error"] {
  color: #ff9b90;
}

.homeLoginFeedback[data-tone="success"] {
  color: #1f7a43;
}

.homeHint {
  font-size: 0.88rem;
  color: var(--muted);
}

#home-client-hint {
  color: #ffffff;
}


a {
  color: var(--link);
}

a:hover {
  color: var(--accent-hover);
}


.app {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px calc(90px + env(safe-area-inset-bottom));
}

.appShell {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: var(--topbar-current-height);
}

.appBody {
  position: relative;
  display: block;
  padding-top: 0;
}

.app.sidebar-collapsed .appBody {
  /* mantido para compatibilidade com JS */
}

.left-sidebar {
  position: fixed;
  top: var(--topbar-current-height);
  left: 0;
  width: var(--sidebar-expanded-width);
  height: calc(100vh - var(--topbar-current-height));
  min-height: calc(100vh - var(--topbar-current-height));
  background: rgba(255, 255, 255, 0.06);
  border: 0;
  border-right: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: none;
  border-radius: 0;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  overflow-y: auto;
  transition: width 0.25s ease, top 0.22s ease, height 0.22s ease;
  z-index: 10;
  align-self: start;
  margin-top: 0;
}

.theme-dark .left-sidebar {
  background: color-mix(in srgb, var(--dm-bg) 90%, var(--dm-bg2) 10%);
  border-right-color: var(--dm-border);
}

.left-sidebar.collapsed {
  width: var(--sidebar-collapsed-width);
  padding-inline: 8px;
  overflow: hidden;
}

.sidebar-toggle {
  width: 100%;
  min-height: 40px;
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  background: transparent;
  border: 0;
  border-radius: 0;
  padding: 8px 12px;
}

.sidebar-toggle span {
  width: 18px;
  height: 2px;
  background: #fff;
  border-radius: 99px;
  display: block;
  margin-left: 0;
  margin-right: auto;
}

.sidebar-toggle:hover {
  opacity: 0.88;
}

.sidebar-toggle:focus-visible {
  outline: 2px solid rgba(213, 178, 106, 0.75);
  outline-offset: 2px;
}

.sidebar-nav {
  display: grid;
  gap: 8px;
}

.sidebar-item {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 12px;
  border: 1px solid var(--card-border-strong);
  background: rgba(15, 8, 12, 0.24);
  color: rgba(255, 255, 255, 0.92);
  border-radius: 12px;
  padding: 10px 12px;
}

.sidebar-item.active {
  background: rgba(216, 167, 74, 0.2);
  border-color: rgba(216, 167, 74, 0.45);
  color: rgba(255, 255, 255, 0.96);
}

.sidebar-icon {
  color: #d8a74a;
  flex-shrink: 0;
  width: 19px;
  height: 19px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.sidebar-icon svg {
  width: 19px;
  height: 19px;
  display: block;
}

.sidebar-item:hover {
  background: rgba(216, 167, 74, 0.14);
}

.sidebar-item:hover .sidebar-icon,
.sidebar-item.active .sidebar-icon {
  filter: brightness(1.08);
}

.sidebar-label {
  white-space: nowrap;
  opacity: 1;
  transition: opacity 0.2s ease;
}

.left-sidebar.collapsed .sidebar-item,
.left-sidebar.collapsed .sidebar-toggle {
  justify-content: center;
  padding-inline: 8px;
}

.left-sidebar.collapsed .sidebar-toggle span {
  margin-inline: auto;
}

.left-sidebar.collapsed .sidebar-label {
  opacity: 0;
  width: 0;
  overflow: hidden;
}

.app-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}

.topbar {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 50;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  height: var(--topbar-current-height);
  min-height: var(--topbar-current-height);
  padding-block: 10px;
  transition: height 0.22s ease, min-height 0.22s ease, padding 0.22s ease, background 0.22s ease;
  padding-inline: max(18px, calc((100vw - 1280px) / 2 + 24px));
  border-radius: 0;
  margin-bottom: 0;
  background: rgba(255, 255, 255, 0.08);
  border: 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: none;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.theme-dark .topbar {
  background: color-mix(in srgb, var(--dm-bg) 86%, var(--dm-bg2) 14%);
  border-bottom-color: var(--dm-border);
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 18px;
  flex-wrap: nowrap;
}

.brand-button {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  margin: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
  text-decoration: none;
}

.brand-button:focus-visible {
  outline: 2px solid rgba(213, 178, 106, 0.8);
  outline-offset: 4px;
  border-radius: 14px;
}

.brand-copy {
  display: block;
}

.logo {
  width: 92px;
  transition: width 0.22s ease;
  height: auto;
  object-fit: contain;
}

.eyebrow {
  text-transform: uppercase;
  letter-spacing: 0.2em;
  font-size: 0.75rem;
  color: var(--accent);
}

h1 {
  font-size: 2.1rem;
  transition: font-size 0.22s ease, margin 0.22s ease;
  margin: 8px 0;
  color: var(--heading);
}

.subtitle {
  color: #ffffff;
}

.theme-dark .subtitle {
  color: var(--muted);
}

.mode-indicator {
  margin-top: 12px;
  color: #ffffff;
  font-size: 0.95rem;
}

.mode-indicator strong {
  color: #ffffff;
}

.header-actions {
  display: flex;
  gap: 12px;
  align-items: center;
}

.topbar-user-pill {
  font-weight: 700;
}

.topbar-history-btn {
  font-weight: 700;
}

.theme-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: #ffffff;
}

.theme-dark .mode-indicator {
  color: var(--muted);
}

.theme-dark .mode-indicator strong {
  color: var(--heading);
}

.theme-dark .theme-toggle {
  color: var(--muted);
}

.local-storage-panel {
  position: relative;
}

.local-storage-panel summary {
  list-style: none;
  cursor: pointer;
  font-weight: 700;
  color: #ffffff;
  border: 1px solid rgba(255,255,255,.28);
  border-radius: 10px;
  padding: 10px 14px;
  background: rgba(255,255,255,.08);
}

.local-storage-panel summary::-webkit-details-marker {
  display: none;
}

.local-storage-panel[open] summary {
  background: rgba(255,255,255,.16);
}

.local-storage-menu {
  position: absolute;
  right: 0;
  top: calc(100% + 10px);
  width: min(430px, calc(100vw - 32px));
  padding: 14px;
  border-radius: 14px;
  background: rgba(8, 16, 40, .96);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 20px 40px rgba(0,0,0,.28);
  z-index: 120;
}

.local-storage-status {
  margin: 0 0 10px;
  font-size: .92rem;
  line-height: 1.45;
  color: #edf2ff;
}

.local-storage-status[data-tone="success"] { color: #c8f7d2; }
.local-storage-status[data-tone="warning"] { color: #ffe0a8; }
.local-storage-status[data-tone="muted"] { color: #edf2ff; }

.local-storage-actions {
  display: grid;
  gap: 8px;
}

.local-storage-actions button {
  width: 100%;
  justify-content: center;
}

.theme-dark .local-storage-panel summary {
  color: var(--heading);
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.05);
}

.theme-dark .local-storage-menu {
  background: rgba(12, 18, 32, .98);
}

body.topbar-collapsed {
  --topbar-current-height: var(--topbar-height-collapsed);
}

body.topbar-collapsed .topbar {
  padding-block: 6px;
}

body.topbar-collapsed .logo {
  width: 66px;
}

body.topbar-collapsed h1 {
  font-size: 1.2rem;
  margin: 0;
}

body.topbar-collapsed .eyebrow,
body.topbar-collapsed .subtitle,
body.topbar-collapsed .mode-indicator,
body.topbar-collapsed .legacy-calc-btn {
  opacity: 0;
  max-height: 0;
  overflow: hidden;
  pointer-events: none;
  margin: 0;
}

.eyebrow,
.subtitle,
.mode-indicator {
  transition: opacity 0.2s ease, max-height 0.2s ease, margin 0.2s ease;
}
.switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  width: 46px;
  height: 26px;
}

.switch input {
  opacity: 0;
  width: 0;
  height: 0;
}

.slider {
  position: absolute;
  cursor: pointer;
  inset: 0;
  background: var(--card-alt);
  border: 1px solid var(--card-border-strong);
  border-radius: 999px;
  transition: background 0.2s ease, border-color 0.2s ease;
}

.slider::before {
  content: '';
  position: absolute;
  height: 20px;
  width: 20px;
  left: 3px;
  top: 2px;
  background: var(--card);
  border-radius: 50%;
  box-shadow: var(--shadow-soft);
  transition: transform 0.2s ease, background 0.2s ease;
}

.switch input:checked + .slider {
  background: var(--accent);
  border-color: transparent;
}

.switch input:checked + .slider::before {
  transform: translateX(20px);
  background: var(--accent-contrast);
}

button {
  border: 1px solid transparent;
  padding: 12px 20px;
  border-radius: 12px;
  cursor: pointer;
  font-weight: 700;
  transition: box-shadow 0.2s ease, background 0.2s ease, border-color 0.2s ease,
    color 0.2s ease;
}

button.primary {
  background: var(--accent);
  color: var(--accent-contrast);
  border-color: transparent;
  box-shadow: var(--button-shadow);
}

button.ghost {
  background: var(--ghost-bg);
  border: 1px solid var(--ghost-border);
  color: var(--text);
}

button:hover {
  box-shadow: var(--shadow-hover);
}

button.primary:hover {
  background: var(--accent-hover);
}

button.ghost:hover {
  border-color: var(--accent);
  color: var(--heading);
}


.card-header.card-header--dense {
  display: grid;
  justify-content: stretch;
  align-items: start;
  gap: 6px;
}

.card-header.card-header--dense > * {
  margin: 0;
}

.card-header.card-header--dense h2,
.card-header.card-header--dense h3 {
  font-size: clamp(1.06rem, 0.98rem + 0.45vw, 1.22rem);
  line-height: 1.18;
}

.card-kicker {
  margin: 0;
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--accent-hover);
}

.card-subtitle {
  color: var(--muted);
}

.experience-card,
.product-summary-card {
  border-color: color-mix(in srgb, var(--accent) 20%, var(--card-border));
  box-shadow: 0 10px 24px rgba(39, 23, 27, 0.08);
}

.experience-card--result,
.product-summary-card {
  background: color-mix(in srgb, var(--card-bg) 84%, var(--accent-soft) 16%);
}

.action-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.action-bar--summary {
  padding-top: 6px;
  border-top: 1px solid var(--divider);
}

button.action-export,
button.action-import,
button.action-support,
button.action-danger {
  border-color: var(--ghost-border);
}

button.action-export {
  background: color-mix(in srgb, var(--ghost-bg) 72%, var(--accent-soft) 28%);
}

button.action-import {
  background: color-mix(in srgb, var(--ghost-bg) 80%, var(--card-bg) 20%);
}

button.action-support {
  background: color-mix(in srgb, var(--ghost-bg) 86%, transparent);
}

button.action-danger {
  background: color-mix(in srgb, var(--ghost-bg) 78%, var(--error-bg) 22%);
  border-color: color-mix(in srgb, var(--error-border) 58%, var(--ghost-border) 42%);
}

button.action-danger:hover {
  border-color: color-mix(in srgb, var(--error-border) 72%, var(--accent) 28%);
  color: var(--heading);
}

button.action-main {
  position: relative;
}

button.action-main::after {
  content: 'Principal';
  display: inline-flex;
  align-items: center;
  margin-left: 8px;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  background: rgba(255,255,255,0.24);
  color: inherit;
}

.theme-dark button.action-main::after {
  background: rgba(0,0,0,0.18);
}

.floating-next {
  position: fixed;
  right: max(24px, env(safe-area-inset-right));
  bottom: max(24px, env(safe-area-inset-bottom));
  z-index: 999;
  border-radius: 999px;
  padding: 14px 20px;
  min-width: 128px;
  background: color-mix(in srgb, var(--card) 55%, var(--accent) 45%);
  color: var(--heading);
  border: 1px solid var(--card-border-strong);
  box-shadow: var(--shadow-hover);
  backdrop-filter: blur(var(--card-blur));
  -webkit-backdrop-filter: blur(var(--card-blur));
}

.floating-next:hover {
  background: color-mix(in srgb, var(--card) 40%, var(--accent) 60%);
}

.floating-next:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}


.content {
  min-width: 0;
  margin-left: var(--sidebar-expanded-width);
}

.app.sidebar-collapsed .content {
  margin-left: var(--sidebar-collapsed-width);
}

.grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.column {
  display: flex;
  flex-direction: column;
  gap: 24px;
}


#tributos-minimo-form {
  display: grid;
  gap: 24px;
}

.card {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 20px;
  padding: 20px;
  box-shadow: var(--card-shadow);
  backdrop-filter: blur(var(--card-blur));
  -webkit-backdrop-filter: blur(var(--card-blur));
}

@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .card,
  .app-header {
    background: var(--card-bg);
  }
}

.collapsible-card {
  padding: 0;
}

.collapsible-card[open] {
  padding-bottom: 20px;
}

.collapsible-card .card-body {
  padding: 16px 20px 0;
}

.collapsible-summary {
  list-style: none;
  padding: 18px 20px;
  font-weight: 700;
  color: var(--heading);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 12px;
  border-radius: 16px;
  transition: background 0.2s ease;
}

.summary-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  color: var(--heading);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.summary-icon svg {
  width: 100%;
  height: 100%;
}

.collapsible-summary::-webkit-details-marker {
  display: none;
}

.collapsible-card[open] .collapsible-summary {
  border-bottom: 1px solid var(--card-border);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
  background: var(--card-alt);
}

.summary-open {
  display: none;
}

.collapsible-card[open] .summary-open {
  display: inline;
}

.collapsible-card[open] .summary-closed {
  display: none;
}

.card-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
}

.card-header h2 {
  font-size: 1.4rem;
  color: var(--heading);
}

.card-header p {
  color: var(--muted);
}

.card-helper {
  color: var(--muted);
}

.card-body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.field-group {
  display: grid;
  gap: 12px;
}

label {
  font-weight: 700;
  color: var(--muted);
}

input,
select,
textarea {
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

input,
select {
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 10px;
}

textarea {
  background: var(--input-bg);
  border: 1px solid var(--input-border);
  color: var(--text);
  padding: 10px 12px;
  border-radius: 10px;
  resize: vertical;
}

input::placeholder,
textarea::placeholder {
  color: var(--input-placeholder);
}

input:hover,
select:hover,
textarea:hover {
  border-color: color-mix(in srgb, var(--input-border) 72%, #fff 28%);
}

input:focus,
select:focus {
  outline: 2px solid transparent;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

textarea:focus {
  outline: 2px solid transparent;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

small {
  color: var(--muted);
}

.readonly {
  display: grid;
  gap: 12px;
}

.readonly-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--card-alt);
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px dashed var(--divider-strong);
}

.result-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.result-highlight {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 16px;
  border-radius: 14px;
  background: var(--accent-soft);
  border: 1px solid var(--accent-soft-border);
}

.label {
  color: var(--muted);
  font-size: 0.9rem;
}

.value {
  font-size: 1.2rem;
  font-weight: 700;
  margin-top: 4px;
}

.alertas {
  display: grid;
  gap: 8px;
}

.alert {
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--warning-bg);
  border: 1px solid var(--warning-border);
  color: var(--heading);
}

.inpc-status {
  margin: 8px 0 0;
  font-size: 0.9rem;
  color: var(--muted);
}

.readout {
  white-space: pre-wrap;
  background: var(--card-alt);
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--card-border);
  min-height: 120px;
}

.readout.is-scrollable {
  max-height: 320px;
  overflow: auto;
}

.actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.checkbox-list {
  display: grid;
  gap: 8px;
}

.checkbox-list--choices {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}

.table-wrapper {
  overflow-x: auto;
}

.preview-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.preview-table th,
.preview-table td {
  padding: 6px 8px;
  border-bottom: 1px solid var(--divider);
  text-align: left;
  white-space: nowrap;
}

.preview-table th {
  color: var(--muted);
  font-weight: 700;
  background: var(--card-alt);
}

.contrib-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.95rem;
}

.contrib-table th,
.contrib-table td {
  padding: 8px 10px;
  border-bottom: 1px solid var(--divider);
  text-align: left;
}

.contrib-table th {
  color: var(--muted);
  font-weight: 700;
  background: var(--card-alt);
}

.contrib-table input,
.contrib-table select {
  width: 100%;
  min-width: 120px;
}

.contrib-table .table-actions {
  display: flex;
  justify-content: flex-end;
}

.totals-list {
  display: grid;
  gap: 6px;
  font-weight: 700;
}

.is-hidden {
  display: none !important;
}

.is-hidden-by-mode-guard {
  display: none !important;
}

body[data-calculator-mode="vaeba"] #beneficios-module :is(.card, details, .field, .field-group, .actions, .checkbox, p):has([id^="rmi-"]),
body[data-calculator-mode="cota"] #beneficios-module :is(.card, details, .field, .field-group, .actions, .checkbox, p):has([id^="rmi-"]) {
  display: none !important;
}

.pdf-options {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
  color: var(--muted);
  font-size: 0.95rem;
}

.pdf-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  max-width: 100%;
  min-height: 42px;
  padding: 9px 14px 9px 42px;
  border-radius: 12px;
  border: 1px solid var(--ghost-border);
  background: color-mix(in srgb, var(--ghost-bg) 82%, var(--accent-soft) 18%);
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.2;
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
}

.pdf-toggle:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--ghost-border) 60%);
  color: var(--heading);
}

.pdf-toggle:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.pdf-toggle input[type="checkbox"] {
  position: absolute;
  top: 50%;
  left: 14px;
  width: 18px;
  height: 18px;
  margin: 0;
  transform: translateY(-50%);
  accent-color: var(--accent);
}

.pdf-toggle > span {
  display: inline-block;
  min-width: 0;
  overflow-wrap: anywhere;
}

.pdf-toggle:has(input[type="checkbox"]:checked) {
  border-color: color-mix(in srgb, var(--accent) 58%, var(--ghost-border) 42%);
  background: color-mix(in srgb, var(--accent-soft) 30%, var(--ghost-bg) 70%);
}

.vaeba-ocr-control {
  margin-top: 10px;
  width: min(100%, 460px);
  display: grid;
  gap: 8px;
}

.vaeba-ocr-checkbox {
  position: absolute;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  overflow: hidden;
  border: 0;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

.vaeba-ocr-button {
  width: 100%;
  min-height: 42px;
  border-radius: 12px;
  border: 1px solid var(--ghost-border);
  background: color-mix(in srgb, var(--ghost-bg) 86%, var(--card-bg) 14%);
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.2;
  text-align: left;
  padding: 11px 14px;
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, color 0.18s ease;
}

.vaeba-ocr-button:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--ghost-border) 60%);
  color: var(--heading);
}

.vaeba-ocr-button:focus-visible {
  outline: none;
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.vaeba-ocr-button.is-active {
  border-color: color-mix(in srgb, var(--accent) 58%, var(--ghost-border) 42%);
  background: color-mix(in srgb, var(--accent-soft) 30%, var(--ghost-bg) 70%);
}

.vaeba-ocr-button::after {
  content: 'Desligado';
  float: right;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 600;
}

.vaeba-ocr-button.is-active::after {
  content: 'Ligado';
  color: var(--heading);
}

.vaeba-ocr-help {
  color: var(--muted);
  line-height: 1.35;
}


body.v-loader-active #app-container {
  filter: blur(3px);
  pointer-events: none;
  user-select: none;
  transition: filter 0.2s ease;
}

.v-loader-overlay {
  position: fixed;
  inset: 0;
  z-index: 2400;
  display: grid;
  place-items: center;
  padding: 24px;
  background: color-mix(in srgb, var(--card-bg) 40%, rgba(10, 10, 14, 0.28));
  backdrop-filter: blur(7px);
  -webkit-backdrop-filter: blur(7px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.24s ease;
}

.v-loader-overlay.is-visible,
.v-loader-overlay.is-exiting {
  pointer-events: all;
}

.v-loader-overlay.is-visible {
  opacity: 1;
}

.v-loader-overlay.is-exiting {
  opacity: 0;
}

.v-loader-content {
  width: min(92vw, 380px);
  padding: clamp(10px, 2vw, 18px) clamp(10px, 2vw, 16px);
  display: grid;
  justify-items: center;
  gap: 14px;
}

.v-loader-wrap {
  width: clamp(132px, 23vw, 200px);
  aspect-ratio: 1;
  display: grid;
  place-items: center;
}

.v-loader-svg {
  width: 100%;
  height: 100%;
  overflow: visible;
  filter: drop-shadow(0 10px 24px rgba(58, 39, 0, 0.14));
}

.v-loader-left {
  transform-origin: 50% 50%;
  animation: vLoaderLeftDraw 2.4s cubic-bezier(.65,0,.35,1) infinite;
}

.v-loader-right {
  transform-origin: 50% 50%;
  animation: vLoaderRightDraw 2.4s cubic-bezier(.65,0,.35,1) infinite;
}

.v-loader-whole {
  animation: vLoaderGlow 2.4s ease-in-out infinite;
}

.v-loader-shine {
  opacity: 0;
  mix-blend-mode: screen;
  animation: vLoaderShine 2.4s ease-in-out infinite;
}

.v-loader-text {
  text-align: center;
  font-size: clamp(0.9rem, 2vw, 1rem);
  line-height: 1.45;
  color: var(--text);
  letter-spacing: 0.01em;
}

@keyframes vLoaderLeftDraw {
  0%, 6% { transform: translateY(-20px) scaleY(0); opacity: .08; }
  30%, 74% { transform: translateY(0) scaleY(1); opacity: 1; }
  100% { transform: translateY(0) scaleY(1); opacity: 1; }
}

@keyframes vLoaderRightDraw {
  0%, 34% { transform: translateY(-20px) scaleY(0); opacity: .08; }
  60%, 74% { transform: translateY(0) scaleY(1); opacity: 1; }
  100% { transform: translateY(0) scaleY(1); opacity: 1; }
}

@keyframes vLoaderGlow {
  0%, 68% {
    filter: drop-shadow(0 0 0 rgba(255, 208, 0, 0)) drop-shadow(0 0 0 rgba(229, 175, 23, 0));
  }
  78% {
    filter: drop-shadow(0 0 10px rgba(255, 208, 0, 0.42)) drop-shadow(0 0 24px rgba(229, 175, 23, 0.24));
  }
  84% {
    filter: drop-shadow(0 0 15px rgba(255, 208, 0, 0.5)) drop-shadow(0 0 32px rgba(229, 175, 23, 0.3));
  }
  90% {
    filter: drop-shadow(0 0 7px rgba(255, 208, 0, 0.2)) drop-shadow(0 0 16px rgba(229, 175, 23, 0.14));
  }
  100% {
    filter: drop-shadow(0 0 0 rgba(255, 208, 0, 0)) drop-shadow(0 0 0 rgba(229, 175, 23, 0));
  }
}

@keyframes vLoaderShine {
  0%, 70% { opacity: 0; transform: translateX(-240px); }
  79% { opacity: .95; }
  88% { opacity: 0; transform: translateX(240px); }
  100% { opacity: 0; transform: translateX(240px); }
}

@media (prefers-reduced-motion: reduce) {
  .v-loader-left,
  .v-loader-right,
  .v-loader-whole,
  .v-loader-shine {
    animation-duration: 0.01ms;
    animation-iteration-count: 1;
  }
}

.checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.checkbox input {
  accent-color: var(--accent);
  flex: 0 0 auto;
}

.checkbox--choice {
  width: 100%;
  min-height: 44px;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid color-mix(in srgb, var(--card-border) 78%, var(--accent-soft-border) 22%);
  border-radius: 14px;
  background: color-mix(in srgb, var(--card-bg) 88%, var(--accent-soft) 12%);
  cursor: pointer;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.checkbox--choice:hover {
  border-color: color-mix(in srgb, var(--accent-soft-border) 62%, var(--accent) 38%);
  background: color-mix(in srgb, var(--card-bg) 78%, var(--accent-soft) 22%);
}

.checkbox--choice:focus-within {
  border-color: var(--focus);
  box-shadow: 0 0 0 3px var(--focus-ring);
}

.checkbox--choice input {
  appearance: none;
  -webkit-appearance: none;
  display: block;
  align-self: flex-start;
  flex: 0 0 16px;
  width: 16px;
  min-width: 16px;
  max-width: 16px;
  height: 16px;
  min-height: 16px;
  max-height: 16px;
  padding: 0;
  margin-top: 2px;
  border-radius: 5px;
  border: 1.5px solid color-mix(in srgb, var(--muted) 72%, transparent);
  background: color-mix(in srgb, var(--input-bg) 92%, transparent);
  display: inline-grid;
  place-items: center;
  transition: border-color 0.18s ease, background 0.18s ease, box-shadow 0.18s ease, transform 0.18s ease;
}

.checkbox--choice input::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 2px;
  background: var(--accent-contrast);
  transform: scale(0);
  transition: transform 0.16s ease;
}

.checkbox--choice input:checked {
  border-color: var(--accent);
  background: var(--accent);
}

.checkbox--choice input:checked::after {
  transform: scale(1);
}

.checkbox--choice span {
  display: block;
  min-width: 0;
  color: var(--text);
  font-weight: 600;
  line-height: 1.35;
}

.theme-dark .checkbox--choice {
  background: color-mix(in srgb, var(--card-alt) 86%, transparent);
}

.theme-dark .checkbox--choice input {
  border-color: color-mix(in srgb, var(--dm-muted) 66%, transparent);
  background: color-mix(in srgb, var(--dm-surface) 84%, transparent);
}

.theme-dark .checkbox--choice input::after {
  background: var(--accent-contrast);
}

.pdf-warning {
  color: var(--heading);
  font-weight: 700;
}

.tests-list {
  list-style: none;
  display: grid;
  gap: 8px;
}

.test-item {
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--card-border);
  background: var(--success-bg);
}

.test-item.fail {
  background: var(--error-bg);
  border-color: var(--error-border);
}

@media (max-width: 960px) {
  .app {
    padding-inline: 16px;
  }

  .left-sidebar,
  .app.sidebar-collapsed .left-sidebar {
    position: static;
    width: 100%;
    height: auto;
    min-height: 0;
  }

  .content,
  .app.sidebar-collapsed .content {
    margin-left: 0;
  }

  .grid {
    grid-template-columns: 1fr;
  }

  .header-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .floating-next {
    right: max(16px, env(safe-area-inset-right));
    bottom: max(16px, env(safe-area-inset-bottom));
    padding: 12px 16px;
  }
}

@media (max-width: 1100px) {
  .left-sidebar {
    padding-inline: 8px;
  }

  .left-sidebar .sidebar-item,
  .left-sidebar .sidebar-toggle {
    justify-content: center;
    padding-inline: 8px;
  }

  .left-sidebar .sidebar-label {
    opacity: 0;
    width: 0;
    overflow: hidden;
  }
}

.ficha-summary { display: grid; gap: 0.4rem; margin-bottom: 0.8rem; }
.ficha-import-note { margin: 0; font-size: 0.8rem; color: var(--muted); }
.ficha-years-container { display: grid; gap: 1rem; }
.ficha-year-block { border: 1px solid var(--line); border-radius: 12px; padding: 0.8rem; display: grid; gap: 0.8rem; }
.ficha-year-header { display: flex; align-items: center; gap: 0.8rem; flex-wrap: wrap; }
.ficha-row { border: 1px dashed var(--line); border-radius: 10px; padding: 0.7rem; display: grid; gap: 0.6rem; }
.ficha-row-top { display: grid; grid-template-columns: 2fr 1fr auto; gap: 0.6rem; }
.ficha-preview-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 0.45rem; }
.ficha-preview-grid label { display: grid; gap: 0.25rem; font-size: 0.78rem; }
.ficha-status { margin: 0; font-size: 0.85rem; }
.ficha-status.is-valid { color: #188038; }
.ficha-status.is-error { color: #b42318; }

#tributos-pdf-warning {
  display: none;
  margin: 4px 0 12px;
}


.hint {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
}

.fred-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 24px;
  align-items: start;
  justify-items: stretch;
  width: 100%;
  min-width: 0;
  max-width: none;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.fred-left,
.summary-column-stack {
  display: flex;
  flex-direction: column;
  gap: 16px;
  width: 100%;
  min-width: 0;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.fred-right {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
}

.fred-left .card,
.fred-right .card,
.summary-column-stack .card {
  width: 100%;
}

.tributos-grid > .column,
.tributos-summary-column,
.bitributacao-layout,
.bitributacao-layout > .card,
.bitributacao-entry-card,
.bitributacao-entry-card-body,
.bitributacao-table-shell,
.bitributacao-table-wrapper,
.bitributacao-table,
.fred-card,
.fred-card .card-body {
  width: 100%;
  min-width: 0;
}

.fred-help {
  padding: 0;
}

.fred-help details {
  border-radius: 20px;
}

.fred-help-summary {
  list-style: none;
  cursor: pointer;
  padding: 16px 20px;
  font-weight: 700;
  color: var(--heading);
  display: flex;
  align-items: center;
  gap: 10px;
}

.fred-help-summary::-webkit-details-marker {
  display: none;
}

.fred-help-summary::before {
  content: '▸';
  color: var(--muted);
  transition: transform 0.2s ease;
}

.fred-help details[open] .fred-help-summary {
  border-bottom: 1px solid var(--card-border);
  background: var(--card-alt);
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}

.fred-help details[open] .fred-help-summary::before {
  transform: rotate(90deg);
}

.fred-help-body {
  padding: 12px 16px 16px;
  display: grid;
  gap: 12px;
}

.fred-help-body h4,
.fred-help-body p,
.fred-help-body ul,
.fred-help-body ol {
  margin: 0;
}

.fred-help-body ul,
.fred-help-body ol {
  padding-left: 18px;
  display: grid;
  gap: 6px;
}

.fred-help-intro {
  color: var(--muted);
}

.fred-card .card-header {
  margin-bottom: 0;
}

.fred-card .card-header h3 {
  margin: 0;
  color: var(--heading);
}

.fred-card .card-body,
.fred-card .field,
.fred-card .actions,
.fred-card .checkbox {
  min-width: 0;
}

.fred-client-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 12px 16px;
}

@media (min-width: 760px) {
  .fred-client-grid {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}

.fred-full-width {
  grid-column: 1 / -1;
}

.fred-actions {
  flex-wrap: wrap;
}

#fred-exercicios {
  display: grid;
  gap: 12px;
}

.fred-exercicio {
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 14px;
  background: var(--card-alt);
  display: grid;
  gap: 12px;
}

.fred-exercicio-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.fred-exercicio-header h4 {
  margin: 0;
  color: var(--heading);
}

.exercise-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 12px 16px;
}

.import-feedback {
  display: grid;
  gap: 8px;
  padding: 12px;
  border-radius: 12px;
  border: 1px solid var(--card-border);
  background: var(--card-alt);
}

.import-feedback--success {
  border-color: color-mix(in srgb, var(--accent) 55%, var(--card-border));
}

.import-feedback--warning {
  border-color: var(--warning-border);
  background: color-mix(in srgb, var(--warning-bg) 45%, var(--card-bg));
}

.import-feedback--error {
  border-color: color-mix(in srgb, #d96464 45%, var(--card-border));
  background: color-mix(in srgb, #d96464 10%, var(--card-bg));
}

.import-feedback--neutral {
  background: color-mix(in srgb, var(--card-alt) 88%, transparent);
}

.import-feedback__header,
.import-feedback__meta {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.import-feedback__title {
  font-weight: 700;
  color: var(--heading);
}

.import-feedback__kind,
.import-origin-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--card-border);
  font-size: 12px;
  background: color-mix(in srgb, var(--card-bg) 90%, transparent);
}

.import-feedback__message {
  margin: 0;
}

.import-feedback__list {
  margin: 0;
  padding-left: 18px;
  display: grid;
  gap: 4px;
}

.import-feedback__warnings {
  display: grid;
  gap: 6px;
}

.import-preview {
  display: grid;
  gap: 8px;
}

.import-preview__title {
  font-weight: 700;
  color: var(--heading);
}

.import-preview__body {
  display: grid;
  gap: 8px;
}

.import-preview__empty {
  margin: 0;
  color: color-mix(in srgb, var(--text) 80%, transparent);
}

.field-origin {
  border-style: solid;
}

.fred-exercicio .imported,
.field-origin.imported {
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--accent-soft-border);
}

.fred-import-found {
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: 0.7rem;
  background: var(--card-alt);
  font-size: 0.88rem;
  display: grid;
  gap: 0.35rem;
}

.fred-import-found p {
  margin: 0;
}

.fred-import-warnings {
  display: grid;
  gap: 0.45rem;
}

.import-review-grid {
  display: grid;
  gap: 0.85rem;
}

.import-review-columns {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
}

.import-review-section {
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 0.8rem 0.9rem;
  background: color-mix(in srgb, var(--card-alt) 76%, var(--card-bg) 24%);
  display: grid;
  gap: 0.45rem;
}

.import-review-section h4,
.import-review-summary h4 {
  margin: 0;
  font-size: 0.92rem;
  color: var(--heading);
}

.import-review-section--success { border-color: color-mix(in srgb, #2f9e44 30%, var(--card-border)); }
.import-review-section--warning { border-color: color-mix(in srgb, #f08c00 35%, var(--card-border)); }
.import-review-section--muted { border-style: dashed; }

.import-review-summary {
  border: 1px dashed var(--card-border);
  border-radius: 12px;
  padding: 0.8rem 0.9rem;
  display: grid;
  gap: 0.45rem;
}

.import-review-section ul,
.import-review-summary ul {
  margin: 0;
  padding-left: 1rem;
  display: grid;
  gap: 0.28rem;
}

.import-review-table-note {
  margin: 0;
  font-size: 0.8rem;
  color: color-mix(in srgb, var(--text) 80%, transparent);
}

.modal-import-preview,
.modal-import-details {
  margin-top: 0.85rem;
}

.rmi-import-overview {
  margin-top: 1rem;
  border: 1px solid var(--card-border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card-bg) 92%, transparent);
}

.rmi-import-overview[open] {
  background: color-mix(in srgb, var(--card-alt) 84%, var(--card-bg) 16%);
}

.rmi-import-overview__summary {
  cursor: pointer;
  list-style: none;
  padding: 14px 16px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.rmi-import-overview__summary::-webkit-details-marker {
  display: none;
}

.rmi-import-overview__summary::after {
  content: 'Exibir';
  flex: 0 0 auto;
  align-self: center;
  padding: 4px 10px;
  border-radius: 999px;
  border: 1px solid var(--accent-soft-border);
  background: var(--accent-soft);
  color: var(--heading);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.rmi-import-overview[open] .rmi-import-overview__summary {
  border-bottom: 1px solid var(--card-border);
}

.rmi-import-overview[open] .rmi-import-overview__summary::after {
  content: 'Ocultar';
}

.rmi-import-overview__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.75rem;
  padding: 0.85rem 1rem 1rem;
}

.rmi-import-slot {
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 0.85rem 0.9rem;
  background: var(--card-alt);
  display: grid;
  gap: 0.45rem;
}

.rmi-import-slot__top {
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
  align-items: flex-start;
}

.rmi-import-slot__title {
  margin: 0;
  font-size: 0.92rem;
  color: var(--heading);
}

.rmi-import-slot__meta,
.rmi-import-slot__note {
  margin: 0;
  font-size: 0.82rem;
  color: color-mix(in srgb, var(--text) 80%, transparent);
}

.rmi-import-slot__badge {
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  border: 1px solid var(--card-border);
  white-space: nowrap;
}

.rmi-import-slot[data-state="ready"] .rmi-import-slot__badge {
  border-color: color-mix(in srgb, #2f9e44 45%, var(--card-border));
  color: #2f9e44;
}

.rmi-import-slot[data-state="review"] .rmi-import-slot__badge {
  border-color: color-mix(in srgb, #f08c00 45%, var(--card-border));
  color: #c56a00;
}

.rmi-import-slot[data-state="empty"] .rmi-import-slot__badge {
  color: color-mix(in srgb, var(--text) 70%, transparent);
}

.rmi-import-slot__list {
  margin: 0;
  padding-left: 1rem;
  display: grid;
  gap: 0.24rem;
  font-size: 0.82rem;
}

.fred-auditoria-item {
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: 0.6rem;
  margin-bottom: 0.5rem;
  font-size: 0.9rem;
}

.fred-audit-warning {
  color: #b42318;
  font-weight: 600;
}

@media (max-width: 980px) {
  .fred-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .exercise-grid {
    grid-template-columns: 1fr;
  }
}

.fred-exercicios-resumo {
  border: 1px solid var(--card-border);
  border-radius: 10px;
  padding: 0.7rem;
  background: var(--card-alt);
  display: grid;
  gap: 0.35rem;
  font-size: 0.9rem;
}

.fred-status-badge {
  border-radius: 999px;
  padding: 0.2rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 700;
  border: 1px solid var(--card-border);
}

.fred-inline-message {
  font-size: 0.85rem;
  border-radius: 8px;
  padding: 0.4rem 0.6rem;
  background: color-mix(in srgb, var(--card-alt) 75%, #f59e0b 25%);
}

.fred-status-ok .fred-status-badge {
  background: #dcfce7;
  color: #166534;
}

.fred-status-warn .fred-status-badge {
  background: #fef3c7;
  color: #92400e;
}

.fred-status-blocked .fred-status-badge,
.fred-status-incomplete .fred-status-badge {
  background: #fee2e2;
  color: #991b1b;
}

.fred-quick-entry {
  border: 1px solid var(--card-border);
  border-radius: 10px;
  background: var(--card-alt);
  margin-bottom: 12px;
}

.fred-quick-entry > summary,
.fred-help-chatgpt > summary,
.fred-advanced-options > summary {
  cursor: pointer;
  font-weight: 600;
  padding: 0.7rem 0.85rem;
}

.fred-quick-entry-body,
.fred-help-chatgpt-body {
  padding: 0.8rem;
  display: grid;
  gap: 0.7rem;
}

.fred-monospace {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, 'Liberation Mono', 'Courier New', monospace;
}

.fred-inline-feedback {
  min-height: 1.2em;
}

.fred-inline-feedback.is-error {
  color: #b42318;
}

.fred-inline-feedback.is-success {
  color: #166534;
}

.fred-help-chatgpt {
  border: 1px solid var(--card-border);
  border-radius: 10px;
  background: var(--card-alt);
}

.fred-advanced-options {
  border: 1px dashed var(--card-border);
  border-radius: 10px;
  padding: 0.2rem 0.5rem 0.6rem;
}

:root {
  --topbar-height: 76px;
  --topbar-current-height: var(--topbar-height);
  --wine-base: #5c1f31;
  --wine-dark: #421423;
  --gold-accent: #d5b26a;
  --accent-soft: rgba(213, 178, 106, 0.16);
  --card-bg: rgba(255, 251, 246, 0.88);
  --card-border: rgba(92, 31, 49, 0.14);
  --card-shadow: 0 8px 20px rgba(48, 24, 34, 0.12);
}

.theme-dark {
  --card-bg: var(--dm-card);
  --card-border: var(--dm-border);
}

.topbar {
  height: var(--topbar-height);
  min-height: var(--topbar-height);
  background: color-mix(in srgb, var(--wine-base) 92%, #fff 8%);
  border-bottom: 1px solid rgba(255, 255, 255, 0.15);
  box-shadow: none;
  backdrop-filter: none;
}

.theme-dark .topbar { background: color-mix(in srgb, var(--dm-bg) 86%, var(--dm-bg2) 14%); }
.header-brand .subtitle { display: none; }
.logo { width: 64px; }
h1 { font-size: 1.2rem; margin: 0; color: #fff; }
.eyebrow, .mode-indicator, .theme-toggle { color: #f5e5c3; }
.mode-indicator { margin: 0; background: rgba(0,0,0,.18); border: 1px solid rgba(255,255,255,.16); padding: 4px 10px; border-radius: 999px; }

.mobile-menu-btn,.sidebar-close { display:none; }

.left-sidebar {
  background: color-mix(in srgb, var(--wine-base) 88%, #fff 12%);
  border-right-color: rgba(255,255,255,.18);
  backdrop-filter: none;
}
.theme-dark .left-sidebar {
  background: color-mix(in srgb, var(--dm-bg) 92%, var(--dm-bg2) 8%);
  border-right-color: var(--dm-border);
}
.left-sidebar .sidebar-steps { display: grid; gap: 8px; margin-top: 10px; }
.sidebar-steps-header { min-height: 28px; display: flex; align-items: center; padding-inline: 12px; }
.left-sidebar .sidebar-steps p { color: #f6e8ca; font-weight: 700; font-size: .9rem; margin: 0; }
.theme-dark .left-sidebar .sidebar-steps p { color: var(--dm-muted); }
.sidebar-steps-list { display: grid; gap: 8px; }
.sidebar-aux {
  margin-top: auto;
  padding-top: 10px;
  border-top: 1px solid rgba(255,255,255,.12);
}
.sidebar-help-btn {
  width: 100%;
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 11px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.14);
  color: #fff;
}
.sidebar-help-btn:hover,
.sidebar-help-btn:focus-visible,
.sidebar-help-btn.active {
  background: var(--accent-soft);
  border-color: rgba(213,178,106,.45);
}
.theme-dark .sidebar-help-btn {
  color: var(--dm-text);
  border-color: rgba(255,255,255,.12);
  background: color-mix(in srgb, var(--dm-card) 80%, transparent);
}
.sidebar-help-icon {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #f6e8ca;
  font-weight: 700;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.18);
  font-size: .95rem;
}
.theme-dark .sidebar-help-icon {
  color: var(--dm-accent);
}
.sidebar-help-label {
  white-space: nowrap;
}
.sidebar-calculation {
  width: 100%;
  text-align: left;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 11px;
  border: 1px solid transparent;
  background: transparent;
  color: #fff;
}
.theme-dark .sidebar-calculation {
  color: var(--dm-muted);
  border-color: rgba(255, 255, 255, 0.09);
  background: color-mix(in srgb, var(--dm-card) 75%, transparent);
}
.sidebar-calculation:hover,
.sidebar-calculation:focus-visible,
.sidebar-calculation.is-icon-only:hover,
.sidebar-calculation.is-icon-only:focus-visible {
  background: var(--accent-soft);
  border-color: rgba(213,178,106,.36);
}
.sidebar-calculation.active {
  background: var(--accent-soft);
  border-color: rgba(213,178,106,.55);
  box-shadow: inset 0 0 0 1px rgba(213,178,106,.22);
}
.theme-dark .sidebar-calculation.active {
  color: var(--dm-text);
  border-color: rgba(214, 176, 107, 0.42);
}
.sidebar-calculation-badge {
  width: 28px;
  height: 28px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #f6e8ca;
  font-weight: 700;
  border: 1px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.18);
  font-size: .72rem;
  letter-spacing: .02em;
}
.theme-dark .sidebar-calculation-badge {
  color: var(--dm-accent);
  border-color: rgba(255, 255, 255, 0.2);
  background: rgba(0, 0, 0, 0.2);
}
.sidebar-calculation-label { white-space: nowrap; }
.left-sidebar.collapsed {
  overflow: hidden;
}
.left-sidebar.collapsed .sidebar-nav,
.left-sidebar.collapsed .sidebar-steps,
.left-sidebar.collapsed .sidebar-steps-list {
  justify-items: center;
}
.left-sidebar.collapsed .sidebar-steps-header {
  display: none;
}
.left-sidebar.collapsed .sidebar-item,
.left-sidebar.collapsed .sidebar-calculation,
.left-sidebar.collapsed .sidebar-help-btn {
  width: 44px;
  min-height: 44px;
  justify-content: center;
  align-items: center;
  padding: 4px;
}
.left-sidebar.collapsed .sidebar-item {
  gap: 0;
}
.left-sidebar.collapsed .sidebar-item .sidebar-icon {
  margin: 0;
}
.left-sidebar.collapsed .sidebar-calculation-label {
  display: none;
}
.left-sidebar.collapsed .sidebar-help-label {
  display: none;
}
.left-sidebar.collapsed .sidebar-help-btn {
  margin-inline: auto;
}

body.is-guidelines .stepper,
body.is-guidelines .module-view {
  display: none;
}

.guidelines-screen {
  display: block;
  padding-bottom: 24px;
}

.guidelines-screen.is-hidden {
  display: none;
}

.guidelines-shell {
  display: grid;
  gap: 24px;
}

.guidelines-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--card) 78%, var(--accent-soft) 22%) 0%, color-mix(in srgb, var(--card) 70%, var(--bg-wine-soft) 30%) 100%);
  border-color: var(--card-border-strong);
}

.guidelines-kicker,
.guidelines-section-label {
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-hover);
}

.guidelines-hero h2 {
  font-size: clamp(2rem, 4vw, 2.6rem);
  color: var(--heading);
  margin: 8px 0 12px;
}

.guidelines-lead {
  max-width: 64ch;
  font-size: 1.02rem;
  color: var(--muted);
}

.guidelines-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 12px;
}

.guidelines-warning-card {
  border-color: var(--accent-soft-border);
  background: color-mix(in srgb, var(--card) 80%, var(--accent-soft) 20%);
}

.guidelines-warning-copy {
  display: grid;
  gap: 12px;
  line-height: 1.55;
}

.guidelines-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px;
}

.guidelines-card,
.guidelines-summary-card {
  display: grid;
  gap: 14px;
}

.guidelines-card-intro {
  background: color-mix(in srgb, var(--card) 82%, var(--bg-gold) 18%);
}

.guidelines-card h3 {
  font-size: 1.35rem;
  color: var(--heading);
}

.guidelines-list {
  display: grid;
  gap: 14px;
}

.guidelines-list div {
  display: grid;
  gap: 4px;
  padding-top: 12px;
  border-top: 1px solid var(--divider);
}

.guidelines-list div:first-child {
  padding-top: 0;
  border-top: 0;
}

.guidelines-list dt {
  font-weight: 700;
  color: var(--heading);
}

.guidelines-list dd {
  margin: 0;
  color: var(--muted);
  line-height: 1.5;
}

.guidelines-summary-card {
  background: color-mix(in srgb, var(--card) 86%, var(--bg-wine) 14%);
}

.beneficios-grid { grid-template-columns: minmax(0,1.65fr) minmax(320px, .9fr); align-items: start; }
.tributos-grid { grid-template-columns: minmax(0,1.65fr) minmax(320px, .9fr); align-items: start; }
.beneficios-grid.step-4-active {
  grid-template-columns: minmax(0, 1fr) 390px;
  gap: 24px;
  align-items: start;
}
.beneficios-grid.step-4-active .wizard-column {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-inline: 0;
  justify-self: stretch;
}
.beneficios-grid.step-4-active .summary-column {
  width: 390px;
  justify-self: end;
}
.beneficios-grid.beneficios-final-layout {
  grid-template-columns: minmax(0, 1fr);
  gap: 0;
}
.beneficios-grid.beneficios-final-layout .wizard-column {
  width: min(100%, 1200px);
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(6px, 1.6vw, 18px);
}
.beneficios-grid.beneficios-final-layout .wizard-column > .card,
.beneficios-grid.beneficios-final-layout .wizard-column > details.card {
  width: 100%;
}
.tributos-summary-column .card { animation: fadeStep .22s ease; }
.tributos-summary-column .summary-column-stack {
  min-width: 0;
}
.app-stepper { margin: 0 0 18px; }
.stepper { width: 100%; }
.stepper-scroll { overflow-x: auto; padding-bottom: 6px; }
.stepper-inner {
  position: relative;
  min-width: min(700px, 100%);
  width: 100%;
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 4px 14px;
}
.stepper-track {
  position: absolute;
  left: 4px;
  right: 4px;
  bottom: 2px;
  height: 1px;
  background: color-mix(in srgb, var(--text) 24%, transparent);
}
.theme-dark .stepper-track {
  background: rgba(255, 255, 255, 0.12);
}
.stepper-fill {
  display: block;
  height: 2px;
  margin-top: -0.5px;
  width: 0;
  max-width: 100%;
  background: linear-gradient(90deg, var(--dm-accent) 0%, #e5c790 100%);
  box-shadow: 0 0 8px rgba(214, 176, 107, 0.2);
  transition: width .3s ease;
}
.step-btn {
  position: relative;
  flex: 1 1 0;
  border: 0;
  background: transparent;
  color: #fff;
  font-weight: 500;
  padding: 6px 10px;
  border-radius: 0;
  white-space: nowrap;
  text-align: center;
  transition: color .2s ease, opacity .2s ease;
}
.step-btn:not(:last-child)::after {
  content: '';
  position: absolute;
  right: 0;
  top: 50%;
  width: 1px;
  height: 18px;
  transform: translateY(-50%);
  background: color-mix(in srgb, var(--text) 20%, transparent);
}
.step-btn.done { color: #fff; }
.step-btn.active { color: #fff; font-weight: 700; }
.theme-dark .step-btn { color: var(--dm-muted); }
.theme-dark .step-btn.done,
.theme-dark .step-btn.active { color: var(--dm-text); }
.step-btn:focus-visible { outline: 2px solid rgba(213,178,106,.75); outline-offset: 4px; }

.wizard-column > .card, .wizard-column > details.card { animation: fadeStep .22s ease; }
@keyframes fadeStep { from { opacity: .3; transform: translateY(4px);} to { opacity:1; transform: translateY(0);} }

.summary-column { position: sticky; top: calc(var(--topbar-height) + 16px); }
.calc-summary {
  display: grid;
  gap: 12px;
}
.calc-summary .card-body {
  display: grid;
  gap: 14px;
}
.calc-summary .summary-status {
  font-weight: 700;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--accent-soft-border);
  background: color-mix(in srgb, var(--card-alt) 78%, var(--accent-soft) 22%);
}
.summary-pendencias {
  display: grid;
  gap: 8px;
}
.summary-pendencias-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  list-style: none;
}
.summary-pendencias-toggle::-webkit-details-marker {
  display: none;
}
.summary-pendencias-toggle::before {
  content: '▸';
  flex: 0 0 auto;
  color: var(--text-dim);
  transition: transform 0.18s ease;
}
.summary-pendencias[open] .summary-pendencias-toggle::before {
  transform: rotate(90deg);
}
.summary-pendencias .summary-status {
  margin: 0;
  flex: 1;
}
.summary-checklist { display:grid; gap:8px; padding-left: 16px; }
.summary-checklist li {
  color: var(--text);
}
.summary-link { background: transparent; border: 0; padding:0; color: var(--link); text-decoration: underline; }
.summary-notice { display:none; padding:10px 12px; border:1px solid var(--warning-border); background: var(--warning-bg); border-radius: 12px; }
.summary-notice.is-visible { display:block; }
.summary-kpis {
  padding: 14px;
  border-radius: 16px;
  border: 1px solid var(--divider);
  background: color-mix(in srgb, var(--card-alt) 86%, transparent);
}

.calc-summary #bitributacao-results,
.calc-summary #fred-results {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.calc-summary #bitributacao-results .result-grid,
.calc-summary #fred-results .result-grid {
  min-width: 0;
}

.calc-summary #bitributacao-results .table-wrapper,
.calc-summary #fred-results .table-wrapper {
  max-width: 100%;
  padding-bottom: 2px;
}
.prompt-dropdown summary { cursor:pointer; font-weight: 700; }

.segmented { display:flex; border:1px solid var(--input-border); border-radius: 12px; overflow: hidden; }
.segment { border:0; border-right:1px solid var(--input-border); border-radius:0; background: var(--input-bg); flex:1; padding:10px; }
.segment:last-child { border-right: 0; }
.segment.active { background: var(--accent-soft); color: var(--heading); }
.theme-dark .segment { color: var(--dm-text); }
.theme-dark .segment:hover { background: color-mix(in srgb, var(--dm-surface) 88%, #fff 12%); }
.sr-only-select { position:absolute; width:1px; height:1px; opacity:0; pointer-events:none; }

@media (max-width: 960px) {
  .mobile-menu-btn { display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; background: rgba(255,255,255,.12); color:#fff; }
  .left-sidebar { position: fixed; left: 0; top: var(--topbar-height); height: calc(100vh - var(--topbar-height)); width: min(84vw, 320px); transform: translateX(-105%); transition: transform .24s ease; z-index: 80; border-right: 1px solid rgba(255,255,255,.18); }
  body.sidebar-drawer-open .left-sidebar { transform: translateX(0); }
  .sidebar-close { display:block; align-self:flex-end; background:transparent; color:#fff; border:1px solid rgba(255,255,255,.22); }
  .beneficios-grid { grid-template-columns: 1fr; }
  .beneficios-grid.step-4-active {
    grid-template-columns: 1fr;
    gap: 12px;
  }
  .beneficios-grid.step-4-active .wizard-column {
    max-width: 100%;
    margin: 0;
    padding-inline: 0;
  }
  .beneficios-grid.step-4-active .summary-column {
    width: auto;
  }
  .beneficios-grid.beneficios-final-layout {
    gap: 12px;
  }
  .beneficios-grid.beneficios-final-layout .wizard-column {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding-inline: 0;
  }
  .module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid .wizard-column,
  .beneficios-grid[data-beneficios-final-step="true"] .wizard-column {
    width: 100%;
    max-width: 100%;
    margin: 0;
    padding-inline: 0;
  }
  .tributos-grid { grid-template-columns: 1fr; }
  .stepper-inner { min-width: 760px; }
  .summary-column { position: fixed; left: 10px; right:10px; bottom: 10px; top: auto; z-index: 70; }
  .summary-column .card:not(.calc-summary) { display:none; }
  .calc-summary { max-height: 42vh; overflow: auto; }
  .homeActions,
  .guidelines-actions,
  .guidelines-hero {
    flex-direction: column;
    align-items: stretch;
  }
  .guidelines-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}

.btn-sm { padding: 6px 10px; font-size: 12px; }

.rmi-journey-card,
.rmi-mode-card,
.rmi-context-card {
  border-color: color-mix(in srgb, var(--accent) 18%, var(--card-border));
}

.rmi-journey-card {
  background: color-mix(in srgb, var(--card-bg) 84%, var(--accent-soft) 16%);
}

.rmi-journey-header {
  align-items: flex-start;
}

.rmi-section-kicker {
  margin: 0 0 6px;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent-hover);
}

.rmi-journey-body {
  gap: 18px;
}

.rmi-journey-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(280px, 0.95fr);
  gap: 16px;
}

.rmi-journey-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-bg) 90%, transparent);
}

.rmi-journey-panel--primary {
  background: color-mix(in srgb, var(--card-bg) 76%, var(--accent-soft) 24%);
  border-color: color-mix(in srgb, var(--accent) 26%, var(--card-border));
}

.field-prominent label {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.field-prominent select {
  min-height: 48px;
  font-weight: 700;
}

.rmi-inline-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 8px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent) 18%, transparent);
  border: 1px solid color-mix(in srgb, var(--accent) 32%, var(--card-border));
  color: var(--heading);
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1;
}

.rmi-inline-badge--soft {
  background: var(--card-alt);
  border-color: var(--card-border);
}

.rmi-mode-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.rmi-mode-option {
  width: 100%;
  text-align: left;
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 16px;
  border: 1px solid var(--card-border);
  background: color-mix(in srgb, var(--card-bg) 86%, transparent);
  color: var(--text);
  box-shadow: none;
}

.rmi-mode-option:hover {
  transform: translateY(-1px);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--card-border));
}

.rmi-mode-option.is-active {
  background: color-mix(in srgb, var(--accent-soft) 55%, var(--card-bg) 45%);
  border-color: color-mix(in srgb, var(--accent) 55%, var(--card-border));
  box-shadow: var(--shadow-soft);
}

.rmi-mode-option__eyebrow,
.rmi-panel-title {
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
  font-weight: 700;
}

.rmi-quick-steps {
  display: grid;
  gap: 10px;
}

.rmi-quick-step {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--card-alt);
  border: 1px solid transparent;
}

.rmi-quick-step strong {
  color: var(--heading);
}

.rmi-quick-step.is-active {
  border-color: color-mix(in srgb, var(--accent) 40%, var(--card-border));
  background: color-mix(in srgb, var(--accent-soft) 42%, var(--card-bg) 58%);
}

.rmi-journey-note,
.rmi-import-hub,
.rmi-assist-strip {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid var(--card-border);
  background: var(--card-alt);
}

.rmi-journey-actions .primary {
  min-width: 220px;
}

.rmi-context-grid,
.rmi-essential-grid {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.rmi-auto-readonly {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.rmi-auto-readonly .readonly-row {
  gap: 10px;
}

.rmi-auto-readonly .readonly-row span {
  min-width: 0;
  flex: 1;
  color: var(--muted);
  font-weight: 700;
}

.rmi-auto-readonly .readonly-row input {
  width: min(180px, 100%);
  flex: 1;
  background: transparent;
  border-style: dashed;
}

.rmi-subsection {
  border: 1px solid var(--card-border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card-bg) 90%, transparent);
}

.rmi-subsection[open] {
  background: color-mix(in srgb, var(--card-alt) 82%, var(--card-bg) 18%);
}

.rmi-subsection > summary {
  cursor: pointer;
  list-style: none;
  padding: 14px 16px;
  font-weight: 700;
  color: var(--heading);
}

.rmi-subsection > summary::-webkit-details-marker {
  display: none;
}

.rmi-subsection > summary::after {
  content: '＋';
  float: right;
  color: var(--muted);
}

.rmi-subsection[open] > summary::after {
  content: '−';
}

.rmi-subsection > :not(summary) {
  padding: 0 16px 16px;
}

.rmi-subsection-actions {
  margin-bottom: 8px;
}

.rmi-subsection--advanced {
  opacity: 0.96;
}

.rmi-mode-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--accent-soft) 52%, var(--card-bg) 48%);
  border: 1px solid color-mix(in srgb, var(--accent) 32%, var(--card-border));
  color: var(--heading);
  font-size: 0.76rem;
  font-weight: 700;
  text-align: center;
}

.rmi-mode-card--fat90 {
  background: color-mix(in srgb, var(--card-bg) 88%, rgba(106, 42, 58, 0.08) 12%);
}

.rmi-mode-card--complete {
  background: color-mix(in srgb, var(--card-bg) 88%, rgba(195, 160, 91, 0.08) 12%);
}

.rmi-mode-card.is-active-mode {
  border-color: color-mix(in srgb, var(--accent) 42%, var(--card-border));
  box-shadow: var(--shadow);
}

@media (max-width: 960px) {
  .rmi-journey-grid,
  .rmi-mode-options {
    grid-template-columns: 1fr;
  }

  .rmi-mode-tag {
    width: 100%;
  }
}

@media (max-width: 720px) {
  .rmi-journey-panel,
  .rmi-import-hub,
  .rmi-assist-strip {
    padding: 14px;
  }

  .rmi-journey-actions,
  .rmi-subsection-actions,
  .rmi-import-hub .actions,
  .rmi-assist-strip .actions {
    width: 100%;
  }

  .rmi-journey-actions button,
  .rmi-subsection-actions button,
  .rmi-import-hub .actions button,
  .rmi-assist-strip .actions button {
    width: 100%;
  }

  .rmi-auto-readonly .readonly-row {
    flex-direction: column;
    align-items: stretch;
  }

  .rmi-auto-readonly .readonly-row input {
    width: 100%;
  }
}

.vaeba-technical-summary {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin: 10px 0 14px;
}

.vaeba-technical-summary .summary-chip {
  border: 1px solid var(--border-color, #ddd);
  border-radius: 10px;
  padding: 8px 10px;
  background: var(--surface-muted, rgba(0, 0, 0, 0.03));
}

.vaeba-technical-summary .summary-chip strong {
  display: block;
  margin-top: 4px;
}
.sr-only-textarea { position: absolute; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.45); display: flex; align-items: center; justify-content: center; z-index: 120; padding: 16px; }
.modal-backdrop[hidden] { display: none; }
.modal { width: min(740px, 100%); max-height: 90vh; overflow: auto; background: var(--card-bg); border: 1px solid var(--card-border); border-radius: 14px; padding: 16px; position: relative; box-shadow: 0 20px 40px rgba(0,0,0,.28); }
.modal-close { position: absolute; right: 10px; top: 10px; background: transparent; border: 1px solid var(--input-border); }
.modal-feedback { margin: 0; font-size: 13px; color: color-mix(in srgb, var(--text) 80%, transparent); }
.history-modal {
  width: min(880px, 100%);
}

.history-modal-actions {
  justify-content: flex-start;
}

.history-list {
  margin-top: 12px;
  display: grid;
  gap: 10px;
}

.history-item {
  border: 1px solid var(--card-border);
  border-radius: 12px;
  padding: 12px;
  background: var(--card-alt);
  display: grid;
  gap: 8px;
}

.history-item-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.history-item-meta {
  font-size: 0.85rem;
  color: var(--muted);
}

.history-item-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.history-item-actions button {
  font-size: 0.86rem;
  padding: 6px 10px;
}

@media (max-width: 680px) {
  .homeActionGrid {
    grid-template-columns: 1fr;
  }
}
.field-filled { animation: fieldFlash 1.6s ease; }
@keyframes fieldFlash {
  0% { box-shadow: 0 0 0 0 rgba(95, 196, 120, .45); background: color-mix(in srgb, #5fc478 14%, var(--card-bg)); }
  100% { box-shadow: none; background: transparent; }
}

#rmi-retro-table.hide-tjmg-cols th:nth-child(6),
#rmi-retro-table.hide-tjmg-cols th:nth-child(7),
#rmi-retro-table.hide-tjmg-cols td:nth-child(6),
#rmi-retro-table.hide-tjmg-cols td:nth-child(7) {
  display: none;
}

.rmi-paid-editor {
  display: grid;
  gap: 6px;
  min-width: 150px;
}

.rmi-retro-paid-input {
  min-width: 120px;
}

.rmi-origin-chip {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid var(--divider);
  font-size: 0.72rem;
  line-height: 1.2;
  color: var(--muted);
  background: color-mix(in srgb, var(--card-bg) 92%, transparent);
}

.rmi-origin-chip--inline {
  white-space: nowrap;
}


.readout.rmi-parecer {
  font-family: var(--font-ui);
  font-size: 12pt;
}

#rmi-step4-experience .card-body {
  gap: 12px;
}

.rmi-step4-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding-bottom: 6px;
}

.rmi-step4-block {
  border: 1px solid var(--card-border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card-bg) 92%, var(--accent-soft) 8%);
}

.rmi-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.rmi-kpi-card {
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 12px;
  background: var(--card-bg);
}

.rmi-kpi-card--highlight {
  background: color-mix(in srgb, var(--accent-soft) 55%, var(--card-bg) 45%);
  border-color: color-mix(in srgb, var(--accent) 35%, var(--card-border));
}

.rmi-context-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.rmi-context-badge {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  border: 1px solid var(--card-border);
  border-radius: 999px;
  padding: 6px 12px;
  background: var(--card-bg);
  min-width: 148px;
}

.rmi-context-badge strong {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .03em;
  color: var(--muted);
}

.rmi-context-badge em {
  font-style: normal;
  color: var(--heading);
  font-weight: 700;
}

.rmi-parecer-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  align-items: center;
  margin-bottom: 10px;
}

#rmi-parecer-slot .pdf-options {
  margin-bottom: 8px;
}

#rmi-parecer-slot #parecer {
  max-height: 480px;
  overflow: auto;
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 18px;
  background: color-mix(in srgb, var(--card-alt) 70%, var(--card-bg) 30%);
  line-height: 1.65;
}

@media (max-width: 720px) {
  .rmi-context-badge {
    min-width: 100%;
    border-radius: 12px;
  }
}

/* bitributacao (namespaced) */
.bitributacao-layout {
  display: grid;
  gap: 16px;
  align-content: start;
}

.bitributacao-entry-card-body {
  display: grid;
  gap: 16px;
  align-content: start;
}

.bitributacao-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.bitributacao-table-shell {
  display: grid;
  gap: 14px;
  min-width: 0;
}

.bitributacao-actions {
  justify-content: flex-start;
  align-items: center;
}

.bitributacao-table-wrapper {
  max-width: 100%;
}

.bitributacao-table {
  width: max(100%, 860px);
  table-layout: fixed;
}

.bitributacao-table th,
.bitributacao-table td {
  white-space: normal;
}

.bitributacao-col--competencia { width: 150px; }
.bitributacao-col--beneficio,
.bitributacao-col--ir { width: 170px; }
.bitributacao-col--tipo { width: 110px; }
.bitributacao-col--acoes { width: 64px; }

.bitributacao-table input,
.bitributacao-table select,
.bitributacao-table button {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}

.bitributacao-table td:last-child,
.bitributacao-table th:last-child {
  padding-inline: 8px;
}

.bitributacao-table td:last-child button {
  min-width: 40px;
}

@media (max-width: 900px) {
  .bitributacao-grid {
    grid-template-columns: 1fr;
  }
}


.pdf-options {
  display: grid;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid var(--divider);
  border-radius: 14px;
  background: color-mix(in srgb, var(--card-alt) 86%, transparent);
}

.readout {
  border-radius: 14px;
  border-color: color-mix(in srgb, var(--card-border) 78%, var(--accent-soft-border) 22%);
}

.fred-actions,
.rmi-step4-actions,
.rmi-parecer-toolbar,
#tributos-results-card .actions,
#calc-summary .actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

#tributos-results-card .actions,
#calc-summary .actions,
.rmi-parecer-toolbar {
  padding-top: 6px;
}

#tributos-alerta:empty,
#alertas:empty {
  display: none;
}

@media (max-width: 720px) {
  .action-bar,
  .fred-actions,
  .rmi-step4-actions,
  .rmi-parecer-toolbar,
  #tributos-results-card .actions,
  #calc-summary .actions {
    flex-direction: column;
    align-items: stretch;
  }

  button.action-main::after {
    margin-left: 6px;
  }
}


/* Incremental premium refinement: spacing, medium breakpoints, light/dark balance */
:root {
  --topbar-height: 80px;
  --topbar-current-height: 80px;
  --sidebar-expanded-width: 264px;
  --card-shadow: 0 12px 28px rgba(48, 24, 34, 0.10);
  --shadow: 0 14px 34px rgba(39, 23, 27, 0.09);
  --shadow-soft: 0 8px 20px rgba(39, 23, 27, 0.07);
  --shadow-hover: 0 16px 32px rgba(39, 23, 27, 0.11);
  --card-blur: 8px;
  --input-bg: rgba(255, 255, 255, 0.78);
  --input-border: rgba(74, 31, 43, 0.11);
  --card-border: rgba(92, 31, 49, 0.12);
  --card-border-strong: rgba(74, 31, 43, 0.16);
  --divider: rgba(74, 31, 43, 0.10);
  --divider-strong: rgba(74, 31, 43, 0.16);
}

.theme-dark {
  --bg-gradient: linear-gradient(135deg, #170e14 0%, #20121a 50%, #2a1821 100%);
  --card-bg: color-mix(in srgb, var(--dm-card) 86%, var(--dm-surface) 14%);
  --card: color-mix(in srgb, var(--dm-card) 88%, var(--dm-surface) 12%);
  --card-alt: color-mix(in srgb, var(--dm-surface) 74%, var(--dm-card) 26%);
  --card-strong: color-mix(in srgb, var(--dm-surface) 82%, var(--dm-card) 18%);
  --card-border: rgba(168, 119, 138, 0.14);
  --card-border-strong: rgba(214, 176, 107, 0.18);
  --input-bg: color-mix(in srgb, var(--dm-surface) 78%, #26131d 22%);
  --input-border: rgba(168, 119, 138, 0.22);
  --dm-shadow: 0 14px 32px rgba(0, 0, 0, 0.28);
  --divider: rgba(168, 119, 138, 0.12);
  --divider-strong: rgba(168, 119, 138, 0.18);
  --ghost-bg: color-mix(in srgb, var(--dm-card) 68%, var(--dm-surface) 32%);
  --ghost-border: rgba(168, 119, 138, 0.2);
}

body {
  line-height: 1.5;
}

.app {
  max-width: 1340px;
  padding-inline: clamp(16px, 2.2vw, 28px);
}

.topbar {
  left: 0;
  right: 0;
  width: auto;
  margin-inline: 0;
  height: auto;
  min-height: var(--topbar-height);
  align-items: start;
  align-content: start;
  padding-block: 10px;
  padding-inline: max(16px, calc((100vw - 1340px) / 2 + 24px));
  background: color-mix(in srgb, var(--wine-base) 94%, #fff 6%);
  border-bottom-color: rgba(255, 255, 255, 0.16);
  box-shadow: 0 14px 30px rgba(44, 17, 28, 0.14);
  isolation: isolate;
  z-index: 120;
}


.theme-dark .topbar {
  background: color-mix(in srgb, var(--dm-bg) 88%, var(--dm-bg2) 12%);
  box-shadow: 0 16px 34px rgba(0, 0, 0, 0.32);
}

.app-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 14px 22px;
}

.header-brand {
  flex: 1 1 420px;
  min-width: 0;
  gap: 14px;
}

.brand-copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.logo {
  width: 60px;
  filter: drop-shadow(0 8px 16px rgba(0, 0, 0, 0.14));
}

h1 {
  font-size: clamp(1.02rem, 0.9rem + 0.38vw, 1.22rem);
  line-height: 1.15;
}

.eyebrow {
  font-size: 0.68rem;
  letter-spacing: 0.18em;
}

.mode-indicator {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  line-height: 1.2;
  padding: 5px 11px;
  background: rgba(0,0,0,.14);
}

.header-actions {
  display: flex;
  flex: 0 1 auto;
  min-width: 0;
  justify-content: flex-end;
  justify-self: end;
  align-items: center;
  align-content: flex-start;
  flex-wrap: wrap;
  gap: 10px;
}

.theme-toggle,
.local-storage-panel summary,
#reset-btn {
  min-height: 40px;
}

.theme-toggle {
  padding: 0 2px;
  font-size: 0.92rem;
}

.local-storage-panel summary,
#reset-btn {
  border-radius: 12px;
}

.local-storage-panel summary {
  padding: 9px 13px;
  background: rgba(255,255,255,.07);
}

.theme-dark .product-summary-card,
.theme-dark .experience-card--result {
  background: color-mix(in srgb, var(--dm-card) 78%, var(--dm-surface) 22%);
  border-color: color-mix(in srgb, var(--card-border) 82%, var(--card-border-strong) 18%);
}

.theme-dark .summary-kpis,
.theme-dark .result-grid > div,
.theme-dark .result-highlight,
.theme-dark .readonly-row,
.theme-dark .rmi-kpi-card,
.theme-dark .fred-exercicio,
.theme-dark .import-feedback,
.theme-dark .pdf-options,
.theme-dark #rmi-parecer-slot #parecer,
.theme-dark .local-storage-menu {
  background: color-mix(in srgb, var(--dm-surface) 72%, var(--dm-card) 28%);
  border: 1px solid rgba(168, 119, 138, 0.16);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

.theme-dark button.primary {
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.24);
}

.theme-dark button.ghost,
.theme-dark button.action-export,
.theme-dark button.action-import,
.theme-dark button.action-support,
.theme-dark button.action-danger {
  background: color-mix(in srgb, var(--ghost-bg) 88%, var(--dm-surface) 12%);
}

.theme-dark input:hover,
.theme-dark select:hover,
.theme-dark textarea:hover {
  border-color: rgba(214, 176, 107, 0.24);
}

.local-storage-menu {
  border-radius: 18px;
  padding: 16px;
}

.left-sidebar {
  top: var(--topbar-current-height);
  height: calc(100vh - var(--topbar-current-height));
  min-height: calc(100vh - var(--topbar-current-height));
  padding: 14px 12px 16px;
  background: color-mix(in srgb, var(--wine-base) 89%, #fff 11%);
  z-index: 95;
}


.sidebar-nav,
.sidebar-steps-list,
.sidebar-aux {
  gap: 10px;
}

.sidebar-item,
.sidebar-calculation,
.sidebar-help-btn {
  min-height: 46px;
  border-radius: 14px;
}

.sidebar-item,
.sidebar-calculation {
  padding-inline: 13px;
}

.sidebar-item {
  background: rgba(15, 8, 12, 0.18);
}

.sidebar-calculation,
.sidebar-help-btn {
  background: rgba(0, 0, 0, 0.1);
}

.sidebar-item.active,
.sidebar-calculation.active,
.sidebar-help-btn.active {
  background: color-mix(in srgb, var(--accent-soft) 86%, rgba(255,255,255,0.04) 14%);
}

.content {
  padding-left: clamp(10px, 1.4vw, 18px);
}

.grid {
  gap: clamp(18px, 1.8vw, 28px);
}

.column,
#tributos-minimo-form,
.guidelines-shell,
.guidelines-grid,
.fred-layout,
.summary-column-stack {
  gap: clamp(16px, 1.5vw, 24px);
}

.card {
  padding: clamp(18px, 1.8vw, 24px);
  border-radius: 22px;
}

.card-header {
  gap: 10px 14px;
  margin-bottom: 18px;
}

.card-header h2 {
  font-size: clamp(1.18rem, 1.02rem + 0.42vw, 1.42rem);
  line-height: 1.18;
}

.card-header p,
.card-subtitle,
.guidelines-lead,
.guidelines-warning-copy,
.guidelines-list dd,
.readout,
.modal-feedback,
.local-storage-status {
  line-height: 1.58;
}

.card-body {
  gap: 18px;
}

.field,
.field-group,
.readonly,
.tests-list,
.alertas,
.import-feedback,
.import-preview,
.fred-client-grid,
.exercise-grid,
.bitributacao-layout,
.bitributacao-grid {
  gap: 14px;
}

label {
  font-size: 0.95rem;
  letter-spacing: 0.01em;
}

input,
select,
textarea,
.segment {
  min-height: 44px;
  border-radius: 12px;
}

textarea {
  min-height: 112px;
}

input,
select,
textarea {
  padding: 11px 13px;
}

.readonly-row,
.fred-exercicio,
.import-feedback,
.pdf-options,
.summary-kpis,
.result-highlight,
#rmi-parecer-slot #parecer,
.modal {
  border-radius: 16px;
}

.readonly-row {
  padding: 12px 14px;
}

.result-grid,
.result-highlight,
.rmi-kpi-grid {
  gap: 14px;
}

.result-grid > div,
.result-highlight > div,
.summary-kpis > div,
.rmi-kpi-card {
  min-width: 0;
}

.label {
  font-size: 0.86rem;
  letter-spacing: 0.01em;
}

.value {
  font-size: clamp(1.02rem, 0.96rem + 0.32vw, 1.26rem);
  line-height: 1.2;
}

.summary-column {
  position: sticky;
  top: calc(var(--topbar-current-height) + 18px);
  z-index: 5;
}

.calc-summary {
  gap: 14px;
}

.calc-summary .card-body {
  gap: 16px;
}

.calc-summary .summary-status,
.summary-notice {
  line-height: 1.5;
}

.summary-checklist {
  gap: 10px;
  padding-left: 18px;
}

.summary-kpis {
  padding: 16px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.preview-table,
.contrib-table {
  font-size: 0.9rem;
}

.table-wrapper {
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: thin;
  padding-bottom: 4px;
}

.preview-table,
.contrib-table {
  min-width: 100%;
}

.preview-table th,
.preview-table td,
.contrib-table th,
.contrib-table td {
  padding: 10px 12px;
  vertical-align: top;
}

.preview-table th,
.contrib-table th {
  position: sticky;
  top: 0;
}

.preview-table tr:last-child td,
.contrib-table tr:last-child td {
  border-bottom: 0;
}

.readout {
  padding: 14px 15px;
  font-size: 0.95rem;
}

.homeScreen {
  padding: clamp(18px, 4vw, 32px);
}

.card.homeCard {
  width: min(560px, 100%);
  gap: 16px;
}

.guidelines-hero {
  align-items: center;
}

.beneficios-grid,
.tributos-grid {
  grid-template-columns: minmax(0, 1.55fr) minmax(320px, 0.92fr);
}

.beneficios-grid.step-4-active {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 382px);
}

.module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid,
.beneficios-grid[data-beneficios-final-step="true"] {
  grid-template-columns: minmax(0, 1fr);
  gap: clamp(14px, 2vw, 24px);
  align-items: start;
}

.module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid .summary-column,
.beneficios-grid[data-beneficios-final-step="true"] .summary-column {
  display: none;
}

.module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid .wizard-column,
.beneficios-grid[data-beneficios-final-step="true"] .wizard-column {
  width: min(100%, 1200px);
  max-width: 1200px;
  margin-inline: auto;
  padding-inline: clamp(6px, 1.6vw, 18px);
}

.module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid .wizard-column > .card,
.module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid .wizard-column > details.card,
.beneficios-grid[data-beneficios-final-step="true"] .wizard-column > .card,
.beneficios-grid[data-beneficios-final-step="true"] .wizard-column > details.card {
  width: 100%;
}

@media (min-width: 961px) and (max-width: 1366px) {
  :root {
    --sidebar-expanded-width: 248px;
  }

  .app {
    max-width: 1260px;
  }

  .content {
    padding-left: 12px;
  }

  .beneficios-grid,
  .tributos-grid {
    grid-template-columns: minmax(0, 1.38fr) minmax(290px, 0.86fr);
    gap: 20px;
  }

  .beneficios-grid.step-4-active {
    grid-template-columns: minmax(0, 1fr) minmax(312px, 348px);
  }

  .module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid,
  .beneficios-grid[data-beneficios-final-step="true"] {
    grid-template-columns: minmax(0, 1fr);
  }

  .summary-column {
    min-width: 0;
  }

  .summary-kpis,
  .result-grid,
  .result-highlight {
    grid-template-columns: 1fr;
  }

  .header-actions {
    gap: 8px;
  }

  .theme-toggle {
    font-size: 0.88rem;
  }

  .local-storage-panel summary,
  #reset-btn {
    padding-inline: 11px;
  }
}

@media (max-width: 1180px) {
  .topbar {
    padding-inline: 16px;
  }

  .app-header {
    grid-template-columns: minmax(0, 1fr);
  }

  .header-actions {
    width: 100%;
    justify-content: flex-start;
    justify-self: stretch;
  }

  .header-brand {
    flex-basis: 100%;
  }

  .content {
    padding-left: 8px;
  }
}

@media (max-width: 960px) {
  :root {
    --topbar-height: 74px;
    --topbar-current-height: 74px;
  }

  .app {
    padding-inline: 14px;
  }

  .topbar {
    padding-inline: 14px;
  }

  .app-header {
    grid-template-columns: auto minmax(0, 1fr);
    align-items: start;
  }

  .mobile-menu-btn {
    display: inline-flex;
    grid-column: 1;
    grid-row: 1;
    border-radius: 12px;
  }

  .header-brand {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
  }

  .header-actions {
    grid-column: 1 / -1;
    grid-row: 2;
  }

  .left-sidebar {
    top: var(--topbar-current-height);
    height: calc(100vh - var(--topbar-current-height));
    min-height: calc(100vh - var(--topbar-current-height));
    width: min(88vw, 320px);
    padding: 12px;
    box-shadow: 16px 0 36px rgba(0, 0, 0, 0.16);
  }

  .content {
    padding-left: 0;
  }

  .summary-column {
    position: static;
    top: auto;
  }

  .summary-column .card:not(.calc-summary) {
    display: block;
  }

  .calc-summary {
    max-height: none;
    overflow: visible;
  }

  .summary-kpis,
  .result-grid,
  .result-highlight {
    grid-template-columns: 1fr;
  }

  .stepper-scroll {
    margin-inline: -2px;
  }

  .card {
    padding: 18px;
  }

  .field-group,
  .fred-client-grid,
  .exercise-grid,
  .bitributacao-grid,
  .rmi-auto-readonly {
    gap: 12px;
  }
}

@media (max-width: 720px) {
  body {
    font-size: 15px;
  }

  .appShell {
    gap: 8px;
  }

  .app-header {
    grid-template-columns: minmax(0, 1fr);
  }

  .mobile-menu-btn {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
  }

  .header-brand {
    grid-column: 1;
    grid-row: 2;
    gap: 12px;
    align-items: center;
  }

  .logo {
    width: 54px;
  }

  h1 {
    font-size: 1.04rem;
  }

  .mode-indicator,
  .theme-toggle,
  .local-storage-panel,
  #reset-btn {
    width: 100%;
  }

  .theme-toggle {
    justify-content: space-between;
  }

  .local-storage-panel summary,
  #reset-btn,
  .header-actions > button,
  .header-actions > details {
    width: 100%;
  }

  .card,
  .collapsible-card .card-body,
  .modal {
    padding: 16px;
  }

  .card-header {
    align-items: flex-start;
  }

  .readonly-row {
    flex-direction: column;
    align-items: stretch;
    gap: 6px;
  }

  .preview-table,
  .contrib-table {
    font-size: 0.84rem;
  }

  .preview-table th,
  .preview-table td,
  .contrib-table th,
  .contrib-table td {
    padding: 9px 10px;
  }

  .homeActions > *,
  .guidelines-actions > * {
    width: 100%;
  }
}

/* Fine visual refinement: premium finish, spacing and readability without structural changes */
:root {
  --surface-raised: color-mix(in srgb, var(--card-bg) 88%, #fff 12%);
  --surface-muted: color-mix(in srgb, var(--card-alt) 88%, var(--card-bg) 12%);
  --surface-soft-border: color-mix(in srgb, var(--card-border) 84%, #fff 16%);
  --table-head-bg: color-mix(in srgb, var(--card-alt) 76%, var(--accent-soft) 24%);
  --table-row-hover: color-mix(in srgb, var(--accent-soft) 14%, var(--card-bg) 86%);
  --button-radius: 13px;
}

.theme-dark {
  --surface-raised: color-mix(in srgb, var(--dm-card) 72%, var(--dm-surface) 28%);
  --surface-muted: color-mix(in srgb, var(--dm-surface) 68%, var(--dm-card) 32%);
  --surface-soft-border: color-mix(in srgb, var(--card-border) 76%, rgba(255, 255, 255, 0.06) 24%);
  --table-head-bg: color-mix(in srgb, var(--dm-surface) 78%, var(--accent-soft) 22%);
  --table-row-hover: color-mix(in srgb, var(--accent-soft) 18%, var(--dm-card) 82%);
}

.card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 96%, #fff 4%) 0%, var(--card-bg) 100%);
  border-color: var(--surface-soft-border);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.34) inset,
    0 14px 32px rgba(48, 24, 34, 0.09);
}

.theme-dark .card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--card-bg) 92%, rgba(255, 255, 255, 0.02) 8%) 0%, var(--card-bg) 100%);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.025) inset,
    0 16px 34px rgba(0, 0, 0, 0.26);
}

.experience-card,
.product-summary-card,
.guidelines-card,
.guidelines-summary-card,
.guidelines-warning-card,
.homeCard {
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.3) inset,
    0 16px 34px rgba(48, 24, 34, 0.10);
}

.theme-dark .experience-card,
.theme-dark .product-summary-card,
.theme-dark .guidelines-card,
.theme-dark .guidelines-summary-card,
.theme-dark .guidelines-warning-card,
.theme-dark .homeCard {
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.03) inset,
    0 18px 38px rgba(0, 0, 0, 0.28);
}

.card-header {
  margin-bottom: 20px;
}

.card-header--dense {
  gap: 7px;
}

.card-kicker,
.guidelines-kicker,
.guidelines-section-label,
.rmi-mode-option__eyebrow,
.rmi-panel-title,
.rmi-section-kicker,
.eyebrow {
  letter-spacing: 0.11em;
}

.card-subtitle,
.subtitle,
.guidelines-lead,
.guidelines-list dd,
.homeHint,
.modal-feedback,
small {
  color: color-mix(in srgb, var(--muted) 92%, var(--text) 8%);
}

.card-body {
  gap: 20px;
}

.field {
  gap: 8px;
}

.field-group {
  gap: 14px;
}

label {
  color: color-mix(in srgb, var(--muted) 88%, var(--heading) 12%);
}

input,
select,
textarea,
.segment {
  min-height: 46px;
  padding: 12px 14px;
  border-radius: 13px;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--input-bg) 96%, #fff 4%) 0%, var(--input-bg) 100%);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.18) inset;
  transition:
    border-color 0.18s ease,
    box-shadow 0.18s ease,
    background 0.18s ease,
    transform 0.18s ease;
}

textarea {
  min-height: 120px;
}

input::placeholder,
textarea::placeholder {
  color: color-mix(in srgb, var(--input-placeholder) 88%, transparent);
}

input:hover,
select:hover,
textarea:hover,
.segment:hover {
  background: linear-gradient(180deg, color-mix(in srgb, var(--input-bg) 92%, #fff 8%) 0%, var(--input-bg) 100%);
}

input:focus,
select:focus,
textarea:focus,
.segment:focus-visible {
  transform: translateY(-1px);
  box-shadow:
    0 0 0 3px var(--focus-ring),
    0 8px 18px rgba(39, 23, 27, 0.08);
}

.theme-dark input,
.theme-dark select,
.theme-dark textarea,
.theme-dark .segment {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.025) inset;
}

button {
  min-height: 44px;
  padding: 11px 18px;
  border-radius: var(--button-radius);
  letter-spacing: 0.01em;
}

button.primary {
  background: linear-gradient(180deg, color-mix(in srgb, var(--accent) 92%, #fff 8%) 0%, var(--accent) 100%);
}

button.ghost,
button.action-export,
button.action-import,
button.action-support,
button.action-danger {
  background: linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 94%, #fff 6%) 0%, var(--ghost-bg) 100%);
}

button:hover {
  transform: translateY(-1px);
}

button:active {
  transform: translateY(0);
}

.theme-dark button.ghost,
.theme-dark button.action-export,
.theme-dark button.action-import,
.theme-dark button.action-support,
.theme-dark button.action-danger {
  background: linear-gradient(180deg, color-mix(in srgb, var(--ghost-bg) 90%, rgba(255, 255, 255, 0.02) 10%) 0%, var(--ghost-bg) 100%);
}

.actions,
.action-bar,
.rmi-step4-actions,
.fred-actions,
.rmi-parecer-toolbar,
#calc-summary .actions,
#tributos-results-card .actions {
  gap: 10px 12px;
}

.action-bar--summary {
  margin-top: 2px;
  padding-top: 10px;
}

.summary-column-stack {
  gap: 18px;
}

.calc-summary .card-header {
  margin-bottom: 16px;
}

.calc-summary .card-body {
  gap: 18px;
}

.calc-summary .summary-status,
.summary-notice,
.pdf-options,
.import-feedback,
.import-preview,
.readonly-row,
.rmi-journey-panel,
.rmi-quick-step,
.rmi-journey-note,
.rmi-import-hub,
.rmi-assist-strip,
.rmi-subsection,
.rmi-step4-block,
.fred-import-found,
.fred-exercicios-resumo,
.fred-auditoria-item {
  border-color: var(--surface-soft-border);
}

.calc-summary .summary-status,
.summary-notice,
.pdf-options,
.import-feedback,
.import-preview,
.readonly-row,
.rmi-journey-panel,
.rmi-quick-step,
.rmi-journey-note,
.rmi-import-hub,
.rmi-assist-strip,
.rmi-step4-block,
.fred-import-found,
.fred-exercicios-resumo,
.fred-auditoria-item {
  background: var(--surface-muted);
}

.summary-checklist {
  gap: 11px;
}

.summary-checklist li::marker {
  color: var(--accent-hover);
}

.summary-kpis,
.rmi-kpi-grid {
  gap: 12px;
}

.summary-kpis > div,
.result-grid > div,
.result-highlight > div,
.rmi-kpi-card {
  padding: 14px 15px;
  border-radius: 15px;
  border: 1px solid var(--surface-soft-border);
  background: var(--surface-raised);
}

.result-highlight {
  padding: 14px;
}

.label {
  line-height: 1.35;
  margin-bottom: 5px;
}

.value {
  letter-spacing: -0.01em;
}

.readout,
#rmi-parecer-slot #parecer {
  background: var(--surface-muted);
  border-color: var(--surface-soft-border);
  padding: 15px 16px;
  line-height: 1.62;
}

.table-wrapper {
  border: 1px solid var(--surface-soft-border);
  border-radius: 16px;
  background: color-mix(in srgb, var(--card-bg) 95%, transparent);
}

.theme-dark .table-wrapper {
  background: color-mix(in srgb, var(--dm-card) 82%, var(--dm-surface) 18%);
}

.preview-table,
.contrib-table {
  font-variant-numeric: tabular-nums;
}

.preview-table th,
.contrib-table th {
  background: var(--table-head-bg);
  color: color-mix(in srgb, var(--muted) 84%, var(--heading) 16%);
  border-bottom-color: var(--surface-soft-border);
}

.preview-table td,
.contrib-table td {
  border-bottom-color: color-mix(in srgb, var(--divider) 86%, transparent);
}

.preview-table tbody tr:hover,
.contrib-table tbody tr:hover {
  background: var(--table-row-hover);
}

.import-feedback,
.import-preview {
  padding: 14px 15px;
  border-radius: 16px;
}

.import-feedback__title,
.import-preview__title {
  letter-spacing: 0.01em;
}

.import-feedback__kind,
.import-origin-chip,
.rmi-inline-badge,
.rmi-mode-tag,
.fred-status-badge {
  border-color: var(--surface-soft-border);
  background: color-mix(in srgb, var(--surface-raised) 90%, var(--accent-soft) 10%);
}

.readonly-row {
  gap: 12px;
}

.readonly-row span {
  color: color-mix(in srgb, var(--muted) 88%, var(--heading) 12%);
}

.guidelines-card,
.guidelines-summary-card,
.guidelines-warning-card,
.homeCard {
  border-color: color-mix(in srgb, var(--surface-soft-border) 84%, var(--accent-soft-border) 16%);
}

.local-storage-menu {
  border: 1px solid var(--surface-soft-border);
  background: var(--surface-muted);
}

.theme-dark .calc-summary .summary-status,
.theme-dark .summary-notice,
.theme-dark .pdf-options,
.theme-dark .import-feedback,
.theme-dark .import-preview,
.theme-dark .readonly-row,
.theme-dark .rmi-journey-panel,
.theme-dark .rmi-quick-step,
.theme-dark .rmi-journey-note,
.theme-dark .rmi-import-hub,
.theme-dark .rmi-assist-strip,
.theme-dark .rmi-step4-block,
.theme-dark .fred-import-found,
.theme-dark .fred-exercicios-resumo,
.theme-dark .fred-auditoria-item,
.theme-dark .local-storage-menu,
.theme-dark .readout,
.theme-dark #rmi-parecer-slot #parecer,
.theme-dark .summary-kpis > div,
.theme-dark .result-grid > div,
.theme-dark .result-highlight > div,
.theme-dark .rmi-kpi-card {
  background: var(--surface-raised);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.02);
}

@media (max-width: 960px) {
  .card-body {
    gap: 18px;
  }

  .summary-column-stack {
    gap: 16px;
  }
}

/* Benefícios — ajuste fino visual de opções auxiliares e pendências do resumo */
#beneficios-module .pdf-options {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px 10px;
  padding: 0;
  margin: 0 0 10px;
  color: inherit;
  font-size: inherit;
}

#beneficios-module #rmi-parecer-slot .pdf-options {
  display: flex;
  width: 100%;
  margin-bottom: 10px;
  padding: 0;
}

#beneficios-module .pdf-options .pdf-toggle {
  flex: 0 1 auto;
  max-width: min(100%, 300px);
}

#beneficios-module .pdf-options .pdf-warning {
  flex: 1 1 100%;
  margin: 0;
}

#beneficios-module #calc-summary .card-body {
  gap: 10px;
  padding: 14px 14px 12px;
}

#beneficios-module #calc-summary .summary-status {
  margin: 0;
  padding: 8px 10px;
  line-height: 1.25;
}

#beneficios-module #calc-summary .summary-pendencias {
  gap: 6px;
}

#beneficios-module #calc-summary .summary-notice {
  margin: 0;
  padding: 8px 10px;
}

#beneficios-module #calc-summary .summary-checklist {
  gap: 4px;
  padding: 0 0 0 14px;
  margin: 0;
}

#beneficios-module #calc-summary .summary-checklist li {
  line-height: 1.22;
  margin: 0;
}

#beneficios-module #calc-summary .summary-link {
  display: inline;
  line-height: 1.2;
}

#beneficios-module #calc-summary .summary-kpis {
  margin-top: 2px;
  padding: 11px 12px;
  gap: 8px;
}

#beneficios-module #calc-summary .actions.action-bar--summary {
  margin-top: 0;
  padding-top: 6px;
}

@media (max-width: 720px) {
  .summary-kpis > div,
  .result-grid > div,
  .result-highlight > div,
  .rmi-kpi-card,
  .import-feedback,
  .import-preview,
  .pdf-options,
  .readonly-row {
    padding: 13px 14px;
  }

  .table-wrapper {
    border-radius: 14px;
  }
}

/* ===== Mobile layout authority (single source of truth) ===== */
@media (max-width: 960px) {
  :root {
    --mobile-content-padding: 14px;
    --mobile-action-bar-height: 78px;
  }

  body {
    --topbar-height: auto;
  }

  .app {
    padding-inline: var(--mobile-content-padding);
    padding-bottom: calc(var(--mobile-action-bar-height) + 26px + env(safe-area-inset-bottom));
  }

  .appShell {
    padding-top: var(--topbar-current-height);
    gap: 10px;
  }

  .topbar {
    height: auto;
    min-height: 0;
    padding: 10px var(--mobile-content-padding);
    width: 100%;
    margin: 0;
    left: 0;
  }

  .app-header {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 10px;
    align-items: start;
    width: 100%;
  }

  .mobile-menu-btn {
    display: inline-flex;
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    align-self: start;
  }

  .header-brand {
    grid-column: 2;
    grid-row: 1;
    min-width: 0;
    gap: 10px;
    align-items: center;
  }

  .brand-copy {
    min-width: 0;
  }

  .logo {
    width: 52px;
  }

  h1 {
    margin: 0;
    font-size: 1.04rem;
    line-height: 1.15;
  }

  .subtitle,
  .eyebrow,
  .mode-indicator {
    margin: 0;
    line-height: 1.25;
  }

  .header-actions {
    grid-column: 1 / -1;
    grid-row: 2;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    align-items: stretch;
  }

  .header-actions > *,
  .header-actions > details,
  .header-actions > button,
  .theme-toggle,
  .local-storage-panel summary,
  #reset-btn {
    width: 100%;
    min-height: 40px;
  }

  .left-sidebar,
  .left-sidebar.collapsed,
  .app.sidebar-collapsed .left-sidebar {
    position: fixed;
    top: var(--topbar-current-height);
    left: 0;
    width: min(84vw, 320px);
    max-width: 320px;
    height: calc(100dvh - var(--topbar-current-height));
    min-height: calc(100dvh - var(--topbar-current-height));
    margin: 0;
    border-radius: 0;
    padding: 12px;
    transform: translateX(-102%);
    visibility: hidden;
    pointer-events: none;
    opacity: 0;
    overflow-y: auto;
    z-index: 90;
    box-shadow: 18px 0 36px rgba(0, 0, 0, 0.24);
    transition: transform .24s ease, opacity .2s ease, visibility .2s ease;
  }

  body.sidebar-drawer-open .left-sidebar,
  body.sidebar-drawer-open .left-sidebar.collapsed,
  body.sidebar-drawer-open .app.sidebar-collapsed .left-sidebar {
    transform: translateX(0);
    visibility: visible;
    pointer-events: auto;
    opacity: 1;
  }

  .left-sidebar .sidebar-toggle {
    display: none;
  }

  .sidebar-close {
    display: inline-flex;
  }

  .content,
  .app.sidebar-collapsed .content {
    margin-left: 0;
    padding-left: 0;
    width: 100%;
  }

  .grid,
  .beneficios-grid,
  .tributos-grid,
  .beneficios-grid.step-4-active,
  .module-view[data-module="beneficios"][data-beneficios-final-step="true"] .beneficios-grid,
  .beneficios-grid[data-beneficios-final-step="true"] {
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
  }

  .column,
  .wizard-column,
  .summary-column,
  .tributos-summary-column,
  .summary-column-stack {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    gap: 14px;
  }

  .summary-column,
  .tributos-summary-column {
    position: static;
    top: auto;
    inset: auto;
    z-index: auto;
    order: 20;
  }

  .summary-column .card:not(.calc-summary) {
    display: block;
  }

  .calc-summary {
    position: static;
    inset: auto;
    max-height: none;
    overflow: visible;
    margin: 0;
  }

  .stepper {
    margin-top: 2px;
  }

  .stepper-scroll {
    overflow-x: auto;
    padding-bottom: 4px;
    -webkit-overflow-scrolling: touch;
  }

  .stepper-inner {
    width: max-content;
    min-width: 100%;
    gap: 8px;
  }

  .step-btn {
    white-space: nowrap;
  }

  .card,
  .collapsible-card .card-body {
    padding: 16px;
  }

  .table-wrapper {
    overflow-x: auto;
  }

  .floating-next {
    position: fixed;
    left: max(12px, env(safe-area-inset-left));
    right: max(12px, env(safe-area-inset-right));
    bottom: calc(10px + env(safe-area-inset-bottom));
    min-height: 52px;
    z-index: 65;
  }

  .floating-next {
    border-radius: 14px;
    justify-content: center;
  }
}

@media (max-width: 720px) {
  .header-actions {
    grid-template-columns: 1fr;
  }

  .topbar {
    padding-top: 8px;
    padding-bottom: 8px;
  }
}

/* ===== LUMA refresh: topbar, marca e ações do usuário ===== */
:root {
  --topbar-height: 76px;
  --topbar-current-height: var(--topbar-height);
}

.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;
}

.topbar {
  height: auto;
  min-height: var(--topbar-height);
  padding-block: 10px;
  background: color-mix(in srgb, var(--wine-base, var(--bg-wine)) 95%, #fff 5%);
  border-bottom: 1px solid color-mix(in srgb, var(--accent) 18%, rgba(255, 255, 255, 0.2) 82%);
  box-shadow: 0 10px 24px rgba(44, 17, 28, 0.12);
}

.theme-dark .topbar {
  background: color-mix(in srgb, var(--dm-bg) 90%, var(--dm-bg2) 10%);
  border-bottom-color: rgba(255, 255, 255, 0.1);
}

.theme-dark .card.homeCard {
  background: color-mix(in srgb, var(--dm-bg) 90%, var(--dm-bg2) 10%);
  border-color: rgba(255, 255, 255, 0.1);
}

.app-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.header-brand {
  gap: 12px;
}

.logo,
.homeLogo {
  object-fit: contain;
}

.logo {
  width: 58px;
  height: 40px;
  filter: drop-shadow(0 4px 10px rgba(0, 0, 0, 0.12));
}

.homeLogo {
  width: clamp(124px, 22vw, 164px);
}

.brand-copy {
  display: flex;
  align-items: center;
}

.header-brand .eyebrow,
.header-brand .subtitle {
  display: none !important;
}

.header-brand h1 {
  margin: 0;
  font-family: "Montserrat", "Alegreya Sans", system-ui, sans-serif;
  font-size: clamp(1.01rem, 0.94rem + 0.28vw, 1.16rem);
  line-height: 1.16;
  letter-spacing: 0.012em;
  font-weight: 600;
  color: color-mix(in srgb, #fff 90%, var(--accent) 10%);
}

.theme-dark .header-brand h1 {
  color: color-mix(in srgb, #fff 86%, var(--accent) 14%);
}

.header-actions {
  gap: 10px;
  align-items: center;
}

.theme-toggle,
#reset-btn,
#topbar-user-pill {
  min-height: 40px;
  border-radius: 12px;
}

.theme-toggle {
  padding: 0 8px;
  gap: 8px;
  color: rgba(255, 255, 255, 0.94);
  font-size: 0.9rem;
  font-weight: 600;
}

#reset-btn,
#topbar-user-pill {
  border: 1px solid color-mix(in srgb, var(--accent) 22%, rgba(255, 255, 255, 0.22) 78%);
  background: color-mix(in srgb, rgba(255, 255, 255, 0.14) 78%, var(--accent-soft) 22%);
  color: #fff;
}

#reset-btn:hover,
#topbar-user-pill:hover {
  border-color: color-mix(in srgb, var(--accent) 52%, rgba(255, 255, 255, 0.3) 48%);
  background: color-mix(in srgb, rgba(255, 255, 255, 0.2) 72%, var(--accent-soft) 28%);
  box-shadow: 0 8px 18px rgba(28, 10, 17, 0.16);
}

#reset-btn:focus-visible,
#topbar-user-pill:focus-visible,
.topbar-user-menu button:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 75%, #fff 25%);
  outline-offset: 2px;
}

.topbar-user-menu-wrap {
  position: relative;
}

.topbar-user-pill {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  padding: 7px 12px 7px 9px;
  font-weight: 600;
}

.topbar-user-avatar {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(145deg, color-mix(in srgb, var(--accent) 72%, #fff 28%), color-mix(in srgb, var(--accent) 88%, #8c5f19 12%));
  color: color-mix(in srgb, #2d1d10 80%, #000 20%);
  font-size: 0.8rem;
  font-weight: 700;
}

.topbar-user-name {
  max-width: 140px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.topbar-user-chevron {
  font-size: 0.8rem;
  opacity: 0.9;
  transform: translateY(1px);
}

#topbar-user-pill[aria-expanded="true"] .topbar-user-chevron {
  transform: rotate(180deg) translateY(-1px);
}

.topbar-user-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 180px;
  border-radius: 14px;
  padding: 8px;
  background: var(--card-strong);
  border: 1px solid var(--card-border-strong);
  box-shadow: var(--shadow);
  z-index: 160;
}

.topbar-user-menu button {
  width: 100%;
  text-align: left;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text);
  box-shadow: none;
}

.topbar-user-menu button:hover {
  background: var(--accent-soft);
  border-color: var(--accent-soft-border);
}

.left-sidebar,
.topbar {
  border-radius: 0;
}

.card,
.modal,
button,
input,
select,
textarea {
  border-radius: 14px;
}

.card {
  border: 1px solid color-mix(in srgb, var(--card-border) 86%, var(--accent-soft-border) 14%);
  box-shadow: 0 10px 24px rgba(39, 23, 27, 0.08);
}

button {
  min-height: 40px;
  padding: 10px 16px;
  border-width: 1px;
}

button.primary {
  box-shadow: 0 8px 18px rgba(195, 160, 91, 0.22);
}

button.ghost {
  border-color: color-mix(in srgb, var(--ghost-border) 82%, var(--accent-soft-border) 18%);
}

@media (max-width: 960px) {
  :root {
    --topbar-height: 72px;
    --topbar-current-height: var(--topbar-height);
  }

  .header-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .theme-toggle {
    grid-column: 1;
  }

  #reset-btn {
    grid-column: 2;
  }

  .topbar-user-menu-wrap {
    grid-column: 1 / -1;
  }

  #topbar-user-pill {
    width: 100%;
    justify-content: flex-start;
  }

  .topbar-user-menu {
    left: 0;
    right: auto;
    width: 100%;
  }
}
