/* ============================================================
   Quoti Consulting — Design System
   Created By: iTechSmart Inc.
   Dual theme: dark-luxe (default) + ivory light
   ============================================================ */

@import url('fonts.css'); /* self-hosted Fraunces + Plus Jakarta Sans + JetBrains Mono */

/* ---------- Tokens ---------- */
:root {
  --font-display: "Fraunces", Georgia, serif;
  --font-sans: "Plus Jakarta Sans", ui-sans-serif, system-ui, sans-serif;
  --font-mono: "JetBrains Mono", ui-monospace, monospace;

  --gold-100: #F9EBB5;
  --gold-200: #F3DD8C;
  --gold-300: #E9C963;
  --gold-400: #DDB44A;
  --gold-500: #C9982F;
  --gold-600: #A8791A;
  --gold-700: #7E5A12;

  --grad-gold: linear-gradient(120deg, #F3DD8C 0%, #DDB44A 38%, #A8791A 100%);
  --grad-gold-soft: linear-gradient(120deg, rgba(243,221,140,.16), rgba(168,121,26,.16));

  /* Quoti brand palette: deep navy · royal blue · rich gold · soft purple · white */
  --navy-950: #060F20;
  --navy-900: #0A1A33;
  --navy-800: #0F2448;
  --navy-700: #16305C;
  --royal-300: #7FA4EC;
  --royal-500: #2E5FD0;
  --royal-600: #2450B4;
  --royal-700: #1A3F94;
  --purple-300: #B9A5E8;
  --purple-500: #7C5FC0;
  --purple-700: #5F46A3;
  --lblue-100: #F0F6FD;
  --lblue-200: #E1EDFA;

  --grad-navy: linear-gradient(180deg, #0A1A33 0%, #0F2448 100%);
  --grad-blue: linear-gradient(120deg, #2E5FD0 0%, #2450B4 55%, #1A3F94 100%);
  --grad-blue-soft: linear-gradient(120deg, rgba(46,95,208,.12), rgba(26,63,148,.12));
  --grad-purple: linear-gradient(120deg, #9B7FD9 0%, #7C5FC0 55%, #5F46A3 100%);
  --grad-purple-soft: linear-gradient(120deg, rgba(155,127,217,.14), rgba(95,70,163,.14));
  --grad-cta: linear-gradient(120deg, #1A3F94 0%, #2E5FD0 45%, #7C5FC0 100%);
  --grad-royal: linear-gradient(120deg, #F3DD8C 0%, #DDB44A 32%, #2E5FD0 100%);

  --ease-lux: cubic-bezier(.22,.9,.28,1);
  --radius: 18px;
  --radius-lg: 26px;
}

/* Light (default) — the Quoti brand theme: white · navy · royal · gold · purple */
:root,
:root[data-theme="light"] {
  color-scheme: light;
  --bg: #FFFFFF;
  --bg-2: #F0F6FD;
  --bg-3: #E1EDFA;
  --surface: #FFFFFF;
  --surface-2: #FFFFFF;
  --surface-solid: #FFFFFF;
  --border: rgba(10, 26, 51, 0.13);
  --border-strong: rgba(10, 26, 51, 0.3);
  --text: #0B1F3F;
  --text-soft: #2E4265;
  --muted: #5D6E8A;
  --accent: #A87C1F;
  --accent-deep: #8A6414;
  --on-accent: #0A1A33;
  --glow: rgba(201, 152, 47, 0.24);
  --shadow: 0 24px 55px -24px rgba(10, 26, 51, .25);
  --shadow-soft: 0 10px 30px -16px rgba(10, 26, 51, .16);
  --header-bg: rgba(255, 255, 255, 0.85);
  --input-bg: #FFFFFF;
  --blue: #2456C4;
  --blue-deep: #1A3F94;
  --glow-blue: rgba(46, 95, 208, 0.2);
  --purple: #6B4FB3;
  --glow-purple: rgba(124, 95, 192, 0.2);
  --navy-band: linear-gradient(180deg, #0A1A33 0%, #10264D 100%);
}

/* Dark — navy-dark variant */
:root[data-theme="dark"] {
  color-scheme: dark;
  --bg: #071223;
  --bg-2: #0B1B36;
  --bg-3: #102448;
  --surface: rgba(255, 255, 255, 0.05);
  --surface-2: rgba(255, 255, 255, 0.08);
  --surface-solid: #0E2140;
  --border: rgba(143, 184, 232, 0.16);
  --border-strong: rgba(143, 184, 232, 0.38);
  --text: #EFF4FB;
  --text-soft: #C6D4E8;
  --muted: #8CA0BE;
  --accent: #E9C963;
  --accent-deep: #DDB44A;
  --on-accent: #0A1A33;
  --glow: rgba(233, 201, 99, 0.16);
  --shadow: 0 24px 60px -22px rgba(0, 0, 0, .65);
  --shadow-soft: 0 10px 34px -14px rgba(0, 0, 0, .5);
  --header-bg: rgba(7, 18, 35, 0.78);
  --input-bg: rgba(255, 255, 255, 0.06);
  --blue: #7FA4EC;
  --blue-deep: #2E5FD0;
  --glow-blue: rgba(46, 95, 208, 0.28);
  --purple: #B9A5E8;
  --glow-purple: rgba(155, 127, 217, 0.26);
  --navy-band: linear-gradient(180deg, #0B1D3B 0%, #122A55 100%);
}

/* ---------- Base ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 16.5px;
  line-height: 1.65;
  color: var(--text);
  background: var(--bg);
  transition: background .45s var(--ease-lux), color .45s var(--ease-lux);
  overflow-x: hidden;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }
::selection { background: var(--gold-400); color: #221703; }

h1, h2, h3, h4 {
  font-family: var(--font-display);
  font-weight: 500;
  line-height: 1.08;
  letter-spacing: -0.015em;
  margin: 0 0 .5em;
  text-wrap: balance;
}
h1 { font-size: clamp(2.6rem, 5.6vw, 4.6rem); }
h2 { font-size: clamp(2rem, 3.6vw, 3rem); }
h3 { font-size: clamp(1.3rem, 2vw, 1.6rem); }
p { margin: 0 0 1em; }
.lead { font-size: clamp(1.05rem, 1.5vw, 1.24rem); color: var(--text-soft); max-width: 62ch; }
.muted { color: var(--muted); }

.container { width: min(1180px, 92vw); margin-inline: auto; }
.container-wide { width: min(1360px, 94vw); margin-inline: auto; }
section { position: relative; padding: clamp(4.5rem, 9vw, 7.5rem) 0; }
.section-tight { padding: clamp(3rem, 6vw, 4.5rem) 0; }
.center { text-align: center; }
.center .lead { margin-inline: auto; }

/* Gradient / accent text */
.gold {
  background: var(--grad-gold-text, var(--grad-gold));
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
:root, :root[data-theme="light"] { --grad-gold-text: linear-gradient(120deg, #B8892A 0%, #8A6414 60%, #6E4E0E 100%); }
:root[data-theme="dark"] { --grad-gold-text: var(--grad-gold); }
/* On navy bands, gold text must be the bright gradient in both themes */
.section-navy .gold, .hero .gold, .site-footer .gold, .cta-band .gold { background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; }
em.serif { font-family: var(--font-display); font-style: italic; }

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  font-family: var(--font-mono);
  font-size: .74rem;
  font-weight: 500;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 1.1rem;
}
.eyebrow::before {
  content: "";
  width: 26px; height: 1.5px;
  background: var(--grad-gold);
  display: inline-block;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .55rem;
  padding: .95rem 1.75rem;
  border-radius: 999px;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .01em;
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .3s var(--ease-lux), box-shadow .3s var(--ease-lux), background .3s, border-color .3s, color .3s;
  white-space: nowrap;
}
.btn svg { width: 17px; height: 17px; flex: none; transition: transform .3s var(--ease-lux); }
.btn:hover svg { transform: translateX(3px); }
.btn-gold {
  background: var(--grad-gold);
  color: var(--on-accent);
  box-shadow: 0 10px 30px -10px var(--glow), inset 0 1px 0 rgba(255,255,255,.4);
}
.btn-gold:hover { transform: translateY(-2px); box-shadow: 0 18px 40px -12px var(--glow), inset 0 1px 0 rgba(255,255,255,.45); }
.btn-outline {
  border-color: var(--border-strong);
  color: var(--text);
  background: transparent;
}
.btn-outline:hover { border-color: var(--accent); background: var(--grad-gold-soft); transform: translateY(-2px); }
.btn-lg { padding: 1.15rem 2.2rem; font-size: 1.02rem; }
.btn-sm { padding: .6rem 1.15rem; font-size: .84rem; }

/* ---------- Header ---------- */
.site-header {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background: var(--header-bg);
  border-bottom: 1px solid transparent;
  transition: border-color .4s, background .4s;
}
.site-header.scrolled { border-bottom-color: var(--border); }
.header-inner {
  display: flex;
  align-items: center;
  gap: 1.4rem;
  height: 78px;
}
.brand { display: flex; align-items: center; gap: .7rem; flex: none; }
.brand img, .brand svg { width: 46px; height: 46px; }
.brand-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 1.32rem;
  letter-spacing: .06em;
  line-height: 1;
}
.brand-name small {
  display: block;
  font-family: var(--font-mono);
  font-size: .56rem;
  letter-spacing: .42em;
  text-transform: uppercase;
  color: var(--accent);
  margin-top: .28rem;
}
.main-nav { display: flex; align-items: center; gap: 1.35rem; margin-left: auto; }
.main-nav a {
  font-size: .86rem;
  font-weight: 600;
  color: var(--text-soft);
  position: relative;
  padding: .35rem 0;
  transition: color .25s;
}
.main-nav a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 100%; height: 1.5px;
  background: var(--grad-gold);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .3s var(--ease-lux);
}
.main-nav a:hover, .main-nav a[aria-current="page"] { color: var(--text); }
.main-nav a:hover::after, .main-nav a[aria-current="page"]::after { transform: scaleX(1); }
.header-actions { display: flex; align-items: center; gap: .8rem; margin-left: .4rem; }

.theme-toggle {
  width: 42px; height: 42px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color .3s, transform .3s var(--ease-lux), background .3s;
}
.theme-toggle:hover { border-color: var(--accent); transform: rotate(15deg); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-sun { display: none; }
:root[data-theme="light"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="light"] .theme-toggle .icon-moon { display: none; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: block; }

.nav-burger {
  display: none;
  width: 44px; height: 44px;
  border: 1px solid var(--border);
  background: var(--surface);
  border-radius: 12px;
  cursor: pointer;
  color: var(--text);
  align-items: center;
  justify-content: center;
}
.nav-burger svg { width: 20px; height: 20px; }

@media (max-width: 1330px) {
  .main-nav {
    position: fixed;
    inset: 78px 0 auto 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: var(--bg);
    border-bottom: 1px solid var(--border);
    padding: .6rem 4vw 1.4rem;
    transform: translateY(-115%);
    opacity: 0;
    transition: transform .4s var(--ease-lux), opacity .3s;
    box-shadow: var(--shadow);
    max-height: calc(100dvh - 78px);
    overflow-y: auto;
  }
  .main-nav.open { transform: translateY(0); opacity: 1; }
  .main-nav a { padding: .8rem .3rem; font-size: 1rem; border-bottom: 1px solid var(--border); }
  .main-nav a:last-of-type { border-bottom: 0; }
  .main-nav a::after { display: none; }
  .nav-burger { display: inline-flex; }
  .header-cta { display: none; }
}

/* ---------- Navy band (hero, footer, AOS, contact — deep navy in BOTH themes) ---------- */
.section-navy, .hero, .site-footer {
  --text: #F4F8FE;
  --text-soft: #C9D6EA;
  --muted: #93A7C6;
  --border: rgba(143, 184, 232, 0.18);
  --border-strong: rgba(143, 184, 232, 0.42);
  --surface: rgba(255, 255, 255, 0.06);
  --surface-2: rgba(255, 255, 255, 0.1);
  --surface-solid: #10264D;
  --input-bg: rgba(255, 255, 255, 0.08);
  --accent: #E9C963;
  --glow: rgba(233, 201, 99, 0.18);
  --blue: #7FA4EC;
  --purple: #B9A5E8;
  --shadow-soft: 0 10px 34px -14px rgba(3, 9, 20, .5);
  --shadow: 0 24px 60px -22px rgba(3, 9, 20, .65);
  background: var(--navy-band);
  color: var(--text);
}
.section-navy .eyebrow, .hero .eyebrow { color: var(--accent); }

/* ---------- Hero ---------- */
.hero {
  min-height: 92svh;
  display: flex;
  align-items: center;
  padding: 9.5rem 0 5.5rem;
  overflow: hidden;
  isolation: isolate;
}
.hero-sub { min-height: 62svh; padding-top: 10rem; }
.hero-bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  background:
    radial-gradient(1000px 520px at 78% -10%, rgba(233, 201, 99, .14), transparent 62%),
    radial-gradient(820px 460px at 8% 8%, rgba(46, 95, 208, .28), transparent 60%);
  transition: background .45s var(--ease-lux);
}
.hero-grid-lines {
  position: absolute;
  inset: 0;
  z-index: -1;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 72px 72px;
  mask-image: radial-gradient(720px 480px at 70% 10%, rgba(0,0,0,.5), transparent 75%);
  -webkit-mask-image: radial-gradient(720px 480px at 70% 10%, rgba(0,0,0,.5), transparent 75%);
  opacity: .8;
}
.orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  z-index: -1;
  opacity: .5;
  pointer-events: none;
}
.orb-gold { background: radial-gradient(circle, rgba(221,180,74,.5), transparent 65%); }
.orb-amber { background: radial-gradient(circle, rgba(168,121,26,.42), transparent 65%); }
.hero-mark-watermark {
  position: absolute;
  right: -4%;
  bottom: -12%;
  width: clamp(320px, 38vw, 560px);
  opacity: .07;
  z-index: -1;
  pointer-events: none;
  animation: floatSlow 14s ease-in-out infinite;
}
.hero-badges { display: flex; flex-wrap: wrap; gap: .6rem; margin: 1.6rem 0 2.2rem; }
.chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--text-soft);
  border: 1px solid var(--border);
  background: var(--surface);
  padding: .42rem .95rem;
  border-radius: 999px;
}
.chip svg { width: 14px; height: 14px; color: var(--accent); flex: none; }
.hero-ctas { display: flex; flex-wrap: wrap; gap: .9rem; align-items: center; }
.hero-note { margin-top: 1.1rem; font-size: .85rem; color: var(--muted); }

/* ---------- Cards & grids ---------- */
.grid { display: grid; gap: 1.4rem; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-5 { grid-template-columns: repeat(5, 1fr); }
@media (max-width: 1020px) { .grid-3, .grid-4 { grid-template-columns: repeat(2, 1fr); } .grid-5 { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 660px) { .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; } .grid-5 { grid-template-columns: repeat(2, 1fr); } }

.card {
  position: relative;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 1.9rem 1.7rem;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow-soft);
  transition: transform .4s var(--ease-lux), border-color .4s, box-shadow .4s;
  overflow: hidden;
}
.card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto 0;
  height: 2px;
  background: var(--grad-gold);
  opacity: 0;
  transition: opacity .4s;
}
.card:hover { transform: translateY(-6px); border-color: var(--border-strong); box-shadow: var(--shadow); }
.card:hover::before { opacity: 1; }
.card h3 { margin-top: 1rem; }
.card p:last-child { margin-bottom: 0; }

.icon-tile {
  width: 52px; height: 52px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--grad-gold-soft);
  border: 1px solid var(--border);
  color: var(--accent);
}
.icon-tile svg { width: 24px; height: 24px; }

/* ---------- Pricing ---------- */
.price-card { display: flex; flex-direction: column; }
.price-card .price {
  font-family: var(--font-display);
  font-size: 2.35rem;
  font-weight: 600;
  margin: .4rem 0 .1rem;
}
.price-card .price small { font-size: .95rem; font-family: var(--font-sans); font-weight: 500; color: var(--muted); }
.price-card .price-from { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); }
.price-card ul { list-style: none; margin: 1.1rem 0 1.6rem; padding: 0; display: grid; gap: .55rem; flex: 1; }
.price-card li { display: flex; gap: .6rem; align-items: flex-start; font-size: .92rem; color: var(--text-soft); }
.price-card li svg { width: 16px; height: 16px; color: var(--accent); flex: none; margin-top: .22rem; }
.price-card .btn { width: 100%; }
.price-card.featured {
  border-color: var(--border-strong);
  background: linear-gradient(var(--surface-2), var(--surface-2)) padding-box;
  box-shadow: 0 24px 60px -18px var(--glow);
}
.price-card.featured::before { opacity: 1; height: 3px; }
.ribbon {
  position: absolute;
  top: 1.1rem; right: 1.1rem;
  font-family: var(--font-mono);
  font-size: .62rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  background: var(--grad-gold);
  color: var(--on-accent);
  font-weight: 600;
  padding: .32rem .7rem;
  border-radius: 999px;
}

/* ---------- Stats ---------- */
.stats-band {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
  border-block: 1px solid var(--border);
  padding: 2.4rem 0;
}
@media (max-width: 900px) { .stats-band { grid-template-columns: repeat(2, 1fr); } }
.stat .stat-num {
  font-family: var(--font-display);
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 550;
  line-height: 1;
}
.stat .stat-label { font-size: .85rem; color: var(--muted); margin-top: .5rem; }

.stats-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 900px) { .stats-3 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .stats-3 { grid-template-columns: 1fr 1fr; } }

/* Brand statement band */
.statement {
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 2.4vw, 1.9rem);
  font-style: italic;
  line-height: 1.5;
  max-width: 46ch;
  margin: 0 auto;
  color: var(--text-soft);
  text-align: center;
}
.statement strong { color: var(--text); font-weight: 600; }
.statement::before { content: "“"; display: block; font-size: 3.4em; line-height: .4; margin-bottom: .25em; background: var(--grad-gold); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ---------- Checklist ---------- */
.check-list { list-style: none; padding: 0; margin: 1.4rem 0; display: grid; gap: .8rem; }
.check-list li { display: flex; gap: .8rem; align-items: flex-start; color: var(--text-soft); }
.check-list li strong { color: var(--text); }
.check-icon {
  flex: none;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--grad-gold-soft);
  border: 1px solid var(--border-strong);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  margin-top: .15rem;
}
.check-icon svg { width: 12px; height: 12px; }

