@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,100..1000;1,9..40,100..1000&family=Playfair+Display:ital,wght@0,400..900;1,400..900&display=swap');

/* Design tokens — port from landing/src/index.css */
:root {
  --primary: hsl(220 60% 20%);
  --primary-foreground: hsl(45 30% 96%);
  --background: hsl(45 30% 98%);
  --foreground: hsl(220 40% 15%);
  --card: hsl(0 0% 100%);
  --card-foreground: hsl(220 40% 15%);
  --secondary: hsl(220 20% 94%);
  --secondary-foreground: hsl(220 40% 25%);
  --muted: hsl(220 15% 92%);
  --muted-foreground: hsl(220 15% 45%);
  --accent: hsl(45 70% 45%);
  --accent-foreground: hsl(220 60% 15%);
  --success: hsl(160 60% 40%);
  --warning: hsl(38 92% 50%);
  --destructive: hsl(0 72% 51%);
  --border: hsl(220 20% 88%);
  --ring: hsl(45 70% 45%);
  --radius: 0.75rem;
  --gradient-hero: linear-gradient(135deg, hsl(220 60% 20%) 0%, hsl(220 50% 30%) 100%);
  --shadow-md: 0 4px 6px -1px hsl(220 60% 20% / 0.1), 0 2px 4px -1px hsl(220 60% 20% / 0.06);
  --shadow-lg: 0 10px 15px -3px hsl(220 60% 20% / 0.1), 0 4px 6px -2px hsl(220 60% 20% / 0.05);
  --shadow-xl: 0 20px 25px -5px hsl(220 60% 20% / 0.1), 0 10px 10px -5px hsl(220 60% 20% / 0.04);
  --shadow-gold: 0 4px 14px 0 hsl(45 70% 45% / 0.3);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'DM Sans', system-ui, sans-serif;
  background: var(--background);
  color: var(--foreground);
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}

h1, h2, h3, h4, h5, h6 {
  font-family: 'Playfair Display', Georgia, serif;
  letter-spacing: -0.02em;
  line-height: 1.2;
}

a { color: inherit; text-decoration: none; }

img { max-width: 100%; height: auto; }

.container {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 2rem;
}

.page { min-height: 100vh; display: flex; flex-direction: column; }
.page-main { flex: 1; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid hsl(220 20% 88% / 0.5);
  background: hsl(0 0% 100% / 0.95);
  backdrop-filter: blur(8px);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 4rem;
}

.site-logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-width: 0;
}

.site-logo img { width: 2.25rem; height: 2.25rem; flex-shrink: 0; }
.site-logo img.sm { width: 2rem; height: 2rem; }

.site-logo__name {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.25;
}

@media (min-width: 640px) { .site-logo__name { display: inline; } }
@media (max-width: 639px) { .site-logo__name { display: none; } }
@media (min-width: 1024px) { .site-logo__name { font-size: 1rem; } }

.nav-desktop { display: none; align-items: center; gap: 0.25rem; }
@media (min-width: 768px) { .nav-desktop { display: flex; } }

.menu-toggle { display: flex; }
@media (min-width: 768px) { .menu-toggle { display: none; } }

.nav-mobile {
  overflow: hidden;
  max-height: 0;
  transition: max-height 0.3s ease;
  border-top: 1px solid hsl(220 20% 88% / 0.5);
  background: var(--card);
}

.nav-mobile.open { max-height: 10rem; }
.nav-mobile__inner { display: flex; flex-direction: column; gap: 0.5rem; padding: 1rem 0; }

/* Buttons */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  border-radius: var(--radius);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
  text-decoration: none;
  white-space: nowrap;
}

.btn:disabled { opacity: 0.5; pointer-events: none; }

.btn-sm { padding: 0.5rem 0.75rem; font-size: 0.875rem; border-radius: calc(var(--radius) - 2px); }
.btn-lg { padding: 0.75rem 2rem; font-size: 1rem; }
.btn-xl { padding: 0.875rem 2.5rem; font-size: 1.125rem; border-radius: calc(var(--radius) + 4px); }
.btn-block { width: 100%; }

.btn-default { background: var(--primary); color: var(--primary-foreground); box-shadow: var(--shadow-md); }
.btn-default:hover { opacity: 0.9; box-shadow: var(--shadow-lg); }

.btn-gold, .btn-hero {
  background: var(--accent);
  color: var(--accent-foreground);
  box-shadow: var(--shadow-md);
}
.btn-gold:hover, .btn-hero:hover { opacity: 0.9; box-shadow: var(--shadow-lg); }
.btn-hero { box-shadow: var(--shadow-lg); font-size: 1rem; }

.btn-secondary { background: var(--secondary); color: var(--secondary-foreground); }
.btn-secondary:hover { opacity: 0.8; }

.btn-ghost {
  background: transparent;
  color: var(--foreground);
}
.btn-ghost:hover { background: hsl(45 70% 45% / 0.1); }

.btn-outline {
  background: transparent;
  color: var(--primary);
  border: 2px solid var(--primary);
}
.btn-outline:hover { background: var(--primary); color: var(--primary-foreground); }

.btn-option {
  width: 100%;
  justify-content: flex-start;
  text-align: left;
  height: auto;
  padding: 1rem;
  background: transparent;
  color: var(--foreground);
  border: 2px solid var(--border);
}

.btn-option:hover { border-color: var(--primary); }
.btn-option.selected {
  background: var(--primary);
  color: var(--primary-foreground);
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--accent);
}

.btn-icon {
  width: 2.5rem;
  height: 2.5rem;
  padding: 0;
}

/* Cards */
.card {
  border-radius: calc(var(--radius) + 4px);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--card-foreground);
  transition: all 0.3s ease;
}

.card-elevated { border: none; box-shadow: var(--shadow-lg); }
.card-elevated:hover { box-shadow: var(--shadow-xl); }

.card-feature {
  border: none;
  box-shadow: var(--shadow-lg);
  max-width: 36rem;
  margin: 0 auto;
}
.card-feature:hover { box-shadow: var(--shadow-xl); transform: translateY(-4px); }

.card-header { padding: 1.5rem 1.5rem 0; }
.card-content { padding: 1.5rem; }
.card-content.pt-0 { padding-top: 0; }

.card-title {
  font-family: 'Playfair Display', Georgia, serif;
  font-size: 1.5rem;
  font-weight: 600;
  margin: 0 0 0.25rem;
}

.card-desc { font-size: 0.875rem; color: var(--muted-foreground); margin: 0; }

/* Hero */
.hero {
  background: var(--gradient-hero);
  padding: 4rem 0;
  color: var(--primary-foreground);
}

@media (min-width: 768px) { .hero { padding: 6rem 0; } }
@media (min-width: 1024px) { .hero { padding: 8rem 0; } }

.hero__inner { max-width: 48rem; margin: 0 auto; text-align: center; }

.hero h1 {
  font-size: 2.25rem;
  font-weight: 700;
  margin: 0 0 1.5rem;
  text-wrap: balance;
}

@media (min-width: 768px) { .hero h1 { font-size: 3rem; } }
@media (min-width: 1024px) { .hero h1 { font-size: 3.75rem; } }

.hero__lead {
  font-size: 1.125rem;
  opacity: 0.9;
  margin: 0 0 1rem;
  line-height: 1.7;
}

@media (min-width: 768px) { .hero__lead { font-size: 1.25rem; } }

.hero__highlight {
  max-width: 42rem;
  margin: 0 auto 2rem;
  padding: 1.25rem 1.5rem;
  border-radius: calc(var(--radius) + 4px);
  border: 2px solid var(--accent);
  background: hsl(45 30% 96% / 0.1);
  box-shadow: var(--shadow-gold);
  backdrop-filter: blur(4px);
}

.hero__highlight-label {
  font-size: 0.625rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.6;
  margin: 0 0 0.5rem;
}

@media (min-width: 768px) { .hero__highlight-label { font-size: 0.75rem; } }

.hero__highlight-text {
  font-size: 1.125rem;
  font-weight: 700;
  margin: 0;
  line-height: 1.4;
}

@media (min-width: 768px) { .hero__highlight-text { font-size: 1.25rem; } }

.hero__highlight-text .accent { color: var(--accent); font-size: 1.5rem; font-family: 'Playfair Display', Georgia, serif; }
@media (min-width: 768px) { .hero__highlight-text .accent { font-size: 1.875rem; } }

.hero__actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  align-items: center;
}

@media (min-width: 640px) {
  .hero__actions { flex-direction: row; }
  .hero__actions .btn { width: auto; }
}

/* Sections */
.section { padding: 4rem 0; }
@media (min-width: 768px) { .section { padding: 6rem 0; } }

.section-muted { background: hsl(220 15% 92% / 0.3); }

