﻿/*
 * mygarage360 — Design System v3
 * Premium Automotive Dashboard · Tesla/Rivian-inspired
 * Matte dark surfaces · Amber accent · Mobile-first
 *
 * Fonts: load once per page via <link> to fonts.googleapis.com (not @import here —
 * duplicate @import + link blocked first paint and slowed every page load).
 */

:root {
  /* ── Surfaces — Matte Dark ──────────────────────────── */
  --ink:  #0F0F10;
  --s1:   #171717;
  --s2:   #1E1E1F;
  --s3:   #262627;
  --s4:   #2E2E2F;
  --s5:   #383838;

  /* Legacy navy aliases (backward compat) */
  --navy: #0B1F3A;

  /* ── Accent — Amber / Orange ────────────────────────── */
  --amber:       #F5A623;
  --amber-h:     #E8961A;
  --amber-d:     #D4860F;
  --amber-pale:  rgba(245,166,35,0.10);
  --amber-glow:  rgba(245,166,35,0.20);

  /* Backward-compat aliases */
  --signal:   #F5A623;
  --signal-h: #E8961A;
  --signal-d: #D4860F;
  --accent:   #F5A623;
  --ah:       #E8961A;
  --ad:       #D4860F;
  --a2:       #D4860F;
  --warn:     #F5A623;

  /* ── Status ─────────────────────────────────────────── */
  --ok:      #22C55E;
  --ok-bg:   rgba(34,197,94,0.10);
  --ok-bd:   rgba(34,197,94,0.22);
  --err:     #EF4444;
  --err-d:   #DC2626;
  --err-bg:  rgba(239,68,68,0.10);
  --err-bd:  rgba(239,68,68,0.22);
  --info:    #60A5FA;
  --info-bg: rgba(96,165,250,0.10);

  /* ── Text ───────────────────────────────────────────── */
  --tp: #F0F0F0;
  --ts: #9CA3AF;
  --tm: #6B7280;

  /* ── Borders ────────────────────────────────────────── */
  --bd:  rgba(255,255,255,0.07);
  --bds: rgba(255,255,255,0.12);
  --bdh: rgba(255,255,255,0.20);

  /* Legacy */
  --b: rgba(255,255,255,0.07);

  /* ── Typography ─────────────────────────────────────── */
  --fd: 'Plus Jakarta Sans', system-ui, -apple-system, sans-serif;
  --fm: 'JetBrains Mono', ui-monospace, monospace;

  /* ── Type scale ─────────────────────────────────────── */
  --fs-xs:  11px;
  --fs-sm:  12px;
  --fs-md:  14px;
  --fs-base:15px;
  --fs-lg:  16px;
  --fs-xl:  20px;
  --fs-2xl: 28px;

  /* ── Radius ─────────────────────────────────────────── */
  --r1: 6px;
  --r2: 10px;
  --r3: 14px;
  --r4: 18px;
  --r5: 24px;

  /* ── Shadows — Matte Depth ──────────────────────────── */
  --shadow-xs:    0 1px 3px rgba(0,0,0,0.40);
  --shadow-sm:    0 2px 8px rgba(0,0,0,0.50);
  --shadow-md:    0 6px 20px rgba(0,0,0,0.55);
  --shadow-lg:    0 16px 48px rgba(0,0,0,0.65);
  --shadow-amber: 0 4px 18px rgba(245,166,35,0.28);
  --shadow-amber-h: 0 8px 30px rgba(245,166,35,0.42);

  /* ── Paper / print ──────────────────────────────────── */
  --paper: #FAFAF7;
  --lane:  #E8E5DD;

  /* ── Motion ─────────────────────────────────────────── */
  --ease:  cubic-bezier(0.22, 1, 0.36, 1);
  --easeS: cubic-bezier(0.4, 0, 0.2, 1);
  --t1: 150ms;
  --t2: 220ms;
  --t3: 320ms;

  /* ── Spacing ────────────────────────────────────────── */
  --sp1: 8px;
  --sp2: 12px;
  --sp3: 16px;
  --sp4: 24px;
}

/* ══════════════════════════════════════════════════════
   BASE RESET
══════════════════════════════════════════════════════ */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

body {
  background: var(--ink);
  font-family: var(--fd);
  color: var(--tp);
  min-height: 100vh;
  font-size: var(--fs-md);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-tap-highlight-color: transparent;
  overflow-x: hidden;
}

/* Canvas omitted — scaling with max-width + height:auto breaks square QR renders */
img, video, svg { max-width: 100%; height: auto; }