/* ---------- Steps ---------- */
.steps { counter-reset: step; display: grid; gap: 1.4rem; }
.step { position: relative; padding-left: 4.4rem; }
.step::before {
  counter-increment: step;
  content: "0" counter(step);
  position: absolute;
  left: 0; top: .1rem;
  font-family: var(--font-display);
  font-size: 1.9rem;
  font-weight: 550;
  background: var(--grad-gold);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.step h3 { font-size: 1.25rem; margin-bottom: .3rem; }
.step p { color: var(--text-soft); margin: 0; }

/* ---------- Marquee ---------- */
.marquee {
  overflow: hidden;
  border-block: 1px solid var(--border);
  padding: 1.15rem 0;
  mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track {
  display: flex;
  gap: 3.2rem;
  width: max-content;
  animation: marquee 36s linear infinite;
}
.marquee-track span {
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-style: italic;
  color: var(--muted);
  display: inline-flex;
  align-items: center;
  gap: 3.2rem;
  white-space: nowrap;
}
.marquee-track span::after { content: "✦"; font-style: normal; color: var(--accent); font-size: .8rem; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ---------- Quote / testimonial ---------- */
.quote-card { padding: 2.2rem 2rem; }
.quote-card blockquote {
  margin: 0 0 1.2rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.14rem;
  line-height: 1.5;
  color: var(--text-soft);
}
.quote-card blockquote::before { content: "“"; color: var(--accent); font-size: 1.6em; line-height: 0; vertical-align: -0.25em; margin-right: .1em; }
.quote-who { display: flex; align-items: center; gap: .85rem; }
.avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: var(--grad-gold);
  color: var(--on-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: .9rem;
  letter-spacing: .02em;
}
.quote-who .who-name { font-weight: 700; font-size: .93rem; }
.quote-who .who-role { font-size: .8rem; color: var(--muted); }

/* ---------- FAQ ---------- */
.faq { display: grid; gap: .9rem; max-width: 820px; margin-inline: auto; }
.faq details {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  overflow: hidden;
  transition: border-color .3s;
}
.faq details[open] { border-color: var(--border-strong); }
.faq summary {
  cursor: pointer;
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem 1.4rem;
  font-weight: 700;
  font-size: 1rem;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--font-display);
  font-size: 1.5rem;
  color: var(--accent);
  transition: transform .3s var(--ease-lux);
  flex: none;
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq .faq-body { padding: 0 1.4rem 1.3rem; color: var(--text-soft); font-size: .95rem; }
.faq .faq-body p:last-child { margin: 0; }

/* ---------- Forms ---------- */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-grid .full { grid-column: 1 / -1; }
@media (max-width: 660px) { .form-grid { grid-template-columns: 1fr; } }
label.field { display: grid; gap: .4rem; font-size: .82rem; font-weight: 700; color: var(--text-soft); }
input, select, textarea {
  font: inherit;
  color: var(--text);
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: .85rem 1rem;
  width: 100%;
  transition: border-color .3s, box-shadow .3s;
}
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--glow);
}
textarea { min-height: 130px; resize: vertical; }
.form-note { font-size: .8rem; color: var(--muted); }
.form-success {
  display: none;
  border: 1px solid var(--border-strong);
  background: var(--grad-gold-soft);
  border-radius: var(--radius);
  padding: 1.2rem 1.4rem;
  font-weight: 600;
}
.form-success.visible { display: block; }

/* ---------- CTA band ---------- */
.cta-band {
  position: relative;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border-strong);
  background:
    radial-gradient(640px 300px at 85% 0%, var(--glow), transparent 65%),
    var(--surface-2);
  padding: clamp(2.6rem, 6vw, 4.4rem);
  overflow: hidden;
  text-align: center;
  box-shadow: var(--shadow);
}
.cta-band .hero-mark-watermark { right: -6%; bottom: -30%; opacity: .06; }
.cta-band h2 { max-width: 20ch; margin-inline: auto; }
.cta-band .lead { margin-inline: auto; }

