/* ════════════════════════════════════════════════════════════════════════
   LOVEIKO LABS — CANONICAL STYLE SYSTEM  ·  ll-* namespace
   App pages, listicles, About. Matches loveikolabs.com (dark + neon green).
   Fonts: Cormorant Garamond (display) · Syne (UI/body).
   ════════════════════════════════════════════════════════════════════════ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #08080a;
  --surface: #0f0f12;
  --surface-2: #16161a;
  --border: rgba(255,255,255,0.07);
  --border-strong: rgba(255,255,255,0.14);
  --text: #e8e4dc;
  --muted: #6b6860;
  --faint: #44423d;
  --green: #6ac570;
  --green-dim: rgba(106,197,112,0.12);
  --green-strong: rgba(106,197,112,0.28);
  --green-glow: rgba(106,197,112,0.05);
  --gold: #d4af37;
  --rose: #c46c6c;
  --neon: 0 0 20px rgba(106,197,112,0.15), 0 0 40px rgba(106,197,112,0.05);
  --neon-strong: 0 0 10px rgba(106,197,112,0.3), 0 0 30px rgba(106,197,112,0.1), 0 0 60px rgba(106,197,112,0.05);
  --neon-text: 0 0 6px rgba(106,197,112,0.55), 0 0 18px rgba(106,197,112,0.3), 0 0 36px rgba(106,197,112,0.12);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Syne', sans-serif;
  font-size: 16px;
  line-height: 1.7;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}

/* film-grain overlay — identical to homepage */
body::before {
  content: ''; position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  background-size: 150px; pointer-events: none; z-index: 100; opacity: 0.4;
}

::selection { background: var(--green-strong); color: #fff; }

/* ─────────────────────────────  TOP NAV  ───────────────────────────── */
.ll-nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 600;
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 48px;
  background: rgba(8,8,10,0.9);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border);
}
.ll-nav__logo {
  display: flex; align-items: center; gap: 11px;
  text-decoration: none; color: var(--text);
}
.ll-nav__logo img { width: 30px; height: 30px; border-radius: 7px; display: block; }
.ll-nav__logo-text {
  font-weight: 800; font-size: 14px; letter-spacing: 0.14em; text-transform: uppercase;
}
.ll-nav__logo-text span { color: var(--green); text-shadow: var(--neon-text); }
.ll-nav__links { display: flex; gap: 30px; list-style: none; }
.ll-nav__links a {
  color: var(--muted); text-decoration: none;
  font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  transition: color 0.2s, text-shadow 0.2s;
}
.ll-nav__links a:hover,
.ll-nav__links a[aria-current] { color: var(--green); text-shadow: var(--neon-text); }

/* ─────────────────────────────  PAGE SHELL  ──────────────────────── */
.ll-page { max-width: 1000px; margin: 0 auto; padding: 0 48px; }
.ll-breadcrumb {
  padding: 92px 0 0; font-size: 11px;
  letter-spacing: 0.13em; text-transform: uppercase; color: var(--faint);
}
.ll-breadcrumb a { color: var(--faint); text-decoration: none; transition: color 0.2s; }
.ll-breadcrumb a:hover { color: var(--green); }
.ll-breadcrumb span { margin: 0 9px; opacity: 0.5; }

