/* =====================================================
   YNOKAI UI — DESIGN SYSTEM v1
   Single source of truth for all colors, typography,
   spacing and components. Never use hex codes outside
   this file — always consume a CSS variable.
   ===================================================== */


/* ═══════════════════════════════════════════════════
   1. DESIGN TOKENS — LIGHT (default)
   ═══════════════════════════════════════════════════ */
:root {

  /* ── Brand (same in both themes) ───────────────── */
  --color-primary:          #EF8C00;
  --color-primary-hover:    #D47A00;
  --color-primary-dim:      rgba(239, 140, 0, 0.08);
  --color-primary-border:   rgba(239, 140, 0, 0.20);
  --color-secondary:        #782CF6;
  --color-secondary-hover:  #6520D4;
  --color-secondary-dim:    rgba(120, 44, 246, 0.08);
  --color-secondary-border: rgba(120, 44, 246, 0.18);

  /* ── State colors ───────────────────────────────── */
  --c-success:         #059669;
  --c-success-dim:     rgba(5,   150, 105, 0.08);
  --c-success-border:  rgba(5,   150, 105, 0.20);
  --c-warning:         #d97706;
  --c-warning-dim:     rgba(217, 119, 6,   0.08);
  --c-warning-border:  rgba(217, 119, 6,   0.20);
  --c-danger:          #dc2626;
  --c-danger-dim:      rgba(220, 38,  38,  0.08);
  --c-danger-border:   rgba(220, 38,  38,  0.20);
  --c-info:            #2563eb;
  --c-info-dim:        rgba(37,  99,  235, 0.08);
  --c-info-border:     rgba(37,  99,  235, 0.20);

  /* ── Surfaces & text ────────────────────────────── */
  --bg:              #F2F2F3;
  --bg-alt:          #E8E8EA;
  --surface:         #FFFFFF;
  --surface-raised:  #F7F7F9;
  --border:          rgba(0, 0, 0, 0.07);
  --border-strong:   rgba(0, 0, 0, 0.12);
  --text-primary:    #000000;
  --text-secondary:  #555555;
  --text-muted:      #888888;

  /* ── Icon badge system ──────────────────────────── */
  --icon-bg-primary:        rgba(239, 140, 0,   0.08);
  --icon-border-primary:    rgba(239, 140, 0,   0.20);
  --icon-bg-secondary:      rgba(120, 44,  246, 0.08);
  --icon-border-secondary:  rgba(120, 44,  246, 0.18);
  --icon-bg-success:        rgba(5,   150, 105, 0.08);
  --icon-border-success:    rgba(5,   150, 105, 0.20);
  --icon-bg-warning:        rgba(217, 119, 6,   0.08);
  --icon-border-warning:    rgba(217, 119, 6,   0.20);
  --icon-bg-danger:         rgba(220, 38,  38,  0.08);
  --icon-border-danger:     rgba(220, 38,  38,  0.20);
  --icon-bg-info:           rgba(37,  99,  235, 0.08);
  --icon-border-info:       rgba(37,  99,  235, 0.20);
  --icon-bg-neutral:        rgba(0,   0,   0,   0.05);
  --icon-border-neutral:    rgba(0,   0,   0,   0.10);

  /* ── Table tokens ───────────────────────────────── */
  --table-header-bg:     rgba(5, 150, 105, 0.06);
  --table-header-color:  #065f46;
  --table-row-divider:   rgba(0, 0, 0, 0.06);
  --table-row-hover:     rgba(0, 0, 0, 0.02);

  /* ── Chart tokens ───────────────────────────────── */
  --chart-label:          #858585;
  --chart-grid:           rgba(0, 0, 0, 0.06);
  --chart-tooltip-bg:     #1e293b;
  --chart-tooltip-text:   #e2e8f0;

  /* ── Misc tokens ────────────────────────────────── */
  --progress-bg:          rgba(0, 0, 0, 0.08);

  /* ── Sidebar ────────────────────────────────────── */
  --sidebar-w:            64px;
  --sidebar-w-expanded:   240px;
  --sidebar-bg:           #FFFFFF;
  --sidebar-border:       rgba(0, 0, 0, 0.05);
  --sidebar-hover:        rgba(0, 0, 0, 0.04);
  --sidebar-active:       rgba(239, 140, 0, 0.10);

  /* ── Topbar ─────────────────────────────────────── */
  --topbar-h:             46px;
  --topbar-bg:            rgba(255, 255, 255, 0.95);
  --topbar-border:        rgba(0, 0, 0, 0.07);

  /* ── Shadows ────────────────────────────────────── */
  --shadow-sm:     0 1px 3px rgba(0, 0, 0, 0.07), 0 0 0 1px rgba(0, 0, 0, 0.04);
  --shadow-md:     0 4px 16px rgba(0, 0, 0, 0.10);
  --shadow-float:  0 4px 28px rgba(0, 0, 0, 0.08), 0 0 0 1px rgba(0, 0, 0, 0.05);
  --shadow-flyout: 0 12px 44px rgba(0, 0, 0, 0.13), 0 0 0 1px rgba(0, 0, 0, 0.07);

  /* ── Typography ─────────────────────────────────── */
  --font-base: 'Inter', system-ui, -apple-system, sans-serif;

  /* ── Radii ──────────────────────────────────────── */
  --radius-sm:   7px;
  --radius-md:   11px;
  --radius-lg:   14px;
  --radius-pill: 22px;

  /* ── Transitions ────────────────────────────────── */
  --t:      140ms ease;
  --t-slow: 260ms cubic-bezier(0.4, 0, 0.2, 1);

  /* ── Layout ─────────────────────────────────────── */
  --float: 12px;

  /* ── Legacy aliases (backward compat) ──────────── */
  --primary-color:    var(--color-primary);
  --secondary-color:  var(--color-secondary);
  --accent-color:     var(--color-primary);
  --dark-bg:          var(--bg);
  --card-bg:          var(--surface);
  --border-color:     var(--border);
  --card-shadow:      var(--shadow-sm);
  --color-success:    var(--c-success);
  --color-danger:     var(--c-danger);
  --gradient:         linear-gradient(135deg, #782CF6 0%, #EF8C00 100%);
}


/* ═══════════════════════════════════════════════════
   2. DESIGN TOKENS — DARK
   ═══════════════════════════════════════════════════ */
[data-theme="dark"] {

  /* ── State colors ───────────────────────────────── */
  --c-success:         #10b981;
  --c-success-dim:     rgba(16, 185, 129, 0.12);
  --c-success-border:  rgba(16, 185, 129, 0.26);
  --c-warning:         #f59e0b;
  --c-warning-dim:     rgba(245, 158, 11, 0.12);
  --c-warning-border:  rgba(245, 158, 11, 0.26);
  --c-danger:          #ef4444;
  --c-danger-dim:      rgba(239, 68, 68, 0.12);
  --c-danger-border:   rgba(239, 68, 68, 0.26);
  --c-info:            #3b82f6;
  --c-info-dim:        rgba(59, 130, 246, 0.12);
  --c-info-border:     rgba(59, 130, 246, 0.26);

  /* ── Brand dims (darker alphas for dark bg) ─────── */
  --color-primary-dim:      rgba(239, 140, 0, 0.12);
  --color-primary-border:   rgba(239, 140, 0, 0.28);
  --color-secondary-dim:    rgba(120, 44, 246, 0.12);
  --color-secondary-border: rgba(120, 44, 246, 0.28);

  /* ── Surfaces & text ────────────────────────────── */
  --bg:              #0D0D10;
  --bg-alt:          #080809;
  --surface:         #17171B;
  --surface-raised:  #202026;
  --border:          rgba(255, 255, 255, 0.07);
  --border-strong:   rgba(255, 255, 255, 0.12);
  --text-primary:    #FFFFFF;
  --text-secondary:  #BFBFBF;
  --text-muted:      #606068;

  /* ── Icon badge system ──────────────────────────── */
  --icon-bg-primary:        rgba(239, 140, 0,   0.14);
  --icon-border-primary:    rgba(239, 140, 0,   0.30);
  --icon-bg-secondary:      rgba(120, 44,  246, 0.12);
  --icon-border-secondary:  rgba(120, 44,  246, 0.28);
  --icon-bg-success:        rgba(16,  185, 129, 0.12);
  --icon-border-success:    rgba(16,  185, 129, 0.26);
  --icon-bg-warning:        rgba(245, 158, 11,  0.12);
  --icon-border-warning:    rgba(245, 158, 11,  0.26);
  --icon-bg-danger:         rgba(239, 68,  68,  0.12);
  --icon-border-danger:     rgba(239, 68,  68,  0.26);
  --icon-bg-info:           rgba(59,  130, 246, 0.12);
  --icon-border-info:       rgba(59,  130, 246, 0.26);
  --icon-bg-neutral:        rgba(148, 163, 184, 0.10);
  --icon-border-neutral:    rgba(148, 163, 184, 0.20);

  /* ── Table tokens ───────────────────────────────── */
  --table-header-bg:     rgba(16, 185, 129, 0.07);
  --table-header-color:  rgba(110, 231, 183, 0.85);
  --table-row-divider:   rgba(255, 255, 255, 0.05);
  --table-row-hover:     rgba(255, 255, 255, 0.03);

  /* ── Chart tokens ───────────────────────────────── */
  --chart-label:          #BFBFBF;
  --chart-grid:           rgba(255, 255, 255, 0.06);

  /* ── Misc tokens ────────────────────────────────── */
  --progress-bg:          rgba(255, 255, 255, 0.10);

  /* ── Sidebar ────────────────────────────────────── */
  --sidebar-bg:      #141418;
  --sidebar-border:  rgba(255, 255, 255, 0.06);
  --sidebar-hover:   rgba(255, 255, 255, 0.05);
  --sidebar-active:  rgba(239, 140, 0, 0.14);

  /* ── Topbar ─────────────────────────────────────── */
  --topbar-bg:       rgba(16, 16, 20, 0.94);
  --topbar-border:   rgba(255, 255, 255, 0.07);

  /* ── Shadows ────────────────────────────────────── */
  --shadow-sm:     0 1px 3px rgba(0, 0, 0, 0.5);
  --shadow-md:     0 4px 20px rgba(0, 0, 0, 0.6);
  --shadow-float:  0 8px 40px rgba(0, 0, 0, 0.5),  0 0 0 1px rgba(255, 255, 255, 0.05);
  --shadow-flyout: 0 24px 64px rgba(0, 0, 0, 0.6), 0 0 0 1px rgba(255, 255, 255, 0.08);

  /* ── Legacy aliases ─────────────────────────────── */
  --dark-bg:    var(--bg);
  --card-bg:    var(--surface);
  --card-shadow: var(--shadow-md);
  --border-color: var(--border);
}


/* ═══════════════════════════════════════════════════
   3. RESET
   ═══════════════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }


/* ═══════════════════════════════════════════════════
   7. TYPOGRAPHY — utility classes
   ═══════════════════════════════════════════════════ */
.eb-display {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: -0.025em;
  line-height: 1.15;
}

.eb-page-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: -0.015em;
  line-height: 1.3;
}

