@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800;850&family=JetBrains+Mono:wght@400;500;600;700&display=swap');

.demo-banner {
  position: sticky;
  top: 0;
  z-index: 80;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  min-height: 42px;
  padding: 8px 18px;
  color: #e0f2fe;
  background: linear-gradient(90deg, #0f172a, #0e7490 48%, #115e59);
  border-bottom: 1px solid rgb(255 255 255 / 0.12);
  box-shadow: 0 10px 30px rgb(2 8 23 / 0.18);
}

.demo-banner strong {
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.demo-banner span {
  color: rgb(224 242 254 / 0.86);
  font-size: 0.9rem;
}

.demo-banner a {
  color: #ffffff;
  font-weight: 800;
  text-decoration: none;
}

.demo-banner a:hover {
  text-decoration: underline;
}

body:has(.demo-banner) .boot-overlay {
  top: 42px;
}

@media (max-width: 720px) {
  .demo-banner {
    align-items: flex-start;
    flex-direction: column;
    gap: 2px;
  }
}

:root {
  color-scheme: light;
  --bg: #f8fafc;
  --card: #ffffff;
  --text: #0f172a;
  --muted: #64748b;
  --line: #e2e8f0;
  --track: #e2e8f0;
  --accent: #06b6d4;
  --accent-violet: #8b5cf6;
  --accent-green: #22c55e;
  --accent-amber: #fbbf24;
  --negative: #f87171;
  --table-head: #f8fafc;
  --table-head-text: #334155;
  --button-border: #cbd5e1;
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.06);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.08);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.1);
  --shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  --gradient-brand: linear-gradient(135deg, #06b6d4, #8b5cf6);
  --font-mono: 'JetBrains Mono', 'SF Mono', 'Consolas', 'Monaco', monospace;
  --gap-sm: 12px;
  --gap-md: 20px;
  --gap-lg: 28px;
  --radius-sm: 6px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-full: 999px;
  --gradient-pro: linear-gradient(135deg, #3b82f6, #8b5cf6);
  --gradient-pro-text: linear-gradient(135deg, #3b82f6, #8b5cf6);
}

:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #0a0e1a;
  --card: #0f172a;
  --text: #e5e7eb;
  --muted: #64748b;
  --line: #1e293b;
  --track: #1e293b;
  --accent: #06b6d4;
  --accent-violet: #8b5cf6;
  --accent-green: #22c55e;
  --accent-amber: #fbbf24;
  --negative: #f87171;
  --table-head: #111827;
  --table-head-text: #cbd5e1;
  --button-border: #334155;
  --shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.2);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.3);
  --shadow-lg: 0 12px 32px rgba(0, 0, 0, 0.4);
  --shadow: 0 4px 12px rgba(0, 0, 0, 0.3);
  --gradient-brand: linear-gradient(135deg, #06b6d4, #8b5cf6);
  --gradient-pro: linear-gradient(135deg, #3b82f6, #8b5cf6);
  --gradient-pro-text: linear-gradient(135deg, #3b82f6, #8b5cf6);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  min-height: 100vh;
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.boot-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  background: color-mix(in srgb, var(--bg) 92%, transparent);
  backdrop-filter: blur(6px);
}

.boot-card {
  display: grid;
  justify-items: center;
  gap: 10px;
  width: min(320px, calc(100vw - 48px));
  padding: 26px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--card);
  box-shadow: var(--shadow);
  text-align: center;
}

.boot-card img {
  width: 46px;
  height: 46px;
  border-radius: 10px;
  animation: bootPulse 1.1s ease-in-out infinite;
}

.boot-card span {
  color: var(--muted);
  font-size: 0.9rem;
}

.boot-issue-link {
  color: var(--accent);
  font-size: 0.84rem;
  font-weight: 750;
  text-decoration: none;
}

.boot-issue-link:hover {
  text-decoration: underline;
}

.boot-overlay.is-error .boot-card img {
  animation: none;
}

@keyframes bootPulse {
  0%,
  100% {
    transform: scale(0.96);
    opacity: 0.72;
  }
  50% {
    transform: scale(1.04);
    opacity: 1;
  }
}

h1,
h2,
p {
  margin: 0;
}

.page-shell {
  display: grid;
  gap: 28px;
  width: min(1200px, calc(100% - 32px));
  margin: 0 auto;
  padding: 32px 0;
}

.hero,
.panel {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
  min-width: 0;
}

.hero {
  padding: 28px;
}

.hero-top {
  display: grid;
  gap: 18px;
  align-items: center;
  justify-items: center;
  text-align: center;
}

.header-actions {
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  align-items: center;
  justify-content: center;
  justify-self: center;
  width: fit-content;
  max-width: 100%;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: var(--radius-full);
  transition:
    background-color 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease,
    transform 160ms ease;
}

.header-actions::before {
  content: '';
  display: none;
}

.toolbar-menu {
  position: relative;
}

.toolbar-menu > summary {
  list-style: none;
}

.toolbar-menu > summary::-webkit-details-marker {
  display: none;
}

.toolbar-menu-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 35;
  display: grid;
  gap: 6px;
  min-width: 160px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--card);
  box-shadow: var(--shadow);
  padding: 8px;
}

.toolbar-menu-panel .button {
  justify-content: flex-start;
  width: 100%;
  text-align: left;
  text-decoration: none;
}

.toolbar-menu-panel .button:hover {
  text-decoration: none;
}

.header-actions.is-fixed {
  position: fixed;
  top: 12px;
  left: 50%;
  z-index: 30;
  width: min(940px, calc(100vw - 24px));
  justify-content: center;
  background: color-mix(in srgb, var(--card) 85%, transparent);
  border-color: var(--line);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(16px) saturate(1.4);
  transform: translateX(-50%);
}

:root[data-theme="dark"] .header-actions.is-fixed {
  background: rgba(10, 14, 26, 0.88);
  border-color: var(--line);
}

.toolbar-brand {
  display: none;
  align-items: center;
  gap: 8px;
  margin-right: 6px;
  color: var(--text);
  font-size: 0.92rem;
  font-weight: 800;
}

.toolbar-brand img {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  object-fit: cover;
}

.header-actions.is-fixed .toolbar-brand {
  display: inline-flex;
}

.header-actions.is-fixed .app-version {
  padding: 4px 8px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
}

.app-version {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.2;
  gap: 2px;
}

.app-edition {
  font-size: 0.6rem;
  font-style: italic;
  font-weight: 400;
}

.app-edition-community {
  color: var(--accent);
}

.app-edition-professional,
.pro-edition-label {
  font-style: italic;
  font-weight: 700;
  background: var(--gradient-pro);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.eyebrow {
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0;
  text-transform: uppercase;
}

.brand-block {
  display: grid;
  gap: 10px;
  min-width: 0;
  justify-items: center;
  text-align: center;
}

.brand-banner {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 16px;
  width: auto;
  max-width: 100%;
}

.brand-lockup-logo {
  display: block;
  width: 74px;
  height: 74px;
  border-radius: 18px;
  object-fit: cover;
  box-shadow: 0 14px 30px rgba(6, 182, 212, 0.18);
}

.brand-wordmark {
  background: var(--gradient-brand);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  font-size: clamp(2.2rem, 5vw, 3.8rem);
  font-weight: 850;
  line-height: 0.95;
  letter-spacing: -0.02em;
}

:root[data-theme="dark"] .brand-wordmark {
  filter: brightness(1.1);
}

.brand-logo {
  display: none;
  width: 74px;
  height: 74px;
  object-fit: contain;
}

h1 {
  max-width: 780px;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1.05;
}

.hero-copy {
  max-width: 760px;
  margin-top: 0;
  color: var(--muted);
  font-size: 0.98rem;
  line-height: 1.6;
  text-align: center;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: minmax(360px, 0.9fr) minmax(0, 1.35fr);
  gap: 28px;
  align-items: start;
  min-width: 0;
}

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

.panel {
  padding: 28px;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  gap: 20px;
  align-items: flex-start;
  margin-bottom: 20px;
}

h2 {
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.subtle {
  margin-top: 4px;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.5;
}

.total-box {
  min-width: 150px;
  text-align: right;
}

.total-box span,
.donut-center span {
  display: block;
  color: var(--muted);
  font-size: 0.84rem;
}

.total-box strong {
  display: block;
  margin-top: 4px;
  font-size: 1.35rem;
}

.metric-label {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  max-width: 100%;
}

.metric-info-button {
  display: inline-grid;
  place-items: center;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin: 0;
  padding: 0;
  border: 1px solid color-mix(in srgb, var(--muted) 26%, var(--line));
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--card) 92%, var(--bg));
  color: var(--muted);
  cursor: help;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1;
  appearance: none;
}

.metric-info-button:hover,
.metric-info-button:focus-visible {
  border-color: var(--accent);
  color: var(--text);
  outline: none;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
}

.metric-info-tooltip {
  position: absolute;
  z-index: 20;
  top: 50%;
  left: calc(100% + 8px);
  display: block;
  width: max-content;
  max-width: min(280px, calc(100vw - 32px));
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-sm);
  background: var(--card);
  box-shadow: var(--shadow-sm);
  color: var(--text);
  font-size: 0.78rem;
  line-height: 1.45;
  padding: 8px 10px;
  pointer-events: none;
  text-align: left;
  text-transform: none;
  white-space: normal;
  opacity: 0;
  transform: translateY(-50%) translateX(-4px);
  transition: opacity 120ms ease, transform 120ms ease;
}

.metric-info-button:hover + .sr-only + .metric-info-tooltip,
.metric-label:focus-within .metric-info-tooltip {
  opacity: 1;
  transform: translateY(-50%) translateX(0);
}

.total-box .metric-info-tooltip {
  left: auto;
  right: calc(100% + 8px);
  transform: translateY(-50%) translateX(4px);
}

.total-box .metric-label {
  justify-content: flex-end;
}

.history-stats .metric-label {
  align-items: center;
}

.source-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  justify-content: space-between;
  margin: -8px 0 24px;
  color: var(--muted);
  font-size: 0.86rem;
}

.source-row-left {
  display: flex;
  gap: 6px;
  align-items: center;
}

.refresh-button {
  display: grid;
  place-items: center;
  width: 22px;
  height: 22px;
  border: 1px solid var(--button-border);
  border-radius: 4px;
  background: var(--card);
  color: var(--muted);
  cursor: pointer;
  flex-shrink: 0;
  padding: 0;
  transition: background 160ms ease, border-color 160ms ease, color 160ms ease;
}

.refresh-button:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 25%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 60%, var(--button-border));
  color: var(--accent);
}