/* ─────────────────────────────  HERO  ─────────────────────────────── */
.ll-hero {
  position: relative; text-align: center;
  padding: 56px 0 64px;
  border-bottom: 1px solid var(--border);
}
.ll-hero::before {
  content: ''; position: absolute; inset: -40px -200px auto; height: 460px; z-index: -1;
  background:
    radial-gradient(ellipse 46% 60% at 50% 24%, rgba(106,197,112,0.10) 0%, transparent 70%),
    radial-gradient(ellipse 30% 40% at 78% 70%, rgba(106,197,112,0.045) 0%, transparent 60%);
  pointer-events: none;
}
.ll-hero__icon {
  width: 96px; height: 96px; border-radius: 22px; overflow: hidden;
  margin: 0 auto 26px; border: 1px solid var(--border-strong);
  box-shadow: var(--neon), 0 18px 50px rgba(0,0,0,0.6);
}
.ll-hero__icon img { width: 100%; height: 100%; object-fit: cover; display: block; }
.ll-eyebrow {
  font-size: 11px; letter-spacing: 0.3em; text-transform: uppercase;
  color: var(--green); text-shadow: var(--neon-text); margin-bottom: 22px;
}
.ll-hero h1 {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: clamp(40px, 6.4vw, 76px); line-height: 1.04; letter-spacing: -0.02em;
  max-width: 18ch; margin: 0 auto 24px;
}
.ll-hero h1 em { font-style: italic; color: var(--green); text-shadow: var(--neon-text); }
.ll-hero__sub {
  max-width: 60ch; margin: 0 auto 26px;
  color: var(--muted); font-size: 17px; line-height: 1.75;
}
.ll-hero__rating {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 7px 15px; margin-bottom: 28px;
  border: 1px solid var(--border); border-radius: 999px; background: var(--surface);
  font-size: 13px; color: var(--text);
}
.ll-hero__rating .stars { color: var(--gold); letter-spacing: 0.08em; }
.ll-hero__rating .muted { color: var(--muted); }
.ll-hero__cta {
  display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; margin-bottom: 22px;
}
.ll-hero__meta { font-size: 12.5px; color: var(--faint); letter-spacing: 0.02em; }

/* ─────────────────────────────  BUTTONS  ──────────────────────────── */
.ll-btn {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 15px 28px; border-radius: 3px;
  font-family: 'Syne', sans-serif; font-weight: 700;
  font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase;
  text-decoration: none; cursor: pointer;
  background: var(--green); color: #07140a;
  border: 1px solid var(--green);
  box-shadow: 0 0 24px rgba(106,197,112,0.28);
  transition: transform 0.2s var(--ease), box-shadow 0.3s, background 0.2s;
}
.ll-btn:hover { transform: translateY(-2px); box-shadow: 0 0 38px rgba(106,197,112,0.5); }
.ll-btn--ghost {
  background: transparent; color: var(--green);
  border: 1px solid var(--green-strong); box-shadow: none;
  text-shadow: var(--neon-text);
}
.ll-btn--ghost:hover { background: var(--green-dim); box-shadow: var(--neon); }

/* ─────────────────────  STICKY JUMP / ANCHOR NAV  ─────────────────── */
.ll-jump {
  position: sticky; top: 63px; z-index: 500;
  display: flex; gap: 6px; flex-wrap: wrap;
  padding: 12px 0; margin-bottom: 8px;
  background: rgba(8,8,10,0.92);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border-bottom: 1px solid var(--border);
}
.ll-jump a {
  font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--muted); text-decoration: none;
  padding: 7px 13px; border-radius: 999px; border: 1px solid transparent;
  transition: color 0.2s, border-color 0.2s, background 0.2s;
}
.ll-jump a:hover { color: var(--green); border-color: var(--green-strong); background: var(--green-dim); }

