/* ─── DESIGN TOKENS ────────────────────────────────────────────── */
:root {
  --bg-deep:   #08131a;
  --bg-mid:    #11202a;
  --bg-card:   rgba(12, 28, 36, 0.74);
  --bg-glass:  rgba(17, 38, 48, 0.52);
  --bg-input:  rgba(9, 20, 26, 0.72);

  --border-subtle: rgba(82, 158, 171, 0.18);
  --border-glow:   rgba(90, 183, 183, 0.32);
  --border-active: rgba(123, 202, 185, 0.52);

  --accent-blue:    #3aa6a2;
  --accent-violet:  #ff8b48;
  --accent-cyan:    #59c7c2;
  --accent-emerald: #10b981;
  --accent-amber:   #f59e0b;
  --accent-rose:    #f43f5e;

  --ink-primary:   #e6f2ef;
  --ink-secondary: #9ab7b1;
  --ink-muted:     #5d7d77;

  --glow-blue:   rgba(77, 173, 169, 0.22);
  --glow-violet: rgba(255, 139, 72, 0.18);

  --panel-shadow: 0 24px 80px rgba(0, 0, 0, 0.7),
                  0 0 0 1px var(--border-subtle),
                  inset 0 1px 0 rgba(255, 255, 255, 0.06);
  --card-shadow:  0 8px 32px rgba(0, 0, 0, 0.5),
                  0 0 0 1px var(--border-subtle);
  --btn-shadow:   0 4px 24px rgba(79, 140, 255, 0.3);
  --modal-shadow: 0 40px 120px rgba(0, 0, 0, 0.85),
                  0 0 0 1px rgba(99, 149, 255, 0.2),
                  inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

/* ─── RESET ─────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body.modal-open {
  overflow: hidden;
}

body,
.site-header,
.glass-panel,
.hero-panel,
.metric-card,
.modal-card,
input,
textarea,
select,
button {
  transition:
    background-color 220ms ease,
    background 220ms ease,
    border-color 220ms ease,
    box-shadow 220ms ease,
    color 180ms ease,
    filter 180ms ease;
}

/* ─── BODY ──────────────────────────────────────────────────────── */
body {
  font-family: 'DM Sans', ui-sans-serif, system-ui;
  background-color: var(--bg-deep);
  background-image:
    radial-gradient(ellipse 85% 58% at 0% 0%, rgba(58,166,162,0.15) 0%, transparent 58%),
    radial-gradient(ellipse 60% 46% at 95% 12%, rgba(255,139,72,0.13) 0%, transparent 52%),
    radial-gradient(ellipse 65% 52% at 45% 100%, rgba(89,199,194,0.08) 0%, transparent 46%),
    url("data:image/svg+xml,%3Csvg width='64' height='64' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%233aa6a2' fill-opacity='0.03'%3E%3Cpath d='M32 0l4.2 12.8L49 17l-10.4 7.7L42.8 38 32 30.2 21.2 38l4.2-13.3L15 17l12.8-4.2z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
  min-height: 100vh;
  color: var(--ink-primary);
  -webkit-font-smoothing: antialiased;
}

body::before {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(115deg, rgba(255,255,255,0.035), transparent 24%, rgba(79,140,255,0.035) 52%, transparent 76%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.018) 0 1px, transparent 1px 120px);
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.92), rgba(0,0,0,0.28));
}

body::after {
  content: '';
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    radial-gradient(circle at 18% 18%, rgba(34,211,238,0.075), transparent 26%),
    radial-gradient(circle at 80% 14%, rgba(139,108,255,0.08), transparent 24%),
    linear-gradient(180deg, transparent 0%, rgba(0,0,0,0.20) 100%);
  mix-blend-mode: screen;
}

/* ─── SCROLLBAR ─────────────────────────────────────────────────── */
::-webkit-scrollbar              { width: 6px; height: 6px; }
::-webkit-scrollbar-track        { background: var(--bg-mid); }
::-webkit-scrollbar-thumb        { background: rgba(79,140,255,0.3); border-radius: 99px; }
::-webkit-scrollbar-thumb:hover  { background: rgba(79,140,255,0.55); }

/* ─── HEADINGS ──────────────────────────────────────────────────── */
h1, h2, h3 {
  font-family: 'Manrope', sans-serif;
  letter-spacing: -0.01em;
}
h1 { color: var(--ink-primary); }
h2 { color: var(--ink-primary); }
h3 { color: var(--ink-secondary); }
p  {
  color: var(--ink-muted);
  line-height: 1.55;
}

/* ─── GLASS PANEL ───────────────────────────────────────────────── */
.glass-panel {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.07), rgba(255,255,255,0.014) 34%, rgba(34,211,238,0.024)),
    linear-gradient(315deg, rgba(139,108,255,0.045), transparent 42%),
    var(--bg-card);
  border: 1px solid rgba(126,164,255,0.16);
  box-shadow:
    0 28px 90px rgba(0,0,0,0.68),
    0 0 0 1px rgba(255,255,255,0.035),
    inset 0 1px 0 rgba(255,255,255,0.09),
    inset 0 -26px 60px rgba(0,0,0,0.20);
  backdrop-filter: blur(28px) saturate(190%) contrast(108%);
  -webkit-backdrop-filter: blur(28px) saturate(190%) contrast(108%);
  position: relative;
  overflow: hidden;
  transform-style: preserve-3d;
}

.glass-panel::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.085) 0%, transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,0.04), transparent 22%);
  pointer-events: none;
  z-index: 0;
  border-radius: inherit;
}

.glass-panel::after {
  content: '';
  position: absolute;
  inset: 1px;
  border-radius: inherit;
  pointer-events: none;
  background:
    linear-gradient(120deg, transparent 18%, rgba(255,255,255,0.055) 32%, transparent 46%),
    linear-gradient(300deg, transparent 58%, rgba(79,140,255,0.055) 82%, transparent);
  opacity: 0.72;
  z-index: 0;
}

.glass-panel > * { position: relative; z-index: 1; }

.glass-panel:hover {
  border-color: rgba(99,149,255,0.22);
  box-shadow:
    0 30px 90px rgba(0,0,0,0.72),
    0 0 0 1px rgba(99,149,255,0.16),
    0 0 54px rgba(79,140,255,0.07),
    inset 0 1px 0 rgba(255,255,255,0.08);
  transform: translateY(-2px);
}

/* ─── HERO PANEL ────────────────────────────────────────────────── */
.hero-panel {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.018) 44%),
    linear-gradient(315deg, rgba(89,199,194,0.08), transparent 36%),
    linear-gradient(135deg, rgba(11, 24, 31, 0.93) 0%, rgba(10, 21, 28, 0.88) 100%);
  border: 1px solid rgba(102,182,180,0.34);
  box-shadow:
    0 28px 88px rgba(0,0,0,0.56),
    0 0 48px rgba(58,166,162,0.12),
    inset 0 1px 0 rgba(255,255,255,0.1),
    inset 0 -28px 56px rgba(0,0,0,0.2);
  backdrop-filter: blur(36px) saturate(215%) contrast(110%);
  -webkit-backdrop-filter: blur(36px) saturate(215%) contrast(110%);
  position: relative;
  overflow: hidden;
  transform-style: preserve-3d;
}

.hero-panel::before {
  content: '';
  position: absolute;
  top: -40%; left: -20%;
  width: 60%; height: 140%;
  background: radial-gradient(ellipse, rgba(58,166,162,0.16) 0%, transparent 65%);
  pointer-events: none;
}

