/* B2B LA — shared subpage styles */

:root {
  color-scheme: light;
  --linen: #f6f0e4;
  --linen-2: #eee4d2;
  --ink: #0e1115;
  --muted: #66615a;
  --soft: #dacca3;
  --violet: #6b63ff;
  --violet-2: #8b84ff;
  --violet-deep: #2a2380;
  --gold: #c5a969;
  --gold-2: #e8cc8a;
  --line: rgba(17, 20, 23, .1);
  --line-strong: rgba(17, 20, 23, .22);
  --nav: rgba(246, 240, 228, .82);
  --mono: "SFMono-Regular", "JetBrains Mono", "Roboto Mono", Consolas, monospace;
  --sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --ease: cubic-bezier(.2, .8, .2, 1);
  --ease-2: cubic-bezier(.16, 1, .3, 1);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at 88% 8%, color-mix(in srgb, var(--soft), transparent 44%), transparent 25rem),
    linear-gradient(180deg, var(--linen) 0%, color-mix(in srgb, var(--linen), white 24%) 44%, var(--linen-2) 100%);
  color: var(--ink);
  font-family: var(--sans);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
body::before {
  content: ""; position: fixed; inset: 0; z-index: -1;
  pointer-events: none; opacity: .14;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
}
a { color: inherit; text-decoration: none; }
::selection { background: rgba(107,99,255,.25); }

/* NAV */
.nav {
  position: sticky; top: 0; z-index: 30;
  display: grid; grid-template-columns: auto 1fr auto;
  align-items: center; gap: 1.5rem;
  min-height: 4.25rem;
  padding: .85rem clamp(1rem, 3vw, 2.25rem);
  border-bottom: 1px solid var(--line);
  background: var(--nav);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.brand { display: flex; align-items: center; gap: .7rem; font-weight: 760; letter-spacing: -.03em; font-size: 1.35rem; }
.brand-mark {
  width: 2rem; aspect-ratio: 1; border-radius: 50%;
  background:
    radial-gradient(circle at 30% 28%, rgba(255,255,255,.68), transparent 14%),
    linear-gradient(135deg, #111417, var(--violet) 72%, var(--soft));
  box-shadow: 0 .65rem 1.4rem rgba(79, 73, 190, .28);
}
.nav-links {
  display: flex; justify-content: center; align-items: center;
  gap: clamp(.45rem, 1.5vw, 1.25rem);
  color: rgba(17,20,23,.68);
  font-family: var(--mono); font-size: .66rem; letter-spacing: .12em; text-transform: uppercase;
}
.nav-links a,
.nav-trigger {
  padding: .45rem .2rem;
  transition: color .25s;
}
.nav-links a:hover,
.nav-item:hover .nav-trigger,
.nav-item:focus-within .nav-trigger { color: var(--ink); }
.nav-item { position: relative; }
.nav-trigger {
  display: inline-flex; align-items: center; gap: .35rem;
  border: 0; background: transparent;
  color: inherit; font: inherit; letter-spacing: inherit; text-transform: inherit;
  cursor: default;
}
.nav-trigger::after {
  content: "";
  width: .38rem; height: .38rem;
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  transform: translateY(-.12rem) rotate(45deg);
  opacity: .75;
}
.nav-menu {
  position: absolute;
  top: calc(100% + .8rem); left: 50%;
  width: min(34rem, calc(100vw - 2rem));
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .35rem;
  padding: .75rem;
  border: 1px solid rgba(17,20,23,.12);
  border-radius: 16px;
  background: rgba(255,250,240,.94);
  box-shadow: 0 1.6rem 4rem rgba(17,20,23,.18);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  opacity: 0; visibility: hidden;
  transform: translate(-50%, .35rem);
  transition: opacity .2s var(--ease-2), transform .2s var(--ease-2), visibility .2s;
}
.nav-item:hover .nav-menu,
.nav-item:focus-within .nav-menu {
  opacity: 1; visibility: visible; transform: translate(-50%, 0);
}
.nav-menu.services { width: min(28rem, calc(100vw - 2rem)); }
.nav-menu.trades { width: min(46rem, calc(100vw - 2rem)); grid-template-columns: repeat(3, minmax(0, 1fr)); }
.nav-menu a {
  display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  min-height: 2.65rem;
  padding: .7rem .8rem;
  border-radius: 10px;
  color: rgba(17,20,23,.72);
  background: rgba(255,255,255,.2);
  letter-spacing: .08em;
}
.nav-menu a::after {
  content: "";
  width: .34rem;
  height: .34rem;
  border-radius: 50%;
  background: currentColor;
  opacity: .32;
  flex: 0 0 .34rem;
}
.nav-menu a:hover { background: rgba(107,99,255,.1); color: var(--ink); }
.mobile-nav { display: none; position: relative; justify-self: end; }
.mobile-nav summary {
  position: relative;
  z-index: 70;
  list-style: none;
  display: inline-grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border: 0;
  border-radius: 0;
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  user-select: none;
  appearance: none;
  -webkit-appearance: none;
  font-size: 0;
  line-height: 0;
  overflow: hidden;
  list-style-type: none;
}
.mobile-nav summary::-webkit-details-marker { display: none; }
.mobile-nav summary::marker { content: ""; font-size: 0; }
.mobile-nav summary:focus { outline: none; }
.mobile-nav summary:focus-visible { outline: 2px solid var(--gold); outline-offset: .25rem; border-radius: 6px; }
.mobile-nav summary::before,
.mobile-nav summary::after { content: none; }
.mobile-nav-icon {
  display: grid;
  gap: .25rem;
  width: 1.18rem;
}
.mobile-nav-icon span {
  display: block;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform-origin: center;
  transition: transform .24s var(--ease-2), opacity .18s var(--ease-2);
}
.mobile-nav[open] summary { position: fixed; top: 1rem; right: 1rem; background: transparent; color: var(--ink); }
.mobile-nav[open] .mobile-nav-icon span:nth-child(1) { transform: translateY(.375rem) rotate(45deg); }
.mobile-nav[open] .mobile-nav-icon span:nth-child(2) { opacity: 0; }
.mobile-nav[open] .mobile-nav-icon span:nth-child(3) { transform: translateY(-.375rem) rotate(-45deg); }
.mobile-nav[open]::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 50;
  background: rgba(14,17,21,.34);
  backdrop-filter: blur(5px);
  -webkit-backdrop-filter: blur(5px);
}
.mobile-nav-panel {
  position: fixed;
  top: 0; right: 0; bottom: auto; left: clamp(3.4rem, 14vw, calc(100vw - 25rem));
  width: auto;
  height: 100svh;
  max-height: none;
  padding: 5rem 1rem 1.2rem;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  border-left: 1px solid rgba(17,20,23,.1);
  background:
    radial-gradient(circle at 18% 4%, rgba(107,99,255,.18), transparent 12rem),
    #fffaf0;
  box-shadow: -1.5rem 0 4rem rgba(17,20,23,.24);
  z-index: 60;
  animation: mobileDrawerIn .24s var(--ease-2) both;
}
@keyframes mobileDrawerIn {
  from { transform: translateX(100%); opacity: .75; }
  to { transform: translateX(0); opacity: 1; }
}
.mobile-nav-top {
  position: sticky;
  top: -5rem;
  z-index: 2;
  display: flex;
  gap: .45rem;
  margin: -1rem -1rem 1.05rem;
  padding: 1rem 1rem .8rem;
  overflow-x: auto;
  background: linear-gradient(180deg, rgba(255,250,240,.98) 74%, rgba(255,250,240,0));
  scrollbar-width: none;
}
.mobile-nav-top::-webkit-scrollbar { display: none; }
.mobile-nav-top a {
  flex: 0 0 auto;
  min-height: 2.7rem;
  padding: .78rem .95rem;
  border-radius: 999px;
  border-color: rgba(17,20,23,.1);
  background: rgba(255,255,255,.62);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.5);
}
.mobile-nav-top a.mobile-nav-feature {
  color: var(--ink);
  border-color: rgba(197,169,105,.55);
  background: linear-gradient(135deg, var(--gold-2) 0%, var(--gold) 42%, var(--violet-2) 100%);
  box-shadow: 0 .8rem 1.4rem rgba(107,99,255,.14), inset 0 0 0 1px rgba(255,255,255,.28);
  font-weight: 800;
}
.mobile-nav-top a.mobile-nav-feature::after { opacity: .42; }