.section-header { text-align: center; margin-bottom: 3rem; }

.section-header h2 {
  font-size: 1.875rem;
  font-weight: 700;
  margin: 0 0 1rem;
}

@media (min-width: 768px) { .section-header h2 { font-size: 2.25rem; } }

.section-header p {
  font-size: 1.125rem;
  color: var(--muted-foreground);
  max-width: 42rem;
  margin: 0 auto;
}

/* Benefits grid */
.benefits-grid {
  display: grid;
  gap: 1.5rem;
}

@media (min-width: 640px) { .benefits-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .benefits-grid { grid-template-columns: repeat(4, 1fr); } }

.benefit-card {
  text-align: center;
  padding: 1.5rem;
  border-radius: calc(var(--radius) + 4px);
  border: 1px solid var(--border);
  background: var(--card);
  transition: all 0.3s ease;
}

.benefit-card:hover { box-shadow: var(--shadow-lg); }

.benefit-card.highlighted {
  border: 2px solid var(--accent);
  background: hsl(45 70% 45% / 0.1);
  box-shadow: var(--shadow-gold);
}

.benefit-card__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: calc(var(--radius) + 4px);
  margin: 0 auto 1rem;
  background: hsl(220 60% 20% / 0.1);
  color: var(--primary);
}

.benefit-card.highlighted .benefit-card__icon {
  background: hsl(45 70% 45% / 0.2);
  color: var(--accent);
}

.benefit-card h3 { font-size: 1rem; font-weight: 600; margin: 0 0 0.5rem; font-family: 'DM Sans', system-ui, sans-serif; }
.benefit-card.highlighted h3 { color: var(--accent-foreground); }

.benefit-card p { font-size: 0.875rem; color: var(--muted-foreground); margin: 0; }
.benefit-card.highlighted p { color: hsl(220 40% 15% / 0.8); }

/* Feature card icon */
.feature-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: calc(var(--radius) + 4px);
  background: hsl(45 70% 45% / 0.1);
  color: var(--accent);
  margin-bottom: 0.5rem;
}

/* CTA card */
.cta-card {
  max-width: 48rem;
  margin: 0 auto;
  text-align: center;
  padding: 2rem;
}

@media (min-width: 768px) { .cta-card { padding: 3rem; } }

.cta-card h2 { font-size: 1.5rem; margin: 0 0 1rem; }
@media (min-width: 768px) { .cta-card h2 { font-size: 1.875rem; } }

.cta-card p { color: var(--muted-foreground); margin: 0 auto 1.5rem; max-width: 36rem; }

.cta-card__actions {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  justify-content: center;
  margin-bottom: 2rem;
}

@media (min-width: 640px) {
  .cta-card__actions { flex-direction: row; }
  .cta-card__actions .btn { width: auto; }
}

/* Disclaimer */
.disclaimer {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem;
  border-radius: var(--radius);
  border: 1px solid hsl(38 92% 50% / 0.3);
  background: hsl(38 92% 50% / 0.05);
  font-size: 0.875rem;
}

.disclaimer svg { flex-shrink: 0; color: var(--warning); margin-top: 0.125rem; }
.disclaimer p { margin: 0; color: var(--muted-foreground); line-height: 1.6; }
.disclaimer strong { color: var(--warning); }

/* Footer */
.site-footer {
  border-top: 1px solid var(--border);
  background: hsl(220 15% 92% / 0.3);
  padding: 2rem 0;
}

.footer-grid {
  display: grid;
  gap: 2rem;
}

@media (min-width: 768px) { .footer-grid { grid-template-columns: repeat(4, 1fr); } }

.footer-grid h4 { font-family: 'DM Sans', system-ui, sans-serif; font-weight: 600; margin: 0 0 0.75rem; }

.footer-links { display: flex; flex-direction: column; gap: 0.5rem; }

.footer-links a {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  transition: color 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
}

.footer-links a:hover { color: var(--foreground); }

.footer-desc { font-size: 0.875rem; color: var(--muted-foreground); line-height: 1.6; margin: 0; }

.footer-bottom {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--border);
  text-align: center;
}

.footer-bottom p { font-size: 0.75rem; color: var(--muted-foreground); margin: 0; }

/* Checklist */
.page-narrow { max-width: 42rem; margin: 0 auto; }
.page-content { padding: 2rem 0; }
@media (min-width: 768px) { .page-content { padding: 3rem 0; } }

.page-intro { text-align: center; margin-bottom: 1.5rem; }
.page-intro h1 { font-size: 1.875rem; margin: 0 0 0.75rem; }
@media (min-width: 768px) { .page-intro h1 { font-size: 2.25rem; } }
.page-intro p { color: var(--muted-foreground); margin: 0; }

.checklist-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.checklist-header__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: var(--radius);
  background: hsl(45 70% 45% / 0.1);
  color: var(--accent);
  flex-shrink: 0;
}

.progress {
  height: 0.5rem;
  background: var(--muted);
  border-radius: 999px;
  overflow: hidden;
  margin-top: 1rem;
}

.progress__bar {
  height: 100%;
  background: var(--accent);
  border-radius: 999px;
  transition: width 0.3s ease;
}

.question-area { min-height: 200px; }
.question-area h3 { font-size: 1.25rem; margin: 0 0 0.75rem; }

.question-tip {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  padding: 0.75rem;
  border-radius: var(--radius);
  background: hsl(220 15% 92% / 0.5);
  margin: 0 0 1.5rem;
}

.options-grid { display: grid; gap: 0.75rem; }

.option-radio {
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  border: 2px solid currentColor;
  margin-right: 0.75rem;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.btn-option.selected .option-radio {
  border-color: var(--primary-foreground);
  background: var(--primary-foreground);
}

.btn-option.selected .option-radio::after {
  content: '';
  width: 0.625rem;
  height: 0.625rem;
  border-radius: 50%;
  background: var(--primary);
}

.checklist-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 1rem;
  margin-top: 1.5rem;
  border-top: 1px solid var(--border);
}

.checklist-footer span { font-size: 0.875rem; color: var(--muted-foreground); }

/* Result */
.result-card { border-width: 2px; }
.result-card.eligible { background: hsl(160 60% 40% / 0.1); border-color: hsl(160 60% 40% / 0.3); }
.result-card.possible { background: hsl(38 92% 50% / 0.1); border-color: hsl(38 92% 50% / 0.3); }
.result-card.not_eligible { background: var(--muted); border-color: var(--muted); }

.result-icon { width: 4rem; height: 4rem; margin: 0 auto 1rem; }
.result-icon.success { color: var(--success); }
.result-icon.warning { color: var(--warning); }
.result-icon.muted { color: var(--muted-foreground); }

.result-title { text-align: center; font-size: 1.5rem; margin: 0 0 0.5rem; }
.result-desc { text-align: center; color: var(--muted-foreground); margin: 0 0 1.5rem; }

.score-box {
  padding: 1rem;
  border-radius: var(--radius);
  background: var(--card);
  border: 1px solid var(--border);
  margin-bottom: 1.5rem;
}

.score-box__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 0.5rem;
  font-size: 0.875rem;
}

.score-box__row span:first-child { color: var(--muted-foreground); }
.score-box__row span:last-child { font-weight: 600; }

.result-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1.5rem;
}

@media (min-width: 640px) {
  .result-actions { flex-direction: row; }
  .result-actions .btn:first-child { flex: 1; }
}

.info-box {
  margin-top: 2rem;
  padding: 1.5rem;
  border-radius: calc(var(--radius) + 4px);
  border: 1px solid var(--border);
  background: var(--card);
}

.info-box h3 { font-size: 1.125rem; margin: 0 0 0.75rem; }
.info-box p { font-size: 0.875rem; color: var(--muted-foreground); margin: 0; line-height: 1.7; }

/* Forms */
.form-group { margin-bottom: 1rem; }
.form-group label { display: block; font-size: 0.875rem; font-weight: 500; margin-bottom: 0.375rem; }

.form-input {
  width: 100%;
  padding: 0.625rem 0.875rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-family: inherit;
  font-size: 1rem;
  background: var(--card);
  color: var(--foreground);
}

.form-input:focus {
  outline: 2px solid var(--ring);
  outline-offset: 2px;
}

.form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}

.form-check input { margin-top: 0.25rem; flex-shrink: 0; }
.form-check label { font-size: 0.875rem; line-height: 1.5; cursor: pointer; }
.form-check a { color: var(--accent); text-decoration: underline; }

.btn--blocked {
  opacity: 0.5;
  cursor: not-allowed;
}

.landing-modal {
  border: none;
  padding: 0;
  margin: auto;
  max-width: min(28rem, calc(100vw - 2rem));
  width: 100%;
  background: transparent;
}

