/* =========================================================
   SABECORT v3 — Design Tokens
   Premium B2B automotive / tuning — dark-first with light mode
   ========================================================= */

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

:root {
  /* ── Brand ─────────────────────────────────────────── */
  --brand-red:        #E11D2A;   /* refinado: más saturado, menos carmesí */
  --brand-red-hot:    #FF2E3E;
  --brand-red-deep:   #9A0E19;
  --brand-red-muted:  rgba(225, 29, 42, 0.12);
  --brand-red-glow:   rgba(225, 29, 42, 0.35);

  /* ── Neutrals — warm-cool blend (zinc-slate tuned) ── */
  --ink-0:   #FFFFFF;
  --ink-50:  #F7F7F8;
  --ink-100: #EDEDF0;
  --ink-200: #D9D9DE;
  --ink-300: #B7B7BF;
  --ink-400: #8A8A95;
  --ink-500: #5F5F6A;
  --ink-600: #3E3E48;
  --ink-700: #262630;
  --ink-800: #18181F;
  --ink-850: #101016;
  --ink-900: #0A0A0E;
  --ink-950: #050507;

  /* ── Semantic (shared light/dark) ─────────────────── */
  --ok:      #12B76A;
  --ok-mute: rgba(18, 183, 106, 0.14);
  --warn:    #F79009;
  --warn-mute: rgba(247, 144, 9, 0.14);
  --bad:     #F04438;
  --bad-mute: rgba(240, 68, 56, 0.14);
  --info:    #2970FF;
  --info-mute: rgba(41, 112, 255, 0.14);
  --violet:  #7A5AF8;
  --violet-mute: rgba(122, 90, 248, 0.14);

  /* ── Partners ─────────────────────────────────────── */
  --texa:    #1B3A6B;
  --texa-accent: #2E5DB0;
  --dimsport: #E30613;

  /* ── Type ─────────────────────────────────────────── */
  --font-display: 'SabecortSport', 'Inter', system-ui, sans-serif;
  --font-sans:    'Inter', system-ui, -apple-system, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;

  /* ── Radius scale — controlled by tweak ───────────── */
  --radius-scale: 1;
  --r-xs: calc(2px  * var(--radius-scale));
  --r-sm: calc(4px  * var(--radius-scale));
  --r-md: calc(8px  * var(--radius-scale));
  --r-lg: calc(12px * var(--radius-scale));
  --r-xl: calc(16px * var(--radius-scale));
  --r-pill: 999px;

  /* ── Density scale (line-height + paddings) ────── */
  --density: 1;        /* 0.85 compact, 1 normal, 1.15 comfy */

  /* ── Shadows ──────────────────────────────────────── */
  --shadow-1: 0 1px 2px rgba(0,0,0,.08), 0 0 0 1px rgba(0,0,0,.04);
  --shadow-2: 0 4px 12px rgba(0,0,0,.10), 0 0 0 1px rgba(0,0,0,.05);
  --shadow-3: 0 16px 44px rgba(0,0,0,.16), 0 0 0 1px rgba(0,0,0,.06);
  --shadow-glow: 0 0 0 3px var(--brand-red-glow);

  /* ── Elevation on dark ────────────────────────────── */
  --elev-dark-1: inset 0 1px 0 rgba(255,255,255,.04);
  --elev-dark-2: inset 0 1px 0 rgba(255,255,255,.06), 0 1px 0 rgba(0,0,0,.4);
}

/* ────────────────────────────────────────────────────
   Theme: DARK (default premium automotive)
   ──────────────────────────────────────────────────── */
[data-theme="dark"], :root {
  --bg:        var(--ink-950);
  --bg-1:      var(--ink-900);
  --bg-2:      var(--ink-850);
  --bg-3:      var(--ink-800);
  --bg-hover:  var(--ink-700);
  --surface:   var(--ink-850);
  --surface-2: var(--ink-800);
  --surface-3: var(--ink-700);
  --fg:        var(--ink-50);
  --fg-2:      var(--ink-300);
  --fg-3:      var(--ink-400);
  --fg-4:      var(--ink-500);
  --border:    rgba(255,255,255,.07);
  --border-2:  rgba(255,255,255,.12);
  --border-strong: rgba(255,255,255,.18);
  --accent:    var(--brand-red);
  --accent-fg: #FFFFFF;
  --grid-line: rgba(255,255,255,.035);
  color-scheme: dark;
}