:root.dark .refresh-button:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 35%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 70%, var(--button-border));
}

.refresh-button:active:not(:disabled) {
  transform: scale(0.93);
}

.refresh-button:disabled {
  cursor: progress;
  opacity: 0.5;
}

.refresh-button svg {
  transition: transform 400ms ease;
}

.refresh-button:disabled svg {
  animation: refreshSpin 900ms linear infinite;
}

@keyframes refreshSpin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
}

.button {
  border: 1px solid var(--button-border);
  border-radius: var(--radius-sm);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-size: 0.84rem;
  font-weight: 600;
  padding: 8px 14px;
  transition: background-color 120ms ease, border-color 120ms ease, transform 100ms ease;
}

.button:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 25%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 60%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}

:root.dark .button:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 35%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 70%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}

.button:active:not(:disabled) {
  transform: scale(0.97);
}

.button:disabled {
  cursor: progress;
  opacity: 0.5;
}

.calendar-button {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  flex: 0 0 auto;
  height: 36px;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  padding: 0 11px;
  text-decoration: none;
  transition: background-color 120ms ease, border-color 120ms ease, transform 100ms ease;
}

.calendar-button:hover {
  background: color-mix(in srgb, var(--accent) 25%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 60%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}

:root.dark .calendar-button:hover {
  background: color-mix(in srgb, var(--accent) 35%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 70%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}

.calendar-button:active {
  transform: scale(0.97);
}

.calendar-icon {
  position: relative;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-radius: 4px;
}

.calendar-icon::before {
  position: absolute;
  top: 3px;
  left: -2px;
  width: 16px;
  border-top: 2px solid currentColor;
  content: "";
}

.settings-icon {
  position: relative;
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.settings-icon::before {
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  background: currentColor;
  content: "";
}

.instruments-icon,
.export-icon,
.admin-icon {
  position: relative;
  display: inline-block;
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
}

.toolbar-svg {
  width: 17px;
  height: 17px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.instruments-icon {
  border: 2px solid currentColor;
  border-radius: 4px;
}

.instruments-icon::before {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 3px;
  height: 3px;
  border-radius: 2px;
  background: currentColor;
  box-shadow:
    6px 0 0 currentColor,
    0 6px 0 currentColor,
    6px 6px 0 currentColor;
  content: "";
}

.instruments-icon::after {
  content: none;
}

.export-icon {
  border: 2px solid currentColor;
  border-top: 0;
  border-radius: 0 0 4px 4px;
}

.export-icon::before {
  position: absolute;
  top: 1px;
  left: 6px;
  width: 2px;
  height: 10px;
  border-radius: var(--radius-full);
  background: currentColor;
  content: "";
}

.export-icon::after {
  position: absolute;
  top: 0;
  left: 3px;
  width: 7px;
  height: 7px;
  border-top: 2px solid currentColor;
  border-right: 2px solid currentColor;
  content: "";
  transform: rotate(-45deg);
}

.admin-icon {
  width: 17px;
  height: 17px;
}

.admin-icon::before {
  position: absolute;
  top: 3px;
  left: 2px;
  width: 13px;
  height: 2px;
  border-radius: var(--radius-full);
  background: currentColor;
  box-shadow:
    0 5px 0 currentColor,
    0 10px 0 currentColor;
  content: "";
}

.admin-icon::after {
  position: absolute;
  top: 1px;
  left: 9px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  box-shadow:
    -6px 5px 0 currentColor,
    2px 10px 0 currentColor;
  content: "";
}

.balance-toggle {
  display: grid;
  flex: 0 0 auto;
  place-items: center;
  width: 36px;
  height: 36px;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  padding: 0;
  transition: background-color 120ms ease, border-color 120ms ease, transform 100ms ease;
}

.balance-toggle:hover {
  background: color-mix(in srgb, var(--accent) 25%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 60%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 20%, transparent);
}

:root.dark .balance-toggle:hover {
  background: color-mix(in srgb, var(--accent) 35%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 70%, var(--button-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 30%, transparent);
}

.balance-toggle:active {
  transform: scale(0.97);
}

.eye-icon {
  display: block;
  width: 19px;
  height: 19px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2;
}

.eye-pupil {
  fill: currentColor;
  stroke: none;
}

.eye-slash {
  opacity: 0;
}

.balance-toggle.is-hidden .eye-slash {
  opacity: 1;
}

.button-primary {
  background: var(--text);
  color: var(--card);
}

.theme-toggle {
  flex: 0 0 auto;
  border: 0;
  background: transparent;
  cursor: pointer;
  padding: 0;
  transition: transform 100ms ease;
}

.theme-toggle:hover {
  transform: scale(1.05);
}

.theme-toggle:active {
  transform: scale(0.97);
}

.theme-toggle-track {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  width: 70px;
  height: 36px;
  padding: 4px;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  background: var(--bg);
}

.theme-symbol {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1;
}

.theme-symbol-sun::before {
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 50%;
  box-shadow:
    0 -8px 0 -6px currentColor,
    0 8px 0 -6px currentColor,
    8px 0 0 -6px currentColor,
    -8px 0 0 -6px currentColor,
    6px 6px 0 -6px currentColor,
    -6px -6px 0 -6px currentColor,
    6px -6px 0 -6px currentColor,
    -6px 6px 0 -6px currentColor;
  content: "";
}

.theme-symbol-moon::before {
  width: 13px;
  height: 13px;
  border-radius: 50%;
  box-shadow: inset -4px 0 0 0 currentColor;
  content: "";
}

.theme-thumb {
  position: absolute;
  top: 4px;
  left: 4px;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--card);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  transition: transform 160ms ease;
}

:root[data-theme="dark"] .theme-thumb {
  transform: translateX(36px);
}

:root[data-theme="dark"] .hero,
:root[data-theme="dark"] .panel {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.04), var(--shadow);
}

:root[data-theme="dark"] .hero:hover,
:root[data-theme="dark"] .panel:hover {
  box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), var(--shadow-md);
}

.chart-layout {
  display: grid;
  grid-template-columns: minmax(280px, 0.9fr) minmax(260px, 1fr);
  gap: 28px;
  align-items: center;
  justify-items: stretch;
  position: relative;
}

.chart-layout > .donut-chart {
  justify-self: center;
}

.donut-chart {
  position: relative;
  display: grid;
  place-items: center;
  width: min(100%, 300px);
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--track);
  animation: donutIn 600ms ease forwards;
}

@keyframes donutIn {
  from {
    opacity: 0;
    transform: scale(0.88);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}

.donut-chart::before {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background:
    conic-gradient(
      transparent 0deg,
      transparent var(--donut-active-start, 0deg),
      var(--donut-active-color, transparent) var(--donut-active-start, 0deg),
      var(--donut-active-color, transparent) var(--donut-active-end, 0deg),
      transparent var(--donut-active-end, 0deg),
      transparent 360deg
    );
  content: "";
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.12));
  opacity: 0;
  pointer-events: none;
  transform: translate(0, 0);
  transform-origin: center;
  transition:
    opacity 140ms ease,
    transform 140ms ease;
}

.donut-chart-active::before {
  opacity: 1;
  transform: translate(var(--donut-active-x, 0), var(--donut-active-y, 0));
}

.donut-chart::after {
  position: absolute;
  width: 58%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--card);
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.06);
  content: "";
}

:root[data-theme="dark"] .donut-chart::after {
  box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.3);
}

:root[data-theme="dark"] .donut-chart::before {
  filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.3));
}

.donut-center {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 2px;
  justify-items: center;
  text-align: center;
}