.landing-modal::backdrop {
  background: hsl(220 45% 12% / 0.55);
  backdrop-filter: blur(2px);
}

.landing-modal__panel {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

.landing-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--border);
}

.landing-modal__title {
  margin: 0;
  font-size: 1.0625rem;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 600;
}

.landing-modal__desc {
  margin: 0.375rem 0 0;
  font-size: 0.875rem;
  color: var(--muted-foreground);
  line-height: 1.5;
}

.landing-modal__desc a {
  color: var(--accent);
  text-decoration: underline;
}

.landing-modal__close {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--secondary);
  color: var(--muted-foreground);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.landing-modal__close:hover {
  background: hsl(220 20% 90%);
  color: var(--foreground);
}

.landing-modal__body {
  padding: 1.25rem;
}

.landing-modal__body p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted-foreground);
  line-height: 1.6;
}

.landing-modal__actions {
  display: flex;
  justify-content: flex-end;
  gap: 0.75rem;
  padding: 0 1.25rem 1.25rem;
}

.form-error {
  padding: 0.75rem 1rem;
  border-radius: var(--radius);
  background: hsl(0 72% 51% / 0.1);
  border: 1px solid hsl(0 72% 51% / 0.3);
  color: var(--destructive);
  font-size: 0.875rem;
  margin-bottom: 1rem;
}

.form-success {
  text-align: center;
  padding: 1.5rem;
}

.form-success svg { width: 3rem; height: 3rem; color: var(--success); margin: 0 auto 1rem; display: block; }

.hidden { display: none !important; }

/* Legal pages */
.legal-card { max-width: 48rem; margin: 0 auto; }
.legal-meta { font-size: 0.875rem; color: var(--muted-foreground); margin: 0; }

.legal-content h3 {
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 1rem;
  font-weight: 600;
  color: var(--foreground);
  margin: 1.5rem 0 0.75rem;
}

.legal-content p { font-size: 0.875rem; color: var(--muted-foreground); margin: 0 0 1rem; }
.legal-content ul { font-size: 0.875rem; color: var(--muted-foreground); padding-left: 1.5rem; margin: 0 0 1rem; }
.legal-content li { margin-bottom: 0.25rem; }

/* Icons inline */
.icon { width: 1rem; height: 1rem; flex-shrink: 0; }
.icon-md { width: 1.25rem; height: 1.25rem; }
.icon-lg { width: 1.5rem; height: 1.5rem; }

/* Animations */
.animate-fade-in { animation: fadeIn 0.5s ease-out forwards; }
.animate-slide-up { animation: slideUp 0.6s ease-out forwards; }

@keyframes fadeIn { from { opacity: 0; } to { opacity: 1; } }
@keyframes slideUp {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Coming soon */
.coming-soon { min-height: 100vh; display: flex; align-items: center; }

.coming-soon__inner {
  max-width: 40rem;
  margin: 0 auto;
  text-align: center;
  color: var(--primary-foreground);
}

.coming-soon__logo {
  width: 4.5rem;
  height: 4.5rem;
  margin: 0 auto 1.5rem;
  display: block;
}

.coming-soon__eyebrow {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  opacity: 0.7;
  margin: 0 0 1rem;
}

.coming-soon h1 {
  font-size: 2.25rem;
  margin: 0 0 1rem;
}

@media (min-width: 768px) {
  .coming-soon h1 { font-size: 3rem; }
}

.coming-soon__domain {
  margin: 2rem 0 0;
  font-size: 0.875rem;
  opacity: 0.65;
  letter-spacing: 0.04em;
}

/* Admin auth + dashboard */
.admin-auth {
  min-height: 100vh;
  display: flex;
  align-items: center;
}

.admin-auth__card {
  max-width: 28rem;
  margin: 0 auto;
  width: 100%;
}

.admin-header .admin-user {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  margin-right: 0.75rem;
}

.admin-dashboard h1 {
  font-size: 2rem;
  margin: 0 0 0.5rem;
}

/* Dashboard métricas */
.dashboard-intro {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.5rem;
  text-align: left;
}

.dashboard-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.dashboard-summary__item {
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.375rem 0.75rem;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--card);
}

.dashboard-summary__item--pending { color: var(--muted-foreground); }
.dashboard-summary__item--on { color: hsl(142 60% 35%); border-color: hsl(142 40% 75%); background: hsl(142 50% 95%); }
.dashboard-summary__item--off { color: hsl(0 60% 45%); border-color: hsl(0 40% 85%); background: hsl(0 50% 97%); }

.dashboard-quick-links {
  margin-bottom: 2rem;
}

.metrics-section {
  margin-bottom: 2.5rem;
}

.metrics-section__header {
  margin-bottom: 1rem;
}

.metrics-section__header h2 {
  font-size: 1.25rem;
  margin: 0 0 0.375rem;
  font-family: 'DM Sans', system-ui, sans-serif;
}

.metrics-section__hint {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  margin: 0;
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 1rem;
}

.metric-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1rem 1.125rem;
  text-align: left;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

.metric-card--pending { border-left: 3px solid var(--muted-foreground); }
.metric-card--on_track { border-left: 3px solid hsl(142 55% 40%); }
.metric-card--off_track { border-left: 3px solid hsl(0 55% 50%); }

.metric-card__top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.metric-card__phase {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted-foreground);
  background: hsl(220 15% 94%);
  padding: 0.2rem 0.5rem;
  border-radius: 4px;
}

.metric-card__status {
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
}

.metric-card__status--pending { background: hsl(220 15% 94%); color: var(--muted-foreground); }
.metric-card__status--on_track { background: hsl(142 50% 92%); color: hsl(142 55% 30%); }
.metric-card__status--off_track { background: hsl(0 50% 95%); color: hsl(0 55% 40%); }

.metric-card__label {
  font-size: 0.9375rem;
  font-weight: 600;
  margin: 0;
  font-family: 'DM Sans', system-ui, sans-serif;
  line-height: 1.3;
}

.metric-card__values {
  display: flex;
  gap: 1.25rem;
  flex-wrap: wrap;
}

.metric-card__value-block {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.metric-card__value-label {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted-foreground);
}

.metric-card__value {
  font-size: 1.375rem;
  font-weight: 700;
  font-family: 'Instrument Serif', Georgia, serif;
  color: var(--foreground);
}

.metric-card__target {
  font-size: 1rem;
  font-weight: 600;
  color: var(--accent-foreground);
}

.metric-card__formula {
  font-size: 0.8125rem;
  color: var(--muted-foreground);
  margin: 0;
  font-style: italic;
}

.metric-card__meta {
  font-size: 0.75rem;
  color: var(--muted-foreground);
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}

.metric-card__source {
  opacity: 0.85;
}

.funnel-dashboard {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  max-width: 32rem;
}

.funnel-dashboard__arrow {
  text-align: center;
  color: var(--muted-foreground);
  font-size: 0.875rem;
  line-height: 1;
  padding: 0.125rem 0;
}

.metric-card--funnel .metric-card__value {
  font-size: 1.125rem;
}

.dashboard-footnote {
  margin-top: 2rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.dashboard-footnote code {
  font-size: 0.75rem;
}

.dev-login-quick {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--border);
}

.dev-login-quick__heading {
  font-size: 0.75rem;
  color: var(--muted-foreground);
  margin: 0 0 0.75rem;
  text-align: center;
}

.dev-login-quick__list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}

.dev-login-fill {
  border: 1px dashed var(--accent);
  background: hsl(45 70% 45% / 0.08);
  color: var(--accent-foreground);
  font-family: 'DM Sans', system-ui, sans-serif;
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.5rem 0.875rem;
  border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.2s ease;
}

.dev-login-fill:hover {
  background: hsl(45 70% 45% / 0.16);
}

/* Admin shell — tokens e hierarquia visual */
.admin-body {
  --admin-bg: hsl(220 22% 92%);
  --admin-surface: hsl(0 0% 100%);
  --admin-surface-muted: hsl(220 24% 96%);
  --admin-surface-data: hsl(220 26% 95%);
  --admin-border: hsl(220 18% 84%);
  --admin-border-strong: hsl(220 22% 76%);
  --admin-sidebar-bg: hsl(220 55% 14%);
  --admin-sidebar-border: hsl(220 45% 20%);
  --admin-sidebar-text: hsl(45 25% 92%);
  --admin-sidebar-muted: hsl(220 15% 65%);
  background: var(--admin-bg);
  height: 100vh;
  overflow: hidden;
}

.admin-shell {
  display: flex;
  height: 100vh;
  min-height: 100vh;
  overflow: hidden;
}