/* ─────────────────────────────  SECTIONS  ─────────────────────────── */
.ll-section { padding: 64px 0; border-bottom: 1px solid var(--border); scroll-margin-top: 122px; }
.ll-section:last-of-type { border-bottom: none; }
.ll-section > h2 {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: clamp(30px, 4vw, 48px); line-height: 1.1; letter-spacing: -0.015em;
  margin-bottom: 8px;
}
.ll-section > h2 em { font-style: italic; color: var(--green); text-shadow: var(--neon-text); }
/* kicker — high specificity so the prose rule below can never mute it */
.ll-page p.ll-kicker, .ll-kicker {
  font-family: 'Syne', sans-serif;
  font-size: 12px; font-weight: 700; letter-spacing: 0.28em; text-transform: uppercase;
  color: var(--green); text-shadow: var(--neon-text); margin: 0 0 14px;
}
.ll-section h3 {
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: 18px;
  letter-spacing: 0.01em; margin-bottom: 10px; color: var(--text);
}
/* prose — DIRECT-child paragraphs only, so component text keeps its own colour/size */
.ll-section > p { color: var(--muted); font-size: 16px; line-height: 1.78; margin-bottom: 16px; }
.ll-page p.ll-lead, .ll-lead { color: var(--text); font-size: 19px; line-height: 1.72; }
.ll-section strong { color: var(--text); font-weight: 700; }
.ll-section em { color: var(--green); font-style: italic; }
.ll-section > p a, .ll-section li a, .ll-faq__a a {
  color: var(--green); text-decoration: none;
  border-bottom: 1px solid var(--green-strong); transition: text-shadow 0.2s;
}
.ll-section > p a:hover, .ll-section li a:hover, .ll-faq__a a:hover { text-shadow: var(--neon-text); }

/* ─────────────────────────────  CARD GRID  ────────────────────────── */
.ll-cards {
  display: grid; gap: 16px; margin-top: 28px;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.ll-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 3px;
  padding: 28px 26px; transition: background 0.25s, border-color 0.25s;
}
.ll-card:hover { background: var(--surface-2); border-color: var(--green-strong); }
.ll-card h3 { margin-bottom: 8px; }
.ll-card p { font-size: 14.5px; line-height: 1.7; margin: 0; }

/* ─────────────────────────  FEATURE LIST  ─────────────────────────── */
.ll-features { list-style: none; margin: 26px 0 16px; }
.ll-features li {
  position: relative; padding: 16px 0 16px 30px;
  border-bottom: 1px solid var(--border);
  color: var(--muted); font-size: 15.5px; line-height: 1.7;
}
.ll-features li:last-child { border-bottom: none; }
.ll-features li::before {
  content: ''; position: absolute; left: 2px; top: 24px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--green); box-shadow: 0 0 10px rgba(106,197,112,0.6);
}
.ll-features li strong { color: var(--text); }

/* ─────────────────────────  NUMBERED STEPS  ───────────────────────── */
.ll-steps { counter-reset: s; list-style: none; margin: 28px 0 8px; }
.ll-steps li {
  counter-increment: s; position: relative;
  padding: 0 0 26px 62px; min-height: 46px;
}
.ll-steps li:last-child { padding-bottom: 0; }
.ll-steps li::before {
  content: counter(s, decimal-leading-zero);
  position: absolute; left: 0; top: -4px;
  font-family: 'Cormorant Garamond', serif; font-size: 30px;
  color: var(--green); text-shadow: var(--neon-text);
}
.ll-steps li::after {
  content: ''; position: absolute; left: 13px; top: 30px; bottom: 12px; width: 1px;
  background: linear-gradient(var(--green-strong), transparent);
}
.ll-steps li:last-child::after { display: none; }
.ll-steps li strong { display: block; color: var(--text); font-size: 16px; margin-bottom: 5px; }
.ll-steps li span { color: var(--muted); font-size: 15px; line-height: 1.7; }

/* ─────────────────────────  COMPARISON TABLE  ─────────────────────── */
.ll-table-wrap { overflow-x: auto; margin: 26px 0 14px; border: 1px solid var(--border); }
.ll-table { width: 100%; border-collapse: collapse; min-width: 540px; background: var(--surface); }
.ll-table th, .ll-table td {
  padding: 14px 18px; text-align: left;
  border-bottom: 1px solid var(--border); border-right: 1px solid var(--border);
  font-size: 14px; line-height: 1.55; color: var(--muted);
}
.ll-table th {
  background: var(--surface-2); color: var(--text);
  font-size: 11.5px; letter-spacing: 0.1em; text-transform: uppercase; font-weight: 700;
}
.ll-table th.is-us, .ll-table td.is-us { background: var(--green-glow); }
.ll-table th.is-us { color: var(--green); text-shadow: var(--neon-text); }
.ll-table td:first-child { color: var(--text); font-weight: 600; background: var(--surface-2); }
.ll-table tr:last-child td { border-bottom: none; }
.ll-table .yes { color: var(--green); }
.ll-table .no { color: var(--rose); }