[data-theme="light"] {
  --bg:        #FAFAFB;
  --bg-1:      #F2F2F4;
  --bg-2:      #ECECEF;
  --bg-3:      #E5E5E9;
  --bg-hover:  #EDEDF0;
  --surface:   #FFFFFF;
  --surface-2: #F7F7F8;
  --surface-3: #EEEEF1;
  --fg:        #0A0A0E;
  --fg-2:      #3E3E48;
  --fg-3:      #5F5F6A;
  --fg-4:      #8A8A95;
  --border:    rgba(10,10,14,.08);
  --border-2:  rgba(10,10,14,.14);
  --border-strong: rgba(10,10,14,.22);
  --accent:    var(--brand-red);
  --accent-fg: #FFFFFF;
  --grid-line: rgba(10,10,14,.04);
  color-scheme: light;
}

/* ────────────────────────────────────────────────────
   Base reset + typography
   ──────────────────────────────────────────────────── */
*,*::before,*::after { box-sizing: border-box; }
html,body { margin:0; padding:0; height:100%; }

body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: "ss01","cv11";
  font-size: 14px;
  line-height: 1.5;
  overscroll-behavior: none;
}

/* Display type — used for section titles & big numbers */
.display {
  font-family: var(--font-display);
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.mono  { font-family: var(--font-mono); }
.eyebrow {
  font-family: var(--font-mono);
  font-size: 10.5px;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--fg-4);
}

h1,h2,h3,h4 { margin: 0; font-weight: 600; letter-spacing: -0.01em; }
h1 { font-size: 28px; }
h2 { font-size: 22px; }
h3 { font-size: 17px; }
h4 { font-size: 14px; }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

hr { border: 0; height: 1px; background: var(--border); margin: 0; }

::selection { background: var(--brand-red); color: #fff; }

/* ────────────────────────────────────────────────────
   Scrollbars
   ──────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--border-2);
  border-radius: var(--r-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--border-strong); background-clip: padding-box; }

/* ────────────────────────────────────────────────────
   Primitives
   ──────────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-1);
}
.card-flush {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  overflow: hidden;
}

.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: var(--r-md);
  font-size: 13px;
  font-weight: 500;
  transition: all .15s;
  border: 1px solid transparent;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-0.5px); }
.btn-primary {
  background: var(--brand-red);
  color: #fff;
  box-shadow: 0 1px 0 rgba(0,0,0,.15), inset 0 1px 0 rgba(255,255,255,.18);
}
.btn-primary:hover { background: var(--brand-red-hot); box-shadow: 0 4px 14px var(--brand-red-glow); }
.btn-ghost {
  background: transparent;
  color: var(--fg);
  border-color: var(--border-2);
}
.btn-ghost:hover { background: var(--surface-2); border-color: var(--border-strong); }
.btn-subtle {
  background: var(--surface-2);
  color: var(--fg);
}
.btn-subtle:hover { background: var(--surface-3); }

/* Pill / tag */
.tag {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 2px 8px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  background: var(--surface-2);
  color: var(--fg-2);
  border: 1px solid var(--border);
  line-height: 1.6;
}
.tag-ok   { background: var(--ok-mute);   color: var(--ok);   border-color: var(--ok-mute); }
.tag-warn { background: var(--warn-mute); color: var(--warn); border-color: var(--warn-mute); }
.tag-bad  { background: var(--bad-mute);  color: var(--bad);  border-color: var(--bad-mute); }
.tag-info { background: var(--info-mute); color: var(--info); border-color: var(--info-mute); }
.tag-violet { background: var(--violet-mute); color: var(--violet); border-color: var(--violet-mute); }
.tag-accent { background: var(--brand-red-muted); color: var(--brand-red); border-color: var(--brand-red-muted); }

/* Racing stripe divider */
.stripe {
  height: 3px;
  background: linear-gradient(90deg,
    transparent 0, var(--brand-red) 10%, var(--brand-red) 38%,
    var(--ink-100) 38%, var(--ink-100) 50%, transparent 50%);
  background-size: 200% 100%;
}

/* Grid backdrop */
.grid-bg {
  background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 32px 32px;
}

/* Focus ring */
*:focus-visible {
  outline: 2px solid var(--brand-red);
  outline-offset: 2px;
  border-radius: var(--r-sm);
}

/* Utilities */
.row { display: flex; align-items: center; gap: 12px; }
.col { display: flex; flex-direction: column; gap: 12px; }
.between { justify-content: space-between; }
.gap-2 { gap: 8px; }
.gap-3 { gap: 12px; }
.gap-4 { gap: 16px; }
.gap-6 { gap: 24px; }
.mt-auto { margin-top: auto; }
.grow { flex: 1; min-width: 0; }
.truncate { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hide-scroll::-webkit-scrollbar { display: none; }

/* Sabecort display font — hosted locally */
@font-face {
  font-family: 'SabecortSport';
  src: url('/static/fonts/SabecortSport-Bold.ttf') format('truetype');
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