.admin-sidebar {
  width: 15rem;
  flex-shrink: 0;
  height: 100vh;
  overflow-y: auto;
  background: var(--admin-sidebar-bg);
  border-right: 1px solid var(--admin-sidebar-border);
  padding: 1.5rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}

.admin-sidebar__brand {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0 0.5rem;
  font-weight: 600;
  font-size: 0.9375rem;
  color: var(--admin-sidebar-text);
}

.admin-sidebar__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-shrink: 0;
  gap: 0.75rem;
}

.admin-sidebar__toggle {
  display: none;
}

.admin-sidebar__brand img {
  width: 1.75rem;
  height: 1.75rem;
}

.admin-sidebar__nav {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  flex: 1;
}

@media (min-width: 769px) {
  .admin-sidebar__nav[hidden] {
    display: flex !important;
  }
}

.admin-sidebar__link {
  display: block;
  padding: 0.625rem 0.75rem;
  border-radius: var(--radius);
  color: var(--admin-sidebar-muted);
  text-decoration: none;
  font-size: 0.9375rem;
  transition: background 0.15s ease, color 0.15s ease;
}

.admin-sidebar__link:hover {
  background: hsl(220 45% 22%);
  color: var(--admin-sidebar-text);
}

.admin-sidebar__link.is-active {
  background: hsl(45 70% 45% / 0.18);
  color: hsl(45 40% 96%);
  font-weight: 600;
}

.admin-sidebar__version {
  margin-top: auto;
  padding: 1rem 0.75rem 0;
  border-top: 1px solid hsl(220 45% 22%);
}

.admin-sidebar__version-link {
  display: block;
  font-size: 0.8125rem;
  color: var(--admin-sidebar-muted);
  text-decoration: none;
  line-height: 1.4;
}

.admin-sidebar__version-link:hover {
  color: var(--admin-sidebar-text);
}

.admin-sidebar__version-number {
  color: hsl(45 40% 88%);
  font-weight: 600;
}

.admin-main {
  flex: 1;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  font-family: 'Inter', 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 1rem;
  line-height: 1.65;
  color: hsl(220 35% 12%);
  font-variant-numeric: tabular-nums;
  --admin-text-muted: hsl(220 18% 32%);
}

/* Tipografia legível — só conteúdo (sidebar inalterada) */
.admin-main h1,
.admin-main h2,
.admin-main h3,
.admin-main h4,
.admin-main h5,
.admin-main h6 {
  font-family: inherit;
  letter-spacing: -0.015em;
  line-height: 1.35;
  color: hsl(220 40% 10%);
  font-weight: 700;
}

.admin-main .admin-page h1,
.admin-main .admin-dashboard h1 {
  font-size: 1.625rem;
}

.admin-main .admin-page__desc,
.admin-main .form-hint,
.admin-main .admin-field-static--muted,
.admin-main .admin-table__muted,
.admin-main .admin-modal__desc,
.admin-main .dashboard-footnote,
.admin-main .metrics-section__hint,
.admin-main .metric-card__formula,
.admin-main .metric-card__meta,
.admin-main .dash-v2-metric__target,
.admin-main .dash-v2-metric__pending,
.admin-main .dash-v2-metric__formula,
.admin-main .dash-v2-metric__meta,
.admin-main .dash-v2-metric__source,
.admin-main .dash-v2__welcome,
.admin-main .dash-v2__health-hint,
.admin-main .dash-v2-stat__label,
.admin-main .crm-section-desc {
  color: var(--admin-text-muted);
}

.admin-main .admin-page__desc {
  font-size: 1rem;
  line-height: 1.55;
}

.admin-main .admin-card__title,
.admin-main .admin-modal__title,
.admin-main .metrics-section__header h2,
.admin-main .crm-subtitle {
  font-family: inherit;
  font-size: 1.125rem;
}

.admin-main .admin-table {
  font-size: 1rem;
}

.admin-main .admin-table th {
  font-size: 0.8125rem;
  letter-spacing: 0.025em;
  color: hsl(220 22% 28%);
}

.admin-main .admin-table__muted {
  font-size: 0.9375rem;
}

.admin-main .admin-field-static,
.admin-main .crm-dl dd {
  font-size: 1rem;
}

.admin-main .crm-dl dt {
  font-size: 0.75rem;
  color: var(--admin-text-muted);
}

.admin-main .admin-alert,
.admin-main .form-input,
.admin-main .admin-filters__field .form-input,
.admin-main .crm-textarea {
  font-size: 1rem;
}

.admin-main .admin-filters__field label {
  font-size: 0.75rem;
  color: var(--admin-text-muted);
}

.admin-main .metric-card__label,
.admin-main .dash-v2-metric__label {
  font-family: inherit;
  font-size: 1rem;
}

.admin-main .metric-card__value,
.admin-main .metric-card--funnel .metric-card__value,
.admin-main .dash-v2-metric__value,
.admin-main .dash-v2-metric--featured .dash-v2-metric__value,
.admin-main .dash-v2__title,
.admin-main .dash-v2-stat__value {
  font-family: inherit;
  letter-spacing: -0.02em;
}

.admin-main .metric-card__value {
  font-size: 1.5rem;
}

.admin-main .dash-v2-metric__value {
  font-size: 1.625rem;
}

.admin-main .dash-v2-metric--featured .dash-v2-metric__value {
  font-size: 1.875rem;
}

.admin-main .dash-v2__title {
  font-size: 1.75rem;
}

.admin-main .dash-v2-stat__value {
  font-size: 1.625rem;
}

.admin-main .metric-card__value-label,
.admin-main .metric-card__phase,
.admin-main .metric-card__status,
.admin-main .dash-v2-metric__phase,
.admin-main .dash-v2-metric__status,
.admin-main .dash-v2-metric__progress-label,
.admin-main .crm-badge {
  font-size: 0.8125rem;
}

.admin-main .admin-pagination__summary,
.admin-main .admin-pagination__link,
.admin-main .dash-v2__nav-link,
.admin-main .btn-sm {
  font-size: 0.9375rem;
}

.admin-main .admin-topbar__title {
  font-size: 1.0625rem;
}

.admin-main .admin-card--form .form-group label,
.admin-main .admin-filters .form-group label {
  font-size: 0.9375rem;
  color: hsl(220 25% 22%);
}

.admin-topbar {
  border-bottom: 1px solid var(--admin-border);
  background: var(--admin-surface);
  box-shadow: 0 1px 3px hsl(220 40% 15% / 0.06);
}

.admin-topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.5rem;
}

.admin-topbar__title {
  font-weight: 600;
  font-size: 1rem;
  color: var(--foreground);
}

.admin-topbar__actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.admin-user {
  font-size: 0.875rem;
  color: var(--muted-foreground);
}

.admin-content {
  flex: 1;
  padding: 1.5rem;
}

.admin-page__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.admin-page__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.admin-page h1 {
  font-size: 1.75rem;
  margin: 0 0 0.375rem;
}

.admin-page__desc {
  margin: 0;
  color: var(--muted-foreground);
  font-size: 0.9375rem;
}

/* Cards — base + variantes por função */
.admin-card {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  padding: 1.25rem;
  margin-bottom: 1rem;
}

.admin-card__header {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 1rem;
}

.admin-card__title {
  font-size: 1.0625rem;
  margin: 0;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 600;
}

.admin-card__tag {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  white-space: nowrap;
}

.admin-card__tag--readonly {
  background: hsl(220 20% 90%);
  color: hsl(220 20% 38%);
}

.admin-card__tag--editable {
  background: hsl(45 70% 92%);
  color: hsl(35 60% 28%);
  border: 1px solid hsl(45 60% 78%);
}

.admin-card__tag--list {
  background: hsl(210 40% 92%);
  color: hsl(210 45% 32%);
}

.admin-card__tag--filter {
  background: hsl(220 15% 90%);
  color: hsl(220 15% 40%);
}

.admin-card--data {
  background: var(--admin-surface-data);
  border-color: var(--admin-border);
  box-shadow: inset 0 1px 0 hsl(0 0% 100% / 0.6);
}

.admin-card--form {
  background: var(--admin-surface);
  border-color: var(--admin-border-strong);
  border-left: 3px solid var(--accent);
  box-shadow: var(--shadow-md);
}

.admin-card--form-narrow {
  max-width: 32rem;
}

.admin-card--profile-account .form-input[readonly] {
  background: hsl(220 18% 96%);
  cursor: default;
  overflow-wrap: anywhere;
}

.admin-card--table {
  padding: 0;
  overflow: hidden;
  background: var(--admin-surface);
  border-color: var(--admin-border-strong);
  box-shadow: var(--shadow-md);
}

.admin-card--table > .admin-card__header {
  padding: 1rem 1.25rem 0;
  margin-bottom: 0.75rem;
}

