:root {
  --font-sans:
    "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont,
    "Segoe UI", sans-serif;
  --font-display: var(--font-sans);
  --bg: oklch(97.5% 0.012 80);
  --panel: oklch(100% 0 0);
  --panel-soft: oklch(96.5% 0.01 80);
  --line: oklch(91.5% 0.012 70);
  --text: oklch(28% 0.02 60);
  --muted: oklch(50% 0.02 60);
  --pink: oklch(78% 0.09 350);
  --pink-strong: oklch(66% 0.12 348);
  --pink-soft: oklch(95% 0.032 350);
  --beige: oklch(94% 0.018 80);
  --gray: oklch(94.5% 0.008 80);
  --green-soft: oklch(96.2% 0.044 156.743);
  --green-strong: oklch(44.8% 0.119 151.328);
  --blue-soft: oklch(93.2% 0.032 255.585);
  --blue-strong: oklch(48.8% 0.243 264.376);
  --neutral-100: oklch(100% 0 0);
  --neutral-99: oklch(99% 0.006 80);
  --neutral-98: oklch(98% 0.006 80);
  --neutral-96: oklch(96% 0.01 80);
  --neutral-94: oklch(94% 0.018 80);
  --neutral-92: oklch(92% 0.012 70);
  --neutral-0: oklch(0% 0 0);
  --on-accent: oklch(100% 0 0);
  --shadow: 0 24px 70px -32px oklch(50% 0.05 30 / 0.26);
  --shadow-card:
    0 16px 40px -28px oklch(42% 0.04 35 / 0.28),
    0 1px 0 color-mix(in oklch, var(--neutral-100) 72%, transparent) inset;
  --shadow-soft: 0 8px 26px -18px oklch(40% 0.04 40 / 0.22);
  --gradient-warm: linear-gradient(
    135deg,
    oklch(99% 0.006 80),
    oklch(94% 0.026 52)
  );
  --gradient-rose: linear-gradient(
    135deg,
    oklch(82% 0.085 350),
    oklch(70% 0.115 348)
  );
  --radius: 20px;
  font-family: var(--font-sans);
}

/* Dashboard executivo */
.dashboard-page {
  max-width: 1440px;
  padding-top: 24px;
}
.dashboard-overview-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(0, 1.05fr) minmax(
      250px,
      0.86fr
    );
  gap: 18px;
}
.dashboard-overview-card {
  gap: 14px;
  min-height: 260px;
  padding: 24px 26px;
  border-radius: 24px;
  box-shadow: 0 16px 45px -34px oklch(42% 0.04 35 / 0.28);
}
.dashboard-section-head {
  align-items: center;
}
.dashboard-section-head h2 {
  font-size: 1.12rem;
  font-weight: 600;
  letter-spacing: -0.025em;
}
.dashboard-card-body {
  height: 100%;
  gap: 13px;
}
.dashboard-feature-icon,
.dashboard-mini-icon,
.dashboard-sales-highlight > span,
.dashboard-participation-icon {
  color: var(--pink-strong);
}
.dashboard-feature-icon svg,
.dashboard-mini-icon svg,
.dashboard-sales-highlight svg,
.dashboard-participation-icon svg,
.dashboard-overdue-count svg {
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.dashboard-objective-main {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  align-items: start;
  gap: 16px;
  padding-top: 2px;
}
.dashboard-feature-icon {
  display: grid;
  place-items: center;
  width: 54px;
  height: 54px;
  border-radius: 18px;
  background: var(--pink-soft);
}
.dashboard-feature-icon svg {
  width: 28px;
  height: 28px;
}
.dashboard-objective-text {
  min-height: 54px;
  padding: 2px 0;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.65;
}
.dashboard-objective-text.dashboard-objective-empty {
  color: var(--muted);
}
.dashboard-focus-badge {
  width: 100%;
  min-height: 48px;
  margin-top: auto;
  padding: 0 14px;
  border-radius: 14px;
  background: linear-gradient(
    90deg,
    var(--pink-soft),
    color-mix(in oklch, var(--pink-soft) 45%, transparent)
  );
  color: var(--pink-strong);
  font-size: 0.83rem;
  font-weight: 650;
  text-align: left;
}
.dashboard-focus-badge span {
  margin-right: 7px;
  font-size: 1.15rem;
}
.dashboard-value-label,
.dashboard-progress-note {
  color: var(--muted);
}
.dashboard-value-label {
  font-size: 0.86rem;
}
.dashboard-primary-value {
  font-size: clamp(1.7rem, 2.4vw, 2.25rem);
  font-weight: 520;
}
.dashboard-progress-copy {
  margin-top: 2px;
  font-size: 0.84rem;
}
.dashboard-progress-copy span {
  color: var(--muted);
}
.dashboard-revenue-progress {
  height: 24px;
  margin: 0;
  background: color-mix(in oklch, var(--beige) 70%, var(--panel));
}
.dashboard-revenue-progress > span {
  display: grid;
  min-width: 0;
  place-items: center;
  color: var(--on-accent);
  font-size: 0.72rem;
  font-weight: 700;
}
.dashboard-progress-note {
  font-size: 0.76rem;
}
.dashboard_sales .dashboard-primary-value {
  margin-top: 4px;
  font-size: 2rem;
}
.dashboard-sales-copy {
  margin: -4px 0 0;
  color: var(--muted);
  font-size: 0.84rem;
}
.dashboard-sales-highlight {
  display: flex;
  align-items: center;
  gap: 13px;
  min-height: 64px;
  margin: auto 6px 6px;
  padding: 12px 15px;
  border-radius: 16px;
  background: linear-gradient(
    100deg,
    var(--pink-soft),
    color-mix(in oklch, var(--pink-soft) 36%, transparent)
  );
}
.dashboard-sales-highlight > span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
}
.dashboard-sales-highlight svg {
  width: 26px;
  height: 26px;
}
.dashboard-sales-highlight div {
  display: grid;
}
.dashboard-sales-highlight strong {
  font-size: 0.9rem;
}
.dashboard-sales-highlight small {
  color: var(--muted);
  font-size: 0.76rem;
}
.dashboard-today-grid {
  gap: 0;
}
.dashboard-today-block {
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 12px;
  min-height: 64px;
  padding: 11px 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
}
.dashboard-today-block:last-child {
  border-bottom: 0;
}
.dashboard-mini-icon {
  width: 40px;
  height: 40px;
  border-radius: 13px;
}
.dashboard-mini-icon svg {
  width: 20px;
  height: 20px;
}
.dashboard-today-block div {
  column-gap: 10px;
}
.dashboard-today-block div > strong {
  font-size: 0.82rem;
}
.dashboard-today-block div > span {
  padding: 4px 9px;
  border-radius: 999px;
  background: var(--beige);
  color: var(--text);
  font-size: 0.68rem;
}
.dashboard-today-block div > small {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.74rem;
}
.dashboard-card-link,
.dashboard-participation-link {
  justify-self: center;
  color: var(--pink-strong);
  font-size: 0.82rem;
  font-weight: 600;
}
.dashboard-card-link span,
.dashboard-participation-link span {
  margin-left: 7px;
  font-size: 1rem;
}
.dashboard-overdue-count {
  display: flex;
  align-items: center;
  gap: 9px;
  width: fit-content;
  padding: 9px 13px;
  border-radius: 12px;
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-size: 0.77rem;
}
.dashboard-overdue-count svg {
  width: 18px;
  height: 18px;
}
.dashboard-compact-list {
  gap: 8px;
}
.dashboard-compact-item {
  grid-template-columns: 28px minmax(0, 1fr) 14px;
  gap: 10px;
  min-height: 54px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 13px;
}
.dashboard-compact-item:last-child {
  border-bottom: 1px solid var(--line);
}
.dashboard-compact-item div {
  display: grid;
  min-width: 0;
}
.dashboard-compact-item strong {
  font-size: 0.78rem;
}
.dashboard-compact-item small {
  color: oklch(66% 0.17 55);
  font-size: 0.7rem;
}
.dashboard-overdue-marker {
  width: 22px;
  height: 22px;
  border: 2px solid oklch(75% 0.17 55);
  border-radius: 50%;
}
.dashboard-compact-item b {
  color: var(--muted);
  font-size: 1.25rem;
  font-weight: 400;
}
.dashboard-stock-list > div {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  min-height: 48px;
}
.dashboard-stock-list > div > span:not(.dashboard-product-thumb) {
  overflow: hidden;
  color: var(--text);
  font-size: 0.78rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-product-thumb {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: var(--beige);
  color: var(--pink-strong);
  font-size: 0.76rem;
  font-weight: 700;
}
.dashboard-stock-list strong {
  min-width: 58px;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 0.69rem;
  text-align: center;
}
.dashboard-stock-list strong.healthy {
  color: var(--green-strong);
  background: var(--green-soft);
}
.dashboard-stock-list strong.warning {
  color: oklch(58% 0.16 55);
  background: oklch(95% 0.06 80);
}
.dashboard-stock-list strong.critical {
  color: oklch(58% 0.16 20);
  background: oklch(94% 0.05 20);
}
.dashboard-stock-list strong.theme-stock {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.dashboard_participating {
  min-height: auto;
}
.dashboard_participating .dashboard-card-body {
  gap: 14px;
}
.dashboard-participation-table {
  border: 1px solid var(--line);
  border-radius: 15px;
  overflow: hidden;
}
.dashboard-participation-row {
  grid-template-columns: 92px 26px minmax(180px, 1.8fr) minmax(
      100px,
      0.8fr
    ) minmax(105px, 0.7fr) 18px;
  min-height: 48px;
  padding: 8px 14px;
  border-top: 0;
  border-bottom: 1px solid var(--line);
}
.dashboard-participation-row:last-child {
  border-bottom: 0;
}
.dashboard-participation-row strong {
  font-size: 0.78rem;
}
.dashboard-participation-icon {
  display: grid;
  place-items: center;
}
.dashboard-participation-icon svg {
  width: 18px;
  height: 18px;
}
.dashboard-participation-row small {
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--muted);
  text-align: center;
}
.dashboard-participation-row small.is-success {
  color: var(--green-strong);
  background: var(--green-soft);
}
.dashboard-participation-row small.is-danger {
  color: oklch(58% 0.16 20);
  background: oklch(94% 0.05 20);
}
.dashboard-participation-row small.is-progress {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.dashboard-participation-row small.is-neutral {
  background: var(--beige);
}
.dashboard-participation-link {
  margin-top: 2px;
}

@media (max-width: 1120px) {
  .dashboard-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .dashboard_objective,
  .dashboard_marketing_goal,
  .dashboard_revenue,
  .dashboard_sales,
  .dashboard_today,
  .dashboard_overdue,
  .dashboard_stock {
    grid-column: auto;
    grid-row: auto;
  }
  .dashboard_participating {
    grid-column: 1 / -1;
    grid-row: auto;
  }
}

@media (max-width: 760px) {
  .dashboard-page {
    padding-top: 18px;
  }
  .dashboard-overview-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .dashboard-overview-card {
    min-height: 0;
    padding: 20px;
  }
  .dashboard_participating {
    grid-column: auto;
  }
  .dashboard-participation-row {
    grid-template-columns: 76px 24px minmax(0, 1fr) 16px;
  }
  .dashboard-participation-row
    > span:not(.dashboard-compact-type):not(.dashboard-participation-icon),
  .dashboard-participation-row small {
    grid-column: 3;
  }
  .dashboard-participation-row b {
    grid-column: 4;
    grid-row: 1 / span 3;
  }
}

.sidebar-footer {
  display: grid;
  gap: 4px;
  margin-top: auto;
  padding-top: 20px;
  border-top: 1px solid var(--line);
}
.sidebar-logout {
  margin-top: 8px;
  color: oklch(53% 0.14 25);
}
.sidebar-logout:hover {
  background: color-mix(in oklch, oklch(92% 0.04 25) 72%, transparent);
}
:root.dark-mode .sidebar-logout {
  color: oklch(78% 0.09 25);
}
.sidebar.collapsed .sidebar-footer {
  width: 100%;
}

.theme-mode-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  width: 82px;
  height: 42px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 15px;
  color: var(--muted);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(12px);
}
.theme-mode-switch > span {
  display: grid;
  place-items: center;
  height: 32px;
  border-radius: 11px;
  transition:
    color 0.18s ease,
    background-color 0.18s ease,
    box-shadow 0.18s ease;
}
.theme-mode-switch > span.selected {
  color: var(--text);
  background: var(--panel);
  box-shadow: 0 3px 10px -6px oklch(25% 0.03 60 / 0.45);
}
.theme-mode-switch svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
:root.dark-mode .theme-mode-switch {
  background: color-mix(in oklab, var(--panel-soft) 76%, transparent);
}
:root.dark-mode .theme-mode-switch > span.selected {
  background: var(--neutral-94);
}

@media (max-width: 760px) {
  .theme-mode-switch {
    width: 72px;
    justify-self: end;
  }
}

:root.dark-mode {
  --bg: oklch(10% 0.012 80);
  --panel: oklch(15% 0.012 75);
  --panel-soft: oklch(19% 0.012 75);
  --line: oklch(30% 0.014 70);
  --text: oklch(94% 0.008 75);
  --muted: oklch(70% 0.016 70);
  --pink: oklch(80% 0.075 350);
  --pink-strong: oklch(84% 0.08 350);
  --pink-soft: oklch(33% 0.045 350);
  --beige: oklch(22% 0.018 80);
  --gray: oklch(20% 0.008 80);
  --neutral-100: oklch(17% 0.01 75);
  --neutral-99: oklch(16% 0.01 75);
  --neutral-98: oklch(15% 0.01 75);
  --neutral-96: oklch(20% 0.012 75);
  --neutral-94: oklch(24% 0.014 75);
  --neutral-92: oklch(29% 0.014 70);
  --neutral-0: oklch(100% 0 0);
  --on-accent: oklch(0% 0 0);
  --shadow: 0 24px 70px -34px oklch(0% 0 0 / 0.72);
  --shadow-card:
    0 18px 44px -30px oklch(0% 0 0 / 0.72), 0 1px 0 oklch(100% 0 0 / 0.08) inset;
  --shadow-soft: 0 10px 26px -20px oklch(0% 0 0 / 0.58);
  --gradient-warm: linear-gradient(
    135deg,
    oklch(27% 0.014 265),
    oklch(31% 0.03 350)
  );
  --gradient-rose: linear-gradient(
    135deg,
    oklch(76% 0.085 350),
    oklch(66% 0.1 348)
  );
}

:root.theme-marsala {
  --pink: oklch(58% 0.11 18);
  --pink-strong: oklch(43% 0.12 18);
  --pink-soft: oklch(93% 0.035 18);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(60% 0.12 18),
    oklch(43% 0.12 18)
  );
}
:root.theme-rose {
  --pink: oklch(82% 0.08 350);
  --pink-strong: oklch(66% 0.12 348);
  --pink-soft: oklch(95% 0.032 350);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(84% 0.075 350),
    oklch(70% 0.12 348)
  );
}
:root.theme-yellow {
  --pink: oklch(84% 0.11 86);
  --pink-strong: oklch(56% 0.13 76);
  --pink-soft: oklch(95% 0.05 86);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(88% 0.11 86),
    oklch(67% 0.12 70)
  );
}
:root.theme-olive {
  --pink: oklch(70% 0.075 142);
  --pink-strong: oklch(48% 0.095 142);
  --pink-soft: oklch(93% 0.035 142);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(75% 0.075 142),
    oklch(55% 0.095 150)
  );
}
:root.theme-blue,
:root.theme-navy {
  --pink: oklch(68% 0.075 252);
  --pink-strong: oklch(46% 0.11 252);
  --pink-soft: oklch(93% 0.03 252);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(70% 0.085 252),
    oklch(48% 0.12 258)
  );
}
:root.theme-lilac {
  --pink: oklch(74% 0.09 310);
  --pink-strong: oklch(52% 0.12 310);
  --pink-soft: oklch(94% 0.04 310);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(78% 0.095 310),
    oklch(58% 0.13 300)
  );
}
:root.theme-orange,
:root.theme-caramel {
  --pink: oklch(75% 0.12 48);
  --pink-strong: oklch(52% 0.14 48);
  --pink-soft: oklch(94% 0.045 48);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(78% 0.13 48),
    oklch(60% 0.15 38)
  );
}
:root.theme-graphite {
  --pink: oklch(66% 0.02 260);
  --pink-strong: oklch(38% 0.025 260);
  --pink-soft: oklch(92% 0.006 260);
  --gradient-rose: linear-gradient(
    135deg,
    oklch(62% 0.025 260),
    oklch(42% 0.025 260)
  );
}

* {
  box-sizing: border-box;
}
html {
  scroll-behavior: smooth;
}
body {
  margin: 0;
  background:
    radial-gradient(
      circle at 18% -10%,
      oklch(96% 0.04 350 / 0.55),
      transparent 32rem
    ),
    radial-gradient(
      circle at 92% 8%,
      oklch(96% 0.028 80 / 0.72),
      transparent 30rem
    ),
    var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 400;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: geometricPrecision;
}
:root.dark-mode body {
  background:
    radial-gradient(
      circle at 18% -10%,
      oklch(42% 0.06 350 / 0.24),
      transparent 32rem
    ),
    radial-gradient(
      circle at 92% 8%,
      oklch(35% 0.022 80 / 0.26),
      transparent 30rem
    ),
    var(--bg);
}
button,
input,
select,
textarea {
  font: inherit;
}
button {
  border: 0;
  cursor: pointer;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background-color 0.18s ease,
    border-color 0.18s ease,
    color 0.18s ease;
}
button:hover {
  transform: translateY(-1px);
}
button:active {
  transform: translateY(0);
}
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--pink) 24%, transparent);
}
a {
  color: inherit;
  text-decoration: none;
}
.hidden {
  display: none !important;
}
[hidden] {
  display: none !important;
}

:root.dark-mode .sidebar,
:root.dark-mode .topbar,
:root.dark-mode .card,
:root.dark-mode .item-card,
:root.dark-mode .store-chip,
:root.dark-mode .search-results,
:root.dark-mode .modal,
:root.dark-mode .modal-head,
:root.dark-mode .notification-panel,
:root.dark-mode .finance-window,
:root.dark-mode .finance-full-head,
:root.dark-mode .feed-preview-slot,
:root.dark-mode .check-options label,
:root.dark-mode .checklist-boxes label {
  background: color-mix(in oklab, var(--panel) 88%, transparent);
  border-color: var(--line);
}
:root.dark-mode .btn.ghost,
:root.dark-mode .privacy-toggle,
:root.dark-mode .field input,
:root.dark-mode .field select,
:root.dark-mode .field textarea,
:root.dark-mode .task-detail-value,
:root.dark-mode .filters input,
:root.dark-mode .filters select,
:root.dark-mode .search-wrap input {
  background: color-mix(in oklab, var(--panel-soft) 76%, transparent);
  border-color: var(--line);
  color: var(--text);
}
:root.dark-mode .field label,
:root.dark-mode .check-field legend,
:root.dark-mode .nav-item,
:root.dark-mode .chip {
  color: var(--text);
}
:root.dark-mode .muted,
:root.dark-mode .page-title p,
:root.dark-mode .card p,
:root.dark-mode .store-chip span,
:root.dark-mode .finance-window > summary span,
:root.dark-mode .weekly-task-head span,
:root.dark-mode .mobile-brand div span {
  color: var(--muted);
}
:root.dark-mode .chip,
:root.dark-mode .access-summary span,
:root.dark-mode .privacy-placeholder,
:root.dark-mode .invoice-lines,
:root.dark-mode .sale-product-picker,
:root.dark-mode .sale-product-option,
:root.dark-mode .weekly-task-day,
:root.dark-mode .empty {
  background: color-mix(in oklab, var(--panel-soft) 86%, transparent);
  border-color: var(--line);
}
:root.dark-mode .chip.red {
  color: oklch(84% 0.08 24);
}
:root.dark-mode .chip.green {
  color: oklch(82% 0.11 150);
}
:root.dark-mode .secure-note,
:root.dark-mode .attachment-note,
:root.dark-mode .file-card,
:root.dark-mode .calendar-cell,
:root.dark-mode .event-pill,
:root.dark-mode .date-chip,
:root.dark-mode .feed-remove,
:root.dark-mode .calendar-media-placeholder {
  background: color-mix(in oklab, var(--panel-soft) 84%, transparent);
  border-color: var(--line);
  color: var(--text);
}
:root.dark-mode .event-pill,
:root.dark-mode .calendar-cell.today .calendar-day-button strong,
:root.dark-mode .text-pink,
:root.dark-mode .metric {
  color: var(--pink-strong);
}
:root.dark-mode .nav-item.active,
:root.dark-mode .chip.pink,
:root.dark-mode .avatar {
  color: var(--pink-strong);
}
:root.dark-mode .nav-item.active,
:root.dark-mode .chip.pink {
  background: color-mix(in oklab, var(--pink) 18%, var(--panel-soft));
  border-color: color-mix(in oklab, var(--pink) 36%, var(--line));
}
:root.dark-mode .user-menu {
  color: var(--text);
}
:root.dark-mode .toolbar input,
:root.dark-mode .toolbar select {
  background: color-mix(in oklab, var(--panel-soft) 82%, var(--panel));
  border: 1px solid var(--line);
  color: var(--text);
}
:root.dark-mode .segmented {
  background: color-mix(in oklab, var(--panel-soft) 92%, var(--bg));
  border-color: var(--line);
}
:root.dark-mode .segmented button.active {
  background: color-mix(in oklab, var(--pink) 14%, var(--panel));
  border: 1px solid color-mix(in oklab, var(--pink) 42%, var(--line));
}
:root.dark-mode .calendar-grid {
  border-color: color-mix(in oklab, var(--line) 88%, var(--text));
}
:root.dark-mode .calendar-cell {
  background: color-mix(in oklab, var(--panel-soft) 72%, var(--panel));
  border-color: var(--line);
}
:root.dark-mode .calendar-cell:hover {
  background: color-mix(in oklab, var(--panel-soft) 88%, var(--text) 12%);
}
:root.dark-mode .calendar-cell.today {
  background: color-mix(in oklab, var(--pink) 12%, var(--panel-soft));
}
:root.dark-mode .event-pill {
  background: color-mix(in oklab, var(--pink) 18%, var(--panel-soft));
  border: 1px solid color-mix(in oklab, var(--pink) 28%, var(--line));
}
:root.dark-mode .bulk-action-bar .btn.danger,
:root.dark-mode .bulk-action-bar .btn.danger:disabled {
  color: var(--text);
}
.theme-select {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 13px;
  padding: 0 12px;
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  color: var(--text);
}