.mobile-nav-group + .mobile-nav-group { margin-top: 1.15rem; }
.mobile-nav-group h3 {
  margin: 0 0 .55rem;
  color: rgba(17,20,23,.5);
  font-family: var(--mono); font-size: .62rem; letter-spacing: .16em; text-transform: uppercase;
}
.mobile-nav-grid { display: grid; gap: .52rem; }
.mobile-nav-grid.services,
.mobile-nav-grid.trades { grid-template-columns: 1fr; }
.mobile-nav a {
  display: flex; align-items: center; justify-content: space-between; gap: .8rem;
  min-height: 3.45rem;
  padding: .9rem 1rem;
  border: 1px solid rgba(17,20,23,.09);
  border-radius: 12px;
  background: rgba(255,255,255,.5);
  color: rgba(17,20,23,.82);
  font-family: var(--mono); font-size: .7rem; line-height: 1.2; letter-spacing: .075em; text-transform: uppercase;
  transition: background .18s, border-color .18s, transform .18s var(--ease-2);
}
.mobile-nav a::after {
  content: "";
  width: .48rem;
  height: .48rem;
  border-top: 1.5px solid currentColor;
  border-right: 1.5px solid currentColor;
  transform: rotate(45deg);
  opacity: .32;
  flex: 0 0 .48rem;
}
.mobile-nav a:hover,
.mobile-nav a:focus-visible {
  background: rgba(107,99,255,.1);
  border-color: rgba(107,99,255,.22);
  color: var(--ink);
}
.mobile-nav a:active { transform: scale(.985); }
.nav-actions { display: flex; align-items: center; justify-content: flex-end; gap: .5rem; }

.button {
  display: inline-flex; align-items: center; justify-content: center; gap: .55rem;
  min-height: 2.6rem;
  border-radius: 999px;
  border: 1px solid var(--ink);
  padding: .75rem 1.2rem;
  background: var(--ink); color: #fffdf7;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase;
  white-space: nowrap;
  transform: translateY(0);
  transition: transform .32s var(--ease-2), box-shadow .32s var(--ease-2), background .25s, border-color .25s;
  will-change: transform;
}
.button:hover {
  transform: translateY(-3px);
  box-shadow: 0 1rem 2rem rgba(17,20,23,.18), 0 .3rem .75rem rgba(17,20,23,.12);
}
.button:active {
  transform: translateY(-1px);
  transition-duration: .12s;
}
.button .arr {
  transition: transform .32s var(--ease-2);
  display: inline-grid;
  place-items: center;
  width: 1em;
  flex: 0 0 1em;
}
.button:hover .arr { transform: translate(3px, -1px); }
.button[href="#top"]:hover .arr { transform: translateY(-2px); }
.button.invert { background: #fffaf0; color: var(--ink); border-color: #fffaf0; }
.button.large { min-height: 3.2rem; padding: 1rem 1.55rem; font-size: .72rem; }
.button.ghost { background: transparent; color: var(--ink); }
.button.why-button {
  border-color: rgba(197,169,105,.55);
  background:
    linear-gradient(135deg, var(--gold-2) 0%, var(--gold) 42%, var(--violet-2) 100%);
  color: var(--ink);
  box-shadow: 0 .8rem 1.6rem rgba(107,99,255,.16);
}
.button.why-button:hover {
  box-shadow: 0 1rem 2rem rgba(107,99,255,.2), 0 .4rem .85rem rgba(197,169,105,.2);
}

/* LAYOUT */
.container { width: min(100%, 86rem); margin: 0 auto; padding: 0 clamp(1rem, 4vw, 4rem); }
section { padding: clamp(4.5rem, 8vw, 7rem) 0; border-bottom: 1px solid var(--line); position: relative; }

.label {
  display: inline-flex; align-items: center; gap: .6rem;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--violet); font-weight: 700;
  margin-bottom: 1.1rem;
}
.label::before {
  content: ""; width: .35rem; height: .35rem; border-radius: 50%;
  background: var(--violet);
  box-shadow: 0 0 0 .3rem rgba(107,99,255,.15);
}

h1 {
  margin: 0; max-width: 18ch;
  font-size: clamp(2.8rem, 6vw, 5.4rem);
  line-height: .98;
  letter-spacing: -.04em;
  font-weight: 740;
}
h2 {
  margin: 0 0 1rem; max-width: 24ch;
  font-size: clamp(1.85rem, 3.4vw, 3rem);
  line-height: 1.05; letter-spacing: -.035em; font-weight: 720;
}
h3 {
  margin: 0 0 .6rem;
  font-size: clamp(1.2rem, 1.8vw, 1.5rem);
  line-height: 1.18; letter-spacing: -.02em; font-weight: 700;
}
.lede {
  max-width: 56ch; margin: 1.3rem 0 0;
  color: var(--muted);
  font-size: clamp(1.05rem, 1.4vw, 1.22rem);
  line-height: 1.55;
}

/* CRUMB */
.crumb {
  display: flex; gap: .5rem; align-items: center;
  font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 2rem;
}
.crumb a:hover { color: var(--ink); }
.crumb .sep { opacity: .45; }

