/* ===== Tema base e tokens visuais globais ===== */

:root {
  --bg: #d6daed;
  --bg-accent: radial-gradient(circle at top left, rgba(209, 217, 231, 0.78), transparent 32%),
    radial-gradient(circle at bottom right, rgba(53, 71, 100, 0.14), transparent 28%),
    #d6daed;
  --panel: rgba(255, 255, 255, 0.72);
  --panel-strong: #f5f7fc;
  --panel-border: rgba(53, 71, 100, 0.12);
  --text: #324159;
  --muted: #65738b;
  --heading: #27354b;
  --brand: #354764;
  --brand-dark: #2b3a53;
  --sidebar-bg: rgba(43, 58, 83, 0.95);
  --teal: #536a94;
  --danger: #8a6171;
  --warning: #8c7f61;
  --success: #5f7388;
  --shadow-lg: 0 24px 60px rgba(37, 50, 73, 0.16);
  --shadow-md: 0 14px 30px rgba(37, 50, 73, 0.1);
  --radius-xl: 28px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  min-height: 100vh;
  font-family: 'Manrope', sans-serif;
  background: var(--bg-accent);
  color: var(--text);
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

img {
  max-width: 100%;
  display: block;
}

/* ===== Shell estrutural da aplicação ===== */

.app-shell {
  display: grid;
  grid-template-columns: 290px 1fr;
  min-height: 100vh;
}

.app-shell.is-auth-mode {
  grid-template-columns: 1fr;
}

.app-shell.is-auth-mode .sidebar,
.app-shell.is-auth-mode .topbar {
  display: none;
}

.app-shell.is-auth-mode .workspace {
  padding: 0;
}

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 28px 22px;
  border-right: 1px solid var(--panel-border);
  background: var(--sidebar-bg);
  color: #f4f7fc;
}

.brand-block {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 8px 22px;
}

.brand-block strong {
  display: block;
  font-size: 1rem;
}

.brand-block small {
  color: rgba(244, 247, 252, 0.68);
}

.brand-mark {
  display: grid;
  place-items: center;
  width: 60px;
  height: 60px;
  border-radius: 16px;
  background: linear-gradient(135deg, #d6daed, #d1d9e7);
  color: #354764;
  font-weight: 800;
  overflow: hidden;
  flex-shrink: 0;
}

.brand-mark:has(img) {
  background: rgba(255, 255, 255, 0.15);
}

.brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.logo-upload-widget {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.logo-upload-preview {
  width: 72px;
  height: 72px;
  border-radius: 14px;
  border: 1.5px dashed var(--panel-border, rgba(0,0,0,0.18));
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--bg);
  font-size: 0.78rem;
  color: var(--muted);
  flex-shrink: 0;
}

.logo-upload-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 4px;
}

.logo-upload-controls {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.product-photo-picker {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
}

.product-photo-preview {
  width: 92px;
  height: 92px;
  max-width: 92px;
  max-height: 92px;
  min-width: 92px;
  min-height: 92px;
  border-radius: 14px;
  border: 1.5px dashed var(--panel-border, rgba(0,0,0,0.18));
  display: grid;
  place-items: center;
  overflow: hidden;
  background: var(--bg);
  color: var(--muted);
  font-size: 0.82rem;
  text-align: center;
  flex: 0 0 92px;
}

.product-photo-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  padding: 6px;
}

.product-photo-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}

.sidebar-nav {
  display: flex;
  flex-direction: column;
  gap: 6px;
  height: calc(100vh - 220px);
  overflow: auto;
  padding-right: 4px;
}

.nav-section-title {
  margin: 18px 8px 6px;
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(244, 247, 252, 0.48);
}

.nav-link {
  display: flex;
  align-items: center;
  gap: 12px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: inherit;
  padding: 12px 14px;
  text-align: left;
  transition: 160ms ease;
}

.nav-link__icon {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(214, 218, 237, 0.1);
  color: rgba(255, 255, 255, 0.9);
}

.nav-link__icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.nav-link__label {
  min-width: 0;
}

.nav-link:hover,
.nav-link.is-active {
  background: rgba(214, 218, 237, 0.16);
  color: #ffffff;
}

.nav-link:hover .nav-link__icon,
.nav-link.is-active .nav-link__icon {
  background: rgba(255, 255, 255, 0.14);
}

/* ===== Workspace, cabeçalho e elementos institucionais ===== */

.role-chip,
.tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 700;
}

.role-chip {
  background: rgba(209, 217, 231, 0.16);
  color: #e8eef9;
}

.workspace {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
  padding: 24px 28px 40px;
}

.app-main {
  flex: 1;
}

.app-footer {
  margin-top: 28px;
  min-height: 112px;
  padding: 18px 6px 0;
  border-top: 1px solid rgba(53, 71, 100, 0.12);
  color: var(--muted);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 14px;
  font-size: 0.82rem;
  text-align: center;
}

.app-footer-meta {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  flex-wrap: wrap;
}

.app-footer-role {
  background: rgba(53, 71, 100, 0.12);
  color: var(--brand-dark);
}

.app-footer-environment {
  margin: 0;
  max-width: 560px;
}

.app-footer-copy {
  margin: 0;
}

.topbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 28px;
}

.eyebrow {
  margin: 0 0 6px;
  color: var(--brand-dark);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

h1,
.page-title,
.section-title {
  font-family: 'Fraunces', serif;
  color: var(--heading);
}

h1 {
  margin: 0;
  font-size: clamp(2rem, 3vw, 2.8rem);
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.mobile-menu-toggle,
.mobile-nav-shell {
  display: none;
}

.mobile-menu-toggle {
  width: 54px;
  height: 54px;
  padding: 0;
  border: 1px solid rgba(53, 71, 100, 0.14);
  border-radius: 20px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(238, 242, 251, 0.92));
  color: var(--brand-dark);
  align-items: center;
  justify-content: center;
  box-shadow: 0 16px 30px rgba(37, 50, 73, 0.14);
}

.mobile-menu-toggle:hover,
.mobile-menu-toggle:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(37, 50, 73, 0.18);
}

.mobile-menu-toggle svg,
.mobile-drawer__close svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.mobile-bottom-nav {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: calc(16px + env(safe-area-inset-bottom));
  z-index: 120;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
  border-radius: 24px;
  background: rgba(248, 250, 255, 0.96);
  border: 1px solid rgba(53, 71, 100, 0.1);
  box-shadow: 0 22px 46px rgba(37, 50, 73, 0.18);
  backdrop-filter: blur(16px);
}

.mobile-bottom-nav__item {
  border: 0;
  border-radius: 18px;
  min-height: 72px;
  padding: 10px 6px;
  background: transparent;
  color: var(--muted);
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 6px;
  text-align: center;
  transition: 160ms ease;
}

.mobile-bottom-nav__item span {
  font-size: 0.68rem;
  font-weight: 800;
  line-height: 1.15;
}

.mobile-bottom-nav__item .nav-link__icon,
.mobile-drawer__link .nav-link__icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  background: rgba(53, 71, 100, 0.08);
  color: var(--brand);
}

.mobile-bottom-nav__item.is-active {
  background: linear-gradient(180deg, rgba(83, 106, 148, 0.22), rgba(53, 71, 100, 0.18));
  color: var(--heading);
  box-shadow: inset 0 0 0 1px rgba(53, 71, 100, 0.08);
}

.mobile-bottom-nav__item.is-active .nav-link__icon {
  background: rgba(53, 71, 100, 0.18);
}

.mobile-bottom-nav__item:hover,
.mobile-bottom-nav__item:focus-visible {
  background: rgba(53, 71, 100, 0.08);
}

.mobile-drawer-backdrop {
  position: fixed;
  inset: 0;
  z-index: 129;
  background: rgba(39, 53, 75, 0.38);
  backdrop-filter: blur(4px);
}

.mobile-drawer {
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 130;
  width: min(380px, 92vw);
  border-radius: 0 28px 28px 0;
  padding: 18px 18px calc(24px + env(safe-area-inset-bottom));
  background: linear-gradient(180deg, rgba(248, 250, 255, 0.98), rgba(240, 244, 252, 0.98));
  box-shadow: 0 22px 50px rgba(37, 50, 73, 0.2);
  overflow-y: auto;
  transform: translateX(-104%);
  transition: transform 220ms ease;
}

.mobile-drawer.is-open {
  transform: translateX(0);
}

.mobile-drawer__header,
.mobile-drawer__section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.mobile-drawer__header {
  margin-bottom: 14px;
  padding: 14px 14px 0;
}

.mobile-drawer__summary {
  display: grid;
  gap: 2px;
  margin-top: 10px;
}

.mobile-drawer__summary strong {
  color: var(--heading);
  font-size: 0.94rem;
}

.mobile-drawer__summary span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.mobile-drawer__header h2,
.mobile-drawer__section-header h3 {
  margin: 0;
}

.mobile-drawer__close {
  width: 42px;
  height: 42px;
  flex: 0 0 42px;
  padding: 0;
  border: 1px solid rgba(53, 71, 100, 0.1);
  border-radius: 14px;
  background: rgba(53, 71, 100, 0.04);
  color: var(--heading);
}

.mobile-drawer__search {
  display: grid;
  gap: 8px;
  margin-bottom: 16px;
  padding: 0 14px;
}

.mobile-drawer__search span {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.mobile-drawer__search input {
  width: 100%;
  padding: 13px 14px;
  border-radius: 16px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.92);
}

.mobile-drawer__content {
  display: grid;
  gap: 18px;
  padding: 0 14px;
}

.mobile-drawer__section {
  display: grid;
  gap: 10px;
}

.mobile-drawer__section-header h3 {
  font-size: 0.86rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.mobile-drawer__section-list {
  display: grid;
  gap: 10px;
}

.mobile-drawer__link {
  border: 1px solid rgba(53, 71, 100, 0.08);
  border-radius: 18px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.82);
  display: flex;
  align-items: center;
  gap: 12px;
  text-align: left;
  color: inherit;
}

.mobile-drawer__link.is-active {
  border-color: rgba(53, 71, 100, 0.18);
  background: rgba(53, 71, 100, 0.08);
}

.mobile-drawer__footer {
  margin-top: 18px;
  padding: 16px 14px 0;
  border-top: 1px solid rgba(53, 71, 100, 0.08);
}

.mobile-drawer__logout {
  width: 100%;
  justify-content: center;
}

.mobile-drawer__copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.mobile-drawer__copy strong {
  color: var(--heading);
  font-size: 0.94rem;
}

.mobile-drawer__copy small {
  color: var(--muted);
  font-size: 0.78rem;
}

.today-pill {
  padding: 10px 16px;
  border-radius: 999px;
  background: var(--panel-strong);
  border: 1px solid var(--panel-border);
  box-shadow: var(--shadow-md);
  color: var(--muted);
  font-weight: 700;
}

/* ===== Fluxo de autenticação e grades reutilizáveis ===== */

.page-container {
  display: flex;
  flex-direction: column;
  gap: 22px;
}

.auth-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 32px;
}

.auth-card {
  width: min(520px, 100%);
  padding: 30px;
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.8);
  border: 1px solid var(--panel-border);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(14px);
}

.auth-brand {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 22px;
}

.auth-brand .brand-mark {
  width: 64px;
  height: 64px;
  border-radius: 20px;
}

.auth-brand h1 {
  font-size: clamp(2rem, 4vw, 2.6rem);
}

.auth-form {
  margin-bottom: 18px;
}

.auth-hints .timeline-card p + p {
  margin-top: 6px;
}

