/*
  MD Canônico — Design System CSS
  ================================
  Como usar:
  1. Adicione no <head> do seu HTML:
     <link rel="stylesheet" href="md-canonico.css">
  2. Adicione as fontes (também no <head>, ANTES do CSS):
     <link rel="preconnect" href="https://fonts.googleapis.com">
     <link href="https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600&family=Lora:ital,wght@0,400;0,500;0,600;1,400&display=swap" rel="stylesheet">
  3. Use as classes nos seus elementos HTML.
  4. Para modo escuro, adicione data-theme="dark" no <html>.
  5. Para serifa, adicione data-font="serif" no <html>.
*/

/* ══════════════════════════════════════
   TOKENS — variáveis globais
══════════════════════════════════════ */
:root {
  --font-sans:   'Outfit', sans-serif;
  --font-serif:  'Lora', serif;
  --font-main:   var(--font-sans);

  --sz-xs:  11px;
  --sz-sm:  14px;
  --sz-md:  20px;
  --sz-lg:  32px;

  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-5: 24px; --sp-6: 32px; --sp-7: 48px;

  --r-sm:   5px;
  --r-md:   9px;
  --r-lg:   14px;
  --r-pill: 999px;

  /* Fundo e superfícies */
  --bg:           oklch(98.5% 0.004 75);
  --bg-surface:   oklch(96.5% 0.006 72);
  --bg-raised:    oklch(100%  0.002 70);
  --bg-sunken:    oklch(94%   0.008 70);

  /* Bordas */
  --border:        oklch(86% 0.012 220);
  --border-strong: oklch(72% 0.016 220);

  /* Texto */
  --text:   oklch(22% 0.012 60);
  --text-2: oklch(46% 0.010 60);
  --text-3: oklch(64% 0.008 60);

  /* Prata */
  --silver:       oklch(78% 0.010 225);
  --silver-light: oklch(93% 0.006 220);
  --silver-dark:  oklch(56% 0.016 225);

  /* Bronze */
  --bronze:       oklch(58% 0.092 58);
  --bronze-light: oklch(88% 0.038 62);
  --bronze-dark:  oklch(42% 0.080 55);
  --bronze-tint:  oklch(96% 0.016 65);

  /* Vibrantes */
  --pink:         oklch(62% 0.22 340);
  --pink-tint:    oklch(95% 0.04 340);
  --orange:       oklch(68% 0.19  48);
  --orange-tint:  oklch(96% 0.04  52);
  --cyan:         oklch(64% 0.18 200);
  --cyan-tint:    oklch(95% 0.04 200);
  --green:        oklch(66% 0.20 148);
  --green-tint:   oklch(95% 0.04 148);
  --red:          oklch(58% 0.20  22);
  --red-tint:     oklch(96% 0.04  22);

  /* Gradientes */
  --grad-header: linear-gradient(135deg, oklch(96% 0.010 225) 0%, oklch(94% 0.022 68) 100%);
  --grad-card:   linear-gradient(160deg, oklch(99% 0.004 220) 0%, oklch(97% 0.012 65) 100%);

  /* Sombras */
  --shadow-sm: 0 1px 3px oklch(40% 0.01 60 / 0.08), 0 1px 2px oklch(40% 0.01 60 / 0.06);
  --shadow-md: 0 4px 12px oklch(30% 0.01 60 / 0.10), 0 2px 4px oklch(30% 0.01 60 / 0.06);
  --shadow-lg: 0 8px 28px oklch(25% 0.01 60 / 0.12), 0 3px 8px oklch(25% 0.01 60 / 0.07);

  /* Acento padrão (troque para --pink, --orange, --cyan ou --green) */
  --accent:      var(--bronze);
  --accent-tint: var(--bronze-tint);
  --accent-dark: var(--bronze-dark);
}