/* HERO */
.hero {
  position: relative;
  padding: clamp(5rem, 10vw, 8rem) 0 clamp(4rem, 8vw, 6rem);
  overflow: hidden;
}
.hero-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.hero-cta { margin-top: 2rem; }
.hero-vis {
  position: relative; aspect-ratio: 1.05 / 1;
  min-height: 22rem;
  border-radius: 22px;
  overflow: hidden;
  background: linear-gradient(135deg, #16191f, #0d1015);
  border: 1px solid rgba(255,250,240,.08);
  isolation: isolate;
}
.hero-vis .blob {
  position: absolute; border-radius: 50%; filter: blur(60px); opacity: .85;
  animation: blobFloat 18s ease-in-out infinite;
}
@keyframes blobFloat {
  0%, 100% { transform: translate(0,0) scale(1); }
  33% { transform: translate(2rem, -1.5rem) scale(1.08); }
  66% { transform: translate(-1.5rem, 2rem) scale(.95); }
}

/* Hero variants — color palettes per industry */
.hero-vis.violet .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, var(--violet), var(--violet-deep) 60%, transparent 75%); }
.hero-vis.violet .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--gold), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.violet .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, var(--violet-2), transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis.gold .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, var(--gold-2), #b08620 60%, transparent 75%); }
.hero-vis.gold .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--violet), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.gold .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, var(--gold), transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis.teal .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, #2bc6bf, #0e6e75 60%, transparent 75%); }
.hero-vis.teal .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--violet), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.teal .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, #5be0d6, transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis.coral .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, #ec8e62, #8c3a22 60%, transparent 75%); }
.hero-vis.coral .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--gold), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.coral .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, #f6b18d, transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis.azure .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, #5b9af6, #1f4ea7 60%, transparent 75%); }
.hero-vis.azure .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--gold-2), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.azure .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, #8eb6f8, transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis.lime .b1 { width: 30rem; height: 30rem; left: -8rem; top: -8rem; background: radial-gradient(circle, #b5d854, #51742a 60%, transparent 75%); }
.hero-vis.lime .b2 { width: 24rem; height: 24rem; right: -6rem; bottom: -6rem; background: radial-gradient(circle, var(--violet), transparent 70%); opacity: .55; animation-delay: -6s; }
.hero-vis.lime .b3 { width: 20rem; height: 20rem; left: 32%; top: 30%; background: radial-gradient(circle, #d4ed8a, transparent 65%); opacity: .7; animation-delay: -12s; }

.hero-vis .ring {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  border: 1px solid rgba(255,250,240,.35);
  border-radius: 50%;
  animation: ringPulse 4.5s var(--ease) infinite;
  width: 8rem; height: 8rem;
}
.hero-vis .ring.r2 { animation-delay: -1.5s; }
.hero-vis .ring.r3 { animation-delay: -3s; }
@keyframes ringPulse {
  0% { transform: translate(-50%,-50%) scale(.4); opacity: 1; }
  100% { transform: translate(-50%,-50%) scale(2.8); opacity: 0; }
}
.hero-vis .core {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);
  width: 1rem; height: 1rem; border-radius: 50%;
  background: #fffaf0;
  box-shadow:
    0 0 0 .4rem rgba(255,250,240,.18),
    0 0 0 1rem rgba(107,99,255,.4),
    0 0 60px rgba(107,99,255,.85);
  animation: coreBeat 1.6s ease-in-out infinite;
}
@keyframes coreBeat {
  0%, 100% { transform: translate(-50%,-50%) scale(1); }
  50% { transform: translate(-50%,-50%) scale(1.15); }
}
.hero-vis .grain {
  position: absolute; inset: -10%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  background-size: 200px 200px;
  opacity: .35;
  mix-blend-mode: overlay;
  pointer-events: none;
}

/* TWO-COL */
.two-col {
  display: grid; grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.copy p {
  margin: 0 0 1.1em;
  max-width: 60ch;
  color: var(--ink);
  font-size: clamp(1.05rem, 1.4vw, 1.18rem);
  line-height: 1.6;
}
.copy p:last-child { margin-bottom: 0; }
.copy strong { color: var(--violet); font-weight: 600; }

/* STEPS */
.steps { display: grid; gap: 0; border-top: 1px solid var(--line); }
.step {
  display: grid;
  grid-template-columns: 4rem minmax(0, 1fr);
  gap: clamp(1rem, 2.4vw, 2rem);
  padding: 1.5rem 0;
  border-bottom: 1px solid var(--line);
  transition: padding-left .5s var(--ease-2), background .35s;
}
.step:hover { padding-left: 1rem; background: rgba(107,99,255,.03); }
.step-num {
  font-family: var(--mono); font-size: .72rem;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--violet); padding-top: .35rem;
}
.step h3 { margin-bottom: .35rem; }
.step p { margin: 0; max-width: 60ch; color: var(--muted); line-height: 1.55; font-size: 1rem; }

/* CARD GRIDS */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2rem;
}
.card {
  position: relative;
  padding: 1.4rem 1.4rem 1.55rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 252, 245, .42);
  transition: transform .45s var(--ease-2), border-color .35s, box-shadow .45s;
  overflow: hidden;
  isolation: isolate;
}
.card::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 0%), rgba(107,99,255,.16), transparent 55%);
  opacity: 0; transition: opacity .45s var(--ease);
}
.card:hover {
  transform: translateY(-4px);
  border-color: rgba(107,99,255,.35);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.06);
}
.card:hover::before { opacity: 1; }
.card .pill {
  display: inline-block;
  padding: .25rem .55rem;
  background: rgba(107,99,255,.12);
  color: var(--violet);
  font-family: var(--mono); font-size: .58rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700;
  border-radius: 4px;
  margin-bottom: .85rem;
}
.card .pill.gold { background: rgba(197, 169, 105, .18); color: #8c6b1f; }
.card .pill.coral { background: rgba(236, 142, 98, .18); color: #b04f29; }
.card .pill.teal { background: rgba(43, 198, 191, .18); color: #117a78; }
.card .pill.azure { background: rgba(91, 154, 246, .18); color: #1f4ea7; }
.card h3 { font-size: 1.15rem; margin-bottom: .35rem; }
.card p { margin: 0; color: var(--muted); font-size: .95rem; line-height: 1.5; }

/* BLOG */
.blog-hero-image {
  position: relative;
  min-height: clamp(19rem, 32vw, 30rem);
  border-radius: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  box-shadow: 0 1.4rem 3rem rgba(17,20,23,.08);
  background: var(--ink);
}
.blog-hero-image img {
  width: 100%;
  height: 100%;
  min-height: inherit;
  object-fit: cover;
  display: block;
}
.blog-hero-image::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 45%, rgba(14,17,21,.48));
  pointer-events: none;
}
.blog-meta {
  display: flex;
  flex-wrap: wrap;
  gap: .55rem;
  margin: 1.25rem 0 0;
  color: var(--muted);
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.blog-meta span {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}
.blog-meta span + span::before {
  content: "";
  width: .28rem;
  height: .28rem;
  border-radius: 50%;
  background: var(--violet);
  opacity: .6;
}
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem;
  margin-top: 2.25rem;
}
.blog-card {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 100%;
  border: 1px solid var(--line);
  border-radius: 14px;
  overflow: hidden;
  background: rgba(255, 252, 245, .48);
  box-shadow: 0 .8rem 1.8rem rgba(17,20,23,.035);
  transition: transform .45s var(--ease-2), border-color .35s, box-shadow .45s;
}
.blog-card:hover {
  transform: translateY(-4px);
  border-color: rgba(107,99,255,.35);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.07);
}
.blog-card img {
  width: 100%;
  aspect-ratio: 16 / 10;
  object-fit: cover;
  display: block;
  background: var(--ink);
}
.blog-card-body {
  display: flex;
  flex-direction: column;
  gap: .65rem;
  padding: 1.2rem;
}
.blog-card .pill { align-self: flex-start; }
.blog-card h3 {
  margin: 0;
  font-size: 1.12rem;
}
.blog-card p {
  margin: 0;
  color: var(--muted);
  font-size: .95rem;
  line-height: 1.5;
}
.blog-card .read-more {
  margin-top: auto;
  padding-top: .45rem;
  color: var(--violet);
  font-family: var(--mono);
  font-size: .62rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
}
.article-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 17rem;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.article-body {
  max-width: 48rem;
}
.article-body p,
.article-body li {
  color: var(--ink);
  font-size: clamp(1.04rem, 1.3vw, 1.16rem);
  line-height: 1.7;
}
.article-body p { margin: 0 0 1.2em; }
.article-body h2 {
  margin-top: 2.2rem;
  max-width: 26ch;
}
.article-body h3 {
  margin-top: 1.8rem;
}
.article-body ul,
.article-body ol {
  margin: 0 0 1.4rem;
  padding-left: 1.25rem;
}
.article-body a {
  color: var(--violet);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: .18em;
}
.article-callout {
  margin: 2rem 0;
  padding: 1.35rem;
  border: 1px solid rgba(107,99,255,.2);
  border-radius: 14px;
  background: rgba(107,99,255,.06);
}
.article-callout p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
}
.article-cta {
  margin: clamp(2rem, 4vw, 3rem) 0 0;
  padding: clamp(1.25rem, 3vw, 1.8rem);
  border: 1px solid rgba(107,99,255,.22);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(107,99,255,.12), transparent 58%),
    linear-gradient(135deg, rgba(255,252,245,.74), rgba(255,252,245,.48));
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.045);
}
.article-cta h2 {
  margin: 0 0 .7rem;
  max-width: 21ch;
  font-size: clamp(1.45rem, 2.4vw, 2rem);
}
.article-cta p {
  margin: 0;
  color: var(--muted);
  font-size: 1rem;
  line-height: 1.58;
}
.article-cta .button {
  margin-top: 1.1rem;
}
.article-body .article-cta .button {
  color: #fffdf7;
  text-decoration: none;
}
.article-body .article-cta .button.invert {
  color: var(--ink);
}
.article-toc {
  position: sticky;
  top: 6rem;
  padding: 1.15rem;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(255,252,245,.55);
}
.article-toc h2 {
  margin: 0 0 .8rem;
  font-size: 1rem;
}
.article-toc ol {
  display: grid;
  gap: .65rem;
  padding-left: 1.1rem;
  margin: 0;
}
.article-toc li::marker {
  color: var(--muted);
  font-family: var(--mono);
  font-size: .75rem;
}
.article-toc a {
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.35;
}
.article-toc a:hover { color: var(--ink); }