.eb-section-title {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.4;
}

.eb-card-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-primary);
  line-height: 1.4;
}

.eb-body {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--text-primary);
  line-height: 1.55;
}

.eb-body-2 {
  font-size: 0.875rem;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.55;
}

.eb-small {
  font-size: 0.8125rem;
  font-weight: 400;
  color: var(--text-secondary);
  line-height: 1.5;
}

.eb-caption {
  font-size: 0.75rem;
  font-weight: 400;
  color: var(--text-muted);
  line-height: 1.4;
}

.eb-label {
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--text-muted);
  line-height: 1;
}

.eb-kpi-lg {
  font-size: 2.25rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  font-variant-numeric: tabular-nums;
}
.eb-kpi {
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.1;
  font-variant-numeric: tabular-nums;
}
.eb-kpi-sm {
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: -0.015em;
  line-height: 1.2;
  font-variant-numeric: tabular-nums;
}


/* ═══════════════════════════════════════════════════
   8. CARDS
   ═══════════════════════════════════════════════════ */
.eb-card {
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  transition: border-color var(--t), box-shadow var(--t), transform var(--t);
}
.eb-card:hover {
  border-color: var(--color-primary-border);
  box-shadow: var(--shadow-md);
}
:root:not([data-theme="dark"]) .eb-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.08), 0 0 0 1px rgba(239,140,0,0.18);
  transform: translateY(-1px);
}

