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

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

a { color: var(--color-primary-600); text-decoration: none; }
a:hover { text-decoration: underline; }

h1, h2, h3, h4 { font-family: var(--font-sans); font-weight: 700; margin: 0 0 var(--space-3); line-height: 1.2; letter-spacing: -0.01em; }
h1 { font-size: var(--text-3xl); }
h2 { font-size: var(--text-2xl); }
h3 { font-size: var(--text-xl); }

/* === Layout app === */
.app { display: flex; min-height: 100vh; }
.sidebar {
  width: var(--sidebar-width);
  background: var(--color-primary);
  color: #fff;
  padding: var(--space-6) var(--space-4);
  position: fixed; top: 0; left: 0; bottom: 0;
  overflow-y: auto;
}
.sidebar .brand {
  font-family: var(--font-sans);
  font-size: var(--text-xl);
  font-weight: 700;
  color: #fff;
  margin-bottom: var(--space-8);
  display: block;
  text-decoration: none;
}
.sidebar .brand span { display:block; font-size: var(--text-sm); font-family: var(--font-sans); font-weight: 400; color: rgba(255,255,255,0.7); }
.sidebar nav a {
  display: flex; align-items: center; gap: var(--space-3);
  color: rgba(255,255,255,0.85);
  padding: var(--space-3) var(--space-3);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  margin-bottom: var(--space-1);
  text-decoration: none;
}
.sidebar nav a:hover { background: rgba(255,255,255,0.08); color: #fff; text-decoration: none; }
.sidebar nav a.active { background: var(--color-primary-600); color: #fff; }
.sidebar .user-block { margin-top: var(--space-8); padding-top: var(--space-4); border-top: 1px solid rgba(255,255,255,0.15); font-size: var(--text-sm); }
.sidebar .user-block a { color: var(--color-accent); }

.main { flex: 1; margin-left: var(--sidebar-width); padding: var(--space-8); max-width: 100%; }

/* === Cards === */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  margin-bottom: var(--space-4);
}
.card h2, .card h3 { margin-top: 0; }

/* === Botones === */
.btn {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  font-family: var(--font-sans); font-size: var(--text-sm); font-weight: 500;
  cursor: pointer;
  transition: all 0.15s ease;
  text-decoration: none;
}
.btn-primary { background: var(--color-primary); color: #fff; }
.btn-primary:hover { background: var(--color-primary-600); text-decoration: none; }
.btn-accent { background: var(--color-accent); color: #1A1A1A; }
.btn-accent:hover { background: var(--color-accent-dark); color: #fff; text-decoration: none; }
.btn-ghost { background: transparent; color: var(--color-text); border-color: var(--color-border); }
.btn-ghost:hover { background: var(--color-surface-muted); text-decoration: none; }
.btn-danger { background: var(--color-error); color: #fff; }

/* === Forms === */
.form-group { margin-bottom: var(--space-4); }
.form-group label { display: block; font-size: var(--text-sm); font-weight: 500; color: var(--color-text-muted); margin-bottom: var(--space-2); }
.form-group input, .form-group textarea, .form-group select {
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  font-family: var(--font-sans); font-size: var(--text-base);
  background: var(--color-surface);
  color: var(--color-text);
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(27, 67, 50, 0.1);
}

/* === Chips / badges === */
.chip { display: inline-block; padding: 2px var(--space-3); border-radius: var(--radius-full); font-size: var(--text-xs); font-weight: 500; }
.chip-success { background: var(--color-success-bg); color: var(--color-success); }
.chip-error { background: var(--color-error-bg); color: var(--color-error); }
.chip-warning { background: var(--color-warning-bg); color: var(--color-warning); }
.chip-info { background: var(--color-info-bg); color: var(--color-info); }

/* === Tablas === */
.table { width: 100%; border-collapse: collapse; background: var(--color-surface); border-radius: var(--radius-md); overflow: hidden; }
.table thead { background: var(--color-surface-muted); position: sticky; top: 0; }
.table th, .table td { padding: var(--space-3) var(--space-4); text-align: left; border-bottom: 1px solid var(--color-border); font-size: var(--text-sm); }
.table th { font-weight: 600; color: var(--color-text-muted); font-size: var(--text-xs); text-transform: uppercase; letter-spacing: 0.04em; }
.table tbody tr:hover { background: var(--color-surface-muted); }
.table tbody tr:nth-child(even) { background: rgba(247,246,242,0.4); }

/* === Alerts === */
.alert { padding: var(--space-3) var(--space-4); border-radius: var(--radius-md); margin-bottom: var(--space-4); font-size: var(--text-sm); }
.alert-error { background: var(--color-error-bg); color: var(--color-error); }
.alert-success { background: var(--color-success-bg); color: var(--color-success); }

/* === Login === */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-600) 100%); padding: var(--space-4); }
.login-card { background: var(--color-surface); padding: var(--space-10); border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); width: 100%; max-width: 420px; }
.login-card h1 { font-family: var(--font-sans); font-size: var(--text-3xl); color: var(--color-primary); margin-bottom: var(--space-2); }
.login-card .subtitle { color: var(--color-text-muted); margin-bottom: var(--space-8); font-size: var(--text-sm); }
.login-card .btn-primary { width: 100%; justify-content: center; padding: var(--space-3); }

/* === Dashboard KPI === */
.kpi-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: var(--space-4); margin-bottom: var(--space-6); }
.kpi { background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); padding: var(--space-5); }
.kpi .label { font-size: var(--text-xs); font-weight: 500; text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); margin-bottom: var(--space-2); }
.kpi .value { font-family: var(--font-sans); font-size: var(--text-3xl); font-weight: 600; color: var(--color-primary); }

/* === Responsive === */
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); transition: transform 0.2s; z-index: 100; }
  .sidebar.open { transform: translateX(0); }
  .main { margin-left: 0; padding: var(--space-4); }
}

/* === Pulido adicional === */
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-sm); }
.btn:active { transform: translateY(0); }
.kpi { transition: transform 0.15s ease, box-shadow 0.15s ease; }
.kpi:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }

/* Scrollbar más sutil */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: var(--color-bg); }
::-webkit-scrollbar-thumb { background: var(--color-border-strong); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--color-text-faint); }

/* Selection */
::selection { background: var(--color-primary); color: #fff; }

/* Focus visible */
:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; border-radius: var(--radius-sm); }
button:focus, input:focus, select:focus, textarea:focus { outline: none; }

/* Code tag styling consistente */
code { font-family: ui-monospace, 'SF Mono', Monaco, Consolas, 'Liberation Mono', monospace; font-size: 0.9em; background: var(--color-surface-muted); padding: 1px 6px; border-radius: 4px; }

/* Card hover sutil en las que son clickeables */
.card a { text-decoration: none; }

/* Tables pulido */
.table tbody tr { transition: background 0.15s; }
.table code { background: transparent; padding: 0; }