/* IMAGE PLACEHOLDER */
.img-slot {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 14px;
  overflow: hidden;
  background: linear-gradient(135deg, var(--violet-deep), var(--ink));
  border: 1px solid var(--line);
  margin-top: 2rem;
}
.img-slot img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
}
.img-slot .ph {
  position: absolute; inset: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: .55rem;
  color: rgba(255,250,240,.6);
  font-family: var(--mono); font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  text-align: center;
  padding: 1rem;
}
.img-slot .ph strong { color: rgba(255,250,240,.9); display: block; }

.ai-seo-motion-slot {
  border-color: rgba(17,20,23,.22);
  background:
    radial-gradient(circle at 88% 20%, rgba(197,169,105,.22), transparent 18rem),
    radial-gradient(circle at 44% 54%, rgba(107,99,255,.22), transparent 20rem),
    #0d1015;
  box-shadow: 0 1.65rem 3.4rem rgba(17,20,23,.12);
}
.ai-search-map {
  position: absolute;
  inset: 0;
  overflow: hidden;
  background:
    radial-gradient(ellipse at 52% 52%, rgba(91,154,246,.16), transparent 31%),
    radial-gradient(ellipse at 83% 56%, rgba(197,169,105,.12), transparent 34%),
    linear-gradient(135deg, #0d1015 0%, #141720 56%, #221f1a 100%);
  isolation: isolate;
}
.ai-search-map::before,
.ai-search-map::after {
  content: "";
  position: absolute;
  pointer-events: none;
}
.ai-search-map::before {
  inset: 0;
  background:
    linear-gradient(rgba(255,250,240,.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,250,240,.035) 1px, transparent 1px);
  background-size: 4.2rem 4.2rem;
  mask-image: radial-gradient(ellipse at 50% 52%, #000 0%, transparent 72%);
}
.ai-search-map::after {
  inset: -12%;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  background-size: 220px 220px;
  opacity: .22;
  mix-blend-mode: overlay;
}
.ai-grid-glow {
  position: absolute;
  left: 36%;
  top: 12%;
  width: 28%;
  height: 76%;
  border-radius: 50%;
  background:
    repeating-radial-gradient(ellipse at center, rgba(255,250,240,.11) 0 1px, transparent 1px 7px),
    radial-gradient(ellipse at center, rgba(43,198,191,.26), rgba(107,99,255,.15) 45%, transparent 72%);
  filter: blur(.2px);
  opacity: .86;
  animation: aiMeshBreathe 7s var(--ease) infinite;
}
@keyframes aiMeshBreathe {
  0%, 100% { transform: scale(.96); opacity: .68; }
  50% { transform: scale(1.04); opacity: .94; }
}
.ai-query-orbit {
  position: absolute;
  left: 5.6%;
  top: 21%;
  width: 23%;
  height: 6.2%;
  border: 1px solid rgba(255,250,240,.2);
  border-radius: 999px;
  background: rgba(255,250,240,.025);
  box-shadow: inset 0 0 1.4rem rgba(255,250,240,.045);
}
.ai-query-orbit::before {
  content: "";
  position: absolute;
  left: 6%;
  top: 50%;
  width: 4.5%;
  aspect-ratio: 1;
  border: 1px solid rgba(255,250,240,.62);
  border-radius: 50%;
  transform: translateY(-50%);
}
.ai-query-orbit::after {
  content: "";
  position: absolute;
  left: 9.5%;
  top: 54%;
  width: 3.2%;
  height: 1px;
  background: rgba(255,250,240,.62);
  transform: rotate(45deg);
  transform-origin: left center;
}
.ai-query-orbit span {
  position: absolute;
  right: 4%;
  top: 50%;
  width: 8%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: #8b84ff;
  box-shadow: 0 0 0 .55rem rgba(107,99,255,.16), 0 0 2rem rgba(107,99,255,.9);
  transform: translateY(-50%);
  animation: aiQueryPulse 2.8s ease-in-out infinite;
}
@keyframes aiQueryPulse {
  0%, 100% { opacity: .72; transform: translateY(-50%) scale(.88); }
  50% { opacity: 1; transform: translateY(-50%) scale(1.06); }
}
.ai-source-grid {
  position: absolute;
  left: 5.8%;
  top: 32.5%;
  width: 22%;
  height: 38%;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 5.5%;
}
.ai-source-grid .tile {
  position: relative;
  border: 1px solid rgba(255,250,240,.2);
  border-radius: 7px;
  background: linear-gradient(180deg, rgba(255,250,240,.075), rgba(255,250,240,.025));
  box-shadow: inset 0 0 1.2rem rgba(255,250,240,.035);
  animation: aiTileSignal 5.4s ease-in-out infinite;
}
.ai-source-grid .tile::before,
.ai-source-grid .tile::after {
  content: "";
  position: absolute;
  left: 18%;
  right: 18%;
  height: 1px;
  background: rgba(255,250,240,.24);
}
.ai-source-grid .tile::before { bottom: 27%; }
.ai-source-grid .tile::after { bottom: 18%; right: 38%; }
.ai-source-grid .tile:nth-child(3n + 1) { animation-delay: -.8s; }
.ai-source-grid .tile:nth-child(3n + 2) { animation-delay: -1.7s; }
.ai-source-grid .tile:nth-child(3n) { animation-delay: -2.6s; }
.ai-source-grid .tile:nth-child(-n + 4) { --tile-signal: #8b84ff; }
.ai-source-grid .tile:nth-child(n + 5):nth-child(-n + 8) { --tile-signal: #e8cc8a; }
.ai-source-grid .tile:nth-child(n + 9) { --tile-signal: #5be0d6; }
.ai-source-grid .tile.t1::before,
.ai-source-grid .tile.t6::before,
.ai-source-grid .tile.t11::before {
  top: 23%;
  bottom: auto;
  height: 22%;
  border: 1px solid rgba(255,250,240,.24);
  border-bottom: 0;
  background: transparent;
}
@keyframes aiTileSignal {
  0%, 72%, 100% { border-color: rgba(255,250,240,.18); box-shadow: inset 0 0 1.2rem rgba(255,250,240,.035); }
  28%, 44% { border-color: color-mix(in srgb, var(--tile-signal), white 12%); box-shadow: 0 0 1rem color-mix(in srgb, var(--tile-signal), transparent 55%), inset 0 0 1.2rem rgba(255,250,240,.055); }
}
.ai-flow-map {
  position: absolute;
  inset: 0;
  z-index: 2;
  overflow: visible;
}
.flow {
  fill: none;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-dasharray: 12 22;
  animation: aiFlow 3.2s linear infinite;
  filter: drop-shadow(0 0 .45rem currentColor);
  opacity: .8;
}
.flow.faint {
  stroke-width: .8;
  stroke-dasharray: 4 18;
  opacity: .36;
  animation-duration: 4.8s;
}
.flow-violet { color: #8b84ff; stroke: currentColor; }
.flow-gold { color: #e8cc8a; stroke: currentColor; animation-delay: -.45s; }
.flow-teal { color: #5be0d6; stroke: currentColor; animation-delay: -.9s; }
@keyframes aiFlow {
  to { stroke-dashoffset: -68; }
}
.ai-hub {
  position: absolute;
  left: 40.4%;
  width: 2.3%;
  aspect-ratio: 1;
  z-index: 3;
  border-radius: 50%;
  background: currentColor;
  box-shadow:
    0 0 0 .55rem color-mix(in srgb, currentColor, transparent 72%),
    0 0 2.5rem currentColor;
  animation: aiHubBeat 2.6s ease-in-out infinite;
}
.hub-violet { top: 39%; color: #8b84ff; }
.hub-gold { top: 49%; color: #e8cc8a; animation-delay: -.75s; }
.hub-teal { top: 59%; color: #5be0d6; animation-delay: -1.4s; }
@keyframes aiHubBeat {
  0%, 100% { transform: scale(.92); opacity: .78; }
  50% { transform: scale(1.12); opacity: 1; }
}
.ai-card-stack {
  position: absolute;
  left: 53.8%;
  top: 17.8%;
  width: 21.4%;
  display: grid;
  gap: 7.5%;
  z-index: 4;
}
.answer-card {
  position: relative;
  min-height: 5.9rem;
  border: 1px solid rgba(255,250,240,.13);
  border-radius: 10px;
  background: rgba(255,250,240,.07);
  box-shadow: 0 1rem 2.2rem rgba(0,0,0,.24), inset 0 0 1rem rgba(255,250,240,.03);
  backdrop-filter: blur(14px);
  animation: aiCardRise 6s var(--ease) infinite;
}
.answer-card:nth-child(2) { animation-delay: -1.4s; }
.answer-card:nth-child(3) { animation-delay: -2.8s; }
@keyframes aiCardRise {
  0%, 100% { transform: translateY(.2rem); opacity: .78; }
  42%, 64% { transform: translateY(-.15rem); opacity: 1; }
}
.answer-card .thumb {
  position: absolute;
  left: 7%;
  top: 17%;
  width: 31%;
  height: 54%;
  border-radius: 5px;
  background:
    linear-gradient(135deg, rgba(255,250,240,.5), rgba(255,250,240,.1)),
    radial-gradient(circle at 75% 24%, rgba(255,250,240,.55), transparent 20%),
    linear-gradient(160deg, rgba(197,169,105,.55), rgba(91,154,246,.28));
  box-shadow: inset 0 0 0 1px rgba(255,250,240,.14);
}
.answer-card .bar {
  position: absolute;
  left: 44%;
  height: 3px;
  border-radius: 999px;
  background: currentColor;
  opacity: .48;
  box-shadow: 0 0 .8rem currentColor;
  animation: aiBarScan 2.8s ease-in-out infinite;
}
.answer-card .b1 { top: 24%; width: 38%; }
.answer-card .b2 { top: 40%; width: 29%; animation-delay: -.5s; }
.answer-card .b3 { top: 61%; width: 46%; animation-delay: -1s; }
.answer-card .signal {
  position: absolute;
  right: 8%;
  top: 50%;
  width: 4%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: currentColor;
  box-shadow: 0 0 1rem currentColor;
}
.card-violet { color: #8b84ff; }
.card-gold { color: #e8cc8a; }
.card-teal { color: #5be0d6; }
@keyframes aiBarScan {
  0%, 100% { transform: scaleX(.68); opacity: .25; transform-origin: left center; }
  45%, 62% { transform: scaleX(1); opacity: .72; transform-origin: left center; }
}
.ai-result-rail {
  position: absolute;
  right: 5.4%;
  top: 17.6%;
  width: 18%;
  height: 63%;
  z-index: 3;
  border: 1px solid rgba(255,250,240,.12);
  border-radius: 10px;
  background: rgba(255,250,240,.045);
  backdrop-filter: blur(14px);
  box-shadow: inset 0 0 1.6rem rgba(255,250,240,.025);
}
.ai-result-rail::before {
  content: "";
  position: absolute;
  left: 8%;
  right: 48%;
  top: 7%;
  height: 5%;
  border: 1px solid rgba(255,250,240,.2);
  border-radius: 999px;
}
.search-dot {
  position: absolute;
  left: 11%;
  top: 8.2%;
  width: 2%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255,250,240,.62);
  box-shadow: 0 0 .55rem rgba(255,250,240,.42);
}
.result-row {
  position: absolute;
  left: 8%;
  right: 8%;
  height: 13.5%;
  border-radius: 7px;
  background: rgba(255,250,240,.055);
  box-shadow: inset 0 0 0 1px rgba(255,250,240,.045);
  animation: aiResultFocus 8s ease-in-out infinite;
}
.result-row.r1 { top: 20%; --row-light: #8b84ff; animation-delay: 0s; }
.result-row.r2 { top: 37%; --row-light: #e8cc8a; animation-delay: -2s; }
.result-row.r3 { top: 54%; --row-light: #5be0d6; animation-delay: -4s; }
.result-row.r4 { top: 71%; --row-light: #e8cc8a; animation-delay: -6s; }
.mini-thumb {
  position: absolute;
  left: 6%;
  top: 18%;
  width: 22%;
  height: 64%;
  border-radius: 4px;
  background: linear-gradient(135deg, rgba(255,250,240,.5), rgba(197,169,105,.18));
}
.mini-line {
  position: absolute;
  left: 35%;
  height: 4%;
  border-radius: 999px;
  background: rgba(255,250,240,.23);
}
.mini-line.l1 { top: 28%; width: 48%; }
.mini-line.l2 { top: 52%; width: 35%; }
.rank-light {
  position: absolute;
  right: 7%;
  top: 43%;
  width: 4%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: var(--row-light);
  box-shadow: 0 0 1rem var(--row-light);
}
@keyframes aiResultFocus {
  0%, 65%, 100% { transform: translateX(0); background: rgba(255,250,240,.055); }
  18%, 34% { transform: translateX(-.3rem); background: color-mix(in srgb, var(--row-light), transparent 88%); }
}

@media (prefers-reduced-motion: reduce) {
  .ai-grid-glow,
  .ai-query-orbit span,
  .ai-source-grid .tile,
  .flow,
  .ai-hub,
  .answer-card,
  .answer-card .bar,
  .result-row {
    animation: none;
  }
}

/* STATS */
.stats {
  background: var(--ink); color: #fffaf0;
  position: relative; overflow: hidden;
}
.stats::before {
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(circle at 80% 50%, rgba(107,99,255,.25), transparent 22rem);
  pointer-events: none;
}
.stats .label { color: var(--violet-2); }
.stats h2 { color: #fffaf0; }
.stat-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 2rem; margin-top: 2.5rem;
  position: relative;
}
.stat { padding-right: 1.5rem; border-right: 1px solid rgba(255,250,240,.14); }
.stat:last-child { border-right: 0; }
.stat-num {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: .45rem;
  font-size: clamp(2.5rem, 5vw, 4.2rem);
  line-height: .95; letter-spacing: 0; font-weight: 740;
}
.stat-num .unit {
  display: inline-block;
  max-width: 10rem;
  font-size: clamp(.95rem, 1.45vw, 1.45rem);
  line-height: 1.05;
  letter-spacing: 0;
  font-weight: 700;
  color: rgba(255,250,240,.55);
}
.stat-label {
  margin-top: 1rem;
  font-family: var(--mono);
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,250,240,.66);
  max-width: 22ch; line-height: 1.45;
}

/* FAQ */
.faq { display: grid; gap: 0; border-top: 1px solid var(--line); margin-top: 2rem; }
.faq details {
  border-bottom: 1px solid var(--line);
  padding: 1.4rem 0;
  transition: background .35s, padding .35s;
}
.faq details[open] { background: rgba(107,99,255,.03); padding-left: 1rem; padding-right: 1rem; }
.faq summary {
  list-style: none;
  cursor: pointer;
  display: flex; justify-content: space-between; align-items: center;
  gap: 1rem;
  font-size: clamp(1.05rem, 1.4vw, 1.22rem);
  font-weight: 620;
  letter-spacing: -.015em;
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+";
  font-family: var(--mono);
  font-size: 1.4rem;
  color: var(--violet);
  line-height: 1;
  transition: transform .35s var(--ease-2);
}
.faq details[open] summary::after { transform: rotate(45deg); }
.faq p {
  margin: 1rem 0 0;
  max-width: 70ch;
  color: var(--muted);
  line-height: 1.6;
}

/* CTA */
.cta {
  background:
    radial-gradient(circle at 78% 30%, rgba(107,99,255,.26), transparent 18rem),
    var(--ink);
  color: #fffaf0;
}
.cta h2 { color: #fffaf0; max-width: 18ch; }
.cta .lede { color: rgba(255,250,240,.7); }
.cta-grid {
  display: grid; grid-template-columns: 1.1fr .9fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: end;
}
.cta-actions { display: flex; gap: .75rem; flex-wrap: wrap; margin-top: 2rem; }

/* RELATED */
.related-grid {
  display: grid; grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1rem; margin-top: 2.5rem;
}
.related-card {
  display: block;
  padding: 1.3rem 1.4rem 1.45rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 252, 245, .42);
  transition: transform .45s var(--ease-2), border-color .35s, box-shadow .45s;
}
.related-card:hover {
  transform: translateY(-4px);
  border-color: rgba(107,99,255,.35);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.06);
}
.related-card .num {
  font-family: var(--mono); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted); display: flex; justify-content: space-between;
}
.related-card .num .arr { color: var(--violet); }
.related-card h3 { margin: .85rem 0 .35rem; font-size: 1.2rem; }
.related-card p { margin: 0; color: var(--muted); font-size: .92rem; line-height: 1.5; }

/* FOOTER */
footer {
  background: var(--ink);
  color: rgba(255,250,240,.6);
  padding: 3.5rem clamp(1rem, 3vw, 2.25rem) 2rem;
  border-top: 1px solid rgba(255,250,240,.08);
}
.ft-nav-top {
  max-width: 86rem;
  margin: 0 auto 2.5rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(255,250,240,.1);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1.5rem;
  flex-wrap: wrap;
}
.ft-nav-top h3 {
  margin: 0;
  color: #fffaf0;
  font-size: clamp(1.4rem, 2.2vw, 1.85rem);
  letter-spacing: -.025em;
  font-weight: 720;
  max-width: 28ch;
}
.ft-nav-top-actions { display: flex; gap: .65rem; flex-wrap: wrap; }
.ft-nav-top .button { background: #fffaf0; color: var(--ink); border-color: #fffaf0; }
.ft-nav-top .button.ghost { background: transparent; color: #fffaf0; border-color: rgba(255,250,240,.4); }
@media (max-width: 640px) {
  .ft-nav-top { flex-direction: column; align-items: flex-start; }
}
footer .ft-grid {
  display: grid; grid-template-columns: 1.4fr repeat(3, minmax(0, 1fr));
  gap: 2rem;
  max-width: 86rem; margin: 0 auto;
}
footer h4 {
  margin: 0 0 1rem;
  font-family: var(--mono);
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: #fffaf0;
  font-weight: 700;
}
footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: .55rem; }
footer ul a {
  font-family: var(--mono);
  font-size: .68rem; letter-spacing: .1em; text-transform: uppercase;
  color: rgba(255,250,240,.55);
  transition: color .25s;
}
footer ul a:hover { color: #fffaf0; }
footer .ft-grid p {
  color: rgba(255,250,240,.55);
  max-width: 28ch;
  margin: 0;
  font-family: var(--mono);
  font-size: .68rem; letter-spacing: .1em; text-transform: uppercase;
  line-height: 1.5;
}
footer .ft-bottom {
  max-width: 86rem; margin: 2.5rem auto 0;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,250,240,.08);
  display: flex; justify-content: space-between; gap: 1rem;
  font-family: var(--mono);
  font-size: .65rem; letter-spacing: .12em; text-transform: uppercase;
}

/* ===================================================================
   EDITORIAL / TRADE PAGE STYLES — newsletter-style long-form pages
   =================================================================== */

/* Full-bleed image hero */
.hero-full {
  position: relative;
  min-height: clamp(34rem, 65vh, 48rem);
  display: flex;
  align-items: flex-end;
  overflow: hidden;
  border-bottom: 1px solid var(--line);
  isolation: isolate;
}
.hero-full .bg {
  position: absolute; inset: 0;
  overflow: hidden;
  background: linear-gradient(135deg, var(--violet-deep), var(--ink));
}
.hero-full .bg img,
.hero-full .bg video {
  width: 100%; height: 100%; object-fit: cover;
  opacity: .55;
  display: block;
}
.trade-hero-reel {
  position: absolute;
  inset: 0;
}
.hero-full .trade-hero-reel video {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 900ms ease;
}
.hero-full .trade-hero-reel video.is-active {
  opacity: .55;
}
.hero-full .bg::after {
  content: ""; position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(14,17,21,.15) 0%, rgba(14,17,21,.5) 55%, rgba(14,17,21,.92) 100%),
    radial-gradient(ellipse at 80% 20%, rgba(107,99,255,.18), transparent 60%);
  pointer-events: none;
}
.hero-full .blob {
  position: absolute; border-radius: 50%; filter: blur(80px);
  opacity: .55;
  animation: blobFloat 20s ease-in-out infinite;
  pointer-events: none;
}
.hero-full .grain-overlay {
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  background-size: 220px 220px;
  opacity: .25;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.hero-full-content {
  position: relative; z-index: 2;
  color: #fffaf0;
  width: 100%;
  padding-top: clamp(4rem, 10vw, 8rem);
  padding-bottom: clamp(3rem, 6vw, 5rem);
  padding-left: clamp(1.5rem, 5vw, 4.5rem);
  padding-right: clamp(1.5rem, 5vw, 4.5rem);
}
.hero-full .label { color: var(--violet-2); }
.hero-full .crumb { color: rgba(255,250,240,.55); }
.hero-full .crumb a:hover { color: #fffaf0; }
.hero-full h1 {
  color: #fffaf0;
  max-width: 24ch;
  font-size: clamp(2.6rem, 6.5vw, 5.6rem);
}
.hero-full .lede {
  color: rgba(255,250,240,.8);
  max-width: 56ch;
}

/* Article reading column */
.article {
  max-width: 50rem;
  margin: 0 auto;
  padding: clamp(3.5rem, 7vw, 6rem) 0;
}
.article p {
  margin: 0 0 1.4em;
  font-size: clamp(1.1rem, 1.4vw, 1.22rem);
  line-height: 1.7;
  color: var(--ink);
}
.article p:last-child { margin-bottom: 0; }
.article h2 {
  margin: 2.5rem 0 1.1rem;
  font-size: clamp(1.55rem, 2.6vw, 2.2rem);
  max-width: none;
}
.article h3 {
  margin: 2rem 0 .8rem;
  font-size: clamp(1.15rem, 1.8vw, 1.45rem);
}
.article strong { color: var(--violet); font-weight: 620; }
.article a { color: var(--violet); border-bottom: 1px solid rgba(107,99,255,.35); transition: border-color .25s; }
.article a:hover { border-bottom-color: var(--violet); }
.article ul, .article ol {
  margin: 0 0 1.4em;
  padding-left: 1.2rem;
  font-size: clamp(1.05rem, 1.35vw, 1.18rem);
  line-height: 1.65;
}
.article li { margin: 0 0 .55em; }

/* Embedded images */
.article-image {
  margin: clamp(2rem, 4vw, 3rem) 0;
  border: 1px solid rgba(17,20,23,.22);
  border-radius: 14px;
  overflow: hidden;
  position: relative;
  aspect-ratio: 16 / 9;
  background: rgba(255, 252, 245, .42);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.045);
  isolation: isolate;
}
.article-image .blob {
  position: absolute; border-radius: 50%; filter: blur(70px);
  opacity: .65; pointer-events: none;
  animation: blobFloat 20s ease-in-out infinite;
}
.article-image .ph {
  position: absolute; inset: 0; z-index: 2;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: .55rem;
  color: rgba(255,250,240,.65);
  font-family: var(--mono); font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
  text-align: center; padding: 1.5rem;
}
.article-image .ph strong { color: rgba(255,250,240,.95); display: block; }
.article-image .ph .desc { max-width: 36ch; line-height: 1.5; color: rgba(255,250,240,.5); text-transform: none; letter-spacing: .04em; font-size: .7rem; }
.article-image .grain-overlay {
  position: absolute; inset: 1px; z-index: 1;
  border-radius: 13px;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 220 220' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.5'/%3E%3C/svg%3E");
  background-size: 220px 220px;
  opacity: .3;
  mix-blend-mode: overlay;
  pointer-events: none;
}
.article-image img {
  width: 100%; height: 100%; object-fit: cover;
  display: block;
  position: relative; z-index: 0;
}
.article-image figcaption {
  position: absolute; bottom: 1rem; left: 1rem; z-index: 3;
  padding: .35rem .65rem;
  background: rgba(14,17,21,.65);
  border-radius: 999px;
  backdrop-filter: blur(8px);
  font-family: var(--mono); font-size: .6rem; letter-spacing: .14em; text-transform: uppercase;
  color: rgba(255,250,240,.85);
}

.brand-mockups {
  display: grid;
  grid-template-columns: 1fr;
  width: min(72rem, calc(100vw - clamp(2rem, 8vw, 8rem)));
  gap: clamp(1rem, 2vw, 1.35rem);
  margin: clamp(2.25rem, 4.5vw, 3.5rem) 0;
  margin-left: 50%;
  transform: translateX(-50%);
}
.brand-mockup {
  position: relative;
  overflow: hidden;
  min-height: 0;
  margin: 0;
  aspect-ratio: 16 / 8.4;
  border: 1px solid rgba(20, 22, 26, .12);
  border-radius: 14px;
  background: var(--ink);
  box-shadow: 0 26px 70px rgba(14, 17, 21, .16);
  isolation: isolate;
}
.brand-mockup img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media (max-width: 760px) {
  .brand-mockups {
    width: 100%;
    margin-left: 0;
    transform: none;
  }
  .brand-mockup {
    aspect-ratio: 4 / 3;
  }
}

/* Pull quote */
.pull-quote {
  margin: clamp(2.5rem, 5vw, 4rem) 0;
  padding: clamp(1.5rem, 3vw, 2.5rem);
  border-left: 3px solid var(--violet);
  background:
    radial-gradient(circle at 100% 0%, rgba(107,99,255,.07), transparent 60%),
    rgba(255, 252, 245, .55);
  border-radius: 0 14px 14px 0;
}
.pull-quote p {
  margin: 0;
  font-size: clamp(1.3rem, 2.2vw, 1.85rem);
  line-height: 1.34;
  font-weight: 620;
  letter-spacing: -.02em;
  color: var(--ink);
}
.pull-quote cite {
  display: block;
  margin-top: 1rem;
  font-style: normal;
  font-family: var(--mono);
  font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted);
}

/* Growth chart */
.growth-section {
  padding: clamp(3.5rem, 7vw, 5.5rem) 0;
}
.growth-panel {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
  gap: clamp(1.5rem, 4vw, 3rem);
  align-items: center;
  padding: clamp(1.4rem, 3.5vw, 2.4rem);
  border: 1px solid var(--line);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(107,99,255,.09), transparent 58%),
    rgba(255, 252, 245, .48);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.04);
}
.growth-copy h2 { margin-bottom: 1rem; }
.growth-copy .lede { margin-top: 0; }
.growth-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .75rem;
  margin-top: 1.5rem;
}
.growth-metric {
  min-height: 6.1rem;
  padding: .95rem;
  border: 1px solid rgba(17,20,23,.08);
  border-radius: 10px;
  background: rgba(255,250,240,.5);
}
.growth-metric strong {
  display: block;
  font-size: clamp(1.25rem, 2.2vw, 1.75rem);
  line-height: 1;
  letter-spacing: -.03em;
  color: var(--violet);
}
.growth-metric span {
  display: block;
  margin-top: .55rem;
  font-family: var(--mono);
  font-size: .58rem;
  line-height: 1.35;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}
.growth-chart {
  position: relative;
  min-height: clamp(18rem, 32vw, 25rem);
  padding: clamp(1rem, 2.5vw, 1.5rem);
  border: 1px solid rgba(17,20,23,.18);
  border-radius: 14px;
  background:
    linear-gradient(180deg, rgba(255,250,240,.68), rgba(255,250,240,.34)),
    radial-gradient(circle at 18% 20%, rgba(197,169,105,.18), transparent 34%);
  overflow: hidden;
}
.growth-chart svg {
  width: 100%;
  height: 100%;
  min-height: 15rem;
  display: block;
}
.growth-gridline {
  stroke: rgba(17,20,23,.1);
  stroke-width: 1;
}
.growth-area { fill: rgba(107,99,255,.12); }
.growth-path {
  fill: none;
  stroke: var(--violet);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.growth-point {
  fill: #fffaf0;
  stroke: var(--violet);
  stroke-width: 3;
}
.growth-axis {
  display: flex;
  justify-content: space-between;
  gap: .75rem;
  margin-top: .65rem;
  font-family: var(--mono);
  font-size: .6rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}
.growth-legend {
  position: absolute;
  top: 1rem;
  right: 1rem;
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .4rem .55rem;
  border: 1px solid rgba(17,20,23,.08);
  border-radius: 999px;
  background: rgba(255,250,240,.72);
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}
.growth-legend::before {
  content: "";
  width: .48rem;
  height: .48rem;
  border-radius: 50%;
  background: var(--violet);
  box-shadow: 0 0 0 .25rem rgba(107,99,255,.14);
}

/* About page */
.about-hero {
  min-height: calc(100vh - 4.25rem);
  display: grid;
  align-items: center;
  padding: clamp(5rem, 9vw, 8rem) 0;
  background:
    radial-gradient(circle at 85% 10%, rgba(107,99,255,.16), transparent 30rem),
    radial-gradient(circle at 18% 78%, rgba(197,169,105,.2), transparent 24rem),
    linear-gradient(180deg, rgba(255,250,240,.74), rgba(255,250,240,.36));
}
.about-kicker {
  display: inline-flex;
  align-items: center;
  gap: .65rem;
  margin-bottom: 1.35rem;
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--violet);
  font-weight: 700;
}
.about-kicker::before {
  content: "";
  width: 2.7rem;
  height: 1px;
  background: var(--violet);
}
.about-hero h1 {
  max-width: 14ch;
}
.about-subhead {
  max-width: 64rem;
  margin: clamp(1.5rem, 3vw, 2.4rem) 0 0;
  font-size: clamp(1.35rem, 2.55vw, 2.35rem);
  line-height: 1.23;
  letter-spacing: -.035em;
  color: var(--ink);
}
.about-subhead strong {
  color: var(--violet);
}
.about-proof {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: .9rem;
  margin-top: clamp(2rem, 4vw, 3rem);
  max-width: 58rem;
}
.about-proof-card {
  padding: 1.15rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 252, 245, .52);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.04);
}
.about-proof-card strong {
  display: block;
  margin-bottom: .45rem;
  font-size: clamp(1.4rem, 2.5vw, 2rem);
  line-height: 1;
  letter-spacing: -.035em;
  color: var(--violet);
}
.about-proof-card span {
  display: block;
  font-family: var(--mono);
  font-size: .62rem;
  line-height: 1.45;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--muted);
}
.about-letter {
  padding: clamp(3.5rem, 7vw, 6rem) 0;
}
.about-letter-panel {
  max-width: 70rem;
  margin: 0 auto;
  padding: clamp(1.6rem, 4vw, 3rem);
  border: 1px solid rgba(17,20,23,.14);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(107,99,255,.08), transparent 58%),
    rgba(255, 252, 245, .54);
  box-shadow: 0 1.4rem 3rem rgba(17,20,23,.05);
}
.about-letter-panel p {
  margin: 0;
  font-size: clamp(1.18rem, 1.75vw, 1.55rem);
  line-height: 1.55;
  letter-spacing: -.015em;
}
.about-letter-panel p + p {
  margin-top: 1.35rem;
}
.about-split {
  display: grid;
  grid-template-columns: minmax(0, .8fr) minmax(0, 1.2fr);
  gap: clamp(1.8rem, 5vw, 4rem);
  align-items: start;
}
.about-list {
  display: grid;
  gap: .9rem;
}
.about-list-item {
  padding: 1.1rem 1.2rem;
  border-top: 1px solid var(--line);
}
.about-list-item h3 {
  margin-bottom: .35rem;
}
.about-list-item p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}
/* Inline stat cluster */
.inline-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin: clamp(2.5rem, 5vw, 3.5rem) 0;
  padding: clamp(1.5rem, 3vw, 2rem);
  border: 1px solid var(--line);
  border-radius: 14px;
  background:
    radial-gradient(circle at 100% 0%, rgba(107,99,255,.08), transparent 60%),
    rgba(255, 252, 245, .42);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.035);
}
.inline-stats .istat {
  text-align: left;
}
.inline-stats .istat-num {
  font-size: clamp(1.6rem, 2.6vw, 2.1rem);
  font-weight: 740;
  letter-spacing: -.03em;
  line-height: 1;
  color: var(--violet);
}
.inline-stats .istat-label {
  margin-top: .55rem;
  font-family: var(--mono); font-size: .62rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--muted);
  line-height: 1.4;
}

/* Trade grid for related */
.trade-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1rem; margin-top: 2.5rem;
}
.trade-card {
  display: block;
  padding: 1.4rem;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 252, 245, .42);
  transition: transform .45s var(--ease-2), border-color .35s, box-shadow .45s;
  box-shadow: 0 .75rem 1.8rem rgba(17,20,23,.03);
}
.trade-card:hover {
  transform: translateY(-4px);
  border-color: rgba(107,99,255,.35);
  box-shadow: 0 1.25rem 2.5rem rgba(17,20,23,.06);
}
.trade-card .pill {
  display: inline-block;
  padding: .2rem .5rem;
  background: rgba(107,99,255,.12);
  color: var(--violet);
  font-family: var(--mono); font-size: .55rem; letter-spacing: .14em; text-transform: uppercase;
  font-weight: 700; border-radius: 4px;
  margin-bottom: .55rem;
}
.trade-card h3 { font-size: 1.05rem; margin: 0 0 .25rem; }
.trade-card p { font-size: .85rem; color: var(--muted); margin: 0; line-height: 1.5; }

@media (max-width: 980px) {
  .growth-panel { grid-template-columns: 1fr; }
  .about-proof, .about-split { grid-template-columns: 1fr; }
  .trade-grid { grid-template-columns: repeat(2, 1fr); }
  .inline-stats { grid-template-columns: 1fr; gap: 1.2rem; }
}
@media (max-width: 640px) {
  .nav { gap: .55rem; }
  .mobile-nav summary { width: 2.25rem; height: 2.25rem; }
  .mobile-nav[open] summary { top: .9rem; right: .9rem; }
  .mobile-nav-panel { left: 3rem; padding-inline: .85rem; }
  .nav-actions { gap: .35rem; }
  .nav-actions .button { padding: .65rem .8rem; font-size: .58rem; }
  .growth-metrics { grid-template-columns: 1fr; }
  .growth-chart { min-height: 16rem; }
  .about-proof { grid-template-columns: 1fr; }
  .trade-grid { grid-template-columns: 1fr; }
}


/* Mobile scroll performance and readability */
@media (max-width: 760px) {
  html { scroll-behavior: auto; }
  body { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }
  body::before { display: none; }
  .nav,
  .nav-menu,
  .mobile-nav[open]::before,
  .article-image .caption {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .nav { background: rgba(246, 240, 228, .97); }
  .mobile-nav[open]::before { background: rgba(14,17,21,.24); }
  .mobile-nav-panel {
    box-shadow: -.65rem 0 1.8rem rgba(17,20,23,.18);
    contain: layout paint;
  }
  main > section:not(:first-child),
  footer {
    content-visibility: auto;
    contain-intrinsic-size: 760px;
  }
  .hero-vis .blob,
  .hero-full .blob,
  .article-image .blob {
    filter: none;
    animation: none;
    opacity: .32;
  }
  .hero-vis .ring,
  .hero-vis .core,
  .ai-query-node,
  .answer-card,
  .result-row,
  .flow-line,
  .hub-orbit,
  .growth-line::after {
    animation: none;
  }
  .answer-card,
  .ai-answer-panel,
  .ai-citation-stack,
  .article-image .caption {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .button:hover,
  .card:hover,
  .related-card:hover,
  .trade-card:hover {
    transform: none;
  }
  .label,
  .eyebrow,
  .article-kicker,
  .mobile-nav-group h3 {
    font-size: .7rem;
  }
  .mobile-nav a {
    min-height: 3.8rem;
    font-size: .78rem;
    line-height: 1.25;
  }
  .container {
    padding-inline: clamp(1.12rem, 5vw, 1.4rem);
  }
  section {
    padding: 3.4rem 0;
  }
  .hero,
  .hero-full {
    min-height: auto;
  }
  .hero-grid,
  .two-col,
  .cta-grid {
    gap: 2rem;
  }
  .display,
  .hero-full h1 {
    font-size: clamp(2.45rem, 11vw, 3.55rem);
    line-height: 1.04;
    letter-spacing: 0;
  }
  .section-title,
  .article h2,
  .article-body h2,
  .about-split h2,
  .growth-copy h2 {
    font-size: clamp(1.65rem, 7vw, 2.15rem);
    line-height: 1.14;
    letter-spacing: 0;
  }
  .lede,
  .article p,
  .article li,
  .article-body p,
  .article-body li,
  .about-letter p,
  .about-list-item p,
  .copy p,
  .card p,
  .related-card p,
  .trade-card p,
  .step p,
  .growth-copy p,
  .pull-quote cite {
    max-width: 35ch;
    font-size: 1.08rem;
    line-height: 1.68;
    color: #4d4840;
  }
  .hero-full .lede {
    max-width: 32ch;
    font-size: 1.08rem;
    line-height: 1.62;
  }
  .card p,
  .related-card p,
  .trade-card p,
  .step p {
    font-size: 1.02rem;
    line-height: 1.58;
  }
  .article-body p,
  .article-body li {
    margin-bottom: 1.05em;
  }
  .article-callout,
  .article-cta,
  .card,
  .related-card,
  .trade-card {
    padding: 1.15rem;
  }
  .article h2,
  .about-split h2,
  .growth-copy h2 {
    line-height: 1.08;
  }
}


/* Mobile-safe motion: transform/opacity only */
@media (max-width: 760px) {
  .hero-vis .blob,
  .hero-full .blob,
  .article-image .blob {
    will-change: transform;
    animation: mobileSoftDrift 16s ease-in-out infinite;
  }
  .hero-vis .b2,
  .hero-full .b2,
  .article-image .b2 { animation-delay: -5s; }
  .hero-vis .b3,
  .hero-full .b3,
  .article-image .b3 { animation-delay: -10s; }
  .hero-vis .ring,
  .hero-vis .core,
  .ai-query-node,
  .answer-card,
  .result-row,
  .flow-line,
  .hub-orbit,
  .growth-line::after {
    will-change: transform, opacity;
    animation: mobileFloat 7s ease-in-out infinite;
  }
  .answer-card:nth-child(2),
  .result-row:nth-child(2n) { animation-delay: -2.5s; }
  .answer-card:nth-child(3),
  .result-row:nth-child(3n) { animation-delay: -5s; }
}
@keyframes mobileFloat {
  0%, 100% { transform: translate3d(0, 0, 0); }
  50% { transform: translate3d(0, -7px, 0); }
}
@keyframes mobileSoftDrift {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50% { transform: translate3d(10px, -8px, 0) scale(1.03); }
}

/* RESPONSIVE */
@media (max-width: 980px) {
  .nav { grid-template-columns: 1fr auto auto; }
  .mobile-nav { display: block; }
  .nav-actions .why-button { display: none; }
  .nav-links { display: none; }
  .nav-menu { display: none; }
  .hero-grid, .two-col, .cta-grid { grid-template-columns: 1fr; }
  .card-grid, .related-grid, .blog-grid { grid-template-columns: repeat(2, 1fr); }
  .article-layout { grid-template-columns: 1fr; }
  .article-toc { position: static; }
  .stat-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; }
  .stat:nth-child(2) { border-right: 0; }
  footer .ft-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .card-grid, .related-grid, .blog-grid, .stat-grid { grid-template-columns: 1fr; }
  .growth-metrics { grid-template-columns: 1fr; }
  .growth-chart { min-height: 16rem; }
  .stat { border-right: 0; padding-right: 0; }
  footer .ft-grid { grid-template-columns: 1fr; }
  footer .ft-bottom { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 360px) {
  .nav {
    gap: .45rem;
    padding-inline: .75rem;
  }
  .brand {
    gap: .45rem;
    font-size: 1.12rem;
    white-space: nowrap;
  }
  .brand-mark { width: 1.7rem; }
  .mobile-nav-panel {
    left: 2.4rem;
    padding-inline: .72rem;
  }
  .nav-actions .button {
    padding-inline: .68rem;
    font-size: .52rem;
    letter-spacing: .08em;
  }
}