/* ─────────────────────────────  SCENARIOS  ────────────────────────── */
.ll-scenarios { display: flex; flex-direction: column; gap: 1px; margin-top: 26px; background: var(--border); border: 1px solid var(--border); }
.ll-scenario { background: var(--bg); padding: 26px 28px; border-left: 2px solid var(--green); }
.ll-scenario h3 {
  font-family: 'Cormorant Garamond', serif; font-weight: 400; font-size: 24px;
  margin-bottom: 10px;
}
.ll-scenario p { margin: 0; font-size: 15px; }

/* ─────────────────────────────  FAQ  ──────────────────────────────── */
.ll-faq { margin-top: 24px; }
.ll-faq details {
  border-bottom: 1px solid var(--border);
}
.ll-faq summary {
  list-style: none; cursor: pointer; padding: 22px 40px 22px 0; position: relative;
  font-family: 'Cormorant Garamond', serif; font-weight: 400;
  font-size: 22px; line-height: 1.32; color: var(--text);
  transition: color 0.2s;
}
.ll-faq summary::-webkit-details-marker { display: none; }
.ll-faq summary:hover { color: var(--green); }
.ll-faq summary::after {
  content: '+'; position: absolute; right: 4px; top: 20px;
  font-family: 'Syne', sans-serif; font-size: 24px; font-weight: 400;
  color: var(--green); transition: transform 0.25s var(--ease);
}
.ll-faq details[open] summary::after { transform: rotate(45deg); }
.ll-faq details[open] summary { color: var(--green); text-shadow: var(--neon-text); }
.ll-faq__a { padding: 0 0 24px; color: var(--muted); font-size: 15.5px; line-height: 1.78; }
.ll-faq__a p { color: var(--muted); margin-bottom: 12px; }
.ll-faq__a p:last-child { margin-bottom: 0; }

/* ─────────────────────────────  PRICING  ──────────────────────────── */
.ll-pricing {
  display: grid; gap: 16px; margin-top: 28px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.ll-price {
  background: var(--surface); border: 1px solid var(--border); border-radius: 3px;
  padding: 30px 26px; position: relative;
}
.ll-price--featured { border-color: var(--green-strong); box-shadow: var(--neon); }
.ll-price--featured::before {
  content: 'Best value'; position: absolute; top: 0; right: 0;
  font-size: 9.5px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 700;
  color: #07140a; background: var(--green); padding: 5px 12px;
}
.ll-price h3 { font-size: 13px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--muted); }
.ll-price__amount {
  font-family: 'Cormorant Garamond', serif; font-size: 48px; line-height: 1;
  color: var(--green); text-shadow: var(--neon-text); margin: 12px 0 6px;
}
.ll-price__amount span { font-size: 14px; color: var(--muted); font-family: 'Syne', sans-serif; text-shadow: none; }
.ll-price ul { list-style: none; margin-top: 16px; }
.ll-price li {
  font-size: 13.5px; color: var(--muted); padding: 7px 0 7px 20px; position: relative;
}
.ll-price li::before { content: '·'; position: absolute; left: 4px; color: var(--green); font-weight: 700; }

/* ─────────────────────────────  CALLOUT  ──────────────────────────── */
.ll-callout {
  margin: 26px 0; padding: 24px 28px;
  background: var(--surface); border-left: 2px solid var(--green);
  font-size: 15px; line-height: 1.74; color: var(--muted);
}
.ll-callout strong { color: var(--green); text-shadow: var(--neon-text); }