/* ── MODO ESCURO ── */
[data-theme="dark"] {
  --bg:           oklch(16% 0.008 240);
  --bg-surface:   oklch(20% 0.010 240);
  --bg-raised:    oklch(23% 0.010 238);
  --bg-sunken:    oklch(13% 0.007 240);
  --border:        oklch(30% 0.014 230);
  --border-strong: oklch(42% 0.016 230);
  --text:   oklch(93% 0.006 70);
  --text-2: oklch(70% 0.008 65);
  --text-3: oklch(52% 0.008 65);
  --silver-light: oklch(28% 0.012 230);
  --bronze-tint:  oklch(22% 0.022 60);
  --grad-header: linear-gradient(135deg, oklch(24% 0.015 225) 0%, oklch(22% 0.025 62) 100%);
  --grad-card:   linear-gradient(160deg, oklch(22% 0.010 230) 0%, oklch(20% 0.018 65) 100%);
  --shadow-sm: 0 1px 3px oklch(5% 0.01 60 / 0.4);
  --shadow-md: 0 4px 12px oklch(5% 0.01 60 / 0.5);
  --shadow-lg: 0 8px 28px oklch(5% 0.01 60 / 0.6);
}

/* ── CONTRASTE ALTO ── */
[data-contrast="high"] {
  --border:        oklch(60% 0.02 220);
  --border-strong: oklch(40% 0.025 220);
  --text-2: oklch(36% 0.012 60);
  --text-3: oklch(48% 0.010 60);
}

/* ── SERIFA ── */
[data-font="serif"] { --font-main: var(--font-serif); }


/* ══════════════════════════════════════
   BASE
══════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: var(--font-main);
  font-size: var(--sz-sm);
  color: var(--text);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}


/* ══════════════════════════════════════
   TIPOGRAFIA
   Uso: <h1 class="mdc-h1"> etc.
══════════════════════════════════════ */
.mdc-display {
  font-size: var(--sz-lg);
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.mdc-heading {
  font-size: var(--sz-md);
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
  line-height: 1.25;
}
.mdc-body {
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  font-weight: 400;
  color: var(--text-2);
  line-height: 1.65;
}
.mdc-caption {
  font-size: var(--sz-xs);
  font-family: var(--font-sans);
  font-weight: 400;
  color: var(--text-3);
  line-height: 1.4;
}
.mdc-label {
  font-size: var(--sz-xs);
  font-family: var(--font-sans);
  font-weight: 500;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}


/* ══════════════════════════════════════
   LAYOUT
══════════════════════════════════════ */
/* Container principal */
.mdc-layout {
  display: flex;
  height: 100vh;
  overflow: hidden;
}

/* Sidebar */
.mdc-sidebar {
  width: 220px;
  flex-shrink: 0;
  background: var(--grad-card);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-sm);
  overflow-y: auto;
}
.mdc-sidebar-brand {
  padding: var(--sp-5) var(--sp-4);
  border-bottom: 1px solid var(--border);
  background: var(--grad-header);
}
.mdc-sidebar-brand h1 {
  font-size: var(--sz-md);
  font-family: var(--font-serif);
  font-weight: 600;
  color: var(--bronze);
  letter-spacing: -0.01em;
  margin: 0;
}
.mdc-sidebar-brand small {
  font-size: var(--sz-xs);
  color: var(--text-3);
  display: block;
  margin-top: 2px;
}
.mdc-sidebar-body {
  flex: 1;
  padding: var(--sp-3) var(--sp-2);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.mdc-sidebar-footer {
  padding: var(--sp-3) var(--sp-2);
  border-top: 1px solid var(--border);
}

/* Conteúdo principal */
.mdc-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
.mdc-content {
  flex: 1;
  overflow-y: auto;
  padding: var(--sp-6);
}

/* Topbar */
.mdc-topbar {
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 var(--sp-5);
  background: var(--grad-header);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow-sm);
  flex-shrink: 0;
}


