/* ============================================================
   TRACKR — Ultra Premium UI
   3D · Glassmorphism · Scroll FX · Micro-interactions
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300&family=DM+Mono:wght@400;500&display=swap');

/* ── Dark theme (default) ── */
:root {
  --bg-primary: #0a0a12;
  --bg-secondary: #0f0f1c;
  --bg-card: #13132a;
  --bg-card-hover: #191932;
  --bg-sidebar: #07070d;
  --bg-glass: rgba(19,19,42,0.78);
  --bg-glass-light: rgba(255,255,255,0.04);

  --text-primary: #eeedf0;
  --text-secondary: #8e8ca8;
  --text-muted: #4a4860;
  --text-inverse: #0a0a12;
  --text-sidebar: rgba(238,237,240,0.8);

  --accent: #f0c84a;
  --accent-light: #ffd966;
  --accent-dark: #c9a82a;
  --accent-bg: rgba(240,200,74,0.08);
  --accent-glow: rgba(240,200,74,0.3);
  --accent-glow-strong: rgba(240,200,74,0.55);

  --purple: #a78bfa;
  --purple-bg: rgba(167,139,250,0.08);
  --cyan: #22d3ee;
  --cyan-bg: rgba(34,211,238,0.08);

  --danger: #f87171;
  --danger-bg: rgba(248,113,113,0.1);
  --success: #4ade80;
  --success-bg: rgba(74,222,128,0.1);
  --warning: #fb923c;
  --warning-bg: rgba(251,146,60,0.1);
  --info: #60a5fa;
  --info-bg: rgba(96,165,250,0.1);

  --border: rgba(255,255,255,0.07);
  --border-subtle: rgba(255,255,255,0.04);
  --border-strong: rgba(255,255,255,0.13);
  --border-accent: rgba(240,200,74,0.28);
  --border-glass: rgba(255,255,255,0.1);

  --shadow-sm: 0 1px 4px rgba(0,0,0,0.5);
  --shadow-md: 0 4px 24px rgba(0,0,0,0.55), 0 1px 6px rgba(0,0,0,0.35);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.65), 0 4px 14px rgba(0,0,0,0.45);
  --shadow-xl: 0 32px 80px rgba(0,0,0,0.75), 0 8px 28px rgba(0,0,0,0.55);
  --shadow-glow: 0 0 40px var(--accent-glow), 0 0 80px rgba(240,200,74,0.1);
  --shadow-glow-strong: 0 0 60px var(--accent-glow-strong), 0 0 120px rgba(240,200,74,0.18);
  --shadow-3d: 0 28px 72px rgba(0,0,0,0.7), 0 8px 24px rgba(0,0,0,0.5), 0 0 0 1px var(--border);
  --shadow-card-3d: 0 20px 60px rgba(0,0,0,0.55), 0 0 0 1px var(--border);

  --font-display: 'Syne', sans-serif;
  --font-body: 'DM Sans', sans-serif;
  --font-mono: 'DM Mono', monospace;

  --space-1:4px; --space-2:8px; --space-3:12px; --space-4:16px; --space-5:20px;
  --space-6:24px; --space-8:32px; --space-10:40px; --space-12:48px;
  --space-16:64px; --space-20:80px; --space-24:96px;

  --radius-sm:4px; --radius-md:8px; --radius-lg:12px; --radius-xl:16px;
  --radius-2xl:20px; --radius-3xl:28px; --radius-full:9999px;

  --transition-fast: 120ms ease;
  --transition-base: 220ms cubic-bezier(0.4,0,0.2,1);
  --transition-slow: 400ms cubic-bezier(0.4,0,0.2,1);
  --transition-spring: 600ms cubic-bezier(0.34,1.56,0.64,1);
  --transition-bounce: 500ms cubic-bezier(0.68,-0.55,0.265,1.55);

  --sidebar-width: 248px;
  --topbar-height: 60px;
  --perspective: 1200px;
}

/* ── Light theme ── */
[data-theme="light"] {
  --bg-primary: #f2f1ed;
  --bg-secondary: #e8e6df;
  --bg-card: #ffffff;
  --bg-card-hover: #fafaf7;
  --bg-sidebar: #0e0e1c;
  --bg-glass: rgba(255,255,255,0.84);
  --bg-glass-light: rgba(0,0,0,0.02);

  --text-primary: #0e0d0b;
  --text-secondary: #5a5751;
  --text-muted: #8f8c87;
  --text-inverse: #f2f1ed;
  --text-sidebar: rgba(244,243,239,0.82);

  --accent: #b8860b;
  --accent-light: #d4a017;
  --accent-dark: #8a6508;
  --accent-bg: rgba(184,134,11,0.08);
  --accent-glow: rgba(184,134,11,0.2);
  --accent-glow-strong: rgba(184,134,11,0.4);

  --purple: #7c3aed;
  --purple-bg: rgba(124,58,237,0.08);
  --cyan: #0891b2;
  --cyan-bg: rgba(8,145,178,0.08);

  --danger: #dc2626;
  --danger-bg: rgba(220,38,38,0.08);
  --success: #16a34a;
  --success-bg: rgba(22,163,74,0.08);
  --warning: #d97706;
  --warning-bg: rgba(217,119,6,0.08);
  --info: #2563eb;
  --info-bg: rgba(37,99,235,0.08);

  --border: rgba(0,0,0,0.09);
  --border-subtle: rgba(0,0,0,0.05);
  --border-strong: rgba(0,0,0,0.16);
  --border-accent: rgba(184,134,11,0.22);
  --border-glass: rgba(0,0,0,0.08);

  --shadow-sm: 0 1px 3px rgba(0,0,0,0.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,0.1), 0 1px 4px rgba(0,0,0,0.06);
  --shadow-lg: 0 12px 40px rgba(0,0,0,0.12), 0 4px 10px rgba(0,0,0,0.08);
  --shadow-xl: 0 24px 64px rgba(0,0,0,0.14), 0 8px 20px rgba(0,0,0,0.1);
  --shadow-glow: 0 0 30px var(--accent-glow), 0 0 60px rgba(184,134,11,0.08);
  --shadow-glow-strong: 0 0 50px var(--accent-glow-strong);
  --shadow-3d: 0 20px 60px rgba(0,0,0,0.14), 0 6px 18px rgba(0,0,0,0.1), 0 0 0 1px var(--border);
  --shadow-card-3d: 0 16px 48px rgba(0,0,0,0.12), 0 0 0 1px var(--border);
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { font-size:15px; scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
[hidden] { display:none !important; }

body {
  font-family: var(--font-body);
  background: var(--bg-primary);
  color: var(--text-primary);
  line-height: 1.6;
  min-height: 100vh;
  transition: background-color 0.4s ease, color 0.4s ease;
  overflow-x: hidden;
}

img { max-width:100%; display:block; }
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:inherit; }
input,textarea,select { font-family:inherit; }
ul,ol { list-style:none; }

h1,h2,h3,h4,h5,h6 {
  font-family: var(--font-display);
  font-weight: 700;
  line-height: 1.15;
  color: var(--text-primary);
  letter-spacing: -0.025em;
}

/* ── Film grain noise overlay ── */
body::after {
  content:'';
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:9000;
  opacity:0.022;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='300' height='300' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat:repeat;
  background-size:200px;
}
[data-theme="light"] body::after { opacity:0.01; }

/* ============================================================
   FLOATING PARTICLES CANVAS
   ============================================================ */
#particles-canvas {
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:1;
}

/* ============================================================
   PUBLIC NAVIGATION — floating pill
   ============================================================ */
.pub-nav {
  position:fixed;
  top:14px;
  left:50%;
  transform:translateX(-50%);
  z-index:100;
  width:calc(100% - 48px);
  max-width:1200px;
  height:56px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 var(--space-5);
  background:var(--bg-glass);
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border:1px solid var(--border-glass);
  border-radius:var(--radius-2xl);
  box-shadow:var(--shadow-md), 0 0 0 1px var(--border-subtle) inset;
  transition:all 0.5s cubic-bezier(0.4,0,0.2,1);
}

.pub-nav.scrolled {
  top:8px;
  height:52px;
  width:calc(100% - 32px);
  box-shadow:var(--shadow-lg);
}

.nav-logo {
  display:flex;
  align-items:center;
  gap:var(--space-3);
  font-family:var(--font-display);
  font-size:1.25rem;
  font-weight:800;
  color:var(--text-primary);
  letter-spacing:-0.035em;
}

.nav-logo-icon {
  width:34px;
  height:34px;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 14px var(--accent-glow), 0 0 0 1px rgba(255,255,255,0.12) inset;
  transition:transform var(--transition-spring), box-shadow var(--transition-base);
}
.nav-logo:hover .nav-logo-icon {
  transform:rotate(-10deg) scale(1.12);
  box-shadow:0 8px 28px var(--accent-glow-strong);
}
.nav-logo-icon img { width:20px; height:20px; }

.nav-links { display:flex; align-items:center; gap:2px; }

.nav-link {
  padding:6px 14px;
  font-size:0.875rem;
  font-weight:500;
  color:var(--text-secondary);
  border-radius:var(--radius-lg);
  transition:all var(--transition-fast);
  position:relative;
}

.nav-link::after {
  content:'';
  position:absolute;
  bottom:4px;
  left:50%;
  transform:translateX(-50%) scaleX(0);
  width:18px;
  height:2px;
  background:var(--accent);
  border-radius:2px;
  transition:transform var(--transition-spring);
}
.nav-link:hover { color:var(--text-primary); }
.nav-link:hover::after { transform:translateX(-50%) scaleX(1); }

.nav-actions { display:flex; align-items:center; gap:var(--space-2); }

/* ── Theme Toggle ── */
.theme-toggle {
  width:36px;
  height:36px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:var(--radius-lg);
  background:var(--bg-glass-light);
  border:1px solid var(--border);
  color:var(--text-secondary);
  transition:all var(--transition-base);
  position:relative;
  overflow:hidden;
}
.theme-toggle::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle, var(--accent-bg), transparent 70%);
  opacity:0;
  transition:opacity var(--transition-fast);
}
.theme-toggle:hover { color:var(--accent); border-color:var(--border-accent); box-shadow:0 0 20px var(--accent-glow); }
.theme-toggle:hover::before { opacity:1; }
.theme-toggle .icon-sun,.theme-toggle .icon-moon { width:15px; height:15px; position:relative; z-index:1; }
[data-theme="dark"] .icon-sun { display:none; }
[data-theme="light"] .icon-moon { display:none; }
:not([data-theme]) .icon-moon { display:none; }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-2);
  padding:10px 22px;
  font-family:var(--font-body);
  font-size:0.9rem;
  font-weight:600;
  line-height:1;
  border-radius:var(--radius-lg);
  border:1px solid transparent;
  transition:all var(--transition-base);
  white-space:nowrap;
  position:relative;
  overflow:hidden;
  letter-spacing:-0.01em;
  cursor:pointer;
}

/* Shimmer sweep */
.btn::before {
  content:'';
  position:absolute;
  top:0;
  left:-120%;
  width:60%;
  height:100%;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
  transform:skewX(-18deg);
  transition:left 0.6s ease;
  pointer-events:none;
}
.btn:hover::before { left:180%; }
.btn:active { transform:scale(0.97); }

.btn-primary {
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  color:#0a0a12;
  border-color:transparent;
  box-shadow:0 4px 16px var(--accent-glow), 0 1px 4px rgba(0,0,0,0.3), 0 0 0 1px rgba(255,255,255,0.12) inset;
}
.btn-primary:hover {
  background:linear-gradient(135deg, var(--accent-light) 0%, var(--accent) 100%);
  box-shadow:0 8px 32px var(--accent-glow-strong), 0 2px 10px rgba(0,0,0,0.4);
  transform:translateY(-2px);
}

.btn-secondary {
  background:var(--bg-glass-light);
  color:var(--text-primary);
  border-color:var(--border-strong);
  backdrop-filter:blur(8px);
}
.btn-secondary:hover {
  background:var(--bg-card-hover);
  border-color:var(--border-accent);
  box-shadow:var(--shadow-md);
  transform:translateY(-1px);
}

.btn-ghost {
  background:transparent;
  color:var(--text-secondary);
  border-color:transparent;
}
.btn-ghost:hover { background:var(--bg-glass-light); color:var(--text-primary); }

.btn-danger { background:transparent; color:var(--danger); border-color:var(--danger); }
.btn-danger:hover { background:var(--danger-bg); box-shadow:0 4px 16px rgba(248,113,113,0.2); transform:translateY(-1px); }