.hero-panel::after {
  content: '';
  position: absolute;
  top: 0; right: 0;
  width: 200px; height: 200px;
  background: radial-gradient(ellipse, rgba(255,139,72,0.1) 0%, transparent 65%);
  pointer-events: none;
}

.hero-panel > * { position: relative; z-index: 1; }

.hero-panel:hover {
  transform: translateY(-2px);
}

/* ─── PREVIEW FRAME ─────────────────────────────────────────────── */
.preview-frame {
  background: linear-gradient(180deg, rgba(10,15,30,0.95) 0%, rgba(6,8,18,0.98) 100%);
  border: 1px solid var(--border-subtle);
}

.preview-canvas {
  border-radius: 1.25rem;
  border: 1px solid rgba(79,140,255,0.15);
  background: rgba(255,255,255,0.97);
  padding: 1rem;
  box-shadow: 0 8px 48px rgba(0,0,0,0.6), 0 0 0 1px rgba(79,140,255,0.08);
}

.preview-launcher {
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.preview-launcher:hover {
  transform: translateY(-2px);
  border-color: rgba(58,166,162,0.28);
  box-shadow: 0 14px 52px rgba(0,0,0,0.28), 0 0 0 1px rgba(58,166,162,0.12);
}

.preview-launcher:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(58,166,162,0.18), 0 14px 52px rgba(0,0,0,0.28);
}

/* ─── SITE HEADER ───────────────────────────────────────────────── */
.site-header {
  background:
    linear-gradient(180deg, rgba(8,17,26,0.96), rgba(8,17,26,0.86)),
    linear-gradient(115deg, rgba(255,255,255,0.03), transparent 38%, rgba(58,166,162,0.05) 74%, transparent),
    rgba(8,17,26,0.9);
  border-bottom: 1px solid rgba(82,158,171,0.2);
  backdrop-filter: blur(34px) saturate(190%) contrast(108%);
  -webkit-backdrop-filter: blur(34px) saturate(190%) contrast(108%);
  box-shadow:
    0 12px 42px rgba(0,0,0,0.26),
    inset 0 1px 0 rgba(255,255,255,0.045);
}

.header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.25rem;
}

.header-brand-row {
  display: flex;
  align-items: center;
  gap: 0.9rem;
}

/* ─── BRAND BADGE ───────────────────────────────────────────────── */
.brand-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(8rem, 10vw, 10rem);
  height: 3.35rem;
  margin-top: 0;
  margin-left: 0;
  margin-right: 0;
  border-radius: 0;
  background: transparent;
  color: inherit;
  font-family: 'Syne', sans-serif;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0;
  box-shadow: none;
  border: 0;
  transition: transform 200ms ease, filter 200ms ease;
  animation: logo-drift 5.2s ease-in-out infinite;
  position: relative;
  isolation: isolate;
  overflow: visible;
  padding: 0;
}

.brand-badge:hover {
  transform: translateY(-1px) scale(1.025);
  filter: saturate(1.08) brightness(1.08);
}

.brand-badge::after {
  content: '';
  position: absolute;
  left: 8%;
  right: 10%;
  bottom: 0.1rem;
  height: 0.7rem;
  border-radius: 999px;
  background: rgba(79,140,255,0.22);
  filter: blur(18px);
  pointer-events: none;
  z-index: -1;
}

.brand-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: left center;
  filter:
    drop-shadow(0 8px 14px rgba(0,0,0,0.32))
    drop-shadow(0 0 10px rgba(58,166,162,0.18));
}

.header-copy {
  margin-left: 0;
  padding-top: 0;
}

.header-copy h1 {
  max-width: 26rem;
  line-height: 1.1;
}

.header-copy p {
  max-width: 34rem;
  line-height: 1.45;
}

.header-title {
  font-family: 'Manrope', sans-serif;
  font-weight: 800;
  letter-spacing: -0.02em;
}

.header-subtitle {
  color: var(--ink-muted);
}

.header-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
}

.header-actions-top,
.header-actions-bottom {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
}

/* ─── SOFT BADGE ────────────────────────────────────────────────── */
.soft-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  border-radius: 999px;
  border: 1px solid var(--border-subtle);
  background: rgba(79,140,255,0.08);
  padding: 0.3rem 0.75rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--ink-secondary);
  letter-spacing: 0.01em;
}

.soft-badge strong { color: var(--ink-primary); }

/* ─── STEP EDITOR ──────────────────────────────────────────────── */
.editor-step-rail {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.6rem;
}

.editor-step-chip {
  text-align: left;
  border: 1px solid var(--border-subtle);
  background: rgba(255,255,255,0.03);
  border-radius: 0.9rem !important;
  padding: 0.65rem 0.8rem !important;
}

.editor-step-chip-active {
  border-color: var(--border-active) !important;
  background:
    linear-gradient(145deg, rgba(89,199,194,0.22), rgba(89,199,194,0.08)),
    rgba(8,20,25,0.72) !important;
  box-shadow: 0 14px 24px rgba(0,0,0,0.24), 0 0 24px rgba(58,166,162,0.15) !important;
}

.editor-step-chip-inactive {
  color: var(--ink-secondary) !important;
}

.editor-step-chip-title {
  display: block;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--ink-primary);
}

.editor-step-chip-sub {
  display: block;
  font-size: 0.72rem;
  margin-top: 0.2rem;
  color: var(--ink-muted);
}

.step-stage {
  border: 1px solid var(--border-subtle);
  border-radius: 1rem;
  padding: 1rem;
  background:
    linear-gradient(140deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01) 42%),
    rgba(10,21,27,0.58);
}

.editor-step-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-top: 1px solid var(--border-subtle);
}

.ats-action-panel {
  background:
    linear-gradient(145deg, rgba(89,199,194,0.08), rgba(255,139,72,0.08) 65%),
    rgba(10,21,27,0.6);
}

/* ─── STATUS BADGES ─────────────────────────────────────────────── */
.status-online {
  background: rgba(16,185,129,0.12);
  border-color: rgba(16,185,129,0.3);
  color: #34d399;
}

.status-offline {
  background: rgba(245,158,11,0.12);
  border-color: rgba(245,158,11,0.3);
  color: #fbbf24;
}

/* ─── SECTION KICKER ────────────────────────────────────────────── */
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.67rem;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--accent-blue);
  text-shadow: none;
}

.section-kicker::before {
  content: '';
  width: 1.2rem;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent-blue), var(--accent-violet));
}

/* ─── METRIC CARDS ──────────────────────────────────────────────── */
.metric-card {
  border: 1px solid rgba(103,173,178,0.2);
  border-radius: 1.1rem;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.014) 46%),
    rgba(10,20,27,0.72);
  padding: 1rem 1.1rem;
  backdrop-filter: blur(18px) saturate(180%);
  -webkit-backdrop-filter: blur(18px) saturate(180%);
  transition: border-color 200ms ease, box-shadow 200ms ease;
  position: relative;
  overflow: hidden;
  box-shadow:
    0 12px 26px rgba(0,0,0,0.2),
    inset 0 1px 0 rgba(255,255,255,0.075);
}

.metric-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(58,166,162,0.42), transparent);
}

.metric-card:hover {
  border-color: var(--border-glow);
  box-shadow:
    0 15px 34px rgba(0,0,0,0.26),
    0 0 24px var(--glow-blue),
    inset 0 1px 0 rgba(255,255,255,0.10);
  transform: translateY(-1px);
}

.metric-label {
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
}