.eb-card-inner {
  background: var(--surface-raised);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 1rem;
}

.eb-card-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding-bottom: 0.75rem;
  margin-bottom: 0.75rem;
  border-bottom: 1px solid var(--border);
}


/* ═══════════════════════════════════════════════════
   9. ICON BADGES
   ═══════════════════════════════════════════════════ */
.eb-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2rem;
  height: 2rem;
  border-radius: var(--radius-sm);
  font-size: 0.875rem;
}
.eb-icon-sm { width: 1.625rem; height: 1.625rem; font-size: 0.75rem;   border-radius: 6px; }
.eb-icon-lg { width: 2.5rem;   height: 2.5rem;   font-size: 1.0625rem; border-radius: var(--radius-md); }

.eb-icon-primary   { background: var(--icon-bg-primary);   border: 1px solid var(--icon-border-primary);   color: var(--color-primary);   }
.eb-icon-secondary { background: var(--icon-bg-secondary); border: 1px solid var(--icon-border-secondary); color: var(--color-secondary); }
.eb-icon-success   { background: var(--icon-bg-success);   border: 1px solid var(--icon-border-success);   color: var(--c-success);       }
.eb-icon-warning   { background: var(--icon-bg-warning);   border: 1px solid var(--icon-border-warning);   color: var(--c-warning);       }
.eb-icon-danger    { background: var(--icon-bg-danger);    border: 1px solid var(--icon-border-danger);    color: var(--c-danger);        }
.eb-icon-info      { background: var(--icon-bg-info);      border: 1px solid var(--icon-border-info);      color: var(--c-info);          }
.eb-icon-neutral   { background: var(--icon-bg-neutral);   border: 1px solid var(--icon-border-neutral);   color: var(--text-muted);      }