.btn-glass {
  background:var(--bg-glass);
  color:var(--text-primary);
  border-color:var(--border-glass);
  backdrop-filter:blur(12px);
}
.btn-glass:hover { background:var(--bg-card); box-shadow:var(--shadow-md); transform:translateY(-2px); }

.btn-sm { padding:6px 16px; font-size:0.8rem; border-radius:var(--radius-md); }
.btn-lg { padding:14px 32px; font-size:1rem; border-radius:var(--radius-xl); }
.btn-icon { padding:8px; border-radius:var(--radius-md); aspect-ratio:1; }
.btn-block { width:100%; }

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero {
  min-height:100vh;
  display:flex;
  align-items:center;
  padding:110px 0 80px;
  position:relative;
  overflow:hidden;
}

.hero-bg { position:absolute; inset:0; z-index:0; pointer-events:none; }

/* Animated mesh gradient */
.hero-mesh {
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 70% 55% at 15% 5%, rgba(240,200,74,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 55% 70% at 85% 85%, rgba(167,139,250,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 45% 45% at 55% 45%, rgba(34,211,238,0.04) 0%, transparent 65%);
  animation:mesh-breathe 14s ease-in-out infinite alternate;
}

@keyframes mesh-breathe {
  0%   { transform:translate(0,0) scale(1); }
  33%  { transform:translate(20px,-12px) scale(1.02); }
  66%  { transform:translate(-15px,18px) scale(0.99); }
  100% { transform:translate(10px,-6px) scale(1.01); }
}

.hero-grid-lines {
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(var(--border-subtle) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-subtle) 1px, transparent 1px);
  background-size:56px 56px;
  mask-image:radial-gradient(ellipse 65% 55% at 50% 10%, rgba(0,0,0,0.7) 0%, transparent 100%);
  -webkit-mask-image:radial-gradient(ellipse 65% 55% at 50% 10%, rgba(0,0,0,0.7) 0%, transparent 100%);
}

/* Floating orbs */
.hero-orb {
  position:absolute;
  border-radius:50%;
  filter:blur(90px);
  pointer-events:none;
  will-change:transform;
}

.hero-orb-1 {
  width:520px; height:520px;
  background:radial-gradient(circle, var(--accent) 0%, transparent 70%);
  opacity:0.12;
  top:-220px; left:-80px;
  animation:orb1 16s ease-in-out infinite;
}
.hero-orb-2 {
  width:420px; height:420px;
  background:radial-gradient(circle, var(--purple) 0%, transparent 70%);
  opacity:0.1;
  bottom:-100px; right:-80px;
  animation:orb2 20s ease-in-out infinite;
}
.hero-orb-3 {
  width:280px; height:280px;
  background:radial-gradient(circle, var(--cyan) 0%, transparent 70%);
  opacity:0.07;
  top:45%; right:28%;
  animation:orb3 11s ease-in-out infinite;
}

@keyframes orb1 {
  0%,100% { transform:translate(0,0) scale(1); }
  33%  { transform:translate(70px,45px) scale(1.1); }
  66%  { transform:translate(-35px,70px) scale(0.95); }
}
@keyframes orb2 {
  0%,100% { transform:translate(0,0); }
  40% { transform:translate(-60px,-40px) scale(1.06); }
  75% { transform:translate(50px,-55px) scale(0.97); }
}
@keyframes orb3 {
  0%,100% { transform:translate(0,0); }
  50% { transform:translate(35px,-45px); }
}

.hero-content {
  position:relative;
  z-index:2;
  max-width:700px;
}

.hero-eyebrow {
  display:inline-flex;
  align-items:center;
  gap:var(--space-2);
  padding:5px 14px;
  background:var(--accent-bg);
  border:1px solid var(--border-accent);
  border-radius:var(--radius-full);
  font-family:var(--font-mono);
  font-size:0.72rem;
  font-weight:500;
  color:var(--accent);
  letter-spacing:0.08em;
  text-transform:uppercase;
  margin-bottom:var(--space-6);
  backdrop-filter:blur(8px);
  animation:eyebrow-in 0.7s cubic-bezier(0.16,1,0.3,1) both;
}

@keyframes eyebrow-in {
  from { opacity:0; transform:translateY(12px) scale(0.95); }
  to   { opacity:1; transform:none; }
}

.hero-eyebrow-dot {
  width:7px; height:7px;
  border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 10px var(--accent-glow);
  animation:dot-pulse 2s ease-in-out infinite;
}

@keyframes dot-pulse {
  0%,100% { opacity:1; box-shadow:0 0 10px var(--accent-glow); transform:scale(1); }
  50%  { opacity:0.45; box-shadow:0 0 3px var(--accent-glow); transform:scale(0.8); }
}

.hero-title {
  font-size:clamp(2.8rem,6.5vw,4.75rem);
  font-weight:800;
  letter-spacing:-0.045em;
  line-height:1.0;
  margin-bottom:var(--space-6);
  animation:title-up 0.9s cubic-bezier(0.16,1,0.3,1) 0.1s both;
}

@keyframes title-up {
  from { opacity:0; transform:translateY(28px) skewY(0.8deg); }
  to   { opacity:1; transform:none; }
}

.hero-title-gradient {
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 50%, #ffa500 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  display:inline;
  position:relative;
  filter:drop-shadow(0 0 18px var(--accent-glow));
}

.hero-subtitle {
  font-size:clamp(0.975rem,2vw,1.175rem);
  color:var(--text-secondary);
  line-height:1.78;
  max-width:530px;
  margin-bottom:var(--space-8);
  animation:title-up 0.9s cubic-bezier(0.16,1,0.3,1) 0.2s both;
}

.hero-actions {
  display:flex;
  align-items:center;
  gap:var(--space-4);
  flex-wrap:wrap;
  animation:title-up 0.9s cubic-bezier(0.16,1,0.3,1) 0.3s both;
}

.hero-social-proof {
  display:flex;
  align-items:center;
  gap:var(--space-6);
  margin-top:var(--space-10);
  padding-top:var(--space-8);
  border-top:1px solid var(--border);
  animation:title-up 0.9s cubic-bezier(0.16,1,0.3,1) 0.5s both;
}

.hero-stat-num {
  font-family:var(--font-display);
  font-size:2.25rem;
  font-weight:800;
  line-height:1;
  letter-spacing:-0.05em;
  background:linear-gradient(135deg, var(--accent), var(--text-primary));
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
}

.hero-stat-label {
  font-size:0.72rem;
  color:var(--text-muted);
  font-family:var(--font-mono);
  text-transform:uppercase;
  letter-spacing:0.09em;
  margin-top:3px;
}

/* ── 3D Dashboard preview ── */
.hero-dashboard {
  position:absolute;
  right:-60px;
  top:50%;
  transform:translateY(-50%);
  width:520px;
  z-index:2;
  pointer-events:none;
  animation:dash-enter 1s cubic-bezier(0.16,1,0.3,1) 0.4s both;
}

@keyframes dash-enter {
  from { opacity:0; transform:translateY(-42%) translateX(80px) rotateY(-15deg) rotateX(5deg); }
  to   { opacity:1; transform:translateY(-50%) rotateY(-4deg) rotateX(2deg); }
}

.hero-dashboard-inner {
  transform:rotateY(-4deg) rotateX(2deg);
  transform-style:preserve-3d;
  animation:idle-rock 10s ease-in-out infinite;
}

@keyframes idle-rock {
  0%,100% { transform:rotateY(-4deg) rotateX(2deg); }
  33%  { transform:rotateY(-1.5deg) rotateX(4deg) translateY(-4px); }
  66%  { transform:rotateY(-6deg) rotateX(1deg) translateY(4px); }
}

/* ── FEATURES ── */
.features { padding:var(--space-24) 0; position:relative; }

.section-label {
  display:inline-block;
  font-family:var(--font-mono);
  font-size:0.72rem;
  font-weight:500;
  color:var(--accent);
  text-transform:uppercase;
  letter-spacing:0.12em;
  margin-bottom:var(--space-4);
}

.section-title {
  font-size:clamp(1.75rem,4vw,2.75rem);
  font-weight:800;
  letter-spacing:-0.035em;
  margin-bottom:var(--space-4);
}

.section-subtitle {
  font-size:1.05rem;
  color:var(--text-secondary);
  max-width:560px;
  line-height:1.75;
}

.section-intro {
  text-align:center;
  max-width:600px;
  margin:0 auto;
}

.hiw-layout {
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(320px, 0.95fr);
  gap:var(--space-16);
  align-items:center;
}

.hiw-card-stack {
  display:flex;
  flex-direction:column;
  gap:var(--space-4);
}

.features-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(290px,1fr));
  gap:var(--space-5);
  margin-top:var(--space-12);
}

.feature-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-6);
  transition:all 0.5s cubic-bezier(0.4,0,0.2,1);
  position:relative;
  overflow:hidden;
  cursor:default;
  /* mouse-tracking glow applied via JS */
}

.feature-card-glow {
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at var(--mx,50%) var(--my,50%), var(--accent-bg) 0%, transparent 65%);
  opacity:0;
  transition:opacity var(--transition-base);
  pointer-events:none;
}

.feature-card:hover .feature-card-glow { opacity:1; }

.feature-card::after {
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:2px;
  background:linear-gradient(90deg, transparent, var(--accent), transparent);
  transform:scaleX(0);
  transition:transform 0.5s cubic-bezier(0.4,0,0.2,1);
}

.feature-card:hover {
  border-color:var(--border-accent);
  box-shadow:var(--shadow-lg), var(--shadow-glow);
  transform:translateY(-7px);
}
.feature-card:hover::after { transform:scaleX(1); }

.feature-icon {
  width:48px;
  height:48px;
  border-radius:var(--radius-xl);
  background:var(--accent-bg);
  border:1px solid var(--border-accent);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:var(--space-5);
  color:var(--accent);
  transition:all var(--transition-spring);
  position:relative;
  z-index:1;
}

.feature-card:hover .feature-icon {
  transform:rotate(-10deg) scale(1.18);
  box-shadow:0 8px 28px var(--accent-glow);
}
.feature-icon svg { width:22px; height:22px; }

.feature-title {
  font-family:var(--font-display);
  font-size:1.05rem;
  font-weight:700;
  color:var(--text-primary);
  margin-bottom:var(--space-3);
  position:relative;
  z-index:1;
}

.feature-desc {
  font-size:0.875rem;
  color:var(--text-secondary);
  line-height:1.78;
  position:relative;
  z-index:1;
}

/* ── CTA ── */
.cta-section { padding:var(--space-20) 0 var(--space-24); text-align:center; }

.cta-box {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-3xl);
  padding:var(--space-16) var(--space-10);
  max-width:740px;
  margin:0 auto;
  position:relative;
  overflow:hidden;
  transition:all var(--transition-slow);
}

.cta-box:hover { box-shadow:var(--shadow-glow), var(--shadow-lg); border-color:var(--border-accent); }

.cta-box-gradient {
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 75% 55% at 50% -5%, rgba(240,200,74,0.1) 0%, transparent 60%),
    radial-gradient(ellipse 55% 55% at 50% 115%, rgba(167,139,250,0.06) 0%, transparent 60%);
  pointer-events:none;
}

.cta-title {
  font-size:clamp(1.75rem,3.5vw,2.75rem);
  font-weight:800;
  letter-spacing:-0.04em;
  margin-bottom:var(--space-4);
  position:relative;
  z-index:1;
}

.cta-subtitle {
  font-size:1rem;
  color:var(--text-secondary);
  margin-bottom:var(--space-8);
  position:relative;
  z-index:1;
}

.cta-actions {
  display:flex;
  justify-content:center;
  gap:var(--space-4);
  flex-wrap:wrap;
  position:relative;
  z-index:1;
}

/* ── Footer ── */
.pub-footer {
  padding:var(--space-10) 0 var(--space-8);
  border-top:1px solid var(--border);
}

.footer-inner { display:flex; align-items:center; justify-content:space-between; gap:var(--space-6); flex-wrap:wrap; }
.footer-copy { font-size:0.8rem; color:var(--text-muted); }
.footer-links { display:flex; gap:var(--space-5); }
.footer-link { font-size:0.8rem; color:var(--text-muted); transition:color var(--transition-fast); }
.footer-link:hover { color:var(--accent); }

/* ============================================================
   AUTH PAGES
   ============================================================ */
.auth-page {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:var(--space-8) var(--space-4);
  position:relative;
  z-index:2;
}

.auth-bg { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }

.auth-bg-gradient {
  position:absolute;
  inset:0;
  background:
    radial-gradient(ellipse 55% 50% at 25% 25%, rgba(240,200,74,0.07) 0%, transparent 60%),
    radial-gradient(ellipse 50% 55% at 78% 78%, rgba(167,139,250,0.06) 0%, transparent 60%);
}