.layout-grid,
.two-column,
.three-column,
.four-column {
  display: grid;
  gap: 18px;
}

.two-column {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.three-column {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.four-column,
.stats-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.stats-grid {
  display: grid;
  gap: 18px;
}

.card,
.panel,
.catalog-card,
.metric-card,
.calendar-event,
.timeline-card,
.summary-tile {
  border: 1px solid var(--panel-border);
  background: var(--panel);
  backdrop-filter: blur(10px);
  box-shadow: var(--shadow-md);
}

.panel,
.card,
.catalog-card,
.metric-card,
.timeline-card,
.summary-tile {
  border-radius: var(--radius-lg);
}

.card,
.metric-card,
.summary-tile {
  padding: 20px;
}

.panel {
  padding: 22px;
}

.panel-header,
.panel-actions,
.inline-stack,
.field-row,
.toolbar,
.table-actions,
.kpi-row,
.client-summary,
.item-line,
.order-summary-list {
  display: flex;
  align-items: center;
  gap: 12px;
}

.panel-header,
.toolbar,
.kpi-row,
.client-summary {
  justify-content: space-between;
}

.panel-actions,
.toolbar {
  flex-wrap: wrap;
}

.pdv-header-actions,
.pdv-document-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pdv-header-actions {
  margin-left: auto;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.pdv-document-actions {
  padding: 4px;
  border-radius: 18px;
  border: 1px solid var(--panel-border);
  background: rgba(255, 255, 255, 0.34);
  flex-wrap: wrap;
}

.pdv-document-actions .btn {
  min-width: 118px;
}

.panel-header {
  margin-bottom: 18px;
}

.panel-header h2,
.panel-header h3,
.panel h2,
.panel h3 {
  margin: 0;
}

.panel-header p,
.muted-text,
.helper,
.metric-label,
.table-subtle,
.field small {
  margin: 0;
  color: var(--muted);
}

.metric-card {
  position: relative;
  overflow: hidden;
}

.metric-card::after {
  content: '';
  position: absolute;
  inset: auto -20px -30px auto;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: rgba(53, 71, 100, 0.08);
}

.metric-card--revenue {
  border-color: rgba(42, 134, 92, 0.3);
  background: linear-gradient(150deg, rgba(42, 134, 92, 0.13), rgba(255, 255, 255, 0.7));
}

.metric-card--revenue::after {
  background: rgba(42, 134, 92, 0.16);
}

.metric-card--revenue .metric-value {
  color: #1f7a52;
}

.metric-card--expense {
  border-color: rgba(180, 71, 71, 0.3);
  background: linear-gradient(150deg, rgba(180, 71, 71, 0.14), rgba(255, 255, 255, 0.7));
}

.metric-card--expense::after {
  background: rgba(180, 71, 71, 0.14);
}

.metric-card--expense .metric-value {
  color: #a13e3e;
}

.metric-card--balance {
  border-color: rgba(58, 99, 174, 0.32);
  background: linear-gradient(150deg, rgba(58, 99, 174, 0.14), rgba(255, 255, 255, 0.72));
}

.metric-card--balance::after {
  background: rgba(58, 99, 174, 0.14);
}

.metric-card--balance .metric-value {
  color: #2f4f89;
}

.metric-label {
  font-size: 0.85rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.metric-value {
  margin: 12px 0 6px;
  font-size: clamp(1.8rem, 2.2vw, 2.5rem);
  font-weight: 800;
  color: var(--heading);
}

.metric-trend {
  color: var(--teal);
  font-weight: 700;
}

.btn {
  border: 0;
  border-radius: 14px;
  padding: 11px 16px;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-weight: 700;
  line-height: 1.1;
  text-align: center;
  transition: 160ms ease;
}

.btn:disabled {
  opacity: 0.58;
  cursor: not-allowed;
  box-shadow: none;
}

.btn-primary {
  background: linear-gradient(135deg, var(--brand), #4d6389);
  color: #f7f9fd;
  box-shadow: 0 12px 22px rgba(53, 71, 100, 0.24);
}

.btn-primary:hover {
  transform: translateY(-1px);
}

.btn-secondary {
  background: #dfe5f1;
  color: var(--heading);
}

.btn-ghost {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--panel-border);
}

.btn-danger {
  background: rgba(138, 97, 113, 0.14);
  color: var(--danger);
}

.btn-inline {
  min-height: 42px;
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 0.88rem;
}

.panel-actions .btn,
.toolbar .btn {
  white-space: nowrap;
}

.form-grid {
  display: grid;
  gap: 16px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
}

.field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.field label {
  font-weight: 700;
  color: var(--heading);
}

.field input,
.field select,
.field textarea,
.search-input {
  width: 100%;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.86);
  color: var(--text);
}

.field textarea {
  min-height: 104px;
  resize: vertical;
}

.field-inline-action {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.money-input {
  position: relative;
  width: 100%;
  min-width: 0;
}

.field-row .money-input {
  flex: 1 1 auto;
}

.money-input span {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-weight: 700;
  pointer-events: none;
}

.money-input input {
  padding-left: 44px;
}

.password-visibility-button {
  width: 52px;
  min-width: 52px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.password-visibility-button svg {
  width: 24px;
  height: 24px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.span-3 {
  grid-column: span 3;
}

.span-4 {
  grid-column: span 4;
}

.span-5 {
  grid-column: span 5;
}

.span-6 {
  grid-column: span 6;
}

.span-7 {
  grid-column: span 7;
}

@media (max-width: 1120px) {
  .pdv-header-actions {
    width: 100%;
    margin-left: 0;
    justify-content: flex-start;
  }
}

.span-8 {
  grid-column: span 8;
}

.span-9 {
  grid-column: span 9;
}

.span-12 {
  grid-column: span 12;
}

.table-wrap {
  overflow: auto;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th,
.data-table td {
  padding: 14px 12px;
  border-bottom: 1px solid rgba(53, 71, 100, 0.08);
  text-align: left;
  vertical-align: top;
}

.data-table th {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted);
}

.mobile-record-list,
.pdv-mobile-only {
  display: none;
}

.mobile-record-list {
  gap: 12px;
}

.mobile-record-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.86);
  box-shadow: var(--shadow-md);
}

.mobile-record-card__head,
.mobile-record-card__actions,
.pdv-mobile-cta__actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.mobile-record-card__head {
  justify-content: space-between;
}

.mobile-record-card__title {
  min-width: 0;
  flex: 1 1 auto;
}

.mobile-record-card__title strong,
.mobile-record-card__head strong {
  display: block;
  color: var(--heading);
}

.mobile-record-card__inline-action {
  padding-inline: 0;
  min-height: 0;
  border: 0;
  background: transparent;
  justify-content: flex-start;
}

.mobile-record-card__cover {
  padding: 0;
  border: 0;
  background: transparent;
}

.mobile-record-card__stats {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mobile-record-card__stats div {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(53, 71, 100, 0.04);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.mobile-record-card__stats span {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.mobile-record-card__stats strong {
  color: var(--heading);
}

.mobile-record-card__actions {
  flex-wrap: wrap;
}

.availability-card-mobile__stats {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pdv-client-suggestions {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.pdv-client-suggestions__empty {
  margin: 8px 0 0;
}

.pdv-client-suggestion {
  border: 1px solid rgba(53, 71, 100, 0.08);
  border-radius: 14px;
  padding: 10px 12px;
  background: rgba(53, 71, 100, 0.04);
  text-align: left;
  display: grid;
  gap: 4px;
}

.pdv-client-suggestion strong {
  color: var(--heading);
}

.pdv-client-suggestion span {
  color: var(--muted);
  font-size: 0.8rem;
}

.pdv-client-suggestion small {
  color: var(--brand-dark);
  font-size: 0.75rem;
  font-weight: 700;
}

.pdv-client-suggestion.is-active {
  border-color: rgba(53, 71, 100, 0.18);
  background: rgba(53, 71, 100, 0.08);
}

.status-badge {
  display: inline-flex;
  align-items: center;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.status-badge.disponivel,
.tag.success {
  background: rgba(95, 115, 136, 0.14);
  color: var(--success);
}

.status-badge.reservado,
.tag.info {
  background: rgba(83, 106, 148, 0.12);
  color: var(--teal);
}

.status-badge.retirado,
.status-badge.aguardando-devolucao,
.status-badge.orcamento,
.tag.warning {
  background: rgba(140, 127, 97, 0.12);
  color: var(--warning);
}

.status-badge.cancelado,
.status-badge.indisponivel,
.status-badge.em-manutencao,
.tag.danger {
  background: rgba(138, 97, 113, 0.12);
  color: var(--danger);
}

.catalog-grid,
.summary-grid,
.report-grid,
.alert-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.catalog-card {
  overflow: hidden;
}

.catalog-card img {
  width: 100%;
  height: 170px;
  object-fit: cover;
}

/* No catalogo consultivo do PDV, mantem cards com largura estavel
   e mostra a imagem inteira mesmo quando ha poucos resultados. */
[data-pdv-panel='catalog'] .catalog-grid {
  grid-template-columns: repeat(auto-fill, minmax(320px, 420px));
  justify-content: start;
}

.catalog-category-nav {
  display: flex;
  gap: 10px;
  overflow: visible;
  flex-wrap: nowrap;
  padding: 4px 2px 12px;
  margin-bottom: 8px;
  scrollbar-width: thin;
  align-items: center;
}

.catalog-category-nav__item {
  flex: 0 0 auto;
  min-height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.76);
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.catalog-category-nav__item:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.2);
  color: var(--heading);
}

.catalog-category-nav__item.is-active {
  background: linear-gradient(135deg, rgba(61, 86, 134, 0.95), rgba(88, 114, 164, 0.92));
  border-color: rgba(61, 86, 134, 0.95);
  color: #fff;
  box-shadow: 0 10px 22px rgba(61, 86, 134, 0.22);
}

.catalog-category-menu {
  position: relative;
  flex: 0 0 auto;
}

.catalog-category-menu[open] {
  z-index: 3;
}

.catalog-category-menu__trigger {
  list-style: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.76);
  color: var(--muted);
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
  white-space: nowrap;
}

.catalog-category-menu__trigger::-webkit-details-marker {
  display: none;
}

.catalog-category-menu__trigger::after {
  content: '▾';
  margin-left: 8px;
  font-size: 0.8rem;
}

.catalog-category-menu:hover .catalog-category-menu__trigger {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.2);
  color: var(--heading);
}

.catalog-category-menu.is-active .catalog-category-menu__trigger,
.catalog-category-menu[open] .catalog-category-menu__trigger {
  background: linear-gradient(135deg, rgba(61, 86, 134, 0.95), rgba(88, 114, 164, 0.92));
  border-color: rgba(61, 86, 134, 0.95);
  color: #fff;
  box-shadow: 0 10px 22px rgba(61, 86, 134, 0.22);
}

.catalog-category-menu__panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  display: grid;
  gap: 8px;
  min-width: 220px;
  max-width: min(320px, 70vw);
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 40px rgba(53, 71, 100, 0.18);
  backdrop-filter: blur(12px);
}

.catalog-category-menu__item {
  min-height: 38px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(242, 244, 251, 0.92);
  color: var(--text);
  text-align: left;
  font: inherit;
  font-size: 0.9rem;
  font-weight: 700;
  cursor: pointer;
}

.catalog-category-menu__item.is-active {
  border-color: rgba(61, 86, 134, 0.95);
  background: rgba(61, 86, 134, 0.1);
  color: rgba(43, 58, 83, 1);
}

[data-pdv-panel='catalog'] .catalog-card img {
  height: 220px;
  object-fit: contain;
  object-position: center;
  background: #eef1f7;
}

.catalog-card-content {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px;
}

.catalog-card .price-row {
  align-items: flex-end;
}

.catalog-card-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  flex: 1;
}

.catalog-card-actions .btn {
  width: 100%;
}

.catalog-card h3,
.timeline-card h3,
.summary-tile strong {
  margin: 0 0 8px;
}

.price-row,
.list-row,
.visual-stat,
.total-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.total-box {
  padding: 18px;
  border-radius: 18px;
  background: #354764;
  color: #f6f8fc;
}

.total-box strong {
  font-size: 1.5rem;
}

.timeline {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.timeline-card {
  padding: 18px;
}

.timeline-meta,
.stack-list,
.mini-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.calendar-board {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
}

.calendar-event {
  padding: 16px;
  border-radius: 18px;
}

.progress-bars {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.comparison-chart {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
  min-height: 260px;
}

.comparison-bar-card {
  display: grid;
  gap: 10px;
}

.comparison-bar-meta {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  text-align: center;
}

.comparison-bar-meta span {
  color: var(--muted);
  font-size: 0.82rem;
}

.comparison-bar-track {
  height: 180px;
  border-radius: 18px;
  background: rgba(53, 71, 100, 0.08);
  display: flex;
  align-items: flex-end;
  padding: 8px;
}

.comparison-bar-fill {
  width: 100%;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--brand), var(--teal));
  min-height: 2px;
}

.comparison-chart.is-expense .comparison-bar-fill {
  background: linear-gradient(180deg, var(--warning), var(--danger));
}

.executive-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(320px, 0.9fr);
  gap: 18px;
}

.executive-hero-main,
.executive-hero-side {
  overflow: hidden;
}

.executive-hero-main {
  background: linear-gradient(135deg, rgba(43, 58, 83, 0.98), rgba(64, 86, 121, 0.92));
  color: #f6f8fc;
}

.executive-hero-main h2,
.executive-hero-main p,
.executive-hero-main .tag,
.executive-hero-side h2 {
  color: inherit;
}

.executive-hero-copy p {
  color: rgba(246, 248, 252, 0.8);
  max-width: 820px;
}

.executive-kpi-grid,
.executive-side-metrics {
  display: grid;
  gap: 14px;
}

.executive-kpi-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin-top: 22px;
}

.executive-side-metrics {
  grid-template-columns: 1fr;
}

.executive-metric-card {
  padding: 18px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: var(--shadow-md);
}

.executive-hero-main .executive-metric-card {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.08);
}

.executive-metric-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.executive-metric-head span {
  font-size: 0.82rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 800;
  color: var(--muted);
}

.executive-hero-main .executive-metric-head span {
  color: rgba(246, 248, 252, 0.72);
}

.executive-metric-card strong {
  display: block;
  margin-bottom: 6px;
  font-size: clamp(1.3rem, 2vw, 2rem);
  color: var(--heading);
}

.executive-hero-main .executive-metric-card strong,
.executive-hero-main .executive-metric-card p {
  color: #f6f8fc;
}

.executive-metric-card p {
  margin: 0;
  color: var(--muted);
}

.delta-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 800;
}