/* ══════════════════════════════════════
   MENU / NAV ITEMS
   Uso: <a class="mdc-nav-item mdc-nav-item--active">
══════════════════════════════════════ */
.mdc-nav-item {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  padding: 7px 10px;
  border-radius: var(--r-sm);
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  font-weight: 400;
  color: var(--text-2);
  text-decoration: none;
  cursor: pointer;
  border-left: 2px solid transparent;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
  user-select: none;
}
.mdc-nav-item:hover {
  background: var(--bg-surface);
  color: var(--text);
}
.mdc-nav-item--active,
.mdc-nav-item.active {
  background: var(--bronze-tint);
  color: var(--bronze-dark);
  font-weight: 500;
  border-left-color: var(--bronze);
}
/* Item filho (sub-menu) */
.mdc-nav-item--sub {
  font-size: var(--sz-xs);
  padding: 5px 8px 5px 28px;
}
.mdc-nav-icon {
  font-size: 13px;
  width: 16px;
  text-align: center;
  opacity: 0.65;
}
.mdc-nav-item--active .mdc-nav-icon,
.mdc-nav-item.active .mdc-nav-icon {
  opacity: 1;
}


/* ══════════════════════════════════════
   BOTÕES
   Uso: <button class="mdc-btn mdc-btn--primary">
══════════════════════════════════════ */
.mdc-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 16px;
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  font-weight: 500;
  border-radius: var(--r-sm);
  border: none;
  cursor: pointer;
  transition: all 0.12s ease;
  letter-spacing: 0.01em;
  line-height: 1;
  white-space: nowrap;
  outline: none;
  text-decoration: none;
}
.mdc-btn:active { transform: scale(0.98); }

.mdc-btn--sm  { padding: 5px 10px; font-size: var(--sz-xs); }
.mdc-btn--lg  { padding: 11px 22px; font-size: var(--sz-md); }