/* ─────────────────────────────  DISCLAIMER  ───────────────────────── */
.ll-disclaimer {
  margin-top: 22px; padding: 20px 24px;
  border: 1px dashed var(--border-strong); border-radius: 3px;
  font-size: 13.5px; line-height: 1.7; color: var(--faint);
}
.ll-disclaimer p { font-size: 13.5px !important; color: var(--faint) !important; margin-bottom: 10px; }
.ll-disclaimer p:last-child { margin-bottom: 0; }
.ll-disclaimer a { color: var(--muted); }

/* ─────────────────────────────  RELATED  ──────────────────────────── */
.ll-related {
  display: grid; gap: 16px; margin-top: 26px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}
.ll-related-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 3px;
  padding: 24px; text-decoration: none !important; display: block; color: var(--text);
  transition: background 0.25s, border-color 0.25s;
}
.ll-related-card:hover { background: var(--surface-2); border-color: var(--green-strong); }
.ll-related-card h3 { color: var(--green); text-shadow: var(--neon-text); margin-bottom: 6px; font-size: 16px; }
.ll-related-card p { color: var(--muted); font-size: 13.5px; line-height: 1.65; margin: 0; }

/* ─────────────────────────────  CTA BAND  ─────────────────────────── */
.ll-cta-band { text-align: center; padding: 64px 0; }
.ll-cta-band h2 {
  font-family: 'Cormorant Garamond', serif; font-weight: 300;
  font-size: clamp(28px, 3.6vw, 44px); line-height: 1.12; margin-bottom: 22px;
}
.ll-cta-band h2 em { font-style: italic; color: var(--green); text-shadow: var(--neon-text); }

/* ─────────────────────────────  FOOTER  ───────────────────────────── */
.ll-footer { border-top: 1px solid var(--border); margin-top: 8px; }
.ll-footer__grid {
  max-width: 1000px; margin: 0 auto; padding: 48px;
  display: grid; gap: 36px; grid-template-columns: 1.4fr 1fr 1fr;
}
.ll-footer__grid strong {
  display: block; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text); margin-bottom: 14px;
}
.ll-footer__grid p { font-size: 13.5px; color: var(--muted); line-height: 1.7; }
.ll-footer__grid ul { list-style: none; }
.ll-footer__grid li { margin-bottom: 9px; }
.ll-footer__grid a { font-size: 13.5px; color: var(--muted); text-decoration: none; transition: color 0.2s; }
.ll-footer__grid a:hover { color: var(--green); text-shadow: var(--neon-text); }
.ll-footer__brand span { color: var(--green); text-shadow: var(--neon-text); }
.ll-footer__legal {
  max-width: 1000px; margin: 0 auto; padding: 22px 48px;
  border-top: 1px solid var(--border);
  font-size: 12px; color: var(--faint); line-height: 1.65;
}

/* ─────────────────────────  LISTICLE RANK ITEMS  ──────────────────── */
.ll-rank { display: flex; flex-direction: column; gap: 14px; margin-top: 28px; }
.ll-rank-item {
  display: flex; gap: 22px; align-items: flex-start;
  background: var(--surface); border: 1px solid var(--border); padding: 24px 26px;
  transition: border-color 0.25s;
}
.ll-rank-item:hover { border-color: var(--green-strong); }
.ll-rank-item.is-top { border-color: var(--green-strong); box-shadow: var(--neon); }
.ll-rank__num {
  font-family: 'Cormorant Garamond', serif; font-size: 44px; line-height: 1;
  color: var(--green); text-shadow: var(--neon-text); flex-shrink: 0; width: 52px;
}
.ll-rank__body h3 { font-size: 19px; margin-bottom: 6px; }
.ll-rank__body p { font-size: 14.5px; margin-bottom: 8px; }