.metric-value {
  margin-top: 0.25rem;
  font-family: 'Manrope', sans-serif;
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: 0;
  background: linear-gradient(135deg, var(--ink-primary), var(--accent-blue));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

.metric-copy {
  margin-top: 0.2rem;
  font-size: 0.75rem;
  color: var(--ink-muted);
}

/* ─── EDITOR FLOW DIVIDERS ──────────────────────────────────────── */
.editor-flow > div + div {
  border-top: 1px solid var(--border-subtle);
  margin-top: 1.4rem;
  padding-top: 1.4rem;
}

/* ─── INPUTS ────────────────────────────────────────────────────── */
input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
textarea,
select {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.038), rgba(255,255,255,0.012)),
    var(--bg-input) !important;
  border: 1px solid rgba(126,164,255,0.16) !important;
  color: var(--ink-primary) !important;
  border-radius: 0.7rem;
  padding: 0.6rem 0.85rem;
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  transition: border-color 160ms ease, box-shadow 160ms ease;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.045),
    inset 0 -12px 24px rgba(0,0,0,0.16);
}

input::placeholder,
textarea::placeholder { color: var(--ink-muted) !important; }

select option { background: var(--bg-mid); color: var(--ink-primary); }

input:not([type="checkbox"]):not([type="radio"]):not([type="file"]):focus,
textarea:focus,
select:focus {
  outline: none !important;
  border-color: var(--border-active) !important;
  box-shadow: 0 0 0 3px rgba(79,140,255,0.15), inset 0 1px 0 rgba(0,0,0,0.3) !important;
  background: rgba(15,22,50,0.85) !important;
}

input[type="file"] {
  background: var(--bg-input) !important;
  border: 1px solid var(--border-subtle) !important;
  color: var(--ink-secondary) !important;
}

/* ─── LABELS ────────────────────────────────────────────────────── */
label { color: var(--ink-secondary) !important; }

/* ─── BUTTONS — BASE ────────────────────────────────────────────── */
button[class] {
  border-radius: 0.75rem !important;
  font-family: 'DM Sans', sans-serif;
  font-weight: 700;
  line-height: 1.2;
  padding: 0.62rem 1.1rem;
  cursor: pointer;
  letter-spacing: 0.01em;
  transition:
    transform 140ms ease,
    box-shadow 200ms ease,
    background 200ms ease,
    border-color 200ms ease,
    color 160ms ease,
    opacity 180ms ease;
}

button[class]:hover  { transform: translateY(-2px); }
button[class]:active { transform: translateY(0px); }

button[class]:focus-visible {
  outline: none;
  box-shadow: 0 0 0 3px rgba(58,166,162,0.30);
}

button[class]:disabled {
  cursor: not-allowed;
  transform: none !important;
  opacity: 0.40;
  filter: saturate(0.5);
}

/* compact toolbar / inline buttons */
button[class*="text-xs"],
button[class*="px-2"],
button[class*="py-1"] {
  padding: 0.40rem 0.70rem;
  font-size: 0.78rem;
}

/* full-width modal actions */
button[class*="w-full"] { padding: 0.76rem 1rem; }

/* ─── BUTTON VARIANTS ───────────────────────────────────────────── */

/* ─── PRIMARY ACTION (Continue, Save) — teal gradient ──────────── */
button[class*="bg-slate-900"] {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow:
    0 6px 22px rgba(58,166,162,0.38),
    0 2px 6px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -1px 0 rgba(0,0,0,0.12) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}

button[class*="bg-slate-900"]:hover:not(:disabled) {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  box-shadow:
    0 10px 32px rgba(58,166,162,0.50),
    0 2px 8px rgba(0,0,0,0.24),
    inset 0 1px 0 rgba(255,255,255,0.28) !important;
}

/* Blue / Emerald — merged into teal primary above */

/* ─── GHOST / SECONDARY (Go Back, Export, Open Preview) ────────── */
button[class*="border-slate-300"],
button[class*="border-slate-200"] {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow:
    0 4px 16px rgba(58,166,162,0.32),
    inset 0 1px 0 rgba(255,255,255,0.20) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.16);
}

button[class*="border-slate-300"]:hover:not(:disabled),
button[class*="border-slate-200"]:hover:not(:disabled) {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  border-color: rgba(90,210,206,0.62) !important;
  color: #ffffff !important;
  box-shadow:
    0 8px 24px rgba(58,166,162,0.46),
    inset 0 1px 0 rgba(255,255,255,0.26) !important;
}

/* ─── DANGER (Reset Resume, Remove Job/Entry/Section) ──────────── */
button[class*="text-rose-700"],
button[class*="bg-rose-"] {
  color: #fda4af !important;
  background:
    linear-gradient(180deg, rgba(244,63,94,0.14), rgba(244,63,94,0.06)) !important;
  border: 1px solid rgba(244,63,94,0.44) !important;
  box-shadow:
    0 4px 14px rgba(244,63,94,0.18),
    inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

button[class*="text-rose-700"]:hover:not(:disabled),
button[class*="bg-rose-"]:hover:not(:disabled) {
  background:
    linear-gradient(180deg, rgba(244,63,94,0.22), rgba(244,63,94,0.12)) !important;
  border-color: rgba(244,63,94,0.62) !important;
  color: #fff1f2 !important;
  box-shadow:
    0 6px 20px rgba(244,63,94,0.30),
    inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

/* ─── ADDITIVE (Add Skill, Add Experience, Add Bullet…) ─────────── */
button[class*="font-semibold"][class*="text-slate-700"] {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  padding: 0.40rem 0.95rem;
  box-shadow:
    0 4px 14px rgba(58,166,162,0.30),
    inset 0 1px 0 rgba(255,255,255,0.20) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.16);
}

button[class*="font-semibold"][class*="text-slate-700"]:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  border-color: rgba(90,210,206,0.62) !important;
  color: #ffffff !important;
  box-shadow:
    0 6px 20px rgba(58,166,162,0.44),
    inset 0 1px 0 rgba(255,255,255,0.26) !important;
  transform: translateY(-2px);
}

/* ─── HEADER BUTTONS ────────────────────────────────────────────── */
.btn-header-login {
  min-height: 2.45rem;
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  padding: 0.56rem 1.05rem !important;
  font-size: 0.84rem !important;
  font-weight: 700;
  border-radius: 0.75rem !important;
  box-shadow:
    0 6px 22px rgba(58,166,162,0.36),
    inset 0 1px 0 rgba(255,255,255,0.22);
  transition: all 180ms ease !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}

.btn-header-login:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  box-shadow: 0 10px 30px rgba(58,166,162,0.48), inset 0 1px 0 rgba(255,255,255,0.26) !important;
  transform: translateY(-2px);
}

.btn-header-signup {
  min-height: 2.45rem;
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  padding: 0.56rem 1.15rem !important;
  font-size: 0.84rem !important;
  font-weight: 700;
  border-radius: 0.75rem !important;
  box-shadow:
    0 6px 22px rgba(58,166,162,0.38),
    inset 0 1px 0 rgba(255,255,255,0.22);
  transition: all 180ms ease !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}

.btn-header-signup:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  box-shadow: 0 10px 30px rgba(58,166,162,0.48), inset 0 1px 0 rgba(255,255,255,0.26) !important;
  transform: translateY(-2px);
}