.auth-bg-grid {
  position:absolute;
  inset:0;
  background-image:
    linear-gradient(var(--border-subtle) 1px, transparent 1px),
    linear-gradient(90deg, var(--border-subtle) 1px, transparent 1px);
  background-size:52px 52px;
}

.auth-card {
  width:100%;
  max-width:430px;
  background:var(--bg-glass);
  border:1px solid var(--border-glass);
  border-radius:var(--radius-3xl);
  padding:var(--space-10);
  box-shadow:var(--shadow-3d);
  backdrop-filter:blur(36px) saturate(180%);
  -webkit-backdrop-filter:blur(36px) saturate(180%);
  position:relative;
  z-index:2;
  animation:card-appear 0.65s cubic-bezier(0.16,1,0.3,1) both;
  overflow:hidden;
}

.auth-card::before {
  content:'';
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:linear-gradient(135deg, rgba(255,255,255,0.07) 0%, transparent 50%);
  pointer-events:none;
}

@keyframes card-appear {
  from { opacity:0; transform:translateY(36px) scale(0.95); }
  to   { opacity:1; transform:none; }
}

.auth-logo { display:flex; justify-content:center; margin-bottom:var(--space-8); }
.auth-header { text-align:center; margin-bottom:var(--space-7); }
.auth-title { font-size:1.75rem; font-weight:800; letter-spacing:-0.035em; margin-bottom:var(--space-2); }
.auth-subtitle { font-size:0.9rem; color:var(--text-secondary); }

.auth-footer-text {
  text-align:center;
  font-size:0.875rem;
  color:var(--text-secondary);
  margin-top:var(--space-6);
}
.auth-footer-text a { color:var(--accent); font-weight:600; transition:color var(--transition-fast); }
.auth-footer-text a:hover { color:var(--accent-light); }

.auth-back {
  position:fixed;
  top:var(--space-5);
  left:var(--space-6);
  z-index:10;
  display:flex;
  align-items:center;
  gap:var(--space-2);
  font-size:0.875rem;
  color:var(--text-secondary);
  padding:6px 14px;
  border-radius:var(--radius-lg);
  background:var(--bg-glass);
  border:1px solid var(--border);
  backdrop-filter:blur(12px);
  transition:all var(--transition-fast);
}
.auth-back:hover { color:var(--text-primary); border-color:var(--border-strong); box-shadow:var(--shadow-sm); }
.auth-back svg { width:14px; height:14px; }

/* ============================================================
   FORMS
   ============================================================ */
.form-group {
  display:flex;
  flex-direction:column;
  gap:6px;
  margin-bottom:var(--space-5);
}

.form-label {
  font-size:0.76rem;
  font-weight:600;
  color:var(--text-secondary);
  text-transform:uppercase;
  letter-spacing:0.08em;
  font-family:var(--font-mono);
}

.form-control {
  width:100%;
  padding:11px 16px;
  background:var(--bg-glass-light);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  color:var(--text-primary);
  font-size:0.925rem;
  font-family:var(--font-body);
  transition:all var(--transition-base);
  appearance:none;
}
.form-control:focus {
  outline:none;
  border-color:var(--accent);
  background:var(--bg-card);
  box-shadow:0 0 0 3px var(--accent-bg), 0 4px 16px rgba(0,0,0,0.2);
}
.form-control::placeholder { color:var(--text-muted); }

textarea.form-control { resize:vertical; min-height:120px; line-height:1.65; }

select.form-control {
  padding-right:38px;
  cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%238e8ca8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;
  background-position:right 14px center;
}

.form-hint { font-size:0.76rem; color:var(--text-muted); }
.form-error-text { font-size:0.76rem; color:var(--danger); display:none; }
.form-control.is-invalid { border-color:var(--danger); box-shadow:0 0 0 3px var(--danger-bg); }

.form-row { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-5); }
.form-row-third { grid-template-columns:repeat(3, minmax(0, 1fr)); }
@media (max-width:580px) { .form-row, .form-row-third { grid-template-columns:1fr; } }

.page-shell-narrow {
  max-width:760px;
  width:100%;
  margin:0 auto;
}

.page-shell-compact {
  max-width:640px;
  width:100%;
  margin:0 auto;
}

.form-actions-row {
  display:flex;
  gap:var(--space-3);
}

.form-actions-row > .btn {
  min-height:46px;
}

.location-card-glass {
  margin-bottom: var(--space-5);
  padding: var(--space-5);
  background: linear-gradient(180deg, rgba(240,200,74,0.06), rgba(255,255,255,0.02));
  border: 1px solid var(--border-accent);
  border-radius: var(--radius-xl);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.comp-card-glass {
  margin-bottom: var(--space-5);
  padding: var(--space-5);
  background: linear-gradient(180deg, rgba(34,211,238,0.08), rgba(255,255,255,0.02));
  border: 1px solid rgba(34,211,238,0.24);
  border-radius: var(--radius-xl);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.04);
}

.location-card-header {
  display: flex;
  gap: var(--space-4);
  align-items: flex-start;
  margin-bottom: var(--space-5);
}

.location-card-title {
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.location-card-subtitle {
  color: var(--text-secondary);
  font-size: 0.84rem;
  line-height: 1.6;
}

.location-pills,
.table-location {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.location-picker {
  margin-bottom: var(--space-5);
}

.location-search-shell {
  position: relative;
  z-index: 1200;
}

.location-search-input {
  padding-left: 42px;
}

.location-search-icon {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  width: 16px;
  height: 16px;
  z-index: 2;
}

.location-search-icon svg {
  width: 16px;
  height: 16px;
}

.location-search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 1400;
  padding: 8px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-glass);
  background: rgba(19,19,42,0.96);
  box-shadow: var(--shadow-lg), 0 0 24px rgba(34,211,238,0.12);
  backdrop-filter: blur(18px);
}

[data-theme="light"] .location-search-results {
  background: rgba(255,255,255,0.96);
}

.location-search-result {
  width: 100%;
  display: block;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--text-primary);
  text-align: left;
}

.location-search-result:hover {
  background: var(--bg-glass-light);
}

.location-search-result-title {
  display: block;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.location-search-result-meta {
  display: block;
  margin-top: 2px;
  color: var(--text-muted);
  font-size: 0.74rem;
  font-family: var(--font-mono);
}

.location-map-shell {
  padding: 14px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: var(--bg-glass-light);
  position: relative;
  z-index: 1;
}

.location-map-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: 10px;
}

.location-map-toolbar-copy {
  color: var(--text-muted);
  font-size: 0.73rem;
  font-family: var(--font-mono);
}

.location-map {
  width: 100%;
  height: 260px;
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--border);
  background:
    radial-gradient(circle at 25% 25%, rgba(34,211,238,0.12), transparent 30%),
    radial-gradient(circle at 75% 70%, rgba(240,200,74,0.12), transparent 32%),
    linear-gradient(180deg, rgba(19,19,42,0.9), rgba(12,12,20,0.95));
}

.location-map.is-disabled {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.78rem;
  text-align: center;
  padding: var(--space-6);
}

.leaflet-control-zoom {
  border: 0 !important;
  box-shadow: none !important;
}

.leaflet-control-zoom a {
  width: 32px !important;
  height: 32px !important;
  line-height: 30px !important;
  border-radius: 12px !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  background: rgba(19,19,42,0.92) !important;
  color: var(--accent) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,0.35), 0 0 0 1px rgba(255,255,255,0.03) inset;
  margin-bottom: 6px !important;
}

.leaflet-control-zoom a:hover {
  background: rgba(26,26,46,0.98) !important;
  color: var(--accent-light) !important;
  border-color: var(--border-accent) !important;
}

.leaflet-control-attribution {
  padding: 6px 10px !important;
  border-radius: 12px 0 0 0 !important;
  background: rgba(10,10,18,0.72) !important;
  color: var(--text-muted) !important;
  backdrop-filter: blur(14px);
  border-top: 1px solid rgba(255,255,255,0.06);
  border-left: 1px solid rgba(255,255,255,0.06);
}

.leaflet-control-attribution a {
  color: var(--accent) !important;
}

.location-pill,
.table-location span {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--bg-glass-light);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  font-size: 0.76rem;
  line-height: 1;
}

.location-pill-accent,
.table-location-country {
  background: var(--accent-bg);
  border-color: var(--border-accent);
  color: var(--accent);
}

.table-subtext {
  margin-top: 4px;
  color: var(--text-muted);
  font-size: 0.76rem;
}

.comp-pills,
.table-compensation {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.table-compensation {
  margin-top: 8px;
}

.comp-pill,
.table-comp-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: var(--cyan-bg);
  border: 1px solid rgba(34,211,238,0.2);
  color: var(--cyan);
  font-size: 0.74rem;
  line-height: 1;
  font-family: var(--font-mono);
}

.comp-pill-accent,
.table-comp-pill-accent {
  background: var(--accent-bg);
  border-color: var(--border-accent);
  color: var(--accent);
}

.input-prefix-wrap {
  position: relative;
}

.input-stepper-wrap input[type="number"] {
  -moz-appearance: textfield;
}

.input-stepper-wrap input[type="number"]::-webkit-outer-spin-button,
.input-stepper-wrap input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

.input-prefix {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.88rem;
  pointer-events: none;
}

.input-with-prefix {
  padding-left: 34px;
}

.input-with-stepper {
  padding-right: 40px;
}

.input-stepper-buttons {
  position: absolute;
  top: 8px;
  right: 8px;
  bottom: 8px;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.input-stepper-btn {
  width: 22px;
  flex: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  color: var(--text-secondary);
  transition: all var(--transition-fast);
}

.input-stepper-btn svg {
  width: 10px;
  height: 10px;
}

.input-stepper-btn:hover {
  color: var(--accent);
  border-color: var(--border-accent);
  box-shadow: 0 0 18px var(--accent-glow);
}

.input-stepper-btn:active {
  transform: scale(0.96);
}

.field-microcopy {
  margin-top: 6px;
  color: var(--text-muted);
  font-size: 0.74rem;
  font-family: var(--font-mono);
}

.site-meta-footer {
  padding: 14px 20px 18px;
  border-top: 1px solid var(--border-subtle);
  background: rgba(0,0,0,0.12);
}

.site-meta-footer-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--text-muted);
  font-size: 0.73rem;
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.site-meta-footer-inner a {
  color: var(--accent);
}

.site-meta-sep {
  opacity: 0.45;
}

.custom-date-picker {
  position: relative;
}

.custom-date-trigger {
  width: 100%;
  display: flex;
  align-items: center;
  gap: var(--space-4);
  min-height: 52px;
  padding: 12px 14px;
  border-radius: var(--radius-xl);
  border: 1px solid var(--border);
  background: var(--bg-card);
  color: var(--text-primary);
  text-align: left;
  transition: all var(--transition-base);
}

.custom-date-trigger:hover,
.custom-date-picker.open .custom-date-trigger {
  border-color: var(--border-accent);
  box-shadow: 0 0 0 3px var(--accent-bg), var(--shadow-md);
}

.custom-date-trigger-icon {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  background: var(--accent-bg);
  border: 1px solid var(--border-accent);
  color: var(--accent);
  flex-shrink: 0;
}

.custom-date-trigger-icon svg {
  width: 18px;
  height: 18px;
}

.custom-date-trigger-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.custom-date-label {
  font-weight: 600;
  letter-spacing: -0.01em;
}

.custom-date-label.is-empty {
  color: var(--text-secondary);
}

.custom-date-hint {
  color: var(--text-muted);
  font-size: 0.74rem;
  font-family: var(--font-mono);
  margin-top: 2px;
}

.custom-date-popover {
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  z-index: 20;
  width: min(320px, calc(100vw - 48px));
  padding: var(--space-4);
  border-radius: var(--radius-2xl);
  background: rgba(19,19,42,0.96);
  border: 1px solid var(--border-glass);
  box-shadow: var(--shadow-xl), 0 0 32px var(--accent-glow);
  backdrop-filter: blur(24px) saturate(160%);
}

[data-theme="light"] .custom-date-popover {
  background: rgba(255,255,255,0.96);
}

.custom-date-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-4);
}

.custom-date-nav {
  width: 34px;
  height: 34px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--bg-glass-light);
  color: var(--text-secondary);
}

.custom-date-nav:hover {
  color: var(--accent);
  border-color: var(--border-accent);
}

.custom-date-month {
  font-family: var(--font-display);
  font-size: 1.02rem;
  letter-spacing: -0.02em;
}

.custom-date-weekdays,
.custom-date-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 6px;
}