/* ═══════════════════════════════════════════════════
   10. BADGES / TAGS
   ═══════════════════════════════════════════════════ */
.eb-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.2rem 0.55rem;
  border-radius: 9999px;
  font-size: 0.6875rem;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: 0.01em;
}
.eb-badge-primary   { background: var(--color-primary-dim);   color: var(--color-primary);   border: 1px solid var(--color-primary-border);   }
.eb-badge-secondary { background: var(--color-secondary-dim); color: var(--color-secondary); border: 1px solid var(--color-secondary-border); }
.eb-badge-success   { background: var(--c-success-dim);       color: var(--c-success);       border: 1px solid var(--c-success-border);       }
.eb-badge-warning   { background: var(--c-warning-dim);       color: var(--c-warning);       border: 1px solid var(--c-warning-border);       }
.eb-badge-danger    { background: var(--c-danger-dim);        color: var(--c-danger);        border: 1px solid var(--c-danger-border);        }
.eb-badge-info      { background: var(--c-info-dim);          color: var(--c-info);          border: 1px solid var(--c-info-border);          }
.eb-badge-neutral   { background: var(--icon-bg-neutral);     color: var(--text-secondary);  border: 1px solid var(--icon-border-neutral);    }


/* ═══════════════════════════════════════════════════
   11. BUTTONS
   ═══════════════════════════════════════════════════ */
.eb-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.5rem 1rem;
  border: none;
  border-radius: var(--radius-md);
  font-size: 0.875rem;
  font-weight: 600;
  font-family: var(--font-base);
  cursor: pointer;
  white-space: nowrap;
  line-height: 1;
  transition: background var(--t), color var(--t), box-shadow var(--t), transform var(--t);
}
.eb-btn:active { transform: translateY(1px); }
.eb-btn-sm { padding: 0.3rem 0.7rem; font-size: 0.8125rem; border-radius: var(--radius-sm); }
.eb-btn-lg { padding: 0.7rem 1.5rem; font-size: 0.9375rem; border-radius: var(--radius-lg); }