/* ─── USER CHIP ─────────────────────────────────────────────────── */
.theme-toggle-button {
  width: 2.6rem;
  height: 2.6rem;
  min-height: 2.6rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
  background:
    linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.028) 42%),
    linear-gradient(135deg, rgba(79,140,255,0.18), rgba(139,108,255,0.12)) !important;
  border: 1px solid rgba(150,184,255,0.26) !important;
  color: var(--ink-primary) !important;
  padding: 0 !important;
  border-radius: 999px !important;
  box-shadow:
    0 14px 34px rgba(0,0,0,0.26),
    0 0 26px rgba(79,140,255,0.12),
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -14px 24px rgba(0,0,0,0.14) !important;
  backdrop-filter: blur(18px) saturate(190%);
  -webkit-backdrop-filter: blur(18px) saturate(190%);
}

.theme-toggle-button:hover {
  border-color: rgba(150,184,255,0.42) !important;
  box-shadow:
    0 18px 42px rgba(0,0,0,0.30),
    0 0 34px rgba(79,140,255,0.18),
    inset 0 1px 0 rgba(255,255,255,0.16) !important;
}

.theme-toggle-icon {
  width: 1.65rem;
  height: 1.65rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,0.45), transparent 38%),
    linear-gradient(135deg, #4f8cff, #8b6cff);
  color: #fff;
  font-family: 'DM Sans', sans-serif;
  font-size: 1rem;
  font-weight: 800;
  box-shadow: 0 8px 18px rgba(79,140,255,0.26);
}

.user-chip {
  background: rgba(10,15,32,0.7) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: 1.5rem !important;
  padding: 0.45rem 0.85rem !important;
  backdrop-filter: blur(12px);
}

.user-role-admin {
  background: rgba(245,158,11,0.15);
  border: 1px solid rgba(245,158,11,0.3);
  color: #fbbf24;
  border-radius: 999px;
  padding: 0.15rem 0.55rem;
  font-size: 0.68rem;
  font-weight: 700;
}

.user-role-user {
  background: rgba(79,140,255,0.12);
  border: 1px solid rgba(79,140,255,0.25);
  color: var(--accent-blue);
  border-radius: 999px;
  padding: 0.15rem 0.55rem;
  font-size: 0.68rem;
  font-weight: 700;
}

/* ─── ARTICLE CARDS (experience / education / projects) ─────────── */
article.rounded-xl {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.05), rgba(255,255,255,0.012) 48%),
    rgba(10,15,32,0.66) !important;
  border: 1px solid rgba(99,149,255,0.14) !important;
  backdrop-filter: blur(12px);
  box-shadow:
    0 14px 34px rgba(0,0,0,0.22),
    inset 0 1px 0 rgba(255,255,255,0.045);
  transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

article.rounded-xl:hover {
  border-color: var(--border-glow) !important;
  box-shadow:
    0 18px 44px rgba(0,0,0,0.30),
    0 0 26px rgba(79,140,255,0.08),
    inset 0 1px 0 rgba(255,255,255,0.06);
  transform: translateY(-1px);
}

.bg-white,
.bg-white\/90 {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.055), rgba(255,255,255,0.012) 48%),
    rgba(10,15,32,0.66) !important;
}

/* ─── ATS SCORE PANEL ───────────────────────────────────────────── */
.ats-score-panel {
  background: linear-gradient(135deg, #080f28 0%, #0d1635 60%, #0a1428 100%);
  border: 1px solid var(--border-glow);
  box-shadow: 0 0 60px rgba(79,140,255,0.12), inset 0 1px 0 rgba(255,255,255,0.05);
  position: relative;
  overflow: hidden;
}

.ats-score-panel::before {
  content: '';
  position: absolute;
  bottom: -60px; right: -60px;
  width: 220px; height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(79,140,255,0.15) 0%, transparent 65%);
  pointer-events: none;
}

.ats-score-num {
  font-family: 'Manrope', sans-serif;
  font-size: 3.5rem;
  font-weight: 800;
  letter-spacing: 0;
  background: linear-gradient(135deg, #fff, var(--accent-blue));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* ─── KEYWORD CHIPS ─────────────────────────────────────────────── */
.chip-match {
  background: rgba(16,185,129,0.12);
  border: 1px solid rgba(16,185,129,0.25);
  color: #34d399;
  border-radius: 999px;
  padding: 0.22rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 600;
}

.chip-miss {
  background: rgba(245,158,11,0.1);
  border: 1px solid rgba(245,158,11,0.22);
  color: #fbbf24;
  border-radius: 999px;
  padding: 0.22rem 0.7rem;
  font-size: 0.72rem;
  font-weight: 600;
}

/* ─── INSIGHT PANELS ────────────────────────────────────────────── */
.insight-strengths {
  background: rgba(16,185,129,0.07) !important;
  border: 1px solid rgba(16,185,129,0.18) !important;
  border-radius: 1rem;
}

.insight-warnings {
  background: rgba(245,158,11,0.07) !important;
  border: 1px solid rgba(245,158,11,0.18) !important;
  border-radius: 1rem;
}

/* ─── EXPORT PANEL ──────────────────────────────────────────────── */
.export-panel {
  background: linear-gradient(135deg, #04070f 0%, #080f24 60%, #060c1e 100%);
  border: 1px solid var(--border-subtle);
  position: relative;
  overflow: hidden;
}

.export-panel::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(79,140,255,0.5), rgba(139,108,255,0.5), transparent);
}

/* ─── RESUME SHEET (print preview) ─────────────────────────────── */
.resume-sheet {
  border: 1px solid var(--resume-line);
  background: linear-gradient(180deg, var(--resume-paper, #fff), var(--resume-panel, #f8fafc));
  color: var(--resume-ink, #0f172a);
  box-shadow: 0 32px 80px rgba(0,0,0,0.55), 0 0 0 1px rgba(79,140,255,0.06);
}

.resume-headline { color: var(--resume-accent); }
.resume-divider  { border-top: 2px solid var(--resume-line); }
.resume-meta     { color: var(--resume-meta, #64748b) !important; }

/* ─── DRAG HANDLE ───────────────────────────────────────────────── */
.drag-handle { cursor: grab; }
.drag-handle:active { cursor: grabbing; }

.drag-handle .rounded-lg {
  background: rgba(10,15,32,0.65) !important;
  border: 1px solid var(--border-subtle) !important;
  color: var(--ink-secondary) !important;
}

.drag-handle .rounded-lg:hover {
  border-color: var(--border-glow) !important;
  background: rgba(79,140,255,0.07) !important;
}

.drag-handle .text-slate-400 { color: var(--ink-muted) !important; }

/* ─── MODAL BACKDROP ────────────────────────────────────────────── */
.modal-backdrop {
  background:
    radial-gradient(circle at 50% 8%, rgba(79,140,255,0.14), transparent 34%),
    radial-gradient(circle at 88% 22%, rgba(139,108,255,0.12), transparent 28%),
    rgba(3,5,15,0.84);
  backdrop-filter: blur(16px) saturate(135%);
  -webkit-backdrop-filter: blur(16px) saturate(135%);
}

/* ─── PREVIEW MODAL ────────────────────────────────────────────── */
.preview-modal-backdrop {
  background:
    radial-gradient(circle at 20% 0%, rgba(58,166,162,0.12), transparent 34%),
    radial-gradient(circle at 85% 10%, rgba(255,139,72,0.1), transparent 30%),
    rgba(4,7,16,0.82);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.preview-modal-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(245,248,252,0.9)),
    rgba(255,255,255,0.92);
  border: 1px solid rgba(148,163,184,0.22);
  box-shadow:
    0 36px 120px rgba(0,0,0,0.35),
    0 0 0 1px rgba(255,255,255,0.45),
    inset 0 1px 0 rgba(255,255,255,0.9);
  color: #0f172a;
  position: relative;
  display: flex;
  flex-direction: column;
  max-height: calc(100vh - 2rem);
  overflow: hidden;
}

.preview-modal-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  right: 0;
  height: 4px;
  background: linear-gradient(90deg, var(--resume-accent), rgba(255,255,255,0.15), var(--resume-accent));
  opacity: 0.95;
}

body[data-app-theme="dark"] .preview-modal-backdrop {
  background:
    radial-gradient(circle at 20% 0%, rgba(58,166,162,0.16), transparent 34%),
    radial-gradient(circle at 85% 10%, rgba(255,139,72,0.12), transparent 30%),
    rgba(1,4,10,0.9);
}

body[data-app-theme="dark"] .preview-modal-card {
  background:
    linear-gradient(180deg, rgba(14,20,38,0.98), rgba(9,13,26,0.96)),
    rgba(10,15,32,0.96);
  border: 1px solid rgba(141,178,255,0.18);
  box-shadow:
    0 36px 120px rgba(0,0,0,0.62),
    0 0 0 1px rgba(255,255,255,0.04),
    inset 0 1px 0 rgba(255,255,255,0.05);
  color: #e2e8f0;
}

body[data-app-theme="dark"] .preview-modal-card::before {
  opacity: 0.8;
}

body[data-app-theme="dark"] .preview-modal-toolbar,
body[data-app-theme="dark"] .preview-modal-actions,
body[data-app-theme="dark"] .preview-modal-sidebar {
  background:
    linear-gradient(180deg, rgba(15,23,42,0.94), rgba(10,15,28,0.88));
  border-color: rgba(148,163,184,0.12);
}

body[data-app-theme="dark"] .preview-modal-body {
  background:
    linear-gradient(180deg, rgba(5,9,20,0.82), rgba(10,15,28,0.74));
}

body[data-app-theme="dark"] .preview-toolbar-badge {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: #cbd5e1 !important;
}

body[data-app-theme="dark"] .preview-modal-card .modal-close {
  background: rgba(255,255,255,0.06) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: #cbd5e1 !important;
}

body[data-app-theme="dark"] .preview-modal-card .modal-close:hover {
  background: rgba(255,255,255,0.1) !important;
  color: #fff !important;
}

.preview-modal-body {
  display: block;
  background:
    linear-gradient(180deg, rgba(241,245,249,0.92), rgba(226,232,240,0.72));
  padding: 1.2rem;
  flex: 1;
  min-height: 0;
}

.preview-modal-sidebar {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  border: 1px solid rgba(148,163,184,0.16);
  border-radius: 1.4rem;
  background: rgba(248,250,252,0.92);
  padding: 1rem;
  max-height: calc(100vh - 10rem);
  overflow-y: auto;
}

.preview-sidebar-stats {
  display: grid;
  gap: 0.75rem;
}

.preview-sidebar-stat {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  border-radius: 1rem;
  padding: 0.85rem 0.95rem;
  background: rgba(255,255,255,0.72);
  border: 1px solid rgba(148,163,184,0.14);
}

.preview-sidebar-stat span {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #64748b;
}

.preview-sidebar-stat strong {
  font-size: 0.95rem;
  color: #0f172a;
}

.preview-modal-actions-compact {
  flex-direction: column;
  align-items: stretch;
  justify-content: flex-start;
  gap: 0.9rem;
  border-bottom: 0;
}

.preview-modal-downloads {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.preview-toolbar-badge {
  background: rgba(15,23,42,0.04) !important;
  border-color: rgba(15,23,42,0.09) !important;
  color: #334155 !important;
}

.preview-modal-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.15rem 0.95rem;
  border-bottom: 1px solid rgba(148,163,184,0.18);
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,250,252,0.86));
  position: relative;
}

.preview-toolbar-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.55rem;
}

.preview-toolbar-top-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: 0.55rem;
}