.custom-date-weekdays {
  margin-bottom: var(--space-3);
}

.custom-date-weekday {
  text-align: center;
  color: var(--text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
}

.custom-date-day {
  aspect-ratio: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  border: 1px solid transparent;
  background: transparent;
  color: var(--text-secondary);
  font-size: 0.84rem;
}

.custom-date-day:hover {
  color: var(--text-primary);
  border-color: var(--border);
  background: var(--bg-glass-light);
}

.custom-date-day.is-outside {
  color: var(--text-muted);
  opacity: 0.45;
}

.custom-date-day.is-today {
  border-color: rgba(34,211,238,0.28);
  color: var(--cyan);
}

.custom-date-day.is-selected {
  background: linear-gradient(135deg, var(--accent), var(--accent-dark));
  color: var(--text-inverse);
  box-shadow: 0 0 18px var(--accent-glow);
}

.custom-date-footer {
  margin-top: var(--space-4);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}

.custom-date-footer-note {
  color: var(--text-muted);
  font-size: 0.72rem;
  font-family: var(--font-mono);
}

.custom-date-footer-actions {
  display: flex;
  gap: var(--space-2);
}

.custom-date-footer-btn {
  padding: 7px 10px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--bg-glass-light);
  color: var(--text-secondary);
  font-size: 0.75rem;
  font-weight: 600;
}

.custom-date-footer-btn:hover {
  color: var(--text-primary);
  border-color: var(--border-accent);
}

/* ── File Upload ── */
.file-upload-area {
  border:2px dashed var(--border-strong);
  border-radius:var(--radius-2xl);
  padding:var(--space-12) var(--space-6);
  text-align:center;
  cursor:pointer;
  transition:all var(--transition-base);
  background:var(--bg-glass-light);
  position:relative;
  overflow:hidden;
}

.file-upload-area::before {
  content:'';
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 50% 50%, var(--accent-bg), transparent 70%);
  opacity:0;
  transition:opacity var(--transition-base);
  pointer-events:none;
}

.file-upload-area:hover,.file-upload-area.dragging {
  border-color:var(--accent);
  box-shadow:0 0 0 4px var(--accent-bg), var(--shadow-glow);
}
.file-upload-area:hover::before,.file-upload-area.dragging::before { opacity:1; }

.file-upload-area input[type="file"] {
  position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; z-index:2;
}

.file-upload-icon {
  width:52px; height:52px;
  margin:0 auto var(--space-4);
  color:var(--text-muted);
  transition:all var(--transition-spring);
  position:relative; z-index:1;
}

.file-upload-area:hover .file-upload-icon,
.file-upload-area.dragging .file-upload-icon {
  color:var(--accent);
  transform:scale(1.2) translateY(-6px) rotate(-5deg);
  filter:drop-shadow(0 6px 12px var(--accent-glow));
}

.file-upload-label {
  display:block; font-size:0.925rem; font-weight:500;
  color:var(--text-secondary); margin-bottom:4px;
  position:relative; z-index:1;
}
.file-upload-accent { color:var(--accent); font-weight:700; }
.file-upload-hint { font-size:0.76rem; color:var(--text-muted); position:relative; z-index:1; }

.file-selected {
  display:flex;
  align-items:center;
  gap:var(--space-3);
  padding:var(--space-3) var(--space-4);
  background:var(--accent-bg);
  border:1px solid var(--border-accent);
  border-radius:var(--radius-lg);
  margin-top:var(--space-3);
  animation:slide-in 0.35s cubic-bezier(0.16,1,0.3,1);
}

@keyframes slide-in {
  from { opacity:0; transform:translateY(-10px) scale(0.97); }
  to   { opacity:1; transform:none; }
}

.file-selected-name {
  font-size:0.85rem; font-weight:500;
  font-family:var(--font-mono);
  color:var(--text-primary);
  flex:1; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}

.document-stack {
  display:grid;
  gap:var(--space-5);
}

.document-composer {
  position:relative;
  padding:var(--space-5);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--bg-card) 88%, transparent), color-mix(in srgb, var(--bg-secondary) 92%, transparent)),
    radial-gradient(circle at top right, color-mix(in srgb, var(--accent-glow) 16%, transparent), transparent 38%);
  box-shadow:var(--shadow-md);
}

.document-composer.is-invalid {
  border-color:var(--danger);
  box-shadow:0 0 0 4px var(--danger-bg), var(--shadow-md);
}

.document-composer-header {
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:var(--space-4);
  margin-bottom:var(--space-4);
}

.document-composer-title {
  margin:0;
  font-size:1rem;
  font-weight:700;
  color:var(--text-primary);
}

.document-composer-subtitle {
  margin:6px 0 0;
  font-size:0.84rem;
  line-height:1.6;
  color:var(--text-muted);
}

.document-composer-badge {
  display:inline-flex;
  align-items:center;
  padding:6px 12px;
  border-radius:999px;
  border:1px solid var(--border-accent);
  background:var(--accent-bg);
  color:var(--accent);
  font-size:0.72rem;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:0.08em;
}

.document-composer-badge-soft {
  border-color:var(--border);
  background:var(--bg-glass-light);
  color:var(--text-secondary);
}

.document-mode-switch {
  display:inline-grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--space-2);
  padding:6px;
  margin-bottom:var(--space-4);
  border:1px solid var(--border);
  border-radius:999px;
  background:var(--bg-glass-light);
}

.document-mode-pill {
  position:relative;
  cursor:pointer;
}

.document-mode-pill input {
  position:absolute;
  inset:0;
  opacity:0;
  pointer-events:none;
}

.document-mode-pill span {
  display:flex;
  align-items:center;
  justify-content:center;
  min-width:140px;
  padding:10px 16px;
  border-radius:999px;
  color:var(--text-muted);
  font-size:0.82rem;
  font-weight:700;
  transition:all var(--transition-base);
}

.document-mode-pill input:checked + span {
  background:linear-gradient(135deg, var(--accent), color-mix(in srgb, var(--accent) 75%, white));
  color:#081015;
  box-shadow:0 12px 24px color-mix(in srgb, var(--accent-glow) 50%, transparent);
}

.document-panel {
  display:none;
  animation:slide-in 0.28s ease;
}

.document-panel.is-active {
  display:block;
}

/* ── Alerts ── */
.alert {
  display:flex; align-items:flex-start; gap:var(--space-3);
  padding:var(--space-4) var(--space-5);
  border-radius:var(--radius-lg); border:1px solid;
  font-size:0.9rem; line-height:1.5;
  margin-bottom:var(--space-5);
  backdrop-filter:blur(8px);
}
.alert-error   { background:var(--danger-bg);  border-color:var(--danger);  color:var(--danger); }
.alert-success { background:var(--success-bg); border-color:var(--success); color:var(--success); }
.alert-warning { background:var(--warning-bg); border-color:var(--warning); color:var(--warning); }
.alert-info    { background:var(--info-bg);    border-color:var(--info);    color:var(--info); }

.alert-icon { width:18px; height:18px; flex-shrink:0; margin-top:2px; }
.alert-close {
  margin-left:auto; background:none; border:none;
  color:inherit; opacity:0.5; padding:0; font-size:1.1rem; line-height:1;
  transition:opacity var(--transition-fast);
}
.alert-close:hover { opacity:1; }

/* ── Badges ── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:3px 10px;
  font-size:0.7rem; font-weight:600;
  font-family:var(--font-mono);
  border-radius:var(--radius-full);
  letter-spacing:0.05em; text-transform:uppercase; white-space:nowrap;
}
.badge::before {
  content:''; width:5px; height:5px; border-radius:50%;
  background:currentColor; flex-shrink:0;
}

.badge-applied    { background:var(--info-bg);    color:var(--info); }
.badge-interview  { background:var(--warning-bg); color:var(--warning); }
.badge-offer      { background:var(--success-bg); color:var(--success); }
.badge-rejected   { background:var(--danger-bg);  color:var(--danger); }
.badge-withdrawn  { background:var(--bg-glass-light); color:var(--text-muted); border:1px solid var(--border); }
.badge-saved      { background:var(--purple-bg);  color:var(--purple); }

/* ============================================================
   APP / DASHBOARD LAYOUT
   ============================================================ */
.app-layout { display:flex; min-height:100vh; }

/* ── Sidebar ── */
.sidebar {
  width:var(--sidebar-width); min-height:100vh;
  background:var(--bg-sidebar);
  position:fixed; left:0; top:0; bottom:0; z-index:50;
  display:flex; flex-direction:column;
  transition:transform var(--transition-slow);
  border-right:1px solid rgba(255,255,255,0.05);
  overflow:hidden;
}

.sidebar::before {
  content:''; position:absolute; top:0; left:0; right:0; height:180px;
  background:radial-gradient(ellipse at 50% 0%, rgba(240,200,74,0.07) 0%, transparent 70%);
  pointer-events:none;
}

.sidebar-header {
  padding:var(--space-5);
  border-bottom:1px solid rgba(255,255,255,0.05);
  display:flex; align-items:center; justify-content:space-between;
  position:relative; z-index:1;
}

.sidebar-logo {
  display:flex; align-items:center; gap:var(--space-3);
  font-family:var(--font-display); font-size:1.2rem; font-weight:800;
  color:#eeedf0; letter-spacing:-0.035em;
}

.sidebar-logo-icon {
  width:32px; height:32px;
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  border-radius:var(--radius-lg);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 14px var(--accent-glow), 0 0 0 1px rgba(255,255,255,0.12) inset;
  flex-shrink:0;
  transition:transform var(--transition-spring);
}
.sidebar-logo:hover .sidebar-logo-icon { transform:rotate(-10deg) scale(1.12); }
.sidebar-logo-icon img { width:18px; height:18px; }

.sidebar-nav {
  flex:1; padding:var(--space-4) var(--space-3); overflow-y:auto;
  position:relative; z-index:1;
}

.sidebar-section-label {
  font-family:var(--font-mono); font-size:0.6rem; font-weight:500;
  text-transform:uppercase; letter-spacing:0.15em;
  color:rgba(238,237,234,0.22);
  padding:var(--space-4) var(--space-3) var(--space-2); display:block;
}

.sidebar-item {
  display:flex; align-items:center; gap:var(--space-3);
  padding:9px var(--space-3); border-radius:var(--radius-lg);
  font-size:0.875rem; font-weight:500;
  color:var(--text-sidebar);
  transition:all var(--transition-base);
  margin-bottom:2px; position:relative; overflow:hidden;
}

.sidebar-item::before {
  content:''; position:absolute; left:0; top:50%;
  transform:translateY(-50%) scaleY(0);
  width:3px; height:65%;
  background:var(--accent);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
  transition:transform var(--transition-spring);
}

.sidebar-item svg { width:16px; height:16px; flex-shrink:0; opacity:0.55; transition:all var(--transition-base); }
.sidebar-item:hover { background:rgba(255,255,255,0.07); color:#eeedf0; }
.sidebar-item:hover svg { opacity:1; transform:scale(1.1); }
.sidebar-item.active { background:var(--accent-bg); color:var(--accent); font-weight:600; }
.sidebar-item.active svg { opacity:1; color:var(--accent); }
.sidebar-item.active::before { transform:translateY(-50%) scaleY(1); }

.sidebar-badge {
  margin-left:auto; min-width:20px; height:20px; padding:0 6px;
  background:var(--accent-bg); color:var(--accent); border:1px solid var(--border-accent);
  border-radius:var(--radius-full); font-size:0.66rem; font-weight:700;
  font-family:var(--font-mono); display:flex; align-items:center; justify-content:center;
}

.sidebar-footer {
  padding:var(--space-3) var(--space-3) var(--space-4);
  border-top:1px solid rgba(255,255,255,0.05);
  position:relative; z-index:1;
}

.sidebar-user {
  display:flex; align-items:center; gap:var(--space-3);
  padding:var(--space-3); border-radius:var(--radius-lg);
  transition:background var(--transition-fast); cursor:pointer;
}
.sidebar-user:hover { background:rgba(255,255,255,0.06); }

.sidebar-avatar {
  width:34px; height:34px; border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--accent), var(--accent-dark));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--font-display); font-size:0.8rem; font-weight:800; color:#0a0a12;
  flex-shrink:0; text-transform:uppercase;
  box-shadow:0 2px 10px var(--accent-glow);
}