.delta-badge.positive {
  background: rgba(95, 115, 136, 0.14);
  color: var(--success);
}

.delta-badge.negative {
  background: rgba(138, 97, 113, 0.14);
  color: var(--danger);
}

.delta-badge.neutral {
  background: rgba(53, 71, 100, 0.08);
  color: var(--muted);
}

.executive-bars {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.executive-bar-row {
  display: grid;
  gap: 8px;
}

.executive-bar-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.executive-bar-meta span {
  color: var(--muted);
  font-weight: 700;
}

.executive-bar-track {
  height: 12px;
  border-radius: 999px;
  background: rgba(53, 71, 100, 0.08);
  overflow: hidden;
}

.executive-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand), var(--teal));
}

.executive-bars.is-payment .executive-bar-fill {
  background: linear-gradient(90deg, var(--teal), #8da4ca);
}

.executive-bars.is-products .executive-bar-fill {
  background: linear-gradient(90deg, var(--brand-dark), var(--brand));
}

.executive-bars.is-clients .executive-bar-fill {
  background: linear-gradient(90deg, #6a7fa1, var(--teal));
}

.executive-analysis-grid,
.executive-bottom-grid,
.executive-board-grid {
  align-items: stretch;
}

.progress-item {
  display: grid;
  gap: 8px;
}

.progress-track {
  height: 10px;
  border-radius: 999px;
  background: rgba(53, 71, 100, 0.08);
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--brand), #8b9dbd);
}

.system-tabs-shell {
  display: grid;
  gap: 18px;
}

.system-tabs-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.system-tab {
  border: 1px solid rgba(53, 71, 100, 0.14);
  background: rgba(255, 255, 255, 0.72);
  color: var(--heading);
  padding: 12px 18px;
  border-radius: 999px;
  font-weight: 800;
  cursor: pointer;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.system-tab:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.24);
}

.system-tab.is-active {
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.96), rgba(83, 106, 148, 0.92));
  color: #f6f8fc;
  border-color: transparent;
  box-shadow: var(--shadow-md);
}

.system-tab-panel.is-hidden {
  display: none;
}

.pdv-mobile-steps {
  display: grid;
  gap: 12px;
}

.pdv-mobile-summary {
  display: grid;
  gap: 10px;
}

.pdv-mobile-summary__toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 0;
  background: transparent;
  padding: 0;
  text-align: left;
}

.pdv-mobile-summary__toggle span {
  display: grid;
  gap: 3px;
}

.pdv-mobile-summary__toggle strong {
  color: var(--heading);
}

.pdv-mobile-summary__toggle small {
  color: var(--muted);
}

.pdv-mobile-summary__toggle svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  transition: transform 0.18s ease;
}

.pdv-mobile-summary__toggle svg.is-expanded {
  transform: rotate(180deg);
}

.pdv-mobile-summary__content.is-hidden {
  display: none;
}

.pdv-mobile-summary__stats {
  margin-top: 2px;
}

.pdv-mobile-steps__nav {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.pdv-mobile-step {
  border: 1px solid rgba(53, 71, 100, 0.1);
  border-radius: 18px;
  padding: 14px 12px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--muted);
  text-align: left;
  display: grid;
  gap: 4px;
}

.pdv-mobile-step strong {
  color: var(--heading);
  font-size: 0.9rem;
}

.pdv-mobile-step span {
  font-size: 0.76rem;
  line-height: 1.3;
}

.pdv-mobile-step.is-active {
  background: rgba(53, 71, 100, 0.1);
  border-color: rgba(53, 71, 100, 0.18);
}

.pdv-mobile-step:disabled {
  opacity: 0.5;
}

.pdv-mobile-stage-grid,
.pdv-mobile-stage-lines,
.pdv-mobile-stage-catalog {
  margin-top: 16px;
}

.pdv-mobile-cta-spacer {
  height: 176px;
}

.pdv-mobile-cta {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: calc(104px + env(safe-area-inset-bottom));
  z-index: 119;
  padding: 14px;
  border-radius: 22px;
  background: rgba(248, 250, 255, 0.96);
  border: 1px solid rgba(53, 71, 100, 0.1);
  box-shadow: 0 18px 34px rgba(37, 50, 73, 0.16);
  backdrop-filter: blur(16px);
}

.pdv-mobile-cta__summary {
  display: grid;
  gap: 4px;
  margin-bottom: 12px;
}

.pdv-mobile-cta__summary strong {
  color: var(--heading);
  font-size: 1rem;
}

.pdv-mobile-cta__summary span {
  color: var(--muted);
  font-size: 0.82rem;
}

.pdv-mobile-cta__actions {
  flex-wrap: wrap;
}

.pdv-mobile-cta__actions--split > * {
  flex: 1 1 0;
}

.pdv-mobile-cta__actions--stack {
  display: grid;
  gap: 10px;
}

.pdv-quick-actions {
  display: grid;
  gap: 14px;
}

.pdv-quick-actions__group {
  display: grid;
  gap: 8px;
}

.pdv-quick-actions__group span {
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.pdv-quick-actions__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.client-history-tabs {
  gap: 14px;
}

.client-history-tabs .system-tabs-nav {
  padding: 8px;
  border-radius: 18px;
  background: rgba(214, 218, 237, 0.45);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.client-history-tabs .system-tab {
  flex: 1 1 220px;
  justify-content: center;
}

.client-history-panel {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.kit-items-picker {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 10px;
}

.kit-items-toolbar {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(180px, 0.8fr) auto;
  gap: 12px;
  align-items: center;
}

.kit-items-search input {
  margin: 0;
}

.kit-items-category-filter select {
  margin: 0;
}

.kit-items-toolbar__meta {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: var(--heading);
  white-space: nowrap;
}

.kit-items-results {
  color: var(--muted);
  font-size: 0.84rem;
  padding: 0 2px;
}

.kit-items-selected {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.kit-items-selected.is-empty {
  padding: 12px 14px;
}

.kit-items-selected__empty {
  color: var(--muted);
  font-size: 0.88rem;
}

.kit-selected-tag {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(83, 106, 148, 0.1);
  color: var(--heading);
  font-size: 0.82rem;
  font-weight: 600;
}

.kit-items-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
  max-height: 280px;
  overflow: auto;
  padding: 4px;
  align-content: start;
}

.kit-item-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px solid rgba(53, 71, 100, 0.1);
  background: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.kit-item-card[hidden] {
  display: none;
}

.kit-item-card:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.2);
  box-shadow: 0 8px 22px rgba(53, 71, 100, 0.08);
}

.kit-item-card.is-selected {
  border-color: rgba(83, 106, 148, 0.32);
  background: linear-gradient(180deg, rgba(83, 106, 148, 0.12), rgba(83, 106, 148, 0.05));
  box-shadow: 0 10px 24px rgba(83, 106, 148, 0.12);
}

.kit-item-card__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-top: 2px;
}

.kit-item-card__check input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.kit-item-card__content {
  min-width: 0;
}

.kit-item-card__content strong {
  display: block;
  color: var(--heading);
  font-size: 0.9rem;
  line-height: 1.25;
}

.kit-item-card__content span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.78rem;
}

.kit-items-empty-search {
  margin: 0;
  padding: 4px 2px 0;
}

.kit-items-empty-search[hidden] {
  display: none;
}

.kit-items-pagination {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}

.kit-items-pagination[hidden] {
  display: none;
}

.kit-items-pagination__info {
  min-width: 110px;
  text-align: center;
  color: var(--muted);
  font-size: 0.84rem;
}

@media (max-width: 720px) {
  .kit-items-toolbar {
    grid-template-columns: 1fr;
  }

  .kit-items-toolbar__meta {
    justify-content: space-between;
  }

  .kit-items-list {
    grid-template-columns: 1fr;
    max-height: 240px;
  }

  .kit-items-pagination {
    justify-content: space-between;
  }
}