.landing {
  min-height: 100vh;
  background:
    radial-gradient(
      circle at top right,
      color-mix(in oklch, var(--pink) 24%, transparent),
      transparent 34rem
    ),
    linear-gradient(180deg, oklch(99% 0.008 80) 0%, var(--bg) 100%);
}
.public-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1180px;
  margin: 0 auto;
  padding: 22px;
}
.logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-weight: 600;
  letter-spacing: 0;
  color: var(--text);
  text-transform: lowercase;
}
.logo-mark {
  width: 42px;
  aspect-ratio: 1 / 1;
  border-radius: 0;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.logo-mark img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1.05fr);
  gap: 34px;
  align-items: center;
  max-width: 1180px;
  min-height: calc(100vh - 170px);
  margin: 0 auto;
  padding: 30px 22px 68px;
}
.hero-copy h1 {
  margin: 0 0 18px;
  font-size: clamp(2.6rem, 6vw, 5.3rem);
  line-height: 0.98;
  letter-spacing: -0.01em;
  font-family: var(--font-display);
  font-weight: 560;
}
.hero-copy p {
  max-width: 620px;
  color: var(--muted);
  font-size: 1.15rem;
  line-height: 1.7;
}
.hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 28px;
}
.hero-preview {
  background: color-mix(in oklch, var(--neutral-100) 80%, transparent);
  border: 1px solid oklch(91.5% 0.012 70 / 0.82);
  border-radius: 32px;
  box-shadow: var(--shadow);
  padding: 18px;
  backdrop-filter: blur(18px);
}
.preview-shell {
  min-height: 520px;
  border-radius: 24px;
  background: var(--gradient-warm);
  overflow: hidden;
  display: grid;
  grid-template-columns: 130px 1fr;
  border: 1px solid var(--line);
}
.preview-side {
  padding: 18px 12px;
  background: oklch(93.5% 0.02 76);
}
.preview-pill {
  height: 28px;
  border-radius: 9px;
  margin: 12px 0;
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
}
.preview-pill.active {
  background: var(--pink-soft);
}
.preview-main {
  padding: 22px;
}
.preview-top {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.preview-line {
  height: 12px;
  border-radius: 99px;
  background: var(--gray);
}
.preview-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.preview-card {
  min-height: 128px;
  border-radius: 18px;
  border: 1px solid var(--line);
  background: color-mix(in oklch, var(--neutral-100) 92%, transparent);
  padding: 16px;
  box-shadow: var(--shadow-card);
}
.preview-card.wide {
  grid-column: 1 / -1;
  min-height: 150px;
}
.progress {
  height: 9px;
  border-radius: 99px;
  overflow: hidden;
  background: oklch(92% 0.012 70);
}
.progress > span {
  display: block;
  height: 100%;
  width: var(--value, 45%);
  background: var(--gradient-rose);
}
.landing-section {
  max-width: 1180px;
  margin: 0 auto;
  padding: 72px 22px;
}
.section-kicker {
  color: var(--pink-strong);
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.78rem;
  letter-spacing: 0.1em;
}
.landing-section h2 {
  font-size: clamp(2rem, 4vw, 3.2rem);
  margin: 10px 0 12px;
  font-family: var(--font-display);
  font-weight: 540;
  letter-spacing: -0.01em;
}
.landing-section > p {
  color: var(--muted);
  max-width: 720px;
  line-height: 1.7;
}
.feature-grid,
.step-grid,
.benefit-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 28px;
}
.feature-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.landing-card {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px;
  box-shadow: var(--shadow-card);
}
.landing-card h3 {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-weight: 540;
  letter-spacing: -0.01em;
}
.landing-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}
.benefit-band {
  background: color-mix(in oklch, var(--neutral-100) 66%, transparent);
  border-block: 1px solid var(--line);
}
.quote {
  display: inline-block;
  margin: 18px 0;
  color: var(--on-accent);
  background: var(--gradient-rose);
  border-radius: 16px;
  padding: 12px 16px;
  font-weight: 600;
}
.bullet-list {
  display: grid;
  gap: 12px;
  padding: 0;
  margin: 18px 0 0;
  list-style: none;
}
.bullet-list li {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
}
.bullet-list li::before {
  content: "✓";
  display: grid;
  place-items: center;
  min-width: 24px;
  height: 24px;
  border-radius: 8px;
  background: var(--pink-soft);
  color: var(--pink-strong);
  font-weight: 540;
}
.auth-page {
  position: relative;
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 24px;
  background: var(--gradient-warm);
}
.theme-mode-toggle {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 14px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  box-shadow: var(--shadow-soft);
  backdrop-filter: blur(12px);
}
.theme-mode-toggle svg {
  width: 19px;
  height: 19px;
}
.auth-card {
  width: min(100%, 980px);
  display: grid;
  grid-template-columns: 0.9fr 1.1fr;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 32px;
  background: var(--panel);
  box-shadow: var(--shadow);
}
.auth-aside {
  padding: 34px;
  background: linear-gradient(
    135deg,
    color-mix(in oklch, var(--pink-soft) 42%, oklch(94% 0.025 80)),
    var(--pink-soft)
  );
}
.auth-aside h1 {
  font-size: 2.4rem;
  margin: 50px 0 14px;
  font-family: var(--font-display);
  font-weight: 560;
  letter-spacing: -0.01em;
}
.auth-form {
  padding: 34px;
}
.onboarding-card {
  width: min(100%, 1180px);
  grid-template-columns: 0.78fr 1.22fr;
}
.onboarding-panel {
  display: grid;
  align-content: center;
  gap: 22px;
}
.onboarding-panel h2 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 620;
}
.onboarding-options {
  display: grid;
  gap: 16px;
}
.onboarding-option {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  align-items: center;
  gap: 20px;
  padding: 24px;
  border: 1px solid color-mix(in oklch, var(--pink) 34%, var(--line));
  border-radius: 22px;
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  box-shadow: var(--shadow-soft);
}
.onboarding-option.warm {
  border-color: oklch(88% 0.026 62);
  background: oklch(98% 0.014 55 / 0.72);
}
.onboarding-option h3,
.join-request-person h3 {
  margin: 0 0 6px;
}
.onboarding-option p {
  margin: 0 0 10px;
  color: var(--muted);
  line-height: 1.45;
}
.onboarding-option small {
  color: var(--pink);
  font-weight: 650;
}
.onboarding-icon {
  display: grid;
  place-items: center;
  width: 64px;
  aspect-ratio: 1;
  border-radius: 999px;
  background: var(--pink-soft);
  color: var(--pink);
  font-size: 1.8rem;
  font-weight: 700;
}
.onboarding-option.warm .onboarding-icon {
  background: oklch(94% 0.022 65);
  color: oklch(58% 0.09 54);
}
.onboarding-note {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: oklch(97% 0.008 58 / 0.82);
  color: var(--muted);
}
.onboarding-note strong {
  display: grid;
  place-items: center;
  width: 24px;
  aspect-ratio: 1;
  border-radius: 999px;
  border: 1px solid currentColor;
  color: var(--pink);
  flex-shrink: 0;
}
.onboarding-form {
  display: grid;
  gap: 14px;
}
.field {
  display: grid;
  gap: 6px;
  margin-bottom: 14px;
}
.field label {
  color: oklch(37% 0.025 60);
  font-size: 0.88rem;
  font-weight: 560;
}
.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 82%, transparent);
  color: var(--text);
  padding: 11px 13px;
  outline: none;
}
.field textarea {
  min-height: 96px;
  resize: vertical;
}
.field select[multiple] {
  min-height: 118px;
  padding: 8px;
}
.check-field {
  border: 0;
  padding: 0;
}
.check-field legend {
  color: oklch(37% 0.025 60);
  font-size: 0.88rem;
  font-weight: 560;
  margin-bottom: 8px;
}
.check-options,
.checklist-boxes {
  display: grid;
  gap: 8px;
}
.check-options label,
.checklist-boxes label {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 40px;
  padding: 9px 11px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  color: var(--text);
}
.check-options input,
.checklist-boxes input {
  width: 17px;
  height: 17px;
  accent-color: var(--pink);
  flex: 0 0 auto;
}
.checklist-preview,
.task-checklist {
  display: grid;
  gap: 9px;
}
.checklist-boxes label.done span {
  color: var(--muted);
  text-decoration: line-through;
}
.attachment-note {
  margin-top: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: oklch(98% 0.006 80 / 0.82);
  color: var(--text);
  font-size: 0.9rem;
  line-height: 1.55;
}
.field input:focus,
.field select:focus,
.field textarea:focus {
  border-color: var(--pink);
  box-shadow: 0 0 0 4px color-mix(in oklch, var(--pink) 20%, transparent);
}
.password-control {
  position: relative;
  display: grid;
}
.password-control input {
  padding-right: 44px;
}
.password-control .icon-btn {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 32px;
  height: 32px;
  min-height: 32px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--pink-strong);
}
.password-control .icon-btn svg {
  width: 18px;
  height: 18px;
}
.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.form-grid .form-full {
  grid-column: 1 / -1;
}
.company-record-form-grid {
  align-items: start;
}
.task-form-grid,
.daily-form-grid {
  align-items: start;
}
.company-record-form-grid .field {
  margin-bottom: 0;
}
.company-record-form-grid .field select,
.company-record-form-grid .field input[type="file"] {
  min-height: 44px;
}
.company-record-form-grid .field input[type="file"] {
  padding: 9px 13px;
}
.company-record-form-grid .calendar-toggle-field {
  position: relative;
  z-index: 1;
}
.company-record-form-grid .calendar-toggle-field.open {
  z-index: 8;
}
.company-record-form-grid .calendar-option-list {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 10;
  max-height: 190px;
  overflow: auto;
  margin-top: 0;
  box-shadow: var(--shadow-card);
}
.team-member-form-grid,
.marketing-content-form-grid,
.finance-entry-form-grid {
  align-items: start;
}
.team-member-form-grid .calendar-toggle-field,
.marketing-content-form-grid .calendar-toggle-field,
.finance-entry-form-grid .calendar-toggle-field,
.task-form-grid .calendar-toggle-field,
.daily-form-grid .calendar-toggle-field {
  position: relative;
}
.team-member-form-grid .calendar-toggle-field.open,
.marketing-content-form-grid .calendar-toggle-field.open,
.finance-entry-form-grid .calendar-toggle-field.open,
.task-form-grid .calendar-toggle-field.open,
.daily-form-grid .calendar-toggle-field.open {
  z-index: 8;
}
.finance-entry-form-grid .finance-description {
  grid-column: 1;
}
.finance-entry-form-grid .finance-date {
  grid-column: 2;
}
.finance-entry-form-grid .finance-notes textarea {
  min-height: 44px;
}
.finance-entry-form-grid .finance-access-view {
  grid-column: 1;
}
.finance-entry-form-grid .finance-access-edit {
  grid-column: 2;
}
.event-form-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 14px;
}
.event-form-grid .event-description textarea {
  min-height: 120px;
}
.marketing-objective {
  grid-column: 1;
}
.marketing-references {
  grid-column: 2;
}
.marketing-references textarea {
  min-height: 44px;
}
.sales-form-grid .sale-products-field {
  grid-column: 1 / -1;
}
.sales-form-grid .sales-notes {
  grid-column: 1 / -1;
  grid-row: 3;
}
.sales-form-grid .sales-notes textarea {
  min-height: 120px;
  height: 120px;
}
.sales-form-grid .sales-delivery,
.sales-form-grid .sales-discount,
.sales-form-grid .sales-payment,
.sales-form-grid .sales-access-view {
  grid-column: 1;
}
.sales-form-grid .sales-packaging,
.sales-form-grid .sales-extra-costs,
.sales-form-grid .sales-statuses-field,
.sales-form-grid .sales-access-edit {
  grid-column: 2;
}
.sales-form-grid .sales-delivery,
.sales-form-grid .sales-packaging {
  grid-row: 4;
}
.sales-form-grid .sales-discount,
.sales-form-grid .sales-extra-costs {
  grid-row: 5;
}
.sales-form-grid .sales-payment,
.sales-form-grid .sales-statuses-field {
  grid-row: 6;
}
.sales-form-grid .sales-access-view,
.sales-form-grid .sales-access-edit {
  grid-row: 7;
}
.sales-status-card-row {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.sales-state-card {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 44px;
  height: 44px;
  margin: 0;
  padding: 0 10px;
  border: 1px solid color-mix(in oklch, var(--green-strong) 18%, var(--line));
  border-radius: 14px;
  color: var(--green-strong);
  background: color-mix(in oklch, var(--green-soft) 82%, transparent);
  cursor: pointer;
}
.sales-state-card.active {
  border-color: color-mix(in oklch, var(--green-strong) 40%, var(--line));
  box-shadow: inset 0 0 0 1px
    color-mix(in oklch, var(--green-strong) 12%, transparent);
}
.sales-state-card input {
  width: 16px;
  height: 16px;
  min-height: 16px;
  margin: 0;
  accent-color: var(--green-strong);
}
.sales-state-card svg {
  width: 17px;
  height: 17px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  flex: 0 0 auto;
}
.sales-state-card strong {
  font-size: 0.82rem;
  font-weight: 650;
}
.sales-money-hint {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.25;
}
.sales-form-grid .sales-discount.money-field > span,
.sales-form-grid .sales-extra-costs.money-field > span {
  top: 35px;
  bottom: auto;
}
.checklist-editor {
  display: grid;
  gap: 8px;
}
.checklist-input-row {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  padding: 0;
  border-radius: 12px;
  border: 1px solid transparent;
  transform-origin: center;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease,
    background-color 0.18s ease,
    opacity 0.18s ease,
    margin 0.18s ease,
    border-color 0.18s ease,
    filter 0.18s ease;
}
.checklist-input-row {
  grid-template-columns: 28px 22px minmax(0, 1fr);
}
.checklist-drag-handle {
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--panel-soft);
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: grab;
  user-select: none;
  line-height: 1;
  touch-action: none;
  -webkit-user-drag: element;
}
.checklist-drag-handle:active {
  cursor: grabbing;
}
.checklist-input-row.dragging {
  opacity: 0.97;
  background: color-mix(in oklch, var(--panel-soft) 94%, var(--neutral-100));
  border-color: color-mix(in oklch, var(--pink-strong) 28%, transparent);
  box-shadow: 0 12px 28px rgb(0 0 0 / 0.12);
  transform: translateY(-2px) scale(1.01);
  z-index: 10;
  cursor: grabbing;
  filter: saturate(1.02);
}
.checklist-input-row.dragging .checklist-drag-handle {
  cursor: grabbing;
}
.checklist-input-row.drag-over {
  background: color-mix(in oklch, var(--pink) 6%, transparent);
}
.checklist-input-row.drop-before {
  margin-top: 10px;
}
.checklist-input-row.drop-after {
  margin-bottom: 10px;
}
.checklist-input-row {
  position: relative;
}
.checklist-drop-placeholder {
  min-height: 44px;
  border-radius: 12px;
  border: 1px solid color-mix(in oklch, var(--line) 84%, transparent);
  background: color-mix(in oklch, var(--panel-soft) 98%, var(--neutral-100));
  box-shadow:
    inset 0 0 0 1px color-mix(in oklch, var(--text) 3%, transparent),
    0 4px 10px rgb(0 0 0 / 0.035);
  margin: 4px 0;
  opacity: 0.99;
  transition:
    height 0.18s ease,
    background-color 0.18s ease,
    border-color 0.18s ease,
    margin 0.18s ease,
    box-shadow 0.18s ease,
    opacity 0.18s ease;
}
.checklist-input-row .checklist-done-input {
  width: 18px;
  height: 18px;
  min-height: 18px;
  padding: 0;
  accent-color: var(--pink);
}
.checklist-input-row .checklist-text-input {
  min-height: 40px;
}
.checklist-add {
  width: fit-content;
  min-width: 72px;
  justify-content: center;
}
.date-list-field {
  gap: 12px;
}
.date-list-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}
.date-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.date-chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 30px;
  padding: 0 8px 0 11px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: oklch(98% 0.006 80 / 0.86);
  color: var(--text);
  font-size: 0.82rem;
}
.date-chip button {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border-radius: 999px;
  color: var(--muted);
  background: var(--gray);
}
.recurrence-box {
  display: grid;
  gap: 14px;
  margin-top: 0;
  border: 0;
  background: transparent;
}
.daily-date-pair {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.daily-date-card {
  display: grid;
  gap: 12px;
  min-height: 126px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--neutral-100) 62%, transparent);
}
.daily-date-card label {
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 700;
}
.daily-date-card input,
.daily-date-card select {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 82%, transparent);
  color: var(--text);
  padding: 11px 13px;
}
.sr-date-list {
  display: none;
}
.recurrence-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-height: 48px;
  padding: 0 16px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--neutral-100) 62%, transparent);
  color: var(--text);
  font-weight: 700;
  box-shadow: none;
}
.recurrence-toggle b {
  transition: transform 0.18s ease;
}
.recurrence-toggle.open b {
  transform: rotate(180deg);
}
.recurrence-toggle.open {
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.recurrence-panel {
  display: grid;
  gap: 14px;
  padding: 14px 16px 16px;
  margin-top: -14px;
  border: 1px solid var(--line);
  border-top: 0;
  border-radius: 0 0 16px 16px;
  background: color-mix(in oklch, var(--neutral-100) 62%, transparent);
  animation: companyBlockIn 0.18s ease;
}
.recurrence-panel[hidden] {
  display: none;
}
.recurrence-panel .field {
  margin-bottom: 0;
}
.recurrence-warning {
  margin: 0;
  color: oklch(44% 0.14 22);
  font-size: 0.88rem;
}
.recurrence-generated {
  display: grid;
  gap: 10px;
}
.recurrence-generated strong {
  font-size: 0.9rem;
}
.access-field {
  gap: 5px;
  margin-bottom: 10px;
}
.access-field legend {
  font-size: 0.78rem;
  color: var(--muted);
}
.access-field .check-options {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.access-field .check-options label {
  min-height: 30px;
  padding: 5px 8px;
  border-radius: 999px;
  background: oklch(98% 0.006 80 / 0.66);
  font-size: 0.78rem;
  color: oklch(43% 0.02 60);
}
.access-field .check-options input {
  width: 13px;
  height: 13px;
  min-height: 13px;
  padding: 0;
  border-radius: 3px;
}
.access-field small {
  font-size: 0.72rem;
}
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 42px;
  margin: 10px 0px;
  padding: 0 17px;
  border-radius: 14px;
  color: var(--text);
  background: var(--gray);
  font-weight: 540;
  white-space: nowrap;
  letter-spacing: 0;
  box-shadow: 0 1px 0 oklch(100% 0 0 / 0.55) inset;
}
.btn.primary {
  color: var(--on-accent);
  background: var(--gradient-rose);
  box-shadow:
    0 16px 30px -16px color-mix(in oklch, var(--pink-strong) 68%, transparent),
    0 1px 0 oklch(100% 0 0 / 0.25) inset;
}
.btn.ghost {
  background: color-mix(in oklch, var(--neutral-100) 45%, transparent);
  border: 1px solid var(--line);
}
.btn.danger {
  color: oklch(44% 0.14 22);
  background: oklch(94% 0.04 22);
}
.btn.small {
  min-height: 34px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: 0.84rem;
}
.link-btn {
  background: transparent;
  color: var(--pink-strong);
  font-weight: 600;
  padding: 0;
}
.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 268px minmax(0, 1fr);
  transition: grid-template-columns 0.2s ease;
}
.app-shell.sidebar-collapsed {
  grid-template-columns: 88px minmax(0, 1fr);
}
.sidebar {
  position: sticky;
  top: 0;
  z-index: 30;
  height: 100vh;
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 24px 16px;
  background: oklch(98.5% 0.008 80 / 0.88);
  border-right: 1px solid var(--line);
  backdrop-filter: blur(18px);
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  scrollbar-gutter: stable;
  transition: padding 0.2s ease;
}
.sidebar::-webkit-scrollbar {
  width: 8px;
}
.sidebar::-webkit-scrollbar-thumb {
  border: 2px solid transparent;
  border-radius: 999px;
  background: color-mix(in oklab, var(--muted) 36%, transparent);
  background-clip: padding-box;
}
.sidebar-toggle {
  position: fixed;
  top: 74px;
  left: 268px;
  right: auto;
  z-index: 70;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  transform: translateX(-50%);
  border-radius: 14px;
  color: var(--pink-strong);
  background: var(--neutral-100);
  border: 1px solid color-mix(in oklch, var(--pink) 32%, var(--line));
  box-shadow:
    0 12px 28px -16px color-mix(in oklch, var(--pink-strong) 38%, transparent),
    0 1px 0 var(--neutral-100) inset;
  transition:
    transform 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}