.donut-center strong {
  font-size: 1.15rem;
  font-family: var(--font-mono);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.donut-center span {
  font-size: 0.72rem;
  color: var(--muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.donut-chart-small {
  width: min(100%, 260px);
}

.donut-chart-small .donut-center strong {
  font-size: 1rem;
}

.subchart {
  display: grid;
  gap: 18px;
  margin-top: 28px;
  padding-top: 24px;
  border-top: 3px solid var(--subchart-color, var(--accent));
  animation: subchartIn 300ms ease forwards;
}

@keyframes subchartIn {
  from {
    opacity: 0;
    transform: translateX(16px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

.subchart[hidden] {
  display: none;
  animation: none;
}

.subchart-header {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  justify-content: space-between;
}

h3 {
  margin: 0;
  font-size: 1.05rem;
}

.subchart-grid {
  display: grid;
  grid-template-columns: minmax(240px, 0.9fr) minmax(260px, 1fr);
  gap: 28px;
  align-items: center;
  width: 100%;
}

.subchart-grid > .donut-chart {
  justify-self: center;
}

.legend {
  display: grid;
  gap: 10px;
  width: 100%;
  align-content: center;
}

.legend-separator {
  height: 1px;
  background: var(--line);
  margin: 4px 0;
}

.legend-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
}

.legend-row-button {
  margin: -6px -8px;
  padding: 6px 8px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background-color 80ms ease, border-color 80ms ease;
}

.legend-row-button:hover,
.legend-row-button:focus-visible {
  border-color: var(--line);
  background: color-mix(in srgb, var(--accent) 4%, var(--card));
  outline: none;
}

.legend-row-selected {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--card));
}

.swatch {
  width: 10px;
  height: 10px;
  margin-top: 2px;
  border-radius: 2px;
  flex-shrink: 0;
}

.legend-name {
  display: block;
  font-size: 0.88rem;
  font-weight: 600;
}

.legend-detail {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.8rem;
  line-height: 1.4;
}

.legend-value {
  text-align: right;
  white-space: nowrap;
}

.legend-value strong {
  display: block;
  font-size: 0.9rem;
  font-family: var(--font-mono);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.legend-value span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.76rem;
}

.table-wrap {
  min-width: 0;
  overflow-x: auto;
}

.monthly-summary,
.history-stats,
.ledger-filters,
.metric-grid {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

.monthly-summary,
.history-stats,
.metric-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.ytd-summary {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

.monthly-summary article,
.history-stats article,
.metric-grid article,
.transaction-preview {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  background: var(--bg);
  padding: 12px;
  transition: box-shadow 120ms ease, transform 120ms ease;
}

.operation-create-row {
  display: flex;
  justify-content: flex-start;
  margin-bottom: -8px;
}

.monthly-summary article:hover,
.history-stats article:hover,
.metric-grid article:hover {
  box-shadow: var(--shadow-sm);
}

.monthly-summary span,
.history-stats span,
.metric-grid span,
.transaction-preview span {
  color: var(--muted);
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.monthly-summary strong,
.history-stats strong,
.metric-grid strong {
  font-size: 1rem;
  font-family: var(--font-mono);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.monthly-summary small,
.metric-grid small,
.transaction-preview small {
  color: var(--muted);
  font-size: 0.74rem;
}

.ytd-zero-notice {
  display: grid;
  gap: 3px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 6%, var(--card)), var(--card));
  padding: 12px 14px;
}

.ytd-zero-notice strong {
  font-size: 0.88rem;
}

.ytd-zero-notice span {
  color: var(--muted);
  font-size: 0.8rem;
}

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

.ledger-filters {
  grid-template-columns: 1fr 160px 150px 150px 150px;
}

.ledger-filter-info {
  margin-bottom: 10px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 600;
}

.ledger-totals,
.backup-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 14px;
  padding: 10px 14px;
  border-radius: var(--radius-sm);
  background: var(--table-head);
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
}

.ledger-totals strong,
.backup-list a {
  color: var(--text);
  font-size: 0.92rem;
  font-family: var(--font-mono);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.ops-grid {
  display: grid;
  grid-template-columns: minmax(220px, 0.7fr) minmax(0, 1.3fr);
  gap: 20px;
}

.metric-panel .panel-header {
  margin-bottom: 14px;
}

.ops-grid h3 {
  margin: 0 0 10px;
  font-size: 1rem;
}

.import-box {
  display: grid;
  gap: 10px;
}

.admin-grid .import-box {
  gap: 10px;
}

.import-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 110px;
  gap: 10px;
}

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

.import-source-teaser {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.import-source-badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 3px 7px;
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  font-size: 0.68rem;
  font-weight: 750;
  line-height: 1.1;
  overflow-wrap: anywhere;
}

.import-source-badge-pro {
  color: #0f766e;
  border-color: color-mix(in srgb, #14b8a6 42%, var(--line));
  background: color-mix(in srgb, #14b8a6 9%, var(--card));
}

.import-source-badge-soon {
  color: #0f766e;
  border-color: color-mix(in srgb, #14b8a6 42%, var(--line));
  background: color-mix(in srgb, #14b8a6 9%, var(--card));
}

.import-step-body {
  display: grid;
  gap: 12px;
}

.import-progress {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 6px 0 14px;
}

.import-progress-item {
  position: relative;
  display: flex;
  gap: 8px;
  align-items: center;
  min-height: 46px;
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  padding: 8px 12px;
  color: var(--muted);
  background: var(--bg);
}

.import-progress-item span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--panel) 75%, transparent);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
}

.import-progress-item strong {
  font-size: 0.84rem;
}

.import-progress-item.is-active {
  border-color: color-mix(in srgb, var(--accent-primary) 65%, var(--line));
  color: var(--text);
  box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--accent-primary) 65%, transparent);
}

.import-progress-item.is-done span {
  background: #16a34a;
  color: #fff;
}

.import-workflow-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 6px;
}

.import-empty-step,
.import-step-intro {
  display: grid;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 14px;
}

.import-summary-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 10px;
}

.import-summary-cards article {
  display: grid;
  gap: 5px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 10px 12px;
}

.import-summary-cards span,
.import-impact-list small,
.import-operation-row span,
.import-operation-row p,
.import-step-intro span,
.import-empty-step span {
  color: var(--muted);
  font-size: 0.84rem;
}

.import-instrument-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.import-instrument-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel) 75%, transparent);
}