/* ---------- Page hero band (sub pages) ---------- */
.breadcrumbs {
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
  display: flex;
  gap: .6rem;
  margin-bottom: 1.3rem;
}
.breadcrumbs a:hover { color: var(--accent); }
.breadcrumbs span::before { content: "/"; margin-right: .6rem; color: var(--border-strong); }

/* ---------- Footer ---------- */
.site-footer {
  border-top: 1px solid var(--border);
  background: var(--navy-band);
  padding: 4.2rem 0 2rem;
  margin-top: 2rem;
}
.footer-grid {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1fr 1.2fr;
  gap: 2.4rem;
}
@media (max-width: 980px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 620px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-grid h4 {
  font-family: var(--font-mono);
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 1.1rem;
  font-weight: 600;
}
.footer-grid ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .55rem; }
.footer-grid a { color: var(--muted); font-size: .92rem; transition: color .25s; }
.footer-grid a:hover { color: var(--text); }
.footer-tagline { color: var(--muted); font-size: .92rem; max-width: 34ch; font-style: italic; font-family: var(--font-display); }
.footer-creds { font-family: var(--font-mono); font-size: .66rem; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-top: 1rem; max-width: 38ch; line-height: 1.9; }
.footer-bottom {
  margin-top: 3rem;
  padding-top: 1.6rem;
  border-top: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: .8rem 2rem;
  align-items: center;
  justify-content: space-between;
  font-size: .8rem;
  color: var(--muted);
}
.footer-watermark { font-family: var(--font-mono); font-size: .72rem; letter-spacing: .08em; color: var(--muted); transition: color .25s; }
.footer-watermark strong { color: var(--accent); font-weight: 600; transition: color .25s; }
a.footer-watermark:hover { color: var(--text); }
a.footer-watermark:hover strong { color: var(--blue); text-decoration: underline; text-underline-offset: 3px; }