.sidebar-toggle:hover {
  background: var(--pink-soft);
  border-color: color-mix(in oklch, var(--pink) 64%, var(--line));
  transform: translateX(-50%) translateY(-1px);
}
.sidebar-toggle svg {
  width: 18px;
  height: 18px;
}
.mobile-sidebar-overlay {
  display: none;
}
.sidebar.collapsed {
  align-items: center;
  gap: 16px;
  padding: 24px 12px;
}
.app-shell.sidebar-collapsed .sidebar-toggle {
  left: 88px;
}
.sidebar.collapsed .logo {
  justify-content: center;
  width: 100%;
}
.sidebar.collapsed .logo-text,
.sidebar.collapsed .store-chip,
.sidebar.collapsed .nav-group-label,
.sidebar.collapsed .nav-item span {
  display: none;
}
.sidebar.collapsed .nav-list {
  gap: 8px;
}
.sidebar.collapsed .nav-item {
  justify-content: center;
  width: 48px;
  min-height: 48px;
  padding: 0;
  border-radius: 16px;
}
.sidebar.collapsed .nav-icon {
  width: 20px;
  height: 20px;
}
.store-chip {
  padding: 15px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
  box-shadow: var(--shadow-soft);
}
.store-chip strong {
  display: block;
}
.store-chip span {
  color: var(--muted);
  font-size: 0.84rem;
}
.nav-group-label {
  margin: 10px 10px 8px;
  color: var(--muted);
  font-size: 0.69rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.11em;
}
.nav-list {
  display: grid;
  gap: 4px;
}
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  min-height: 42px;
  border-radius: 14px;
  padding: 0 12px;
  color: oklch(39% 0.02 60);
  background: transparent;
  font-weight: 500;
  text-align: left;
}
.nav-icon {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  opacity: 0.78;
}
.nav-item.active {
  color: var(--pink-strong);
  background: var(--pink-soft);
  box-shadow:
    0 10px 24px -18px color-mix(in oklch, var(--pink-strong) 62%, transparent),
    0 1px 0 color-mix(in oklch, var(--neutral-100) 62%, transparent) inset;
}
.nav-item.active .nav-icon {
  opacity: 1;
}
.main-area {
  min-width: 0;
  padding-bottom: 36px;
}
.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 18px 24px;
  background: oklch(97.5% 0.012 80 / 0.78);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid oklch(91.5% 0.012 70 / 0.72);
}
.topbar-history {
  min-height: 46px;
}
.topbar-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
}
.mobile-brand {
  display: none;
}
.search-wrap {
  position: relative;
}
.search-wrap input {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 0 16px 0 42px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  box-shadow: var(--shadow-soft);
}
.search-wrap::before {
  content: "⌕";
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-weight: 540;
}
.search-results {
  position: absolute;
  inset: calc(100% + 8px) 0 auto 0;
  z-index: 30;
  max-height: 360px;
  overflow: auto;
  background: color-mix(in oklch, var(--neutral-100) 95%, transparent);
  border: 1px solid var(--line);
  border-radius: 18px;
  box-shadow: var(--shadow);
  padding: 8px;
}
.search-result {
  display: block;
  width: 100%;
  padding: 11px;
  border-radius: 12px;
  background: transparent;
  text-align: left;
}
.search-result:hover {
  background: var(--panel-soft);
}
.user-menu {
  display: flex;
  align-items: center;
  gap: 10px;
  border: 0;
  background: transparent;
  text-align: left;
}
.user-menu .avatar {
  width: 42px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.user-menu .avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.account-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.account-wide {
  grid-column: 1 / -1;
}
.account-card {
  display: grid;
  gap: 14px;
  align-content: start;
}
.account-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-bottom: 4px;
  min-height: 46px;
}
.account-preview-plain {
  align-items: flex-start;
}
.account-preview h3 {
  margin: 0;
}
.account-avatar {
  width: 42px;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
.account-actions {
  padding: 0;
}
.account-team-card {
  margin-top: 16px;
  display: grid;
  gap: 14px;
}
.account-team-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}
.account-team-grid div {
  display: grid;
  gap: 4px;
}
.account-danger-zone {
  margin-top: 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.account-danger-zone h3 {
  margin: 0 0 4px;
}
.account-danger-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  flex-wrap: wrap;
}
.ghost-danger {
  background: color-mix(in srgb, oklch(44% 0.14 22) 10%, transparent);
  border-color: color-mix(in srgb, oklch(44% 0.14 22) 18%, var(--line));
}
.page {
  max-width: 1800px;
  margin: 0 auto;
  padding: 28px 24px 84px;
}
.page-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: flex-start;
  margin-bottom: 22px;
}
.page-title h1 {
  margin: 0;
  font-size: clamp(1.85rem, 3.2vw, 2.75rem);
  font-family: var(--font-display);
  font-weight: 560;
  letter-spacing: -0.01em;
  line-height: 1.06;
}
.page-title p {
  margin: 8px 0 0;
  color: var(--muted);
}
.toolbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}
.filters {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 0 0 18px;
}
.filters input,
.filters select {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  padding: 0 12px;
}
.filters .btn.active {
  color: var(--pink-strong);
  background: var(--pink-soft);
  border-color: color-mix(in oklch, var(--pink) 44%, var(--line));
}
.team-toolbar {
  display: flex;
  align-items: center;
  gap: 12px;
  margin: 0 0 18px;
}
.team-toolbar input {
  flex: 1;
  min-width: 220px;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  padding: 0 14px;
}
.team-list {
  display: grid;
  gap: 12px;
  width: 100%;
  max-width: none;
}
.team-member-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 14px;
  border-radius: 18px;
  padding: 15px 16px;
}
.team-member-card .item-actions {
  justify-content: flex-end;
  align-self: center;
}
.team-member-main {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 14px;
}
.team-member-main .avatar {
  width: 54px;
  aspect-ratio: 1 / 1;
  flex: 0 0 54px;
  border-radius: 50%;
  overflow: hidden;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.team-member-main .avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
  display: block;
}
.team-avatar-fallback {
  background: linear-gradient(135deg, oklch(96% 0.02 25), oklch(91% 0.02 210));
  border: 1px solid var(--line);
  border-radius: 50%;
}
.team-member-info {
  min-width: 0;
  display: grid;
  gap: 3px;
}
.team-member-info h3 {
  margin: 10px;
}
.team-member-info span,
.team-member-info small {
  color: var(--muted);
}
.team-member-side {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.trash-list {
  gap: 8px;
}
.trash-item-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 16px;
  min-height: 68px;
  padding: 11px 14px;
  border-radius: 16px;
  box-shadow: var(--shadow-soft);
}
.trash-item-copy {
  min-width: 0;
}
.trash-item-copy .item-title {
  margin: 0;
  font-size: 0.94rem;
  line-height: 1.35;
}
.trash-item-copy p {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 0.75rem;
  line-height: 1.35;
}
.trash-item-actions {
  flex: 0 0 auto;
  flex-wrap: nowrap;
  justify-content: flex-end;
}
.trash-item-actions .btn.small {
  width: auto;
  flex: 0 0 auto;
}
.member-photo-field {
  grid-column: 1 / -1;
}
.member-photo-control {
  display: flex;
  align-items: center;
  gap: 14px;
}
.member-avatar-preview {
  width: 58px;
  aspect-ratio: 1 / 1;
  flex: 0 0 58px;
  border-radius: 50%;
  overflow: hidden;
}
.member-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  border-radius: 50%;
  display: block;
}
.segmented {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  background: oklch(93.8% 0.014 80);
  border-radius: 15px;
  border: 1px solid var(--line);
}
.segmented button {
  min-height: 34px;
  border-radius: 12px;
  padding: 0 12px;
  background: transparent;
  font-weight: 540;
  color: var(--muted);
}
.segmented button.active {
  background: color-mix(in oklch, var(--neutral-100) 90%, transparent);
  color: var(--pink-strong);
  box-shadow: var(--shadow-soft);
}
.grid {
  display: grid;
  gap: 16px;
  align-items: start;
}
.grid.cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.grid.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.grid.cols-4 {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.dashboard-card-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.dashboard-page {
  display: grid;
  gap: 22px;
}
.dashboard-head {
  margin-bottom: 0;
}
.dashboard-create-menu {
  position: relative;
  z-index: 8;
}
.dashboard-create-menu summary {
  list-style: none;
  min-width: 112px;
  text-align: center;
}
.dashboard-create-menu summary::-webkit-details-marker {
  display: none;
}
.dashboard-create-dropdown {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  display: grid;
  min-width: 190px;
  padding: 8px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  box-shadow: var(--shadow-card);
}
.dashboard-create-dropdown button {
  padding: 10px 12px;
  border-radius: 11px;
  background: transparent;
  color: var(--text);
  text-align: left;
}
.dashboard-create-dropdown button:hover {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.dashboard-indicators {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.dashboard-indicator-card,
.dashboard-section-card {
  min-width: 0;
}
.dashboard-indicator-card {
  display: grid;
  gap: 12px;
  min-height: 176px;
}
.dashboard-indicator-head,
.dashboard-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dashboard-indicator-head {
  justify-content: flex-start;
}
.dashboard-indicator-head h2,
.dashboard-section-head h2 {
  margin: 0;
  font-size: 1rem;
  font-weight: 620;
}
.dashboard-indicator-icon {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  border-radius: 13px;
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.dashboard-indicator-icon svg {
  width: 20px;
  height: 20px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.dashboard-indicator-value {
  font-size: clamp(1.9rem, 3vw, 2.5rem);
  line-height: 1;
  letter-spacing: -0.04em;
}
.dashboard-indicator-detail {
  display: grid;
  gap: 7px;
  color: var(--muted);
  font-size: 0.86rem;
}
.dashboard-indicator-detail .progress {
  margin-top: 2px;
}
.dashboard-content-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, 0.8fr);
  gap: 16px;
  align-items: start;
}
.dashboard-section-card {
  display: grid;
  gap: 16px;
}
.dashboard-goals,
.dashboard-activities {
  grid-column: 1 / -1;
}
.dashboard-task-list,
.dashboard-goal-list,
.dashboard-activity-list {
  display: grid;
  gap: 0;
}
.dashboard-task-item,
.dashboard-activity-item {
  display: grid;
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.dashboard-task-item {
  grid-template-columns: 20px minmax(0, 1fr);
}
.dashboard-task-item:last-child,
.dashboard-activity-item:last-child {
  border-bottom: 0;
}
.dashboard-task-status {
  width: 18px;
  height: 18px;
  border: 2px solid color-mix(in oklch, var(--pink) 64%, var(--line));
  border-radius: 6px;
}
.dashboard-task-item div,
.dashboard-goal-item div,
.dashboard-activity-item div {
  min-width: 0;
}
.dashboard-task-item strong,
.dashboard-task-item small {
  display: block;
}
.dashboard-task-item strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-task-item small,
.dashboard-goal-item span,
.dashboard-activity-item small {
  color: var(--muted);
  font-size: 0.8rem;
}
.dashboard-objective-text {
  width: 100%;
  padding: 0;
  border-radius: 0;
  background: transparent;
  margin: 0;
  color: var(--text) !important;
  font-size: 1.08rem;
  line-height: 1.55;
  text-align: left;
}
.dashboard-objective-text:hover {
  color: var(--pink-strong) !important;
}
.dashboard-objective-text.dashboard-objective-empty {
  color: var(--muted) !important;
  font-size: 0.95rem;
}
.dashboard-empty-copy {
  display: grid;
  justify-items: start;
  gap: 8px;
  min-height: 96px;
  align-content: center;
}
.dashboard-empty-copy p {
  margin: 0;
}
.dashboard-goal-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.dashboard-goal-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--panel-soft) 62%, transparent);
}
.dashboard-goal-item strong,
.dashboard-goal-item span {
  display: block;
}
.dashboard-goal-item .progress {
  grid-column: 1 / -1;
}
.dashboard-activity-item {
  grid-template-columns: 38px minmax(0, 1fr);
}
.dashboard-activity-avatar {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-size: 0.76rem;
  font-weight: 700;
}
.dashboard-activity-item p {
  margin: 0 0 2px;
  color: var(--text);
  line-height: 1.4;
}
.dashboard-activity-item p span {
  color: var(--muted);
}
.dashboard-overview-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1.4fr) minmax(220px, 1fr);
  gap: 16px;
  align-items: stretch;
}
.dashboard-overview-card {
  display: grid;
  gap: 16px;
  min-width: 0;
  min-height: 190px;
  align-content: start;
}
.dashboard_participating {
  grid-column: 1 / -1;
  min-height: auto;
}
.dashboard_objective {
  grid-column: 1;
  grid-row: 1;
}
.dashboard_marketing_goal {
  grid-column: 1;
  grid-row: 2;
}
.dashboard_revenue {
  grid-column: 2;
  grid-row: 1;
}
.dashboard_sales {
  grid-column: 3;
  grid-row: 1;
}
.dashboard_today {
  grid-column: 2;
  grid-row: 2;
}
.dashboard_overdue {
  grid-column: 1;
  grid-row: 3;
}
.dashboard_stock {
  grid-column: 3;
  grid-row: 2;
}
.dashboard_participating {
  grid-row: 4;
}
.dashboard-card-body {
  display: grid;
  gap: 12px;
  min-width: 0;
}
.dashboard-primary-value {
  font-size: clamp(1.45rem, 2.4vw, 2rem);
  line-height: 1;
  letter-spacing: -0.04em;
}
.dashboard-progress-copy,
.dashboard-summary-lines > div,
.dashboard-stock-list > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dashboard-stock-list > div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
}
.dashboard-stock-list > div small {
  grid-column: 1 / -1;
  justify-self: start;
  min-height: 22px;
  margin-bottom: 6px;
  font-size: 0.7rem;
}
.dashboard-progress-copy span,
.dashboard-summary-lines span,
.dashboard-stock-list span {
  color: var(--muted);
}
.dashboard-progress-copy {
  width: 100%;
  padding: 0;
  border-radius: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
}
.dashboard-progress-copy:hover span,
.dashboard-progress-copy:hover strong {
  color: var(--pink-strong);
}
.dashboard-revenue-progress {
  margin-block: 2px;
}
.dashboard_sales .dashboard-primary-value {
  font-size: clamp(1.35rem, 2vw, 1.8rem);
}
.dashboard-summary-lines,
.dashboard-stock-list,
.dashboard-compact-list {
  display: grid;
  gap: 0;
}
.dashboard-summary-lines > div,
.dashboard-stock-list > div {
  min-height: 42px;
  border-bottom: 1px solid var(--line);
}
.dashboard-summary-lines > div:last-child,
.dashboard-stock-list > div:last-child {
  border-bottom: 0;
}
.dashboard-compact-item {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  border-bottom: 1px solid var(--line);
}
.dashboard-compact-item:last-child {
  border-bottom: 0;
}
.dashboard-compact-item strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-compact-item small,
.dashboard-compact-type {
  color: var(--muted);
  font-size: 0.78rem;
}
.dashboard-compact-type {
  display: inline-flex;
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  background: var(--pink-soft);
  color: var(--pink-strong);
}
.dashboard-focus-badge {
  display: inline-flex;
  width: fit-content;
  padding: 5px 9px;
  border-radius: 999px;
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-size: 0.75rem;
  font-weight: 650;
}
.dashboard-empty-compact {
  display: grid;
  justify-items: start;
  gap: 12px;
}
.dashboard-empty-compact p {
  margin: 0;
}
.dashboard-today-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.dashboard-today-block {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 9px;
  min-width: 0;
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--panel-soft) 62%, transparent);
}
.dashboard-mini-icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 10px;
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.dashboard-mini-icon svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.dashboard-today-block div > strong,
.dashboard-today-block div > span,
.dashboard-today-block div > small {
  min-width: 0;
}
.dashboard-today-block div {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 8px;
  min-width: 0;
}
.dashboard-today-block div > strong {
  font-size: 0.82rem;
}
.dashboard-today-block div > span {
  grid-column: 2;
  grid-row: 1;
}
.dashboard-today-block div > small {
  grid-column: 1 / -1;
}
.dashboard-today-block div > span,
.dashboard-today-block div > small {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.72rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-card-link {
  justify-self: start;
  margin-top: auto;
}
.dashboard-positive-state {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--muted);
}
.dashboard-positive-state span {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  color: var(--green-strong);
  background: var(--green-soft);
}
.dashboard-positive-state p {
  margin: 0;
}
.dashboard-participation-table {
  display: grid;
  min-width: 0;
}
.dashboard-participation-head,
.dashboard-participation-row {
  display: grid;
  grid-template-columns: 110px minmax(180px, 1.6fr) minmax(100px, 0.8fr) minmax(
      100px,
      0.7fr
    ) 24px;
  align-items: center;
  gap: 12px;
}
.dashboard-participation-head {
  padding: 0 10px 8px;
  color: var(--muted);
  font-size: 0.74rem;
}
.dashboard-participation-row {
  width: 100%;
  min-height: 48px;
  padding: 8px 10px;
  border-top: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
}
.dashboard-participation-row:hover {
  background: color-mix(in oklch, var(--pink-soft) 48%, transparent);
}
.dashboard-participation-row strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-participation-row > span:not(.dashboard-compact-type),
.dashboard-participation-row small {
  color: var(--muted);
}
.dashboard-participation-row b {
  color: var(--pink-strong);
  font-size: 1.3rem;
  text-align: right;
}
.dashboard_stock .dashboard-section-head h2 {
  font-size: 0.94rem;
}
.weekly-task-board {
  display: grid;
  grid-template-columns: repeat(7, minmax(180px, 1fr));
  gap: 12px;
  overflow-x: auto;
  padding-bottom: 6px;
}
.weekly-task-day {
  min-width: 180px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in oklch, var(--neutral-100) 66%, transparent);
  padding: 12px;
  box-shadow: var(--shadow-soft);
  overflow: visible;
  box-sizing: border-box;
}
.weekly-task-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
  text-transform: capitalize;
}
.weekly-task-head span {
  color: var(--muted);
  font-size: 0.82rem;
}
.weekly-task-list {
  display: grid;
  gap: 8px;
  width: 100%;
  min-width: 0;
  box-sizing: border-box;
}
.weekly-task-day .weekly-task-card {
  display: grid;
  grid-template-columns: 1fr;
  align-items: stretch;
  gap: 6px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 78px;
  padding: 10px;
  border-radius: 14px;
  box-sizing: border-box;
  overflow: visible;
}
.weekly-task-card-main {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  display: grid;
  gap: 4px;
  box-sizing: border-box;
}
.weekly-task-card-main span {
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.2;
  text-transform: capitalize;
}
.weekly-task-card-main .item-title {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: normal;
}
.weekly-task-card .weekly-task-toggle {
  grid-column: auto;
  grid-row: auto;
  width: 32px;
  height: 32px;
  justify-self: end;
  align-self: end;
}
.task-summary .chip {
  white-space: normal;
}
.task-card {
  gap: 0;
}
.task-summary {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto 38px;
  align-items: center;
  gap: 10px;
}
.task-summary-main {
  min-width: 200px;
}
.task-summary-main .item-title {
  margin-bottom: 2px;
}
.task-details-panel {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--line);
}
.task-detail-modal-content {
  align-items: start;
}
.task-detail-value {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 82%, transparent);
  color: var(--text);
  padding: 11px 13px;
  overflow-wrap: anywhere;
}
.task-detail-value.multiline {
  min-height: 96px;
}
.dashboard-column {
  display: grid;
  gap: 16px;
  align-content: start;
}
.masonry-grid {
  column-count: 2;
  column-gap: 16px;
}
.masonry-grid .item-card {
  display: inline-grid;
  width: 100%;
  margin: 0 0 16px;
  break-inside: avoid;
}
.company-block-section {
  display: grid;
  gap: 14px;
}
.company-block-list {
  display: grid;
  gap: 12px;
}
.company-block-card {
  gap: 0;
  padding: 0;
  overflow: hidden;
}
.company-block-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  min-height: 62px;
  padding: 16px 18px;
  border: 0;
  background: transparent;
  color: var(--text);
  text-align: left;
  box-shadow: none;
  cursor: pointer;
}
.company-block-title {
  overflow: hidden;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.company-block-chevron {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  transition:
    transform 0.18s ease,
    background 0.18s ease;
}
.company-block-card.open .company-block-chevron {
  transform: rotate(180deg);
  background: var(--pink-soft);
  color: var(--pink-strong);
}
.company-block-details {
  display: grid;
  gap: 12px;
  padding: 0 18px 18px;
  animation: companyBlockIn 0.18s ease;
}
.company-block-details[hidden] {
  display: none;
}
.company-block-details p {
  margin: 0;
  line-height: 1.6;
}
.company-block-attachments {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  width: 100%;
}
.company-block-attachments:empty {
  display: none;
}
.company-block-attachments .record-image,
.company-block-attachments .file-card {
  width: 100%;
  max-height: 220px;
}
.company-block-attachments .record-image {
  aspect-ratio: 4 / 3;
}
.compact-empty {
  min-height: 110px;
}
@keyframes companyBlockIn {
  from {
    opacity: 0;
    transform: translateY(-4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.daily-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.daily-lane {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: color-mix(in oklch, var(--neutral-100) 48%, transparent);
  box-shadow: var(--shadow-soft);
}
.daily-lane-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.daily-lane-head h3 {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.96rem;
  font-weight: 560;
  color: var(--text);
}
.daily-card.done {
  opacity: 0.78;
}
.daily-time {
  color: var(--pink-strong);
  font-size: 1rem;
  font-weight: 560;
  white-space: nowrap;
}
.completed-panel {
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: color-mix(in oklch, var(--neutral-100) 56%, transparent);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.completed-panel summary {
  cursor: pointer;
  padding: 16px 18px;
  color: var(--text);
  font-weight: 540;
}
.completed-panel .list {
  padding: 0 14px 14px;
}
.daily-filter-panel {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto repeat(3, minmax(150px, 200px));
  gap: 10px;
  align-items: center;
  margin-bottom: 18px;
}
.daily-filter-panel input,
.daily-filter-panel select {
  min-height: 42px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  padding: 0 12px;
}
.daily-filter-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: nowrap;
}
.daily-list-board {
  display: grid;
  gap: 16px;
}
.daily-record-group {
  display: grid;
  gap: 10px;
}
.daily-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 2px;
}
.daily-group-head h3 {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 0.96rem;
  font-weight: 560;
}
.daily-record-list {
  display: grid;
  gap: 10px;
}
.daily-record-card {
  gap: 12px;
  padding: 14px;
}
.daily-record-main {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto 38px;
  gap: 12px;
  align-items: center;
}
.daily-check {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1.5px solid color-mix(in oklch, var(--pink) 52%, var(--line));
  border-radius: 999px;
  color: var(--on-accent);
  background: color-mix(in oklch, var(--neutral-100) 86%, transparent);
  font-weight: 700;
}
.daily-check.checked {
  background: var(--pink);
  border-color: var(--pink);
}
.daily-check:disabled {
  cursor: default;
  opacity: 0.75;
}
.daily-record-title {
  min-width: 0;
}
.daily-record-title .item-title {
  overflow-wrap: anywhere;
}
.daily-details-toggle {
  display: grid;
  grid-column: 4;
  grid-row: 1;
  place-items: center;
  width: 36px;
  height: 36px;
  cursor: pointer;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--muted);
  background: color-mix(in oklch, var(--neutral-100) 70%, transparent);
  list-style: none;
}
.daily-details-toggle.open {
  color: var(--pink-strong);
  background: var(--pink-soft);
  transform: rotate(180deg);
}
.daily-details-panel {
  grid-column: 1 / -1;
  display: grid;
  gap: 9px;
  margin-top: 2px;
}
.daily-description {
  margin: 0;
  color: oklch(39% 0.018 60);
  font-size: 0.92rem;
  line-height: 1.5;
}
.daily-detail-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  padding: 0;
  border: 0;
  background: transparent;
}
.daily-detail-grid span {
  display: grid;
  gap: 3px;
  min-width: 0;
  color: oklch(52% 0.018 60);
  font-size: 0.79rem;
}
.daily-detail-grid strong {
  color: oklch(62% 0.016 60);
  font-size: 0.68rem;
  font-weight: 560;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.daily-priority {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: oklch(94.5% 0.014 78);
  color: oklch(47% 0.02 60);
  font-size: 0.72rem;
  font-style: normal;
}
.daily-priority.pink {
  background: var(--pink-soft);
  color: var(--pink-strong);
}
.daily-priority.red {
  background: oklch(94% 0.04 22);
  color: oklch(44% 0.14 22);
}
.daily-assignee {
  display: grid;
}
.daily-record-card .access-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 0;
}
.daily-record-card .access-summary span {
  border: 0;
  border-radius: 12px;
  background: oklch(98% 0.006 80 / 0.62);
  padding: 8px 10px;
  color: oklch(51% 0.018 60);
  font-size: 0.78rem;
}
.avatar.tiny {
  width: 28px;
  height: 28px;
  font-size: 0.72rem;
}
.daily-details-panel p,
.daily-details-panel .task-checklist,
.daily-details-panel .access-summary {
  margin-top: 0;
}
.daily-record-card .item-actions {
  gap: 7px;
}
.daily-record-card .item-actions .btn {
  min-height: 30px;
  padding: 0 10px;
  border-radius: 10px;
  font-size: 0.78rem;
}
.daily-duplicate-action.btn.small {
  display: inline-grid;
  place-items: center;
  width: 30px;
  min-width: 30px;
  padding: 0;
}
.daily-action-icon {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.card {
  background: color-mix(in oklch, var(--neutral-100) 86%, transparent);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px;
  box-shadow: var(--shadow-card);
  backdrop-filter: blur(10px);
}
.card h3 {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-weight: 540;
  letter-spacing: -0.01em;
  font-size: 1.18rem;
}
.privacy-card .item-top h3 {
  margin-bottom: 0;
}
.card-tools {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}
.privacy-toggle {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--pink-strong);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  box-shadow: 0 1px 0 color-mix(in oklch, var(--neutral-100) 70%, transparent)
    inset;
  transition:
    color 0.18s ease,
    background 0.18s ease,
    border-color 0.18s ease;
}
.privacy-toggle:hover {
  color: var(--pink-strong);
  background: var(--pink-soft);
  border-color: color-mix(in oklch, var(--pink) 46%, var(--line));
}
.privacy-toggle svg {
  width: 18px;
  height: 18px;
}
.privacy-placeholder {
  display: grid;
  place-items: center;
  min-height: 74px;
  border: 1px dashed oklch(87% 0.018 70);
  border-radius: 16px;
  color: var(--muted);
  background: oklch(98% 0.006 80 / 0.74);
  font-size: 0.9rem;
}
.card p {
  color: var(--muted);
  line-height: 1.55;
}
.metric {
  font-size: 1rem;
  font-family: var(--font-display);
  font-weight: 560;
  letter-spacing: -0.01em;
}
.muted {
  color: var(--muted);
}
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: oklch(94.5% 0.014 78);
  color: oklch(42% 0.02 60);
  font-size: 0.8rem;
  font-weight: 540;
  box-shadow: 0 1px 0 color-mix(in oklch, var(--neutral-100) 50%, transparent)
    inset;
}