.import-instrument-card.is-confirmed {
  border-color: color-mix(in srgb, #16a34a 35%, var(--line));
}

.import-instrument-card.is-incomplete {
  border-color: color-mix(in srgb, #ef4444 60%, var(--line));
}

.import-instrument-card.is-safety-omitted {
  border-color: color-mix(in srgb, #ef4444 58%, var(--line));
  background: color-mix(in srgb, #7f1d1d 13%, var(--panel));
}

.import-safety-message {
  border: 1px solid color-mix(in srgb, #ef4444 45%, var(--line));
  border-radius: 8px;
  background: color-mix(in srgb, #7f1d1d 18%, transparent);
  color: #fecaca;
  padding: 9px 10px;
  font-size: 0.84rem;
  font-weight: 700;
}

.import-instrument-card header {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.import-instrument-metrics {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 12px;
  color: var(--muted);
  font-size: 0.8rem;
}

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

.import-suggestions .button {
  gap: 8px;
}

.import-suggestions small {
  color: var(--muted);
  font-size: 0.72rem;
}

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

.import-create-grid input,
.import-create-grid select {
  width: 100%;
  min-height: 36px;
}

.import-ops-toolbar {
  display: flex;
  gap: 12px;
  align-items: end;
  flex-wrap: wrap;
}

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

.import-operation-list,
.import-impact-list {
  display: grid;
  gap: 8px;
}

.import-operation-group {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--panel) 72%, transparent);
  overflow: hidden;
}

.import-operation-group > summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(140px, auto);
  gap: 12px;
  align-items: center;
  padding: 12px;
  cursor: pointer;
  list-style: none;
}

.import-operation-group > summary::-webkit-details-marker {
  display: none;
}

.import-operation-group > summary div {
  display: grid;
  gap: 3px;
}

.import-operation-group > summary span {
  color: var(--muted);
  font-size: 0.84rem;
}

.import-operation-group-details {
  display: grid;
  gap: 8px;
  border-top: 1px solid var(--line);
  padding: 10px;
}

.import-operation-row,
.import-impact-list article {
  display: grid;
  grid-template-columns: minmax(180px, 1.4fr) minmax(130px, 0.8fr) minmax(120px, 0.8fr) minmax(116px, 0.55fr);
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 10px 12px;
}

.import-operation-row > div:first-child {
  display: grid;
  gap: 3px;
}

.import-operation-row p {
  grid-column: 1 / -1;
  margin: 0;
}

.import-row-reference {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 650;
}

.import-operation-money {
  display: grid;
  gap: 3px;
  justify-items: end;
}

.import-warning-text {
  color: #d97706;
  font-size: 0.8em;
  font-weight: 500;
}

.import-impact-list article {
  grid-template-columns: minmax(120px, 0.8fr) minmax(0, 1.4fr) minmax(120px, 0.5fr);
}

.import-ops-table td,
.import-impact-table td {
  white-space: normal;
  vertical-align: top;
}

.import-detail-cell {
  max-width: 280px;
}

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

.import-wide-field {
  grid-column: 1 / -1;
}

.import-box input,
.import-box textarea {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  padding: 9px 10px;
}

.import-box textarea {
  resize: vertical;
  min-height: 110px;
  font: inherit;
}

.import-summary,
.import-batch-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
}

.import-summary {
  margin: 10px 0;
  color: var(--muted);
  font-size: 0.82rem;
}

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

.import-batches h4 {
  margin: 6px 0 0;
}

.import-batch-row {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 8px;
}

.import-batch-row.is-rolled-back {
  opacity: 0.55;
  background: color-mix(in srgb, var(--muted) 6%, transparent);
}

.import-batch-row.is-rolled-back strong {
  text-decoration: line-through;
  text-decoration-color: var(--muted);
}

.import-committing-overlay {
  display: grid;
  place-items: center;
  padding: 48px 24px;
}

.import-committing-card {
  display: grid;
  justify-items: center;
  gap: 14px;
  padding: 32px 40px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--card);
  box-shadow: var(--shadow);
  text-align: center;
}

.import-committing-card img {
  width: 52px;
  height: 52px;
  border-radius: 12px;
  animation: importSpin 1.4s ease-in-out infinite;
}

.import-committing-card strong {
  font-size: 1.05rem;
}

.import-committing-card span {
  color: var(--muted);
  font-size: 0.88rem;
}

@keyframes importSpin {
  0% { transform: scale(0.92) rotate(0deg); opacity: 0.7; }
  50% { transform: scale(1.08) rotate(180deg); opacity: 1; }
  100% { transform: scale(0.92) rotate(360deg); opacity: 0.7; }
}

.import-row-error td {
  color: #fca5a5;
}

.import-row-duplicate td {
  color: var(--muted);
}

.import-row-ignored td {
  color: color-mix(in srgb, var(--muted) 80%, var(--text));
}

.import-row-skipped td {
  color: var(--muted);
}

.import-row-needs_mapping td,
.import-row-blocked td {
  color: #fbbf24;
}

.import-row-control {
  width: 100%;
  min-width: 120px;
  height: 34px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 7px;
  color: var(--text);
  background: var(--panel);
  font: inherit;
  font-size: 0.82rem;
}

.import-row-control option {
  color: #111827;
  background: #ffffff;
}

:root[data-theme="dark"] .import-row-control option {
  color: #e5e7eb;
  background: #1e293b;
}

.import-auto-group {
  min-height: 38px;
  padding: 9px 10px;
  border: 1px solid var(--line);
  border-radius: 6px;
  color: var(--muted);
  background: var(--bg);
  font-size: 0.82rem;
  font-weight: 800;
}

.import-row-symbol {
  min-width: 180px;
}

.import-preview-output {
  min-width: 0;
}

.import-advanced-options {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 10px 12px;
}

.import-advanced-options summary {
  cursor: pointer;
  color: var(--muted);
  font-weight: 700;
}

.import-advanced-options .field {
  margin-top: 10px;
}

.import-preview-output .table-wrap {
  overflow-x: auto;
  max-width: 100%;
}

.import-preview-output table {
  width: 100%;
  min-width: 0 !important;
  table-layout: auto;
}

.import-preview-output th,
.import-preview-output td {
  white-space: normal;
  overflow-wrap: anywhere;
  word-break: break-word;
  line-height: 1.35;
}

.import-kind-pill {
  margin-bottom: 10px;
  color: var(--muted);
  font-size: 0.82rem;
}

.import-warning-banner {
  margin-bottom: 10px;
  padding: 10px;
  border: 1px solid color-mix(in srgb, #f59e0b 40%, var(--line));
  border-radius: 8px;
  color: color-mix(in srgb, #fbbf24 75%, var(--text));
  background: color-mix(in srgb, #f59e0b 10%, transparent);
  display: grid;
  gap: 4px;
  font-size: 0.84rem;
}

.import-mapping-required {
  margin: 8px 0 2px;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  color: var(--muted);
  font-size: 0.84rem;
}

.import-mapping-required ul {
  margin: 8px 0;
  padding-left: 18px;
}

.import-mapping-required code {
  color: var(--text);
}

.status-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--radius-full);
  padding: 2px 9px;
  font-size: 0.74rem;
}

.status-ok {
  color: #34d399;
}

.status-warn {
  color: #fbbf24;
}

.status-error {
  color: #f87171;
  border-color: color-mix(in srgb, #ef4444 55%, var(--line));
}

.status-muted {
  color: var(--muted);
}

.import-field-missing {
  border-color: #ef4444 !important;
  box-shadow: 0 0 0 1px color-mix(in srgb, #ef4444 60%, transparent);
}

.instrument-input {
  width: 100%;
  min-width: 90px;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  padding: 7px 8px;
}

.instrument-color {
  min-width: 54px;
  padding: 2px;
}

.color-input,
.field input[type='color'],
.instrument-create-form input[type='color'] {
  min-height: 42px;
  padding: 4px;
  cursor: pointer;
}

.color-input::-webkit-color-swatch-wrapper,
.field input[type='color']::-webkit-color-swatch-wrapper,
.instrument-create-form input[type='color']::-webkit-color-swatch-wrapper {
  padding: 0;
}

.color-input::-webkit-color-swatch,
.field input[type='color']::-webkit-color-swatch,
.instrument-create-form input[type='color']::-webkit-color-swatch {
  border: 0;
  border-radius: 4px;
}

.button-compact {
  padding: 5px 8px;
  font-size: 0.78rem;
}

.table-wrap[hidden] {
  display: none;
}

table {
  width: 100%;
  min-width: 780px;
  border-collapse: collapse;
  font-size: 0.86rem;
}

th,
td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  white-space: nowrap;
}

th {
  background: var(--table-head);
  color: var(--table-head-text);
  font-weight: 700;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

tbody tr {
  transition: background-color 80ms ease;
}

tbody tr:hover {
  background: color-mix(in srgb, var(--accent) 4%, var(--card));
  cursor: pointer;
}

tbody tr.is-selected {
  background: color-mix(in srgb, var(--accent) 10%, var(--card));
  cursor: pointer;
}

tbody tr:last-child td {
  border-bottom: 0;
}

td:first-child,
td:last-child {
  font-weight: 700;
}

.pending {
  color: var(--muted);
}

.cell-main,
.cell-price,
.cell-date {
  display: block;
}

.cell-main {
  font-weight: 700;
}

.cell-price {
  margin-top: 3px;
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 500;
}

.cell-date {
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 500;
}

.ytd-panel {
  display: grid;
  gap: 18px;
}

.ytd-month-list {
  display: grid;
  gap: 10px;
}

.ytd-month-card {
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  overflow: hidden;
}

.ytd-month-card summary {
  display: grid;
  grid-template-columns: 0.9fr repeat(5, minmax(100px, 1fr)) 36px;
  gap: 12px;
  align-items: center;
  min-height: 72px;
  padding: 14px 16px;
  cursor: pointer;
  list-style: none;
}

.ytd-month-card summary::-webkit-details-marker {
  display: none;
}

.ytd-month-card summary::after {
  content: '';
  display: grid;
  place-items: center;
  justify-self: end;
  width: 32px;
  height: 32px;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  color: var(--text);
  background:
    linear-gradient(45deg, transparent 45%, currentColor 46% 54%, transparent 55%) 10px 9px / 8px 8px no-repeat,
    linear-gradient(-45deg, transparent 45%, currentColor 46% 54%, transparent 55%) 15px 9px / 8px 8px no-repeat;
  opacity: 0.9;
  transition:
    transform 160ms ease,
    border-color 160ms ease,
    background-color 160ms ease;
}

.ytd-month-card[open] summary::after {
  transform: rotate(180deg);
  border-color: var(--accent);
  background-color: color-mix(in srgb, var(--accent) 10%, transparent);
}

.ytd-month-card small,
.ytd-month-meta,
.ytd-group-row small {
  color: var(--muted);
  font-size: 0.78rem;
}

.ytd-month-card summary span {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.ytd-month-card summary small {
  font-weight: 700;
  text-transform: uppercase;
}

.ytd-month-card summary strong {
  font-size: 0.95rem;
}

.ytd-month-title {
  color: var(--text);
  font-size: 1rem;
  font-weight: 800;
}

.ytd-month-body {
  display: grid;
  gap: 14px;
  padding: 0 16px 16px;
}

.ytd-month-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.ytd-driver-dot,
.ytd-group-name i {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 7px;
  border-radius: 3px;
  background: var(--driver-color, var(--group-color, var(--accent)));
}

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

.ytd-group-row {
  display: grid;
  grid-template-columns: minmax(160px, 1.4fr) repeat(3, minmax(90px, 0.7fr)) minmax(220px, 1.4fr);
  gap: 12px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}

.ytd-group-row > div {
  display: grid;
  gap: 4px;
}

.ytd-group-name {
  display: flex;
  align-items: center;
  font-weight: 800;
}

.ytd-group-row ul {
  display: grid;
  gap: 5px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.ytd-group-row li {
  display: grid;
  gap: 2px;
}

.is-positive {
  color: var(--accent-green);
}

.is-negative {
  color: var(--negative);
}

:root[data-negative-red='false'] .is-negative {
  color: inherit;
}

.type-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 0.76rem;
  font-weight: 700;
}

.type-buy {
  background: color-mix(in srgb, var(--accent-green) 12%, transparent);
  color: var(--accent-green);
}

.type-sell {
  background: color-mix(in srgb, var(--negative) 12%, transparent);
  color: var(--negative);
}

.origin-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 0.72rem;
  font-weight: 600;
  background: color-mix(in srgb, var(--muted) 10%, transparent);
  color: var(--muted);
}

.origin-auto {
  background: color-mix(in srgb, var(--accent-violet) 12%, transparent);
  color: var(--accent-violet);
}

.origin-import {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  color: var(--accent);
}

.metric-grid article.has-border-accent {
  border-left: 3px solid var(--accent);
}

.metric-grid article.has-border-positive {
  border-left: 3px solid var(--accent-green);
}

.metric-grid article.has-border-negative {
  border-left: 3px solid var(--negative);
}

.metric-grid article.has-border-amber {
  border-left: 3px solid var(--accent-amber);
}

.metric-grid article.has-border-violet {
  border-left: 3px solid var(--accent-violet);
}

.metric-grid article .metric-micro {
  color: var(--muted);
  font-size: 0.72rem;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.history-panel {
  display: grid;
  gap: 18px;
}

.history-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.history-range {
  transition: background-color 120ms ease, color 120ms ease, transform 100ms ease;
}

.history-range:hover:not(.is-active) {
  background: color-mix(in srgb, var(--accent) 8%, var(--card));
}

.history-range:active {
  transform: scale(0.97);
}

.history-range.is-active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}

.history-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  justify-content: space-between;
  color: var(--muted);
  font-size: 0.86rem;
}

.granularity-pill {
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  padding: 4px 9px;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 700;
}

.history-chart-wrap {
  position: relative;
  height: 320px;
}

.history-chart {
  height: 320px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
}

.history-empty {
  display: grid;
  min-height: 320px;
  place-items: center;
  color: var(--muted);
  font-weight: 700;
}

.history-svg {
  display: block;
  width: 100%;
  height: 320px;
}

.history-grid-line {
  stroke: var(--line);
  stroke-width: 0.5;
  opacity: 0.5;
}

.history-reference-line {
  stroke: var(--line);
  stroke-dasharray: 4 8;
  stroke-width: 0.8;
  opacity: 0.35;
}

:root[data-theme="dark"] .history-grid-line {
  opacity: 0.15;
}

:root[data-theme="dark"] .history-reference-line {
  opacity: 0.15;
}

.history-axis-label {
  fill: var(--muted);
  font-size: 11px;
  font-family: var(--font-mono);
  font-weight: 500;
}

.history-guide-label {
  fill: var(--muted);
  font-size: 10px;
  font-family: var(--font-mono);
  font-weight: 500;
  text-anchor: end;
}

.history-axis-label-mid {
  text-anchor: middle;
}

.history-axis-label-end {
  text-anchor: end;
}

.history-line {
  fill: none;
  stroke: url(#historyLineGrad);
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 2.5;
}

.history-contributed-line {
  fill: none;
  stroke: var(--muted);
  stroke-dasharray: 4 3;
  stroke-linecap: round;
  stroke-width: 1.4;
  opacity: 0.5;
}

.history-area {
  fill: url(#historyAreaGrad);
}

.history-event {
  cursor: pointer;
  fill: var(--card);
  stroke-width: 2;
}

.history-event-ring {
  fill: none;
  stroke-width: 2;
  opacity: 0.35;
}

.history-event-ring-add {
  stroke: var(--event-color, #16a34a);
}

.history-event-ring-remove {
  stroke: var(--event-color, #dc2626);
}

.history-event-add {
  stroke: var(--event-color, #16a34a);
}

.history-event-remove {
  stroke: var(--event-color, #dc2626);
}

.history-tooltip {
  position: absolute;
  z-index: 2;
  max-width: 240px;
  white-space: pre-line;
  border: 1px solid var(--line);
  border-left: 3px solid var(--accent);
  border-radius: var(--radius-sm);
  background: var(--card);
  color: var(--text);
  box-shadow: var(--shadow-sm);
  font-size: 0.8rem;
  line-height: 1.45;
  padding: 8px 12px;
  pointer-events: none;
  font-family: var(--font-mono);
}

.donut-tooltip {
  position: fixed;
  z-index: 40;
  display: grid;
  gap: 6px;
  width: min(280px, calc(100vw - 28px));
  border: 1px solid var(--line);
  border-left: 3px solid var(--donut-active-color, var(--accent));
  border-radius: var(--radius-sm);
  background: var(--card);
  box-shadow: var(--shadow-sm);
  color: var(--text);
  padding: 10px 12px;
  pointer-events: none;
}

.donut-tooltip-title {
  font-weight: 700;
  font-size: 0.88rem;
}

.donut-tooltip-total {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 600;
  font-family: var(--font-mono);
}

.donut-tooltip ul {
  display: grid;
  gap: 7px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.donut-tooltip li {
  display: grid;
  gap: 2px;
  border-top: 1px solid var(--line);
  padding-top: 7px;
}

.donut-tooltip li span {
  color: var(--text);
  font-size: 0.86rem;
}

.donut-tooltip li strong {
  color: var(--muted);
  font-size: 0.78rem;
}

.history-event-panel {
  display: none;
}

.modal {
  width: min(520px, calc(100% - 32px));
  max-width: calc(100vw - 32px);
  padding: 0;
  border: 0;
  border-radius: var(--radius-lg);
  background: transparent;
  color: var(--text);
  animation: modalIn 200ms ease forwards;
}

.modal.is-closing {
  animation: modalOut 150ms ease forwards;
}

@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(0.96) translateY(8px);
  }
  to {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
}

@keyframes modalOut {
  from {
    opacity: 1;
    transform: scale(1) translateY(0);
  }
  to {
    opacity: 0;
    transform: scale(0.96) translateY(8px);
  }
}

#instrument-dialog {
  width: min(1180px, calc(100vw - 32px));
}

#auto-dialog {
  width: min(1120px, calc(100vw - 32px));
}

#instrument-delete-dialog.transaction-delete-dialog {
  width: min(620px, calc(100vw - 32px));
}

#import-dialog {
  width: min(1160px, calc(100vw - 32px));
}

#admin-dialog {
  width: min(880px, calc(100vw - 32px));
}

#wizard-dialog {
  width: min(1040px, calc(100vw - 32px));
}

.modal::backdrop {
  background: rgba(15, 23, 42, 0.6);
  backdrop-filter: blur(6px);
}

:root[data-theme="dark"] .modal::backdrop {
  background: rgba(0, 0, 0, 0.7);
}

.modal-panel {
  display: grid;
  gap: 18px;
  max-height: calc(100vh - 48px);
  overflow-y: auto;
  padding: 24px;
  border: 1px solid var(--line);
  border-top: 3px solid var(--accent);
  border-radius: var(--radius-lg);
  background: var(--card);
  box-shadow: var(--shadow-lg);
}

.modal-panel-wide {
  width: 100%;
}

.instrument-config-stack {
  display: grid;
  gap: 22px;
}

.instrument-config-section {
  display: grid;
  gap: 12px;
}

.instrument-config-section h3 {
  margin: 0;
  font-size: 1rem;
}

.instrument-section-heading {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  align-items: end;
  justify-content: space-between;
}

.instrument-position-filter {
  min-width: 210px;
  margin: 0;
}

.instrument-filter-grid {
  display: grid;
  grid-template-columns: 170px repeat(5, minmax(120px, 1fr));
  gap: 10px;
  align-items: end;
}

.instrument-filter-grid .field {
  margin: 0;
}

.instrument-create-panel {
  display: grid;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--card) 82%, var(--bg));
  padding: 14px;
}

.instrument-create-panel h4,
.instrument-list-heading h4 {
  margin: 0 0 4px;
}

.instrument-create-panel p,
.instrument-list-heading p {
  margin: 0;
}

.instrument-list-heading {
  margin-top: 18px;
}

.bulk-toolbar {
  display: flex;
  gap: 10px;
  align-items: center;
  justify-content: flex-end;
  min-height: 34px;
  animation: bulkToolbarIn 200ms ease forwards;
}

@keyframes bulkToolbarIn {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.ledger-bulk-toolbar {
  margin: -2px 0 12px;
}

.icon-bulk-delete {
  gap: 8px;
}

.icon-bulk-delete:hover:not(:disabled) {
  animation: deletePulse 600ms ease infinite;
}

@keyframes deletePulse {
  0%, 100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--negative) 40%, transparent); }
  50% { box-shadow: 0 0 0 4px color-mix(in srgb, var(--negative) 20%, transparent); }
}