/* ─────────────────────────────  REVEAL  ───────────────────────────── */
/* translateY only — no opacity fade, so accent colours never read as dim */
.ll-reveal { transform: translateY(24px); transition: transform 0.6s var(--ease); }
.ll-reveal.in { transform: none; }
@media (prefers-reduced-motion: reduce) {
  .ll-reveal { transform: none; transition: none; }
  html { scroll-behavior: auto; }
}

/* ───────────────────────  CUSTOM CURSOR (desktop)  ────────────────── */
@media (pointer: fine) {
  body.ll-cursor-ready,
  body.ll-cursor-ready a,
  body.ll-cursor-ready button,
  body.ll-cursor-ready summary { cursor: none; }
}
.ll-cursor, .ll-cursor-ring {
  position: fixed; top: 0; left: 0; border-radius: 50%;
  pointer-events: none; opacity: 0; will-change: transform;
  transition: opacity 0.3s, width 0.2s var(--ease), height 0.2s var(--ease), border-color 0.2s;
}
.ll-cursor { width: 7px; height: 7px; background: var(--green); z-index: 9999; box-shadow: 0 0 10px rgba(106,197,112,0.7); }
.ll-cursor-ring { width: 30px; height: 30px; border: 1px solid var(--green-strong); z-index: 9998; }
.ll-cursor.on, .ll-cursor-ring.on { opacity: 1; }
.ll-cursor.lg { width: 13px; height: 13px; }
.ll-cursor-ring.lg { width: 48px; height: 48px; border-color: var(--green); box-shadow: var(--neon); }

/* ─────────────────────  MOTION — tasteful, light  ─────────────────── */
@keyframes ll-glow  { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } }
@keyframes ll-float { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-7px); } }
.ll-hero::before { animation: ll-glow 8s ease-in-out infinite; }
.ll-hero__icon   { animation: ll-float 6s ease-in-out infinite; }

/* card hover-lift */
.ll-card:hover, .ll-related-card:hover, .ll-rank-item:hover { transform: translateY(-4px); }

/* staggered reveal of grid children — translateY only, never opacity */
.ll-cards > *, .ll-pricing > *, .ll-related > *, .ll-rank > * {
  transition: background 0.25s, border-color 0.25s, transform 0.55s var(--ease), box-shadow 0.3s;
}
.ll-reveal:not(.in) .ll-cards > *,
.ll-reveal:not(.in) .ll-pricing > *,
.ll-reveal:not(.in) .ll-related > *,
.ll-reveal:not(.in) .ll-rank > * { transform: translateY(22px); }
.ll-cards > :nth-child(2), .ll-pricing > :nth-child(2), .ll-related > :nth-child(2), .ll-rank > :nth-child(2) { transition-delay: 0.07s; }
.ll-cards > :nth-child(3), .ll-pricing > :nth-child(3), .ll-related > :nth-child(3), .ll-rank > :nth-child(3) { transition-delay: 0.14s; }
.ll-cards > :nth-child(4), .ll-related > :nth-child(4), .ll-rank > :nth-child(4) { transition-delay: 0.21s; }
.ll-cards > :nth-child(n+5), .ll-rank > :nth-child(n+5) { transition-delay: 0.28s; }

/* jump-nav active link — set by scroll-spy */
.ll-jump a.is-active {
  color: var(--green); border-color: var(--green-strong);
  background: var(--green-dim); text-shadow: var(--neon-text);
}

@media (prefers-reduced-motion: reduce) {
  .ll-hero::before, .ll-hero__icon { animation: none; }
  .ll-cards > *, .ll-pricing > *, .ll-related > *, .ll-rank > * { transform: none !important; }
}