.list {
  display: grid;
  gap: 12px;
}
.bulk-action-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  justify-content: space-between;
  margin: 0 0 14px;
  padding: 9px 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in oklch, var(--neutral-100) 52%, transparent);
  box-shadow: 0 10px 24px -24px oklch(50% 0.035 60 / 0.35);
}
.bulk-action-bar .muted {
  margin-right: auto;
  font-size: 0.9rem;
}
.bulk-action-bar .btn.danger {
  min-height: 34px;
  padding: 0 14px;
  border-color: oklch(88% 0.035 20);
  background: oklch(96% 0.035 20 / 0.72);
  color: oklch(42% 0.12 22);
  box-shadow: none;
}
.bulk-action-bar .btn.danger:disabled {
  background: oklch(96% 0.008 75 / 0.6);
  color: oklch(61% 0.018 65);
  border-color: var(--line);
}
.bulk-select-all {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 650;
  white-space: nowrap;
}
.bulk-select-all input,
.bulk-item-check input {
  width: 17px;
  height: 17px;
  accent-color: var(--pink);
}
.bulk-item {
  position: relative;
  --bulk-gutter: 44px;
  padding-left: calc(17px + var(--bulk-gutter));
}
.bulk-item-check {
  position: absolute;
  top: 17px;
  left: 17px;
  z-index: 3;
  display: grid;
  place-items: center;
  opacity: 0;
  transform: scale(0.96);
  transition:
    opacity 0.16s ease,
    transform 0.16s ease;
}
.bulk-item:hover > .bulk-item-check,
.bulk-item.bulk-selected > .bulk-item-check,
.bulk-action-bar.active ~ .bulk-list .bulk-item-check,
.bulk-action-bar.active ~ .daily-list-board .bulk-item-check,
.bulk-action-bar.active ~ .weekly-task-board .bulk-item-check,
.bulk-action-bar.active ~ .completed-section .bulk-item-check {
  opacity: 1;
  transform: scale(1);
}
.activity-log-card .bulk-item-check {
  top: 50%;
  transform: translateY(-50%) scale(0.96);
}
.activity-log-card:hover > .bulk-item-check,
.activity-log-card.bulk-selected > .bulk-item-check,
.bulk-action-bar.active ~ .bulk-list .activity-log-card .bulk-item-check {
  transform: translateY(-50%) scale(1);
}
.bulk-item.bulk-selected {
  border-color: color-mix(in oklch, var(--pink) 76%, var(--line));
  box-shadow: 0 16px 35px -28px
    color-mix(in oklch, var(--pink-strong) 52%, transparent);
}
.item-card {
  display: grid;
  gap: 12px;
  background: color-mix(in oklch, var(--neutral-100) 82%, transparent);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 17px;
  box-shadow: var(--shadow-card);
}
.item-card.bulk-item {
  padding-left: calc(17px + var(--bulk-gutter));
}
.item-card.compact-card {
  gap: 8px;
  padding: 13px 14px;
  box-shadow: var(--shadow-soft);
}
.activity-log-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.activity-log-card.clickable {
  cursor: pointer;
}
.activity-log-card.clickable:hover {
  border-color: color-mix(in oklch, var(--pink) 44%, var(--line));
  background: color-mix(in oklch, var(--neutral-100) 94%, transparent);
}
.activity-log-sentence {
  margin: 0;
  min-width: 0;
  line-height: 1.45;
}
.activity-log-actions {
  flex: 0 0 auto;
}
.activity-log-actions .btn.small {
  width: auto;
  min-width: 72px;
  flex-basis: auto;
  padding-inline: 12px;
  white-space: nowrap;
}
.compact-card .item-title {
  line-height: 1.25;
}
.card .dashboard-task-card .item-title,
.dashboard-task-card h3.item-title {
  font-family: var(--font-sans);
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0;
  color: var(--muted);
  line-height: 1.55;
}
.item-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.item-title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 540;
  letter-spacing: 0;
}
.item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}
.access-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 0.78rem;
}
.access-summary span {
  padding: 6px 9px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: oklch(98% 0.006 80 / 0.82);
}
.combined-section {
  display: grid;
  gap: 14px;
  margin-bottom: 28px;
}
.section-heading h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 540;
  letter-spacing: -0.01em;
}
.section-heading span {
  color: var(--muted);
}
.item-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.item-actions .btn.small {
  width: 72px;
  flex: 0 0 72px;
  min-height: 30px;
  padding: 0 8px;
  border-radius: 10px;
  font-size: 0.76rem;
}
.item-actions .btn.small.primary,
.item-actions .btn.small.ghost,
.item-actions .btn.small.danger {
  min-width: 72px;
}
.item-actions .action-icon-btn.btn.small {
  display: inline-grid;
  place-items: center;
  width: 30px;
  min-width: 30px;
  flex: 0 0 30px;
  padding: 0;
}
.action-icon-btn svg {
  width: 15px;
  height: 15px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.item-actions [data-destroy].btn.small {
  width: 138px;
  flex-basis: 138px;
  min-width: 138px;
  font-size: 0.72rem;
  white-space: normal;
  line-height: 1.1;
}
.kanban-board {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 14px;
  overflow-x: hidden;
  padding: 2px 2px 14px;
  scroll-snap-type: none;
}
.kanban-column {
  min-height: 560px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
  box-shadow: var(--shadow-card);
  scroll-snap-align: start;
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    transform 0.18s ease;
}
.kanban-column.drag-over {
  border-color: var(--pink);
  background: color-mix(in oklch, var(--pink-soft) 72%, transparent);
  transform: translateY(-2px);
}
.kanban-column-head {
  position: sticky;
  top: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
  padding: 4px 2px 10px;
  background: linear-gradient(
    180deg,
    color-mix(in oklch, var(--neutral-100) 78%, transparent),
    oklch(100% 0 0 / 0)
  );
  backdrop-filter: blur(8px);
}
.kanban-column-head strong {
  display: block;
  font-family: var(--font-display);
  font-size: 1.08rem;
  letter-spacing: -0.01em;
}
.kanban-column-head span {
  display: block;
  color: var(--muted);
  font-size: 0.78rem;
  margin-top: 2px;
}
.kanban-list {
  display: grid;
  gap: 11px;
}
.kanban-empty {
  min-height: 118px;
  display: grid;
  place-items: center;
  padding: 18px;
  border: 1px dashed oklch(86% 0.016 70);
  border-radius: 18px;
  color: var(--muted);
  text-align: center;
  font-size: 0.9rem;
}
.marketing-kanban-card {
  cursor: grab;
  gap: 10px;
}
.marketing-card-details {
  display: grid;
  gap: 10px;
}
.details-toggle {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--muted);
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  font-size: 1.1rem;
  line-height: 1;
}
.marketing-kanban-card.dragging {
  opacity: 0.55;
  cursor: grabbing;
}
.marketing-tabs {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  overflow: visible;
}
.marketing-tab {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
  white-space: nowrap;
  font-size: 0.9rem;
  font-weight: 600;
  box-shadow: none;
}
.marketing-tab.active {
  color: var(--pink-strong);
  border-color: color-mix(in oklch, var(--pink) 60%, transparent);
  background: color-mix(in oklch, var(--pink-soft) 70%, transparent);
}
.marketing-tab.active::after {
  display: none;
}
.marketing-content-filters {
  margin-bottom: 18px;
}
.marketing-idea-filters {
  align-items: center;
}
.marketing-idea-filters input {
  min-height: 36px;
  width: min(220px, 100%);
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 13px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
}
.marketing-ideas-grid {
  display: grid;
  grid-template-columns: 1fr;
  align-items: start;
  gap: 12px;
}
.marketing-idea-card {
  align-self: start;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  overflow: hidden;
}
.marketing-idea-summary {
  appearance: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-height: 72px;
  padding: 16px 18px;
  border: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  text-align: left;
}
.marketing-idea-summary span {
  display: flex;
  align-items: baseline;
  gap: 14px;
  min-width: 0;
}
.marketing-idea-summary strong,
.marketing-idea-summary small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.marketing-idea-summary strong {
  font-size: 1rem;
}
.marketing-idea-summary small {
  color: var(--muted);
  font-size: 0.86rem;
}
.marketing-idea-summary b {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  flex: 0 0 auto;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-soft);
  font-size: 0.95rem;
  line-height: 1;
}
.marketing-idea-details {
  display: grid;
  gap: 14px;
  padding: 0 18px 18px;
  border-top: 1px solid var(--line);
}
.marketing-idea-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px 18px;
  padding-top: 16px;
}
.marketing-idea-meta span,
.marketing-idea-section {
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}
.marketing-idea-meta strong,
.marketing-idea-section > strong {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
}
.marketing-idea-meta span,
.marketing-idea-section p {
  color: var(--text);
  font-size: 0.86rem;
}
.marketing-idea-section {
  padding-top: 12px;
  border-top: 1px solid oklch(88% 0.015 70 / 0.72);
}
.marketing-idea-section p {
  margin: 0;
}
.marketing-idea-section .content-thumb-list,
.marketing-idea-section .content-thumb {
  margin-top: 6px;
}
.marketing-insight-filters {
  align-items: center;
}
.marketing-insight-filters input {
  min-height: 36px;
  width: min(220px, 100%);
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 13px;
  color: var(--text);
  background: var(--panel);
}
.marketing-insights-list {
  display: grid;
  gap: 12px;
}
.marketing-insight-card {
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel);
  overflow: hidden;
}
.marketing-insight-summary {
  appearance: none;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 16px;
  width: 100%;
  min-height: 74px;
  padding: 15px 18px;
  border: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  text-align: left;
}
.marketing-insight-title {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.marketing-insight-title strong,
.marketing-insight-title small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.marketing-insight-title strong {
  font-size: 1rem;
}
.marketing-insight-title small {
  color: var(--muted);
  font-size: 0.82rem;
}
.marketing-insight-metrics {
  display: flex;
  align-items: center;
  gap: 14px;
}
.marketing-insight-metrics span {
  display: grid;
  gap: 2px;
  min-width: 68px;
}
.marketing-insight-metrics b {
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1;
}
.marketing-insight-metrics small {
  color: var(--muted);
  font-size: 0.68rem;
}
.marketing-insight-chevron {
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-soft);
  font-size: 0.95rem;
  line-height: 1;
}
.marketing-insight-details {
  display: grid;
  gap: 14px;
  padding: 0 18px 18px;
  border-top: 1px solid var(--line);
}
.marketing-insight-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px 18px;
  padding-top: 16px;
}
.marketing-insight-meta span,
.marketing-insight-section {
  min-width: 0;
  padding: 0;
  border: 0;
  background: transparent;
}
.marketing-insight-meta strong,
.marketing-insight-section > strong {
  display: block;
  margin-bottom: 5px;
  color: var(--muted);
  font-size: 0.72rem;
  text-transform: uppercase;
}
.marketing-insight-meta span,
.marketing-insight-section,
.marketing-insight-section a {
  color: var(--text);
  font-size: 0.86rem;
}
.marketing-insight-section {
  padding-top: 16px;
}
.marketing-insight-section a {
  display: inline-block;
  max-width: 100%;
  overflow-wrap: anywhere;
  color: var(--pink-strong);
}
.marketing-planning {
  display: grid;
  gap: 14px;
}
.marketing-month-switcher {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 0;
}
.marketing-month-switcher strong {
  min-width: 132px;
  text-align: center;
  font-size: 1rem;
}
.marketing-plan-card {
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
  box-shadow: none;
}
.marketing-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}
.marketing-card-head > div {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.marketing-card-head h3 {
  margin: 0;
  font-size: 0.93rem;
}
.marketing-plan-icon {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 9px;
  color: var(--pink-strong);
  background: transparent;
  font-size: 0.95rem;
  font-weight: 700;
}
.marketing-objective-card {
  position: relative;
  min-height: auto;
  overflow: visible;
}
.marketing-objective-card::after {
  display: none;
}
.marketing-objective-card .marketing-card-head {
  position: relative;
  z-index: 1;
}
.marketing-objective-card p {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 760px;
  color: var(--muted);
  font-size: 0.92rem;
}
.marketing-metrics-grid,
.marketing-planning-grid {
  display: grid;
  gap: 14px;
}
.marketing-metrics-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.marketing-planning-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: start;
}
.marketing-metric-card strong {
  display: block;
  margin-bottom: 10px;
  font-family: var(--font-display);
  font-size: 1.55rem;
  line-height: 1;
}
.marketing-metric-card .progress {
  height: 7px;
  margin-bottom: 10px;
}
.marketing-metric-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
}
.marketing-add-btn {
  width: 28px;
  height: 28px;
  padding: 0;
  font-size: 1.05rem;
  color: var(--pink-strong);
}
.marketing-list-card {
  min-height: 150px;
  align-self: start;
  padding: 14px 16px;
}
.marketing-empty-visual {
  min-height: auto;
  display: block;
  padding-top: 24px;
  text-align: left;
  color: var(--muted);
}
.marketing-empty-visual > span {
  display: none;
}
.marketing-empty-visual p {
  margin: 0;
  font-size: 0.9rem;
}
.marketing-plan-list {
  display: grid;
  gap: 8px;
}
.marketing-plan-item,
.marketing-date-item {
  padding: 10px 11px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: color-mix(in oklch, var(--neutral-100) 50%, transparent);
  font-size: 0.88rem;
}
.marketing-plan-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.marketing-plan-item > span,
.marketing-date-item > div {
  min-width: 0;
  flex: 1;
}
.marketing-item-edit {
  width: auto;
  flex: 0 0 auto;
}
.marketing-item-actions {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  flex-wrap: wrap;
  justify-content: flex-end;
  flex: 0 0 auto;
  margin-left: auto;
}
.marketing-plan-item > .marketing-item-actions,
.marketing-date-item > .marketing-item-actions {
  flex: 0 0 auto;
}
.marketing-item-icon {
  display: grid;
  place-items: center;
  width: 27px;
  height: 27px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--muted);
  background: color-mix(in oklch, var(--neutral-100) 65%, transparent);
}
.marketing-item-icon:hover {
  color: var(--pink-strong);
  border-color: color-mix(in oklch, var(--pink) 42%, var(--line));
}
.marketing-item-icon.danger:hover {
  color: var(--red-strong);
  background: var(--red-soft);
}
.marketing-item-icon svg {
  width: 14px;
  height: 14px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.marketing-date-item {
  display: flex;
  align-items: center;
  gap: 10px;
}
.marketing-date-item b {
  display: grid;
  place-items: center;
  width: 40px;
  height: 44px;
  border-radius: 10px;
  background: color-mix(in oklch, var(--pink-soft) 70%, transparent);
  color: var(--text);
  line-height: 1;
}
.marketing-date-item b span {
  font-size: 0.95rem;
}
.marketing-date-item b small,
.marketing-date-item div small {
  color: var(--muted);
  text-transform: uppercase;
}
.marketing-date-item div {
  display: grid;
  gap: 3px;
}
.content-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: var(--panel-soft);
}
.content-thumb.placeholder {
  display: grid;
  place-items: center;
  color: var(--muted);
  font-weight: 540;
  background:
    linear-gradient(
      135deg,
      color-mix(in oklch, var(--pink-soft) 74%, transparent),
      oklch(96% 0.016 80)
    ),
    var(--panel-soft);
}
.content-thumb-list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.content-thumb-list.compact {
  grid-template-columns: 1fr;
}
.content-thumb-list .file-card {
  min-width: 0;
}
.media-count {
  position: absolute;
  right: 8px;
  bottom: 8px;
  padding: 5px 8px;
  border-radius: 999px;
  color: var(--on-accent);
  background: oklch(28% 0.02 60 / 0.78);
  font-size: 0.78rem;
  font-weight: 600;
}
.feed-preview-wrap {
  max-width: 760px;
  margin-inline: auto;
}
.feed-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.feed-preview-slot {
  position: relative;
  display: grid;
  place-items: center;
  aspect-ratio: 4 / 5;
  border: 1px solid var(--line);
  border-radius: 0;
  background: color-mix(in oklch, var(--neutral-100) 74%, transparent);
  overflow: hidden;
  color: var(--muted);
  font-size: 2rem;
  cursor: pointer;
}
.feed-preview-slot[draggable="true"] {
  cursor: grab;
}
.feed-preview-slot.dragging {
  opacity: 0.56;
  transform: scale(0.985);
}
.feed-preview-slot.drag-over {
  border-color: var(--pink);
  background: var(--pink-soft);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--pink) 20%, transparent);
}
.feed-preview-slot input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.feed-preview-slot img,
.feed-preview-slot video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.feed-remove {
  position: absolute;
  top: 6px;
  right: 6px;
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  color: var(--on-accent);
  background: oklch(28% 0.02 60 / 0.72);
  font-size: 1rem;
  line-height: 1;
}
.feed-preview-help {
  text-align: center;
  margin-top: 12px;
}
.marketing-calendar {
  padding: 0;
  overflow: hidden;
}
.marketing-calendar-cell {
  min-height: 174px;
  padding: 8px;
}
.marketing-day-list {
  display: grid;
  gap: 6px;
  margin-top: 4px;
}
.marketing-calendar-item {
  display: grid;
  gap: 5px;
  width: 100%;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in oklch, var(--neutral-100) 80%, transparent);
  text-align: left;
  font-size: 0.72rem;
  color: var(--text);
}
.marketing-calendar-item img,
.marketing-calendar-item video,
.calendar-media-placeholder {
  width: 100%;
  height: 70px;
  border-radius: 9px;
  object-fit: cover;
  background: var(--pink-soft);
}
.marketing-calendar-item span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
  line-height: 1.2;
  overflow-wrap: anywhere;
}
.record-image {
  width: 100%;
  max-height: 260px;
  object-fit: cover;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-soft);
}
.file-card {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--neutral-100) 66%, transparent);
  box-shadow: var(--shadow-soft);
}
.file-card > span {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 14px;
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-size: 0.78rem;
  font-weight: 600;
}
.file-card strong {
  display: block;
  font-weight: 540;
}
.file-card small {
  display: block;
  color: var(--muted);
  margin-top: 2px;
}
.kanban-stage-row {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
}
.stage-select {
  width: 100%;
  min-height: 36px;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 0 10px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  font-weight: 540;
}
.finance-report {
  margin-bottom: 16px;
}
.finance-windows {
  display: grid;
  gap: 12px;
}
.finance-month-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}
.finance-window {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  box-shadow: var(--shadow-card);
}
.finance-window > summary {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  height: 80px;
  min-height: 60px;
  padding: 15px 18px;
  cursor: pointer;
  list-style: none;
  flex-direction: row;
}
.finance-window > summary > div {
  min-width: 0;
}
.finance-window > summary span {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: clamp(0.82rem, 1vw, 0.88rem);
}
.sales-window summary > div {
  min-width: 0;
}
.sales-window summary span {
  max-width: 100%;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: clamp(0.72rem, 1vw, 0.88rem);
}
.sales-window .finance-summary-controls .chip {
  min-width: 106px;
  justify-content: center;
}
.finance-window > summary::-webkit-details-marker {
  display: none;
}
.finance-window > summary::after {
  content: "";
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 0;
  height: 0;
}
.finance-window[open] > summary {
  border-bottom: 1px solid var(--line);
}
.finance-window[open] > summary::after {
  content: "×";
  width: 32px;
  height: 32px;
  border-radius: 12px;
  background: var(--pink-soft);
  color: var(--pink-strong);
  font-size: 1.2rem;
  line-height: 1;
}
.finance-window > summary strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 540;
  font-size: 1.15rem;
}
.finance-window > summary span {
  display: block;
  color: var(--muted);
  font-size: clamp(0.72rem, 1vw, 0.88rem);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.finance-window > summary > .chip {
  display: inline-flex;
  margin-left: auto;
  margin-top: 0;
  color: oklch(42% 0.02 60);
  font-size: 0.8rem;
}
.finance-window > summary > .chip.pink {
  color: var(--pink-strong);
}
.finance-summary-controls {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
}
.finance-month-summary-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  margin-left: auto;
}
.finance-month-summary-actions .finance-summary-controls {
  margin-left: 0;
}
.finance-month-add {
  display: inline-grid;
  place-items: center;
  flex: 0 0 34px;
  width: 34px;
  min-width: 34px;
  height: 34px;
  min-height: 34px;
  padding: 0;
  border-radius: 12px;
  color: var(--pink-strong);
  font-size: 1.15rem;
  line-height: 1;
}
.finance-summary-controls .chip {
  display: inline-flex;
  margin: 0;
  color: oklch(42% 0.02 60);
  font-size: 0.8rem;
}
.finance-summary-controls .chip.pink {
  color: var(--pink-strong);
}
.finance-summary-value {
  color: inherit;
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 540;
  white-space: nowrap;
}
.finance-month-grid > .finance-window:not(.sales-window) > summary {
  flex-wrap: wrap;
  height: auto;
}
.finance-month-grid
  > .finance-window:not(.sales-window)
  > summary
  > div:first-child {
  flex: 1 1 110px;
}
.finance-month-grid
  > .finance-window:not(.sales-window)
  > summary
  .finance-summary-controls {
  flex: 0 1 auto;
  max-width: 100%;
}
.finance-month-grid
  > .finance-window:not(.sales-window)
  > summary
  .finance-summary-value {
  max-width: none;
  overflow: visible;
  text-align: right;
  text-overflow: clip;
  white-space: normal;
  overflow-wrap: anywhere;
}
.finance-summary-value.pink {
  color: var(--pink-strong);
}
.finance-eye {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  color: var(--pink-strong);
}
.finance-window-body {
  padding: 16px;
}
details.finance-window:not([open]) > .finance-window-body {
  display: none;
}
.sales-report-body {
  display: grid;
  gap: 16px;
}
.sales-report-window:not(.open) > .sales-report-body {
  display: none;
}
.sales-report-summary {
  display: flex;
  align-items: center;
  gap: 16px;
  min-height: 92px;
  padding: 16px 18px;
  cursor: pointer;
}
.sales-report-summary > div:first-child {
  min-width: 0;
  margin-right: auto;
}
.sales-report-summary > div:first-child strong,
.sales-report-summary > div:first-child span {
  display: block;
}
.sales-report-summary > div:first-child strong {
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 540;
}
.sales-report-summary > div:first-child span {
  margin-top: 2px;
  color: var(--muted);
  font-size: clamp(0.72rem, 1vw, 0.88rem);
}
.sales-report-permission {
  display: flex;
  justify-content: flex-end;
}
.sales-kpi-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.sales-kpi-card {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 17px;
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  box-shadow: var(--shadow-soft);
}
.sales-kpi-card > span {
  display: grid;
  place-items: center;
  flex: 0 0 42px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.sales-kpi-card svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.7;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.sales-kpi-card div {
  display: grid;
  min-width: 0;
  gap: 4px;
}
.sales-kpi-card small {
  color: var(--muted);
  font-size: 0.72rem;
}
.sales-kpi-card strong {
  overflow: hidden;
  font-family: var(--font-display);
  font-size: clamp(0.92rem, 1.25vw, 1.12rem);
  font-weight: 560;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sales-kpi-card em {
  color: var(--muted);
  font-size: 0.7rem;
  font-style: normal;
  line-height: 1.3;
}
.sales-report-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(240px, 0.85fr);
  gap: 12px;
  align-items: stretch;
}
.sales-report-grid > .card {
  min-width: 0;
  padding: 18px;
}
.sales-report-grid h3 {
  margin: 0;
  font-size: 0.98rem;
}
.sales-report-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.sales-report-title span {
  color: var(--muted);
  font-size: 0.68rem;
}
.sales-annual-chart {
  display: grid;
  grid-template-columns: repeat(12, minmax(2px, 1fr));
  align-items: end;
  gap: 7px;
  height: 230px;
  margin-top: 18px;
}
.sales-annual-column {
  display: grid;
  grid-template-rows: 30px minmax(0, 1fr) 18px;
  align-items: end;
  min-width: 0;
  height: 100%;
  text-align: center;
}
.sales-annual-column > span {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.55rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sales-annual-column > div {
  position: relative;
  display: flex;
  align-items: end;
  justify-content: center;
  width: 100%;
  height: 100%;
  border-bottom: 1px solid var(--line);
}
.sales-annual-column i {
  display: block;
  width: min(24px, 72%);
  min-height: 3px;
  border-radius: 7px 7px 2px 2px;
  background: var(--gradient-rose);
}
.sales-annual-column small {
  padding-top: 5px;
  color: var(--muted);
  font-size: 0.62rem;
}
.sales-products-ranking,
.sales-quick-summary {
  display: grid;
  align-content: start;
  gap: 16px;
}
.sales-ranking-list {
  display: grid;
  gap: 14px;
}
.sales-ranking-list > div {
  display: grid;
  gap: 7px;
}
.sales-ranking-list span {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
}
.sales-ranking-list strong {
  overflow: hidden;
  font-size: 0.72rem;
  font-weight: 520;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sales-ranking-list b {
  flex: 0 0 auto;
  color: var(--muted);
  font-size: 0.7rem;
}
.sales-ranking-list i {
  display: block;
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in oklch, var(--line) 72%, transparent);
}
.sales-ranking-list em {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--gradient-rose);
}
.sales-quick-summary {
  gap: 0;
}
.sales-quick-summary h3 {
  margin-bottom: 7px;
}
.sales-quick-line {
  display: grid;
  grid-template-columns: 8px minmax(0, 1fr);
  gap: 1px 8px;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}
.sales-quick-line:last-child {
  border-bottom: 0;
}
.sales-quick-line > span {
  grid-row: 1 / span 2;
  align-self: center;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--pink);
}
.sales-quick-line small {
  color: var(--muted);
  font-size: 0.66rem;
}
.sales-quick-line strong {
  overflow-wrap: anywhere;
  font-size: 0.72rem;
  font-weight: 560;
}
.finance-month-grid > .finance-window[open],
.sales-month-grid > .finance-window[open] {
  position: fixed;
  inset: 18px;
  z-index: 80;
  overflow: auto;
  border-radius: 24px;
  background: var(--bg);
  box-shadow: 0 28px 80px -32px oklch(35% 0.04 40 / 0.45);
}
.finance-month-grid > .finance-window[open] > summary,
.sales-month-grid > .finance-window[open] > summary {
  position: sticky;
  top: 0;
  z-index: 2;
  background: oklch(98% 0.012 80 / 0.94);
  backdrop-filter: blur(18px);
}
.finance-full-head {
  position: sticky;
  top: 73px;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin: -4px 0 16px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklch, var(--neutral-100) 82%, transparent);
  box-shadow: var(--shadow-soft);
}
.finance-inline-totals {
  display: grid;
  grid-template-columns: repeat(3, minmax(110px, 1fr));
  gap: 8px;
  flex: 1;
}