.trash-icon {
  position: relative;
  width: 14px;
  height: 14px;
  border: 2px solid currentColor;
  border-top: 0;
  border-radius: 0 0 3px 3px;
}

.trash-icon::before {
  position: absolute;
  left: -3px;
  top: -5px;
  width: 16px;
  border-top: 2px solid currentColor;
  content: "";
}

.trash-icon::after {
  position: absolute;
  left: 3px;
  top: -8px;
  width: 6px;
  border-top: 2px solid currentColor;
  content: "";
}

/* ── Admin Panel ─────────────────────────────────────────── */

.admin-panel {
  width: 100%;
  max-width: min(880px, calc(100vw - 32px));
  overflow-x: hidden;
}

.admin-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--line);
  position: relative;
}

.admin-header::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 72px;
  height: 2px;
  background: var(--gradient-brand);
  border-radius: 1px;
}

.admin-header-text h2 {
  font-size: 1.3rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  margin: 0;
}

.admin-header-text .subtle {
  font-size: 0.82rem;
  margin-top: 2px;
}

/* ── Admin Grid ─────────────────────────────────────────── */

.admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  min-width: 0;
  gap: 18px;
}

/* ── Admin Cards ────────────────────────────────────────── */

.admin-card {
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--card) 80%, var(--bg));
  padding: 18px;
  animation: adminCardIn 350ms ease both;
}

.admin-card:nth-child(2) { animation-delay: 60ms; }
.admin-card:nth-child(3) { animation-delay: 120ms; }

@keyframes adminCardIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.admin-card--full {
  grid-column: 1 / -1;
}

.admin-card--preferences {
  border-left: 3px solid color-mix(in srgb, var(--accent) 60%, transparent);
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent) 4%, var(--card)),
    color-mix(in srgb, var(--accent-violet) 3%, var(--card))
  );
}

.admin-card--backups {
  border-top: 2px solid color-mix(in srgb, var(--accent-green) 40%, transparent);
}

.admin-card--imports {
  border-top: 2px solid color-mix(in srgb, var(--accent-amber) 40%, transparent);
}

/* ── Card Headings ──────────────────────────────────────── */

.admin-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 16px;
}

.admin-card-icon {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 7px;
  background: color-mix(in srgb, var(--accent) 10%, transparent);
  color: var(--accent);
  flex-shrink: 0;
}

.admin-card--backups .admin-card-icon {
  background: color-mix(in srgb, var(--accent-green) 10%, transparent);
  color: var(--accent-green);
}

.admin-card--imports .admin-card-icon {
  background: color-mix(in srgb, var(--accent-amber) 10%, transparent);
  color: var(--accent-amber);
}

.admin-card-head h3 {
  margin: 0;
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: var(--text);
}

/* ── Preferences Grid ───────────────────────────────────── */

.admin-prefs-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  align-items: flex-end;
}

.admin-preference {
  width: 100%;
  border-color: color-mix(in srgb, var(--accent) 15%, var(--line));
}

.admin-prefs-hint {
  margin: 12px 0 0;
  font-size: 0.78rem;
  padding-top: 10px;
  border-top: 1px solid color-mix(in srgb, var(--line) 60%, transparent);
}

/* ── Admin Action Button ────────────────────────────────── */

.admin-action-btn {
  width: 100%;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent-green) 8%, var(--card)),
    color-mix(in srgb, var(--accent) 6%, var(--card))
  );
  border-color: color-mix(in srgb, var(--accent-green) 25%, var(--button-border));
}

.admin-action-btn:hover:not(:disabled) {
  background: linear-gradient(
    135deg,
    color-mix(in srgb, var(--accent-green) 16%, var(--card)),
    color-mix(in srgb, var(--accent) 12%, var(--card))
  );
  border-color: color-mix(in srgb, var(--accent-green) 50%, var(--button-border));
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--accent-green) 10%, transparent);
}

/* ── Shared Admin Bits ──────────────────────────────────── */

.preference-field {
  min-width: 0;
  max-width: none;
}

/* ── Professional Preferences Collapsible Card ──────────── */

.pro-preferences-card {
  margin-top: 16px;
  border: 1px solid color-mix(in srgb, var(--accent) 15%, transparent);
  border-radius: var(--radius-md);
  background: var(--card);
  overflow: hidden;
  transition: border-color 0.2s ease;
  width: 100%;
  grid-column: 1 / -1;
}

.pro-preferences-card:hover {
  border-color: color-mix(in srgb, var(--accent) 25%, transparent);
}

.pro-preferences-summary {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 14px;
  font-size: 0.8rem;
  color: var(--muted);
  cursor: pointer;
  list-style: none;
  user-select: none;
  transition: background 0.15s ease;
}

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

.pro-preferences-summary:hover {
  background: color-mix(in srgb, var(--accent) 4%, var(--card));
}

.pro-preferences-summary svg:first-of-type {
  color: var(--accent);
  opacity: 0.7;
}

.pro-preferences-summary .pro-edition-label {
  font-size: 0.8rem;
}

.pro-preferences-chevron {
  margin-left: auto;
  color: var(--muted);
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}

.pro-preferences-card[open] .pro-preferences-chevron {
  transform: rotate(180deg);
}

.pro-preferences-body {
  padding: 12px 14px 14px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  animation: proPrefsSlideIn 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

@keyframes proPrefsSlideIn {
  from {
    opacity: 0;
    transform: translateY(-6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.pro-preference-group {
  min-width: 0;
}

.pro-preference-group .admin-card-head {
  margin-bottom: 10px;
}

.pro-preference-group .admin-card-head h3 {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--muted);
}

.operations-preference-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.operations-preference-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  background: var(--card);
  border: 1px solid color-mix(in srgb, var(--accent) 12%, transparent);
  border-radius: 6px;
}

.operations-preference-row .preference-label {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--muted);
  min-width: 90px;
  flex-shrink: 0;
}

.operations-preference-row .preference-select {
  flex: 1;
  min-width: 0;
  padding: 4px 8px;
  font-size: 0.85rem;
  font-family: inherit;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, transparent);
  border-radius: 4px;
  background: var(--bg);
  color: var(--text);
  cursor: pointer;
  transition: border-color 0.2s ease;
}

.operations-preference-row .preference-select:hover {
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}

.operations-preference-row .preference-select:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  background: color-mix(in srgb, var(--muted) 8%, var(--bg));
}

.history-filter-main {
  margin-bottom: 10px;
}

.history-filter-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 10px;
}

.history-filter-group {
  flex: 1;
  min-width: 140px;
}

.history-filter-group-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--muted);
  margin-bottom: 4px;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}

.history-filter-checkboxes {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.history-filter-checkbox {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.82rem;
  color: var(--text);
  cursor: pointer;
  user-select: none;
}

.history-filter-checkbox input[type="checkbox"] {
  accent-color: var(--accent);
  width: 14px;
  height: 14px;
}

.history-filter-checkbox input[type="checkbox"]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.backup-list,
.import-batches {
  min-width: 0;
  overflow-wrap: anywhere;
}

.backup-list a,
.import-batches a,
.import-batches button {
  max-width: 100%;
  overflow-wrap: anywhere;
}

.ledger-pagination {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: center;
  margin-top: 16px;
  padding: 12px 0;
}

.ledger-page-info {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
}

.ledger-pagination .button-compact:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.inline-form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin: 10px 0 14px;
}

.inline-form input,
.inline-form select {
  width: auto;
  min-width: 120px;
  border: 1px solid var(--button-border);
  border-radius: 6px;
  background: var(--bg);
  color: var(--text);
  font: inherit;
  padding: 10px 12px;
}

.instrument-create-form {
  display: grid;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 12px;
}

.group-create-form {
  grid-template-columns: minmax(180px, 1fr) 64px auto;
}

.instrument-create-form-wide {
  grid-template-columns: minmax(110px, 0.8fr) minmax(120px, 1fr) minmax(140px, 1.2fr) 100px 82px minmax(120px, 1fr) 58px auto;
}