.panel-nested {
  box-shadow: none;
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.empty-state {
  padding: 34px 22px;
  text-align: center;
  border: 1px dashed rgba(53, 71, 100, 0.18);
  border-radius: 18px;
  color: var(--muted);
}

.order-lines {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.item-line {
  justify-content: space-between;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.qty-stepper {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border-radius: 999px;
  background: #e4e9f3;
  padding: 6px 10px;
}

.qty-stepper button {
  border: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #f8faff;
}

.hero-banner {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 18px;
  padding: 26px;
  border-radius: var(--radius-xl);
  background: linear-gradient(120deg, rgba(43, 58, 83, 0.98), rgba(83, 106, 148, 0.9));
  color: #f5f8fd;
  box-shadow: var(--shadow-lg);
}

.hero-banner h2 {
  color: inherit;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  margin: 8px 0 12px;
}

.hero-banner p {
  color: rgba(245, 248, 253, 0.78);
}

.hero-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.hero-metrics .summary-tile {
  background: rgba(255, 255, 255, 0.12);
  color: inherit;
}

.hero-metrics .summary-tile p {
  margin: 6px 0 0;
}

.crm-hero {
  align-items: stretch;
}

.crm-hero-metrics .summary-tile strong {
  font-size: clamp(1.9rem, 3vw, 2.5rem);
}

.crm-segment-grid {
  display: grid;
  gap: 16px;
  margin-top: 22px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
}

.crm-subfilter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}

.crm-subfilter-chip {
  border: 1px solid rgba(53, 71, 100, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--heading);
  padding: 10px 16px;
  font-weight: 700;
  transition: transform 0.18s ease, border-color 0.18s ease, background 0.18s ease;
}

.crm-subfilter-chip:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.24);
}

.crm-subfilter-chip.is-active {
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.98), rgba(83, 106, 148, 0.92));
  color: #f5f8fd;
  border-color: transparent;
}

.crm-subfilter-helper {
  margin-top: 12px;
}

.crm-segment-card {
  border: 1px solid rgba(53, 71, 100, 0.12);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.68);
  padding: 18px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: space-between;
  min-height: 150px;
  gap: 8px;
  text-align: left;
  transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease;
}

.crm-segment-card strong {
  font-size: 1.9rem;
  color: var(--heading);
}

.crm-segment-card small,
.crm-client-card__header p,
.crm-priority-item p,
.crm-client-stat span {
  color: var(--muted);
}

.crm-segment-card:hover {
  transform: translateY(-2px);
  border-color: rgba(53, 71, 100, 0.24);
  box-shadow: var(--shadow-md);
}

.crm-segment-card.is-active {
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.98), rgba(83, 106, 148, 0.92));
  border-color: transparent;
  box-shadow: var(--shadow-md);
}

.crm-segment-card.is-active,
.crm-segment-card.is-active strong,
.crm-segment-card.is-active small,
.crm-segment-card.is-active .crm-segment-title {
  color: #f5f8fd;
}

.crm-segment-title {
  font-weight: 800;
  color: var(--heading);
}

.crm-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(320px, 0.9fr);
  gap: 18px;
  align-items: start;
}

.crm-main-panel {
  min-width: 0;
}

.crm-clients-grid,
.crm-side-stack {
  display: grid;
  gap: 16px;
}