.finance-inline-totals.finance-general-totals {
  grid-template-columns: repeat(5, minmax(105px, 1fr));
}

.finance-general-head {
  display: grid;
  grid-template-columns: minmax(150px, auto) 1fr auto;
}

.finance-general-head .finance-general-totals {
  grid-column: 1 / -1;
  grid-row: 2;
}

.finance-general-head .finance-access-control {
  grid-column: 3;
  grid-row: 1;
}

.finance-overview-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: start;
  gap: 12px;
  margin-bottom: 16px;
}

.finance-overview-card {
  position: relative;
  box-sizing: border-box;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  border: 1px solid color-mix(in oklch, var(--pink) 18%, var(--line));
  border-radius: 20px;
  background: color-mix(in oklch, var(--pink-soft) 48%, var(--neutral-100));
  box-shadow: var(--shadow-soft);
}

.finance-overview-card summary,
.finance-profit-products-card summary {
  position: relative;
  box-sizing: border-box;
  min-width: 0;
  max-width: 100%;
  min-height: 0;
  height: auto;
  display: grid;
  gap: 12px;
  cursor: pointer;
  list-style: none;
}

.finance-overview-card summary {
  grid-template-columns: 44px minmax(0, 1fr) 32px;
  align-items: start;
  padding: 16px;
}

.finance-overview-card summary::-webkit-details-marker,
.finance-profit-products-card summary::-webkit-details-marker {
  display: none;
}

.finance-overview-icon {
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 17px;
  color: var(--pink-strong);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
}

.finance-overview-icon svg {
  width: 24px;
  height: 24px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.75;
}

.finance-overview-copy {
  display: grid;
  min-width: 0;
  max-width: 100%;
  gap: 5px;
  overflow-wrap: anywhere;
}

.finance-overview-title {
  display: block;
  min-width: 0;
  max-width: 100%;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 700;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.finance-overview-copy strong {
  color: var(--pink-strong);
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.7vw, 1.55rem);
  font-weight: 620;
  line-height: 1.08;
  white-space: normal;
  overflow-wrap: anywhere;
}

.finance-overview-copy small {
  color: var(--muted);
  font-size: 0.72rem;
  line-height: 1.35;
  white-space: normal;
  overflow-wrap: anywhere;
}

.finance-overview-toggle {
  position: relative;
  z-index: 1;
  justify-self: end;
  align-self: start;
  flex: 0 0 32px;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border: 1px solid color-mix(in oklch, var(--pink) 20%, var(--line));
  border-radius: 11px;
  color: var(--pink-strong);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  transition: transform 0.2s ease;
}

.finance-overview-card[open] .finance-overview-toggle,
.finance-profit-products-card[open] .finance-overview-toggle {
  transform: rotate(180deg);
}

.finance-overview-breakdown {
  box-sizing: border-box;
  min-width: 0;
  max-width: 100%;
  display: grid;
  gap: 8px;
  padding: 0 16px 16px;
}

.finance-overview-line,
.finance-overview-result {
  box-sizing: border-box;
  min-width: 0;
  max-width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: start;
  padding: 9px 10px;
  border-radius: 13px;
  background: color-mix(in oklch, var(--neutral-100) 70%, transparent);
}

.finance-overview-line small,
.finance-overview-result small {
  min-width: 0;
  color: var(--muted);
  font-size: 0.74rem;
  line-height: 1.25;
  white-space: normal;
  overflow-wrap: anywhere;
}

.finance-overview-line strong,
.finance-overview-result strong {
  justify-self: end;
  color: var(--text);
  text-align: right;
  white-space: nowrap;
}

.finance-overview-line.negative strong {
  color: oklch(55% 0.13 45);
}

.finance-overview-line.positive strong {
  color: var(--green-strong);
}

.finance-overview-result {
  margin-top: 2px;
  border: 1px solid color-mix(in oklch, var(--pink) 24%, var(--line));
  background: var(--pink-soft);
}

.finance-overview-result strong {
  color: var(--pink-strong);
}

.finance-profit-products-card {
  position: relative;
  box-sizing: border-box;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  box-shadow: var(--shadow-card);
}

.finance-profit-products-card summary {
  grid-template-columns: minmax(0, 1fr) 34px;
  align-items: start;
  padding: 18px;
}

.finance-profit-products-card .finance-overview-toggle {
  align-self: start;
  justify-self: end;
}

.finance-profit-products-card summary strong,
.finance-profit-products-card summary span {
  display: block;
  min-width: 0;
  max-width: 100%;
  overflow-wrap: anywhere;
}

.finance-profit-products-card summary strong {
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 560;
  line-height: 1.2;
}

.finance-profit-products-card summary span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.35;
}

.finance-profit-products-body {
  display: grid;
  gap: 12px;
  padding: 0 18px 18px;
}

.finance-profit-table {
  box-sizing: border-box;
  width: 100%;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
}

.finance-profit-row {
  box-sizing: border-box;
  min-width: 760px;
  display: grid;
  grid-template-columns: minmax(220px, 1.35fr) minmax(96px, 0.55fr) repeat(3, minmax(130px, 0.8fr));
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
  font-size: 0.84rem;
}

.finance-profit-row:last-child {
  border-bottom: 0;
}

.finance-profit-row.head {
  color: var(--muted);
  background: color-mix(in oklch, var(--panel-soft) 86%, transparent);
  font-size: 0.72rem;
  font-weight: 750;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.finance-profit-row span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.finance-profit-row > span:nth-child(n + 2) {
  text-align: right;
}

.finance-profit-row strong,
.finance-profit-row small {
  display: block;
}

.finance-profit-row strong {
  color: var(--text);
  white-space: normal;
  overflow-wrap: anywhere;
}

.finance-profit-row small {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.74rem;
}

.finance-profit-row .profit {
  color: var(--green-strong);
  font-weight: 750;
}

.finance-profit-row.total {
  background: var(--pink-soft);
  color: var(--pink-strong);
  font-weight: 760;
}

.finance-profit-empty {
  padding: 18px;
  color: var(--muted);
  text-align: center;
}

.finance-profit-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
}

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

.finance-month-entry-card {
  display: grid;
  align-content: start;
  min-width: 0;
  gap: 14px;
}

.finance-month-entry-card > h3 {
  margin: 0;
}
.finance-column-add {
  width: 100%;
  margin-top: auto;
}

.finance-entry-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.finance-entry-summary span {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 10px;
  border-radius: 13px;
  background: color-mix(in oklch, var(--panel-soft) 62%, transparent);
  color: var(--muted);
  font-size: 0.7rem;
  line-height: 1.25;
}

.finance-entry-summary strong {
  color: var(--text);
  font-size: 0.82rem;
}

.finance-entry-list {
  display: grid;
}

.finance-entry-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr) auto auto auto;
  align-items: center;
  gap: 10px;
  min-height: 62px;
  padding: 10px 2px;
  border-bottom: 1px solid var(--line);
}

.finance-entry-row.clickable {
  cursor: pointer;
}

.finance-entry-row.clickable:hover {
  background: color-mix(in oklch, var(--pink-soft) 24%, transparent);
}

.finance-entry-delete {
  min-width: 0;
  padding-inline: 8px;
}

.finance-entry-origin {
  color: var(--pink-strong);
  font-size: 0.68rem;
  font-weight: 650;
  white-space: nowrap;
}

.finance-entry-row:last-child {
  border-bottom: 0;
}

.finance-entry-row-copy {
  display: grid;
  min-width: 0;
  gap: 2px;
}

.finance-entry-row-copy strong,
.finance-entry-row-copy small {
  overflow-wrap: anywhere;
}

.finance-entry-row-copy small,
.finance-entry-row > span {
  color: var(--muted);
  font-size: 0.72rem;
}

.finance-entry-row-value {
  white-space: nowrap;
  font-size: 0.82rem;
}

.finance-entry-row.effectivated-programmed .finance-entry-row-copy,
.finance-entry-row.effectivated-programmed .finance-entry-row-value,
.finance-entry-row.effectivated-programmed > span {
  opacity: 0.6;
  text-decoration: line-through;
}

.finance-forecast-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 18px;
}

.finance-forecast-card {
  display: grid;
  gap: 14px;
  min-width: 0;
  padding: 18px;
}

.finance-forecast-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

.finance-forecast-head h3,
.finance-forecast-head p {
  margin: 0;
}

.finance-forecast-head p {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.78rem;
}

.finance-forecast-head > strong {
  color: var(--pink-strong);
  font-family: var(--font-display);
  font-size: 1.08rem;
  white-space: nowrap;
}

.finance-forecast-columns,
.finance-forecast-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) 88px 68px;
  align-items: center;
  gap: 10px;
}

.finance-forecast-columns {
  padding: 0 4px 7px;
  border-bottom: 1px solid var(--line);
  color: var(--muted);
  font-size: 0.68rem;
}

.finance-forecast-columns span {
  line-height: 1.2;
}

.finance-forecast-columns span:last-child,
.finance-forecast-row > strong:last-child {
  text-align: right;
}

.finance-forecast-list {
  display: grid;
}

.finance-forecast-row {
  min-height: 62px;
  padding: 10px 4px;
  border-bottom: 1px solid var(--line);
  font-size: 0.78rem;
}

.finance-forecast-row:last-child {
  border-bottom: 0;
}

.finance-forecast-description {
  display: grid;
  min-width: 0;
  gap: 2px;
}

.finance-forecast-description strong {
  overflow-wrap: anywhere;
}

.finance-forecast-description small {
  color: var(--muted);
  line-height: 1.35;
}

.finance-forecast-description em {
  width: fit-content;
  margin-top: 2px;
  color: var(--danger);
  font-size: 0.68rem;
  font-style: normal;
  font-weight: 650;
}

.finance-forecast-row.overdue {
  background: color-mix(in oklch, var(--danger-soft) 32%, transparent);
}

.finance-forecast-empty {
  padding: 18px 4px;
}