/* ---------- Motion layer (parallax · spotlight · tilt · reveals) ---------- */

/* Scroll progress bar */
.scroll-progress {
  position: fixed;
  inset: 0 0 auto 0;
  height: 3px;
  z-index: 200;
  background: var(--grad-gold);
  transform-origin: left;
  transform: scaleX(0);
  pointer-events: none;
  box-shadow: 0 0 12px var(--glow);
}

/* Smart header: hides on scroll down, returns on scroll up */
.site-header { transition: border-color .4s, background .4s, transform .45s var(--ease-lux); }
.site-header.hide { transform: translateY(-100%); }

/* Cursor spotlight on cards */
.card::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .45s;
  background: radial-gradient(340px circle at var(--mx, 50%) var(--my, 50%),
    color-mix(in srgb, var(--accent) 13%, transparent), transparent 62%);
  pointer-events: none;
}
.card:hover::after { opacity: 1; }

/* Word-by-word heading reveal (spans injected by JS) */
.split-heading { text-wrap: wrap; }
.split-heading .w {
  display: inline-block;
  opacity: 0;
  transform: translateY(.55em);
  filter: blur(7px);
  transition:
    opacity .55s var(--ease-lux),
    transform .65s var(--ease-lux),
    filter .55s var(--ease-lux);
  transition-delay: calc(var(--wi, 0) * 65ms);
  will-change: opacity, transform, filter;
}
.split-heading.in .w { opacity: 1; transform: none; filter: none; }