/* Primary */
.mdc-btn--primary {
  background: var(--accent);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.mdc-btn--primary:hover {
  background: var(--accent-dark);
  box-shadow: var(--shadow-md);
}

/* Secondary */
.mdc-btn--secondary {
  background: var(--bg-raised);
  color: var(--accent);
  border: 1.5px solid var(--border-strong);
}
.mdc-btn--secondary:hover {
  background: var(--accent-tint);
  border-color: var(--accent);
}

/* Ghost */
.mdc-btn--ghost {
  background: transparent;
  color: var(--text-2);
  border: 1.5px solid transparent;
}
.mdc-btn--ghost:hover {
  background: var(--bg-surface);
  color: var(--text);
}

/* Danger */
.mdc-btn--danger {
  background: var(--red);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.mdc-btn--danger:hover {
  background: oklch(52% 0.22 22);
  box-shadow: var(--shadow-md);
}

/* Disabled */
.mdc-btn:disabled,
.mdc-btn--disabled {
  background: var(--bg-sunken) !important;
  color: var(--text-3) !important;
  border: 1.5px solid var(--border) !important;
  box-shadow: none !important;
  cursor: not-allowed !important;
  transform: none !important;
}


/* ══════════════════════════════════════
   CAMPOS DE TEXTO
   Uso: <div class="mdc-field">
          <label class="mdc-field-label">Nome</label>
          <input class="mdc-input" type="text">
          <span class="mdc-field-helper">Texto de ajuda</span>
        </div>
══════════════════════════════════════ */
.mdc-field {
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.mdc-field-label {
  font-size: var(--sz-xs);
  font-family: var(--font-sans);
  font-weight: 500;
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.mdc-field--error .mdc-field-label {
  color: var(--red);
}
.mdc-input-wrap {
  position: relative;
  display: flex;
  align-items: center;
}
.mdc-input {
  width: 100%;
  background: var(--bg-raised);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-sm);
  padding: 8px 12px;
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  color: var(--text);
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  line-height: 1;
}
.mdc-input:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 2.5px oklch(62% 0.09 58 / 0.3);
}
.mdc-input::placeholder { color: var(--text-3); }
.mdc-input:disabled {
  background: var(--bg-sunken);
  color: var(--text-3);
  cursor: not-allowed;
}
.mdc-field--error .mdc-input {
  border-color: var(--red);
}
.mdc-field--error .mdc-input:focus {
  box-shadow: 0 0 0 2.5px oklch(58% 0.20 22 / 0.3);
}
/* Prefixo / sufixo */
.mdc-input-prefix,
.mdc-input-suffix {
  position: absolute;
  font-size: var(--sz-sm);
  color: var(--text-3);
  pointer-events: none;
}
.mdc-input-prefix { left: 10px; }
.mdc-input-suffix { right: 10px; }
.mdc-input-wrap .mdc-input-prefix ~ .mdc-input { padding-left: 32px; }
.mdc-input-wrap .mdc-input-suffix ~ .mdc-input { padding-right: 32px; }

.mdc-field-helper {
  font-size: var(--sz-xs);
  color: var(--text-3);
  line-height: 1.4;
}
.mdc-field--error .mdc-field-helper {
  color: var(--red);
}

/* Textarea */
.mdc-textarea {
  resize: vertical;
  min-height: 80px;
  line-height: 1.5;
}


/* ══════════════════════════════════════
   SELECT NATIVO (estilizado)
   Uso: <div class="mdc-field">
          <label class="mdc-field-label">Departamento</label>
          <div class="mdc-select-wrap">
            <select class="mdc-select">...</select>
          </div>
        </div>
══════════════════════════════════════ */
.mdc-select-wrap {
  position: relative;
}
.mdc-select-wrap::after {
  content: '▼';
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 9px;
  color: var(--text-3);
  pointer-events: none;
}
.mdc-select {
  width: 100%;
  appearance: none;
  -webkit-appearance: none;
  background: var(--bg-raised);
  border: 1.5px solid var(--border-strong);
  border-radius: var(--r-sm);
  padding: 8px 36px 8px 12px;
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  color: var(--text);
  cursor: pointer;
  outline: none;
  transition: border-color 0.15s, box-shadow 0.15s;
  line-height: 1;
}
.mdc-select:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 2.5px oklch(62% 0.09 58 / 0.3);
}
.mdc-select option { font-family: var(--font-sans); }


/* ══════════════════════════════════════
   CHECKBOX E RADIO
   Uso: <label class="mdc-check">
          <input type="checkbox" class="mdc-check-input">
          <span>Opção</span>
        </label>
══════════════════════════════════════ */
.mdc-check {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-size: var(--sz-sm);
  font-family: var(--font-main);
  color: var(--text);
  cursor: pointer;
  user-select: none;
}
.mdc-check-input {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 1.5px solid var(--border-strong);
  border-radius: 3px;
  background: var(--bg-raised);
  cursor: pointer;
  flex-shrink: 0;
  position: relative;
  transition: border-color 0.12s, background 0.12s;
}
.mdc-check-input:checked {
  background: var(--accent);
  border-color: var(--accent);
}
.mdc-check-input:checked::after {
  content: '';
  position: absolute;
  left: 4px; top: 1px;
  width: 5px; height: 9px;
  border: 2px solid #fff;
  border-top: none;
  border-left: none;
  transform: rotate(45deg);
}
.mdc-check-input[type="radio"] { border-radius: 50%; }
.mdc-check-input[type="radio"]:checked::after {
  width: 6px; height: 6px;
  background: #fff;
  border: none;
  border-radius: 50%;
  left: 3px; top: 3px;
}
.mdc-check-input:focus-visible {
  box-shadow: 0 0 0 2.5px oklch(62% 0.09 58 / 0.3);
}


/* ══════════════════════════════════════
   CARDS
   Uso: <div class="mdc-card">
══════════════════════════════════════ */
.mdc-card {
  background: var(--grad-card);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: var(--sp-5);
  box-shadow: var(--shadow-sm);
}
.mdc-card--flat {
  background: var(--bg-raised);
  box-shadow: none;
}
.mdc-card--raised {
  box-shadow: var(--shadow-md);
}
.mdc-card-header {
  background: var(--grad-header);
  margin: calc(-1 * var(--sp-5));
  margin-bottom: var(--sp-4);
  padding: var(--sp-4) var(--sp-5);
  border-radius: var(--r-md) var(--r-md) 0 0;
  border-bottom: 1px solid var(--border);
}

/* Stat card */
.mdc-stat {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.mdc-stat-label {
  font-size: var(--sz-xs);
  font-family: var(--font-sans);
  color: var(--text-3);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 500;
}
.mdc-stat-value {
  font-size: var(--sz-lg);
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--text);
  line-height: 1;
}
.mdc-stat-delta {
  font-size: var(--sz-xs);
  font-weight: 500;
}
.mdc-stat-delta--up   { color: var(--green); }
.mdc-stat-delta--down { color: var(--red); }


/* ══════════════════════════════════════
   BADGES
   Uso: <span class="mdc-badge mdc-badge--green">Ativo</span>
══════════════════════════════════════ */
.mdc-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: var(--r-pill);
  font-size: var(--sz-xs);
  font-family: var(--font-sans);
  font-weight: 500;
  line-height: 1.5;
}
.mdc-badge::before {
  content: '';
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
  flex-shrink: 0;
  display: none;
}
.mdc-badge--dot::before { display: inline-block; }