.finance-forecast-add {
  width: fit-content;
  margin-top: 2px;
  color: var(--pink-strong);
  font-weight: 650;
}
.finance-inline-totals span {
  display: grid;
  gap: 3px;
  padding: 9px 10px;
  border-radius: 14px;
  background: oklch(98% 0.006 80 / 0.72);
  color: var(--muted);
  font-size: 0.78rem;
}
.finance-inline-totals strong {
  font-family: var(--font-sans);
  font-size: 0.94rem;
  color: var(--text);
}
.finance-access-control {
  display: grid;
  gap: 6px;
  min-width: 150px;
}
.finance-access-control span {
  font-size: 0.76rem;
  color: var(--muted);
}
.finance-full-head strong {
  display: block;
  font-family: var(--font-display);
  font-weight: 540;
  font-size: 1.18rem;
}
.finance-full-head span {
  color: var(--muted);
  font-size: 0.88rem;
}
.sale-lines,
.sale-product-preview {
  display: grid;
  gap: 7px;
}
.sale-lines span,
.sale-product-preview span,
.sale-product-preview div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 9px 10px;
  border-radius: 12px;
  background: oklch(98% 0.006 80 / 0.7);
  color: var(--text);
  font-size: 0.88rem;
}
.sale-product-preview div {
  background: var(--pink-soft);
  color: var(--pink-strong);
}
.sale-products-field select[multiple] {
  min-height: 150px;
}
.sale-product-picker {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
}
.sale-product-option {
  display: grid;
  grid-template-columns: 20px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  border: 0;
  border-radius: 0;
  background: transparent;
}
.sale-product-option + .sale-product-option {
  border-top: 1px solid color-mix(in oklch, var(--line) 80%, transparent);
}
.sale-product-option.disabled {
  opacity: 0.48;
}
.sale-product-option > input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.sale-product-circle {
  width: 18px;
  height: 18px;
  border: 1.5px solid color-mix(in oklch, var(--pink) 46%, var(--line));
  border-radius: 999px;
  background: var(--neutral-100);
}
.sale-product-option:has([data-sale-product-check]:checked)
  .sale-product-circle {
  border-color: var(--pink);
  background: radial-gradient(circle, var(--pink) 42%, var(--neutral-100) 45%);
}
.sale-product-name {
  min-width: 0;
  color: var(--text);
}
.sale-product-name b {
  display: block;
  min-width: 0;
  overflow-wrap: anywhere;
  font-weight: 520;
  line-height: 1.25;
}
.sale-product-name small {
  display: block;
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 400;
}
.money-inline {
  color: var(--pink-strong);
  font-weight: 560;
  white-space: nowrap;
}
.sale-product-side {
  display: flex;
  justify-self: end;
  align-items: center;
  gap: 10px;
}
.sale-product-option [data-sale-product-qty] {
  min-height: 34px;
  padding: 0 8px;
  width: 64px;
  border-radius: 12px;
}
.money-field {
  position: relative;
}
.money-field span {
  position: absolute;
  left: 12px;
  bottom: 12px;
  color: var(--muted);
  font-size: 0.88rem;
  pointer-events: none;
}
.money-field input {
  padding-left: 38px;
}
.sale-summary-value {
  display: flex;
  align-items: center;
  gap: 10px;
}
.sale-products-summary {
  display: block;
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.75rem;
}
.sale-status-badges {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 7px;
}
.sale-card {
  gap: 8px;
  padding: 12px 14px;
}
.sale-card .item-top {
  align-items: center;
}
.sale-card .item-top > div:first-child {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 10px;
}
.sale-card .item-top > div:first-child > .item-title,
.sale-card .item-top > div:first-child > .muted,
.sale-card .item-top > div:first-child > .sale-products-summary {
  grid-column: 1;
}
.sale-card .sale-status-badges {
  grid-column: 2;
  grid-row: 1 / 4;
  align-self: center;
  margin-top: 0;
}
.sale-card > .item-actions {
  margin-top: 0;
}
.sales-filter-panel {
  display: grid;
  gap: 10px;
  margin-bottom: 14px;
}
.sales-search,
.sales-filter-row select,
.sales-custom-dates input,
.sales-page-controls select {
  min-height: 40px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 76%, transparent);
  padding: 0 12px;
}
.sales-search {
  width: 100%;
  min-height: 44px;
}
.sales-filter-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(135px, 1fr)) auto;
  gap: 8px;
  align-items: center;
}
.sales-filter-row .btn {
  width: auto;
  white-space: nowrap;
}
.sales-custom-dates {
  display: flex;
  gap: 8px;
}
.sales-list-header,
.sale-list-row {
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(0, 1.35fr) minmax(
      0,
      0.72fr
    ) minmax(0, 1.42fr) minmax(124px, 0.78fr);
  gap: 12px;
  align-items: center;
}
.sales-list-header {
  padding: 0 14px 7px;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 650;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.sales-list-header span:last-child {
  text-align: right;
}
.sales-rows {
  display: grid;
  gap: 8px;
}
.sale-list-row {
  min-height: 92px;
  padding: 11px 13px;
  border-radius: 15px;
  box-shadow: var(--shadow-soft);
}
.sale-row-main,
.sale-row-products,
.sale-row-payment,
.sale-row-status,
.sale-row-value {
  min-width: 0;
}
.sale-row-main {
  display: grid;
  gap: 3px;
}
.sale-row-main .item-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sale-row-date,
.sale-row-main p,
.sale-row-products small {
  color: var(--muted);
  font-size: 0.69rem;
}
.sale-row-main p {
  overflow: hidden;
  margin: 1px 0 0;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sale-row-products {
  display: grid;
  gap: 6px;
}
.sale-row-products > div {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  max-height: 52px;
  overflow: hidden;
}
.sale-product-chip {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  max-width: calc(50% - 3px);
  min-height: 23px;
  padding: 3px 7px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 64%, transparent);
  font-size: 0.66rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sale-product-chip b {
  flex: 0 0 auto;
  color: var(--pink-strong);
}
.sale-product-chip.more {
  max-width: none;
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.sale-row-payment > span,
.sale-status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 26px;
  padding: 4px 9px;
  border-radius: 999px;
  font-size: 0.69rem;
  font-weight: 600;
  white-space: nowrap;
}
.sale-row-payment small,
.sale-row-value small,
.sale-detail-head-label {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 650;
}
.sale-row-payment svg,
.sale-detail-status-badge svg,
.sale-summary-card svg,
.sale-context-card svg,
.sale-icon-action svg,
.sales-month-kpi-icon svg,
.sales-month-new-sale svg {
  width: 16px;
  height: 16px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.sale-row-payment > span {
  color: var(--muted);
  background: color-mix(in oklch, var(--neutral-100) 66%, transparent);
}
.sale-row-payment > span.gift {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.sale-status-pill.completed {
  color: var(--green-strong);
  background: var(--green-soft);
}
.sale-status-pill.pending {
  color: oklch(55% 0.13 65);
  background: oklch(94% 0.045 75 / 0.8);
}
:root.dark-mode .sale-status-pill.pending {
  color: oklch(82% 0.1 75);
  background: oklch(34% 0.045 70 / 0.72);
}
.sale-row-value {
  display: grid;
  justify-items: end;
  gap: 7px;
  max-width: 100%;
}
.sale-row-value > strong {
  color: var(--pink-strong);
  font-family: var(--font-display);
  font-size: 0.95rem;
  white-space: nowrap;
}
.sale-row-actions {
  display: flex;
  justify-content: flex-end;
  gap: 5px;
  max-width: 100%;
  min-width: 0;
}
.sale-row-actions .item-actions {
  width: auto;
  flex-wrap: nowrap;
  gap: 5px;
}
.sale-row-actions .btn.small {
  min-height: 28px;
  padding: 0 8px;
  font-size: 0.64rem;
}
.sale-row-actions .daily-details-toggle {
  width: 29px;
  height: 29px;
  border-radius: 9px;
}
.sale-row-actions .daily-details-toggle.open {
  color: var(--pink-strong);
  background: var(--pink-soft);
  border-color: color-mix(in oklch, var(--pink) 34%, var(--line));
}
.sale-row-actions-icon .item-actions {
  display: flex;
}
.sale-icon-action.btn.small {
  display: inline-grid;
  place-items: center;
  width: 29px;
  min-width: 29px;
  height: 29px;
  padding: 0;
}
.sale-icon-action.btn.small svg {
  width: 15px;
  height: 15px;
}
.sale-open-card {
  align-items: start;
}
.sale-open-card .sale-row-main,
.sale-open-card .sale-row-products,
.sale-open-card .sale-row-payment,
.sale-open-card .sale-row-status,
.sale-open-card .sale-row-value {
  align-self: start;
}
.sale-open-card .sale-row-products > div {
  max-height: none;
}
.sale-detail-product-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  min-height: 25px;
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 66%, transparent);
  font-size: 0.7rem;
}
.sale-detail-product-chip b {
  color: var(--pink-strong);
}
.sale-detail-status-badges {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  align-items: center;
  min-width: 0;
  max-width: 100%;
}
.sale-detail-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 28px;
  padding: 5px 9px;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  white-space: nowrap;
}
.sale-list-row:not(.sale-open-card) .sale-detail-status-badge {
  min-height: 26px;
  padding: 4px 7px;
  font-size: 0.64rem;
}
.sale-detail-status-badge.ok {
  color: var(--green-strong);
  background: var(--green-soft);
}
.sale-detail-status-badge.pending {
  color: oklch(55% 0.13 65);
  background: oklch(94% 0.045 75 / 0.8);
}
.sale-detail-status-badge.gift,
.sale-detail-gift-badge {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.sale-list-row .sale-details-panel {
  grid-column: 1 / -1;
  min-width: 0;
  padding-top: 10px;
  border-top: 1px solid var(--line);
}
.sales-month-actions {
  position: sticky;
  top: 73px;
  z-index: 1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  align-items: center;
  margin: -4px 0 14px;
}
.sales-month-actions .finance-access-control {
  display: flex;
  min-width: 0;
  gap: 8px;
  align-items: center;
}
.sales-month-actions .finance-access-control span {
  display: none;
}
.sales-month-actions .btn {
  width: auto;
  min-height: 35px;
  padding: 0 12px;
  border-radius: 12px;
  font-size: 0.76rem;
  line-height: 1;
}
.sales-month-actions [data-finance-access]::before {
  content: "⚙";
  display: inline-block;
  margin-right: 6px;
  color: var(--pink-strong);
}
.sales-month-new-sale {
  display: inline-flex;
  gap: 6px;
  align-items: center;
}
.sales-month-new-sale svg {
  width: 15px;
  height: 15px;
}
.sales-month-kpis {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}
.sales-month-kpi {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr);
  gap: 2px 10px;
  align-items: center;
  min-width: 0;
  padding: 12px;
  border: 1px solid color-mix(in oklch, var(--pink) 16%, var(--line));
  border-radius: 16px;
  background: color-mix(in oklch, var(--pink-soft) 54%, var(--neutral-100));
  box-shadow: var(--shadow-soft);
}
.sales-month-kpi-icon {
  display: grid;
  grid-row: 1 / span 2;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 13px;
  color: var(--pink-strong);
  background: color-mix(in oklch, var(--pink-soft) 78%, var(--neutral-100));
}
.sales-month-kpi > span:not(.sales-month-kpi-icon) {
  min-width: 0;
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 650;
}
.sales-month-kpi strong {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--text);
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 650;
}
.sales-month-kpi small {
  color: var(--muted);
  font-family: var(--font-sans);
  font-size: 0.7rem;
  font-weight: 650;
}
.sales-month-kpi em {
  grid-column: 2;
  color: var(--muted);
  font-size: 0.66rem;
  font-style: normal;
  line-height: 1.25;
}
.sales-filter-empty {
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 28px;
  border: 1px dashed var(--line);
  border-radius: 15px;
  color: var(--muted);
  text-align: center;
}
.sales-filter-empty p {
  margin: 0;
}
.sales-list-footer {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-top: 12px;
  color: var(--muted);
  font-size: 0.72rem;
}
.sales-page-controls {
  display: flex;
  align-items: center;
  gap: 7px;
}
.sales-page-controls label {
  display: flex;
  align-items: center;
  gap: 6px;
}
.sales-page-controls select {
  min-height: 32px;
  padding-inline: 8px;
}
.sales-page-controls .btn {
  width: 32px;
  min-width: 32px;
  padding: 0;
}
.sale-details-panel {
  display: grid;
  gap: 12px;
}
.sale-details-panel[hidden] {
  display: none;
}
.sale-detail-report {
  display: grid;
  grid-template-columns: minmax(0, 1.7fr) minmax(260px, 0.95fr);
  gap: 12px;
  align-items: start;
}
.sale-operational-detail {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.sale-detail-calculations {
  display: grid;
  gap: 12px;
}
.sale-detail-box,
.sale-detail-summary-panel {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  box-shadow: var(--shadow-soft);
}
.sale-detail-box h4,
.sale-detail-summary-panel h4 {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 560;
}
.sale-detail-lines {
  display: grid;
  gap: 7px;
}
.sale-detail-items {
  display: grid;
  gap: 7px;
}
.sale-detail-item-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px 10px;
  align-items: center;
  min-height: 42px;
  padding: 9px 10px;
  border-radius: 12px;
  background: color-mix(in oklch, var(--panel-soft) 84%, transparent);
}
.sale-detail-item-line strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sale-detail-item-line small {
  grid-column: 1;
  color: var(--muted);
  font-size: 0.72rem;
}
.sale-detail-item-line b {
  grid-column: 2;
  grid-row: 1 / span 2;
  color: var(--pink-strong);
  white-space: nowrap;
}
.sale-detail-line,
.sale-detail-total {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  min-height: 36px;
  padding: 8px 10px;
  border-radius: 12px;
  color: var(--text);
  background: color-mix(in oklch, var(--panel-soft) 84%, transparent);
  font-size: 0.86rem;
}
.sale-detail-line b {
  color: var(--green-strong);
  font-weight: 800;
}
.sale-detail-line.negative b,
.sale-detail-line.negative strong {
  color: oklch(55% 0.13 45);
}
.sale-detail-line small,
.sale-detail-total small {
  min-width: 0;
  color: var(--text);
  font-size: 0.86rem;
}
.sale-detail-line strong,
.sale-detail-total strong {
  white-space: nowrap;
}
.sale-detail-total {
  grid-template-columns: minmax(0, 1fr) auto;
  margin-top: 3px;
  border: 1px solid color-mix(in oklch, var(--pink) 22%, var(--line));
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-weight: 700;
}
.sale-summary-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--panel-soft) 86%, transparent);
}
.sale-summary-card > svg,
.sale-context-card > svg {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  padding: 8px;
  border-radius: 999px;
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.sale-summary-card.ok > svg {
  color: var(--green-strong);
  background: var(--green-soft);
}
.sale-summary-card.pending > svg {
  color: oklch(55% 0.13 65);
  background: oklch(94% 0.045 75 / 0.8);
}
.sale-summary-card small {
  display: block;
  color: var(--muted);
  font-size: 0.7rem;
}
.sale-summary-card strong {
  color: var(--text);
  font-size: 0.88rem;
}
.sale-context-card {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 11px;
  border-radius: 15px;
  background: var(--pink-soft);
  color: var(--pink-strong);
}
.sale-context-card p {
  margin: 0;
  color: inherit;
  font-size: 0.78rem;
  line-height: 1.4;
}
.sale-detail-gift-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  min-height: 28px;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 700;
}
.sale-detail-gift-badge svg {
  width: 16px;
  height: 16px;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
}
.sale-detail-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.82rem;
}
.invoice-lines {
  display: grid;
  gap: 6px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: oklch(98% 0.006 80 / 0.72);
}
.invoice-lines span {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: var(--text);
  font-size: 0.9rem;
}
.invoice-lines .total {
  margin-top: 4px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  color: var(--pink-strong);
  font-weight: 620;
}
.invoice-lines .subtotal {
  margin-top: 4px;
  padding-top: 8px;
  border-top: 1px solid var(--line);
  font-weight: 620;
}
.product-list {
  display: grid;
  gap: 12px;
}
.product-card {
  width: 100%;
  overflow: hidden;
}
.product-card-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 38px;
  align-items: center;
  gap: 16px;
  min-height: 78px;
}
.product-card:not(.open) {
  padding: 12px 16px;
}
.product-card-head-closed {
  grid-template-columns: 
    minmax(150px, 2fr)
    minmax(100px, 0.5fr)
    minmax(100px, 0.5fr);
    minmax(100px, 0.9fr);
  gap: 12px;
  min-height: 52px;
}
.product-card-head-closed .daily-details-toggle {
  grid-column: 5;
}
.product-card-head-open {
  grid-template-columns: minmax(0, 1fr) auto 38px;
}
.product-card-head-open .daily-details-toggle {
  grid-column: 3;
}
.product-card-title {
  min-width: 0;
}
.product-card-title h3 {
  margin: 0;
}
.product-card-title span,
.product-card-price small {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.72rem;
}
.product-card-title p {
  max-width: 720px;
  margin: 7px 0 0;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.45;
}
.product-card-price {
  text-align: left;
}
.product-card-price strong {
  display: block;
  margin-top: 3px;
  color: var(--pink-strong);
  font-family: var(--font-display);
  font-size: 1.08rem;
  white-space: nowrap;
}
.product-card-stock {
  min-width: 0;
}
.product-card-stock small,
.product-card-stock-bar small {
  display: block;
  color: var(--muted);
  font-size: 0.68rem;
}
.product-card-stock strong {
  display: block;
  margin-top: 3px;
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 560;
  white-space: nowrap;
}
.product-card-stock-bar {
  display: grid;
  grid-template-columns: minmax(180px, 1fr);
  align-items: start;
  gap: 4px;
  width: 100%;
  max-width: 260px;
}
.product-card-stock-bar > i {
  display: block;
  width: 100%;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in oklch, var(--line) 75%, transparent);
}
.product-card-stock-bar > i > em {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--gradient-rose);
}
.product-card-preview {
  display: grid;
  gap: 7px;
  margin-top: 4px;
}
.product-card-preview > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--muted);
  font-size: 0.72rem;
}
.product-card-preview small {
  font-size: 0.66rem;
}
.product-card-preview > i {
  display: block;
  width: 100%;
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: color-mix(in oklch, var(--line) 75%, transparent);
}
.product-card-preview > i > em {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--gradient-rose);
}
.product-card-open-body {
  display: grid;
  gap: 14px;
  margin-top: 14px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.product-batches-section {
  display: grid;
  gap: 12px;
}
.product-batches-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.product-batches-head h3 {
  margin: 0;
  font-size: 1rem;
}
.product-batch-table {
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 15px;
}
.product-batch-table-head,
.product-batch-row {
  display: grid;
  grid-template-columns: minmax(90px, 1fr) repeat(
      2,
      minmax(92px, 0.9fr)
    ) minmax(118px, 1fr) minmax(105px, 1fr) 42px;
  align-items: center;
  gap: 10px;
  padding: 11px 13px;
}
.product-batch-table-head {
  color: var(--muted);
  background: color-mix(in oklch, var(--panel-soft) 72%, transparent);
  font-size: 0.66rem;
  font-weight: 600;
}
.product-batch-row {
  border-top: 1px solid var(--line);
  font-size: 0.72rem;
}
.product-batch-row strong,
.product-batch-row span {
  min-width: 0;
  overflow-wrap: anywhere;
}
.product-batch-row span:nth-child(5) {
  color: var(--pink-strong);
  font-weight: 600;
}
.product-batch-menu {
  width: 32px;
  height: 32px;
  border: 1px solid var(--line);
  border-radius: 10px;
  color: var(--muted);
  background: transparent;
  font-size: 1rem;
}
.product-stock-note,
.product-cost-note {
  margin: 0;
  color: var(--muted);
  font-size: 0.7rem;
}
.product-batch-empty {
  padding: 18px;
  border: 1px dashed var(--line);
  border-radius: 14px;
  color: var(--muted);
  text-align: center;
}
.product-batch-empty p {
  margin: 0;
}
.product-card-footer {
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}
.product-card-footer .item-actions {
  width: auto;
}
.product-batch-management {
  display: grid;
  gap: 14px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}
.product-batch-management-head h3,
.product-new-batch-form h4 {
  margin: 0;
}
.product-batch-management-head p {
  margin: 3px 0 0;
}
.product-batch-compact-list {
  display: grid;
  gap: 7px;
}
.product-batch-compact-list button {
  display: grid;
  grid-template-columns: minmax(80px, 0.8fr) minmax(105px, 1fr) minmax(
      150px,
      1.25fr
    ) 24px;
  align-items: center;
  gap: 9px;
  min-height: 42px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 12px;
  color: var(--text);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
  text-align: left;
}
.product-batch-compact-list span,
.product-batch-compact-list small {
  color: var(--muted);
  font-size: 0.68rem;
}
.product-batch-compact-list b {
  color: var(--muted);
  font-size: 1rem;
}
.product-new-batch-form {
  display: grid;
  gap: 11px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: color-mix(in oklch, var(--panel-soft) 50%, transparent);
}
.product-batch-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.product-batch-fields .field {
  min-width: 0;
}
.product-batch-modal-form textarea {
  min-height: 82px;
}
.product-form-grid {
  align-items: start;
}
.product-form-grid > .field {
  align-self: start;
  margin-bottom: 0;
}
.product-form-grid > .money-field {
  grid-template-rows: auto 44px;
}
.product-form-grid > .money-field input {
  min-height: 44px;
  height: 44px;
}
.product-form-grid > .money-field > span {
  bottom: 13px;
}
.product-form-grid > .form-full textarea {
  min-height: 76px;
}
.product-private-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.product-private-grid span {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 4px;
  align-items: center;
  padding: 10px;
  border-radius: 14px;
  background: oklch(98% 0.006 80 / 0.7);
  color: var(--text);
  font-size: 0.86rem;
}
.product-private-grid strong {
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.product-private-grid b {
  min-width: 0;
  font-weight: 520;
}
.product-eye {
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border: 1px solid var(--line);
  border-radius: 11px;
  color: var(--pink-strong);
  background: color-mix(in oklch, var(--neutral-100) 72%, transparent);
}
.product-eye svg {
  width: 16px;
  height: 16px;
}
.checkbox-field {
  display: flex;
  flex-direction: row;
  align-items: center;
  min-height: 42px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
}
.checkbox-field input {
  width: 16px;
  height: 16px;
  min-height: 16px;
  padding: 0;
  accent-color: var(--pink);
}
.report-metrics {
  margin-top: 16px;
}
.report-metrics div {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
}
.report-metrics span,
.finance-bars span {
  display: block;
  color: var(--muted);
  font-size: 0.82rem;
}
.report-metrics strong,
.finance-bars strong {
  display: block;
  margin-top: 4px;
  font-family: var(--font-display);
  font-weight: 540;
  font-size: 1.25rem;
}
.finance-month-tabs {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  margin: 0 0 16px;
  padding-bottom: 4px;
}
.finance-month-tabs button {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: color-mix(in oklch, var(--neutral-100) 58%, transparent);
  color: var(--muted);
  white-space: nowrap;
}
.finance-month-tabs button.active {
  color: var(--pink-strong);
  background: var(--pink-soft);
  border-color: color-mix(in oklch, var(--pink) 44%, var(--line));
}
.monthly-chart {
  display: flex;
  align-items: end;
  gap: 12px;
  min-height: 160px;
  margin-top: 18px;
  padding: 16px 4px 0;
  overflow-x: auto;
}
.month-bar {
  display: grid;
  min-width: 64px;
  gap: 8px;
  justify-items: center;
}
.month-bar > span {
  color: var(--muted);
  font-size: 0.78rem;
  text-transform: capitalize;
}
.month-bar > div {
  display: flex;
  align-items: end;
  gap: 5px;
  width: 42px;
  height: 112px;
  padding: 5px;
  border-radius: 13px;
  background: oklch(96% 0.012 80);
}
.month-bar i {
  display: block;
  flex: 1;
  min-height: 4px;
  border-radius: 999px 999px 5px 5px;
}
.income {
  background: oklch(82% 0.1 156);
}
.expense {
  background: oklch(82% 0.085 350);
}
.finance-bars {
  display: grid;
  gap: 14px;
}
.finance-track {
  height: 12px;
  margin-top: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: oklch(94% 0.012 80);
}
.finance-track i {
  display: block;
  height: 100%;
  min-width: 5%;
  border-radius: inherit;
}
.form-image-preview {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border: 1px solid var(--line);
  border-radius: 16px;
  margin-bottom: 8px;
}
.empty {
  display: grid;
  place-items: center;
  min-height: 220px;
  padding: 28px;
  text-align: center;
  background: color-mix(in oklch, var(--neutral-100) 62%, transparent);
  border: 1px dashed oklch(85% 0.018 70);
  border-radius: var(--radius);
}
.empty h3 {
  margin: 0 0 8px;
  font-family: var(--font-display);
  font-weight: 540;
}
.empty p {
  color: var(--muted);
  margin: 0 0 18px;
}
.calendar-shell {
  overflow: hidden;
}
.calendar-month-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}
.calendar-month-head h3 {
  margin: 0;
  text-align: center;
  flex: 1;
}
.calendar-weekdays {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 8px;
}
.calendar-weekdays span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 600;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.calendar-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
}
.calendar-cell {
  min-height: 116px;
  padding: 10px;
  border-radius: 0;
  background: color-mix(in oklch, var(--neutral-100) 78%, transparent);
  border: 0;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  transition:
    border-color 0.18s ease,
    background-color 0.18s ease,
    transform 0.18s ease;
}
.calendar-cell:hover {
  background: color-mix(in oklch, var(--neutral-100) 94%, transparent);
  transform: none;
}
.calendar-cell:nth-child(7n) {
  border-right: 0;
}
.calendar-cell:nth-last-child(-n + 7) {
  border-bottom: 0;
}
.calendar-cell.dim {
  opacity: 0.48;
}
.calendar-cell.today {
  background: color-mix(in oklch, var(--pink-soft) 74%, transparent);
}
.calendar-day-button {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
  padding: 0;
  color: var(--text);
  background: transparent;
  text-align: left;
}
.calendar-day-button strong {
  display: block;
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
}
.calendar-cell.today .calendar-day-button strong {
  color: var(--pink-strong);
  background: transparent;
}
.event-pill {
  display: block;
  width: 100%;
  margin-top: 7px;
  padding: 6px 8px;
  border-radius: 10px;
  background: var(--pink-soft);
  color: var(--pink-strong);
  font-size: 0.78rem;
  font-weight: 540;
  text-align: left;
}
.feed-card .feed-image {
  width: 100%;
  max-height: 250px;
  object-fit: cover;
  border-radius: 16px;
  border: 1px solid var(--line);
}
.secure-note {
  border: 1px solid oklch(88% 0.035 32);
  background: oklch(98% 0.018 48);
  color: oklch(42% 0.07 36);
  border-radius: 16px;
  padding: 13px 14px;
  font-size: 0.9rem;
  box-shadow: var(--shadow-soft);
}
.notification-pop {
  position: relative;
}
.notification-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: min(360px, calc(100vw - 32px));
  max-height: 430px;
  overflow: auto;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: color-mix(in oklch, var(--neutral-100) 96%, transparent);
  box-shadow: var(--shadow);
  z-index: 50;
  backdrop-filter: blur(18px);
}
.join-request-card {
  gap: 16px;
  min-width: 0;
}
.join-request-person,
.join-request-team {
  display: flex;
  align-items: center;
  gap: 14px;
}
.join-request-team {
  padding-top: 12px;
  border-top: 1px solid var(--line);
}
.join-request-team .onboarding-icon {
  width: 44px;
  font-size: 1.2rem;
}
.join-request-actions {
  display: flex;
  gap: 12px;
}
.join-request-actions .btn {
  min-width: 132px;
}
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 18px;
  background: oklch(22% 0.018 55 / 0.38);
  backdrop-filter: blur(7px);
}
.modal {
  width: min(680px, 100%);
  max-height: min(90vh, 900px);
  overflow: auto;
  border-radius: 24px;
  background: color-mix(in oklch, var(--neutral-100) 98%, transparent);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.task-detail-shell {
  width: min(920px, 100%);
}
.modal-head {
  position: sticky;
  top: 0;
  z-index: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  padding: 18px 20px;
  background: color-mix(in oklch, var(--neutral-100) 90%, transparent);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(16px);
}
.modal-head h2 {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 540;
  letter-spacing: -0.01em;
}
.modal-body {
  padding: 20px;
}
.calendar-event-modal {
  width: min(490px, 100%);
  max-height: calc(100vh - 18px);
  border-radius: 18px;
}
.calendar-event-modal .modal-head {
  padding: 16px 26px 6px;
  border-bottom: 0;
  background: color-mix(in oklch, var(--neutral-100) 96%, transparent);
}
.calendar-event-modal .modal-head h2 {
  font-family: var(--font-sans);
  font-size: 1.18rem;
  font-weight: 600;
  color: var(--muted);
}
.calendar-event-modal #modal-close {
  width: 30px;
  min-width: 30px;
  height: 30px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--muted);
  font-size: 1.35rem;
  box-shadow: none;
}
.calendar-event-modal .modal-body {
  padding: 10px 26px 8px;
}
.calendar-event-modal .modal-actions {
  position: sticky;
  bottom: 0;
  padding: 8px 26px 18px;
  border-top: 0;
  background: color-mix(in oklch, var(--neutral-100) 96%, transparent);
}
.calendar-event-modal .modal-actions .btn.ghost {
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--muted);
}
.calendar-event-modal .event-form-grid {
  gap: 12px;
}
.calendar-event-modal .field {
  gap: 7px;
  margin-bottom: 0;
}
.calendar-event-modal .field label,
.calendar-event-modal .calendar-toggle-field legend,
.calendar-toggle-field legend {
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 600;
}
.calendar-event-modal .field input,
.calendar-event-modal .field select,
.calendar-event-modal .field textarea {
  min-height: 40px;
  border-radius: 10px;
  background: oklch(99% 0.004 80 / 0.86);
}
.calendar-event-modal .field input[name="title"]:focus {
  border-color: oklch(63% 0.14 22);
  box-shadow: 0 0 0 3px oklch(63% 0.14 22 / 0.12);
}
.calendar-event-modal .event-description textarea {
  min-height: 68px;
}
.calendar-toggle-field {
  border: 0;
  padding: 0;
  margin: 0;
}
.calendar-option-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  min-height: 40px;
  padding: 10px 13px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: oklch(99% 0.004 80 / 0.86);
  color: var(--muted);
  font-weight: 500;
  box-shadow: none;
}
.calendar-option-toggle b {
  font-size: 0.95rem;
  font-weight: 600;
  transition: transform 0.16s ease;
}
.calendar-option-toggle.open b {
  transform: rotate(180deg);
}
.calendar-option-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: oklch(99% 0.004 80 / 0.72);
}
.calendar-option-list[hidden] {
  display: none;
}
.calendar-option-list label {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 20px;
  color: var(--muted);
  font-size: 0.9rem;
}
.calendar-option-list input {
  width: 15px;
  height: 15px;
  min-height: 15px;
  margin: 0;
  padding: 0;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--pink);
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  box-sizing: border-box;
  flex: 0 0 auto;
}
.calendar-event-modal .calendar-option-list input[type="checkbox"] {
  width: 15px;
  height: 15px;
  min-height: 15px;
  margin: 0;
  padding: 0;
  appearance: none;
  -webkit-appearance: none;
  border: 1px solid var(--pink);
  border-radius: 999px;
  background: transparent;
  box-shadow: none;
  box-sizing: border-box;
  flex: 0 0 auto;
}
.calendar-option-list input:checked {
  background: radial-gradient(circle, var(--pink) 0 42%, transparent 45%);
}
.calendar-event-modal .calendar-option-list input[type="checkbox"]:checked {
  background: radial-gradient(circle, var(--pink) 0 42%, transparent 45%);
}
.modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 20px 20px;
}
.toast {
  position: fixed;
  left: 50%;
  bottom: 24px;
  z-index: 140;
  transform: translateX(-50%);
  padding: 12px 16px;
  border-radius: 15px;
  color: var(--on-accent);
  background: oklch(28% 0.02 60);
  box-shadow: var(--shadow);
  font-weight: 540;
}