.preview-modal-downloads-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.preview-modal-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.9rem 1.15rem 1rem;
  border-bottom: 1px solid rgba(148,163,184,0.16);
  background: rgba(248,250,252,0.92);
}

.preview-modal-sheet-wrap {
  max-height: calc(100vh - 12rem);
  overflow: auto;
  padding: 0.45rem;
  min-height: 0;
}

.preview-modal-card .modal-close {
  background: rgba(15,23,42,0.04) !important;
  border-color: rgba(15,23,42,0.08) !important;
  color: #334155 !important;
}

.preview-modal-card .modal-close:hover {
  background: rgba(15,23,42,0.08) !important;
  color: #0f172a !important;
}

.preview-download-btn {
  border-radius: 0.8rem;
  padding: 0.60rem 1.0rem;
  font-size: 0.78rem;
  font-weight: 700;
  border: 1px solid transparent;
  letter-spacing: 0.01em;
  transition: transform 160ms ease, box-shadow 200ms ease, border-color 180ms ease, background 200ms ease;
}

.preview-download-btn:hover {
  transform: translateY(-2px);
}

.preview-download-btn:disabled {
  opacity: 0.40;
  filter: saturate(0.5);
  transform: none !important;
}

.preview-download-btn-primary {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%);
  color: #ffffff;
  border-color: rgba(90,200,196,0.52);
  box-shadow:
    0 6px 20px rgba(58,166,162,0.38),
    inset 0 1px 0 rgba(255,255,255,0.22);
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}

.preview-download-btn-primary:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%);
  box-shadow:
    0 10px 28px rgba(58,166,162,0.50),
    inset 0 1px 0 rgba(255,255,255,0.28);
}

.preview-download-btn-secondary {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%);
  color: #ffffff;
  border-color: rgba(90,200,196,0.52);
  box-shadow: 0 6px 20px rgba(58,166,162,0.36), inset 0 1px 0 rgba(255,255,255,0.20);
  text-shadow: 0 1px 2px rgba(0,0,0,0.16);
}

.preview-download-btn-secondary:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%);
  box-shadow: 0 10px 28px rgba(58,166,162,0.48), inset 0 1px 0 rgba(255,255,255,0.26);
}

.preview-download-btn-ghost {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%);
  color: #ffffff;
  border-color: rgba(90,200,196,0.44);
  box-shadow: 0 4px 14px rgba(58,166,162,0.28), inset 0 1px 0 rgba(255,255,255,0.18);
  text-shadow: 0 1px 2px rgba(0,0,0,0.14);
}

.preview-download-btn-ghost:hover {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%);
  box-shadow: 0 8px 22px rgba(58,166,162,0.44), inset 0 1px 0 rgba(255,255,255,0.24);
}

body[data-app-theme="dark"] .preview-sidebar-stat {
  background: rgba(255,255,255,0.04);
  border-color: rgba(148,163,184,0.1);
}

body[data-app-theme="dark"] .preview-sidebar-stat span {
  color: rgba(203,213,225,0.72);
}

body[data-app-theme="dark"] .preview-sidebar-stat strong {
  color: #f8fafc;
}

body[data-app-theme="dark"] .preview-modal-sidebar {
  border-color: rgba(148,163,184,0.12);
}

body[data-app-theme="dark"] .preview-modal-sidebar .soft-badge {
  background: rgba(255,255,255,0.05) !important;
  border-color: rgba(255,255,255,0.08) !important;
  color: #cbd5e1 !important;
}

@media (max-width: 1024px) {
  .preview-toolbar-actions {
    align-items: flex-start;
  }

  .preview-toolbar-top-row {
    justify-content: flex-start;
  }

  .preview-modal-sheet-wrap {
    max-height: none;
  }
}