/* iOS Safari zooms inputs whose font-size is < 16px on focus.
   Force min 16px on touch devices to prevent that. */
@media (max-width: 768px) {
  input, select, textarea, .finp {
    font-size: 16px !important;
  }
}

/* ══════════════════════════════════════════════════════
   AMBIENT GLOW — subtle background warmth
══════════════════════════════════════════════════════ */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 60% 35% at 50% -10%, rgba(245,166,35,0.06) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}

/* ══════════════════════════════════════════════════════
   NAVIGATION — Automotive header bar
══════════════════════════════════════════════════════ */
nav {
  position: sticky; top: 0; z-index: 200;
  background: rgba(15,15,16,0.96);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--bd);
  height: 56px;
  display: flex; align-items: center;
  padding: 0 20px;
  justify-content: space-between;
  gap: 12px;
}

/* Brand */
.nav-brand {
  display: flex; align-items: center; gap: 8px;
  text-decoration: none; flex-shrink: 0;
}
.nl-mark {
  width: 28px; height: 28px;
  background: linear-gradient(135deg, var(--amber), var(--amber-d));
  border-radius: 7px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 2px 10px rgba(245,166,35,0.30);
}
.nl-mark svg { width: 16px; height: 16px; }
.nl-word {
  font-size: 14px; font-weight: 700;
  color: var(--tp); letter-spacing: -0.2px;
}

/* Nav links */
.nav-links {
  display: flex; gap: 1px; flex: 1; justify-content: center;
}
.nlink {
  color: var(--ts);
  text-decoration: none;
  font-size: 13px; font-weight: 500;
  padding: 5px 11px;
  border-radius: 7px;
  transition: background var(--t1) var(--easeS), color var(--t1) var(--easeS);
  white-space: nowrap;
  min-height: 36px;
  display: inline-flex; align-items: center;
}
.nlink:hover { color: var(--tp); background: rgba(255,255,255,0.05); }
.nlink.on { color: var(--amber); background: var(--amber-pale); font-weight: 600; }
.nlink.sos {
  color: var(--err);
  border: 1px solid var(--err-bd);
  border-radius: 7px;
  /* Always keep the bordered SOS pill clear of whatever sits before it
     (Admin / Documents). The .nav-links gap is intentionally tight, so this
     gives the red SOS button its own breathing room without affecting the
     even spacing of the other text links. */
  margin-left: 8px;
}
.nlink.sos:hover { background: var(--err-bg); }

/* Nav right */
.nav-right {
  display: flex; align-items: center; gap: 6px; flex-shrink: 0;
}
.nav-profile-btn {
  display: flex; align-items: center; gap: 7px;
  background: var(--s2); border: 1px solid var(--bd);
  border-radius: 100px; padding: 4px 10px 4px 4px;
  cursor: pointer;
  transition: border-color var(--t1) var(--easeS), box-shadow var(--t1) var(--easeS);
  font-family: var(--fd);
  min-height: 36px;
}
.nav-profile-btn:hover {
  border-color: var(--bds);
  box-shadow: 0 0 0 2px var(--amber-pale);
}
.nav-avatar {
  width: 26px; height: 26px; border-radius: 50%;
  background: linear-gradient(135deg, var(--amber), var(--amber-d));
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 800; color: #0F0F10; flex-shrink: 0;
}
.nav-avatar.nav-avatar-cc {
  font-size: 8px; font-weight: 800; letter-spacing: -0.4px; line-height: 1;
}
.nav-cc { display: block; transform: scale(0.95); }
a.nav-profile-btn.nav-profile-link { text-decoration: none; color: inherit; }
.nav-profile-incomplete {
  border-color: rgba(245,166,35,0.40) !important;
}
.nav-display-text { font-size: 12px; font-weight: 600; color: var(--tp); }
.nav-add-hint {
  display: inline-block; margin-left: 5px;
  font-size: 10px; font-weight: 700; color: var(--amber);
}
.nav-car-sw {
  display: flex; align-items: center; gap: 5px;
  background: var(--s2); border: 1px solid var(--bd);
  border-radius: 7px; padding: 4px 9px;
  cursor: pointer; font-size: 12px; font-weight: 500; color: var(--ts);
  transition: all var(--t1) var(--easeS);
  max-width: 150px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  min-height: 36px; font-family: var(--fd);
}
.nav-car-sw:hover { border-color: var(--bds); color: var(--tp); }
.nav-out {
  background: none; border: 1px solid var(--bd);
  color: var(--ts); padding: 4px 12px 4px 10px;
  border-radius: 7px; cursor: pointer;
  font-size: 12px; font-weight: 600; font-family: var(--fd);
  display: inline-flex; align-items: center; gap: 5px;
  transition: all var(--t1) var(--easeS);
  min-height: 36px;
}
.nav-out svg { opacity: 0.6; transition: opacity var(--t1) var(--easeS); flex-shrink: 0; }
.nav-out:hover { border-color: rgba(239,68,68,.4); color: #f87171; background: rgba(239,68,68,.06); }
.nav-out:hover svg { opacity: 1; }
@media (max-width: 480px) { .nav-out-label { display: none; } .nav-out { padding: 4px 8px; } }

/* ══════════════════════════════════════════════════════
   REUSABLE COMPONENTS
══════════════════════════════════════════════════════ */

/* -- AppCard ----------------------------------------- */
.app-card {
  background: var(--s1);
  border: 1px solid var(--bd);
  border-radius: var(--r4);
  box-shadow: var(--shadow-sm);
  transition: border-color var(--t2) var(--ease), transform var(--t2) var(--ease), box-shadow var(--t2) var(--ease);
}
.app-card:hover {
  border-color: var(--bds);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

/* -- GlowButton ------------------------------------- */
.glow-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 7px;
  background: linear-gradient(135deg, var(--amber), var(--amber-d));
  color: #0F0F10; border: none; border-radius: var(--r3);
  font-family: var(--fd); font-size: 14px; font-weight: 700;
  padding: 12px 20px; cursor: pointer;
  box-shadow: var(--shadow-amber);
  transition: transform var(--t2) var(--ease), box-shadow var(--t2) var(--ease);
}
.glow-btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-amber-h); }
.glow-btn:active { transform: translateY(0); }
.glow-btn:disabled { opacity: 0.50; cursor: not-allowed; transform: none; box-shadow: none; }