.crm-clients-grid {
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.crm-client-card {
  border-radius: 22px;
  border: 1px solid rgba(53, 71, 100, 0.1);
  background: rgba(255, 255, 255, 0.74);
  padding: 20px;
  display: grid;
  gap: 16px;
}

.crm-client-card__header,
.crm-client-card__actions,
.crm-client-card__tags,
.crm-priority-item {
  display: flex;
  align-items: center;
  gap: 10px;
}

.crm-client-card__header,
.crm-priority-item {
  justify-content: space-between;
}

.crm-client-card__header h3,
.crm-priority-item strong {
  margin: 0;
}

.crm-client-card__tags,
.crm-client-card__actions {
  flex-wrap: wrap;
}

.crm-client-card__tags .role-chip {
  background: rgba(53, 71, 100, 0.08);
  color: var(--heading);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.crm-client-card__tags .tag {
  color: var(--heading);
}

.crm-client-card__tags .tag.info {
  color: var(--teal);
}

.crm-client-card__tags .tag.warning {
  color: var(--warning);
}

.crm-client-card__tags .tag.danger {
  color: var(--danger);
}

.crm-client-card__body {
  display: grid;
  gap: 10px;
}

.crm-client-stat {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(214, 218, 237, 0.28);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.crm-client-stat strong {
  display: block;
  margin-top: 4px;
}

.crm-side-panel {
  padding: 18px;
}

.crm-priority-list {
  display: grid;
  gap: 10px;
}

.crm-priority-item {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.crm-priority-item span {
  font-weight: 800;
  color: var(--heading);
  white-space: nowrap;
}

.reservation-modal-layout {
  display: grid;
  gap: 18px;
}

.reservation-modal-summary-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.reservation-modal-grid {
  align-items: start;
}

.reservation-modal-section {
  display: grid;
  gap: 14px;
}

.reservation-modal-section h3 {
  margin: 0;
}

.reservation-detail-list {
  display: grid;
  gap: 10px;
}

.reservation-detail-item {
  display: grid;
  gap: 6px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.reservation-detail-item span {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--muted);
}

.reservation-detail-item strong {
  color: var(--heading);
}

.reservation-items-list {
  display: grid;
  gap: 12px;
}

.reservation-item-card {
  padding: 16px 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.reservation-item-card p {
  margin: 6px 0 0;
}

.reservation-item-card .list-row span {
  font-weight: 800;
  color: var(--heading);
}

.reservation-modal-actions {
  margin-top: 4px;
  justify-content: flex-end;
}

.modal-root-open {
  overflow: hidden;
}

.modal-overlay {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(39, 53, 75, 0.4);
  backdrop-filter: blur(8px);
  z-index: 1000;
}

.modal-card {
  width: min(920px, 100%);
  max-height: calc(100vh - 48px);
  overflow: auto;
  padding: 22px;
  border-radius: 24px;
  background: #f8faff;
  box-shadow: var(--shadow-lg);
}

.modal-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.modal-header h3 {
  margin: 0;
}

.modal-body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.user-modal-form {
  gap: 14px;
}

.permissions-panel {
  padding: 18px;
}

.permission-group + .permission-group {
  margin-top: 20px;
}

.permission-group__header {
  margin-bottom: 12px;
}

.permission-group__header strong {
  display: block;
  color: var(--heading);
  font-size: 0.96rem;
  margin-bottom: 4px;
}

.permission-group__header p {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.permission-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
}

.permission-card {
  display: grid;
  grid-template-columns: auto auto minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.1);
  background: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(53, 71, 100, 0.05);
  transition: transform 160ms ease, border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.permission-card:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.2);
  box-shadow: 0 14px 32px rgba(53, 71, 100, 0.08);
}

.permission-card.is-selected {
  border-color: rgba(83, 106, 148, 0.32);
  background: linear-gradient(180deg, rgba(83, 106, 148, 0.12), rgba(83, 106, 148, 0.05));
  box-shadow: 0 16px 34px rgba(83, 106, 148, 0.12);
}

.permission-card__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding-top: 2px;
}

.permission-card__check input {
  width: 18px;
  height: 18px;
  margin: 0;
}

.module-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(53, 71, 100, 0.08);
  color: var(--brand-dark);
}

.module-icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.permission-card__content {
  min-width: 0;
  align-self: center;
}

.permission-card__content strong {
  display: block;
  margin: 0;
  color: var(--heading);
  font-size: 0.98rem;
  line-height: 1.2;
}

.permission-chip {
  display: inline-flex;
  margin-top: 8px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  white-space: nowrap;
}

.permission-chip.is-on {
  background: rgba(95, 115, 136, 0.14);
  color: var(--success);
}

.permission-chip.is-off {
  background: rgba(53, 71, 100, 0.08);
  color: var(--muted);
}

.permission-summary-cell {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.users-filter-panel {
  margin-bottom: 16px;
}

.settings-mobile-list {
  margin-top: 16px;
}

.settings-profile-card,
.settings-audit-card {
  gap: 16px;
}

.settings-profile-card__title,
.settings-audit-card__title {
  display: grid;
  gap: 6px;
}

.settings-profile-card__title p,
.settings-audit-card__title p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.settings-profile-card__badges,
.settings-profile-card__modules {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.settings-audit-filter-panel {
  margin-bottom: 18px;
}

.settings-audit-filter-panel__submit {
  display: flex;
  align-items: flex-end;
}

.user-mobile-card {
  gap: 16px;
}

.user-mobile-card__title {
  display: grid;
  gap: 6px;
}

.user-mobile-card__title p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.user-mobile-card__permissions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.user-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 12px;
}

.toast-root {
  position: fixed;
  right: 24px;
  bottom: 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  z-index: 1100;
}

.toast {
  min-width: 280px;
  padding: 14px 16px;
  border-radius: 16px;
  color: #f8faff;
  box-shadow: var(--shadow-lg);
}

.toast.info {
  background: #354764;
}

.toast.success {
  background: var(--success);
}

.toast.warning {
  background: var(--warning);
}

.toast.danger {
  background: var(--danger);
}

.print-sheet {
  background: #fff;
  color: #1e1a18;
  border: 1px solid rgba(30, 26, 24, 0.12);
  border-radius: 18px;
  padding: 30px;
}

.print-header {
  display: flex;
  justify-content: space-between;
  gap: 24px;
  padding-bottom: 18px;
  border-bottom: 2px solid rgba(30, 26, 24, 0.1);
}

.print-header h2 {
  margin: 6px 0 10px;
  font-size: 2rem;
}

.print-kicker {
  margin: 0;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-dark);
  font-weight: 800;
}

.print-doc-meta,
.print-section,
.print-signatures,
.print-clauses {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.print-doc-meta span,
.print-section p,
.print-section li,
.print-footer-note {
  margin: 0;
  line-height: 1.6;
}

.print-grid {
  display: grid;
  gap: 16px;
}

.print-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.print-grid.three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.print-section {
  margin-top: 22px;
}

.print-table {
  width: 100%;
  border-collapse: collapse;
}

.print-table th,
.print-table td {
  padding: 12px 10px;
  border-bottom: 1px solid rgba(30, 26, 24, 0.1);
  text-align: left;
  vertical-align: top;
}

.print-table th {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.76rem;
}

.print-financial-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.print-financial-grid div {
  padding: 14px;
  border: 1px solid rgba(30, 26, 24, 0.1);
  border-radius: 14px;
  background: #faf7f3;
}

.print-financial-grid span {
  display: block;
  color: #6b625b;
  margin-bottom: 6px;
}

.print-financial-grid strong {
  font-size: 1.05rem;
}

.print-financial-grid .highlight {
  background: #354764;
  color: #f7f9fd;
}

.print-financial-grid .highlight span {
  color: rgba(247, 249, 253, 0.72);
}

.print-signatures {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  margin-top: 30px;
}

.print-signatures div {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.calendar-lanes,
.unit-board {
  display: grid;
  gap: 16px;
}

.calendar-lanes {
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.calendar-day {
  border: 1px solid var(--panel-border);
  border-radius: 20px;
  background: var(--panel);
  padding: 18px;
  box-shadow: var(--shadow-md);
}

.calendar-day-header {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.calendar-day-header strong {
  font-size: 1.05rem;
}

.calendar-stack,
.unit-stack {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.calendar-card,
.unit-card {
  border-radius: 16px;
  padding: 14px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.8);
}

.calendar-card.is-retirada {
  border-left: 4px solid var(--teal);
}

.calendar-card.is-devolucao {
  border-left: 4px solid var(--warning);
}

.unit-card.is-highlighted {
  border-color: rgba(83, 106, 148, 0.34);
  background: linear-gradient(135deg, rgba(232, 238, 249, 0.96), rgba(255, 255, 255, 0.92));
  box-shadow: 0 18px 34px rgba(83, 106, 148, 0.14);
}

.calendar-card.is-clickable {
  cursor: pointer;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.calendar-card.is-clickable:hover {
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(37, 50, 73, 0.12);
  border-color: rgba(53, 71, 100, 0.18);
}

.calendar-card.is-pending-pickup {
  border-color: rgba(53, 71, 100, 0.16);
  background: rgba(255, 255, 255, 0.8);
  box-shadow: var(--shadow-md);
}

.calendar-card.is-overdue {
  border-color: rgba(53, 71, 100, 0.16);
  background: rgba(255, 255, 255, 0.8);
  box-shadow: var(--shadow-md);
}

.calendar-card.is-confirmed {
  border-color: rgba(83, 106, 148, 0.28);
}

.calendar-card.is-cancelled {
  opacity: 0.7;
  background: rgba(232, 236, 245, 0.82);
}

.compact-filter-panel {
  display: grid;
  gap: 14px;
  margin-bottom: 18px;
}

.compact-filter-panel__header,
.compact-filter-panel__actions,
.agenda-toolbar,
.agenda-toolbar__views {
  display: flex;
  align-items: center;
  gap: 10px;
}

.compact-filter-panel__header {
  justify-content: space-between;
}

.compact-filter-panel__actions,
.agenda-toolbar__views {
  flex-wrap: wrap;
}

.compact-filter-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.compact-filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(53, 71, 100, 0.1);
  color: var(--muted);
  font-size: 0.8rem;
  white-space: nowrap;
}

.compact-filter-chip strong {
  color: var(--heading);
}

.compact-filter-toggle {
  display: none;
}

.report-focus-bar {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.report-focus-chip {
  display: grid;
  gap: 6px;
  text-align: left;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease, background 160ms ease;
}

.report-focus-chip strong {
  color: var(--heading);
}

.report-focus-chip span {
  font-size: 0.8rem;
}

.report-focus-chip:hover,
.report-focus-chip:focus-visible,
.report-focus-chip.is-active {
  border-color: rgba(83, 106, 148, 0.18);
  background: rgba(83, 106, 148, 0.1);
  color: var(--heading);
  box-shadow: 0 14px 28px rgba(37, 50, 73, 0.08);
}

.report-mobile-card-list,
.agenda-filter-panel {
  margin-bottom: 0;
}

.agenda-summary-strip {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  margin-bottom: 18px;
}

.calendar-card-highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 8px;
}

.calendar-card-highlights.compact {
  margin: 8px 0 0;
}

.tag.is-invisible {
  visibility: hidden;
  pointer-events: none;
}

.agenda-order-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  margin: 12px 0;
}

.agenda-order-grid.is-compact {
  grid-template-columns: 1fr;
  margin: 12px 0 0;
}

.calendar-card-tags {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.calendar-card-tags .tag:not(.info):not(.warning):not(.danger):not(.success) {
  background: rgba(53, 71, 100, 0.08);
  color: var(--heading);
}

.agenda-order-block .status-badge {
  max-width: 100%;
}

.agenda-order-block,
.agenda-detail-section {
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(53, 71, 100, 0.04);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.agenda-order-block span,
.agenda-detail-section span {
  display: block;
  margin-bottom: 6px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--muted);
}

.agenda-order-block strong {
  display: block;
  color: var(--heading);
}

.agenda-order-block.agenda-order-block-type.is-retirada {
  background: rgba(53, 71, 100, 0.04);
  border-color: rgba(53, 71, 100, 0.08);
}

.agenda-order-block.agenda-order-block-type.is-devolucao {
  background: rgba(53, 71, 100, 0.04);
  border-color: rgba(53, 71, 100, 0.08);
}

.agenda-order-details {
  display: grid;
  gap: 10px;
}

.agenda-detail-section p {
  margin: 0;
}

.agenda-detail-line .list-row span {
  font-weight: 800;
  color: var(--heading);
}

.calendar-card header,
.unit-card header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.unit-board {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.unit-card p,
.calendar-card p {
  margin: 6px 0 0;
}

.unit-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.print-toolbar {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
}

.payment-method-grid {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.payment-method-grid.payment-method-grid-compact {
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(104px, 1fr));
}

.payment-option {
  border: 1px solid rgba(53, 71, 100, 0.12);
  border-radius: 16px;
  min-height: 92px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.82);
  text-align: left;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  box-shadow: none;
  transition: 160ms ease;
}

.payment-method-grid-compact .payment-option {
  min-height: 74px;
  padding: 12px;
  gap: 4px;
  border-radius: 14px;
}

.payment-option:hover {
  transform: translateY(-1px);
  border-color: rgba(53, 71, 100, 0.24);
}

.payment-option.is-selected {
  border-color: rgba(53, 71, 100, 0.38);
  background: rgba(53, 71, 100, 0.08);
  box-shadow: 0 10px 20px rgba(53, 71, 100, 0.12);
}

.payment-option strong,
.payment-option span {
  display: block;
}

.payment-option span {
  margin-top: 6px;
  color: var(--muted);
  font-size: 0.84rem;
}

.payment-method-grid-compact .payment-option strong {
  font-size: 0.95rem;
}

.payment-method-grid-compact .payment-option span {
  margin-top: 2px;
  font-size: 0.78rem;
  line-height: 1.2;
}

.payment-summary-box {
  padding: 18px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.1), rgba(209, 217, 231, 0.5));
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.payment-summary-box .list-row + .list-row {
  margin-top: 10px;
}

.pdv-credit-notice {
  margin: 8px 0 0;
  color: var(--warning);
  font-size: 0.9rem;
}

.pdv-credit-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(53, 71, 100, 0.06);
  border: 1px solid rgba(53, 71, 100, 0.08);
  cursor: pointer;
}

.pdv-credit-toggle input {
  width: 18px;
  height: 18px;
}

.pdv-overpayment-warning {
  margin-top: 14px;
  padding: 14px 16px;
  border-radius: 14px;
  background: rgba(140, 127, 97, 0.12);
  border: 1px solid rgba(140, 127, 97, 0.22);
  color: #5d523a;
}

.return-line-card {
  border: 1px solid rgba(53, 71, 100, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.8);
  padding: 18px;
}

.return-checklist {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.return-check-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 14px;
  border-radius: 14px;
  background: #eef2f8;
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.return-check-item input {
  width: 18px;
  height: 18px;
}

@media (max-width: 1280px) {
  .four-column,
  .stats-grid,
  .three-column,
  .two-column,
  .hero-banner,

  .crm-overview-grid {
    grid-template-columns: 1fr;
  }

  .crm-subfilter-bar {
    flex-direction: column;
  }

  .crm-segment-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .reservation-modal-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .executive-hero {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .executive-kpi-grid,
  .comparison-chart {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    display: none;
  }

  .topbar {
    position: sticky;
    top: 0;
    z-index: 110;
    align-items: center;
    margin: -20px -20px 20px;
    padding: calc(14px + env(safe-area-inset-top)) 20px 14px;
    background: linear-gradient(180deg, rgba(214, 218, 237, 0.96), rgba(214, 218, 237, 0.82));
    backdrop-filter: blur(18px);
    border-bottom: 1px solid rgba(53, 71, 100, 0.08);
  }

  .topbar > :first-child {
    flex: 1 1 auto;
    min-width: 0;
  }

  .topbar h1 {
    font-size: clamp(1.6rem, 6vw, 2.2rem);
  }

  .workspace {
    padding: 20px 20px calc(126px + env(safe-area-inset-bottom));
  }

  .mobile-menu-toggle {
    display: inline-flex;
  }

  .mobile-nav-shell {
    display: block;
  }

  .topbar-actions {
    width: auto;
    justify-content: flex-end;
    flex-wrap: nowrap;
  }

  .topbar-actions .btn {
    width: auto;
  }

  .pdv-mobile-only {
    display: block;
  }

  .mobile-step-section.is-mobile-hidden {
    display: none;
  }

  .form-grid,
  .hero-banner,
  .executive-hero,
  .executive-kpi-grid,
  .comparison-chart,
  .two-column,
  .three-column,
  .four-column,
  .stats-grid {
    grid-template-columns: 1fr;
  }

  .span-3,
  .span-4,
  .span-5,
  .span-6,
  .span-7,
  .span-8,
  .span-9,
  .span-12 {
    grid-column: span 12;
  }
}

@media (max-width: 640px) {
  .workspace {
    padding: 18px 18px calc(130px + env(safe-area-inset-bottom));
  }

  .app-footer {
    margin-top: 20px;
    min-height: 0;
    padding-top: 16px;
    font-size: 0.76rem;
  }

  .app-footer-meta {
    flex-direction: column;
    gap: 10px;
  }

  .panel,
  .card,
  .metric-card,
  .timeline-card,
  .summary-tile,
  .catalog-card-content,
  .modal-card {
    padding: 18px;
  }

  .panel-header,
  .toolbar,
  .item-line,
  .kpi-row,
  .client-summary,
  .executive-metric-head,
  .executive-bar-meta {
    flex-direction: column;
    align-items: stretch;
  }

  .btn,
  .btn-inline {
    width: 100%;
  }

  .topbar {
    align-items: flex-start;
    margin: -18px -18px 18px;
    padding: calc(12px + env(safe-area-inset-top)) 18px 12px;
  }

  .topbar-actions {
    margin-left: auto;
    flex-direction: row;
    align-items: center;
    justify-content: flex-end;
  }

  .topbar-actions .btn,
  .mobile-menu-toggle {
    width: auto;
  }

  .topbar-actions #logout-button {
    display: none;
  }

  .mobile-menu-toggle {
    width: 52px;
    height: 52px;
  }

  .today-pill {
    display: none;
  }

  .mobile-bottom-nav {
    left: 12px;
    right: 12px;
    bottom: calc(12px + env(safe-area-inset-bottom));
    gap: 6px;
    padding: 8px;
  }

  .mobile-bottom-nav__item {
    min-height: 66px;
    padding: 8px 2px;
  }

  .mobile-bottom-nav__item span {
    font-size: 0.6rem;
  }

  .mobile-drawer {
    width: 100vw;
    max-width: 100vw;
    border-radius: 0;
    padding-inline: 0;
  }

  .desktop-table-shell {
    display: none;
  }

  .mobile-record-list {
    display: grid;
  }

  .mobile-record-card__head,
  .mobile-record-card__actions,
  .pdv-mobile-steps__nav {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: stretch;
  }

  .mobile-record-card__stats,
  .availability-card-mobile__stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pdv-client-suggestions {
    grid-template-columns: 1fr;
  }

  .pdv-quick-actions__buttons {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pdv-mobile-cta {
    left: 12px;
    right: 12px;
    bottom: calc(96px + env(safe-area-inset-bottom));
  }

  .pdv-mobile-cta__actions--split > * {
    flex: 1 1 100%;
  }

  .field-inline-action {
    grid-template-columns: 1fr;
  }

  .permission-grid {
    grid-template-columns: 1fr;
  }

  .permission-card {
    grid-template-columns: auto auto minmax(0, 1fr);
  }

  .user-modal-actions {
    flex-direction: column;
  }

  .catalog-card-actions {
    grid-template-columns: 1fr;
  }

  .crm-segment-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .reservation-modal-summary-grid {
    grid-template-columns: 1fr;
  }

  .crm-client-card__header,
  .crm-priority-item,
  .crm-client-card__actions {
    flex-direction: column;
    align-items: stretch;
  }

  [data-pdv-panel='catalog'] .catalog-grid {
    grid-template-columns: 1fr;
  }

  .catalog-category-nav {
    margin-bottom: 14px;
    padding-bottom: 4px;
    overflow-x: auto;
  }

  .catalog-category-menu__panel {
    right: auto;
    left: 0;
    min-width: 200px;
  }

  .print-grid.two,
  .print-grid.three,
  .print-financial-grid,
  .print-signatures {
    grid-template-columns: 1fr;
  }
}

/* ===== Gestão financeira pessoal ===== */

.personal-finance-page {
  gap: 18px;
}

.pf-mobile-actions {
  display: none;
}

.pf-hero-panel {
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.12), rgba(255, 255, 255, 0.72));
}

.pf-hero-panel__header {
  align-items: flex-start;
}

.pf-sync-status {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.pf-sync-status small {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
}

.pf-toolbar-actions,
.pf-tabs,
.pf-month-switcher,
.pf-progress-card__head,
.pf-alert-card__head,
.pf-bar-meta {
  display: flex;
  align-items: center;
  gap: 12px;
}

.pf-toolbar-actions,
.pf-tabs {
  flex-wrap: wrap;
}

.pf-controls-grid {
  display: grid;
  gap: 18px;
}

.pf-month-switcher {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 420px) minmax(0, 1fr);
  align-items: center;
  gap: 18px;
  padding: 18px 20px;
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.68));
  border: 1px solid rgba(53, 71, 100, 0.08);
  box-shadow: 0 16px 32px rgba(53, 71, 100, 0.08);
}

.pf-month-switcher__nav {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 18px;
  border-radius: 16px;
  background: linear-gradient(180deg, #61779f, #4d6186);
  border: 1px solid rgba(60, 78, 112, 0.48);
  color: #f7f9fc;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(47, 63, 92, 0.24);
}

.pf-month-switcher__nav:hover,
.pf-month-switcher__nav:focus-visible {
  background: linear-gradient(180deg, #6b82ab, #556b91);
  border-color: rgba(60, 78, 112, 0.62);
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(47, 63, 92, 0.3);
}

.pf-month-switcher__center {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  text-align: center;
  grid-column: 2;
}

.pf-month-switcher__nav.is-prev {
  grid-column: 1;
  justify-self: start;
}

.pf-month-switcher__nav.is-next {
  grid-column: 3;
  justify-self: end;
}

.pf-month-switcher__nav.is-prev,
.pf-month-switcher__nav.is-next {
  width: min(190px, 100%);
}

.pf-table-pagination {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  padding-top: 18px;
}

.pf-table-pagination__info {
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.pf-table-pagination__actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.pf-table-pagination__button {
  min-width: 42px;
  min-height: 40px;
  padding: 0 14px;
  border-radius: 12px;
}

.pf-table-pagination__button.is-active {
  background: linear-gradient(180deg, #61779f, #4d6186);
  border-color: rgba(60, 78, 112, 0.48);
  color: #f7f9fc;
  box-shadow: 0 12px 24px rgba(47, 63, 92, 0.24);
}

.pf-table-pagination__button[disabled] {
  opacity: 0.52;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.pf-table-pagination__ellipsis {
  color: var(--muted);
  font-weight: 700;
  letter-spacing: 0.08em;
}

.pf-future-installments-table .data-table tbody tr {
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.pf-launches-content .data-table tbody tr {
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.pf-entry-row {
  cursor: pointer;
}

.pf-entry-row.is-static {
  cursor: default;
}

.pf-entry-row:hover,
.pf-entry-row:focus-visible {
  background: rgba(97, 119, 159, 0.08);
  box-shadow: inset 0 0 0 1px rgba(77, 97, 134, 0.14);
}

.pf-entry-row.is-static:hover,
.pf-entry-row.is-static:focus-visible {
  background: transparent;
  box-shadow: none;
}

.pf-entry-row:focus-visible {
  outline: 2px solid rgba(77, 97, 134, 0.26);
  outline-offset: -2px;
}

.pf-entry-row.is-static:focus-visible {
  outline: none;
}

.pf-future-installments-table__row {
  cursor: pointer;
}

.pf-future-installments-table__row:hover,
.pf-future-installments-table__row:focus-visible {
  background: rgba(97, 119, 159, 0.08);
  box-shadow: inset 0 0 0 1px rgba(77, 97, 134, 0.14);
}

.pf-future-installments-table__row:focus-visible {
  outline: 2px solid rgba(77, 97, 134, 0.26);
  outline-offset: -2px;
}

.pf-future-installments-table__description {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.pf-future-installments-table__description strong {
  color: var(--heading);
}

.pf-future-installments-table__description span {
  font-size: 0.8rem;
  color: var(--muted);
}

@media (max-width: 720px) {
  .pf-table-pagination {
    align-items: stretch;
  }

  .pf-table-pagination__actions {
    width: 100%;
  }

  .pf-future-installments-table__description span {
    font-size: 0.76rem;
  }
}

.pf-month-switcher__eyebrow {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-month-switcher__center strong {
  font-size: clamp(1.2rem, 2vw, 1.6rem);
  line-height: 1.1;
  text-transform: capitalize;
  color: var(--heading);
}

.pf-month-switcher__field {
  padding: 8px 10px;
  border-radius: 16px;
  background: rgba(53, 71, 100, 0.04);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.pf-month-switcher__center input {
  width: 220px;
  border: 0;
  background: transparent;
  text-align: center;
  color: var(--heading);
  font-weight: 700;
}

.pf-tabs {
  padding: 6px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.pf-tab {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  border-radius: 14px;
  padding: 10px 16px;
  font-weight: 800;
  color: var(--muted);
  background: transparent;
  transition: 160ms ease;
}

.pf-tab__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.pf-tab__icon svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pf-tab__label {
  display: inline-flex;
  align-items: center;
  white-space: nowrap;
}

.pf-tab__label-mobile {
  display: none;
}

.pf-mobile-action {
  display: grid;
  justify-items: center;
  gap: 8px;
  min-height: 72px;
  padding: 12px 10px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(53, 71, 100, 0.12);
  color: var(--heading);
  box-shadow: none;
}

.pf-mobile-action__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
}

.pf-mobile-action__icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  stroke-width: 1.8;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.pf-mobile-action__label {
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1.1;
}

.pf-tab:hover,
.pf-tab.is-active {
  background: rgba(53, 71, 100, 0.12);
  color: var(--heading);
}

.pf-filter-grid {
  display: contents;
}

.pf-bar-list,
.pf-progress-stack,
.pf-alert-stack {
  display: grid;
  gap: 14px;
}

.pf-bar-row {
  display: grid;
  gap: 8px;
}

.pf-bar-meta {
  justify-content: space-between;
}

.pf-bar-meta span,
.pf-progress-card__head span,
.pf-alert-card__head span {
  color: var(--muted);
  font-weight: 700;
}

.pf-bar-track {
  width: 100%;
  height: 12px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(53, 71, 100, 0.08);
}

.pf-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(53, 71, 100, 0.92), rgba(83, 106, 148, 0.88));
}

.pf-trend-chart {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 14px;
}

.pf-trend-card {
  display: grid;
  gap: 10px;
  padding: 14px 12px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid rgba(53, 71, 100, 0.08);
  text-align: center;
}

.pf-trend-label {
  font-weight: 800;
  color: var(--heading);
  text-transform: capitalize;
}

.pf-trend-columns {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 8px;
  min-height: 180px;
}

.pf-trend-column {
  width: 16px;
  min-height: 2px;
  border-radius: 999px 999px 6px 6px;
}

.pf-trend-column.is-income,
.pf-trend-legend .is-income {
  background: rgba(95, 115, 136, 0.9);
}

.pf-trend-column.is-expense,
.pf-trend-legend .is-expense {
  background: rgba(138, 97, 113, 0.86);
}

.pf-trend-column.is-balance,
.pf-trend-legend .is-balance {
  background: rgba(83, 106, 148, 0.86);
}

.pf-trend-legend {
  margin-top: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  color: var(--muted);
  font-size: 0.88rem;
}

.pf-trend-legend span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.pf-trend-legend i {
  width: 12px;
  height: 12px;
  border-radius: 999px;
  display: inline-block;
}

.pf-progress-card,
.pf-alert-card {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.pf-alert-card.is-danger {
  border-color: rgba(138, 97, 113, 0.22);
}

.pf-alert-card.is-warning {
  border-color: rgba(140, 127, 97, 0.22);
}

.pf-alert-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.pf-alert-card .muted-text {
  margin-top: 10px;
}

.progress-fill.is-overflow {
  background: linear-gradient(135deg, rgba(138, 97, 113, 0.94), rgba(167, 106, 126, 0.9));
}

.pf-calendar-mobile-summary,
.pf-calendar-mobile-list {
  display: none;
}

.pf-calendar-mobile-summary {
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 16px;
}

.pf-calendar-mobile-summary__card {
  display: grid;
  gap: 4px;
  padding: 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.pf-calendar-mobile-summary__card strong {
  color: var(--heading);
  font-size: 1rem;
}

.pf-calendar-mobile-summary__card span {
  color: var(--muted);
  font-size: 0.76rem;
}

.pf-calendar-mobile-summary__card.is-revenue strong {
  color: #2a6b43;
}

.pf-calendar-mobile-summary__card.is-expense strong {
  color: #8d3030;
}

.pf-calendar-desktop-shell {
  display: block;
}

.pf-calendar-head,
.pf-calendar-grid {
  min-width: 720px;
}

.pf-calendar-head {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 10px;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pf-calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 10px;
  overflow-x: auto;
}

.pf-calendar-day {
  min-height: 170px;
  padding: 12px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.52);
  display: grid;
  gap: 10px;
  align-content: start;
}

.pf-calendar-day.is-today {
  border-color: rgba(77, 97, 134, 0.28);
  background: linear-gradient(180deg, rgba(214, 221, 241, 0.78), rgba(255, 255, 255, 0.72));
  box-shadow: inset 0 0 0 1px rgba(77, 97, 134, 0.08);
}

.pf-calendar-day.is-muted {
  opacity: 0.45;
}

.pf-calendar-day__head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.82rem;
  color: var(--muted);
}

.pf-calendar-day.is-today .pf-calendar-day__head strong {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 30px;
  height: 30px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(53, 71, 100, 0.12);
  color: var(--heading);
}

.pf-calendar-day__today-pill {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  margin-top: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(53, 71, 100, 0.1);
  color: var(--heading);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pf-calendar-day__items {
  display: grid;
  gap: 8px;
}

.pf-calendar-chip {
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: 16px;
  font-size: 0.82rem;
  width: 100%;
  text-align: left;
  font: inherit;
  cursor: pointer;
  border: 1px solid rgba(53, 71, 100, 0.08);
  border-left: 5px solid transparent;
  background: rgba(255, 255, 255, 0.8);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.pf-calendar-chip.is-expense {
  background: linear-gradient(135deg, rgba(176, 76, 76, 0.09), rgba(255, 255, 255, 0.94));
  border-color: rgba(176, 76, 76, 0.14);
  border-left-color: rgba(176, 76, 76, 0.98);
  box-shadow: inset 0 0 0 1px rgba(176, 76, 76, 0.03);
}

.pf-calendar-chip.is-revenue {
  background: linear-gradient(135deg, rgba(80, 156, 105, 0.09), rgba(255, 255, 255, 0.94));
  border-color: rgba(80, 156, 105, 0.14);
  border-left-color: rgba(80, 156, 105, 0.98);
  box-shadow: inset 0 0 0 1px rgba(80, 156, 105, 0.03);
}

.pf-calendar-chip.is-settled {
  border-color: rgba(53, 71, 100, 0.16);
  box-shadow: var(--shadow-md);
}

.pf-calendar-chip.is-open {
  border-color: rgba(53, 71, 100, 0.12);
}

.pf-calendar-chip__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.pf-calendar-chip__type {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-calendar-chip.is-revenue .pf-calendar-chip__type {
  background: rgba(80, 156, 105, 0.12);
  color: #2a6b43;
}

.pf-calendar-chip.is-expense .pf-calendar-chip__type {
  background: rgba(176, 76, 76, 0.12);
  color: #8d3030;
}

.pf-calendar-chip__status {
  padding: 3px 8px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pf-calendar-chip__status.is-settled {
  background: rgba(80, 156, 105, 0.14);
  color: #2a6b43;
}

.pf-calendar-chip.is-expense .pf-calendar-chip__status.is-open {
  background: rgba(176, 76, 76, 0.12);
  color: #8d3030;
}

.pf-calendar-chip.is-revenue .pf-calendar-chip__status.is-open {
  background: rgba(95, 115, 136, 0.12);
  color: #435672;
}

.pf-calendar-chip__amount {
  color: var(--heading);
  font-weight: 700;
}

.pf-calendar-chip__helper {
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.35;
}

.pf-calendar-chip.is-revenue .pf-calendar-chip__amount {
  color: #2a6b43;
}

.pf-calendar-chip.is-expense .pf-calendar-chip__amount {
  color: #8d3030;
}

.pf-calendar-chip strong {
  color: var(--heading);
}

.pf-calendar-chip:hover,
.pf-calendar-chip:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 16px 30px rgba(37, 50, 73, 0.12);
  border-color: rgba(53, 71, 100, 0.18);
}

.pf-calendar-chip:focus-visible {
  outline: 2px solid rgba(53, 71, 100, 0.2);
  outline-offset: 2px;
}

.pf-calendar-mobile-day {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 20px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.62);
}

.pf-calendar-mobile-day.is-today {
  border-color: rgba(77, 97, 134, 0.24);
  background: linear-gradient(180deg, rgba(214, 221, 241, 0.82), rgba(255, 255, 255, 0.74));
}

.pf-calendar-mobile-day + .pf-calendar-mobile-day {
  margin-top: 12px;
}

.pf-calendar-mobile-day__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.pf-calendar-mobile-day__head strong {
  display: block;
  color: var(--heading);
  font-size: 1rem;
  text-transform: capitalize;
}

.pf-calendar-mobile-day__head p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.8rem;
}

.pf-calendar-mobile-day__totals {
  display: grid;
  gap: 6px;
  justify-items: end;
}

.pf-calendar-mobile-day__totals span {
  display: inline-flex;
  align-items: center;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 800;
}

.pf-calendar-mobile-day__totals .is-revenue {
  background: rgba(80, 156, 105, 0.12);
  color: #2a6b43;
}

.pf-calendar-mobile-day__totals .is-expense {
  background: rgba(176, 76, 76, 0.12);
  color: #8d3030;
}

.pf-calendar-mobile-day__items {
  display: grid;
  gap: 10px;
}

.pf-mobile-summary {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-bottom: 16px;
}

.pf-mobile-summary__card {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(53, 71, 100, 0.08);
}

.pf-mobile-summary__card span,
.pf-plan-highlight span,
.pf-plan-note span {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-mobile-summary__card strong,
.pf-plan-highlight strong,
.pf-plan-note strong,
.pf-entry-card__amount {
  color: var(--heading);
}

.pf-mobile-summary__card strong,
.pf-entry-card__amount {
  font-size: 1.08rem;
  font-weight: 800;
}

.pf-mobile-summary__card small,
.pf-plan-highlight small,
.pf-plan-note p,
.pf-entry-card__description p {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.pf-entry-card__settlement {
  font-weight: 700;
}

.pf-mobile-summary__card.is-revenue strong {
  color: #2a6b43;
}

.pf-mobile-summary__card.is-expense strong {
  color: #8d3030;
}

.pf-entry-card {
  gap: 16px;
}

.pf-entry-card[data-pf-action="open-entry-details"] {
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease;
}

.pf-entry-card[data-pf-action="open-entry-details"]:hover,
.pf-entry-card[data-pf-action="open-entry-details"]:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(53, 71, 100, 0.14);
}

.pf-entry-card[data-pf-action="open-entry-details"]:focus-visible {
  outline: 2px solid rgba(77, 97, 134, 0.26);
  outline-offset: 2px;
}

.pf-entry-card.is-static {
  cursor: default;
}

.pf-entry-card__description {
  display: grid;
  gap: 6px;
}

.pf-entry-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pf-entry-card--revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.1), rgba(255, 255, 255, 0.92));
}

.pf-entry-card--expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.08), rgba(255, 255, 255, 0.92));
}

.pf-launches-content {
  display: grid;
  gap: 4px;
}

.pf-plan-highlights {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-bottom: 18px;
}

.pf-plan-highlight,
.pf-plan-note {
  display: grid;
  gap: 8px;
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.72);
}

.pf-plan-highlight.is-expense strong {
  color: #8d3030;
}

.pf-plan-highlight.is-reserve strong {
  color: #435672;
}

.pf-plan-form {
  gap: 16px 18px;
}

.pf-plan-note {
  margin-top: 16px;
}

.pf-settings-overview {
  display: grid;
  gap: 18px;
}

.pf-settings-overview__hero {
  display: flex;
  align-items: center;
  gap: 18px;
}

.pf-settings-overview__hero p {
  margin-bottom: 0;
}

.pf-settings-highlights {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pf-settings-highlight,
.pf-settings-card,
.pf-category-item {
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.74);
}

.pf-settings-highlight {
  display: grid;
  gap: 8px;
  padding: 16px 18px;
  border-radius: 18px;
}

.pf-settings-highlight span,
.pf-settings-card__counter span {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-settings-highlight strong,
.pf-settings-card__counter strong {
  font-size: 1.18rem;
  font-weight: 800;
  color: var(--heading);
}

.pf-settings-highlight small {
  margin: 0;
  color: var(--muted);
}

.pf-settings-highlight.is-revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.12), rgba(255, 255, 255, 0.92));
}

.pf-settings-highlight.is-expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.1), rgba(255, 255, 255, 0.92));
}

