/**
 * SwingVault Premium Design System (Phase 1 + 2)
 * Loads after inline app styles + app-shell.css — elevates tokens, motion, depth.
 */

:root {
  /* Motion */
  --sv-ease: cubic-bezier(0.16, 1, 0.3, 1);
  --sv-ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --sv-dur-fast: 0.15s;
  --sv-dur: 0.18s;
  --sv-dur-slow: 0.65s;

  /* Type scale (1.25 major third) */
  --sv-text-xs: 0.6875rem;
  --sv-text-sm: 0.8125rem;
  --sv-text-base: 0.9375rem;
  --sv-text-lg: 1.125rem;
  --sv-text-xl: 1.375rem;
  --sv-text-2xl: 1.75rem;

  /* 8px spacing grid */
  --sv-space-1: 8px;
  --sv-space-2: 16px;
  --sv-space-3: 24px;
  --sv-space-4: 32px;
  --sv-space-6: 48px;
  --sv-space-8: 64px;
  --sv-space-12: 96px;
  --sv-space-16: 128px;
  --sv-space-section: clamp(64px, 12vw, 128px);

  /* Elevation */
  --sv-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.24), 0 0 0 1px rgba(255, 255, 255, 0.03);
  --sv-shadow-md: 0 8px 24px rgba(0, 0, 0, 0.35), 0 2px 6px rgba(0, 0, 0, 0.2);
  --sv-shadow-lg: 0 24px 48px rgba(0, 0, 0, 0.45), 0 8px 16px rgba(0, 0, 0, 0.25);
  --sv-shadow-glow: 0 0 0 1px rgba(200, 164, 90, 0.12), 0 12px 40px rgba(200, 164, 90, 0.08);

  /* Glass */
  --sv-glass: rgba(14, 18, 21, 0.82);
  --sv-glass-border: rgba(255, 255, 255, 0.06);
  --sv-blur: 16px;
}

/* ── Global interactive polish ───────────────────────────────────────────── */
.hbtn,
.tb,
.sbb,
.pb,
.pcb,
.prl:not(.unavail),
.stb,
.mob-q-btn,
.mob-tool-btn,
.mob-mark-btn,
.folder-note-open-btn,
.fs-btn,
.ndp-btn,
.ndp-save,
.qub-btn,
.solo-chip {
  transition:
    color var(--sv-dur) var(--sv-ease),
    background var(--sv-dur) var(--sv-ease),
    border-color var(--sv-dur) var(--sv-ease),
    transform var(--sv-dur-fast) var(--sv-ease),
    opacity var(--sv-dur-fast) var(--sv-ease);
}

.hbtn:hover,
.tb:hover,
.sbb:hover {
  box-shadow: var(--sv-shadow-sm);
}

.hbtn.gold:hover {
  box-shadow: var(--sv-shadow-glow);
}

.pc,
.pr,
.nb-entry,
.folder-note-row,
.swing-row,
.or,
.feat-card,
.plan-card,
.hai-card {
  transition:
    background var(--sv-dur) var(--sv-ease),
    border-color var(--sv-dur) var(--sv-ease),
    transform var(--sv-dur-fast) var(--sv-ease);
}

.pc:hover {
  box-shadow: var(--sv-shadow-md);
  border-color: rgba(200, 164, 90, 0.2);
}

/* Header & chrome — glass, soft edge */
.hdr {
  background: var(--sv-glass);
  backdrop-filter: blur(var(--sv-blur));
  -webkit-backdrop-filter: blur(var(--sv-blur));
  border-bottom-color: var(--sv-glass-border);
  box-shadow: var(--sv-shadow-sm);
}

.toolbar {
  background: linear-gradient(180deg, var(--s1) 0%, rgba(14, 18, 21, 0.98) 100%);
}

.side {
  background: var(--sv-glass);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-left-color: var(--sv-glass-border);
}

/* Panels — depth without harsh borders */
.pan {
  border-color: rgba(255, 255, 255, 0.05);
  box-shadow: var(--sv-shadow-md);
}

.ph {
  background: rgba(14, 18, 21, 0.92);
  border-bottom-color: var(--sv-glass-border);
}

/* Modals */
.modal,
#loadChooser,
#compModal .modal-box,
.ndp-overlay,
.mob-sheet,
.mob-file-inner {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.modal-box,
#loadChooser > div,
.comp-inner {
  box-shadow: var(--sv-shadow-lg);
  border: 1px solid var(--sv-glass-border);
}

/* Inputs */
.banner,
.plbl,
.srch input,
.nb-input,
.ndp-input,
.ndp-textarea,
input[type="text"],
input[type="number"],
select.hbtn {
  transition:
    border-color var(--sv-dur) var(--sv-ease),
    background var(--sv-dur) var(--sv-ease);
}

.banner:focus,
.plbl:focus,
.srch input:focus,
.nb-input:focus,
.ndp-input:focus,
.ndp-textarea:focus {
  box-shadow: 0 0 0 2px rgba(200, 164, 90, 0.2);
}

/* Notebook & folder — breathing room */
.nb-entry,
.folder-note-row {
  border-radius: 10px;
  margin-bottom: 2px;
}

.folder-view,
#folder-swings {
  padding-bottom: var(--sv-space-4);
}

.swing-row {
  padding: 10px 12px;
  gap: 10px;
}

.swing-info {
  padding-right: var(--sv-space-2);
}

/* Player grid cards */
.pc {
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--sv-glass-border);
  background: linear-gradient(165deg, var(--s2) 0%, var(--s1) 100%);
}

/* Pro rows */
.pr:hover {
  background: rgba(200, 164, 90, 0.04);
}

/* Toast */
.toast {
  box-shadow: var(--sv-shadow-lg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Mobile chrome */
.mob-home-chrome {
  background: var(--sv-glass);
  backdrop-filter: blur(var(--sv-blur));
  -webkit-backdrop-filter: blur(var(--sv-blur));
  border-top: 1px solid var(--sv-glass-border);
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.35);
}

.mob-tabbar {
  background: var(--sv-glass);
  backdrop-filter: blur(var(--sv-blur));
  -webkit-backdrop-filter: blur(var(--sv-blur));
}

/* Thumbnails — lazy load via loading="lazy" on <img> in renderFolder/renderPlayers */
img.swing-thumb,
img.pc-thumb {
  object-fit: cover;
}

/* Desktop — generous section rhythm in notebook modals */
@media (min-width: 601px) {
  .ndp-box,
  .modal-box {
    padding: var(--sv-space-8);
  }

  .nb-wrap {
    padding: var(--sv-space-6);
  }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}