.instrument-create-form input,
.instrument-create-form select {
  min-width: 0;
  width: 100%;
  border: 1px solid var(--button-border);
  border-radius: 6px;
  background: var(--card);
  color: var(--text);
  font: inherit;
  padding: 10px 12px;
}

.instrument-create-form input[type='color'] {
  height: 42px;
  padding: 4px;
}

.group-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 10px;
}

.group-card,
.empty-config-state {
  display: grid;
  grid-template-columns: minmax(130px, 1fr) 58px auto;
  gap: 8px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 10px;
}

.group-select {
  grid-column: 1 / -1;
  justify-self: start;
  color: var(--muted);
  font-size: 0.78rem;
}

.group-card-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.group-visual-options {
  grid-column: 1 / -1;
  border: 1px solid var(--line);
  border-radius: 6px;
  background: var(--panel);
}

.group-visual-options > summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  padding: 7px 9px;
}

.group-visual-options > summary::-webkit-details-marker {
  display: none;
}

.group-visual-options .group-card-options {
  grid-column: auto;
  padding: 0 9px 9px;
}

.group-card [data-save-group] {
  grid-column: 1 / -1;
  width: 100%;
  justify-self: stretch;
}

.empty-config-state {
  display: block;
  color: var(--muted);
  font-size: 0.88rem;
}

.group-name-input {
  min-width: 0;
}

.switch-field {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 6px;
  align-items: center;
  min-height: 32px;
  min-width: 0;
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 7px 9px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.switch-field input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.instrument-table-wrap {
  overflow-x: visible;
}

.instrument-table {
  width: 100%;
  min-width: 0;
  table-layout: fixed;
}

.instrument-table th:nth-child(1),
.instrument-table td:nth-child(1) {
  width: 12%;
}

.instrument-table th:nth-child(2),
.instrument-table td:nth-child(2) {
  width: 16%;
}

.instrument-table th:nth-child(3),
.instrument-table td:nth-child(3) {
  width: 19%;
}

.instrument-table th:nth-child(4),
.instrument-table td:nth-child(4) {
  width: 15%;
}

.instrument-table th:nth-child(5),
.instrument-table td:nth-child(5) {
  width: 10%;
}

.instrument-table th:nth-child(6),
.instrument-table td:nth-child(6) {
  width: 10%;
}

.instrument-table th:nth-child(7),
.instrument-table td:nth-child(7) {
  width: 8%;
}

.instrument-table th:nth-child(8),
.instrument-table td:nth-child(8) {
  width: 10%;
}

.instrument-table th,
.instrument-table td {
  padding: 10px;
}

.row-select {
  display: inline-flex;
  gap: 8px;
  align-items: center;
  min-width: 0;
  max-width: 100%;
}

.instrument-symbol-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.row-select input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.row-select input[type='checkbox'],
.switch-field input[type='checkbox'],
.check-field input[type='checkbox'] {
  appearance: none;
  border: 1px solid var(--button-border);
  border-radius: 5px;
  background: color-mix(in srgb, var(--panel) 82%, var(--line));
  display: inline-grid;
  place-content: center;
  flex: 0 0 auto;
  transition:
    border-color 0.15s ease,
    background 0.15s ease,
    box-shadow 0.15s ease;
}

.row-select input[type='checkbox']::before,
.switch-field input[type='checkbox']::before,
.check-field input[type='checkbox']::before {
  content: '';
  width: 9px;
  height: 9px;
  transform: scale(0);
  transition: transform 0.12s ease;
  background: #ffffff;
  clip-path: polygon(14% 44%, 0 58%, 38% 96%, 100% 20%, 85% 6%, 36% 68%);
}

.row-select input[type='checkbox']:checked,
.switch-field input[type='checkbox']:checked,
.check-field input[type='checkbox']:checked {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 18%, transparent);
  transform: scale(1.08);
}

.row-select input[type='checkbox']:checked::before,
.switch-field input[type='checkbox']:checked::before,
.check-field input[type='checkbox']:checked::before {
  transform: scale(1);
  animation: checkPop 200ms ease;
}

@keyframes checkPop {
  0% { transform: scale(0); }
  60% { transform: scale(1.2); }
  100% { transform: scale(1); }
}

.row-select input[type='checkbox']:focus-visible,
.switch-field input[type='checkbox']:focus-visible,
.check-field input[type='checkbox']:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--accent) 70%, white);
  outline-offset: 2px;
}

.row-select-only {
  justify-content: center;
}

.instrument-table .instrument-input,
.instrument-table .button {
  width: 100%;
  min-width: 0;
}

.instrument-table .instrument-color {
  width: 100%;
  min-width: 0;
}

.plus-icon {
  position: relative;
  display: inline-block;
  width: 14px;
  height: 14px;
}

.plus-icon::before,
.plus-icon::after {
  content: '';
  position: absolute;
  background: currentColor;
  border-radius: var(--radius-full);
}

.plus-icon::before {
  inset: 6px 1px;
}

.plus-icon::after {
  inset: 1px 6px;
}

@media (min-width: 1400px) {
  .metric-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
  }
}

@media (max-width: 1180px) {
  .instrument-create-form-wide {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .instrument-filter-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .instrument-table-wrap {
    overflow-x: visible;
  }

  .instrument-table,
  .compact-table .instrument-table,
  .instrument-table thead,
  .instrument-table tbody,
  .instrument-table tr,
  .instrument-table td {
    display: block;
    width: 100%;
    min-width: 0;
  }

  .instrument-table thead {
    display: none;
  }

  .instrument-table tbody {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 12px;
  }

  .instrument-table tr {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--bg);
    padding: 12px;
  }

  .instrument-table td {
    display: grid;
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    border-bottom: 0;
    padding: 6px 0;
    white-space: normal;
  }

  .instrument-table tbody tr td {
    width: 100% !important;
    box-sizing: border-box;
  }

  .instrument-table tbody tr td > input,
  .instrument-table tbody tr td > select,
  .instrument-table tbody tr td > button {
    width: 100%;
    min-width: 0;
  }

  .instrument-table td::before {
    content: attr(data-label);
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
  }

  .instrument-table td[colspan] {
    display: block;
  }

  .instrument-table td[colspan]::before {
    content: none;
  }
}

.modal-header,
.modal-actions {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  justify-content: space-between;
}

.modal-actions {
  align-items: center;
  justify-content: flex-end;
}

.icon-close {
  position: relative;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-full);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  font: inherit;
  font-weight: 700;
  overflow: hidden;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease,
    box-shadow 160ms ease;
}

.icon-close::before {
  content: '';
  position: absolute;
  inset: 7px;
  border-radius: inherit;
  background: color-mix(in srgb, var(--negative) 20%, transparent);
  opacity: 0;
  transform: scale(0.5) rotate(20deg);
  transition:
    opacity 160ms ease,
    transform 160ms ease;
}

.icon-close:hover,
.icon-close:focus-visible {
  border-color: color-mix(in srgb, var(--negative) 55%, var(--button-border));
  background: color-mix(in srgb, var(--negative) 10%, var(--card));
  color: #ef4444;
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--negative) 14%, transparent);
  transform: rotate(8deg) scale(1.06);
}

.icon-close:hover::before,
.icon-close:focus-visible::before {
  opacity: 1;
  transform: scale(1.45) rotate(0deg);
}

.icon-close:active {
  transform: rotate(0deg) scale(0.96);
}

.field,
.field-grid {
  display: grid;
  gap: 8px;
  min-width: 0;
}

.field-grid {
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}

.field span {
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.field input,
.field select {
  width: 100%;
  border: 1px solid var(--button-border);
  border-radius: var(--radius-sm);
  background: var(--bg);
  color: var(--text);
  font: inherit;
  padding: 10px 12px;
  transition: border-color 120ms ease, box-shadow 120ms ease;
}

.field input[type='date'] {
  min-width: 0;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-variant-numeric: tabular-nums;
}

.field input[type='date']::-webkit-calendar-picker-indicator {
  opacity: 0.6;
  cursor: pointer;
  filter: invert(var(--icon-invert, 0));
}

:root:not(.dark) {
  --icon-invert: 0;
}

:root.dark {
  --icon-invert: 1;
}

.field input:focus,
.field select:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 20%, transparent);
}

.field input:disabled,
.field select:disabled {
  opacity: 0.48;
  cursor: not-allowed;
}

.auto-plan-list {
  display: grid;
  gap: 12px;
}

.auto-plan-toolbar {
  display: flex;
  justify-content: flex-end;
}

.auto-plan-row {
  display: grid;
  grid-template-columns:
    86px
    minmax(190px, 1.35fr)
    minmax(92px, 0.5fr)
    minmax(118px, 0.58fr)
    minmax(86px, 0.42fr)
    minmax(145px, 0.68fr)
    88px;
  gap: 12px;
  align-items: end;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.auto-plan-row input,
.auto-plan-row select {
  min-width: 0;
}

.auto-plan-row [data-remove-auto-plan] {
  align-self: end;
  width: 100%;
  min-height: 42px;
}

.empty-action-state {
  display: grid;
  gap: 10px;
  align-items: start;
}

.delete-impact-summary {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}

.delete-impact-summary article {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 10px;
}

.delete-impact-summary span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
}

.delete-impact-summary strong {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  font-family: var(--font-mono);
  font-size: 0.9rem;
  white-space: nowrap;
}

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

.wizard-mode-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
}

.wizard-import-entry {
  display: grid;
  gap: 10px;
  margin-bottom: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 12px;
}

.wizard-step {
  display: grid;
  gap: 12px;
  align-content: start;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--bg);
  padding: 14px;
}

.wizard-step > span {
  color: var(--muted);
  font-size: 0.75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.wizard-step h3 {
  margin: 0;
  font-size: 1rem;
}

.wizard-group-options {
  grid-column: auto;
}

.check-field {
  display: flex;
  gap: 8px;
  align-items: center;
  min-height: 40px;
  color: var(--muted);
  font-size: 0.84rem;
  font-weight: 700;
}

.form-feedback {
  min-height: 20px;
  color: var(--muted);
  font-size: 0.88rem;
}

.form-feedback[data-state="error"] {
  color: #ef4444;
}

.form-feedback[data-state="ok"] {
  color: #16a34a;
}

.form-feedback-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: -4px;
  padding: 5px 0;
  border-radius: 4px;
  color: var(--accent);
  font-size: 0.78rem;
  font-weight: 600;
}