/* Magnetic buttons use the composable `translate` property */
.btn { transition: transform .3s var(--ease-lux), box-shadow .3s var(--ease-lux), background .3s, border-color .3s, color .3s, translate .3s var(--ease-lux); }

/* Marquee: pause on hover */
.marquee:hover .marquee-track { animation-play-state: paused; }

/* Scroll-driven animations (progressive enhancement) */
@supports (animation-timeline: view()) {
  .cta-band {
    animation: ctaView linear both;
    animation-timeline: view();
    animation-range: entry 0% cover 42%;
  }
  @keyframes ctaView {
    from { opacity: .45; transform: scale(.955) translateY(28px); }
    to { opacity: 1; transform: none; }
  }
  .cta-band.reveal { transition: none; }

  .stats-band .stat {
    animation: statRise linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 90%;
  }
  @keyframes statRise {
    from { opacity: .2; transform: translateY(30px); }
    to { opacity: 1; transform: none; }
  }
}

/* ---------- Reveal animations ---------- */
.reveal { opacity: 0; transform: translateY(26px); transition: opacity .8s var(--ease-lux), transform .8s var(--ease-lux); }
.reveal.in { opacity: 1; transform: none; }
.reveal-d1 { transition-delay: .1s; }
.reveal-d2 { transition-delay: .2s; }
.reveal-d3 { transition-delay: .3s; }
.reveal-d4 { transition-delay: .4s; }