/* ─────────────────────────────  RESPONSIVE  ───────────────────────── */
@media (max-width: 760px) {
  .ll-nav { padding: 13px 20px; }
  .ll-nav__links { gap: 16px; }
  .ll-nav__links a { font-size: 11px; letter-spacing: 0.08em; }
  .ll-page { padding: 0 20px; }
  .ll-hero { padding: 40px 0 48px; }
  .ll-jump { top: 55px; }
  .ll-jump a { font-size: 11px; padding: 6px 10px; }
  .ll-section { padding: 46px 0; }
  .ll-footer__grid { grid-template-columns: 1fr; gap: 28px; padding: 36px 20px; }
  .ll-footer__legal { padding: 20px; }
  .ll-rank-item { flex-direction: column; gap: 10px; }
}

/* ════════════════════════════════════════════════════════════════════════
   LEGACY — original shared styles for not-yet-migrated app pages.
   Kept so the 5 first-batch apps render until rebuilt onto ll-*. Do not extend.
   ════════════════════════════════════════════════════════════════════════ */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:600;padding:18px 48px;display:flex;align-items:center;justify-content:space-between;background:rgba(8,8,10,0.92);backdrop-filter:blur(20px);border-bottom:1px solid var(--border)}
.site-nav-logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);font-weight:800;font-size:15px;letter-spacing:0.14em;text-transform:uppercase}
.site-nav-logo img{width:28px;height:28px;border-radius:6px}
.site-nav-logo span span{color:var(--green);text-shadow:var(--neon-text)}
.site-nav-links{display:flex;gap:32px;list-style:none}
.site-nav-links a{color:var(--muted);text-decoration:none;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;transition:color 0.2s}
.site-nav-links a:hover{color:var(--green);text-shadow:var(--neon-text)}
.breadcrumbs{padding:100px 48px 24px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);max-width:980px;margin:0 auto}
.breadcrumbs a{color:var(--muted);text-decoration:none}
.breadcrumbs a:hover{color:var(--green)}
.breadcrumbs .separator{margin:0 10px;opacity:0.4}
.page{max-width:880px;margin:0 auto;padding:24px 48px 80px}
.page-wide{max-width:1180px;margin:0 auto;padding:24px 48px 80px}
.eyebrow{font-size:12px;letter-spacing:0.3em;text-transform:uppercase;color:var(--green);margin-bottom:20px;text-shadow:var(--neon-text)}
.page h1,.page-wide h1{font-family:'Cormorant Garamond',serif;font-size:clamp(40px,6vw,72px);font-weight:300;line-height:1.05;letter-spacing:-0.015em;margin-bottom:28px}
.page h1 em{font-style:italic;color:var(--green);text-shadow:var(--neon-text)}
.page h2,.page-wide h2{font-family:'Cormorant Garamond',serif;font-size:clamp(28px,3.5vw,44px);font-weight:400;line-height:1.15;margin:64px 0 24px}
.page h3{font-weight:700;font-size:20px;margin:36px 0 16px}
.page p,.page-wide p{margin-bottom:18px;font-size:16px;line-height:1.75}
.page ul,.page ol{margin:0 0 24px 24px}
.page li{margin-bottom:8px;line-height:1.7}
.lead{font-size:19px;line-height:1.7;margin-bottom:32px}
.page strong{color:var(--text);font-weight:700}
.page em{color:var(--green);font-style:italic}
.page a,.page-wide a{color:var(--green);text-decoration:none;border-bottom:1px solid rgba(106,197,112,0.3);transition:border-color 0.2s}
.page a:hover{border-color:var(--green)}
.related{margin-top:64px;padding-top:32px;border-top:1px solid var(--border)}
.cta{display:inline-flex;align-items:center;gap:10px;padding:16px 28px;background:var(--green);color:#07140a;font-weight:700;font-size:13px;letter-spacing:0.1em;text-transform:uppercase;text-decoration:none;border-radius:3px;border:1px solid var(--green);box-shadow:0 0 22px rgba(106,197,112,0.25);transition:transform 0.2s,box-shadow 0.3s}
.cta:hover{transform:translateY(-2px);box-shadow:0 0 36px rgba(106,197,112,0.45)}
.cta-row{display:flex;flex-wrap:wrap;gap:16px;margin:32px 0}
.cta-secondary{display:inline-flex;align-items:center;gap:8px;color:var(--muted);border-bottom:1px solid var(--border);padding-bottom:4px;font-size:13px;letter-spacing:0.1em;text-transform:uppercase}
.cta-secondary:hover{color:var(--text);border-color:var(--text)}
.hero-block{padding-top:24px;padding-bottom:48px;border-bottom:1px solid var(--border);margin-bottom:48px}
.fact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:1px;background:var(--border);border:1px solid var(--border);margin:32px 0}
.fact{background:var(--bg);padding:24px 26px}
.fact-label{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--green);margin-bottom:8px;text-shadow:var(--neon-text)}
.fact-value{font-family:'Cormorant Garamond',serif;font-size:28px;line-height:1.1}
.fact-desc{font-size:13px;color:var(--muted);margin-top:8px}
.cmp-table{width:100%;border-collapse:collapse;margin:32px 0;background:var(--surface);border:1px solid var(--border)}
.cmp-table th,.cmp-table td{padding:16px 20px;text-align:left;border-bottom:1px solid var(--border);font-size:14px;line-height:1.55}
.cmp-table th{background:var(--surface-2);font-size:12px;letter-spacing:0.1em;text-transform:uppercase;color:var(--muted);font-weight:700}
.cmp-table th.us{color:var(--green);text-shadow:var(--neon-text)}
.cmp-table td.feature{font-weight:600;color:var(--text);background:var(--surface-2)}
.cmp-table .yes{color:var(--green)}
.cmp-table .no{color:#c46c6c}
.cmp-table .partial{color:var(--gold)}
.cmp-table tr:last-child td{border-bottom:none}
.faq-block{margin:48px 0}
.faq-item{border-bottom:1px solid var(--border);padding:28px 0}
.faq-q{font-family:'Cormorant Garamond',serif;font-size:24px;font-weight:400;line-height:1.3;margin-bottom:14px}
.faq-a{font-size:16px;line-height:1.75}
.faq-a p{margin-bottom:12px}
.callout{background:var(--surface);border-left:2px solid var(--green);padding:24px 28px;margin:32px 0;font-size:15px;line-height:1.7}
.callout strong{color:var(--green);text-shadow:var(--neon-text)}
.steps{counter-reset:step;margin:32px 0;list-style:none;padding:0}
.steps li{counter-increment:step;position:relative;padding:0 0 28px 56px}
.steps li::before{content:counter(step,decimal-leading-zero);position:absolute;left:0;top:0;font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--green);text-shadow:var(--neon-text)}
.steps li strong{display:block;font-size:16px;margin-bottom:6px;color:var(--text)}
.steps li p{color:var(--muted);margin:0;font-size:14px}
.site-footer{border-top:1px solid var(--border);padding:32px 48px;margin-top:80px;display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;max-width:980px;margin-left:auto;margin-right:auto}
.site-footer .footer-logo{font-weight:800;font-size:14px;letter-spacing:0.12em;text-transform:uppercase}
.site-footer .footer-logo span{color:var(--green);text-shadow:var(--neon-text)}
.site-footer p{font-size:13px;color:var(--muted)}
.site-footer ul{display:flex;gap:22px;list-style:none}
.site-footer ul a{font-size:13px;color:var(--muted);border:none}
.disclaimer{margin-top:48px;padding-top:24px;border-top:1px dashed var(--border);font-size:13px;color:var(--muted);line-height:1.6;font-style:italic}
@media (max-width:720px){.site-nav{padding:14px 20px}.site-nav-links{gap:18px}.breadcrumbs{padding:90px 20px 16px}.page,.page-wide{padding:16px 20px 60px}.site-footer{padding:24px 20px}}