@media (max-width: 980px) {
  .page-shell {
    width: min(100% - 24px, 760px);
    padding: 20px 0;
  }

  .dashboard-grid {
    grid-template-columns: 1fr;
    width: 100%;
  }

  .hero,
  .panel {
    padding: 22px;
  }

  .panel-header {
    display: grid;
  }

  .hero-top {
    display: grid;
    gap: 18px;
  }

  .brand-banner {
    width: auto;
  }

  .header-actions {
    flex-wrap: nowrap;
    justify-content: center;
    max-width: none;
    gap: 6px;
    padding: 7px 8px;
  }

  .header-actions .toolbar-label {
    display: none;
  }

  .calendar-button {
    justify-content: center;
    width: 36px;
    padding: 0;
  }

  .toolbar-menu > summary.calendar-button {
    width: 36px;
  }

  .source-row {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
  }

  .ledger-header-actions,
  .history-controls {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(88px, 1fr));
    width: 100%;
  }

  .ledger-header-actions .button,
  .history-controls .button {
    min-width: 0;
    padding: 8px 10px;
    text-align: center;
  }

  .subchart-grid {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .chart-layout {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .chart-layout .legend {
    align-content: start;
  }

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

  .admin-card--full {
    grid-column: auto;
  }

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

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

  .auto-plan-row {
    grid-template-columns: 1fr;
  }

  #auto-dialog,
  #import-dialog,
  #wizard-dialog {
    width: calc(100vw - 20px);
  }

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

  #instrument-dialog {
    width: calc(100vw - 20px);
  }

  #instrument-dialog .modal-panel {
    max-height: calc(100vh - 20px);
    padding: 16px;
  }

  .group-create-form,
  .instrument-create-form-wide,
  .group-card,
  .import-grid {
    grid-template-columns: 1fr;
  }

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

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

  .import-ops-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .import-workflow-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .import-operation-row,
  .import-operation-group > summary,
  .import-impact-list article {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .import-operation-money {
    justify-items: start;
  }

  .group-card .instrument-color,
  .instrument-create-form input[type='color'] {
    width: 100%;
  }

  .switch-field {
    justify-content: space-between;
    border: 1px solid var(--line);
    border-radius: 6px;
    padding: 8px 10px;
  }

  .instrument-table-wrap {
    overflow-x: visible;
  }

  .instrument-table,
  .compact-table .instrument-table,
  .instrument-table thead,
  .instrument-table tbody,
  .instrument-table tr,
  .instrument-table td {
    display: block;
    width: 100%;
    min-width: 0;
  }

  .instrument-table thead {
    display: none;
  }

  .instrument-table tbody {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 12px;
  }

  .instrument-table tr {
    border: 1px solid var(--line);
    border-radius: 8px;
    background: var(--bg);
    padding: 10px;
  }

  .instrument-table td {
    display: grid;
    grid-template-columns: 92px minmax(0, 1fr);
    gap: 10px;
    align-items: center;
    border-bottom: 0;
    padding: 6px 0;
    white-space: normal;
  }

  .instrument-table tbody tr td {
    width: 100% !important;
    box-sizing: border-box;
  }

  .instrument-table tbody tr td > input,
  .instrument-table tbody tr td > select,
  .instrument-table tbody tr td > button {
    width: 100%;
    min-width: 0;
  }

  .instrument-table td::before {
    content: attr(data-label);
    color: var(--muted);
    font-size: 0.76rem;
    font-weight: 700;
    text-transform: uppercase;
  }

  .instrument-table td[colspan] {
    display: block;
  }

  .instrument-table td[colspan]::before {
    content: none;
  }

  .monthly-summary,
  .history-stats,
  .ledger-filters,
  .metric-grid,
  .ops-grid {
    grid-template-columns: 1fr;
  }

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

  .ytd-month-card summary,
  .ytd-group-row {
    grid-template-columns: 1fr 1fr;
  }

  .ytd-month-title,
  .ytd-group-row ul {
    grid-column: 1 / -1;
  }

  .ytd-month-card summary::after {
    grid-column: 1 / -1;
  }

  .history-event-panel {
    display: block;
    margin-top: 10px;
    white-space: pre-line;
    border: 1px solid var(--button-border);
    border-radius: 8px;
    background: var(--card);
    color: var(--text);
    font-size: 0.82rem;
    line-height: 1.45;
    padding: 10px 12px;
  }

  .total-box {
    text-align: left;
  }

  .metric-info-tooltip {
    top: calc(100% + 8px);
    left: 0;
    right: auto;
    transform: translateY(-4px);
  }

  .metric-info-button:hover + .sr-only + .metric-info-tooltip,
  .metric-label:focus-within .metric-info-tooltip {
    transform: translateY(0);
  }

  .total-box .metric-info-tooltip {
    left: 0;
    right: auto;
  }
}

@media (max-width: 620px) {
  .hero {
    padding: 18px;
  }

  .brand-banner {
    gap: 12px;
  }

  .brand-logo {
    display: none;
  }

  .ytd-summary,
  .ytd-month-card summary,
  .ytd-group-row {
    grid-template-columns: 1fr;
  }

  .ytd-month-card summary {
    gap: 10px;
  }

  .brand-lockup-logo {
    width: 52px;
    height: 52px;
    border-radius: 14px;
  }

  .brand-wordmark {
    font-size: clamp(2rem, 12vw, 3rem);
  }

  .hero-copy {
    font-size: 0.92rem;
  }

  .header-actions {
    display: flex;
    flex-wrap: nowrap;
    width: fit-content;
    max-width: calc(100vw - 24px);
    gap: 5px;
    overflow: visible;
  }

  .header-actions.is-fixed {
    display: flex;
    flex-wrap: nowrap;
    gap: 6px;
    width: calc(100vw - 16px);
    padding: 7px;
  }

  .header-actions.is-fixed .toolbar-brand {
    margin-right: 2px;
  }

  .header-actions.is-fixed .calendar-button > span:last-child {
    display: none;
  }

  .donut-tooltip.is-touch {
    left: 14px !important;
    right: 14px;
    top: auto !important;
    bottom: 14px;
    width: auto;
    max-height: 45vh;
    overflow-y: auto;
    pointer-events: auto;
  }

  .header-actions .app-version {
    display: none;
  }

  .calendar-button {
    justify-content: center;
    width: 34px;
    height: 34px;
    padding: 0;
  }

  .balance-toggle,
  .theme-toggle {
    justify-self: auto;
  }

  .balance-toggle {
    width: 34px;
    height: 34px;
  }

  .theme-toggle-track {
    width: 58px;
    height: 34px;
  }

  .toolbar-brand span {
    display: none;
  }
}

.instrument-delete-preview {
  padding: 12px 0;
  max-height: 50vh;
  overflow-y: auto;
}

.delete-preview-section {
  margin-bottom: 16px;
}

.delete-preview-section h3 {
  font-size: 0.85rem;
  margin: 0 0 8px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.delete-preview-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.delete-item {
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 0.9rem;
  line-height: 1.4;
}

.delete-item.blocked {
  background: color-mix(in srgb, #ef4444 10%, var(--bg));
  border: 1px solid color-mix(in srgb, #ef4444 30%, var(--line));
  color: #f87171;
}

.delete-item.allowed {
  background: color-mix(in srgb, #22c55e 8%, var(--bg));
  border: 1px solid color-mix(in srgb, #22c55e 25%, var(--line));
  color: var(--text);
}

.button-danger {
  background: #ef4444;
  color: #fff;
  border: none;
}

.button-danger:hover:not(:disabled) {
  background: #dc2626;
}

.button-danger:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* ÔöÇÔöÇ Import dialog refined styles (scoped to #import-dialog) ÔöÇÔöÇ */

#import-dialog .modal-panel {
  gap: 20px;
  padding: 28px;
}

.import-quickstart {
  background: linear-gradient(135deg, color-mix(in srgb, var(--accent) 6%, var(--bg)), color-mix(in srgb, var(--accent) 2%, var(--card)));
  border: 1px solid color-mix(in srgb, var(--accent) 16%, var(--line));
  border-radius: 12px;
  padding: 18px 20px;
}

.import-quickstart-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.import-quickstep {
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: auto auto;
  gap: 0 12px;
  align-items: start;
}

.import-quickstep-num {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--accent) 14%, var(--card));
  border: 1px solid color-mix(in srgb, var(--accent) 35%, var(--line));
  color: var(--accent);
  font-size: 0.88rem;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  grid-row: 1 / -1;
}

.import-quickstep strong {
  font-size: 0.86rem;
  font-weight: 750;
  line-height: 1.2;
}

.import-quickstep small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-size: 0.76rem;
  line-height: 1.35;
}

.import-quickstep .button {
  display: inline-flex;
  margin-top: 8px;
  height: 34px;
}

.button-accent {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  border: 1px solid color-mix(in srgb, var(--accent) 50%, var(--button-border));
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 10%, var(--card));
  color: var(--accent);
  cursor: pointer;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 750;
  padding: 7px 14px;
  transition: background 160ms ease, border-color 160ms ease, box-shadow 160ms ease;
}

.button-accent:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 30%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 75%, var(--button-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 15%, transparent);
}

:root.dark .button-accent:hover:not(:disabled) {
  background: color-mix(in srgb, var(--accent) 45%, var(--card));
  border-color: color-mix(in srgb, var(--accent) 85%, var(--button-border));
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 25%, transparent);
}

.import-file-zone {
  position: relative;
}

.import-file-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: -8px;
}

.import-file-actions .button {
  min-width: 150px;
}

.import-file-zone input[type="file"] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
  z-index: 1;
}

.import-file-drop {
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 6px;
  min-height: 64px;
  padding: 14px;
  border: 2px dashed var(--line);
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg) 85%, var(--card));
  color: var(--muted);
  text-align: center;
  transition: border-color 160ms ease, background 160ms ease, box-shadow 160ms ease;
}

.import-file-drop strong {
  font-size: 0.84rem;
  font-weight: 750;
  color: color-mix(in srgb, var(--text) 75%, var(--muted));
}

.import-file-drop small {
  font-size: 0.74rem;
}

.import-file-zone:hover .import-file-drop,
.import-file-zone:focus-within .import-file-drop {
  border-color: color-mix(in srgb, var(--accent) 45%, var(--line));
  background: color-mix(in srgb, var(--accent) 5%, var(--bg));
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 8%, transparent);
}

.import-file-zone.drag-over .import-file-drop {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 10%, var(--bg));
  box-shadow: 0 0 0 6px color-mix(in srgb, var(--accent) 14%, transparent);
}