@media (max-width: 1060px) {
  .feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .grid.cols-4,
  .grid.cols-3 {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .marketing-planning-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .finance-month-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .finance-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .finance-profit-row {
    grid-template-columns: minmax(180px, 1.2fr) repeat(4, minmax(96px, 0.8fr));
  }
  .sales-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sales-report-grid {
    grid-template-columns: minmax(0, 1.4fr) minmax(220px, 0.8fr);
  }
  .sales-quick-summary {
    grid-column: 1 / -1;
  }
  .sales-filter-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sales-month-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sales-filter-row .btn {
    grid-column: 1 / -1;
    justify-self: start;
  }
  .sales-list-header,
  .sale-list-row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.25fr) minmax(
        0,
        0.65fr
      ) minmax(0, 1.35fr) minmax(122px, 0.75fr);
    gap: 9px;
  }
}
@media (max-width: 820px) {
  .hero,
  .auth-card {
    grid-template-columns: 1fr;
  }
  .onboarding-card {
    grid-template-columns: 1fr;
  }
  .onboarding-option {
    grid-template-columns: 52px minmax(0, 1fr);
    padding: 18px;
  }
  .onboarding-option .btn {
    grid-column: 1 / -1;
    width: 100%;
  }
  .onboarding-icon {
    width: 52px;
    font-size: 1.35rem;
  }
  .hero {
    min-height: auto;
    padding-bottom: 38px;
  }
  .preview-shell {
    min-height: 390px;
    grid-template-columns: 88px 1fr;
  }
  .feature-grid,
  .step-grid,
  .benefit-grid {
    grid-template-columns: 1fr;
  }
  .marketing-metrics-grid {
    grid-template-columns: 1fr;
  }
  .marketing-tabs {
    gap: 6px;
  }
  .marketing-tab {
    font-size: 0.8rem;
    min-height: 32px;
    padding-inline: 10px;
  }
  .app-shell {
    display: block;
  }
  .sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 90;
    display: flex;
    width: min(304px, 86vw);
    height: 100dvh;
    padding: 22px 16px;
    transform: translateX(-102%);
    box-shadow: 10px 0 54px -34px color-mix(in oklch, var(--text) 75%, transparent);
    transition:
      transform 0.22s ease,
      box-shadow 0.22s ease;
  }
  .sidebar-toggle {
    top: 86px;
    left: 0px;
    z-index: 95;
    display: grid;
    width: 25px;
    height: 60px;
    transform: none;
    border-radius: 0 16px 16px 0;
    background: color-mix(in oklch, var(--neutral-100) 92%, transparent);
    backdrop-filter: blur(16px);
  }
  .sidebar-toggle:hover {
    transform: translateY(-1px);
  }
  .app-shell.sidebar-collapsed .sidebar-toggle {
    left: 10px;
  }
  .app-shell.mobile-sidebar-open .sidebar {
    transform: translateX(0);
  }
  .mobile-sidebar-overlay {
    position: fixed;
    inset: 0;
    z-index: 80;
    display: block;
    pointer-events: none;
    opacity: 0;
    background: oklch(16% 0.02 60 / 0.42);
    backdrop-filter: blur(2px);
    transition: opacity 0.2s ease;
  }
  .app-shell.mobile-sidebar-open .mobile-sidebar-overlay {
    pointer-events: auto;
    opacity: 1;
  }
  .sidebar.collapsed {
    align-items: stretch;
    gap: 18px;
    padding: 22px 16px;
  }
  .sidebar.collapsed .logo {
    justify-content: flex-start;
  }
  .sidebar.collapsed .nav-item span {
    display: inline;
  }
  .sidebar.collapsed .logo-text {
    display: inline;
  }
  .sidebar.collapsed .store-chip,
  .sidebar.collapsed .nav-group-label {
    display: block;
  }
  .sidebar.collapsed .nav-list {
    gap: 4px;
  }
  .sidebar.collapsed .nav-item {
    justify-content: flex-start;
    width: 100%;
    min-height: 42px;
    padding: 0 12px;
    border-radius: 14px;
  }
  .sidebar.collapsed .nav-icon {
    width: 18px;
    height: 18px;
  }
  .topbar {
    grid-template-columns: 1fr;
    align-items: stretch;
    padding: 14px;
    gap: 12px;
    transition: transform 0.2s ease;
    will-change: transform;
  }
  .app-shell.topbar-hidden .topbar {
    transform: translateY(calc(-100% - 1px));
  }
  .topbar-actions {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto auto;
    gap: 8px;
    align-items: center;
  }
  .topbar-history,
  .notification-pop > .btn {
    min-height: 42px;
    padding-inline: 10px;
  }
  .topbar-actions .notification-pop {
    min-width: 0;
  }
  .topbar-actions .notification-pop > .btn {
    width: 100%;
  }
  .topbar-actions .user-menu {
    width: auto;
  }
  .topbar-actions .user-menu > div {
    display: none;
  }
  .mobile-brand {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 2px 2px 0;
  }
  .mobile-brand strong {
    display: block;
    font-family: var(--font-display);
    font-size: 1.18rem;
    letter-spacing: -0.01em;
    line-height: 1.05;
  }
  .mobile-brand span span,
  .mobile-brand div span {
    display: block;
    color: var(--muted);
    font-size: 0.78rem;
    margin-top: 2px;
  }
  .topbar .toolbar {
    justify-content: space-between;
  }
  .topbar .toolbar,
  .user-menu,
  .notification-pop {
    width: 100%;
  }
  .theme-mode-toggle {
    justify-self: end;
  }
  .topbar .toolbar .btn,
  .notification-pop > .btn {
    flex: 1 1 auto;
  }
  .page {
    padding: 22px 14px 36px;
  }
  .page-title h1 {
    font-size: 2rem;
  }
  .page-head {
    display: grid;
  }
  .page-head .toolbar {
    width: 100%;
  }
  .page-head .toolbar .btn,
  .theme-select {
    flex: 1 1 100%;
    width: 100%;
  }
  .grid.cols-2,
  .grid.cols-3,
  .grid.cols-4 {
    grid-template-columns: 1fr;
  }
  .dashboard-card-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-indicators,
  .dashboard-content-grid,
  .dashboard-goal-list,
  .dashboard-overview-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-goals,
  .dashboard-activities,
  .dashboard-overview-card,
  .dashboard-participating {
    grid-column: auto;
    grid-row: auto;
  }
  .dashboard-overview-card {
    min-height: 0;
  }
  .dashboard-today-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-compact-item {
    grid-template-columns: 72px minmax(0, 1fr);
  }
  .dashboard-compact-item small {
    grid-column: 2;
  }
  .dashboard-participation-head {
    display: none;
  }
  .dashboard-participation-row {
    grid-template-columns: 82px minmax(0, 1fr) 20px;
  }
  .dashboard-participation-row > span:not(.dashboard-compact-type),
  .dashboard-participation-row small {
    grid-column: 2;
  }
  .dashboard-participation-row b {
    grid-column: 3;
    grid-row: 1 / span 3;
  }
  .dashboard-create-menu,
  .dashboard-create-menu summary {
    width: 100%;
  }
  .dashboard-create-dropdown {
    left: 0;
    right: 0;
  }
  .weekly-task-board {
    grid-template-columns: repeat(7, minmax(240px, 82vw));
    margin-inline: -14px;
    padding-inline: 14px;
  }
  .daily-board {
    grid-template-columns: 1fr;
  }
  .daily-filter-panel {
    grid-template-columns: 1fr;
  }
  .daily-filter-buttons {
    overflow-x: auto;
    padding-bottom: 2px;
  }
  .daily-record-main {
    grid-template-columns: 34px minmax(0, 1fr) 38px;
  }
  .daily-record-main > .chip {
    grid-column: 2 / -1;
    width: fit-content;
  }
  .daily-details-toggle {
    grid-column: 3;
    grid-row: 1;
  }
  .daily-details-panel {
    grid-column: 1 / -1;
  }
  .daily-detail-grid {
    grid-template-columns: 1fr;
  }
  .daily-record-card .access-summary {
    grid-template-columns: 1fr;
  }
  .masonry-grid {
    column-count: 1;
  }
  .finance-month-grid {
    grid-template-columns: 1fr;
  }
  .sales-kpi-grid,
  .sales-report-grid {
    grid-template-columns: 1fr;
  }
  .sales-quick-summary {
    grid-column: auto;
  }
  .sales-annual-chart {
    gap: 4px;
    height: 200px;
  }
  .sales-annual-column > span {
    display: none;
  }
  .sales-annual-column {
    grid-template-rows: minmax(0, 1fr) 18px;
  }
  .product-private-grid {
    grid-template-columns: 1fr;
  }
  .product-card-head {
    grid-template-columns: minmax(0, 1fr) auto 38px;
    gap: 9px;
  }
  .product-card-head-closed {
    grid-template-columns: minmax(0, 1fr) auto 38px;
  }
  .product-card-head-closed .product-card-stock,
  .product-card-head-closed .product-card-stock-bar {
    grid-column: 1 / 3;
  }
  .product-card-head-closed .product-card-stock-bar {
    max-width: none;
  }
  .product-batch-table {
    overflow-x: auto;
  }
  .product-batch-table-head,
  .product-batch-row {
    min-width: 720px;
  }
  .product-batch-fields,
  .product-batch-compact-list button {
    grid-template-columns: 1fr;
  }
  .sale-product-option {
    grid-template-columns: 20px minmax(0, 1fr);
  }
  .sale-product-side {
    grid-column: 2;
    justify-self: stretch;
    justify-content: space-between;
  }
  .sale-summary-value {
    justify-content: space-between;
  }
  .finance-month-grid > .finance-window[open],
  .sales-month-grid > .finance-window[open] {
    inset: 8px;
    border-radius: 20px;
  }
  .finance-full-head {
    top: 73px;
    display: grid;
  }
  .finance-inline-totals {
    grid-template-columns: 1fr;
  }
  .finance-forecast-grid {
    grid-template-columns: 1fr;
  }
  .finance-month-entry-grid {
    grid-template-columns: 1fr;
  }
  .finance-entry-summary {
    grid-template-columns: 1fr;
  }
  .finance-entry-row {
    grid-template-columns: 30px minmax(0, 1fr) auto;
  }
  .finance-entry-row > span {
    grid-column: 2;
  }
  .finance-entry-row-value {
    grid-column: 3;
    grid-row: 1;
  }
  .finance-entry-delete,
  .finance-entry-origin {
    grid-column: 3;
    grid-row: 2;
    justify-self: end;
  }
  .finance-forecast-columns {
    display: none;
  }
  .finance-forecast-row {
    grid-template-columns: 30px minmax(0, 1fr) auto;
  }
  .finance-forecast-row > span {
    grid-column: 2;
  }
  .finance-forecast-row > strong:last-child {
    grid-column: 3;
    grid-row: 1;
  }
  .finance-overview-grid {
    grid-template-columns: 1fr;
  }
  .finance-profit-table {
    overflow-x: auto;
  }
  .finance-profit-row {
    min-width: 760px;
  }
  .feed-preview-grid {
    grid-template-columns: 1fr;
  }
  .content-thumb-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .form-grid {
    grid-template-columns: 1fr;
  }
  .sales-form-grid .sales-notes,
  .sales-form-grid .sales-delivery,
  .sales-form-grid .sales-discount,
  .sales-form-grid .sales-packaging,
  .sales-form-grid .sales-extra-costs,
  .sales-form-grid .sales-payment,
  .sales-form-grid .sales-statuses-field,
  .sales-form-grid .sales-access-edit,
  .sales-form-grid .sales-access-view,
  .event-form-grid .event-description,
  .event-form-grid .event-half,
  .event-form-grid .event-edit,
  .marketing-objective,
  .marketing-references,
  .finance-entry-form-grid .finance-description,
  .finance-entry-form-grid .finance-date {
    grid-column: 1;
    grid-row: auto;
  }
  .account-layout {
    grid-template-columns: 1fr;
  }
  .account-danger-zone {
    align-items: stretch;
    flex-direction: column;
  }
  .account-danger-actions {
    justify-content: flex-start;
  }
  .account-team-grid {
    grid-template-columns: 1fr;
  }
  .sales-list-header {
    display: none;
  }
  .sale-list-row {
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
  }
  .sale-row-main,
  .sale-row-products,
  .sale-row-payment,
  .sale-row-status {
    grid-column: 1;
  }
  .sale-row-value {
    grid-column: 2;
    grid-row: 1 / 5;
    align-self: stretch;
  }
  .sale-row-products > div {
    max-height: none;
  }
  .sale-detail-status-badges {
    flex-wrap: wrap;
  }
  .sale-product-chip {
    max-width: 100%;
  }
  .sales-list-footer {
    align-items: flex-start;
    flex-direction: column;
  }
  .event-form-grid .event-description textarea {
    min-height: 130px;
    height: auto;
  }
  .sales-form-grid .sales-notes textarea {
    min-height: 130px;
    height: auto;
  }
  .sales-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .sales-form-grid .sale-products-field {
    grid-column: 1 / -1;
  }
  .sales-form-grid .sales-notes {
    grid-column: 1 / -1;
    grid-row: 3;
  }
  .sales-form-grid .sales-delivery,
  .sales-form-grid .sales-discount,
  .sales-form-grid .sales-payment,
  .sales-form-grid .sales-access-view {
    grid-column: 1;
  }
  .sales-form-grid .sales-packaging,
  .sales-form-grid .sales-extra-costs,
  .sales-form-grid .sales-statuses-field,
  .sales-form-grid .sales-access-edit {
    grid-column: 2;
  }
  .sales-form-grid .sales-delivery,
  .sales-form-grid .sales-packaging {
    grid-row: 4;
  }
  .sales-form-grid .sales-discount,
  .sales-form-grid .sales-extra-costs {
    grid-row: 5;
  }
  .sales-form-grid .sales-payment,
  .sales-form-grid .sales-statuses-field {
    grid-row: 6;
  }
  .sales-form-grid .sales-access-view,
  .sales-form-grid .sales-access-edit {
    grid-row: 7;
  }
  .date-list-control {
    grid-template-columns: 1fr;
  }
  .daily-date-pair {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .item-top {
    display: grid;
  }
  .item-actions {
    justify-content: stretch;
  }
  .item-actions .btn {
    flex: 1 1 108px;
    width: auto;
    min-height: 44px;
  }
  .item-actions .action-icon-btn.btn.small {
    width: 34px;
    min-width: 34px;
    flex: 0 0 34px;
    min-height: 34px;
  }
  .item-actions [data-destroy].btn.small {
    flex: 1 1 100%;
    width: 100%;
    min-width: 0;
  }
  .sales-window .finance-summary-controls .chip {
    min-width: 92px;
    padding-inline: 8px;
    font-size: 0.72rem;
  }
  .calendar-grid {
    grid-template-columns: 1fr;
  }
  .calendar-weekdays {
    display: none;
  }
  .calendar-cell {
    min-height: auto;
  }
  .kanban-board {
    grid-template-columns: 1fr;
    margin-inline: 0;
    overflow-x: hidden;
    padding-bottom: 18px;
  }
  .kanban-column {
    min-height: 480px;
  }
  .marketing-kanban-card {
    cursor: default;
  }
}
@media (max-width: 420px) {
  .finance-overview-card summary {
    grid-template-columns: 40px minmax(0, 1fr) 30px;
    gap: 10px;
    padding: 14px;
  }
  .finance-overview-icon {
    width: 40px;
    height: 40px;
  }
  .finance-overview-toggle {
    width: 30px;
    height: 30px;
  }
  .finance-overview-line,
  .finance-overview-result {
    grid-template-columns: 1fr;
    gap: 4px;
  }
  .finance-overview-line strong,
  .finance-overview-result strong {
    justify-self: start;
    text-align: left;
  }
}
@media (max-width: 680px) {
  .marketing-planning-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .marketing-idea-meta {
    grid-template-columns: 1fr;
  }
  .marketing-insight-meta {
    grid-template-columns: 1fr;
  }
  .marketing-insight-summary {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .marketing-insight-metrics {
    grid-column: 1 / -1;
    flex-wrap: wrap;
  }
}
@media (min-width: 681px) {
  .company-record-form-grid,
  .task-form-grid,
  .daily-form-grid,
  .event-form-grid,
  .marketing-content-form-grid,
  .finance-entry-form-grid,
  .team-member-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .marketing-insight-form-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (max-width: 320px) {
  .public-nav {
    padding: 18px 14px;
  }
  .public-nav .toolbar .btn.ghost {
    display: none;
  }
  .hero {
    padding-inline: 14px;
  }
  .landing-section {
    padding: 50px 14px;
  }
  .hero-copy h1 {
    font-size: 2.55rem;
  }
  .preview-shell {
    grid-template-columns: 1fr;
  }
  .preview-side {
    display: none;
  }
  .preview-grid {
    grid-template-columns: 1fr;
  }
  .auth-page {
    padding: 12px;
  }
  .auth-aside,
  .auth-form {
    padding: 24px;
  }
  .btn {
    width: 100%;
  }
  .toolbar .btn {
    width: auto;
  }
  .filters input,
  .filters select {
    width: 100%;
  }
  .sales-filter-row {
    grid-template-columns: 1fr;
  }
  .sales-month-actions {
    position: static;
    justify-content: stretch;
  }
  .sales-month-actions .finance-access-control,
  .sales-month-actions .btn {
    flex: 1;
  }
  .sales-month-kpis {
    grid-template-columns: 1fr;
  }
  .sales-filter-row .btn {
    grid-column: 1;
    width: 100%;
  }
  .sales-custom-dates {
    display: grid;
    grid-template-columns: 1fr;
  }
  .sale-list-row {
    grid-template-columns: 1fr;
  }
  .sale-row-value {
    grid-column: 1;
    grid-row: auto;
    justify-items: start;
  }
  .sale-row-actions {
    justify-content: flex-start;
  }
  .sale-detail-report {
    grid-template-columns: 1fr;
  }
  .sale-operational-detail {
    grid-template-columns: 1fr;
  }
  .sale-detail-line,
  .sale-detail-total {
    grid-template-columns: 20px minmax(0, 1fr);
  }
  .sale-detail-line strong,
  .sale-detail-total strong {
    grid-column: 2;
    justify-self: start;
  }
  .sales-page-controls {
    width: 100%;
    flex-wrap: wrap;
  }
  .bulk-action-bar {
    display: grid;
    gap: 10px;
  }
  .bulk-action-bar .btn {
    width: 100%;
  }
  .marketing-planning-grid {
    grid-template-columns: 1fr;
  }
  .marketing-plan-card {
    padding: 14px;
  }
  .marketing-card-head {
    align-items: flex-start;
  }
  .marketing-metric-card strong {
    font-size: 1.35rem;
  }
  .marketing-idea-summary span {
    display: grid;
    gap: 4px;
  }
  .team-toolbar {
    display: grid;
  }
  .team-toolbar input {
    min-width: 0;
    width: 100%;
  }
  .team-member-card {
    grid-template-columns: 1fr;
  }
  .trash-item-card {
    grid-template-columns: 1fr;
    align-items: start;
  }
  .trash-item-actions {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
  .sales-form-grid {
    grid-template-columns: 1fr;
  }
  .sales-form-grid .sales-notes,
  .sales-form-grid .sales-delivery,
  .sales-form-grid .sales-discount,
  .sales-form-grid .sales-packaging,
  .sales-form-grid .sales-extra-costs,
  .sales-form-grid .sales-payment,
  .sales-form-grid .sales-statuses-field,
  .sales-form-grid .sales-access-edit,
  .sales-form-grid .sales-access-view {
    grid-column: 1;
    grid-row: auto;
  }
  .sales-form-grid .sales-notes {
    grid-row: 4;
  }
  .sales-form-grid .sales-delivery {
    grid-row: 5;
  }
  .sales-form-grid .sales-packaging {
    grid-row: 6;
  }
  .sales-form-grid .sales-discount {
    grid-row: 7;
  }
  .sales-form-grid .sales-extra-costs {
    grid-row: 8;
  }
  .sales-form-grid .sales-payment {
    grid-row: 9;
  }
  .sales-form-grid .sales-statuses-field {
    grid-row: 10;
  }
  .sales-form-grid .sales-access-view {
    grid-row: 11;
  }
  .sales-form-grid .sales-access-edit {
    grid-row: 12;
  }
  .sales-form-grid .sales-notes textarea {
    flex: none;
    min-height: 130px;
    height: auto;
  }
  .finance-entry-form-grid .finance-description,
  .finance-entry-form-grid .finance-access-view,
  .finance-entry-form-grid .finance-access-edit {
    grid-column: auto;
  }
  .company-block-attachments {
    grid-template-columns: 1fr;
  }
  .daily-date-pair {
    grid-template-columns: 1fr;
  }
  .team-member-side {
    justify-content: flex-start;
  }
  .company-block-head {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .company-block-head .chip {
    grid-column: 1 / -1;
    justify-self: start;
  }
  .modal-actions {
    display: grid;
  }
  .topbar .toolbar {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .topbar .toolbar .btn {
    width: 100%;
  }
  .user-menu {
    display: grid;
    grid-template-columns: 40px 1fr auto;
    align-items: center;
  }
  .user-menu .btn {
    width: auto;
  }
}

.product-card .task-summary {
  grid-template-columns: minmax(0, 1fr) auto 38px;
}

.product-card .task-summary-main {
  min-width: 0;
}

.product-card .item-title {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-card .metric {
  white-space: nowrap;
}

/* Mantém o layout executivo do Dashboard acima das regras legadas. */
.dashboard-page {
  max-width: 1440px;
  padding-top: 24px;
}
.dashboard-overview-grid {
  grid-template-columns: minmax(0, 1.12fr) minmax(0, 1.05fr) minmax(
      250px,
      0.86fr
    );
  gap: 18px;
  align-items: stretch;
}
.dashboard-overview-card {
  gap: 14px;
  min-height: 260px;
  padding: 24px 26px;
  border-radius: 24px;
  align-content: start;
}
.dashboard-card-body {
  height: 100%;
  gap: 13px;
}
.dashboard-primary-value {
  font-size: clamp(1.7rem, 2.4vw, 2.25rem);
}
.dashboard_sales .dashboard-primary-value {
  font-size: 2rem;
}
.dashboard-revenue-progress {
  height: 24px;
  margin: 0;
}
.dashboard-progress-copy {
  margin-top: 2px;
}
.dashboard-today-grid {
  gap: 0;
}
.dashboard-today-block {
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 12px;
  min-height: 64px;
  padding: 11px 0;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
}
.dashboard-today-block:last-child {
  border-bottom: 0;
}
.dashboard-mini-icon {
  width: 40px;
  height: 40px;
  border-radius: 13px;
}
.dashboard-compact-list {
  gap: 8px;
}
.dashboard-compact-item {
  grid-template-columns: 28px minmax(0, 1fr) 14px;
  gap: 10px;
  min-height: 54px;
  padding: 8px 11px;
  border: 1px solid var(--line);
  border-radius: 13px;
}
.dashboard-compact-item:last-child {
  border-bottom: 1px solid var(--line);
}
.dashboard-stock-list > div {
  grid-template-columns: 36px minmax(0, 1fr) auto;
  gap: 10px;
  min-height: 48px;
}
.dashboard-participation-row {
  grid-template-columns: 92px 26px minmax(180px, 1.8fr) minmax(
      100px,
      0.8fr
    ) minmax(105px, 0.7fr) 18px;
  min-height: 48px;
  padding: 8px 14px;
  border-top: 0;
  border-bottom: 1px solid var(--line);
}
.dashboard_participating {
  grid-column: 1 / -1;
  grid-row: 3;
  min-height: auto;
}

@media (max-width: 1120px) {
  .dashboard-overview-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .dashboard_objective,
  .dashboard_marketing_goal,
  .dashboard_revenue,
  .dashboard_sales,
  .dashboard_today,
  .dashboard_overdue,
  .dashboard_stock {
    grid-column: auto;
    grid-row: auto;
  }
  .dashboard_participating {
    grid-column: 1 / -1;
    grid-row: auto;
  }
}

@media (max-width: 760px) {
  .dashboard-page {
    padding-top: 18px;
  }
  .dashboard-overview-grid {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .dashboard-overview-card {
    min-height: 0;
    padding: 20px;
  }
  .dashboard_participating {
    grid-column: auto;
  }
  .dashboard-participation-row {
    grid-template-columns: 76px 24px minmax(0, 1fr) 16px;
  }
  .dashboard-participation-row
    > span:not(.dashboard-compact-type):not(.dashboard-participation-icon),
  .dashboard-participation-row small {
    grid-column: 3;
  }
  .dashboard-participation-row b {
    grid-column: 4;
    grid-row: 1 / span 3;
  }
}

.dashboard_objective .dashboard-card-body {
  display: block;
}
.dashboard-objective-text,
.dashboard-objective-text.dashboard-objective-empty {
  display: block;
  width: 100%;
  min-height: 0;
  padding: 6px 0;
  border: 0;
  background: transparent;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.65;
  text-align: left;
}
.dashboard-objective-text.dashboard-objective-empty {
  color: var(--muted);
}
.dashboard-objective-text:hover {
  color: var(--pink-strong);
}

.daily-week-card.done {
  opacity: 0.72;
}
.weekly-task-day .daily-week-card.bulk-item {
  position: relative;
  grid-template-columns: minmax(0, 1fr);
  gap: 10px;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  padding: 12px;
  overflow: hidden;
  box-sizing: border-box;
}
.daily-week-card > .weekly-task-card-main,
.daily-week-card > .daily-week-details {
  width: auto;
  max-width: 100%;
  min-width: 0;
}
.daily-week-card .weekly-task-card-main {
  width: 100%;
  gap: 6px;
  text-align: left;
}
.daily-week-card .weekly-task-card-main > span,
.daily-week-card .weekly-task-card-main .item-title {
  width: 100%;
  max-width: none;
  text-align: left;
}
.daily-week-card .weekly-task-card-main > span {
  white-space: normal;
}
.daily-week-card .weekly-task-card-main .item-title {
  font-size: 0.86rem;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.daily-week-card .chip {
  width: fit-content;
  max-width: 100%;
  min-width: 0;
  font-size: 0.68rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: normal;
}
.daily-week-card[data-open-weekly-daily] {
  color: var(--text);
  text-align: left;
}
.daily-week-card[data-open-weekly-daily]:hover {
  border-color: color-mix(in oklch, var(--pink) 50%, var(--line));
  background: color-mix(in oklch, var(--pink-soft) 32%, var(--panel));
}
.daily-week-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  margin-top: 2px;
}
.daily-week-card .daily-week-card-footer .weekly-task-toggle {
  width: 26px;
  height: 26px;
  flex: 0 0 26px;
  justify-self: auto;
  align-self: auto;
  border-radius: 8px;
}
.daily-week-details {
  display: grid;
  gap: 8px;
  width: auto;
  max-width: 100%;
  min-width: 0;
  padding-top: 8px;
  border-top: 1px solid var(--line);
}
.daily-week-details p {
  margin: 0;
  color: var(--muted);
  font-size: 0.76rem;
}
.daily-week-details .item-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  width: auto;
  max-width: 100%;
  min-width: 0;
}
.daily-week-details .item-actions .btn.small {
  width: 100%;
  min-width: 0;
  max-width: 100%;
  flex: none;
  min-height: 30px;
  padding: 0 3px;
  font-size: 0.64rem;
}
.daily-record-card > .item-actions {
  flex-wrap: nowrap;
}

.event-card > .item-actions {
  grid-column: 1 / -1;
  justify-content: flex-end;
  margin-top: 2px;
}

.notification-line-card.unread {
  border-color: color-mix(in oklch, var(--pink) 42%, var(--line));
  background: color-mix(in oklch, var(--pink-soft) 26%, var(--surface));
}
.daily-filter-panel.daily-filter-panel-compact {
  grid-template-columns: minmax(240px, 1fr) auto;
}
.daily-filter-buttons .btn.ghost.active {
  color: var(--on-accent);
  background: var(--gradient-rose);
  border-color: color-mix(in oklch, var(--pink-strong) 72%, var(--line));
  box-shadow:
    0 10px 22px -14px color-mix(in oklch, var(--pink-strong) 72%, transparent),
    0 1px 0 color-mix(in oklch, var(--neutral-100) 42%, transparent) inset;
}
:root.dark-mode .daily-filter-buttons .btn.ghost.active {
  color: var(--on-accent);
  background: var(--gradient-rose);
  border-color: var(--pink);
}
.calendar-week-shell .calendar-cell {
  min-height: 150px;
}
.calendar-week-shell .event-pill.daily-week-completed {
  color: var(--green-strong);
  background: var(--green-soft);
}

.daily-habit-shell {
  display: grid;
  gap: 16px;
  padding: 18px;
  overflow: hidden;
}
.daily-habit-head {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) 42px;
  align-items: center;
  gap: 12px;
  text-align: center;
}
.daily-habit-head h3 {
  margin: 2px 0 0;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 2vw, 1.35rem);
}
.daily-habit-head span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.daily-habit-head .btn {
  width: 38px;
  height: 38px;
  justify-content: center;
  padding: 0;
  border-radius: 13px;
  font-size: 1.18rem;
}
.daily-habit-legend {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 14px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  color: var(--muted);
  background: color-mix(in oklch, var(--panel-soft) 62%, transparent);
  font-size: 0.76rem;
}
.daily-habit-legend span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.daily-habit-legend .daily-habit-dot {
  width: 18px;
  height: 18px;
  font-size: 0.64rem;
  pointer-events: none;
}
.daily-habit-scroll {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 4px;
  scrollbar-width: thin;
}
.daily-habit-grid {
  display: grid;
  grid-template-columns: minmax(220px, 1.45fr) repeat(7, minmax(78px, 0.74fr)) minmax(82px, 0.55fr);
  min-width: 920px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: color-mix(in oklch, var(--neutral-100) 74%, transparent);
  box-shadow: var(--shadow-soft);
}
.daily-habit-header,
.daily-habit-activity,
.daily-habit-cell,
.daily-habit-progress {
  min-width: 0;
  padding: 12px 10px;
  border-right: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.daily-habit-header:nth-child(9n),
.daily-habit-progress {
  border-right: 0;
}
.daily-habit-header {
  display: grid;
  place-items: center;
  gap: 2px;
  color: var(--muted);
  background: color-mix(in oklch, var(--panel-soft) 82%, transparent);
  font-size: 0.72rem;
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.daily-habit-header strong {
  color: var(--text);
  font-size: 0.78rem;
}
.daily-habit-header span {
  font-size: 0.68rem;
}
.daily-habit-header.today {
  color: var(--pink-strong);
  background: var(--pink-soft);
}
.daily-habit-activity-head,
.daily-habit-progress-head {
  justify-items: start;
  padding-inline: 14px;
}
.daily-habit-progress-head {
  justify-items: center;
}
.daily-habit-activity {
  display: grid;
  align-items: center;
  background: color-mix(in oklch, var(--neutral-100) 88%, transparent);
}
.daily-habit-activity button {
  display: grid;
  min-width: 0;
  gap: 4px;
  color: var(--text);
  background: transparent;
  text-align: left;
}
.daily-habit-activity strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 0.88rem;
}
.daily-habit-activity span {
  color: var(--muted);
  font-size: 0.72rem;
}
.daily-habit-cell,
.daily-habit-progress {
  display: grid;
  place-items: center;
  background: color-mix(in oklch, var(--neutral-100) 70%, transparent);
}
.daily-habit-progress strong {
  min-width: 44px;
  padding: 6px 9px;
  border-radius: 999px;
  color: var(--pink-strong);
  background: var(--pink-soft);
  font-size: 0.78rem;
  text-align: center;
}
.daily-habit-dot {
  display: inline-grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border: 1.5px solid var(--line);
  border-radius: 999px;
  color: transparent;
  background: transparent;
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
  transition:
    transform 0.18s ease,
    border-color 0.18s ease,
    background 0.18s ease;
}
.daily-habit-dot.pending {
  border-color: var(--pink);
  color: transparent;
  background: color-mix(in oklch, var(--neutral-100) 80%, transparent);
  cursor: pointer;
}
.daily-habit-dot.pending:hover {
  transform: translateY(-1px);
  background: var(--pink-soft);
}
.daily-habit-dot.done {
  border-color: var(--pink-strong);
  color: var(--on-accent);
  background: var(--pink-strong);
  cursor: pointer;
}
.daily-habit-dot.disabled,
.daily-habit-dot:disabled.disabled {
  border-color: color-mix(in oklch, var(--muted) 28%, var(--line));
  color: transparent;
  background: color-mix(in oklch, var(--muted) 10%, var(--panel-soft));
  cursor: not-allowed;
  opacity: 0.52;
}
.daily-habit-dot.locked {
  cursor: not-allowed;
  opacity: 0.58;
}
.daily-habit-empty {
  grid-column: 1 / -1;
  padding: 24px;
  color: var(--muted);
  text-align: center;
}
:root.dark-mode .daily-habit-shell,
:root.dark-mode .daily-habit-grid,
:root.dark-mode .daily-habit-activity,
:root.dark-mode .daily-habit-cell,
:root.dark-mode .daily-habit-progress {
  background: color-mix(in oklch, var(--panel) 88%, transparent);
}

@media (min-width: 1121px) {
  .dashboard-overview-grid {
    grid-template-rows: 121px 121px auto auto;
  }
  .dashboard_objective {
    grid-column: 1;
    grid-row: 1;
  }
  .dashboard_marketing_goal {
    grid-column: 1;
    grid-row: 2;
  }
  .dashboard_revenue {
    grid-column: 2;
    grid-row: 1 / span 2;
  }
  .dashboard_sales {
    grid-column: 3;
    grid-row: 1 / span 2;
  }
  .dashboard_today {
    grid-column: 1;
    grid-row: 3;
  }
  .dashboard_overdue {
    grid-column: 2;
    grid-row: 3;
  }
  .dashboard_stock {
    grid-column: 3;
    grid-row: 3;
  }
  .dashboard_participating {
    grid-column: 1 / -1;
    grid-row: 4;
  }

  .dashboard_objective,
  .dashboard_marketing_goal {
    min-height: 0;
    padding-block: 16px;
    gap: 8px;
  }

  .dashboard_objective .dashboard-card-body,
  .dashboard_marketing_goal .dashboard-card-body {
    min-height: 0;
  }

  .dashboard_revenue,
  .dashboard_sales {
    min-height: 260px;
  }
}

.dashboard-objective-boxes {
  display: grid;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 10px;
  height: 100%;
}
.dashboard-objective-box {
  display: grid;
  align-content: center;
  gap: 5px;
  width: 100%;
  min-height: 78px;
  padding: 13px 15px;
  border: 1px solid color-mix(in oklch, var(--line) 78%, transparent);
  border-radius: 14px;
  color: var(--text);
  background: color-mix(in oklch, var(--panel-soft) 48%, transparent);
  text-align: left;
}
.dashboard-objective-box:hover {
  border-color: color-mix(in oklch, var(--pink) 46%, var(--line));
  background: color-mix(in oklch, var(--pink-soft) 42%, transparent);
}
.dashboard-objective-box strong {
  font-size: 0.8rem;
}
.dashboard-objective-box span {
  display: -webkit-box;
  overflow: hidden;
  font-size: 0.78rem;
  line-height: 1.4;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.dashboard-scroll-area {
  min-height: 0;
  max-height: 178px;
  overflow-y: auto;
  overflow-x: hidden;
  padding-right: 2px;
  overscroll-behavior: contain;
  scrollbar-width: none;
}
.dashboard-scroll-area::-webkit-scrollbar {
  display: none;
}
.dashboard-participation-scroll {
  max-height: 245px;
}
.dashboard-today-list {
  display: grid;
}
.dashboard-today-item {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) 14px;
  align-items: center;
  gap: 11px;
  width: 100%;
  min-height: 58px;
  padding: 9px 2px;
  border-bottom: 1px solid var(--line);
  color: var(--text);
  background: transparent;
  text-align: left;
}
.dashboard-today-item:last-child {
  border-bottom: 0;
}
.dashboard-today-item:hover {
  color: var(--pink-strong);
}
.dashboard-today-item .dashboard-mini-icon {
  width: 38px;
  height: 38px;
}
.dashboard-today-item > span:nth-child(2) {
  display: grid;
  min-width: 0;
  gap: 2px;
}
.dashboard-today-item strong,
.dashboard-today-item small {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dashboard-today-item strong {
  font-size: 0.78rem;
}
.dashboard-today-item small {
  color: var(--muted);
  font-size: 0.69rem;
}
.dashboard-today-item b {
  color: var(--muted);
  font-size: 1.1rem;
}
.dashboard-compact-item {
  width: 100%;
  color: var(--text);
  background: transparent;
  text-align: left;
}
.dashboard_sales .dashboard-primary-value {
  margin-top: 12px;
  font-size: clamp(2.4rem, 4vw, 3.4rem);
}
.dashboard_sales .dashboard-sales-copy {
  margin-top: 4px;
  font-size: 0.82rem;
}
.dashboard_today .dashboard-card-body,
.dashboard_overdue .dashboard-card-body,
.dashboard_stock .dashboard-card-body {
  min-height: 0;
  overflow: hidden;
}
.daily-week-board {
  grid-template-columns: repeat(10, minmax(0, 1fr));
  overflow: visible;
  margin-inline: 0;
  padding-inline: 0;
}
.daily-week-board .daily-week-day {
  grid-column: span 2;
  min-width: 0;
}
.daily-week-board .daily-week-day:nth-child(6),
.daily-week-board .daily-week-day:nth-child(7) {
  grid-column: span 5;
}

@media (max-width: 900px) {
  .daily-week-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .daily-week-board .daily-week-day,
  .daily-week-board .daily-week-day:nth-child(6),
  .daily-week-board .daily-week-day:nth-child(7) {
    grid-column: auto;
  }
}

@media (max-width: 620px) {
  .daily-filter-panel.daily-filter-panel-compact,
  .daily-week-board {
    grid-template-columns: 1fr;
  }
}

.dashboard-stock-list > div {
  grid-template-columns: minmax(0, 1fr) max-content;
  gap: 8px;
}

.dashboard-stock-list > div > span {
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
}

.dashboard-stock-list strong.theme-stock {
  width: auto;
  min-width: 0;
  padding-inline: 8px;
  white-space: nowrap;
  justify-self: end;
}