.sidebar-user-name { font-size:0.8rem; font-weight:600; color:#eeedf0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar-user-role { font-size:0.65rem; color:rgba(238,237,234,0.3); font-family:var(--font-mono); text-transform:uppercase; letter-spacing:0.07em; }

/* Sidebar theme toggle */
.sidebar .theme-toggle {
  width:100%; height:34px; border-radius:var(--radius-lg); margin-top:var(--space-2);
  border-color:rgba(255,255,255,0.08); color:rgba(238,237,234,0.45);
  background:rgba(255,255,255,0.04); justify-content:center; gap:var(--space-2);
}
.sidebar .theme-toggle:hover { color:var(--accent); border-color:var(--border-accent); box-shadow:0 0 18px var(--accent-glow); background:var(--accent-bg); }

.sidebar-logout-btn {
  display:flex; align-items:center; gap:var(--space-3);
  padding:9px var(--space-3); border-radius:var(--radius-lg);
  font-size:0.85rem; font-weight:500;
  color:rgba(248,113,113,0.65);
  background:none; border:none; width:100%; text-align:left;
  transition:all var(--transition-fast); margin-top:var(--space-2);
}
.sidebar-logout-btn:hover { background:var(--danger-bg); color:var(--danger); }
.sidebar-logout-btn svg { width:15px; height:15px; }

/* ── App Main ── */
.app-main { flex:1; margin-left:var(--sidebar-width); min-height:100vh; display:flex; flex-direction:column; }

/* ── Topbar ── */
.app-topbar {
  height:var(--topbar-height);
  background:var(--bg-glass);
  border-bottom:1px solid var(--border);
  display:flex; align-items:center;
  padding:0 var(--space-8);
  gap:var(--space-4);
  position:sticky; top:0; z-index:40;
  backdrop-filter:blur(28px) saturate(180%);
  -webkit-backdrop-filter:blur(28px) saturate(180%);
}

.topbar-breadcrumb {
  display:flex; align-items:center; gap:var(--space-2);
  font-size:0.8rem; color:var(--text-muted); font-family:var(--font-mono);
}
.topbar-breadcrumb a { transition:color var(--transition-fast); }
.topbar-breadcrumb a:hover { color:var(--text-primary); }
.topbar-breadcrumb-sep { opacity:0.35; }
.topbar-breadcrumb-current { color:var(--text-primary); font-weight:500; }
.topbar-actions { margin-left:auto; display:flex; align-items:center; gap:var(--space-3); }

/* ── Page Content ── */
.page-content { flex:1; padding:var(--space-8); max-width:1100px; width:100%; margin:0 auto; }
.page-content-wide { max-width:1460px; }
.page-content-wide .page-title { font-size:clamp(2.05rem, 2.6vw, 2.55rem); }
.page-content-wide .stat-value {
  font-size:clamp(2.05rem, 2.2vw, 2.45rem);
  display:inline-block;
  line-height:0.92;
  transform:scaleY(1.08);
  transform-origin:center;
}

.page-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:var(--space-4); margin-bottom:var(--space-8); flex-wrap:wrap;
}
.page-title { font-size:1.875rem; font-weight:800; letter-spacing:-0.04em; line-height:1.05; margin-bottom:4px; }
.page-subtitle { font-size:0.8rem; color:var(--text-muted); font-family:var(--font-mono); }
.page-actions { display:flex; align-items:center; gap:var(--space-3); flex-shrink:0; }

/* ── Stats Bar ── */
.stats-bar {
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(130px,1fr));
  gap:var(--space-4);
  margin-bottom:var(--space-8);
}

.stat-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); padding:var(--space-5);
  transition:all var(--transition-slow); position:relative; overflow:hidden;
}
.stat-card::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:var(--accent); transform:scaleX(0); transform-origin:left;
  transition:transform var(--transition-slow);
}
.stat-card:hover { border-color:var(--border-strong); box-shadow:var(--shadow-md); transform:translateY(-3px); }
.stat-card:hover::after { transform:scaleX(1); }

.stat-label { font-family:var(--font-mono); font-size:0.66rem; text-transform:uppercase; letter-spacing:0.1em; color:var(--text-muted); margin-bottom:var(--space-2); }
.stat-value { font-family:var(--font-display); font-size:2rem; font-weight:800; color:var(--text-primary); line-height:1; letter-spacing:-0.04em; }
.stat-value-accent  { color:var(--accent); }
.stat-value-success { color:var(--success); }
.stat-value-danger  { color:var(--danger); }
.stat-value-warning { color:var(--warning); }

/* ── App Table ── */
.app-table-wrap {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-2xl); overflow:hidden; box-shadow:var(--shadow-md);
  display:flex; flex-direction:column;
  min-height:420px;
  max-height:calc(100vh - 320px);
}

.app-table-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:var(--space-5) var(--space-6);
  border-bottom:1px solid var(--border); gap:var(--space-4);
}

.app-table-header-sticky {
  position:relative;
  top:auto;
  z-index:4;
  background:color-mix(in srgb, var(--bg-card) 92%, transparent);
  backdrop-filter:blur(22px) saturate(160%);
  border-top-left-radius:var(--radius-2xl);
  border-top-right-radius:var(--radius-2xl);
}

.table-results-count {
  font-size:0.78rem;
  color:var(--text-muted);
  font-family:var(--font-mono);
}

.app-table-scroller {
  overflow-y:auto;
  overflow-x:hidden;
  flex:1;
  min-height:0;
  scrollbar-gutter:stable;
  border-bottom-left-radius:var(--radius-2xl);
  border-bottom-right-radius:var(--radius-2xl);
}

.table-search {
  display:flex; align-items:center; gap:var(--space-3);
  padding:8px 14px;
  background:var(--bg-glass-light); border:1px solid var(--border);
  border-radius:var(--radius-lg);
  flex:1; max-width:340px;
  transition:all var(--transition-base);
}
.table-search:focus-within { border-color:var(--accent); box-shadow:0 0 0 3px var(--accent-bg); }
.table-search svg { width:15px; height:15px; color:var(--text-muted); flex-shrink:0; }
.table-search input { flex:1; background:none; border:none; outline:none; font-size:0.875rem; color:var(--text-primary); }
.table-search input::placeholder { color:var(--text-muted); }

.table { width:100%; border-collapse:separate; border-spacing:0; table-layout:fixed; min-width:0; }
.table .col-company { width:18%; }
.table .col-role { width:16%; }
.table .col-location { width:19%; }
.table .col-pay { width:12%; }
.table .col-status { width:11%; }
.table .col-applied { width:12%; }
.table .col-actions { width:12%; }
.table th {
  text-align:center; padding:12px 16px;
  font-family:var(--font-mono); font-size:0.75rem; font-weight:700;
  text-transform:uppercase; letter-spacing:0.09em; color:var(--text-muted);
  background:var(--bg-secondary); border-bottom:1px solid var(--border); white-space:nowrap;
  position:sticky; top:0; z-index:8;
}
.table th:first-child { padding-left:var(--space-6); }
.table th:last-child  { padding-right:var(--space-6); }
.table td {
  padding:14px 16px; font-size:0.9rem; color:var(--text-primary); text-align:center;
  border-bottom:1px solid var(--border-subtle); vertical-align:middle;
  transition:color var(--transition-fast);
}
.table td:first-child { padding-left:var(--space-6); }
.table td:last-child  { padding-right:var(--space-6); }
.table tbody tr { transition:background var(--transition-fast); }
.table tbody tr:hover { background:var(--bg-glass-light); }
.table tbody tr:last-child td { border-bottom:none; }
.table tbody tr td:first-child { position:relative; }
.table tbody tr td:first-child::before {
  content:'';
  position:absolute;
  left:0;
  top:0;
  bottom:0;
  width:0;
  background:var(--accent);
  transition:width var(--transition-fast);
}
.table tbody tr:hover td:first-child::before { width:2px; }
.table-company { font-weight:600; }
.table-company-name { font-size:0.95rem; font-weight:700; color:var(--text-primary); }
.table-title { color:var(--text-secondary); font-size:0.875rem; }
.table-title-cell, .table-location-cell, .table-pay-cell, .table-status-cell, .table-actions-cell { vertical-align:top; }
.table-date { font-family:var(--font-mono); font-size:0.76rem; color:var(--text-muted); }
.table-actions { display:flex; align-items:center; justify-content:flex-start; gap:var(--space-2); white-space:nowrap; }
.table-actions-cell { min-width:128px; }
.table-company-name,
.table-title,
.table-date,
.table-status-text {
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.table-location,
.table-compensation {
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  justify-content:center;
}
.table-actions { justify-content:center; }
.table-company,
.table-title-cell,
.table-status-cell,
.table-date,
.table-actions-cell { text-align:center; }
.table-title-cell .table-title,
.table-date,
.table-status-cell,
.table-actions-cell {
  padding-top:2px;
}
.table-status-text {
  display:inline-block;
  font-size:0.84rem;
  font-weight:700;
  letter-spacing:0.01em;
}
.table-status-not_applied { color:var(--text-muted); }
.table-status-applied { color:var(--accent); }
.table-status-interviewing { color:var(--warning); }
.table-status-offer { color:var(--success); }
.table-status-rejected { color:var(--danger); }

/* ── Document Cards ── */
.document-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px,1fr));
  gap:var(--space-5);
}

.document-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-2xl); padding:var(--space-5);
  transition:all var(--transition-slow);
  display:flex; flex-direction:column; gap:var(--space-4);
  position:relative; overflow:hidden;
}
.document-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg, transparent, var(--accent-glow), transparent);
  opacity:0; transition:opacity var(--transition-base);
}
.document-card:hover { box-shadow:var(--shadow-lg); border-color:var(--border-strong); transform:translateY(-5px); }
.document-card:hover::before { opacity:1; }

.document-card-icon {
  width:52px; height:52px; border-radius:var(--radius-xl);
  background:var(--accent-bg); border:1px solid var(--border-accent);
  display:flex; align-items:center; justify-content:center; color:var(--accent);
  transition:all var(--transition-spring);
}
.document-card:hover .document-card-icon { transform:scale(1.1) rotate(-6deg); box-shadow:0 6px 20px var(--accent-glow); }
.document-card-icon svg { width:24px; height:24px; }
.document-card-name { font-family:var(--font-display); font-size:1rem; font-weight:700; color:var(--text-primary); margin-bottom:4px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.document-card-meta { font-family:var(--font-mono); font-size:0.7rem; color:var(--text-muted); }
.document-card-actions { display:flex; gap:var(--space-2); padding-top:var(--space-3); border-top:1px solid var(--border-subtle); margin-top:auto; }

.document-preview-overlay {
  z-index:260;
  padding:clamp(12px, 2vw, 24px);
}

.document-preview-modal {
  width:min(92vw, 1560px);
  max-width:1560px;
  height:min(95vh, 1180px);
  max-height:95vh;
  padding:0;
  display:flex;
  flex-direction:column;
  overflow:hidden;
}

.document-preview-header {
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  justify-content:space-between;
  align-items:center;
  gap:var(--space-4);
  padding:18px 28px;
  border-bottom:1px solid var(--border);
  background:color-mix(in srgb, var(--bg-card) 90%, transparent);
  backdrop-filter:blur(24px) saturate(160%);
}

.document-preview-heading {
  min-width:0;
}

.document-preview-title {
  font-family:var(--font-display);
  font-size:1.3rem;
  font-weight:800;
  letter-spacing:-0.04em;
  margin-bottom:2px;
}

.document-preview-subtitle {
  font-size:0.72rem;
  color:var(--text-muted);
  font-family:var(--font-mono);
  word-break:break-word;
}

.document-preview-toolbar {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:nowrap;
  gap:var(--space-2);
}

.document-preview-body {
  position:relative;
  flex:1;
  display:flex;
  min-height:0;
  padding:14px;
  background:
    radial-gradient(circle at top left, rgba(240,200,74,0.05), transparent 26%),
    radial-gradient(circle at bottom right, rgba(34,211,238,0.05), transparent 28%);
}

.document-preview-loading {
  position:absolute;
  inset:14px;
  display:grid;
  place-items:center;
  z-index:2;
  pointer-events:none;
  border-radius:calc(var(--radius-2xl) - 6px);
  background:rgba(10,10,18,0.28);
  backdrop-filter:blur(2px);
}

.document-preview-spinner {
  width:34px;
  height:34px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,0.1);
  border-top-color:var(--accent);
  box-shadow:0 0 22px var(--accent-glow);
  animation:btn-spin 0.8s linear infinite;
}

.document-viewer-layout {
  display:grid;
  grid-template-columns:minmax(0, 1fr) 320px;
  gap:var(--space-6);
  align-items:start;
}

.document-viewer-sidebar {
  display:flex;
  flex-direction:column;
  gap:var(--space-5);
}

.document-viewer-eyebrow {
  display:flex;
  align-items:center;
  gap:var(--space-2);
  flex-wrap:wrap;
  margin-bottom:var(--space-3);
}