.import-file-selected {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 64px;
  padding: 14px 16px;
  border: 2px solid color-mix(in srgb, #16a34a 40%, var(--line));
  border-radius: 10px;
  background: color-mix(in srgb, #16a34a 6%, var(--bg));
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 750;
}

.import-file-selected span {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.import-file-clear {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border: 1px solid var(--button-border);
  border-radius: 6px;
  background: var(--card);
  color: var(--muted);
  cursor: pointer;
  font-size: 0.85rem;
  flex-shrink: 0;
  transition: color 140ms ease, border-color 140ms ease;
}

.import-file-clear:hover {
  color: #ef4444;
  border-color: color-mix(in srgb, #ef4444 45%, var(--line));
}

/* ÔöÇÔöÇ Refined progress steps ÔöÇÔöÇ */

#import-dialog .import-progress {
  gap: 0;
  margin: 4px 0 16px;
  position: relative;
}

#import-dialog .import-progress::before {
  content: '';
  position: absolute;
  top: 18px;
  left: calc(12.5% + 12px);
  right: calc(12.5% + 12px);
  height: 2px;
  background: var(--line);
  border-radius: var(--radius-full);
  z-index: 0;
}

#import-dialog .import-progress-item {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  z-index: 1;
  min-height: auto;
  border: none;
  border-radius: 0;
  padding: 0;
  background: transparent;
}

#import-dialog .import-progress-item span {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--card);
  border: 2px solid var(--line);
  color: var(--muted);
  font-size: 0.8rem;
  font-weight: 850;
  transition: border-color 200ms ease, background 200ms ease, color 200ms ease;
}

#import-dialog .import-progress-item strong {
  font-size: 0.78rem;
  color: var(--muted);
  text-align: center;
  transition: color 200ms ease;
}

#import-dialog .import-progress-item.is-active span {
  border-color: var(--accent);
  background: color-mix(in srgb, var(--accent) 12%, var(--card));
  color: var(--accent);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--accent) 12%, transparent);
}

#import-dialog .import-progress-item.is-active strong {
  color: var(--text);
  font-weight: 800;
}

#import-dialog .import-progress-item.is-done span {
  background: #16a34a;
  border-color: #16a34a;
  color: #fff;
}

#import-dialog .import-progress-item.is-done strong {
  color: #16a34a;
}

/* ÔöÇÔöÇ Refined workflow actions ÔöÇÔöÇ */

#import-dialog .import-workflow-actions {
  justify-content: space-between;
  margin-top: 8px;
}

#import-dialog .import-workflow-actions .button {
  min-width: 110px;
  padding: 9px 16px;
  border-radius: 8px;
  font-size: 0.86rem;
  transition: transform 120ms ease, box-shadow 120ms ease;
}

#import-dialog .import-workflow-actions .button:not(:disabled):active {
  transform: scale(0.97);
}

#import-dialog .import-workflow-actions .button-primary:not(:disabled) {
  box-shadow: 0 2px 12px color-mix(in srgb, var(--text) 18%, transparent);
}

/* ÔöÇÔöÇ Refined step bodies ÔöÇÔöÇ */

#import-dialog .import-step-body {
  gap: 14px;
}

#import-dialog .import-empty-step {
  display: grid;
  gap: 6px;
  justify-items: center;
  text-align: center;
  border: 2px dashed var(--line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--bg) 85%, var(--card));
  padding: 28px 20px;
}

#import-dialog .import-empty-step strong {
  font-size: 1rem;
  font-weight: 750;
  color: color-mix(in srgb, var(--text) 80%, var(--muted));
}

#import-dialog .import-step-intro {
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-radius: 10px;
  background: color-mix(in srgb, var(--accent) 4%, var(--bg));
}

/* ÔöÇÔöÇ Refined instrument cards ÔöÇÔöÇ */

#import-dialog .import-instrument-card {
  gap: 12px;
  padding: 16px;
  border-radius: 10px;
  background: var(--card);
  transition: border-color 160ms ease, box-shadow 160ms ease;
}

#import-dialog .import-instrument-card header strong {
  display: block;
  overflow-wrap: anywhere;
}

#import-dialog .import-instrument-card:hover {
  border-color: color-mix(in srgb, var(--accent) 25%, var(--line));
}

#import-dialog .import-instrument-card.is-confirmed {
  border-color: color-mix(in srgb, #16a34a 30%, var(--line));
  box-shadow: 0 0 0 1px color-mix(in srgb, #16a34a 16%, transparent);
}

#import-dialog .import-instrument-card.is-incomplete {
  border-color: color-mix(in srgb, #ef4444 50%, var(--line));
  box-shadow: 0 0 0 1px color-mix(in srgb, #ef4444 20%, transparent);
}

/* ÔöÇÔöÇ Refined summary cards ÔöÇÔöÇ */

#import-dialog .import-summary-cards article {
  border-radius: 10px;
  background: var(--card);
  padding: 12px 14px;
  transition: border-color 140ms ease;
}

#import-dialog .import-summary-cards article span {
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.03em;
}

#import-dialog .import-summary-cards article strong {
  font-size: 1.05rem;
  font-variant-numeric: tabular-nums;
}

/* ÔöÇÔöÇ Refined confirm grid ÔöÇÔöÇ */

#import-dialog .import-confirm-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

#import-dialog .import-confirm-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 18px 20px;
  border: 1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  border-radius: 12px;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 10%, transparent), transparent 50%),
    color-mix(in srgb, var(--card) 92%, var(--bg));
}

#import-dialog .import-confirm-hero span,
#import-dialog .import-confirm-total span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  text-transform: uppercase;
}

#import-dialog .import-confirm-hero strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 1.18rem;
  font-weight: 850;
}

#import-dialog .import-confirm-hero p {
  margin: 6px 0 0;
  color: var(--muted);
  font-size: 0.88rem;
}

#import-dialog .import-confirm-total {
  min-width: 190px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line));
  border-radius: 10px;
  background: color-mix(in srgb, var(--bg) 72%, var(--card));
  text-align: right;
}

#import-dialog .import-confirm-grid .metric-card {
  border-radius: 10px;
}

#import-dialog .import-confirm-grid .metric-card span {
  font-size: 0.72rem;
  font-weight: 750;
  letter-spacing: 0.03em;
}

#import-dialog .import-confirm-grid .metric-card strong {
  font-size: 1.08rem;
}

#import-dialog .import-impact-card {
  display: grid;
  grid-template-columns: minmax(150px, 0.8fr) minmax(260px, 1.2fr);
  gap: 16px;
  align-items: center;
}

#import-dialog .import-impact-card > div:first-child {
  display: grid;
  gap: 3px;
}

#import-dialog .import-impact-shares {
  display: grid;
  grid-template-columns: auto repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: stretch;
}

#import-dialog .import-impact-shares b {
  display: grid;
  place-items: center;
  min-height: 48px;
  padding: 8px 10px;
  border-radius: 8px;
  background: color-mix(in srgb, var(--accent) 10%, var(--bg));
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 850;
  text-transform: uppercase;
}

#import-dialog .import-impact-shares span {
  display: grid;
  gap: 2px;
  min-height: 48px;
  padding: 8px 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: color-mix(in srgb, var(--bg) 80%, var(--card));
  color: var(--text);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}

#import-dialog .import-impact-shares small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 750;
  text-transform: uppercase;
}

/* ÔöÇÔöÇ Refined operation groups ÔöÇÔöÇ */

#import-dialog .import-operation-group {
  border-radius: 10px;
  transition: border-color 160ms ease;
}

#import-dialog .import-operation-group[open] {
  border-color: color-mix(in srgb, var(--accent) 30%, var(--line));
}

#import-dialog .import-operation-group > summary {
  padding: 14px 16px;
  gap: 16px;
}

#import-dialog .import-operation-group-details {
  padding: 12px;
  gap: 8px;
}

#import-dialog .import-operation-row {
  border-radius: 8px;
  padding: 12px 14px;
  transition: background 140ms ease;
}

#import-dialog .import-operation-row:hover {
  background: color-mix(in srgb, var(--accent) 3%, var(--bg));
}

/* ÔöÇÔöÇ Refined commit overlay ÔöÇÔöÇ */

#import-dialog .import-committing-card {
  gap: 16px;
  padding: 36px 48px;
  border: 1px solid color-mix(in srgb, var(--accent) 20%, var(--line));
  border-radius: 16px;
  background: linear-gradient(160deg, color-mix(in srgb, var(--accent) 4%, var(--card)), var(--card));
  box-shadow: 0 20px 48px rgba(15, 23, 42, 0.10), 0 0 0 1px color-mix(in srgb, var(--accent) 10%, transparent);
}

#import-dialog .import-committing-card img {
  width: 56px;
  height: 56px;
  border-radius: 14px;
  animation: importSpinRefined 1.3s ease-in-out infinite;
}

@keyframes importSpinRefined {
  0% { transform: scale(0.9) rotate(0deg); opacity: 0.65; }
  50% { transform: scale(1.06) rotate(180deg); opacity: 1; }
  100% { transform: scale(0.9) rotate(360deg); opacity: 0.65; }
}

/* ÔöÇÔöÇ Refined kind pill ÔöÇÔöÇ */

#import-dialog .import-kind-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-bottom: 12px;
  padding: 6px 12px;
  border: 1px solid color-mix(in srgb, var(--accent) 25%, var(--line));
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--accent) 8%, var(--bg));
  color: var(--accent);
  font-size: 0.8rem;
  font-weight: 750;
}

/* ÔöÇÔöÇ Refined warning banner ÔöÇÔöÇ */

#import-dialog .import-warning-banner {
  margin-bottom: 12px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, #f59e0b 35%, var(--line));
  border-radius: 10px;
  color: color-mix(in srgb, #d97706 80%, var(--text));
  background: color-mix(in srgb, #f59e0b 8%, transparent);
  gap: 6px;
  font-size: 0.84rem;
  font-weight: 650;
}

/* ÔöÇÔöÇ Refined suggestions ÔöÇÔöÇ */

#import-dialog .import-suggestions .button {
  font-size: 0.8rem;
  padding: 6px 12px;
  border-radius: 8px;
  transition: transform 120ms ease;
}

#import-dialog .import-suggestions .button:hover:not(:disabled) {
  transform: translateY(-1px);
}

/* ÔöÇÔöÇ Mobile adjustments for new import layout ÔöÇÔöÇ */

@media (max-width: 980px) {
  .import-quickstart-steps {
    grid-template-columns: 1fr;
  }

  #import-dialog .import-progress::before {
    display: none;
  }

  #import-dialog .import-confirm-hero,
  #import-dialog .import-impact-card {
    grid-template-columns: 1fr;
  }

  #import-dialog .import-confirm-total {
    min-width: 0;
    text-align: left;
  }

  #import-dialog .import-confirm-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