@media (max-width: 640px) {
  .preview-modal-body {
    padding: 0.85rem;
  }

  .preview-modal-toolbar,
  .preview-modal-actions {
    padding-inline: 0.9rem;
  }

  .preview-modal-downloads-toolbar {
    width: 100%;
    justify-content: flex-start;
  }
}

/* ─── MODAL CARD ────────────────────────────────────────────────── */
.modal-card {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.08), transparent 27%),
    linear-gradient(315deg, rgba(79,140,255,0.055), transparent 48%),
    linear-gradient(160deg, rgba(17,27,62,0.98) 0%, rgba(9,14,35,0.99) 56%, rgba(8,13,28,0.98) 100%),
    rgba(10,15,38,0.98);
  border: 1px solid rgba(141,178,255,0.38);
  box-shadow:
    0 46px 130px rgba(0,0,0,0.86),
    0 0 0 1px rgba(99,149,255,0.16),
    0 0 86px rgba(79,140,255,0.15),
    inset 0 1px 0 rgba(255,255,255,0.13),
    inset 0 -38px 80px rgba(0,0,0,0.24);
  backdrop-filter: blur(44px) saturate(215%) contrast(110%);
  -webkit-backdrop-filter: blur(44px) saturate(215%) contrast(110%);
  position: relative;
  overflow: hidden;
}

.modal-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(99,149,255,0.6), rgba(139,108,255,0.5), transparent);
  background-size: 200% 100%;
  animation: shimmer 3s linear infinite;
  pointer-events: none;
}

.modal-card::after {
  content: '';
  position: absolute;
  top: -80px; right: -80px;
  width: 200px; height: 200px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(139,108,255,0.1) 0%, transparent 60%);
  pointer-events: none;
}

.modal-card > * {
  position: relative;
  z-index: 1;
}

/* ─── MODAL CLOSE BUTTON ────────────────────────────────────────── */
.modal-close {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.025)) !important;
  border: 1px solid rgba(133,168,255,0.18) !important;
  color: var(--ink-secondary) !important;
  width: 2.35rem;
  height: 2.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 0.8rem !important;
  padding: 0 !important;
  font-size: 1rem;
  flex-shrink: 0;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 10px 20px rgba(0,0,0,0.22) !important;
}

.modal-close:hover {
  background: rgba(244,63,94,0.12) !important;
  border-color: rgba(244,63,94,0.3) !important;
  color: #fb7185 !important;
}

.modal-primary {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  letter-spacing: 0 !important;
  box-shadow:
    0 6px 22px rgba(58,166,162,0.38),
    0 2px 6px rgba(0,0,0,0.28),
    inset 0 1px 0 rgba(255,255,255,0.22),
    inset 0 -1px 0 rgba(0,0,0,0.12) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.18);
}

.modal-primary:hover:not(:disabled) {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  box-shadow:
    0 10px 32px rgba(58,166,162,0.50),
    0 2px 8px rgba(0,0,0,0.24),
    inset 0 1px 0 rgba(255,255,255,0.28) !important;
}

.modal-footer {
  border-top: 1px solid var(--border-subtle);
}

.modal-link-action {
  background: none !important;
  border: none !important;
  box-shadow: none !important;
  padding: 0 0.2rem !important;
  color: var(--accent-blue) !important;
  transform: none !important;
}

.modal-link-action:hover {
  color: #7eb4ff !important;
}

.loading-inline {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
}

.spinner-icon {
  animation: spin 0.8s linear infinite;
}

/* ─── OTP INPUT ─────────────────────────────────────────────────── */
.otp-input {
  background: rgba(8,12,30,0.9) !important;
  border: 1px solid var(--border-glow) !important;
  color: var(--accent-blue) !important;
  font-family: 'JetBrains Mono', monospace !important;
  font-size: 1.8rem !important;
  letter-spacing: 0.35em !important;
  text-align: center;
  border-radius: 1rem !important;
  box-shadow: 0 0 32px rgba(79,140,255,0.12), inset 0 2px 8px rgba(0,0,0,0.5) !important;
}

/* ─── PAYMENT PLAN CARDS ────────────────────────────────────────── */
.plan-card-active {
  background: linear-gradient(135deg, #0f1a40 0%, #1a2f70 100%) !important;
  border: 1px solid rgba(79,140,255,0.4) !important;
  box-shadow: 0 0 32px rgba(79,140,255,0.2), inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

.plan-card-inactive {
  background: rgba(10,15,32,0.5) !important;
  border: 1px solid var(--border-subtle) !important;
}

/* ─── GATEWAY BUTTONS ───────────────────────────────────────────── */
.gw-active {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow:
    0 6px 18px rgba(58,166,162,0.36),
    inset 0 1px 0 rgba(255,255,255,0.20) !important;
}

.gw-inactive {
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03)) !important;
  border: 1px solid rgba(148,163,184,0.40) !important;
  color: var(--ink-secondary) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

.gw-inactive:hover:not(:disabled) {
  background: linear-gradient(180deg, rgba(58,166,162,0.14), rgba(58,166,162,0.05)) !important;
  border-color: rgba(90,190,186,0.52) !important;
  color: var(--ink-primary) !important;
  box-shadow: 0 4px 14px rgba(58,166,162,0.16), inset 0 1px 0 rgba(255,255,255,0.08) !important;
}

/* ─── TEMPLATE SELECTOR BUTTONS ────────────────────────────────── */
.template-btn-active {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border: 1px solid rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow:
    0 6px 18px rgba(58,166,162,0.34),
    inset 0 1px 0 rgba(255,255,255,0.18) !important;
}

.template-btn-inactive {
  background: linear-gradient(180deg, rgba(255,255,255,0.07), rgba(255,255,255,0.02)) !important;
  border: 1px solid rgba(148,163,184,0.38) !important;
  color: var(--ink-secondary) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.16), inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

.template-btn-inactive:hover {
  background: linear-gradient(180deg, rgba(58,166,162,0.12), rgba(58,166,162,0.04)) !important;
  border-color: rgba(90,190,186,0.48) !important;
  color: var(--ink-primary) !important;
  border-color: var(--border-glow) !important;
  color: var(--ink-primary) !important;
}

/* ─── QR / PAYMENT FRAME ────────────────────────────────────────── */
.qr-frame {
  background: rgba(10,15,32,0.7) !important;
  border: 1px solid var(--border-glow) !important;
  border-radius: 1.2rem;
  padding: 1rem;
  backdrop-filter: blur(12px);
}

.qr-frame img {
  border-radius: 0.75rem;
  border: 1px solid rgba(79,140,255,0.2);
}

/* ─── HISTORY ROWS ──────────────────────────────────────────────── */
.history-row {
  background: rgba(10,15,32,0.55) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: 0.85rem;
  transition: border-color 160ms ease;
}

.history-row:hover { border-color: var(--border-glow) !important; }

/* ─── BULLET AI PANEL ───────────────────────────────────────────── */
.bullet-panel {
  background: rgba(10,15,32,0.55) !important;
  border: 1px solid var(--border-subtle) !important;
  border-radius: 1rem;
}

.bullet-panel li { color: var(--ink-secondary) !important; }
.bullet-panel li::marker { color: var(--accent-blue); }

/* ─── TOAST ─────────────────────────────────────────────────────── */
.toast-base {
  border-radius: 1rem;
  backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow: 0 8px 40px rgba(0,0,0,0.6);
  font-family: 'DM Sans', sans-serif;
  font-size: 0.88rem;
  font-weight: 500;
}

/* ─── INSTALL HINT ──────────────────────────────────────────────── */
.install-hint {
  max-width: 23rem;
  text-align: right;
  color: var(--ink-muted) !important;
  font-size: 0.72rem;
}

/* ─── LIGHT / DARK MODE OVERRIDES ───────────────────────────────── */
body[data-app-theme="light"] {
  --bg-deep: #eef5ff;
  --bg-mid: #dfeaff;
  --bg-card: rgba(255, 255, 255, 0.64);
  --bg-glass: rgba(255, 255, 255, 0.54);
  --bg-input: rgba(255, 255, 255, 0.68);
  --border-subtle: rgba(37, 99, 235, 0.14);
  --border-glow: rgba(59, 130, 246, 0.25);
  --border-active: rgba(37, 99, 235, 0.48);
  --ink-primary: #071226;
  --ink-secondary: #233755;
  --ink-muted: #475a78;
  --glow-blue: rgba(37, 99, 235, 0.16);
  --glow-violet: rgba(124, 58, 237, 0.12);
  background-color: #edf4ff;
  background-image:
    radial-gradient(ellipse 70% 52% at 6% 0%, rgba(79,140,255,0.20) 0%, transparent 55%),
    radial-gradient(ellipse 60% 46% at 100% 0%, rgba(139,108,255,0.16) 0%, transparent 50%),
    radial-gradient(ellipse 62% 54% at 50% 100%, rgba(34,211,238,0.13) 0%, transparent 48%),
    linear-gradient(180deg, #f8fbff 0%, #eaf2ff 100%);
  color: var(--ink-primary);
}

body[data-app-theme="light"]::before {
  background:
    linear-gradient(115deg, rgba(255,255,255,0.62), transparent 25%, rgba(59,130,246,0.08) 52%, transparent 76%),
    repeating-linear-gradient(90deg, rgba(15,23,42,0.035) 0 1px, transparent 1px 120px);
  mask-image: linear-gradient(180deg, rgba(0,0,0,0.68), rgba(0,0,0,0.16));
}

body[data-app-theme="light"]::after {
  background:
    radial-gradient(circle at 18% 18%, rgba(59,130,246,0.13), transparent 28%),
    radial-gradient(circle at 82% 12%, rgba(124,58,237,0.10), transparent 25%),
    linear-gradient(180deg, rgba(255,255,255,0.58) 0%, rgba(226,237,255,0.32) 100%);
  mix-blend-mode: normal;
}

body[data-app-theme="light"] .site-header {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.82), rgba(238,245,255,0.68)),
    linear-gradient(115deg, rgba(255,255,255,0.62), transparent 34%, rgba(79,140,255,0.08) 72%, transparent);
  border-bottom-color: rgba(37,99,235,0.13);
  box-shadow:
    0 18px 58px rgba(71,85,105,0.14),
    inset 0 1px 0 rgba(255,255,255,0.9);
}