.admin-form-card {
  margin-bottom: 1rem;
}

.admin-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--admin-border);
}

.admin-card--form .admin-form-actions {
  border-top-color: hsl(45 70% 45% / 0.2);
}

.admin-table-wrap {
  overflow-x: auto;
}

.admin-table--finance-monthly th:not(.admin-table__sticky-col),
.admin-table--finance-monthly td {
  text-align: left;
  white-space: nowrap;
}

.admin-table--finance-monthly .admin-table__sticky-col {
  position: sticky;
  left: 0;
  z-index: 1;
  text-align: left;
  min-width: 11rem;
  background: hsl(220 24% 93%);
  box-shadow: 1px 0 0 var(--admin-border);
}

.admin-table--finance-monthly tbody .admin-table__sticky-col {
  background: hsl(0 0% 100%);
}

.admin-table--finance-monthly tbody tr:nth-child(even) .admin-table__sticky-col {
  background: hsl(220 22% 98%);
}

.admin-table--finance-monthly .admin-table__total-col {
  font-weight: 600;
  background: hsl(220 24% 96%);
}

.admin-table--finance-monthly .admin-table__row--subtotal td,
.admin-table--finance-monthly .admin-table__row--subtotal .admin-table__sticky-col {
  font-weight: 600;
}

.admin-table--finance-monthly .admin-table__row--net td,
.admin-table--finance-monthly .admin-table__row--net .admin-table__sticky-col {
  font-weight: 700;
  border-top: 2px solid var(--admin-border-strong);
}

.admin-table--finance-monthly .admin-table__value--positive {
  color: hsl(152 45% 28%);
}

.admin-table--finance-monthly .admin-table__value--negative {
  color: hsl(0 55% 38%);
}

.admin-table--finance-monthly .admin-table__row--revenue td,
.admin-table--finance-monthly .admin-table__row--revenue .admin-table__sticky-col {
  color: hsl(152 45% 28%);
  background: hsl(152 42% 95%);
}

.admin-table--finance-monthly .admin-table__row--revenue .admin-table__sticky-col {
  background: hsl(152 38% 92%);
}

.admin-table--finance-monthly .admin-table__row--expense td,
.admin-table--finance-monthly .admin-table__row--expense .admin-table__sticky-col {
  color: hsl(0 55% 38%);
  background: hsl(0 60% 97%);
}

.admin-table--finance-monthly .admin-table__row--expense .admin-table__sticky-col {
  background: hsl(0 55% 94%);
}

.admin-table--finance-monthly .admin-table__row--subtotal.admin-table__row--expense td,
.admin-table--finance-monthly .admin-table__row--subtotal.admin-table__row--expense .admin-table__sticky-col {
  font-weight: 600;
  background: hsl(0 50% 93%);
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9375rem;
}

.admin-table th,
.admin-table td {
  padding: 0.875rem 1rem;
  text-align: left;
  border-bottom: 1px solid var(--admin-border);
}

.admin-table thead {
  background: hsl(220 24% 93%);
}

.admin-table th {
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: hsl(220 20% 38%);
  border-bottom-color: var(--admin-border-strong);
}

.admin-table tbody tr:nth-child(even) {
  background: hsl(220 22% 98%);
}

.admin-table tbody tr:hover {
  background: hsl(45 70% 45% / 0.05);
}

.admin-table tbody tr:last-child td {
  border-bottom: none;
}

.admin-table td:has(.crm-cost-row),
.admin-table tr.crm-cost-row td {
  background: hsl(45 55% 96%);
}

.admin-table__actions {
  white-space: nowrap;
}

.admin-pagination {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  padding: 0.875rem 1rem;
  border-top: 1px solid var(--admin-border);
  background: hsl(220 24% 96%);
}

.admin-pagination__summary {
  margin: 0;
  font-size: 0.8125rem;
  color: hsl(220 15% 42%);
}

.admin-pagination__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.25rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.admin-pagination__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.5rem;
  border: 1px solid var(--admin-border-strong);
  border-radius: 0.375rem;
  background: hsl(0 0% 100%);
  color: hsl(220 25% 28%);
  font-size: 0.8125rem;
  font-weight: 500;
  text-decoration: none;
  transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.admin-pagination__link:hover {
  border-color: var(--accent);
  color: hsl(220 30% 18%);
  background: hsl(45 70% 45% / 0.08);
}

.admin-pagination__link.is-active {
  border-color: var(--accent);
  background: var(--accent);
  color: hsl(220 30% 12%);
  font-weight: 600;
  cursor: default;
}

/* Campos editáveis vs somente leitura (admin) */
.admin-body .admin-card--form .form-input,
.admin-body .admin-filters .form-input,
.admin-body .crm-cost-row .form-input {
  background: hsl(0 0% 100%);
  border: 1px solid var(--admin-border-strong);
  box-shadow: inset 0 1px 2px hsl(220 40% 15% / 0.04);
}

.admin-body .admin-card--form .form-input:focus,
.admin-body .admin-filters .form-input:focus,
.admin-body .crm-cost-row .form-input:focus {
  border-color: var(--accent);
  outline: none;
  box-shadow: 0 0 0 3px hsl(45 70% 45% / 0.18);
}

.admin-body .admin-card--form .form-group label,
.admin-body .admin-filters .form-group label {
  color: hsl(220 30% 28%);
}

.admin-field-static {
  margin: 0;
  padding: 0.5rem 0;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--foreground);
  line-height: 1.4;
}

.admin-field-static--muted {
  font-weight: 400;
  color: var(--muted-foreground);
  font-size: 0.8125rem;
}

.admin-inline-form {
  display: inline;
}

.admin-btn-danger {
  color: hsl(0 70% 45%);
  border-color: hsl(0 70% 45% / 0.35);
}

.admin-btn-danger:hover {
  background: hsl(0 70% 45%);
  color: #fff;
}

.admin-alert {
  padding: 0.875rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 1rem;
  font-size: 0.9375rem;
}

.admin-alert--success {
  background: hsl(160 60% 40% / 0.1);
  border: 1px solid hsl(160 60% 40% / 0.25);
  color: hsl(160 50% 28%);
}

.admin-alert--error {
  background: hsl(0 70% 50% / 0.08);
  border: 1px solid hsl(0 70% 50% / 0.25);
  color: hsl(0 60% 35%);
}

.form-hint {
  margin: 0.375rem 0 0;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.admin-table__muted {
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.admin-filters {
  margin-bottom: 0.75rem;
  padding: 0.625rem 0.875rem;
  background: var(--admin-surface-muted);
  border-color: var(--admin-border);
  border-style: dashed;
}

.admin-filters .admin-card__header {
  margin-bottom: 0.625rem;
}

.admin-card--table > .admin-card__header + .admin-field-static,
.admin-table__hint {
  margin-top: -0.25rem;
  padding: 0 1.25rem 0.75rem;
}

.admin-filters .form-group {
  margin-bottom: 0;
}

.admin-filters__form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: flex-end;
}

.admin-filters__field {
  flex: 1 1 8rem;
  min-width: 0;
}

.admin-filters__field--search {
  flex: 2 1 11rem;
}

.admin-filters__field label {
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  color: var(--muted-foreground);
  margin-bottom: 0.2rem;
}

.admin-filters__field .form-input {
  padding: 0.375rem 0.625rem;
  font-size: 0.875rem;
}

.admin-filters__actions {
  flex: 0 0 auto;
  margin: 0;
  gap: 0.5rem;
}

.admin-modal {
  border: none;
  padding: 0;
  margin: auto;
  max-width: min(34rem, calc(100vw - 2rem));
  width: 100%;
  background: transparent;
}

.admin-modal--wide {
  max-width: min(72rem, calc(100vw - 2.5rem));
}

.admin-modal--wide .admin-modal__body {
  max-height: min(75vh, 44rem);
  overflow-y: auto;
}

.admin-modal--wide .crm-textarea {
  min-height: 20rem;
}

.admin-modal::backdrop {
  background: hsl(220 45% 12% / 0.55);
  backdrop-filter: blur(2px);
}

.admin-modal__panel {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border-strong);
  border-radius: var(--radius);
  border-left: 3px solid var(--accent);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}

.admin-modal__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--admin-border);
}

.admin-modal__title {
  margin: 0;
  font-size: 1.0625rem;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 600;
}

.admin-modal__desc {
  margin: 0.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
  line-height: 1.45;
}

.admin-modal__meta {
  margin-top: 0.45rem;
}

.admin-modal__meta-line {
  margin: 0.15rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--muted-foreground);
}

.admin-modal__meta-line:first-child {
  margin-top: 0;
}

.admin-modal__meta-key {
  font-weight: 600;
  letter-spacing: 0.03em;
  color: hsl(220 12% 42%);
  margin-right: 0.3rem;
  white-space: nowrap;
}