.pf-settings-highlight.is-neutral {
  background: linear-gradient(180deg, rgba(87, 104, 136, 0.1), rgba(255, 255, 255, 0.92));
}

.pf-settings-grid {
  align-items: start;
}

.pf-settings-card {
  display: grid;
  gap: 18px;
  padding: 20px;
}

.pf-settings-card__header-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  margin-left: auto;
  flex: 0 0 auto;
  flex-wrap: nowrap;
}

.pf-settings-card .panel-header > div:first-child {
  flex: 1 1 auto;
  min-width: 0;
}

.pf-settings-action {
  min-width: 168px;
  padding-inline: 18px;
  border-radius: 16px;
  font-weight: 800;
  letter-spacing: 0.01em;
  white-space: nowrap;
  flex-shrink: 0;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background-color 180ms ease;
}

.pf-settings-action:hover,
.pf-settings-action:focus-visible {
  transform: translateY(-1px);
}

.pf-settings-action--revenue {
  border-color: rgba(80, 156, 105, 0.22);
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.18), rgba(255, 255, 255, 0.96));
  color: #2a6b43;
  box-shadow: 0 14px 28px rgba(80, 156, 105, 0.14);
}

.pf-settings-action--revenue:hover,
.pf-settings-action--revenue:focus-visible {
  border-color: rgba(80, 156, 105, 0.34);
  box-shadow: 0 18px 32px rgba(80, 156, 105, 0.2);
}