@keyframes floatSlow {
  0%, 100% { transform: translateY(0) rotate(0deg); }
  50% { transform: translateY(-22px) rotate(2deg); }
}
@keyframes floatOrb {
  0%, 100% { transform: translate(0, 0) scale(1); }
  50% { transform: translate(18px, -26px) scale(1.06); }
}
.orb { animation: floatOrb 11s ease-in-out infinite; }
.orb:nth-of-type(2) { animation-duration: 15s; animation-delay: -4s; }

@keyframes shimmer {
  0% { background-position: -160% 0; }
  100% { background-position: 260% 0; }
}
.shimmer-line {
  height: 1px;
  border: 0;
  margin: 0;
  background: linear-gradient(90deg, transparent, var(--gold-400), transparent);
  background-size: 45% 100%;
  background-repeat: no-repeat;
  animation: shimmer 4.5s ease-in-out infinite;
  opacity: .7;
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .15s !important; }
  html { scroll-behavior: auto; }
  .reveal { opacity: 1; transform: none; }
  .split-heading .w { opacity: 1; transform: none; filter: none; }
  .card::after { display: none; }
  .scroll-progress { display: none; }
}

/* ---------- Misc ---------- */
.split { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
@media (max-width: 920px) { .split { grid-template-columns: 1fr; } }
.kicker-row { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; flex-wrap: wrap; margin-bottom: 2.6rem; }
.kicker-row h2 { margin-bottom: 0; }
.tag-row { display: flex; flex-wrap: wrap; gap: .55rem; margin-top: 1rem; }
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--grad-gold); color: var(--on-accent);
  padding: .7rem 1.2rem; border-radius: 0 0 12px 0; z-index: 200; font-weight: 700;
}
.skip-link:focus { left: 0; }