.admin-modal__close {
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  background: var(--admin-surface-muted);
  color: var(--muted-foreground);
  font-size: 1.25rem;
  line-height: 1;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease;
}

.admin-modal__close:hover {
  background: hsl(220 20% 90%);
  color: var(--foreground);
}

.admin-modal__body {
  padding: 1.25rem;
}

.admin-modal__body .admin-form-actions {
  margin-top: 0.5rem;
  padding-top: 0.75rem;
}

.admin-modal__actions {
  justify-content: flex-end;
}

.crm-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(16rem, 1fr);
  gap: 1.25rem;
  align-items: start;
}

.crm-layout__main,
.crm-layout__aside {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

.crm-dl {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 0.75rem 1.25rem;
  margin: 0;
}

.admin-card--data .crm-dl > div {
  padding: 0.625rem 0.75rem;
  background: hsl(0 0% 100% / 0.55);
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(220 18% 88% / 0.8);
}

.crm-dl dt {
  font-size: 0.6875rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--muted-foreground);
  margin-bottom: 0.25rem;
  font-weight: 600;
}

.crm-help-tip {
  text-decoration: underline dotted;
  text-decoration-color: hsl(220 15% 45% / 0.5);
  text-underline-offset: 0.15em;
  cursor: help;
}

.crm-section-desc {
  margin: 0 0 0.75rem;
}

.crm-dl dd {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 500;
  color: var(--foreground);
  line-height: 1.4;
}

.crm-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
  gap: 1rem;
}

.crm-subtitle {
  margin: 1.25rem 0 0.75rem;
  font-size: 1rem;
}

.crm-textarea {
  min-height: 5rem;
  resize: vertical;
}

.crm-badge {
  display: inline-block;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  background: hsl(220 15% 92%);
  color: hsl(220 20% 30%);
}

.crm-badge--won {
  background: hsl(160 55% 90%);
  color: hsl(160 45% 28%);
}

.crm-badge--lost {
  background: hsl(0 60% 94%);
  color: hsl(0 55% 38%);
}

.crm-badge--new,
.crm-badge--contacted,
.crm-badge--proposal_sent {
  background: hsl(210 70% 94%);
  color: hsl(210 55% 32%);
}

.crm-timeline {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.crm-timeline__item {
  padding-left: 0.75rem;
  border-left: 2px solid var(--border);
}

.crm-timeline__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 0.35rem;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.crm-timeline__type {
  font-weight: 600;
  color: var(--foreground);
}

.crm-timeline__author::before {
  content: '·';
  margin-right: 0.5rem;
  color: var(--muted-foreground);
  font-weight: 400;
}

.crm-timeline__body {
  margin: 0;
  font-size: 0.9375rem;
  white-space: pre-wrap;
}

.form-input--compact {
  padding: 0.35rem 0.5rem;
  font-size: 0.875rem;
  max-width: 7rem;
  border-style: dashed;
  border-color: hsl(45 55% 55%);
  background: hsl(0 0% 100%);
}

.crm-cost-row__month {
  min-width: 8.5rem;
}

.crm-cost-row__type {
  min-width: 6.5rem;
}

.crm-cost-row__channel {
  min-width: 7.5rem;
}

.crm-cost-row__amount {
  min-width: 5.5rem;
  max-width: 7rem;
}

.crm-cost-row__notes {
  min-width: 10rem;
  width: 100%;
}

.crm-cost-row__registered {
  font-size: 0.8125rem;
  color: hsl(220 15% 45%);
  white-space: nowrap;
}

.admin-table--costs th:not(.admin-table__col--notes),
.admin-table--costs td:not(.admin-table__col--notes) {
  white-space: nowrap;
}

.admin-table--costs .admin-table__col--notes {
  white-space: normal;
  word-break: break-word;
  min-width: 10rem;
  max-width: 28rem;
}

.admin-table--costs .admin-table__actions {
  vertical-align: middle;
}

.admin-table--costs .admin-table__actions-inner {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.375rem;
  align-items: center;
}

.admin-table--costs .admin-table__actions-inner .admin-inline-form {
  display: inline-flex;
  flex-shrink: 0;
}

.crm-cost-type-toggle {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
}

.crm-cost-type-toggle__option {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.9375rem;
  cursor: pointer;
}

.form-group--full {
  grid-column: 1 / -1;
}

.crm-checklist-answers {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.crm-checklist-answers__item {
  padding: 0.875rem 1rem;
  border: 1px solid hsl(220 18% 86%);
  border-radius: var(--radius);
  background: hsl(0 0% 100% / 0.55);
}

.crm-checklist-answers__question {
  font-size: 0.875rem;
  color: var(--muted-foreground);
  margin-bottom: 0.35rem;
}

.crm-checklist-answers__num {
  font-weight: 600;
  color: var(--foreground);
}

.crm-checklist-answers__answer {
  font-size: 0.9375rem;
  font-weight: 600;
}

.crm-checklist-answers__score {
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--muted-foreground);
  margin-left: 0.35rem;
}

.crm-worklist-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.crm-worklist-card {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  border-top: 3px solid hsl(210 55% 55%);
}

.crm-worklist-card--overdue {
  border-top-color: hsl(0 55% 52%);
}

.crm-worklist-card--today {
  border-top-color: hsl(45 70% 48%);
}

.crm-worklist-card--queue {
  border-top-color: hsl(210 55% 55%);
}

.crm-worklist-card.is-active {
  box-shadow: 0 0 0 2px hsl(45 70% 48% / 0.35);
}

.crm-worklist-card__header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.crm-worklist-card__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
}

.crm-worklist-card__desc {
  margin: 0.25rem 0 0;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.crm-worklist-card__count {
  flex-shrink: 0;
  min-width: 2rem;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: hsl(220 15% 94%);
  font-size: 0.875rem;
  font-weight: 700;
  text-align: center;
}

.crm-worklist-card--overdue .crm-worklist-card__count {
  background: hsl(0 55% 94%);
  color: hsl(0 55% 38%);
}

.crm-worklist-card--today .crm-worklist-card__count {
  background: hsl(45 70% 92%);
  color: hsl(45 55% 28%);
}

.crm-worklist {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.crm-worklist__item {
  padding: 0.65rem 0.75rem;
  border: 1px solid hsl(220 18% 88%);
  border-radius: var(--radius);
  background: hsl(0 0% 100% / 0.6);
}

.crm-worklist__link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.crm-worklist__link:hover {
  color: hsl(210 55% 32%);
}

.crm-worklist__priority {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 999px;
  background: hsl(0 55% 52%);
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 800;
  line-height: 1;
}

.crm-worklist__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 0.5rem;
  align-items: center;
  margin-top: 0.25rem;
}

.crm-worklist__when {
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.crm-worklist__status {
  font-size: 0.6875rem;
}

.crm-worklist__phone {
  margin-top: 0.2rem;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.crm-worklist__empty {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted-foreground);
}

.crm-worklist-card__footer {
  margin-top: auto;
  padding-top: 0.25rem;
}

.crm-kanban {
  display: flex;
  gap: 0.875rem;
  overflow-x: auto;
  padding-bottom: 0.5rem;
  align-items: flex-start;
  -webkit-overflow-scrolling: touch;
}

.crm-kanban__column {
  flex: 0 0 17rem;
  min-width: 17rem;
  max-height: calc(100vh - 14rem);
  display: flex;
  flex-direction: column;
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  box-shadow: 0 1px 2px hsl(220 40% 15% / 0.04);
}

.crm-kanban__column--new {
  border-top: 3px solid hsl(210 70% 55%);
}

.crm-kanban__column--contacted,
.crm-kanban__column--proposal_sent {
  border-top: 3px solid hsl(210 55% 48%);
}

.crm-kanban__column--contract_signed,
.crm-kanban__column--case_filed {
  border-top: 3px solid hsl(160 45% 42%);
}

.crm-kanban__column--won {
  border-top: 3px solid hsl(160 55% 40%);
}

.crm-kanban__column--lost {
  border-top: 3px solid hsl(0 55% 52%);
}

.crm-kanban__column--terminal {
  opacity: 0.92;
  background: hsl(220 18% 97%);
}

.crm-kanban__column-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.75rem 0.875rem;
  border-bottom: 1px solid var(--admin-border);
  flex-shrink: 0;
}

.crm-kanban__column-title {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 700;
  line-height: 1.3;
}

.crm-kanban__column-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5rem;
  height: 1.5rem;
  padding: 0 0.4rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  background: hsl(220 15% 92%);
  color: hsl(220 20% 30%);
}

.crm-kanban__cards {
  list-style: none;
  margin: 0;
  padding: 0.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  overflow-y: auto;
  flex: 1;
  min-height: 0;
}