.document-viewer-chip {
  display:inline-flex;
  align-items:center;
  padding:5px 10px;
  border-radius:var(--radius-full);
  background:var(--accent-bg);
  border:1px solid var(--border-accent);
  color:var(--accent);
  font-family:var(--font-mono);
  font-size:0.68rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.document-viewer-chip-soft {
  background:var(--bg-glass-light);
  border-color:var(--border);
  color:var(--text-secondary);
}

.document-viewer-card {
  min-height:760px;
}

.document-viewer-frame-shell {
  flex:1;
  height:100%;
  min-height:0;
  position:relative;
  overflow:hidden;
  border-radius:calc(var(--radius-2xl) - 6px);
  border:1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(240,200,74,0.08), transparent 32%),
    radial-gradient(circle at bottom right, rgba(34,211,238,0.08), transparent 32%),
    linear-gradient(180deg, rgba(15,15,28,0.96), rgba(11,11,20,0.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}

.document-preview-docx-shell {
  flex:1;
  height:100%;
  min-height:0;
  overflow:auto;
  border-radius:calc(var(--radius-2xl) - 6px);
  border:1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(240,200,74,0.08), transparent 32%),
    radial-gradient(circle at bottom right, rgba(34,211,238,0.08), transparent 32%),
    linear-gradient(180deg, rgba(15,15,28,0.96), rgba(11,11,20,0.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}

.document-preview-pdf-shell {
  flex:1;
  height:100%;
  min-height:0;
  overflow:auto;
  border-radius:calc(var(--radius-2xl) - 6px);
  border:1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(240,200,74,0.08), transparent 32%),
    radial-gradient(circle at bottom right, rgba(34,211,238,0.08), transparent 32%),
    linear-gradient(180deg, rgba(15,15,28,0.96), rgba(11,11,20,0.98));
  box-shadow:inset 0 1px 0 rgba(255,255,255,0.04);
}

.document-preview-pdf-stage {
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:16px;
  min-height:100%;
  padding:16px;
}

.document-preview-pdf-page {
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}

.document-preview-pdf-meta {
  align-self:flex-start;
  padding:4px 10px;
  border-radius:var(--radius-full);
  background:var(--bg-glass-light);
  border:1px solid var(--border);
  color:var(--text-secondary);
  font-family:var(--font-mono);
  font-size:0.66rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
}

.document-preview-pdf-canvas {
  display:block;
  max-width:100%;
  border-radius:18px;
  background:#ffffff;
  box-shadow:0 20px 56px rgba(0,0,0,0.42);
}

.document-preview-pdf-page,
.document-preview-pdf-canvas {
  width:100%;
}

.document-preview-docx-stage {
  min-height:100%;
  padding:clamp(14px, 2vw, 28px);
}

.document-preview-docx-stage .docx-wrapper {
  background:transparent !important;
  padding:0 !important;
}

.document-preview-docx-stage .docx-wrapper > section.docx {
  margin:0 auto 24px !important;
  max-width:min(100%, 1040px) !important;
  box-shadow:0 18px 52px rgba(0,0,0,0.4) !important;
}

[data-theme="light"] .document-preview-docx-stage .docx-wrapper {
  background:rgba(0,0,0,0.02) !important;
}

.document-viewer-frame {
  width:100%;
  height:100%;
  min-height:680px;
  border:0;
  display:block;
  background:#11121e;
}

.document-viewer-fallback {
  flex:1;
  min-height:520px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:var(--space-10) var(--space-6);
  gap:var(--space-4);
}

.document-viewer-fallback-icon {
  width:64px;
  height:64px;
  border-radius:20px;
  display:flex;
  align-items:center;
  justify-content:center;
  color:var(--accent);
  background:var(--accent-bg);
  border:1px solid var(--border-accent);
  box-shadow:0 0 24px var(--accent-glow);
}

.document-viewer-fallback-icon svg {
  width:28px;
  height:28px;
}

.document-viewer-fallback-title {
  font-family:var(--font-display);
  font-size:1.4rem;
  font-weight:800;
  letter-spacing:-0.03em;
}

.document-viewer-fallback-copy,
.document-viewer-note {
  font-size:0.9rem;
  color:var(--text-secondary);
  line-height:1.75;
}

.document-viewer-fallback-copy {
  max-width:480px;
}

.document-viewer-fallback-actions {
  display:flex;
  align-items:center;
  justify-content:center;
  gap:var(--space-3);
  flex-wrap:wrap;
}

/* ── Empty State ── */
.empty-state {
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  padding:var(--space-20) var(--space-8); text-align:center;
}
.empty-state-img {
  width:150px; height:150px; margin-bottom:var(--space-6);
  opacity:0.5; filter:drop-shadow(0 8px 24px var(--accent-glow));
  animation:float-img 4s ease-in-out infinite;
}
@keyframes float-img {
  0%,100% { transform:translateY(0) rotate(0deg); }
  50%  { transform:translateY(-14px) rotate(1.5deg); }
}
.empty-state-title { font-family:var(--font-display); font-size:1.375rem; font-weight:800; margin-bottom:var(--space-3); letter-spacing:-0.025em; }
.empty-state-desc { font-size:0.9rem; color:var(--text-secondary); max-width:380px; line-height:1.75; margin-bottom:var(--space-6); }

/* ── Detail layout ── */
.detail-grid { display:grid; grid-template-columns:1fr 340px; gap:var(--space-6); align-items:start; }

.detail-pair-grid {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--space-5);
}

.detail-pair-grid-spaced {
  margin-bottom:var(--space-5);
}

.detail-doc-grid {
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:var(--space-4);
}

.detail-edit-panel {
  position:sticky;
  top:76px;
}

.detail-section {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-2xl); overflow:hidden; margin-bottom:var(--space-5);
  transition:box-shadow var(--transition-base);
}
.detail-section:hover { box-shadow:var(--shadow-md); }

.detail-section-header {
  display:flex; align-items:center; gap:var(--space-3);
  padding:var(--space-4) var(--space-6);
  border-bottom:1px solid var(--border); background:var(--bg-secondary);
}

.detail-section-icon {
  width:30px; height:30px; border-radius:var(--radius-md);
  background:var(--accent-bg); border:1px solid var(--border-accent);
  display:flex; align-items:center; justify-content:center; color:var(--accent); flex-shrink:0;
}
.detail-section-icon svg { width:14px; height:14px; }
.detail-section-title { font-family:var(--font-mono); font-size:0.7rem; font-weight:600; color:var(--text-secondary); text-transform:uppercase; letter-spacing:0.1em; }
.detail-section-body { padding:var(--space-5) var(--space-6); }
.detail-field { display:flex; flex-direction:column; gap:4px; margin-bottom:var(--space-5); }
.detail-field:last-child { margin-bottom:0; }
.detail-field-label { font-family:var(--font-mono); font-size:0.66rem; text-transform:uppercase; letter-spacing:0.09em; color:var(--text-muted); }
.detail-field-value { font-size:0.925rem; color:var(--text-primary); font-weight:500; line-height:1.55; }
.detail-field-empty { color:var(--text-muted); font-style:italic; font-weight:400; }

/* ── Cards (generic) ── */
.card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-2xl); padding:var(--space-6);
  box-shadow:var(--shadow-sm); transition:box-shadow var(--transition-base);
}
.card:hover { box-shadow:var(--shadow-md); }
.card-header { display:flex; align-items:center; justify-content:space-between; padding-bottom:var(--space-5); margin-bottom:var(--space-5); border-bottom:1px solid var(--border-subtle); }
.card-title { font-family:var(--font-display); font-size:1rem; font-weight:700; color:var(--text-primary); }
.card-lg { padding:var(--space-8) var(--space-10); }

/* ── Confirm Modal ── */
.modal-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,0.75);
  backdrop-filter:blur(10px); -webkit-backdrop-filter:blur(10px);
  z-index:200; display:flex; align-items:center; justify-content:center;
  padding:var(--space-4); opacity:0; pointer-events:none; transition:opacity var(--transition-base);
}
.modal-overlay.active { opacity:1; pointer-events:auto; }
.modal {
  background:var(--bg-card); border:1px solid var(--border-glass);
  border-radius:var(--radius-2xl); padding:var(--space-8);
  max-width:400px; width:100%; box-shadow:var(--shadow-xl);
  transform:scale(0.92) translateY(18px); transition:transform var(--transition-spring);
}
.modal.document-preview-modal {
  max-width:1560px;
  width:min(92vw, 1560px);
  padding:0;
}
.modal-overlay.active .modal { transform:scale(1) translateY(0); }
.modal-title { font-family:var(--font-display); font-size:1.25rem; font-weight:800; margin-bottom:var(--space-3); }
.modal-desc { font-size:0.9rem; color:var(--text-secondary); margin-bottom:var(--space-6); }
.modal-actions { display:flex; gap:var(--space-3); justify-content:flex-end; }

/* ── Toast ── */
.toast-container { position:fixed; bottom:var(--space-6); right:var(--space-6); z-index:300; display:flex; flex-direction:column; gap:var(--space-3); pointer-events:none; }
.toast {
  display:flex; align-items:center; gap:var(--space-3);
  padding:var(--space-4) var(--space-5);
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-xl); box-shadow:var(--shadow-lg);
  font-size:0.875rem; font-weight:500; pointer-events:auto;
  animation:toast-in 0.45s cubic-bezier(0.16,1,0.3,1) both;
  max-width:340px; backdrop-filter:blur(12px);
}
@keyframes toast-in {
  from { opacity:0; transform:translateX(28px) scale(0.94); }
  to   { opacity:1; transform:none; }
}
.toast-success { border-color:var(--success); }
.toast-success svg { color:var(--success); }
.toast-error { border-color:var(--danger); }
.toast-error svg { color:var(--danger); }
.toast svg { width:16px; height:16px; flex-shrink:0; }

/* ── Utilities ── */
.container { width:100%; max-width:1200px; margin:0 auto; padding:0 var(--space-6); }
.flex { display:flex; }
.items-center { align-items:center; }
.justify-between { justify-content:space-between; }
.gap-4 { gap:var(--space-4); }
.text-center { text-align:center; }
.text-muted { color:var(--text-muted); }
.text-accent { color:var(--accent); }
.text-danger { color:var(--danger); }
.text-success { color:var(--success); }
.text-mono { font-family:var(--font-mono); }
.hidden { display:none !important; }
.w-full { width:100%; }
.mt-auto { margin-top:auto; }
.grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-6); }
.grid-3 { display:grid; grid-template-columns:1fr 1fr 1fr; gap:var(--space-6); }
.divider { height:1px; background:var(--border); margin:var(--space-6) 0; }

/* ── Scroll Reveal ── */
[data-reveal] {
  opacity:0;
  transform:translateY(36px);
  transition:opacity 0.75s cubic-bezier(0.16,1,0.3,1), transform 0.75s cubic-bezier(0.16,1,0.3,1);
}
[data-reveal].revealed { opacity:1; transform:none; }
[data-reveal-delay="1"] { transition-delay:0.1s; }
[data-reveal-delay="2"] { transition-delay:0.2s; }
[data-reveal-delay="3"] { transition-delay:0.3s; }
[data-reveal-delay="4"] { transition-delay:0.4s; }
[data-reveal-delay="5"] { transition-delay:0.5s; }

.mobile-menu-toggle {
  display:none; width:38px; height:38px;
  align-items:center; justify-content:center;
  background:var(--bg-glass-light); border:1px solid var(--border);
  color:var(--text-secondary); border-radius:var(--radius-lg);
  transition:all var(--transition-fast);
}
.mobile-menu-toggle:hover { color:var(--text-primary); border-color:var(--border-strong); }

.sidebar-overlay {
  display:none; position:fixed; inset:0;
  background:rgba(0,0,0,0.65); backdrop-filter:blur(4px); z-index:49;
}

.separator-text { display:flex; align-items:center; gap:var(--space-3); color:var(--text-muted); font-size:0.76rem; margin:var(--space-4) 0; }
.separator-text::before,.separator-text::after { content:''; flex:1; height:1px; background:var(--border); }