body[data-app-theme="light"] .glass-panel,
body[data-app-theme="light"] .hero-panel {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.94), rgba(247,250,255,0.68) 38%, rgba(219,234,254,0.38)),
    linear-gradient(315deg, rgba(124,58,237,0.07), transparent 44%),
    rgba(255,255,255,0.78);
  border-color: rgba(37,99,235,0.22);
  box-shadow:
    0 28px 80px rgba(71,85,105,0.18),
    0 0 0 1px rgba(255,255,255,0.72),
    inset 0 1px 0 rgba(255,255,255,0.95),
    inset 0 -24px 54px rgba(37,99,235,0.045);
}

body[data-app-theme="light"] .glass-panel:hover,
body[data-app-theme="light"] .hero-panel:hover {
  border-color: rgba(37,99,235,0.25);
  box-shadow:
    0 32px 88px rgba(71,85,105,0.22),
    0 0 0 1px rgba(255,255,255,0.82),
    0 0 42px rgba(59,130,246,0.10),
    inset 0 1px 0 rgba(255,255,255,0.96);
}

body[data-app-theme="light"] .brand-logo {
  filter:
    drop-shadow(0 14px 20px rgba(15,23,42,0.18))
    drop-shadow(0 0 18px rgba(37,99,235,0.14));
}

body[data-app-theme="light"] .brand-badge::after {
  background: rgba(37,99,235,0.18);
}

body[data-app-theme="light"] .soft-badge,
body[data-app-theme="light"] .metric-card,
body[data-app-theme="light"] article.rounded-xl,
body[data-app-theme="light"] .bg-white,
body[data-app-theme="light"] .bg-white\/90,
body[data-app-theme="light"] [style*="background:rgba(10,15,32"],
body[data-app-theme="light"] [style*="background:linear-gradient(135deg,#040710"],
body[data-app-theme="light"] .qr-frame,
body[data-app-theme="light"] .bullet-panel,
body[data-app-theme="light"] .history-row {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.96), rgba(241,247,255,0.74) 48%),
    rgba(255,255,255,0.82) !important;
  border-color: rgba(37,99,235,0.20) !important;
  color: var(--ink-primary) !important;
  box-shadow:
    0 14px 34px rgba(71,85,105,0.10),
    inset 0 1px 0 rgba(255,255,255,0.9);
}

body[data-app-theme="light"] input:not([type="checkbox"]):not([type="radio"]):not([type="file"]),
body[data-app-theme="light"] textarea,
body[data-app-theme="light"] select,
body[data-app-theme="light"] input[type="file"] {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.86), rgba(255,255,255,0.54)),
    rgba(255,255,255,0.68) !important;
  border-color: rgba(37,99,235,0.22) !important;
  color: var(--ink-primary) !important;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.92),
    0 10px 22px rgba(71,85,105,0.08);
}

body[data-app-theme="light"] input::placeholder,
body[data-app-theme="light"] textarea::placeholder {
  color: #7b8799 !important;
}

/* ─── LIGHT MODE BUTTON OVERRIDES ──────────────────────────────── */
body[data-app-theme="light"] button[class*="bg-slate-900"],
body[data-app-theme="light"] button[class*="bg-blue-600"],
body[data-app-theme="light"] button[class*="bg-emerald-600"],
body[data-app-theme="light"] button[class*="bg-white"],
body[data-app-theme="light"] button[class*="border-slate-300"],
body[data-app-theme="light"] button[class*="border-slate-200"],
body[data-app-theme="light"] button[class*="font-semibold"][class*="text-slate-700"],
body[data-app-theme="light"] .btn-header-login,
body[data-app-theme="light"] .btn-header-signup,
body[data-app-theme="light"] .modal-primary {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border-color: rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow: 0 6px 20px rgba(58,166,162,0.32), inset 0 1px 0 rgba(255,255,255,0.24) !important;
  text-shadow: 0 1px 2px rgba(0,0,0,0.14);
}