.mdc-badge--bronze { background: var(--bronze-tint); color: var(--bronze-dark); border: 1px solid color-mix(in oklch, var(--bronze) 30%, transparent); }
.mdc-badge--green  { background: var(--green-tint);  color: var(--green);       border: 1px solid color-mix(in oklch, var(--green)  30%, transparent); }
.mdc-badge--orange { background: var(--orange-tint); color: var(--orange);      border: 1px solid color-mix(in oklch, var(--orange) 30%, transparent); }
.mdc-badge--pink   { background: var(--pink-tint);   color: var(--pink);        border: 1px solid color-mix(in oklch, var(--pink)   30%, transparent); }
.mdc-badge--cyan   { background: var(--cyan-tint);   color: var(--cyan);        border: 1px solid color-mix(in oklch, var(--cyan)   30%, transparent); }
.mdc-badge--red    { background: var(--red-tint);    color: var(--red);         border: 1px solid color-mix(in oklch, var(--red)    30%, transparent); }


/* ══════════════════════════════════════
   TABELA
   Uso: <table class="mdc-table">
══════════════════════════════════════ */
.mdc-table-wrap {
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  box-shadow: var(--shadow-sm);
}
.mdc-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-main);
  font-size: var(--sz-sm);
}
.mdc-table thead tr {
  background: var(--grad-header);
}
.mdc-table th {
  padding: 10px 14px;
  text-align: left;
  font-size: var(--sz-xs);
  font-weight: 600;
  font-family: var(--font-sans);
  color: var(--text-2);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 1px solid var(--border);
}
.mdc-table td {
  padding: 9px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
}
.mdc-table tbody tr:last-child td { border-bottom: none; }
.mdc-table tbody tr:nth-child(even) { background: var(--bg-surface); }
.mdc-table tbody tr:hover { background: var(--bg-surface); cursor: pointer; }
.mdc-table tbody tr.selected,
.mdc-table tbody tr.mdc-selected { background: var(--bronze-tint); }

/* Coluna de valor (usa serifa) */
.mdc-table .col-value {
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--bronze-dark);
}


/* ══════════════════════════════════════
   DIVISORES E CABEÇALHOS DE SEÇÃO
══════════════════════════════════════ */
.mdc-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: var(--sp-4);
  padding-bottom: var(--sp-3);
  border-bottom: 1px solid var(--border);
}
.mdc-section-header h2 {
  font-size: var(--sz-md);
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
  margin: 0;
}
.mdc-section-header p {
  font-size: var(--sz-xs);
  color: var(--text-3);
  margin: 3px 0 0;
  line-height: 1.4;
}
.mdc-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: var(--sp-5) 0;
}


/* ══════════════════════════════════════
   GRID UTILITÁRIOS
══════════════════════════════════════ */
.mdc-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
.mdc-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-4); }
.mdc-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--sp-4); }
.mdc-stack  { display: flex; flex-direction: column; gap: var(--sp-4); }
.mdc-row    { display: flex; align-items: center; gap: var(--sp-3); }

@media (max-width: 768px) {
  .mdc-grid-2, .mdc-grid-3, .mdc-grid-4 { grid-template-columns: 1fr; }
  .mdc-sidebar { display: none; }
}