/* ── Responsive ── */
@media (max-width:1024px) {
  .hero-dashboard { display:none; }
  .detail-grid { grid-template-columns:1fr; }
  .detail-edit-panel { position:static; top:auto; }
}
@media (max-width:900px) {
  .container { padding:0 var(--space-4); }
  .pub-nav {
    width:calc(100% - 24px);
    padding:0 var(--space-4);
  }
  .nav-links { display:none; }
  .nav-actions { margin-left:auto; }
  .hero {
    min-height:auto;
    padding:120px 0 84px;
  }
  .hero-content { max-width:none; }
  .hero-social-proof {
    flex-wrap:wrap;
    gap:var(--space-4);
  }
  .hero-social-proof > [aria-hidden="true"] { display:none; }
  .section-intro { max-width:100%; }
  .hiw-layout {
    grid-template-columns:1fr;
    gap:var(--space-10);
  }
  .footer-inner {
    flex-direction:column;
    align-items:flex-start;
  }
  .footer-links {
    flex-wrap:wrap;
    gap:var(--space-4);
  }
  .page-content {
    padding:var(--space-6) var(--space-4);
    max-width:100%;
  }
  .page-content-wide { max-width:100%; }
  .page-content-wide .page-title { font-size:clamp(1.85rem, 7vw, 2.2rem); }
  .page-content-wide .stat-value {
    transform:none;
    line-height:1;
  }
  .app-topbar {
    padding:0 var(--space-4);
    min-height:68px;
    height:auto;
    flex-wrap:wrap;
    align-content:center;
    gap:var(--space-3);
  }
  .topbar-breadcrumb {
    min-width:0;
    flex-wrap:wrap;
    font-size:0.72rem;
  }
  .topbar-actions {
    width:100%;
    margin-left:0;
    justify-content:flex-start;
    flex-wrap:wrap;
  }
  .topbar-actions > .btn,
  .topbar-actions > a.btn,
  .topbar-actions > button.btn {
    flex:1 1 180px;
    justify-content:center;
  }
  .page-header {
    flex-direction:column;
    align-items:stretch;
    margin-bottom:var(--space-6);
  }
  .page-actions {
    width:100%;
    justify-content:stretch;
    flex-wrap:wrap;
  }
  .page-actions > a,
  .page-actions > button,
  .page-actions > form {
    flex:1 1 180px;
  }
  .page-actions > a.btn,
  .page-actions > button.btn,
  .page-actions form .btn {
    width:100%;
    justify-content:center;
  }
  .stats-bar {
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:var(--space-3);
  }
  .document-grid { grid-template-columns:1fr; }
  .document-card-actions { flex-wrap:wrap; }
  .document-preview-modal {
    width:min(100%, 1100px);
    height:min(90vh, 920px);
  }
  .document-preview-header {
    padding:var(--space-4) var(--space-5);
  }
  .document-viewer-layout { grid-template-columns:1fr; }
  .document-viewer-card { min-height:0; }
  .document-viewer-frame { min-height:560px; height:72vh; }
  .detail-section-header { padding:var(--space-4) var(--space-5); }
  .detail-section-body { padding:var(--space-5); }
  .detail-pair-grid,
  .detail-doc-grid,
  .form-row,
  .form-row-third {
    grid-template-columns:1fr;
    gap:var(--space-4);
  }
  .location-card-header {
    flex-direction:column;
    gap:var(--space-3);
  }
  .location-map { height:220px; }
  .location-map-toolbar {
    flex-direction:column;
    align-items:flex-start;
  }
  .location-search-results {
    max-height:260px;
    overflow:auto;
  }
  .document-mode-switch { flex-wrap:wrap; }
  .document-mode-pill { flex:1 1 180px; }
  .page-shell-narrow,
  .page-shell-compact { max-width:none; }
  .grid-2,
  .grid-3 { grid-template-columns:1fr; }
}

@media (max-width:768px) {
  :root { --sidebar-width:0px; }
  .sidebar {
    transform:translateX(-100%);
    width:min(84vw, 248px);
    height:100dvh;
    overflow-y:auto;
  }
  .sidebar.open { transform:none; }
  .sidebar-overlay {
    display:block;
    opacity:0;
    pointer-events:none;
    transition:opacity var(--transition-base);
  }
  .sidebar-overlay.active {
    opacity:1;
    pointer-events:auto;
  }
  .app-main {
    margin-left:0;
    min-width:0;
    min-height:100dvh;
  }
  .mobile-menu-toggle { display:flex; }
  #particles-canvas,
  #cursor-dot,
  #cursor-ring { display:none; }
  .page-content {
    flex:0 0 auto;
    padding:var(--space-5) var(--space-4) var(--space-6);
  }
  .page-title { font-size:1.65rem; }
  .page-subtitle { font-size:0.72rem; }
  .stat-card { padding:var(--space-4); }
  .stat-value { font-size:1.75rem; }
  .app-table-wrap {
    display:block;
    min-height:0;
    max-height:none;
    overflow:visible;
  }
  .app-table-header {
    padding:var(--space-4);
    align-items:stretch;
    flex-direction:column;
  }
  .table-search {
    max-width:none;
    width:100%;
  }
  .table-results-count { align-self:flex-start; }
  .app-table-scroller {
    display:block;
    flex:none;
    min-height:auto;
    overflow:visible;
  }
  .table {
    display:block;
    min-width:0;
    width:100%;
  }
  .table colgroup { display:none; }
  .table thead { display:none; }
  .table tbody {
    display:grid;
    gap:var(--space-4);
    padding:var(--space-4);
  }
  .table tbody tr {
    display:block;
    padding:var(--space-4);
    border:1px solid var(--border);
    border-radius:var(--radius-xl);
    background:var(--bg-glass-light);
  }
  .table tbody tr:hover { background:var(--bg-glass-light); }
  .table tbody tr td {
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
    gap:var(--space-4);
    padding:0;
    border:none;
    text-align:right;
  }
  .table tbody tr td + td {
    margin-top:var(--space-3);
    padding-top:var(--space-3);
    border-top:1px solid var(--border-subtle);
  }
  .table td::before {
    content:attr(data-label);
    flex:0 0 40%;
    text-align:left;
    font-family:var(--font-mono);
    font-size:0.68rem;
    text-transform:uppercase;
    letter-spacing:0.08em;
    color:var(--text-muted);
  }
  .table td:first-child,
  .table td:last-child {
    padding-left:0;
    padding-right:0;
  }
  .table tbody tr td:first-child::before {
    position:static;
    width:auto;
    background:none;
    transition:none;
  }
  .table-company-name,
  .table-title,
  .table-date,
  .table-status-text {
    white-space:normal;
    overflow:visible;
    text-overflow:clip;
  }
  .table-company,
  .table-title-cell,
  .table-status-cell,
  .table-date,
  .table-actions-cell {
    text-align:right;
  }
  .table-actions-cell { min-width:0; }
  .table-location,
  .table-compensation {
    justify-content:flex-end;
    max-width:60%;
  }
  .table-actions {
    justify-content:flex-end;
    width:100%;
    flex-wrap:wrap;
  }
  .table-empty-row { display:block; }
  .table-empty-row td {
    display:block;
    text-align:center;
  }
  .table-empty-row td::before { display:none; }
  .auth-page {
    padding:84px var(--space-4) var(--space-6);
    align-items:flex-start;
  }
  .auth-card { padding:var(--space-8) var(--space-6); }
  .auth-back {
    left:var(--space-4);
    top:var(--space-4);
  }
}

@media (max-width:580px) {
  .hero {
    padding:108px 0 72px;
  }
  .hero-title { font-size:clamp(2.2rem, 11vw, 3rem); }
  .hero-subtitle { font-size:0.96rem; }
  .hero-actions,
  .cta-actions,
  .form-actions-row,
  .document-card-actions {
    flex-direction:column;
    align-items:stretch;
  }
  .hero-actions .btn,
  .cta-actions .btn,
  .page-actions > a,
  .page-actions > button,
  .page-actions > form,
  .page-actions form .btn,
  .form-actions-row > .btn,
  .document-card-actions .btn {
    width:100%;
  }
  .document-card-actions form { width:100%; }
  .document-preview-modal {
    height:min(94vh, 860px);
  }
  .document-preview-header {
    grid-template-columns:1fr;
    align-items:stretch;
  }
  .document-preview-toolbar {
    justify-content:flex-start;
    flex-wrap:wrap;
  }
  .document-preview-toolbar > .btn,
  .document-preview-toolbar > a {
    width:100%;
    justify-content:center;
  }
  .document-preview-body {
    padding:var(--space-3);
  }
  .document-preview-pdf-stage,
  .document-preview-docx-stage {
    padding:12px;
  }
  .pub-nav {
    width:calc(100% - 16px);
    top:8px;
    height:auto;
    min-height:56px;
    padding:10px 12px;
    gap:var(--space-3);
  }
  .nav-logo {
    font-size:1.05rem;
    gap:var(--space-2);
  }
  .nav-logo-icon {
    width:30px;
    height:30px;
  }
  .hero-social-proof {
    margin-top:var(--space-8);
    padding-top:var(--space-6);
  }
  .hiw-layout { gap:var(--space-8); }
  .location-map { height:190px; }
  .location-map-shell { padding:12px; }
  .document-viewer-frame { min-height:420px; height:62vh; }
  .document-preview-loading {
    min-height:260px;
    font-size:0.85rem;
  }
  .document-viewer-fallback-actions {
    flex-direction:column;
    align-items:stretch;
    width:100%;
  }
  .document-viewer-fallback-actions .btn { width:100%; }
  .custom-date-popover {
    left:50%;
    transform:translateX(-50%);
    width:min(calc(100vw - 32px), 320px);
  }
  .table tbody { padding:var(--space-3); }
  .table tbody tr { padding:var(--space-3); }
  .table tbody tr td {
    flex-direction:column;
    align-items:flex-start;
    text-align:left;
    gap:var(--space-2);
  }
  .table td::before { flex:none; }
  .table-location,
  .table-compensation,
  .table-actions {
    justify-content:flex-start;
    max-width:none;
    width:100%;
  }
  .stats-bar { grid-template-columns:1fr; }
  .footer-links { gap:var(--space-3); }
}

@media (max-width:480px) {
  .container { padding:0 var(--space-4); }
  .section-title { font-size:1.65rem; }
  .page-content { padding-inline:var(--space-3); }
  .app-topbar { padding:0 var(--space-3); }
  .topbar-breadcrumb { font-size:0.68rem; }
  .stat-label { font-size:0.62rem; }
  .stat-value { font-size:1.6rem; }
  .page-title { font-size:1.5rem; }
  .document-grid { grid-template-columns:1fr; }
  .auth-card { padding:var(--space-7) var(--space-5); }
  .file-upload-area { padding:var(--space-6) var(--space-4); }
  .detail-section-header { padding:var(--space-4); }
  .detail-section-body { padding:var(--space-4); }
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--border-strong); border-radius:var(--radius-full); }
::-webkit-scrollbar-thumb:hover { background:var(--text-muted); }

/* ── Focus ── */
:focus-visible { outline:2px solid var(--accent); outline-offset:2px; border-radius:var(--radius-sm); }
::selection { background:var(--accent-bg); color:var(--accent); }

/* ── Password strength ── */
.pw-strength-bar-track { height:3px; border-radius:2px; background:var(--border); overflow:hidden; margin-bottom:5px; }
.pw-strength-bar-fill { height:100%; border-radius:2px; width:0%; transition:width 0.35s ease, background 0.35s ease; }

/* ── How-it-works step cards ── */
.step-card {
  background:var(--bg-card); border:1px solid var(--border);
  border-radius:var(--radius-2xl); padding:var(--space-8) var(--space-6);
  text-align:center; position:relative; overflow:hidden;
  transition:all var(--transition-slow);
}
.step-card::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 50% 0%, var(--accent-bg), transparent 60%);
  opacity:0; transition:opacity var(--transition-base);
}
.step-card:hover::before { opacity:1; }
.step-card:hover { border-color:var(--border-accent); box-shadow:var(--shadow-glow), var(--shadow-lg); transform:translateY(-8px); }

.step-num {
  width:56px; height:56px; border-radius:var(--radius-full);
  border:2px solid var(--border-accent); background:var(--accent-bg);
  display:flex; align-items:center; justify-content:center;
  margin:0 auto var(--space-5);
  font-family:var(--font-display); font-size:1.375rem; font-weight:800; color:var(--accent);
  box-shadow:0 0 24px var(--accent-glow);
  transition:all var(--transition-spring);
}
.step-card:hover .step-num { transform:scale(1.18) rotate(12deg); box-shadow:0 0 48px var(--accent-glow-strong); }

/* ── Animated counter number ── */
@keyframes count-up { from { opacity:0; transform:translateY(10px); } to { opacity:1; transform:none; } }
.counter-anim { animation:count-up 0.5s cubic-bezier(0.16,1,0.3,1) both; }

/* ============================================================
   TRACKR PREMIUM ADDITIONS v3
   Scroll-triggered 3D · Magnetic · Parallax layers · Cinematic
   ============================================================ */