/* ---------- Brand accents: royal blue + soft purple ---------- */
:root, :root[data-theme="light"] {
  --grad-blue-text: linear-gradient(120deg, #2E5FD0 0%, #2450B4 55%, #16305C 100%);
  --grad-purple-text: linear-gradient(120deg, #7C5FC0 0%, #6B4FB3 55%, #4B3585 100%);
}
:root[data-theme="dark"] {
  --grad-blue-text: linear-gradient(120deg, #BFD5F9 0%, #7FA4EC 45%, #4A7CE0 100%);
  --grad-purple-text: linear-gradient(120deg, #DCD0F5 0%, #B9A5E8 45%, #9B7FD9 100%);
}
.section-navy, .hero, .site-footer, .cta-band {
  --grad-blue-text: linear-gradient(120deg, #BFD5F9 0%, #7FA4EC 45%, #4A7CE0 100%);
  --grad-purple-text: linear-gradient(120deg, #DCD0F5 0%, #B9A5E8 45%, #9B7FD9 100%);
}
.blue, .royal {
  background: var(--grad-blue-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.purple {
  background: var(--grad-purple-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* Eyebrows: royal on white, gold on navy (set above) */
.eyebrow { color: var(--blue); }
.eyebrow::before { background: var(--grad-royal); }

/* Nav: royal hover underline, gold active */
.main-nav a::after { background: var(--grad-blue); }
.main-nav a[aria-current="page"] { color: var(--accent); }
.main-nav a[aria-current="page"]::after { background: var(--grad-gold); }

/* Outline buttons: royal border/text, gold on hover */
.btn-outline { border-color: color-mix(in srgb, var(--blue) 45%, transparent); color: var(--text); }
.btn-outline:hover { border-color: var(--accent); background: var(--grad-gold-soft); }

/* Service icons royal; card hover = light blue tint + gold border */
.icon-tile { background: var(--grad-blue-soft); color: var(--blue); }
.card:hover { border-color: var(--accent); background: linear-gradient(180deg, var(--bg-2), var(--surface)); }
.section-navy .card:hover, .hero .card:hover { background: var(--surface-2); }

/* Testimonials: navy border, gold marks */
.quote-card { border-color: color-mix(in srgb, var(--text) 30%, transparent); }
.avatar-blue, .grid > .quote-card:nth-child(2) .avatar { background: var(--grad-blue); color: #F4F8FD; }
.avatar-purple { background: var(--grad-purple); color: #F7F4FD; }

/* Process timeline: navy line + gold numbered circles */
.steps { position: relative; }
.steps::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 10px;
  bottom: 10px;
  width: 2px;
  background: color-mix(in srgb, var(--text) 22%, transparent);
}
.step::before {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--grad-gold);
  -webkit-background-clip: border-box;
  background-clip: border-box;
  -webkit-text-fill-color: #0A1A33;
  color: #0A1A33;
  font-size: 1.05rem;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 18px -6px var(--glow);
}

/* CTA banners: blue-to-purple gradient with white text */
.cta-band {
  --text: #F5F8FE;
  --text-soft: #DCE6F8;
  --muted: #B9C8E6;
  --accent: #F3DD8C;
  --border: rgba(255,255,255,.2);
  --border-strong: rgba(255,255,255,.4);
  --surface: rgba(255,255,255,.08);
  --input-bg: rgba(255,255,255,.1);
  background: radial-gradient(700px 320px at 85% -10%, rgba(233,201,99,.2), transparent 60%), var(--grad-cta);
  border-color: rgba(255,255,255,.22);
  color: var(--text);
}
.cta-band .eyebrow { color: var(--accent); }

/* Purple-accent pages (Blog · Podcast · Quoti Live) */
.accent-purple .eyebrow { color: var(--purple); }
.accent-purple .eyebrow::before { background: var(--grad-purple); }
.accent-purple .icon-tile { background: var(--grad-purple-soft); color: var(--purple); }
.accent-purple .hero-bg {
  background:
    radial-gradient(1000px 520px at 78% -10%, rgba(233, 201, 99, .12), transparent 62%),
    radial-gradient(820px 460px at 8% 8%, rgba(124, 95, 192, .34), transparent 60%);
}
.accent-purple .chip svg { color: var(--purple); }
.accent-purple .ql-pill.active { background: var(--grad-purple); color: #F7F4FD; }
.accent-purple .ql-badge { color: var(--purple); background: var(--grad-purple-soft); }
.accent-purple .ql-quote-mark { background: var(--grad-purple-text); -webkit-background-clip: text; background-clip: text; }
.accent-purple .marquee-track span::after { color: var(--purple); }
.section-purple-tint { background: var(--grad-purple-soft); }

/* Statistics / key numbers: rich gold */
.stat .stat-num { text-shadow: none; }
.orb-amber { background: radial-gradient(circle, rgba(46,95,208,.45), transparent 65%); }
.scroll-progress { background: var(--grad-royal); }
.shimmer-line { background: linear-gradient(90deg, transparent, var(--gold-400), var(--royal-500), transparent); background-size: 45% 100%; background-repeat: no-repeat; }

/* Why-Quoti style tiles: gold icon, navy text */
.icon-gold.icon-tile { background: var(--grad-gold-soft); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 35%, transparent); }
.section-navy .icon-tile { background: rgba(185,165,232,.14); color: var(--purple); border-color: rgba(185,165,232,.3); }

/* Marquee separators + hero chips alternate royal */
.marquee-track span:nth-child(even)::after { color: var(--blue); }
.hero-badges .chip:nth-child(even) svg { color: var(--blue); }

/* Forms: gold focus outlines (navy labels come from --text-soft) */
input:focus, select:focus, textarea:focus { border-color: var(--gold-400); box-shadow: 0 0 0 4px var(--glow); }
.ql-search:focus-within, .ql-custom:focus-within { border-color: var(--gold-400); box-shadow: 0 0 0 4px var(--glow); }

/* Footer link hover */
.footer-grid a:hover { color: var(--blue); }

/* Royal button */
.btn-blue {
  background: var(--grad-blue);
  color: #F4F8FD;
  box-shadow: 0 10px 30px -10px var(--glow-blue), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-blue:hover { transform: translateY(-2px); box-shadow: 0 18px 40px -12px var(--glow-blue); }
.btn-purple {
  background: var(--grad-purple);
  color: #F7F4FD;
  box-shadow: 0 10px 30px -10px var(--glow-purple), inset 0 1px 0 rgba(255,255,255,.25);
}
.btn-purple:hover { transform: translateY(-2px); box-shadow: 0 18px 40px -12px var(--glow-purple); }

/* ---------- Quoti Live (free quote platform) ---------- */
.ql-stage {
  padding: clamp(2.2rem, 5vw, 3.8rem);
  text-align: center;
  margin: 0;
}
.ql-quote-mark {
  font-family: var(--font-display);
  font-size: 10rem;
  line-height: 1;
  margin: -2.2rem 0 -5.8rem;
  background: var(--grad-blue-text);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}
.ql-text {
  font-family: var(--font-display);
  font-style: italic;
  font-size: clamp(1.4rem, 2.6vw, 2.1rem);
  line-height: 1.45;
  margin: 1rem auto 1.4rem;
  max-width: 26ch;
  min-height: 3em;
  color: var(--text);
  transition: opacity .35s var(--ease-lux);
  text-wrap: balance;
}
.ql-meta { display: flex; align-items: center; justify-content: center; gap: 1rem; flex-wrap: wrap; margin-bottom: 1.6rem; font-size: .85rem; }
.ql-actions { display: flex; justify-content: center; gap: .6rem; flex-wrap: wrap; }
.ql-actions .ql-on { border-color: var(--accent); color: var(--accent); }

.ql-toolbar { display: flex; gap: .9rem; align-items: center; margin: 2.4rem 0 1.4rem; flex-wrap: wrap; }
.ql-search {
  flex: 1;
  min-width: 260px;
  display: flex;
  align-items: center;
  gap: .7rem;
  background: var(--input-bg);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .35rem .6rem .35rem 1.1rem;
  transition: border-color .3s, box-shadow .3s;
}
.ql-search:focus-within { border-color: var(--gold-400); box-shadow: 0 0 0 4px var(--glow); }
.ql-search svg { width: 18px; height: 18px; color: var(--muted); flex: none; }
.ql-search input { border: 0; background: transparent; padding: .6rem 0; box-shadow: none !important; }
.ql-search input:focus { outline: none; border: 0; }

.ql-cats { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 2rem; }
.ql-pill {
  font: inherit;
  font-size: .82rem;
  font-weight: 600;
  color: var(--text-soft);
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: .45rem .95rem;
  cursor: pointer;
  transition: border-color .25s, color .25s, background .25s, transform .25s var(--ease-lux);
}
.ql-pill:hover { border-color: var(--accent); color: var(--text); transform: translateY(-2px); }
.ql-pill.active { background: var(--grad-blue); color: #F4F8FD; border-color: transparent; }
.ql-pill.active .ql-badge { background: rgba(255,255,255,.16); color: inherit; }
.ql-badge {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: .66rem;
  background: var(--grad-blue-soft);
  border-radius: 999px;
  padding: .1rem .5rem;
  margin-left: .3rem;
  color: var(--blue);
}

.ql-results { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.2rem; }
@media (max-width: 1020px) { .ql-results { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 660px) { .ql-results { grid-template-columns: 1fr; } }
.ql-mini { margin: 0; padding: 1.5rem 1.4rem 1.1rem; display: flex; flex-direction: column; }
.ql-mini blockquote {
  margin: 0 0 1rem;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 1.02rem;
  line-height: 1.5;
  color: var(--text-soft);
  flex: 1;
}
.ql-mini blockquote::before { content: "“"; color: var(--accent); margin-right: .1em; }
.ql-mini blockquote::after { content: "”"; color: var(--accent); margin-left: .1em; }
.ql-mini figcaption { display: flex; align-items: center; justify-content: space-between; gap: .6rem; }
.ql-mini-cat { font-family: var(--font-mono); font-size: .68rem; letter-spacing: .08em; text-transform: uppercase; color: var(--muted); }
.ql-mini-actions { display: flex; gap: .3rem; }
.ql-icon-btn {
  font: inherit;
  font-size: 1rem;
  line-height: 1;
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text-soft);
  cursor: pointer;
  transition: border-color .25s, color .25s, transform .2s var(--ease-lux);
}
.ql-icon-btn:hover { border-color: var(--accent); color: var(--accent); transform: scale(1.1); }
.ql-icon-btn.ql-on { color: var(--accent); border-color: var(--accent); }
.ql-loading { grid-column: 1 / -1; text-align: center; padding: 2rem 0; }

.ql-donate { display: flex; justify-content: center; align-items: center; gap: .7rem; flex-wrap: wrap; }
.ql-amt[aria-pressed="true"] { background: var(--grad-gold-soft); border-color: var(--accent); color: var(--text); }
.ql-custom {
  display: inline-flex;
  align-items: center;
  gap: .3rem;
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  padding: 0 .4rem 0 1rem;
  color: var(--muted);
  background: var(--input-bg);
}
.ql-custom input {
  width: 96px;
  border: 0;
  background: transparent;
  padding: .95rem .4rem .95rem 0;
  box-shadow: none !important;
  -moz-appearance: textfield;
  appearance: textfield;
}
.ql-custom input::-webkit-outer-spin-button, .ql-custom input::-webkit-inner-spin-button { -webkit-appearance: none; }
.ql-custom:focus-within { border-color: var(--gold-400); box-shadow: 0 0 0 4px var(--glow); }
.ql-custom input:focus { outline: none; }

.ql-toast {
  position: fixed;
  left: 50%;
  bottom: 26px;
  transform: translate(-50%, 20px);
  background: var(--surface-solid);
  color: var(--text);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  padding: .75rem 1.5rem;
  font-size: .9rem;
  font-weight: 600;
  box-shadow: var(--shadow);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s var(--ease-lux), transform .3s var(--ease-lux);
  z-index: 300;
}
.ql-toast.show { opacity: 1; transform: translate(-50%, 0); }

::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: color-mix(in srgb, var(--accent) 35%, transparent); border-radius: 6px; }
::-webkit-scrollbar-thumb:hover { background: color-mix(in srgb, var(--accent) 60%, transparent); }