body[data-app-theme="light"] button[class*="bg-slate-900"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="bg-blue-600"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="bg-emerald-600"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="bg-white"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="border-slate-300"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="border-slate-200"]:hover:not(:disabled),
body[data-app-theme="light"] button[class*="font-semibold"][class*="text-slate-700"]:hover,
body[data-app-theme="light"] .btn-header-login:hover,
body[data-app-theme="light"] .btn-header-signup:hover,
body[data-app-theme="light"] .modal-primary:hover:not(:disabled) {
  background: linear-gradient(135deg, #226866 0%, #45bbb7 55%, #38a8a4 100%) !important;
  box-shadow: 0 10px 28px rgba(58,166,162,0.44), inset 0 1px 0 rgba(255,255,255,0.28) !important;
}

body[data-app-theme="light"] .theme-toggle-icon {
  background:
    radial-gradient(circle at 35% 25%, rgba(255,255,255,0.72), transparent 38%),
    linear-gradient(135deg, #0f172a, #2563eb);
  box-shadow: 0 8px 18px rgba(37,99,235,0.18);
}

body[data-app-theme="light"] .ats-score-num,
body[data-app-theme="light"] .metric-value {
  background: linear-gradient(135deg, #071226, #2563eb);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

body[data-app-theme="light"] .chip-match {
  background: rgba(5,150,105,0.12) !important;
  border-color: rgba(5,150,105,0.28) !important;
  color: #047857 !important;
}

body[data-app-theme="light"] .chip-miss {
  background: rgba(217,119,6,0.13) !important;
  border-color: rgba(217,119,6,0.28) !important;
  color: #92400e !important;
}

body[data-app-theme="light"] .modal-backdrop {
  background:
    radial-gradient(circle at 50% 8%, rgba(59,130,246,0.16), transparent 34%),
    radial-gradient(circle at 88% 22%, rgba(124,58,237,0.12), transparent 28%),
    rgba(226,237,255,0.70);
}

body[data-app-theme="light"] .modal-card {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.86), transparent 28%),
    linear-gradient(315deg, rgba(59,130,246,0.08), transparent 48%),
    rgba(255,255,255,0.72);
  border-color: rgba(37,99,235,0.18);
  box-shadow:
    0 40px 110px rgba(71,85,105,0.24),
    0 0 0 1px rgba(255,255,255,0.76),
    0 0 80px rgba(59,130,246,0.12),
    inset 0 1px 0 rgba(255,255,255,0.96),
    inset 0 -34px 70px rgba(37,99,235,0.045);
}

body[data-app-theme="light"] .preview-frame,
body[data-app-theme="light"] .export-panel,
body[data-app-theme="light"] .ats-score-panel {
  background:
    linear-gradient(145deg, rgba(255,255,255,0.78), rgba(255,255,255,0.28)),
    rgba(241,247,255,0.72) !important;
  border-color: rgba(37,99,235,0.14) !important;
  box-shadow:
    0 24px 70px rgba(71,85,105,0.16),
    inset 0 1px 0 rgba(255,255,255,0.95) !important;
}

body[data-app-theme="light"] .gw-active,
body[data-app-theme="light"] .template-btn-active,
body[data-app-theme="light"] .plan-card-active {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border-color: rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow: 0 6px 18px rgba(58,166,162,0.34), inset 0 1px 0 rgba(255,255,255,0.22) !important;
}

body[data-app-theme="light"] .gw-inactive,
body[data-app-theme="light"] .template-btn-inactive,
body[data-app-theme="light"] .plan-card-inactive {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(241,247,255,0.80)) !important;
  border-color: rgba(71,113,180,0.28) !important;
  color: #1e293b !important;
  box-shadow: 0 4px 12px rgba(71,85,105,0.14), inset 0 1px 0 rgba(255,255,255,0.98) !important;
}

body[data-app-theme="light"] button[class*="bg-slate-900"],
body[data-app-theme="light"] button[class*="bg-blue-600"],
body[data-app-theme="light"] button[class*="bg-emerald-600"],
body[data-app-theme="light"] button[class*="bg-white"] {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border-color: rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow: 0 6px 22px rgba(58,166,162,0.32), inset 0 1px 0 rgba(255,255,255,0.24) !important;
}

body[data-app-theme="light"] .modal-primary,
body[data-app-theme="light"] .btn-header-signup {
  background: linear-gradient(135deg, #1b6462 0%, #3aa6a2 55%, #2d9290 100%) !important;
  border-color: rgba(90,200,196,0.52) !important;
  color: #ffffff !important;
  box-shadow: 0 6px 22px rgba(58,166,162,0.32), inset 0 1px 0 rgba(255,255,255,0.24) !important;
}

/* ─── TAILWIND COLOR CLASS OVERRIDES ────────────────────────────── */
.text-slate-800,
.text-slate-900 { color: var(--ink-primary) !important; }
.text-slate-700 { color: var(--ink-secondary) !important; }
.text-slate-600,
.text-slate-500 { color: var(--ink-muted) !important; }
.text-slate-400 { color: rgba(74,90,128,0.8) !important; }
.text-slate-300 { color: rgba(143,163,204,0.8) !important; }
.text-slate-200 { color: rgba(200,215,240,0.85) !important; }

.text-emerald-700 { color: #34d399 !important; }
.text-emerald-800 { color: #10b981 !important; }
.text-amber-700   { color: #fbbf24 !important; }
.text-amber-800   { color: #f59e0b !important; }
.text-rose-700    { color: #fb7185 !important; }

.bg-emerald-100 { background: rgba(16,185,129,0.12) !important; }
.bg-amber-100   { background: rgba(245,158,11,0.12)  !important; }
.bg-slate-100   { background: rgba(79,140,255,0.1)   !important; }
.bg-rose-50     { background: rgba(244,63,94,0.07)   !important; }

.border-emerald-200 { border-color: rgba(16,185,129,0.2) !important; }
.border-amber-200   { border-color: rgba(245,158,11,0.2)  !important; }

/* ─── ANIMATIONS ────────────────────────────────────────────────── */
@keyframes rise-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

.rise-in { animation: rise-in 500ms cubic-bezier(0.22, 1, 0.36, 1) both; }

@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-5px); }
}

@keyframes logo-drift {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-3px); }
}

@keyframes pulse-glow {
  0%, 100% { opacity: 0.5; }
  50%       { opacity: 1; }
}

.online-dot { animation: pulse-glow 2s ease-in-out infinite; }

@keyframes shimmer {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

/* ─── CLOAK ─────────────────────────────────────────────────────── */
[x-cloak] { display: none !important; }

/* ─── RESPONSIVE ────────────────────────────────────────────────── */
@media (max-width: 640px) {
  .header-main {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .header-actions {
    align-items: stretch;
  }

  .header-actions-top,
  .header-actions-bottom {
    justify-content: flex-start;
  }

  .header-title {
    font-size: 1.28rem;
  }

  .header-subtitle {
    font-size: 0.82rem;
  }

  .editor-step-rail {
    display: flex;
    overflow-x: auto;
    padding-bottom: 0.2rem;
  }

  .editor-step-chip {
    min-width: 8.4rem;
    flex: 0 0 auto;
  }

  .editor-step-nav {
    position: sticky;
    bottom: 0;
    z-index: 12;
    margin-inline: -0.2rem;
    padding: 0.7rem;
    border-radius: 0.9rem;
    border: 1px solid var(--border-subtle);
    background:
      linear-gradient(145deg, rgba(10,20,28,0.9), rgba(10,20,28,0.72)),
      rgba(8,16,22,0.85);
    backdrop-filter: blur(14px);
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
  }

  .brand-badge {
    width: min(44vw, 8.4rem);
    height: 2.95rem;
    margin-left: 0;
    margin-top: 0;
  }

  .header-copy {
    margin-left: 0;
    padding-top: 0;
  }

  .theme-toggle-button {
    width: 2.45rem;
    height: 2.45rem;
    min-height: 2.45rem;
  }

  .ats-score-num { font-size: 2.5rem; }
  .metric-value  { font-size: 1.3rem; }

  .preview-modal-toolbar {
    flex-direction: column;
    align-items: stretch;
  }

  .preview-modal-actions {
    align-items: stretch;
  }

  .preview-modal-body {
    padding: 0.85rem;
  }

  .preview-modal-sheet-wrap {
    max-height: calc(100vh - 11rem);
  }
}