.pf-settings-action--expense {
  border-color: rgba(176, 76, 76, 0.2);
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.16), rgba(255, 255, 255, 0.96));
  color: #8d3030;
  box-shadow: 0 14px 28px rgba(176, 76, 76, 0.12);
}

.pf-settings-action--expense:hover,
.pf-settings-action--expense:focus-visible {
  border-color: rgba(176, 76, 76, 0.32);
  box-shadow: 0 18px 32px rgba(176, 76, 76, 0.18);
}

.pf-settings-card--revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.08), rgba(255, 255, 255, 0.92));
}

.pf-settings-card--expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.06), rgba(255, 255, 255, 0.92));
}

.pf-settings-card__counter {
  display: grid;
  gap: 4px;
  min-width: 132px;
  padding: 14px 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  text-align: right;
}

.pf-settings-card__counter small {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
}

.pf-category-list {
  display: grid;
  gap: 12px;
}

.pf-category-item {
  display: grid;
  gap: 12px;
  width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  text-align: left;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
  box-shadow: 0 12px 30px rgba(53, 71, 100, 0.05);
}

.pf-category-item.is-in-use {
  box-shadow: inset 0 0 0 1px rgba(53, 71, 100, 0.03);
}

.pf-category-item--revenue:hover,
.pf-category-item--revenue:focus-visible {
  border-color: rgba(80, 156, 105, 0.26);
  box-shadow: 0 18px 34px rgba(80, 156, 105, 0.14);
}

.pf-category-item--expense:hover,
.pf-category-item--expense:focus-visible {
  border-color: rgba(176, 76, 76, 0.24);
  box-shadow: 0 18px 34px rgba(176, 76, 76, 0.12);
}

.pf-category-item:hover,
.pf-category-item:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 18px 34px rgba(53, 71, 100, 0.12);
  border-color: rgba(77, 97, 134, 0.24);
}

.pf-category-item:focus-visible {
  outline: 2px solid rgba(77, 97, 134, 0.2);
  outline-offset: 2px;
}

.pf-category-item__header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.pf-category-item__header strong {
  color: var(--heading);
}

.pf-category-item__header p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.pf-category-item__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.pf-category-item__chevron {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 74px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(87, 104, 136, 0.1);
  color: #435672;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.pf-category-item__chevron--revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.18), rgba(255, 255, 255, 0.94));
  color: #2a6b43;
  box-shadow: inset 0 0 0 1px rgba(80, 156, 105, 0.12);
}

.pf-category-item__chevron--expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.16), rgba(255, 255, 255, 0.94));
  color: #8d3030;
  box-shadow: inset 0 0 0 1px rgba(176, 76, 76, 0.1);
}

.pf-category-modal {
  display: grid;
  gap: 16px;
}

.pf-category-modal__hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.8);
}

.pf-category-modal__hero.is-revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.14), rgba(255, 255, 255, 0.96));
}

.pf-category-modal__hero.is-expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.14), rgba(255, 255, 255, 0.96));
}

.pf-category-modal__hero strong {
  display: block;
  color: var(--heading);
  font-size: 1.1rem;
}

.pf-category-modal__hero p {
  margin: 6px 0 0;
  color: var(--muted);
}

.pf-category-modal__stats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.pf-category-modal-form {
  gap: 14px 16px;
}

.pf-category-modal-form__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.pf-category-modal__actions-secondary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pf-category-delete:disabled {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

.pf-installment-card,
.pf-recurring-card,
.pf-projection-card {
  gap: 16px;
}

.pf-entry-modal {
  display: grid;
  gap: 16px;
}

.pf-entry-modal__hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.8);
}

.pf-entry-modal__hero.is-revenue {
  background: linear-gradient(180deg, rgba(80, 156, 105, 0.14), rgba(255, 255, 255, 0.96));
}