/* Ghost variant */
.glow-btn-ghost {
  background: transparent;
  border: 1px solid var(--bds);
  color: var(--ts);
  box-shadow: none;
}
.glow-btn-ghost:hover {
  border-color: var(--bdh);
  color: var(--tp);
  background: rgba(255,255,255,0.04);
  transform: translateY(-1px);
  box-shadow: var(--shadow-sm);
}

/* Danger variant */
.glow-btn-danger {
  background: linear-gradient(135deg, #EF4444, #DC2626);
  color: #fff;
  box-shadow: 0 4px 18px rgba(239,68,68,0.28);
}
.glow-btn-danger:hover { box-shadow: 0 8px 28px rgba(239,68,68,0.40); }

/* -- Vehicle Type Badges ----------------------------- */
.vtype-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.5px;
  padding: 2px 8px; border-radius: 20px;
  white-space: nowrap; flex-shrink: 0;
}
.vcat-badge {
  display: inline-flex; align-items: center;
  font-size: 9px; font-weight: 700; letter-spacing: 1px;
  text-transform: uppercase;
  padding: 2px 7px; border-radius: 4px;
  white-space: nowrap;
}

/* -- StatusChip -------------------------------------- */
.chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 10px; font-weight: 700; letter-spacing: 0.8px;
  text-transform: uppercase;
  padding: 3px 9px; border-radius: 100px;
  border: 1px solid;
}
.chip-verified {
  color: var(--ok); background: var(--ok-bg); border-color: var(--ok-bd);
}
.chip-active {
  color: var(--amber); background: var(--amber-pale); border-color: var(--amber-glow);
}
.chip-premium {
  color: #F0C040;
  background: rgba(240,192,64,0.10);
  border-color: rgba(240,192,64,0.25);
}
.chip-emergency {
  color: var(--err); background: var(--err-bg); border-color: var(--err-bd);
}
.chip-expired {
  color: var(--tm); background: rgba(107,114,128,0.10); border-color: rgba(107,114,128,0.20);
}
.chip-owner {
  color: var(--info); background: var(--info-bg); border-color: rgba(96,165,250,0.22);
}
.chip-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: currentColor; animation: chip-pulse 2s infinite;
}
@keyframes chip-pulse { 0%,100%{opacity:1} 50%{opacity:.35} }

/* -- Glass Modal ------------------------------------ */
.glass-modal {
  background: rgba(23,23,23,0.88);
  backdrop-filter: blur(20px) saturate(1.6);
  -webkit-backdrop-filter: blur(20px) saturate(1.6);
  border: 1px solid rgba(255,255,255,0.09);
  border-radius: var(--r5);
  box-shadow: var(--shadow-lg), 0 0 0 1px rgba(0,0,0,0.5);
}