.eb-btn-primary { background: var(--color-primary); color: #0a0a0d; }
.eb-btn-primary:hover { background: var(--color-primary-hover); box-shadow: 0 4px 14px rgba(239,140,0,0.35); }

.eb-btn-secondary { background: var(--color-secondary); color: #ffffff; }
.eb-btn-secondary:hover { background: var(--color-secondary-hover); box-shadow: 0 4px 14px rgba(120,44,246,0.35); }

.eb-btn-ghost { background: var(--surface-raised); color: var(--text-secondary); border: 1px solid var(--border-strong); }
.eb-btn-ghost:hover { color: var(--text-primary); border-color: var(--color-primary-border); }

.eb-btn-danger { background: var(--c-danger-dim); color: var(--c-danger); border: 1px solid var(--c-danger-border); }
.eb-btn-danger:hover { background: var(--c-danger); color: white; box-shadow: 0 4px 14px rgba(239,68,68,0.35); }

.eb-btn-success { background: var(--c-success-dim); color: var(--c-success); border: 1px solid var(--c-success-border); }
.eb-btn-success:hover { background: var(--c-success); color: white; }

.eb-btn-warning { background: var(--c-warning-dim); color: var(--c-warning); border: 1px solid var(--c-warning-border); }
.eb-btn-warning:hover { background: var(--c-warning); color: white; }


/* ═══════════════════════════════════════════════════
   12. INPUTS
   ═══════════════════════════════════════════════════ */
.eb-input {
  background: var(--surface-raised);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-family: var(--font-base);
  color: var(--text-primary);
  width: 100%;
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
}
.eb-input::placeholder { color: var(--text-muted); }
.eb-input:focus {
  border-color: rgba(239, 140, 0, 0.50);
  box-shadow: 0 0 0 3px rgba(239, 140, 0, 0.10);
}
.eb-input option                                                     { color: var(--text-primary); background: var(--surface); }
input[type="date"].eb-input::-webkit-datetime-edit                   { color: var(--text-primary); }
input[type="date"].eb-input::-webkit-datetime-edit-fields-wrapper    { color: var(--text-primary); }


/* ═══════════════════════════════════════════════════
   13. TABLES
   ═══════════════════════════════════════════════════ */
.eb-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.8125rem;
  font-variant-numeric: tabular-nums;
}
.eb-table thead tr  { background: var(--table-header-bg); }
.eb-table thead th  {
  padding: 0.6rem 0.75rem;
  text-align: left;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--table-header-color);
  white-space: nowrap;
}
.eb-table tbody tr  { border-top: 1px solid var(--table-row-divider); transition: background var(--t); }
.eb-table tbody tr:hover { background: var(--table-row-hover); }
.eb-table td        { padding: 0.6rem 0.75rem; color: var(--text-primary); vertical-align: middle; }
.eb-table td.muted  { color: var(--text-muted); font-size: 0.75rem; }
.eb-table td.sec    { color: var(--text-secondary); }

[data-theme="dark"] td,
[data-theme="dark"] th { color: var(--text-primary); }


/* ═══════════════════════════════════════════════════
   14. PROGRESS BARS
   ═══════════════════════════════════════════════════ */
.eb-progress    { height: 6px;  background: var(--progress-bg); border-radius: 9999px; overflow: hidden; }
.eb-progress-md { height: 8px;  background: var(--progress-bg); border-radius: 9999px; overflow: hidden; }
.eb-progress-lg { height: 10px; background: var(--progress-bg); border-radius: 9999px; overflow: hidden; }

.eb-progress-fill         { height: 100%; border-radius: 9999px; transition: width 0.45s ease; }
.eb-progress-primary      { background: var(--color-primary);   }
.eb-progress-secondary    { background: var(--color-secondary); }
.eb-progress-success      { background: var(--c-success);       }
.eb-progress-warning      { background: var(--c-warning);       }
.eb-progress-danger       { background: var(--c-danger);        }
.eb-progress-info         { background: var(--c-info);          }


/* ═══════════════════════════════════════════════════
   16. LEGACY COMPONENT OVERRIDES
   ═══════════════════════════════════════════════════ */
.card-header {
  background: rgba(239, 140, 0, 0.04) !important;
}
.dashboard-card {
  border-color: var(--border) !important;
  background: var(--card-bg) !important;
  box-shadow: var(--shadow-sm);
}
:root:not([data-theme="dark"]) .dashboard-card:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,0.09), 0 0 0 1px rgba(239,140,0,0.22) !important;
  border-color: rgba(239,140,0,0.22) !important;
  transform: translateY(-1px);
}