.pf-entry-modal__hero.is-expense {
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.14), rgba(255, 255, 255, 0.96));
}

.pf-entry-modal__eyebrow {
  display: block;
  margin-bottom: 6px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-entry-modal__amount {
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--heading);
}

.pf-entry-modal__tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pf-entry-modal__tab {
  min-height: 40px;
  padding: 9px 16px;
  border-radius: 999px;
  border: 1px solid rgba(53, 71, 100, 0.12);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
  font-weight: 800;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.pf-entry-modal__tab.is-active {
  background: rgba(83, 106, 148, 0.14);
  border-color: rgba(83, 106, 148, 0.22);
  color: #435672;
  box-shadow: 0 10px 22px rgba(83, 106, 148, 0.12);
}

.pf-entry-modal__tab:hover,
.pf-entry-modal__tab:focus-visible {
  transform: translateY(-1px);
}

.pf-entry-modal__panel {
  display: none;
  gap: 16px;
}

.pf-entry-modal__panel.is-active {
  display: grid;
}

.pf-entry-modal__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.pf-entry-modal__item,
.pf-entry-modal__notes {
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.68);
}

.pf-entry-modal__item span,
.pf-entry-modal__notes span {
  display: block;
  margin-bottom: 6px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.pf-entry-modal__notes p {
  margin: 0;
}

.pf-entry-installment-list {
  margin-top: 16px;
}

.pf-entry-installment-card {
  gap: 16px;
}

.pf-entry-installment-row,
.pf-entry-installment-card {
  cursor: pointer;
}

.pf-entry-installment-row td {
  transition: background-color 0.16s ease;
}

.pf-entry-installment-row:hover td {
  background: rgba(83, 106, 148, 0.08);
}

.pf-entry-installment-card {
  transition: transform 0.16s ease, box-shadow 0.16s ease, border-color 0.16s ease;
}

.pf-entry-installment-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 10px 22px rgba(38, 56, 84, 0.12);
  border-color: rgba(83, 106, 148, 0.3);
}

.pf-entry-installment-row:focus-visible,
.pf-entry-installment-card:focus-visible {
  outline: 2px solid rgba(83, 106, 148, 0.45);
  outline-offset: -2px;
}

.pf-entry-installment-inline {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
}

.pf-entry-installment-inline strong {
  color: var(--heading);
}

.pf-entry-installment-inline-action {
  min-width: auto;
  min-height: 32px;
  padding: 6px 12px;
}

.pf-entry-installment-actions {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
}

.pf-entry-installment-actions .pf-entry-installment-inline-action {
  white-space: nowrap;
}

.pf-entry-installment-action-cell {
  min-width: 170px;
}

.pf-entry-installment-action-cell .pf-entry-installment-inline-action {
  white-space: nowrap;
}

.pf-entry-installment-mobile-meta {
  align-items: center;
}

.pf-entry-installment-mobile-meta .pf-entry-installment-actions {
  width: 100%;
  margin-top: 4px;
}

.pf-entries-table .data-table td:last-child {
  min-width: 270px;
}

.pf-entry-actions {
  flex-wrap: wrap;
  gap: 8px;
}

.pf-entry-action {
  min-width: 92px;
  min-height: 40px;
  padding: 9px 14px;
  border-radius: 999px;
  font-size: 0.82rem;
  box-shadow: none;
  justify-content: center;
  text-align: center;
}

.pf-entry-action.is-details {
  background: rgba(95, 115, 136, 0.12);
  color: var(--heading);
  border: 1px solid rgba(95, 115, 136, 0.12);
}

.pf-entry-action.is-edit {
  background: rgba(83, 106, 148, 0.14);
  color: #435672;
  border: 1px solid rgba(83, 106, 148, 0.16);
}

.pf-entry-action.is-status {
  background: rgba(80, 156, 105, 0.16);
  color: #2a6b43;
  border: 1px solid rgba(80, 156, 105, 0.18);
}

.pf-entry-action.is-status:hover,
.pf-entry-action.is-status:focus-visible {
  box-shadow: 0 8px 18px rgba(80, 156, 105, 0.2);
}

.pf-entry-action.is-reopen {
  background: rgba(205, 140, 58, 0.16);
  color: #865323;
  border: 1px solid rgba(205, 140, 58, 0.24);
}

.pf-entry-action.is-reopen:hover,
.pf-entry-action.is-reopen:focus-visible {
  box-shadow: 0 8px 18px rgba(205, 140, 58, 0.22);
}

.pf-entry-action.is-danger,
.pf-entry-action.is-series {
  color: #8d3030;
  border: 1px solid rgba(176, 76, 76, 0.18);
}

.pf-entry-action.is-danger {
  background: rgba(176, 76, 76, 0.12);
}

.pf-entry-action.is-series {
  background: rgba(176, 76, 76, 0.06);
}

.pf-series-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(53, 71, 100, 0.08);
  background: rgba(255, 255, 255, 0.68);
}

.pf-series-actions strong {
  display: block;
  margin-bottom: 4px;
  color: var(--heading);
}

.pf-series-actions__buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pf-entry-actions {
  align-items: stretch;
}

.pf-entry-action:hover,
.pf-entry-action:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(53, 71, 100, 0.12);
}

.pf-entry-modal__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.pf-history-summary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.pf-history-group-list {
  margin-top: 16px;
}

.pf-history-group-card {
  gap: 16px;
  background: linear-gradient(180deg, rgba(176, 76, 76, 0.08), rgba(255, 255, 255, 0.92));
}

.pf-history-group-card .pf-entry-card__amount {
  color: #8d3030;
}

.pf-history-group-card .mobile-record-card__actions {
  align-items: stretch;
}

@media (max-width: 1120px) {
  .pf-hero-panel__header,
  .pf-bar-meta,
  .pf-progress-card__head,
  .pf-alert-card__head {
    flex-direction: column;
    align-items: stretch;
  }

  .pf-month-switcher {
    grid-template-columns: 1fr;
  }

  .pf-month-switcher__center,
  .pf-month-switcher__nav.is-prev,
  .pf-month-switcher__nav.is-next {
    grid-column: auto;
  }

  .pf-toolbar-actions .btn,
  .pf-month-switcher .btn {
    width: 100%;
  }

  .pf-sync-status {
    align-items: flex-start;
  }

  .pf-trend-chart {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .pf-settings-overview__hero,
  .pf-settings-card .panel-header,
  .pf-settings-card__header-actions,
  .pf-category-modal__hero,
  .pf-category-modal-form__actions {
    flex-direction: column;
    align-items: stretch;
  }

  .pf-settings-card__counter {
    text-align: left;
  }
}

@media (max-width: 760px) {
  .personal-finance-page {
    gap: 14px;
    padding-bottom: calc(18px + env(safe-area-inset-bottom));
  }

  .compact-filter-panel__header,
  .compact-filter-panel__actions,
  .agenda-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .compact-filter-toggle {
    display: inline-flex;
  }

  .compact-filter-summary {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: thin;
  }

  .compact-filter-chip {
    flex: 0 0 auto;
  }

  .compact-filter-form.is-collapsed {
    display: none;
  }

  .agenda-toolbar__views,
  .report-focus-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    display: grid;
  }

  .agenda-toolbar__views .btn,
  .report-focus-chip {
    width: 100%;
  }

  .comparison-chart {
    grid-template-columns: 1fr;
    min-height: 0;
  }

  .comparison-chart .comparison-bar-card:not(:last-child) {
    display: none;
  }

  .settings-audit-filter-panel__submit {
    align-items: stretch;
  }

  .comparison-bar-card {
    gap: 8px;
  }

  .comparison-bar-track {
    height: 120px;
    padding: 6px;
  }

  .pf-toolbar-actions {
    display: none;
  }

  .pf-mobile-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
    margin-top: 14px;
  }

  .pf-trend-chart {
    grid-template-columns: 1fr;
  }

  .pf-trend-chart .pf-trend-card:not(:last-child) {
    display: none;
  }

  .pf-settings-highlights,
  .pf-category-modal-form__actions {
    grid-template-columns: 1fr;
  }

  .pf-category-modal__actions-secondary,
  .pf-category-modal-form__actions {
    display: grid;
    align-items: stretch;
    justify-content: stretch;
  }

  .pf-category-modal__actions-secondary .btn,
  .pf-category-modal-form__actions .btn {
    width: 100%;
  }

  .pf-mobile-summary,
  .pf-plan-highlights,
  .pf-history-summary {
    grid-template-columns: 1fr;
  }

  .pf-calendar-desktop-shell {
    display: none;
  }

  .pf-calendar-mobile-summary,
  .pf-calendar-mobile-list {
    display: grid;
  }

  .pf-calendar-mobile-summary {
    grid-template-columns: 1fr;
  }

  .pf-calendar-chip {
    padding: 14px;
  }

  .pf-calendar-chip__head {
    flex-wrap: wrap;
  }

  .pf-calendar-chip strong {
    line-height: 1.25;
  }

  .pf-tabs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 8px;
    padding: 8px;
    border-radius: 22px;
  }

  .pf-tab {
    flex-direction: column;
    justify-content: center;
    min-height: 78px;
    gap: 6px;
    padding: 12px 8px;
    text-align: center;
    border-radius: 16px;
  }

  .pf-tab__icon {
    width: 20px;
    height: 20px;
  }

  .pf-tab__icon svg {
    width: 20px;
    height: 20px;
  }

  .pf-tab__label {
    display: grid;
    justify-items: center;
    gap: 2px;
    width: 100%;
    white-space: normal;
    line-height: 1.1;
  }

  .pf-tab__label-desktop {
    display: none;
  }

  .pf-tab__label-mobile {
    display: block;
    font-size: 0.72rem;
  }

  .pf-month-switcher {
    padding: 16px;
    gap: 14px;
    border-radius: 22px;
  }

  .pf-month-switcher__center {
    align-items: flex-start;
    text-align: left;
  }

  .pf-month-switcher__center strong {
    font-size: 1.12rem;
  }

  .pf-month-switcher__field {
    width: 100%;
  }

  .pf-month-switcher__center input {
    width: 100%;
    text-align: left;
  }

  .pf-month-switcher__nav {
    min-height: 52px;
    padding: 0 14px;
  }

  .pf-entry-modal__hero,
  .pf-entry-modal__grid {
    grid-template-columns: 1fr;
    flex-direction: column;
  }

  .pf-entry-actions .btn,
  .pf-entries-table .data-table td:last-child {
    width: 100%;
    min-width: 0;
  }

  .pf-series-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .pf-series-actions__buttons .btn {
    width: 100%;
  }

  .pf-entry-modal__actions .btn {
    width: 100%;
  }

  .pf-calendar-mobile-day__head {
    flex-direction: column;
    align-items: stretch;
  }

  .pf-calendar-mobile-day__totals {
    justify-items: start;
    grid-template-columns: repeat(2, minmax(0, max-content));
    justify-content: flex-start;
  }
}

@media print {
  body {
    background: #fff;
  }

  .app-shell,
  .toast-root,
  .btn,
  .modal-header,
  .topbar {
    display: none !important;
  }

  #modal-root {
    position: static !important;
    inset: auto !important;
  }

  .modal-overlay,
  .modal-card,
  .modal-body {
    position: static !important;
    display: block !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    max-height: none !important;
    overflow: visible !important;
  }

  .print-sheet {
    border: 0;
    border-radius: 0;
    padding: 0;
    box-shadow: none;
  }
}