/* -- DashSection header ----------------------------- */
.dash-sec-hdr {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.dash-sec-title {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 1.5px; color: var(--tm);
}
.dash-sec-link {
  font-size: 12px; font-weight: 500; color: var(--ts);
  text-decoration: none;
  transition: color var(--t1) var(--easeS);
}
.dash-sec-link:hover { color: var(--amber); }

/* -- Divider ---------------------------------------- */
.divider {
  height: 1px; background: var(--bd); margin: 16px 0;
}

/* -- Form inputs ------------------------------------ */
.finp {
  width: 100%;
  background: var(--s2);
  border: 1px solid var(--bd);
  border-radius: var(--r2);
  padding: 11px 13px;
  color: var(--tp);
  font-size: 14px; font-family: var(--fd);
  outline: none;
  transition: border-color var(--t1) var(--easeS), box-shadow var(--t1) var(--easeS);
}
.finp:focus {
  border-color: var(--amber);
  box-shadow: 0 0 0 3px var(--amber-pale);
}
.finp::placeholder { color: var(--tm); }

/* ══════════════════════════════════════════════════════
   FOCUS RINGS — accessibility
══════════════════════════════════════════════════════ */
a:focus-visible,
button:focus-visible,
select:focus-visible,
input:focus-visible,
textarea:focus-visible {
  outline: 2px solid var(--amber);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ══════════════════════════════════════════════════════
   SCROLLBAR — minimal dark
══════════════════════════════════════════════════════ */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--s4); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--s5); }

/* ══════════════════════════════════════════════════════
   NAVIGATION — Mobile drawer (hamburger)
══════════════════════════════════════════════════════ */
.nav-toggle {
  display: none;
  background: var(--s2);
  border: 1px solid var(--bd);
  color: var(--tp);
  width: 36px; height: 36px;
  border-radius: 8px;
  align-items: center; justify-content: center;
  cursor: pointer; flex-shrink: 0;
  padding: 0;
  transition: border-color var(--t1) var(--easeS), background var(--t1) var(--easeS);
}
.nav-toggle:hover { border-color: var(--bds); background: var(--s3); }
.nav-toggle .nt-bars,
.nav-toggle .nt-bars::before,
.nav-toggle .nt-bars::after {
  display: block;
  width: 18px; height: 2px;
  background: var(--tp);
  border-radius: 2px;
  position: relative;
  transition: transform var(--t1) var(--easeS), opacity var(--t1) var(--easeS), top var(--t1) var(--easeS);
}
.nav-toggle .nt-bars::before,
.nav-toggle .nt-bars::after {
  content: ""; position: absolute; left: 0;
}
.nav-toggle .nt-bars::before { top: -6px; }
.nav-toggle .nt-bars::after  { top:  6px; }
.nav-toggle.open .nt-bars { background: transparent; }
.nav-toggle.open .nt-bars::before { top: 0; transform: rotate(45deg); }
.nav-toggle.open .nt-bars::after  { top: 0; transform: rotate(-45deg); }

/* Compact nav links at medium widths so 7 items fit without wrapping */
@media (max-width: 1060px) {
  .nav-links { gap: 0px; }
  .nlink { padding: 5px 8px; font-size: 12px; }
}

@media (max-width: 720px) {
  nav { padding: 0 14px; height: 52px; gap: 8px; justify-content: flex-start; }
  /* With .nav-links hidden, only brand + toggle + .nav-right remain — space-between was centering the hamburger */
  .nav-right { margin-left: auto; }
  .nav-toggle { display: inline-flex; }

  .nav-links {
    display: none;
    position: absolute;
    top: 100%; left: 0; right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 4px;
    padding: 10px 12px 14px;
    background: rgba(15,15,16,0.98);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-bottom: 1px solid var(--bd);
    box-shadow: 0 12px 32px rgba(0,0,0,0.45);
    max-height: calc(100vh - 52px);
    overflow-y: auto;
  }
  .nav-links.open { display: flex; }
  .nav-links .nlink {
    width: 100%;
    padding: 12px 14px;
    font-size: 14px;
    border-radius: 9px;
    min-height: 44px;
  }
  .nav-links .nlink.sos { justify-content: flex-start; margin-left: 0; }

  /* Tighten the right-side cluster so brand + profile + hamburger fit */
  .nav-right { gap: 4px; }
  .nav-display-text { max-width: 90px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .nl-word { font-size: 13px; }
}

@media (max-width: 380px) {
  .nl-word { display: none; }
  .nav-display-text { display: none; }
  .nav-profile-btn { padding: 4px; }
}