.crm-kanban__card-item {
  margin: 0;
}

.crm-kanban__card {
  display: flex;
  flex-direction: column;
  gap: 0.375rem;
  padding: 0.625rem 0.75rem;
  border-radius: calc(var(--radius) - 2px);
  border: 1px solid hsl(220 18% 88% / 0.9);
  background: hsl(0 0% 100% / 0.7);
  color: inherit;
  text-decoration: none;
  transition: border-color 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}

.crm-kanban__card:hover {
  border-color: var(--admin-border-strong);
  box-shadow: var(--shadow-sm);
  background: hsl(0 0% 100%);
}

.crm-kanban__card-name {
  display: flex;
  align-items: flex-start;
  gap: 0.25rem;
  font-size: 0.875rem;
  font-weight: 600;
  line-height: 1.35;
  color: var(--foreground);
}

.crm-kanban__card-priority {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 1rem;
  height: 1rem;
  border-radius: 50%;
  font-size: 0.6875rem;
  font-weight: 800;
  background: hsl(0 70% 94%);
  color: hsl(0 60% 42%);
}

.crm-kanban__card-eligibility {
  align-self: flex-start;
  font-size: 0.6875rem;
}

.crm-kanban__card-eligibility--eligible {
  background: hsl(160 55% 90%);
  color: hsl(160 45% 28%);
}

.crm-kanban__card-eligibility--possible {
  background: hsl(45 70% 90%);
  color: hsl(45 55% 30%);
}

.crm-kanban__card-eligibility--not_eligible {
  background: hsl(220 15% 92%);
  color: hsl(220 15% 40%);
}

.crm-kanban__card-meta {
  display: block;
}

.crm-kanban__card-when {
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.crm-kanban__card-when--overdue {
  color: hsl(0 55% 42%);
  font-weight: 600;
}

.crm-kanban__empty {
  margin: 0;
  padding: 1rem 0.875rem;
  font-size: 0.8125rem;
  color: var(--muted-foreground);
  font-style: italic;
}

.crm-kanban__column-footer {
  padding: 0.5rem 0.75rem 0.75rem;
  border-top: 1px solid var(--admin-border);
  flex-shrink: 0;
}

.admin-table__filter-note {
  margin: 0 1rem 0.75rem;
  font-size: 0.875rem;
}

@media (max-width: 960px) {
  .crm-worklist-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 960px) {
  .crm-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  .admin-body {
    height: auto;
    overflow: visible;
  }

  .admin-shell {
    flex-direction: column;
    height: auto;
    min-height: 100vh;
    overflow: visible;
  }

  .admin-sidebar {
    position: sticky;
    top: 0;
    z-index: 100;
    width: 100%;
    height: auto;
    overflow-y: visible;
    border-right: none;
    border-bottom: 1px solid var(--admin-sidebar-border);
    padding: 0;
    gap: 0;
  }

  .admin-sidebar__header {
    order: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding: 0.75rem 1rem;
  }

  .admin-sidebar__version {
    order: 1;
    margin-top: 0;
    padding: 0 1rem 0.75rem;
    border-top: none;
  }

  .admin-sidebar.is-open .admin-sidebar__version {
    padding-bottom: 0.5rem;
    border-bottom: 1px solid hsl(220 45% 22%);
  }

  .admin-sidebar__nav {
    order: 2;
    flex: none;
    flex-direction: column;
    flex-wrap: nowrap;
    gap: 0.125rem;
    padding: 0.5rem;
    max-height: min(24rem, calc(100vh - 8rem));
    overflow-y: auto;
  }

  .admin-sidebar:not(.is-open) .admin-sidebar__nav {
    display: none !important;
  }

  .admin-sidebar.is-open .admin-sidebar__nav {
    display: flex !important;
  }

  .admin-sidebar__nav[hidden] {
    display: none !important;
  }

  .admin-sidebar__brand {
    padding: 0;
    min-width: 0;
  }

  .admin-sidebar__toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 2.5rem;
    height: 2.5rem;
    padding: 0;
    border: 1px solid hsl(220 45% 28%);
    border-radius: var(--radius);
    background: hsl(220 45% 18%);
    color: var(--admin-sidebar-text);
    cursor: pointer;
    transition: background 0.15s ease, border-color 0.15s ease;
  }

  .admin-sidebar__toggle:hover {
    background: hsl(220 45% 22%);
    border-color: hsl(220 45% 34%);
  }

  .admin-sidebar__toggle-icon {
    display: block;
    width: 1.125rem;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    box-shadow: 0 -6px 0 currentColor, 0 6px 0 currentColor;
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }

  .admin-sidebar.is-open .admin-sidebar__toggle-icon {
    box-shadow: none;
    transform: rotate(45deg);
  }

  .admin-sidebar.is-open .admin-sidebar__toggle-icon::after {
    content: '';
    display: block;
    width: 1.125rem;
    height: 2px;
    background: currentColor;
    border-radius: 1px;
    transform: rotate(-90deg);
  }

  .admin-sidebar__link {
    width: 100%;
  }

  .admin-main {
    overflow-y: visible;
  }

  .admin-page__header {
    flex-direction: column;
    align-items: stretch;
  }

  .admin-topbar__inner {
    flex-direction: column;
    align-items: flex-start;
  }
}

/* Dashboard v2 — layout profissional (escopo isolado) */
.dash-v2 {
  max-width: 72rem;
  margin: 0 auto;
}

.dash-v2__hero {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  padding: 1.75rem 2rem;
  margin-bottom: 1.5rem;
  border-radius: calc(var(--radius) + 0.25rem);
  background: linear-gradient(135deg, hsl(220 55% 16%) 0%, hsl(220 45% 24%) 55%, hsl(220 40% 28%) 100%);
  color: hsl(45 25% 96%);
  box-shadow: var(--shadow-lg);
}

.dash-v2__eyebrow {
  margin: 0 0 0.375rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  opacity: 0.72;
}

.dash-v2__title {
  margin: 0 0 0.5rem;
  font-size: 2rem;
  font-family: 'Playfair Display', Georgia, serif;
  letter-spacing: -0.02em;
}

.dash-v2__welcome {
  margin: 0;
  font-size: 0.9375rem;
  opacity: 0.88;
  max-width: 36rem;
}

.dash-v2__health {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 0.875rem 1.125rem;
  border-radius: var(--radius);
  background: hsl(0 0% 100% / 0.08);
  border: 1px solid hsl(0 0% 100% / 0.12);
}

.dash-v2__health-ring {
  --health-pct: 0;
  width: 4.25rem;
  height: 4.25rem;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: conic-gradient(
    hsl(142 55% 48%) calc(var(--health-pct) * 1%),
    hsl(0 0% 100% / 0.15) 0
  );
  position: relative;
}

.dash-v2__health-ring::before {
  content: '';
  position: absolute;
  inset: 0.375rem;
  border-radius: 50%;
  background: hsl(220 50% 20%);
}

.dash-v2__health-value {
  position: relative;
  z-index: 1;
  font-size: 0.9375rem;
  font-weight: 700;
}

.dash-v2__health--pending .dash-v2__health-ring {
  background: hsl(0 0% 100% / 0.15);
}

.dash-v2__health--off_track .dash-v2__health-ring {
  background: conic-gradient(
    hsl(0 60% 55%) calc(var(--health-pct) * 1%),
    hsl(0 0% 100% / 0.15) 0
  );
}

.dash-v2__health-meta {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}

.dash-v2__health-label {
  font-weight: 600;
  font-size: 0.9375rem;
}

.dash-v2__health-hint {
  font-size: 0.75rem;
  opacity: 0.72;
}

.dash-v2__stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.875rem;
  margin-bottom: 1.25rem;
}

.dash-v2-stat {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  padding: 1rem 1.125rem;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  box-shadow: 0 1px 2px hsl(220 40% 15% / 0.04);
}

.dash-v2-stat__value {
  font-size: 1.75rem;
  font-weight: 700;
  font-family: 'Playfair Display', Georgia, serif;
  line-height: 1.1;
}

.dash-v2-stat__label {
  font-size: 0.75rem;
  color: var(--muted-foreground);
  font-weight: 500;
}

.dash-v2-stat--on { border-top: 3px solid hsl(142 55% 40%); }
.dash-v2-stat--off { border-top: 3px solid hsl(0 55% 50%); }
.dash-v2-stat--pending { border-top: 3px solid var(--muted-foreground); }

.dash-v2__nav {
  display: flex;
  flex-wrap: wrap;
  gap: 0.375rem;
  margin-bottom: 1.25rem;
  padding: 0.375rem;
  background: var(--admin-surface-muted);
  border: 1px solid var(--admin-border);
  border-radius: 999px;
  width: fit-content;
}