/* ── Horizontal scroll progress bar ── */
#scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 2px;
  width: 0%;
  background: linear-gradient(90deg, var(--accent-dark), var(--accent), var(--accent-light), var(--cyan));
  z-index: 9999;
  transition: width 0.05s linear;
  box-shadow: 0 0 12px var(--accent-glow-strong);
}

/* ── Custom cursor ── */
#cursor-dot {
  position: fixed;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: transform 0.08s ease, background 0.2s, width 0.2s, height 0.2s, opacity 0.2s;
  box-shadow: 0 0 10px var(--accent-glow);
  mix-blend-mode: normal;
}

#cursor-ring {
  position: fixed;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1.5px solid rgba(240,200,74,0.4);
  pointer-events: none;
  z-index: 9997;
  transform: translate(-50%, -50%);
  transition: transform 0.18s cubic-bezier(0.4,0,0.2,1), width 0.25s, height 0.25s, border-color 0.2s, opacity 0.2s;
}

body:has(a:hover) #cursor-ring,
body:has(button:hover) #cursor-ring,
body:has(.btn:hover) #cursor-ring {
  width: 52px;
  height: 52px;
  border-color: var(--accent);
  box-shadow: 0 0 20px var(--accent-glow);
}

@media (hover: none) {
  #cursor-dot, #cursor-ring { display: none; }
}

/* ── Magnetic button wrapper ── */
.magnetic-wrap { display: inline-block; }

/* ── Hero section enhancements ── */
.hero-floating-cards {
  position: absolute;
  right: -40px;
  top: 50%;
  transform: translateY(-50%);
  width: 540px;
  z-index: 2;
  pointer-events: none;
  perspective: 1200px;
}

.hero-card-3d {
  background: var(--bg-glass);
  border: 1px solid var(--border-glass);
  border-radius: var(--radius-2xl);
  backdrop-filter: blur(24px);
  box-shadow: var(--shadow-3d);
  overflow: hidden;
  animation: hero-card-float 1.2s cubic-bezier(0.16,1,0.3,1) both;
  transform-style: preserve-3d;
}

@keyframes hero-card-float {
  from { opacity: 0; transform: translateX(80px) rotateY(-20deg) rotateX(8deg); }
  to   { opacity: 1; transform: rotateY(-4deg) rotateX(2deg); }
}

.hero-card-3d-idle {
  animation: idle-float 10s ease-in-out infinite;
}

@keyframes idle-float {
  0%,100% { transform: rotateY(-4deg) rotateX(2deg) translateY(0px); }
  33%  { transform: rotateY(-2deg) rotateX(4deg) translateY(-6px); }
  66%  { transform: rotateY(-6deg) rotateX(1deg) translateY(4px); }
}

/* ── Scroll-reveal variants ── */
[data-reveal="left"] {
  opacity: 0;
  transform: translateX(-40px);
  transition: opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
[data-reveal="right"] {
  opacity: 0;
  transform: translateX(40px);
  transition: opacity 0.8s cubic-bezier(0.16,1,0.3,1), transform 0.8s cubic-bezier(0.16,1,0.3,1);
}
[data-reveal="scale"] {
  opacity: 0;
  transform: scale(0.88);
  transition: opacity 0.7s cubic-bezier(0.16,1,0.3,1), transform 0.7s cubic-bezier(0.16,1,0.3,1);
}
[data-reveal="left"].revealed,
[data-reveal="right"].revealed,
[data-reveal="scale"].revealed { opacity: 1; transform: none; }

/* ── Landing page — animated word highlight ── */
.word-highlight {
  position: relative;
  display: inline-block;
  z-index: 0;
}
.word-highlight::after {
  content: '';
  position: absolute;
  bottom: 2px;
  left: -2px;
  right: -2px;
  height: 30%;
  background: rgba(240,200,74,0.18);
  border-radius: 3px;
  z-index: -1;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.6s cubic-bezier(0.16,1,0.3,1) 0.8s;
}
.word-highlight.animate-highlight::after { transform: scaleX(1); }

/* ── Typing cursor ── */
.typing-cursor {
  display: inline-block;
  width: 3px;
  height: 1em;
  background: var(--accent);
  margin-left: 3px;
  vertical-align: text-bottom;
  border-radius: 2px;
  animation: blink-cursor 1.1s step-end infinite;
}
@keyframes blink-cursor {
  0%,100% { opacity: 1; }
  50% { opacity: 0; }
}

/* ── Number ticker (hero stats) ── */
.stat-ticker {
  display: inline-block;
  overflow: hidden;
  line-height: 1;
}

/* ── Staggered letter animation ── */
.split-text span {
  display: inline-block;
  opacity: 0;
  transform: translateY(24px) rotate(2deg);
  animation: letter-in 0.5s cubic-bezier(0.16,1,0.3,1) forwards;
}
@keyframes letter-in {
  to { opacity: 1; transform: none; }
}

/* ── Orbital feature icons ── */
.orbital-container {
  position: relative;
  width: 340px;
  height: 340px;
  margin: 0 auto;
}

.orbital-center {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--accent-bg);
  border: 2px solid var(--border-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  box-shadow: 0 0 40px var(--accent-glow), 0 0 80px rgba(240,200,74,0.06);
}

.orbital-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  border: 1px dashed rgba(240,200,74,0.12);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.orbital-ring-1 { width: 180px; height: 180px; animation: ring-spin 20s linear infinite; }
.orbital-ring-2 { width: 280px; height: 280px; animation: ring-spin 30s linear infinite reverse; }

@keyframes ring-spin {
  from { transform: translate(-50%, -50%) rotate(0deg); }
  to   { transform: translate(-50%, -50%) rotate(360deg); }
}

.orbital-node {
  position: absolute;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 1px solid var(--border-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  box-shadow: 0 4px 16px rgba(0,0,0,0.4), 0 0 20px var(--accent-glow);
  z-index: 3;
}

/* ── Glowing divider ── */
.glow-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--accent), var(--cyan), transparent);
  opacity: 0.3;
  margin: 0;
}

/* ── Animated gradient text ── */
.animated-gradient-text {
  background: linear-gradient(
    135deg,
    var(--accent) 0%,
    var(--accent-light) 25%,
    #ff9d4a 50%,
    var(--cyan) 75%,
    var(--accent) 100%
  );
  background-size: 300% 300%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: gradient-shift 6s ease-in-out infinite;
  filter: drop-shadow(0 0 20px var(--accent-glow));
}

@keyframes gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

/* ── Shimmer card loading effect ── */
.shimmer {
  position: relative;
  overflow: hidden;
}
.shimmer::after {
  content: '';
  position: absolute;
  top: 0; left: -100%; width: 60%; height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.04), transparent);
  transform: skewX(-15deg);
  animation: shimmer-slide 3s ease-in-out infinite;
}
@keyframes shimmer-slide {
  0%   { left: -100%; }
  100% { left: 200%; }
}

/* ── Scroll section parallax wrapper ── */
.parallax-section { position: relative; overflow: hidden; }
.parallax-bg {
  position: absolute;
  inset: -20%;
  will-change: transform;
}

/* ── Stats counter pop ── */
.stat-value.counting {
  animation: stat-pop 0.2s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes stat-pop {
  0% { transform: scale(1); }
  50%{ transform: scale(1.15); }
  100%{ transform: scale(1); }
}

/* ── Feature grid enhanced ── */
.features-bento {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto auto;
  gap: var(--space-5);
  margin-top: var(--space-12);
}

.bento-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-2xl);
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
  transition: all 0.5s cubic-bezier(0.4,0,0.2,1);
  cursor: default;
}

.bento-card-wide { grid-column: span 2; }
.bento-card-tall { grid-row: span 2; }

.bento-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle at var(--mx,50%) var(--my,50%), var(--accent-bg) 0%, transparent 65%);
  opacity: 0;
  transition: opacity var(--transition-base);
  pointer-events: none;
}
.bento-card:hover::before { opacity: 1; }
.bento-card:hover {
  border-color: var(--border-accent);
  box-shadow: var(--shadow-lg), var(--shadow-glow);
  transform: translateY(-6px);
}

.bento-card-number {
  position: absolute;
  top: var(--space-5);
  right: var(--space-5);
  font-family: var(--font-display);
  font-size: 3.5rem;
  font-weight: 800;
  color: rgba(240,200,74,0.06);
  line-height: 1;
  letter-spacing: -0.05em;
  pointer-events: none;
  user-select: none;
}

/* ── Landing page how-it-works timeline ── */
.timeline {
  position: relative;
  padding-left: var(--space-10);
}
.timeline::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 20px;
  bottom: 20px;
  width: 2px;
  background: linear-gradient(to bottom, var(--accent), var(--cyan), transparent);
  opacity: 0.3;
}
.timeline-item {
  position: relative;
  margin-bottom: var(--space-10);
}
.timeline-dot {
  position: absolute;
  left: calc(-1 * var(--space-10) + 7px);
  top: 4px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--bg-card);
  border: 2px solid var(--accent);
  box-shadow: 0 0 14px var(--accent-glow);
  transition: all var(--transition-spring);
}
.timeline-item:hover .timeline-dot {
  transform: scale(1.35);
  box-shadow: 0 0 24px var(--accent-glow-strong);
}

/* ── App page — glowing stat cards ── */
.stat-card.glow-on-hover:hover {
  box-shadow: var(--shadow-md), 0 0 30px var(--accent-glow);
}

/* ── Auth page floating particles ── */
.auth-particle {
  position: fixed;
  border-radius: 50%;
  pointer-events: none;
  animation: auth-float linear infinite;
}
@keyframes auth-float {
  0%   { transform: translateY(0) rotate(0deg); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: translateY(-100vh) rotate(720deg); opacity: 0; }
}

/* ── Page transition ── */
.page-transition-out {
  animation: page-out 0.3s ease forwards;
}
@keyframes page-out {
  to { opacity: 0; transform: scale(0.98); }
}

/* ── Noise texture on hero ── */
.hero-noise {
  position: absolute;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 180px;
  opacity: 0.025;
  pointer-events: none;
  z-index: 1;
}

/* ── Animated background grid for app pages ── */
.app-bg-grid {
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.022) 1px, transparent 1px);
  background-size: 48px 48px;
  pointer-events: none;
  z-index: 0;
}

/* ── App layout sits above grid ── */
.app-layout { position: relative; z-index: 1; }

/* ── Sidebar glow dot indicator ── */
.sidebar-status-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--success);
  box-shadow: 0 0 8px var(--success);
  animation: dot-pulse 2.5s ease-in-out infinite;
  margin-left: auto;
}

/* ── Topbar glow line ── */
.app-topbar::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: var(--sidebar-width);
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, var(--accent-glow), transparent 50%);
  opacity: 0.4;
}

/* ── Document card type tag ── */
.doc-type-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: var(--accent-bg);
  border: 1px solid var(--border-accent);
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
  font-size: 0.6rem;
  font-weight: 600;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

/* ── Form focus glow line ── */
.form-control:focus {
  box-shadow: 0 0 0 3px var(--accent-bg), 0 4px 16px rgba(0,0,0,0.2), 0 -1px 0 var(--accent) inset;
}

/* ── Submit button loading state ── */
.btn-loading {
  position: relative;
  color: transparent !important;
  pointer-events: none;
}
.btn-loading::after {
  content: '';
  position: absolute;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(10,10,18,0.3);
  border-top-color: #0a0a12;
  border-radius: 50%;
  animation: btn-spin 0.7s linear infinite;
}
@keyframes btn-spin { to { transform: rotate(360deg); } }

/* ── Glassmorphism card variant ── */
.card-glass {
  background: var(--bg-glass);
  backdrop-filter: blur(28px) saturate(180%);
  -webkit-backdrop-filter: blur(28px) saturate(180%);
  border: 1px solid var(--border-glass);
}

/* Light theme specific overrides */
[data-theme="light"] .hero-orb-1 { opacity: 0.06; }
[data-theme="light"] .hero-orb-2 { opacity: 0.05; }
[data-theme="light"] .hero-orb-3 { opacity: 0.04; }
[data-theme="light"] .hero-mesh { opacity: 0.7; }
[data-theme="light"] #particles-canvas { opacity: 0.4; }
[data-theme="light"] .animated-gradient-text { filter: none; }
[data-theme="light"] .app-bg-grid { opacity: 0.5; }

/* ── Responsive bento ── */
@media (max-width: 900px) {
  .features-bento { grid-template-columns: 1fr 1fr; }
  .bento-card-wide { grid-column: span 1; }
  .bento-card-tall { grid-row: span 1; }
}
@media (max-width: 600px) {
  .features-bento { grid-template-columns: 1fr; }
  .hero-floating-cards { display: none; }
  .orbital-container { display: none; }
}