.dash-v2__nav-link {
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 0.4375rem 0.875rem;
  border-radius: 999px;
  color: var(--muted-foreground);
  transition: background 0.15s ease, color 0.15s ease;
}

.dash-v2__nav-link:hover {
  background: var(--admin-surface);
  color: var(--foreground);
}

.dash-v2__actions {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.75rem;
  margin-bottom: 2rem;
}

.dash-v2-action {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  padding: 1rem 1.125rem;
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.dash-v2-action:hover {
  border-color: var(--admin-border-strong);
  box-shadow: var(--shadow-md);
}

.dash-v2-action__title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--foreground);
}

.dash-v2-action__desc {
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.dash-v2__section {
  margin-bottom: 2rem;
  scroll-margin-top: 1rem;
}

.dash-v2__section-head {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  margin-bottom: 1rem;
}

.dash-v2__section-head h2 {
  margin: 0 0 0.25rem;
  font-size: 1.25rem;
  font-family: 'DM Sans', system-ui, sans-serif;
  font-weight: 700;
}

.dash-v2__section-head p {
  margin: 0;
  font-size: 0.875rem;
  color: var(--muted-foreground);
}

.dash-v2__section-badge {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 0.3125rem 0.625rem;
  border-radius: 999px;
  background: hsl(45 70% 45% / 0.15);
  color: hsl(45 60% 28%);
  border: 1px solid hsl(45 70% 45% / 0.35);
}

.dash-v2__grid {
  display: grid;
  gap: 0.875rem;
}

.dash-v2__grid--north {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.dash-v2__grid--compact {
  grid-template-columns: 1fr;
}

.dash-v2__columns {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.25rem;
  margin-bottom: 2rem;
}

.dash-v2__section--column {
  background: var(--admin-surface-muted);
  border: 1px solid var(--admin-border);
  border-radius: calc(var(--radius) + 0.125rem);
  padding: 1.25rem;
  margin-bottom: 0;
}

.dash-v2-metric {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  padding: 1rem 1.125rem;
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
  box-shadow: 0 1px 2px hsl(220 40% 15% / 0.04);
}

.dash-v2-metric--featured {
  border-color: var(--admin-border-strong);
}

.dash-v2-metric--on_track { border-left: 3px solid hsl(142 55% 40%); }
.dash-v2-metric--off_track { border-left: 3px solid hsl(0 55% 50%); }
.dash-v2-metric--pending { border-left: 3px solid var(--muted-foreground); }

.dash-v2-metric__head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.5rem;
}

.dash-v2-metric__phase {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--muted-foreground);
  background: var(--admin-surface-muted);
  padding: 0.1875rem 0.4375rem;
  border-radius: 4px;
}

.dash-v2-metric__status {
  font-size: 0.6875rem;
  font-weight: 600;
  padding: 0.1875rem 0.5rem;
  border-radius: 999px;
}

.dash-v2-metric__status--pending { background: hsl(220 15% 94%); color: var(--muted-foreground); }
.dash-v2-metric__status--on_track { background: hsl(142 50% 92%); color: hsl(142 55% 28%); }
.dash-v2-metric__status--off_track { background: hsl(0 50% 95%); color: hsl(0 55% 38%); }

.dash-v2-metric__label {
  margin: 0;
  font-size: 0.9375rem;
  font-weight: 600;
  font-family: 'DM Sans', system-ui, sans-serif;
  line-height: 1.35;
}

.dash-v2-metric__value {
  font-size: 1.5rem;
  font-weight: 700;
  font-family: 'Playfair Display', Georgia, serif;
  color: var(--foreground);
  display: block;
}

.dash-v2-metric--featured .dash-v2-metric__value {
  font-size: 1.75rem;
}

.dash-v2-metric__target {
  font-size: 0.75rem;
  color: var(--muted-foreground);
  display: block;
  margin-top: 0.125rem;
}

.dash-v2-metric__progress {
  display: flex;
  align-items: center;
  gap: 0.625rem;
}

.dash-v2-metric__progress-track {
  flex: 1;
  height: 0.375rem;
  background: var(--admin-surface-muted);
  border-radius: 999px;
  overflow: hidden;
}

.dash-v2-metric__progress-fill {
  height: 100%;
  border-radius: 999px;
  transition: width 0.4s ease;
}

.dash-v2-metric__progress-fill--on_track { background: hsl(142 55% 42%); }
.dash-v2-metric__progress-fill--off_track { background: hsl(0 55% 52%); }
.dash-v2-metric__progress-fill--pending { background: var(--muted-foreground); }

.dash-v2-metric__progress-label {
  font-size: 0.6875rem;
  font-weight: 600;
  color: var(--muted-foreground);
  min-width: 2rem;
  text-align: right;
}

.dash-v2-metric__pending {
  margin: 0;
  font-size: 0.75rem;
  color: var(--muted-foreground);
  font-style: italic;
}

.dash-v2-metric__details {
  margin-top: 0.125rem;
  font-size: 0.8125rem;
}

.dash-v2-metric__details summary {
  cursor: pointer;
  font-weight: 600;
  color: var(--muted-foreground);
  user-select: none;
}

.dash-v2-metric__details[open] summary {
  margin-bottom: 0.375rem;
}

.dash-v2-metric__formula {
  margin: 0 0 0.25rem;
  font-style: italic;
  color: var(--muted-foreground);
}

.dash-v2-metric__meta,
.dash-v2-metric__source {
  margin: 0;
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.dash-v2__section--funnel {
  background: var(--admin-surface);
  border: 1px solid var(--admin-border);
  border-radius: calc(var(--radius) + 0.125rem);
  padding: 1.25rem;
}

.dash-v2-funnel {
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 0.5rem;
}

.dash-v2-funnel__connector {
  display: flex;
  align-items: center;
  padding: 0 0.125rem;
}

.dash-v2-funnel__arrow {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  background: var(--admin-surface-muted);
  border-radius: 50%;
  position: relative;
}

.dash-v2-funnel__arrow::after {
  content: '→';
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  font-size: 0.75rem;
  color: var(--muted-foreground);
}

.dash-v2-funnel__step {
  flex: 1 1 8rem;
  min-width: 7.5rem;
  padding: 0.875rem 1rem;
  background: var(--admin-surface-muted);
  border: 1px solid var(--admin-border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  text-align: center;
}

.dash-v2-funnel__step--on_track { border-top: 3px solid hsl(142 55% 40%); }
.dash-v2-funnel__step--pending { border-top: 3px solid var(--muted-foreground); }

.dash-v2-funnel__step-num {
  font-size: 0.625rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--muted-foreground);
}

.dash-v2-funnel__step-label {
  margin: 0;
  font-size: 0.8125rem;
  font-weight: 600;
  font-family: 'DM Sans', system-ui, sans-serif;
  line-height: 1.3;
}

.dash-v2-funnel__step-value {
  margin: 0;
  font-size: 1.125rem;
  font-weight: 700;
  font-family: 'Playfair Display', Georgia, serif;
}

.dash-v2-funnel__step-status {
  font-size: 0.625rem;
  font-weight: 600;
  padding: 0.125rem 0.4375rem;
  border-radius: 999px;
  align-self: center;
}

.dash-v2-funnel__step-status--on_track { background: hsl(142 50% 92%); color: hsl(142 55% 28%); }
.dash-v2-funnel__step-status--pending { background: hsl(220 15% 94%); color: var(--muted-foreground); }

.dash-v2-funnel__step-owner {
  font-size: 0.6875rem;
  color: var(--muted-foreground);
}

.dash-v2__footnote {
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--admin-border);
  font-size: 0.8125rem;
  color: var(--muted-foreground);
}

.dash-v2__footnote code {
  font-size: 0.75rem;
}

.dash-v2__footnote a {
  color: hsl(220 55% 35%);
  text-decoration: underline;
  text-underline-offset: 2px;
}

@media (max-width: 1024px) {
  .dash-v2__stats,
  .dash-v2__actions {
    grid-template-columns: repeat(2, 1fr);
  }

  .dash-v2__columns {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 640px) {
  .dash-v2__hero {
    padding: 1.25rem 1.5rem;
  }

  .dash-v2__title {
    font-size: 1.5rem;
  }

  .dash-v2__stats,
  .dash-v2__actions {
    grid-template-columns: 1fr;
  }

  .dash-v2__nav {
    width: 100%;
    border-radius: var(--radius);
  }

  .dash-v2-funnel {
    flex-direction: column;
  }

  .dash-v2-funnel__connector {
    justify-content: center;
    padding: 0.25rem 0;
  }

  .dash-v2-funnel__arrow::after {
    content: '↓';
  }
}

