:root {
  --navy: #0a1733;
  --navy-2: #112347;
  --navy-3: #1a2f5c;
  --ink: #0b1020;
  --cyan: #06b6d4;
  --cyan-2: #22d3ee;
  --cyan-soft: #cffafe;
  --cyan-bg: #ecfeff;
  --yellow: #facc15;
  --yellow-soft: #fef9c3;
  --paper: #ffffff;
  --paper-2: #f6f8fb;
  --paper-3: #eef2f7;
  --line: #e6ebf2;
  --line-2: #d8e0ec;
  --muted: #5b6680;
  --muted-2: #8b94a8;
  --shadow-sm: 0 1px 2px rgba(10,23,51,.06), 0 1px 1px rgba(10,23,51,.04);
  --shadow-md: 0 8px 24px -8px rgba(10,23,51,.12), 0 2px 6px rgba(10,23,51,.06);
  --shadow-lg: 0 30px 80px -20px rgba(10,23,51,.28), 0 10px 30px -10px rgba(10,23,51,.18);
  --r-sm: 8px;
  --r-md: 12px;
  --r-lg: 18px;
  --r-xl: 28px;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 16px;
  color: var(--ink);
  background: var(--paper);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  line-height: 1.5;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; border: 0; background: none; }

.serif { font-family: 'Instrument Serif', Georgia, serif; font-style: italic; font-weight: 400; letter-spacing: -.01em; }
.mono { font-family: 'JetBrains Mono', ui-monospace, monospace; }

.container { max-width: 1240px; margin: 0 auto; padding: 0 28px; }
.container-narrow { max-width: 980px; margin: 0 auto; padding: 0 28px; }

/* ============ NAV ============ */
.nav {
  position: sticky; top: 0; z-index: 50;
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  background: rgba(255,255,255,.72);
  border-bottom: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; justify-content: space-between; height: 64px; }
.brand { display: flex; align-items: center; gap: 10px; font-weight: 700; letter-spacing: -.01em; font-size: 16px; }
.brand-mark {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--navy); color: #fff;
  display: grid; place-items: center;
  position: relative;
  box-shadow: 0 0 0 1px rgba(10,23,51,.08), 0 6px 14px -6px rgba(6,182,212,.45);
}
.brand-mark::after {
  content: ""; position: absolute; right: -3px; bottom: -3px;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--yellow);
  box-shadow: 0 0 0 2px #fff;
}
.brand-name { font-weight: 700; }
.brand-name em { font-weight: 500; color: var(--muted); font-style: normal; margin-left: 2px; }

.nav-links { display: flex; align-items: center; gap: 28px; }
.nav-links a { font-size: 14px; color: var(--ink); font-weight: 500; opacity: .82; }
.nav-links a:hover { opacity: 1; color: var(--cyan); }
.nav-cta { display: flex; align-items: center; gap: 10px; }

/* ============ BUTTONS ============ */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  font-weight: 600; font-size: 14px;
  padding: 10px 16px; border-radius: 10px;
  transition: transform .12s ease, background .15s ease, box-shadow .15s ease;
  white-space: nowrap;
}
.btn:active { transform: translateY(1px); }
.btn-primary {
  background: var(--navy); color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 1px 2px rgba(10,23,51,.2), 0 8px 18px -10px rgba(6,182,212,.5);
}
.btn-primary:hover { background: #050e23; box-shadow: inset 0 1px 0 rgba(255,255,255,.14), 0 1px 2px rgba(10,23,51,.2), 0 14px 28px -12px rgba(6,182,212,.6); }
.btn-yellow {
  background: var(--yellow); color: var(--navy);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 1px 2px rgba(250,204,21,.4), 0 8px 18px -10px rgba(250,204,21,.5);
}
.btn-yellow:hover { background: #ffd83a; }
.btn-ghost { color: var(--ink); padding: 10px 14px; }
.btn-ghost:hover { background: var(--paper-2); border-radius: 10px; }
.btn-outline {
  background: #fff; color: var(--ink);
  border: 1px solid var(--line-2);
}
.btn-outline:hover { background: var(--paper-2); }
.btn-lg { padding: 13px 22px; font-size: 15px; border-radius: 12px; }
.btn-block { width: 100%; justify-content: center; }

/* ============ HERO ============ */
.hero { position: relative; overflow: hidden; padding: 80px 0 40px; }
.hero-bg-grid {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 80% 60% at 50% -10%, rgba(6,182,212,.18), transparent 60%),
    radial-gradient(ellipse 60% 40% at 90% 10%, rgba(250,204,21,.18), transparent 60%),
    linear-gradient(180deg, #f6fbfd, #fff 70%);
}
.hero-bg-grid::after {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(to right, rgba(10,23,51,.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(10,23,51,.05) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse 90% 70% at 50% 40%, #000 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse 90% 70% at 50% 40%, #000 30%, transparent 75%);
}
.hero-inner { position: relative; display: grid; grid-template-columns: 1.05fr 1fr; gap: 56px; align-items: center; }

.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px;
  background: #fff; border: 1px solid var(--line-2);
  border-radius: 999px; font-size: 13px; color: var(--ink);
  box-shadow: var(--shadow-sm);
}
.eyebrow-dot {
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--cyan); display: grid; place-items: center; color: #fff;
  font-size: 10px; font-weight: 800;
}
.eyebrow .arrow { color: var(--muted); margin-left: 4px; }

h1.headline {
  font-family: 'Inter', sans-serif;
  font-size: clamp(40px, 5.4vw, 68px);
  line-height: 1.02; letter-spacing: -0.035em;
  font-weight: 700;
  margin: 22px 0 18px;
  color: var(--navy);
  text-wrap: balance;
}
h1.headline .serif {
  display: inline-block;
  color: var(--cyan);
  letter-spacing: -.01em;
  font-size: 1.04em;
}
h1.headline .underline-y {
  background-image: linear-gradient(transparent 62%, var(--yellow) 62%);
  background-repeat: no-repeat;
  padding: 0 .04em;
}

.subhead {
  font-size: 18px; line-height: 1.55;
  color: var(--muted); max-width: 540px;
  text-wrap: pretty;
}
.hero-ctas { display: flex; gap: 12px; margin-top: 28px; flex-wrap: wrap; }
.hero-trust {
  margin-top: 28px; display: flex; align-items: center; gap: 18px;
  color: var(--muted); font-size: 13px;
}
.avatars { display: flex; }
.avatars span {
  width: 30px; height: 30px; border-radius: 50%;
  border: 2px solid #fff; margin-left: -8px;
  background: linear-gradient(135deg, var(--cyan), var(--navy));
  display: grid; place-items: center; color: #fff; font-size: 11px; font-weight: 700;
}
.avatars span:first-child { margin-left: 0; }
.stars { color: var(--yellow); letter-spacing: 1px; }

/* hero card */
.hero-card-stack { position: relative; }
.hero-card {
  position: relative;
  background: #fff;
  border-radius: var(--r-xl);
  border: 1px solid var(--line);
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.hc-bar {
  display: flex; align-items: center; gap: 8px;
  padding: 12px 14px;
  background: linear-gradient(180deg, #fafcff, #f3f6fb);
  border-bottom: 1px solid var(--line);
}
.hc-dots { display: flex; gap: 6px; }
.hc-dots span { width: 10px; height: 10px; border-radius: 50%; background: #d6dde8; }
.hc-dots span:nth-child(1) { background: #fc7066; }
.hc-dots span:nth-child(2) { background: #fdbe40; }
.hc-dots span:nth-child(3) { background: #38c75a; }
.hc-url {
  flex: 1; background: #fff; border: 1px solid var(--line);
  border-radius: 8px; padding: 5px 12px; font-size: 12px; color: var(--muted);
  font-family: 'JetBrains Mono', monospace;
  display: flex; align-items: center; gap: 8px;
}
.hc-url .lock { color: #38c75a; }
.hc-body { padding: 22px; }

.hero-listing {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
.listing {
  border: 1px solid var(--line); border-radius: 14px;
  padding: 12px; background: #fff;
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
}
.listing-img {
  height: 78px; border-radius: 10px;
  background:
    repeating-linear-gradient(45deg, #e6f6f9 0 6px, #d5eef3 6px 12px);
  position: relative; overflow: hidden;
}
.listing-img::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(10,23,51,.18));
}
.listing-img.alt {
  background: repeating-linear-gradient(45deg, #fff7c2 0 6px, #fce98a 6px 12px);
}
.listing-img.alt2 {
  background: repeating-linear-gradient(45deg, #e3eaf6 0 6px, #cad6ea 6px 12px);
}
.listing-img.alt3 {
  background: repeating-linear-gradient(45deg, #c6f2f9 0 6px, #9be0ee 6px 12px);
}
.listing-row { display: flex; align-items: center; justify-content: space-between; }
.listing-name { font-weight: 600; font-size: 13px; color: var(--navy); }
.listing-cat { font-size: 11px; color: var(--muted); }
.listing-rating { display: flex; align-items: center; gap: 4px; font-size: 11px; color: var(--navy); font-weight: 600; }
.listing-rating .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--muted); }
.tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 7px; font-size: 10px; font-weight: 600;
  border-radius: 999px; background: var(--cyan-bg); color: #0e7490;
  border: 1px solid var(--cyan-soft);
}
.tag.gold { background: var(--yellow-soft); color: #854d0e; border-color: #fde68a; }

.ai-pill {
  position: absolute; top: 10px; left: 10px;
  display: inline-flex; align-items: center; gap: 5px;
  padding: 4px 9px;
  background: var(--navy); color: #fff;
  font-size: 10px; font-weight: 600; letter-spacing: .02em;
  border-radius: 999px;
  box-shadow: 0 6px 14px -6px rgba(10,23,51,.4);
  z-index: 2;
}
.ai-pill .spark { color: var(--yellow); }

/* floating cards over hero */
.float {
  position: absolute;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px 14px;
  box-shadow: var(--shadow-md);
  font-size: 12px;
  display: flex; align-items: center; gap: 10px;
  animation: floaty 6s ease-in-out infinite;
}
.float-1 { top: 30px; left: -20px; }
.float-2 { bottom: 36px; right: -20px; animation-delay: -2s; }
.float-3 { top: 46%; left: -36px; animation-delay: -4s; }

@media (max-width: 1180px) {
  .float-1, .float-3 { left: 0; }
  .float-2 { right: 0; }
}
.float .icon {
  width: 32px; height: 32px; border-radius: 9px;
  background: var(--cyan-bg); color: var(--cyan);
  display: grid; place-items: center; flex-shrink: 0;
}
.float .icon.navy { background: var(--navy); color: #fff; }
.float .icon.yellow { background: var(--yellow-soft); color: #854d0e; }
.float strong { display: block; color: var(--navy); font-weight: 600; font-size: 12px; margin-bottom: 2px; }
.float span.sub { color: var(--muted); font-size: 11px; }

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

/* trust strip */
.trust-strip {
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background: var(--paper-2);
  padding: 26px 0;
}
.trust-strip-inner {
  display: flex; align-items: center; justify-content: space-between; gap: 24px;
  flex-wrap: wrap;
}
.trust-label { font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .08em; font-weight: 600; }
.logo-row { display: flex; align-items: center; gap: 40px; flex-wrap: wrap; opacity: .8; }
.fake-logo {
  font-weight: 700; color: var(--navy); opacity: .55;
  font-size: 16px; letter-spacing: -.01em;
  display: flex; align-items: center; gap: 6px;
}
.fake-logo .glyph {
  width: 18px; height: 18px; border-radius: 4px; background: var(--navy); opacity: .6;
}
.fake-logo .glyph.circ { border-radius: 50%; }
.fake-logo .glyph.tri { background: transparent; width: 0; height: 0; border-left: 9px solid transparent; border-right: 9px solid transparent; border-bottom: 16px solid var(--navy); opacity: .6; border-radius: 0; }

/* ============ SECTION SHELLS ============ */
section { padding: 100px 0; }
section.tight { padding: 80px 0; }
.section-head { text-align: center; max-width: 760px; margin: 0 auto 56px; }
.kicker {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--cyan); padding: 6px 12px; border-radius: 999px;
  background: var(--cyan-bg); border: 1px solid var(--cyan-soft);
}
h2.section-title {
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700; letter-spacing: -.03em; line-height: 1.05;
  margin: 18px 0 14px;
  color: var(--navy);
  text-wrap: balance;
}
h2.section-title .serif { color: var(--cyan); }
.section-sub {
  font-size: 17px; color: var(--muted); line-height: 1.55;
  max-width: 620px; margin: 0 auto;
}

/* ============ VERTICALS TABS ============ */
.verticals { background: var(--paper); }
.vertical-tabs {
  display: flex; gap: 8px; justify-content: center;
  margin-bottom: 32px; flex-wrap: wrap;
}
.vtab {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 9px 16px; border-radius: 999px;
  background: #fff; border: 1px solid var(--line);
  font-size: 14px; font-weight: 500; color: var(--ink);
  transition: all .15s ease;
}
.vtab:hover { border-color: var(--cyan); color: var(--cyan); }
.vtab.active {
  background: var(--navy); color: #fff; border-color: var(--navy);
}
.vtab .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--cyan); }
.vtab.active .dot { background: var(--yellow); }

.vertical-stage {
  background: linear-gradient(180deg, #f4f8fb 0%, #eef3f8 100%);
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 36px;
  display: grid; grid-template-columns: 1fr 1.3fr; gap: 36px; align-items: center;
  min-height: 460px;
}
.vert-copy h3 {
  font-size: 32px; font-weight: 700; letter-spacing: -.025em; color: var(--navy);
  margin: 8px 0 12px;
}
.vert-copy p { color: var(--muted); font-size: 16px; line-height: 1.55; margin: 0 0 22px; }
.vert-feats { display: flex; flex-direction: column; gap: 10px; }
.vert-feat { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; }
.vert-feat .chk {
  flex-shrink: 0; width: 20px; height: 20px; border-radius: 50%;
  background: var(--cyan-bg); color: var(--cyan);
  display: grid; place-items: center; margin-top: 1px;
}

/* vertical preview card */
.vpreview {
  background: #fff;
  border-radius: 18px;
  border: 1px solid var(--line);
  padding: 18px;
  box-shadow: var(--shadow-md);
}
.vpreview-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: 12px; margin-bottom: 14px;
  border-bottom: 1px solid var(--line);
}
.vpreview-title { font-weight: 700; color: var(--navy); font-size: 14px; }
.vpreview-search {
  flex: 1; margin: 0 16px;
  background: var(--paper-2); border: 1px solid var(--line);
  border-radius: 8px; padding: 6px 10px;
  font-size: 12px; color: var(--muted);
  display: flex; align-items: center; gap: 6px;
}
.vpreview-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.vpreview-card {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 10px; display: flex; flex-direction: column; gap: 8px;
  background: #fff; position: relative;
}
.vpreview-thumb {
  height: 90px; border-radius: 8px;
  background: linear-gradient(135deg, #d4edf3, #b6dde7);
  position: relative; overflow: hidden;
}
.vpreview-thumb.b { background: linear-gradient(135deg, #fde68a, #fbbf24); }
.vpreview-thumb.c { background: linear-gradient(135deg, #cffafe, #67e8f9); }
.vpreview-thumb.d { background: linear-gradient(135deg, #dbe5f3, #a5b8d4); }
.vpreview-thumb.e { background: linear-gradient(135deg, #c7f7e2, #5eddb3); }
.vpreview-thumb.f { background: linear-gradient(135deg, #ffe4d6, #fdba74); }
.vpreview-thumb::after {
  content: ""; position: absolute; inset: 0;
  background-image: radial-gradient(circle at 30% 70%, rgba(255,255,255,.4), transparent 50%);
}
.vpreview-card .vpreview-name { font-weight: 600; font-size: 12px; color: var(--navy); }
.vpreview-card .vpreview-meta { font-size: 11px; color: var(--muted); display: flex; gap: 6px; align-items: center; }
.vpreview-card .vpreview-meta b { color: var(--cyan); }

/* ============ AI FEATURES ============ */
.features-grid {
  display: grid; grid-template-columns: repeat(12, 1fr); gap: 20px;
}
.fcard {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 28px;
  position: relative;
  overflow: hidden;
  transition: border-color .2s ease, transform .2s ease;
}
.fcard:hover { border-color: var(--cyan); transform: translateY(-2px); }
.fcard h4 {
  font-size: 20px; font-weight: 600; color: var(--navy);
  letter-spacing: -.02em; margin: 16px 0 6px;
}
.fcard p { font-size: 14px; color: var(--muted); line-height: 1.55; margin: 0; }
.fcard.lg { grid-column: span 6; min-height: 360px; }
.fcard.md { grid-column: span 6; }
.fcard.sm { grid-column: span 4; }
.fcard .ficon {
  width: 44px; height: 44px; border-radius: 12px;
  display: grid; place-items: center;
  background: var(--navy); color: var(--cyan);
}
.fcard.dark {
  background: var(--navy);
  border-color: var(--navy-3);
  color: #fff;
}
.fcard.dark h4 { color: #fff; }
.fcard.dark p { color: #b6c2db; }
.fcard.dark .ficon { background: rgba(255,255,255,.08); color: var(--yellow); }
.fcard.yellow {
  background: var(--yellow);
  border-color: #facc15;
}
.fcard.yellow h4 { color: var(--navy); }
.fcard.yellow p { color: rgba(10,23,51,.7); }
.fcard.yellow .ficon { background: var(--navy); color: var(--yellow); }

/* fcard visuals */
.fviz {
  margin-top: 22px;
  height: 200px;
  border-radius: 14px;
  background: var(--paper-2);
  border: 1px solid var(--line);
  position: relative;
  overflow: hidden;
}
.fcard.dark .fviz { background: #060f24; border-color: var(--navy-3); }

.viz-prompt {
  position: absolute; top: 14px; left: 14px; right: 14px;
  display: flex; gap: 8px; align-items: center;
  padding: 9px 12px;
  background: #fff; border: 1px solid var(--line); border-radius: 10px;
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  color: var(--ink);
}
.viz-prompt .star { color: var(--cyan); }
.viz-prompt .caret {
  display: inline-block; width: 1.5px; height: 14px; background: var(--cyan);
  animation: blink 1s steps(2) infinite; vertical-align: middle;
}
@keyframes blink { 50% { opacity: 0; } }
.viz-cards {
  position: absolute; bottom: 14px; left: 14px; right: 14px;
  display: flex; gap: 10px;
}
.viz-cards .mini {
  flex: 1; background: #fff; border: 1px solid var(--line);
  border-radius: 10px; padding: 8px; font-size: 11px;
}
.viz-cards .mini-bar {
  height: 38px; border-radius: 6px; margin-bottom: 6px;
  background: linear-gradient(135deg, #cffafe, #67e8f9);
}
.viz-cards .mini-bar.b { background: linear-gradient(135deg, #fde68a, #facc15); }
.viz-cards .mini-bar.c { background: linear-gradient(135deg, #dbe5f3, #94aacd); }
.viz-cards .mini b { color: var(--navy); font-weight: 600; display: block; }
.viz-cards .mini span { color: var(--muted); }

/* chat viz for dark card */
.viz-chat { padding: 18px; display: flex; flex-direction: column; gap: 10px; }
.bubble {
  max-width: 78%;
  padding: 10px 14px; border-radius: 14px;
  font-size: 13px; line-height: 1.45;
}
.bubble.user {
  align-self: flex-end;
  background: var(--cyan); color: var(--navy);
  border-bottom-right-radius: 4px;
}
.bubble.ai {
  align-self: flex-start;
  background: rgba(255,255,255,.08); color: #e6ecf7;
  border-bottom-left-radius: 4px;
  border: 1px solid rgba(255,255,255,.06);
}
.bubble.ai .src {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 10px; color: var(--yellow);
  margin-right: 6px; padding: 1px 6px;
  background: rgba(250,204,21,.1); border-radius: 4px;
}

/* radar viz */
.viz-radar { display: grid; place-items: center; height: 100%; }
.radar {
  width: 160px; height: 160px; border-radius: 50%;
  border: 1px solid var(--line);
  position: relative;
  background:
    radial-gradient(circle, transparent 35%, rgba(6,182,212,.07) 36%, rgba(6,182,212,.07) 37%, transparent 38%),
    radial-gradient(circle, transparent 60%, rgba(6,182,212,.07) 61%, rgba(6,182,212,.07) 62%, transparent 63%),
    radial-gradient(circle, transparent 85%, rgba(6,182,212,.07) 86%, rgba(6,182,212,.07) 87%, transparent 88%);
}
.radar::before, .radar::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(to right, transparent calc(50% - .5px), var(--line) calc(50% - .5px), var(--line) calc(50% + .5px), transparent calc(50% + .5px));
}
.radar::after { transform: rotate(90deg); }
.pin {
  position: absolute; width: 12px; height: 12px; border-radius: 50%;
  background: var(--cyan); border: 2px solid #fff;
  box-shadow: 0 0 0 3px rgba(6,182,212,.25), 0 2px 6px rgba(6,182,212,.4);
  transform: translate(-50%, -50%);
}
.pin.yellow { background: var(--yellow); box-shadow: 0 0 0 3px rgba(250,204,21,.25), 0 2px 6px rgba(250,204,21,.4); }
.pin.navy { background: var(--navy); box-shadow: 0 0 0 3px rgba(10,23,51,.2); }
.radar-label {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  font-size: 11px; color: var(--muted); font-family: 'JetBrains Mono', monospace;
}

/* viz: scoring */
.viz-score { padding: 16px; display: flex; flex-direction: column; gap: 10px; }
.score-row { display: flex; align-items: center; gap: 10px; font-size: 12px; }
.score-name { width: 90px; color: var(--ink); font-weight: 500; }
.score-track { flex: 1; height: 8px; background: var(--paper-3); border-radius: 4px; overflow: hidden; }
.score-fill { height: 100%; background: linear-gradient(90deg, var(--cyan), var(--cyan-2)); border-radius: 4px; }
.score-fill.y { background: linear-gradient(90deg, var(--yellow), #fde047); }
.score-value { font-family: 'JetBrains Mono', monospace; color: var(--navy); font-weight: 600; width: 36px; text-align: right; }

/* ============ DEMO SECTION ============ */
.demo-wrap {
  background: var(--navy);
  color: #fff;
  position: relative;
  overflow: hidden;
}
.demo-wrap::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(ellipse 50% 70% at 20% 30%, rgba(6,182,212,.18), transparent 60%),
    radial-gradient(ellipse 50% 70% at 90% 80%, rgba(250,204,21,.1), transparent 60%);
  pointer-events: none;
}
.demo-wrap .section-title { color: #fff; }
.demo-wrap .section-title .serif { color: var(--cyan-2); }
.demo-wrap .section-sub { color: #b6c2db; }
.demo-wrap .kicker { background: rgba(34,211,238,.1); color: var(--cyan-2); border-color: rgba(34,211,238,.2); }

.demo-stage {
  background: linear-gradient(180deg, #fafcff, #eef2f8);
  border-radius: 24px;
  padding: 24px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 50px 100px -40px rgba(0,0,0,.5), 0 0 0 1px rgba(255,255,255,.06);
  position: relative;
}

.demo-toolbar {
  display: flex; align-items: center; gap: 8px;
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  padding: 8px; margin-bottom: 16px;
  position: relative;
}
.demo-search {
  flex: 1; display: flex; align-items: center; gap: 8px;
  padding: 8px 14px;
  background: var(--paper-2); border-radius: 8px;
  font-size: 14px; color: var(--ink);
  border: 1px solid transparent;
}
.demo-search.active { background: #fff; border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(6,182,212,.12); }
.demo-search .placeholder { color: var(--muted); }
.demo-search .typed { color: var(--navy); font-weight: 500; }
.demo-search .caret { display: inline-block; width: 2px; height: 14px; background: var(--cyan); vertical-align: middle; animation: blink 1s steps(2) infinite; }
.demo-ai-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px; background: var(--navy); color: #fff;
  border-radius: 8px; font-size: 13px; font-weight: 600;
}
.demo-ai-toggle .spark { color: var(--yellow); }

.demo-body { display: grid; grid-template-columns: 240px 1fr; gap: 16px; }
.demo-side {
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  padding: 16px;
}
.demo-side h5 {
  margin: 0 0 12px; font-size: 12px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); font-weight: 700;
}
.demo-filter {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 10px; border-radius: 8px;
  font-size: 13px; color: var(--ink); cursor: pointer;
}
.demo-filter:hover { background: var(--paper-2); }
.demo-filter.active { background: var(--cyan-bg); color: #0e7490; font-weight: 600; }
.demo-filter .count { font-size: 11px; color: var(--muted); }
.demo-filter.active .count { color: #0e7490; }
.demo-side hr { border: 0; border-top: 1px solid var(--line); margin: 14px 0; }
.demo-tag-row { display: flex; flex-wrap: wrap; gap: 6px; }
.demo-tag-btn {
  font-size: 12px; padding: 4px 10px; border-radius: 999px;
  background: var(--paper-2); border: 1px solid var(--line);
  color: var(--ink);
}
.demo-tag-btn.active { background: var(--navy); color: #fff; border-color: var(--navy); }

.demo-results {
  background: #fff; border: 1px solid var(--line); border-radius: 14px;
  padding: 16px;
}
.demo-results-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 14px;
}
.demo-results-head .res-count { font-size: 13px; color: var(--muted); }
.demo-results-head .res-count b { color: var(--navy); }
.demo-results-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.demo-listing {
  border: 1px solid var(--line); border-radius: 12px;
  padding: 12px; background: #fff;
  display: flex; gap: 12px;
  position: relative;
  transition: border-color .15s ease;
}
.demo-listing:hover { border-color: var(--cyan); }
.demo-listing.featured { border-color: var(--yellow); background: linear-gradient(180deg, #fffdf5, #fff); }
.demo-listing-thumb {
  width: 90px; height: 90px; flex-shrink: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #cffafe, #22d3ee);
}
.demo-listing-thumb.b { background: linear-gradient(135deg, #fde68a, #facc15); }
.demo-listing-thumb.c { background: linear-gradient(135deg, #dbe5f3, #94aacd); }
.demo-listing-thumb.d { background: linear-gradient(135deg, #c7f7e2, #5eddb3); }
.demo-listing-body { flex: 1; min-width: 0; }
.demo-listing-body h6 { margin: 0; font-size: 14px; color: var(--navy); font-weight: 600; }
.demo-listing-body .cat { font-size: 11px; color: var(--muted); margin-bottom: 6px; }
.demo-listing-body .desc { font-size: 12px; color: var(--muted); line-height: 1.45; margin: 6px 0 8px; }
.demo-listing-body .meta { display: flex; align-items: center; gap: 10px; font-size: 11px; color: var(--muted); }
.demo-listing-body .rating { color: var(--navy); font-weight: 600; }
.featured-pill {
  position: absolute; top: 8px; right: 8px;
  background: var(--yellow); color: var(--navy);
  font-size: 10px; font-weight: 700; padding: 2px 7px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 3px;
}
.ai-match {
  position: absolute; top: 8px; right: 8px;
  background: var(--navy); color: #fff;
  font-size: 10px; font-weight: 600; padding: 3px 7px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 4px;
}
.ai-match .pct { color: var(--cyan-2); }

.ai-summary {
  margin-bottom: 14px;
  display: flex; gap: 12px;
  background: linear-gradient(135deg, #0a1733, #112347);
  border-radius: 12px;
  padding: 14px;
  color: #e6ecf7;
}
.ai-summary .ai-icon {
  flex-shrink: 0; width: 32px; height: 32px; border-radius: 8px;
  background: rgba(34,211,238,.15); color: var(--cyan-2);
  display: grid; place-items: center;
}
.ai-summary .ai-text { font-size: 13px; line-height: 1.5; }
.ai-summary .ai-text b { color: var(--yellow); font-weight: 600; }

/* tabs in demo */
.demo-modes { display: flex; gap: 6px; }
.demo-mode {
  padding: 6px 12px; font-size: 13px; border-radius: 8px;
  color: #cbd5ea; background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  font-weight: 500;
}
.demo-mode.active { background: var(--cyan); color: var(--navy); border-color: var(--cyan); }

/* ============ HOW IT WORKS ============ */
.steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.step {
  position: relative;
  padding: 28px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
}
.step-num {
  position: absolute; top: -16px; left: 28px;
  width: 32px; height: 32px; border-radius: 10px;
  background: var(--navy); color: var(--yellow);
  display: grid; place-items: center;
  font-weight: 700; font-size: 14px;
  font-family: 'JetBrains Mono', monospace;
  border: 3px solid #fff;
  box-shadow: var(--shadow-sm);
}
.step h4 {
  font-size: 20px; font-weight: 600; color: var(--navy);
  letter-spacing: -.02em; margin: 16px 0 8px;
}
.step p { font-size: 14px; color: var(--muted); line-height: 1.55; margin: 0; }
.step-visual {
  margin-top: 22px;
  height: 140px; background: var(--paper-2);
  border-radius: 12px; border: 1px solid var(--line);
  position: relative; overflow: hidden;
}

/* ============ PRICING ============ */
.price-toggle {
  display: inline-flex; padding: 4px;
  background: var(--paper-2); border: 1px solid var(--line);
  border-radius: 999px; margin: 24px auto 0;
}
.price-toggle button {
  padding: 8px 18px; font-size: 13px; font-weight: 600;
  border-radius: 999px; color: var(--muted);
}
.price-toggle button.active { background: var(--navy); color: #fff; }
.save-pill {
  display: inline-block; margin-left: 6px;
  font-size: 10px; font-weight: 700; padding: 2px 6px;
  background: var(--yellow); color: var(--navy); border-radius: 4px;
}

.pricing-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.pcard {
  background: #fff; border: 1px solid var(--line);
  border-radius: 20px; padding: 32px;
  position: relative;
}
.pcard.featured {
  background: var(--navy); color: #fff;
  border-color: var(--navy);
  transform: scale(1.02);
  box-shadow: 0 30px 70px -20px rgba(6,182,212,.35);
}
.pcard.featured h3 { color: #fff; }
.pcard.featured .p-desc { color: #b6c2db; }
.pcard.featured .price-line { color: #fff; }
.pcard.featured .price-line .per { color: #b6c2db; }
.pcard.featured .feat { color: #e6ecf7; }
.pcard.featured .feat .chk { background: var(--cyan); color: var(--navy); }
.popular-tag {
  position: absolute; top: -10px; left: 50%; transform: translateX(-50%);
  background: var(--yellow); color: var(--navy);
  font-size: 11px; font-weight: 700; padding: 4px 12px; border-radius: 999px;
  letter-spacing: .05em;
}
.pcard h3 {
  margin: 0 0 6px; font-size: 18px; font-weight: 600;
  color: var(--navy); letter-spacing: -.01em;
}
.p-desc { font-size: 13px; color: var(--muted); margin-bottom: 24px; }
.price-line {
  display: flex; align-items: baseline; gap: 6px;
  color: var(--navy); margin-bottom: 24px;
}
.price-line .amount { font-size: 44px; font-weight: 700; letter-spacing: -.03em; }
.price-line .amount .currency { font-size: 22px; vertical-align: top; }
.price-line .per { font-size: 13px; color: var(--muted); }
.pfeatures { list-style: none; padding: 0; margin: 24px 0; display: flex; flex-direction: column; gap: 12px; }
.feat { display: flex; gap: 10px; align-items: flex-start; font-size: 14px; color: var(--ink); }
.feat .chk {
  flex-shrink: 0; width: 18px; height: 18px; border-radius: 50%;
  background: var(--cyan-bg); color: var(--cyan);
  display: grid; place-items: center; margin-top: 1px;
}

/* ============ COMPARISON ============ */
.compare {
  background: var(--paper-2);
}
.compare-table {
  background: #fff; border: 1px solid var(--line);
  border-radius: 20px; overflow: hidden;
}
.compare-row {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr;
  border-bottom: 1px solid var(--line);
}
.compare-row:last-child { border-bottom: 0; }
.compare-row > div {
  padding: 18px 22px; font-size: 14px; color: var(--ink);
}
.compare-row > div + div { border-left: 1px solid var(--line); }
.compare-row.head > div {
  background: var(--paper-2); font-weight: 700; color: var(--navy); font-size: 13px;
  text-transform: uppercase; letter-spacing: .06em;
}
.compare-row.head .col-sdp { background: var(--navy); color: #fff; position: relative; }
.compare-row.head .col-sdp::before {
  content: ""; position: absolute; top: 6px; right: 16px;
  width: 8px; height: 8px; border-radius: 50%; background: var(--yellow);
}
.compare .check { color: #16a34a; font-weight: 700; }
.compare .cross { color: var(--muted-2); }
.compare-feature { font-weight: 600; color: var(--navy); }

/* ============ TESTIMONIALS ============ */
.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.tcard {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
  padding: 28px;
  position: relative;
}
.tcard .stars { font-size: 14px; margin-bottom: 14px; }
.tcard blockquote {
  margin: 0; font-size: 16px; line-height: 1.55; color: var(--navy);
  letter-spacing: -.01em;
}
.tcard blockquote b { color: var(--cyan); font-weight: 600; }
.tcard .who {
  margin-top: 22px; display: flex; align-items: center; gap: 12px;
}
.tcard .who .av {
  width: 40px; height: 40px; border-radius: 50%;
  background: linear-gradient(135deg, var(--cyan), var(--navy));
  display: grid; place-items: center; color: #fff; font-weight: 700;
}
.tcard .who-name { font-weight: 600; font-size: 14px; color: var(--navy); }
.tcard .who-role { font-size: 12px; color: var(--muted); }

.tcard.feature {
  background: var(--navy); color: #fff; border-color: var(--navy);
  grid-column: span 2;
}
.tcard.feature blockquote { color: #fff; font-size: 22px; line-height: 1.45; }
.tcard.feature blockquote b { color: var(--yellow); }
.tcard.feature .who-name { color: #fff; }
.tcard.feature .who-role { color: #b6c2db; }
.metrics-strip {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 30px;
  border: 1px solid var(--line); border-radius: 20px;
  background: #fff; padding: 30px; margin-top: 30px;
}
.metric .num {
  font-size: 22px; font-weight: 700; letter-spacing: -.02em; color: var(--navy);
  font-family: 'Inter', sans-serif;
}
.metric .num .unit {
  color: var(--cyan);
  display: inline-block;
  padding: 4px 10px;
  background: var(--cyan-bg);
  border: 1px solid var(--cyan-soft);
  border-radius: 6px;
  font-size: 13px;
  letter-spacing: .02em;
  font-family: 'JetBrains Mono', monospace;
}
.metric .label { font-size: 13px; color: var(--muted); margin-top: 10px; line-height: 1.5; }

/* ============ FAQ ============ */
.faq-list { max-width: 820px; margin: 0 auto; }
.faq-item {
  border-bottom: 1px solid var(--line);
  padding: 22px 0;
}
.faq-q {
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; font-size: 17px; font-weight: 600; color: var(--navy);
  letter-spacing: -.01em;
}
.faq-q .plus {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--paper-2); display: grid; place-items: center;
  color: var(--navy); transition: transform .2s ease;
  flex-shrink: 0;
}
.faq-item.open .faq-q .plus { background: var(--cyan); color: #fff; transform: rotate(45deg); }
.faq-a {
  max-height: 0; overflow: hidden;
  transition: max-height .3s ease, padding-top .3s ease;
  font-size: 15px; color: var(--muted); line-height: 1.6;
}
.faq-item.open .faq-a { max-height: 240px; padding-top: 14px; }

/* ============ FLYWHEEL / PITCH FROM ADMIN ============ */
.flywheel-wrap {
  background: linear-gradient(180deg, #f6fbfd 0%, #ffffff 100%);
  position: relative;
}
.flywheel-grid {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 48px;
  align-items: center;
}
.flywheel-copy h2 {
  font-size: clamp(32px, 4vw, 52px);
  font-weight: 700; letter-spacing: -.03em; line-height: 1.05;
  margin: 18px 0 16px; color: var(--navy); text-wrap: balance;
}
.flywheel-copy h2 .serif { color: var(--cyan); }
.flywheel-copy p {
  font-size: 17px; color: var(--muted); line-height: 1.55;
  max-width: 540px; margin: 0 0 24px;
}
.flow-steps { display: flex; flex-direction: column; gap: 14px; margin-top: 12px; }
.flow-step {
  display: flex; gap: 14px; align-items: flex-start;
  padding: 14px 16px;
  background: #fff; border: 1px solid var(--line);
  border-radius: 14px;
  transition: border-color .15s ease, transform .15s ease;
}
.flow-step:hover { border-color: var(--cyan); transform: translateX(2px); }
.flow-step .num {
  flex-shrink: 0;
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--navy); color: var(--yellow);
  display: grid; place-items: center;
  font-weight: 700; font-size: 13px;
  font-family: 'JetBrains Mono', monospace;
}
.flow-step b {
  display: block; color: var(--navy); font-size: 15px;
  font-weight: 600; margin-bottom: 2px; letter-spacing: -.01em;
}
.flow-step span { font-size: 13px; color: var(--muted); line-height: 1.45; }

/* admin mock */
.admin-mock {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 20px;
  box-shadow: var(--shadow-lg);
  overflow: hidden;
}
.admin-bar {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 16px;
  background: var(--navy); color: #fff;
}
.admin-bar .dot {
  width: 8px; height: 8px; border-radius: 50%; background: var(--cyan-2);
  box-shadow: 0 0 0 3px rgba(34,211,238,.18);
}
.admin-bar .title { font-size: 13px; font-weight: 600; }
.admin-bar .crumb { font-size: 12px; color: #b6c2db; }
.admin-bar .crumb b { color: #fff; font-weight: 500; }
.admin-tabs {
  display: flex; gap: 0; padding: 0 16px;
  background: #fff; border-bottom: 1px solid var(--line);
}
.admin-tab {
  padding: 12px 14px;
  font-size: 13px; color: var(--muted); font-weight: 500;
  border-bottom: 2px solid transparent;
  cursor: pointer;
}
.admin-tab.active { color: var(--navy); border-bottom-color: var(--cyan); font-weight: 600; }
.admin-body { padding: 18px; background: var(--paper-2); }

/* business detail card */
.biz-head {
  display: flex; align-items: center; gap: 14px;
  padding-bottom: 14px; border-bottom: 1px solid var(--line);
  margin-bottom: 14px;
}
.biz-logo {
  width: 48px; height: 48px; border-radius: 12px;
  background: linear-gradient(135deg, var(--cyan), var(--navy));
  color: #fff; font-weight: 700; font-size: 16px;
  display: grid; place-items: center;
}
.biz-name { font-weight: 700; font-size: 16px; color: var(--navy); letter-spacing: -.01em; }
.biz-meta { font-size: 12px; color: var(--muted); display: flex; gap: 8px; }
.biz-meta .dot-sep { color: var(--line-2); }
.biz-status {
  margin-left: auto;
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--cyan-bg); color: #0e7490;
  font-size: 11px; font-weight: 600;
  padding: 4px 10px; border-radius: 999px;
  border: 1px solid var(--cyan-soft);
}
.biz-status .dotd { width: 6px; height: 6px; border-radius: 50%; background: var(--cyan); }

.audit-title {
  font-size: 11px; text-transform: uppercase; letter-spacing: .08em;
  color: var(--muted); font-weight: 700; margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
}
.audit-title .spark { color: var(--cyan); }
.signals { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-bottom: 16px; }
.signal {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  display: flex; align-items: center; gap: 10px;
  font-size: 12px;
}
.signal .si-ic {
  width: 28px; height: 28px; border-radius: 8px;
  display: grid; place-items: center; flex-shrink: 0;
}
.signal.bad .si-ic { background: #ffe4e6; color: #be123c; }
.signal.warn .si-ic { background: var(--yellow-soft); color: #854d0e; }
.signal.ok .si-ic { background: var(--cyan-bg); color: #0e7490; }
.signal b { display: block; color: var(--navy); font-weight: 600; font-size: 12px; }
.signal span { color: var(--muted); font-size: 11px; }

.opp-score {
  background: linear-gradient(135deg, #0a1733, #112347);
  color: #fff;
  border-radius: 14px;
  padding: 16px;
  display: flex; align-items: center; gap: 16px;
  margin-bottom: 16px;
}
.opp-num {
  font-size: 36px; font-weight: 700; letter-spacing: -.03em;
  color: var(--yellow);
  font-family: 'Inter', sans-serif;
}
.opp-num small { font-size: 16px; color: #b6c2db; font-weight: 500; }
.opp-text { flex: 1; }
.opp-text b { display: block; font-size: 14px; font-weight: 600; margin-bottom: 2px; }
.opp-text span { font-size: 12px; color: #b6c2db; }

.pitch-row { display: flex; gap: 8px; }
.pitch-btn {
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 11px 14px;
  background: var(--cyan); color: var(--navy);
  border-radius: 10px;
  font-weight: 700; font-size: 13px;
  border: 0; cursor: pointer;
  transition: background .15s ease;
}
.pitch-btn:hover { background: var(--yellow); }
.pitch-btn.alt { background: #fff; color: var(--navy); border: 1px solid var(--line-2); flex: 0 0 auto; padding: 11px 14px; }
.pitch-btn.alt:hover { background: var(--paper-2); }

/* floating revenue tag */
.rev-float {
  position: absolute; top: -12px; right: -12px;
  background: var(--yellow); color: var(--navy);
  border-radius: 12px;
  padding: 10px 14px;
  box-shadow: 0 14px 28px -10px rgba(250,204,21,.5);
  font-size: 12px; font-weight: 600;
  display: flex; align-items: center; gap: 8px;
  z-index: 2;
}
.rev-float b { font-size: 16px; font-family: 'Inter', sans-serif; letter-spacing: -.01em; }
.admin-wrap { position: relative; }

@media (max-width: 960px) {
  .flywheel-grid { grid-template-columns: 1fr; }
  .signals { grid-template-columns: 1fr; }
  .rev-float { right: 0; }
}

/* ============ SEE IT IN ACTION ============ */
.sia {
  padding-bottom: 120px;
  position: relative;
}
.sia .section-head { margin-bottom: 40px; }
.sia-frame {
  position: relative;
  margin: 0 auto;
  max-width: 1480px;
  border-radius: 24px;
  overflow: hidden;
  background: #0a1733;
  border: 1px solid var(--line);
  box-shadow:
    0 60px 120px -30px rgba(10,23,51,.4),
    0 30px 60px -20px rgba(6,182,212,.18);
}
.sia-chrome {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 18px;
  background: linear-gradient(180deg, #fafcff, #f1f5fb);
  border-bottom: 1px solid var(--line);
}
.sia-chrome .hc-dots span:nth-child(1) { background: #fc7066; }
.sia-chrome .hc-dots span:nth-child(2) { background: #fdbe40; }
.sia-chrome .hc-dots span:nth-child(3) { background: #38c75a; }
.sia-url {
  flex: 1; background: #fff; border: 1px solid var(--line);
  border-radius: 8px; padding: 7px 14px;
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  color: var(--navy); display: flex; align-items: center; gap: 8px;
}
.sia-url .lock { color: #38c75a; }
.sia-url .path { color: var(--muted); }
.sia-chrome .open-btn {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600; color: var(--navy);
  padding: 7px 14px; border-radius: 8px;
  border: 1px solid var(--line); background: #fff;
  text-decoration: none;
}
.sia-chrome .open-btn:hover { background: var(--cyan); color: #fff; border-color: var(--cyan); }

.sia-viewport {
  position: relative;
  height: 640px;
  overflow: hidden;
  background: #fff;
}
.sia-viewport iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 200%;
  border: 0;
  background: #fff;
  transform: translateY(0);
  transform-origin: top left;
  will-change: transform;
}
.sia-overlay {
  position: absolute;
  inset: auto 0 0 0;
  height: 80px;
  background: linear-gradient(0deg, rgba(10,23,51,.06), transparent);
  pointer-events: none;
}

.sia-badges {
  position: absolute; top: 20px; right: 20px;
  display: flex; flex-direction: column; gap: 10px;
  pointer-events: none;
}
.sia-badge {
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 12px; color: var(--ink);
  display: flex; align-items: center; gap: 8px;
  box-shadow: var(--shadow-md);
}
.sia-badge .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--yellow);
  box-shadow: 0 0 0 4px rgba(250,204,21,.2);
  animation: pulse 1.6s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { box-shadow: 0 0 0 4px rgba(250,204,21,.2); }
  50% { box-shadow: 0 0 0 8px rgba(250,204,21,0); }
}
.sia-badge b { color: var(--navy); font-weight: 600; }
.sia-badge.cyan .dot { background: var(--cyan); box-shadow: 0 0 0 4px rgba(6,182,212,.2); }

.sia-caption {
  margin-top: 24px;
  text-align: center;
  font-size: 14px;
  color: var(--muted);
}
.sia-caption a {
  color: var(--cyan); font-weight: 600; text-decoration: underline;
}

.sia-fallback {
  position: absolute; inset: 0;
  display: none;
  flex-direction: column; align-items: center; justify-content: center;
  background: linear-gradient(180deg, #fafcff, #f1f5fb);
  color: var(--muted);
  z-index: 5;
  text-align: center; padding: 40px;
}
.sia-fallback.show { display: flex; }
.sia-fallback strong { color: var(--navy); font-size: 18px; margin-bottom: 6px; }
.sia-fallback a {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 16px;
  background: var(--navy); color: #fff;
  padding: 10px 18px; border-radius: 10px;
  font-weight: 600; font-size: 14px;
}

@media (max-width: 960px) {
  .sia-viewport { height: 440px; }
  .sia-badges { display: none; }
}

/* ============ FINAL CTA ============ */
.final-cta {
  position: relative; overflow: hidden;
  background: var(--navy); color: #fff;
}
.final-cta::before {
  content: ""; position: absolute; inset: 0;
  background:
    radial-gradient(circle at 20% 20%, rgba(6,182,212,.25), transparent 50%),
    radial-gradient(circle at 80% 80%, rgba(250,204,21,.12), transparent 50%);
}
.final-cta .container { position: relative; }
.final-cta-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: 60px; align-items: center; }
.final-cta-center {
  text-align: center;
  max-width: 760px;
  margin: 0 auto;
  position: relative;
}
.final-cta-center p {
  margin-left: auto; margin-right: auto;
}
.final-ctas {
  display: flex; gap: 12px; justify-content: center;
  margin-top: 32px; flex-wrap: wrap;
}
.final-trust {
  margin-top: 28px;
  display: flex; gap: 22px; justify-content: center; flex-wrap: wrap;
  font-size: 13px; color: #b6c2db;
}
.final-trust span { display: inline-flex; align-items: center; gap: 6px; }
.final-trust svg { color: var(--cyan-2); }
.final-cta h2 {
  font-size: clamp(36px, 5vw, 56px);
  font-weight: 700; letter-spacing: -.03em; line-height: 1.05;
  margin: 0 0 18px; color: #fff;
}
.final-cta h2 .serif { color: var(--cyan-2); }
.final-cta p { color: #b6c2db; font-size: 18px; line-height: 1.55; max-width: 540px; }

.cta-card {
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 20px; padding: 28px;
  backdrop-filter: blur(10px);
}
.cta-card h4 { margin: 0 0 4px; font-size: 16px; }
.cta-card p { margin: 0 0 18px; font-size: 13px; color: #b6c2db; }
.cta-form { display: flex; flex-direction: column; gap: 12px; }
.cta-input {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 10px; padding: 12px 14px;
  color: #fff; font-size: 14px; font-family: inherit;
  outline: none;
}
.cta-input::placeholder { color: #8a96b3; }
.cta-input:focus { border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(6,182,212,.18); }
.cta-card .check-row { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #b6c2db; }
.cta-check {
  display: flex; flex-wrap: wrap; gap: 14px;
  margin-top: 12px; font-size: 12px; color: #b6c2db;
}
.cta-check span { display: inline-flex; align-items: center; gap: 4px; }
.cta-check svg { color: var(--cyan-2); }

/* ============ FOOTER ============ */
footer {
  background: #060e22; color: #b6c2db;
  padding: 60px 0 28px;
}
.foot-grid { display: grid; grid-template-columns: 1.4fr repeat(3, 1fr); gap: 40px; margin-bottom: 40px; }
.foot-grid h5 {
  color: #fff; font-size: 13px; text-transform: uppercase; letter-spacing: .08em;
  margin: 0 0 14px; font-weight: 700;
}
.foot-grid ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-grid a,
.foot-grid li a,
.foot-grid ul a { font-size: 14px; color: #b6c2db; opacity: .85; text-decoration: none; }
.foot-grid a:hover,
.foot-grid li a:hover { color: #fff; opacity: 1; }
footer p, footer li, footer span { color: #b6c2db; }
.foot-bottom { color: #b6c2db; }
.foot-bottom a { color: #b6c2db; }
.foot-bottom a:hover { color: #fff; }
.foot-bottom {
  display: flex; align-items: center; justify-content: space-between;
  padding-top: 24px; border-top: 1px solid rgba(255,255,255,.08);
  font-size: 13px;
}
.foot-bottom .brand-name { color: #fff; }
.socials { display: flex; gap: 12px; }
.socials a {
  width: 32px; height: 32px; border-radius: 8px;
  background: rgba(255,255,255,.06); display: grid; place-items: center;
  color: #b6c2db;
}
.socials a:hover { background: rgba(255,255,255,.12); color: #fff; }

/* ============ RESPONSIVE ============ */
@media (max-width: 960px) {
  .hero-inner, .vertical-stage, .final-cta-grid { grid-template-columns: 1fr; gap: 36px; }
  .features-grid { grid-template-columns: repeat(6, 1fr); }
  .fcard.lg, .fcard.md, .fcard.sm { grid-column: span 6; }
  .steps, .pricing-grid, .testimonial-grid { grid-template-columns: 1fr; }
  .tcard.feature { grid-column: span 1; }
  .metrics-strip { grid-template-columns: repeat(2, 1fr); }
  .demo-body { grid-template-columns: 1fr; }
  .demo-results-grid { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
  .nav-links { display: none; }
  .float { display: none; }
  section { padding: 64px 0; }
}

/* ─────────────────────────────────────────────────────────────────────────
 * SSR support, data-attribute-driven visibility for the dual-rendered
 * interactive sections. Lets the page work without JS (showing default
 * state) AND lets the JS swap states by flipping a single attribute.
 * Added 2026-05-26 for the PHP-partials port (Option B).
 * ───────────────────────────────────────────────────────────────────── */

/* Demo: hide elements scoped to the inactive mode. */
.demo-stage[data-mode="ai"]      [data-demo-only="classic"] { display: none; }
.demo-stage[data-mode="classic"] [data-demo-only="ai"]      { display: none; }

/* Search bar visual state mirrors mode (default AI). */
.demo-stage[data-mode="ai"]      .demo-search { background:#fff; border-color: var(--cyan); box-shadow: 0 0 0 4px rgba(6,182,212,.12); }
.demo-stage[data-mode="classic"] .demo-search { background: var(--paper-2); border-color: transparent; box-shadow: none; }

/* Demo mode toggle pills, match active state across either mode. */
.demo-modes [data-demo-mode][aria-selected="true"],
.demo-modes [data-demo-mode].active { background: var(--cyan); color: var(--navy); border-color: var(--cyan); }

/* ─────────────────────────────────────────────────────────────────────────
 * Verticals, fix HTML5 [hidden] being overridden by `display: grid`.
 * Without this, all 6 panels stack on top of each other on page load.
 * Bug spotted 2026-05-26 on live smartdirectorypro.com.
 * ───────────────────────────────────────────────────────────────────── */
.vertical-stage[hidden] { display: none !important; }

/* ============================================================================
 * Content shell, used by every non-landing route (page, single, blog,
 * archive, search, 404). Keeps the landing nav + footer styling, gives
 * inner content a polished editorial layout.
 * Added 2026-05-26 for the template-hierarchy buildout.
 * ========================================================================== */

.sdt-shell {
	padding: 80px 0 100px;
	background: linear-gradient(180deg, #fafcff, #ffffff 200px);
	min-height: 60vh;
}
.sdt-shell--center { display: flex; align-items: center; min-height: 70vh; }

.sdt-shell__head {
	max-width: 760px;
	margin: 0 auto 48px;
	text-align: center;
}
.sdt-shell__title {
	font-size: clamp(32px, 4.4vw, 56px);
	line-height: 1.05;
	letter-spacing: -.025em;
	margin: 14px 0 14px;
	color: var(--navy);
	text-wrap: balance;
}
.sdt-shell__sub {
	font-size: 17px;
	color: var(--muted);
	max-width: 580px;
	margin: 14px auto 0;
	line-height: 1.55;
}
.sdt-shell__crumbs {
	display: inline-flex; gap: 8px; flex-wrap: wrap; justify-content: center;
	margin-bottom: 14px;
}
.sdt-shell__crumb {
	display: inline-block; padding: 4px 12px;
	background: var(--cyan-bg); color: #0e7490;
	border: 1px solid var(--cyan-soft);
	border-radius: 999px;
	font-size: 12px; font-weight: 600;
}
.sdt-shell__meta {
	font-size: 13px;
	color: var(--muted);
	margin-top: 14px;
	display: flex; gap: 8px; justify-content: center; flex-wrap: wrap;
}
.sdt-shell__sep { color: var(--line-2); }

.sdt-shell__hero {
	max-width: 980px; margin: 0 auto 48px;
	border-radius: var(--r-lg);
	overflow: hidden;
	border: 1px solid var(--line);
	box-shadow: var(--shadow-md);
}
.sdt-shell__hero img { display: block; width: 100%; height: auto; }

/* Long-form content area: typography for blog posts, pages, and rich content */
.sdt-shell__content {
	max-width: 760px;
	margin: 0 auto;
	font-size: 17px;
	line-height: 1.7;
	color: var(--ink);
}
.sdt-shell__content--prose {
	font-size: 18px;
	line-height: 1.75;
}
.sdt-shell__content h2 {
	font-size: clamp(24px, 2.6vw, 32px); margin: 56px 0 16px; color: var(--navy);
	letter-spacing: -.02em; line-height: 1.2; font-weight: 700;
}
.sdt-shell__content h3 {
	font-size: 22px; margin: 36px 0 12px; color: var(--navy);
	letter-spacing: -.015em; font-weight: 600;
}
.sdt-shell__content h4 { font-size: 18px; margin: 28px 0 10px; color: var(--navy); font-weight: 600; }
.sdt-shell__content p,
.sdt-shell__content ul,
.sdt-shell__content ol { margin: 0 0 18px; }
.sdt-shell__content ul, .sdt-shell__content ol { padding-left: 24px; }
.sdt-shell__content li { margin: 6px 0; }
.sdt-shell__content a { color: var(--cyan); text-decoration: underline; text-underline-offset: 3px; }
.sdt-shell__content a:hover { color: var(--navy); }
.sdt-shell__content blockquote {
	margin: 24px 0; padding: 18px 24px;
	border-left: 4px solid var(--cyan);
	background: var(--paper-2);
	border-radius: 0 12px 12px 0;
	color: var(--navy); font-style: italic;
}
.sdt-shell__content pre,
.sdt-shell__content code {
	font-family: 'JetBrains Mono', monospace;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: 8px;
}
.sdt-shell__content code { padding: 2px 6px; font-size: .9em; }
.sdt-shell__content pre { padding: 16px 18px; overflow-x: auto; font-size: 13.5px; line-height: 1.55; }
.sdt-shell__content pre code { background: none; border: 0; padding: 0; }
.sdt-shell__content img,
.sdt-shell__content figure { max-width: 100%; height: auto; border-radius: 10px; }
.sdt-shell__content figure { margin: 24px 0; }
.sdt-shell__content figcaption {
	font-size: 13px; color: var(--muted); text-align: center; margin-top: 8px;
}
.sdt-shell__content hr {
	margin: 40px 0; border: 0; border-top: 1px solid var(--line);
}
.sdt-shell__content table {
	width: 100%; border-collapse: collapse; margin: 24px 0;
	font-size: 14.5px;
}
.sdt-shell__content th, .sdt-shell__content td {
	padding: 12px 14px; border-bottom: 1px solid var(--line); text-align: left;
}
.sdt-shell__content th { background: var(--paper-2); font-weight: 600; color: var(--navy); }

.sdt-shell__tags {
	max-width: 760px; margin: 36px auto 0;
	display: flex; gap: 8px; flex-wrap: wrap;
	border-top: 1px solid var(--line); padding-top: 20px;
}
.sdt-shell__tag {
	display: inline-block; padding: 4px 12px;
	background: var(--paper-2); border: 1px solid var(--line);
	border-radius: 999px; font-size: 12px; color: var(--muted);
}
.sdt-shell__tag:hover { color: var(--cyan); border-color: var(--cyan); }

/* Grid of cards (blog index, archive) */
.sdt-shell__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
	gap: 24px;
}
.sdt-shell__card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	overflow: hidden;
	transition: border-color .2s ease, transform .2s ease;
}
.sdt-shell__card:hover { border-color: var(--cyan); transform: translateY(-2px); }
.sdt-shell__card-img { display: block; }
.sdt-shell__card-img img { display: block; width: 100%; height: 180px; object-fit: cover; }
.sdt-shell__card-body { padding: 20px 22px; }
.sdt-shell__card-cat {
	display: inline-block; font-size: 11px; font-weight: 700;
	color: var(--cyan); letter-spacing: .08em; text-transform: uppercase;
	margin-bottom: 8px;
}
.sdt-shell__card-title {
	margin: 0 0 8px;
	font-size: 19px; line-height: 1.25; letter-spacing: -.015em;
	color: var(--navy); font-weight: 600;
}
.sdt-shell__card-title a { color: inherit; }
.sdt-shell__card-title a:hover { color: var(--cyan); }
.sdt-shell__card-excerpt { font-size: 14px; color: var(--muted); margin: 0 0 14px; line-height: 1.55; }
.sdt-shell__card-meta {
	font-size: 12px; color: var(--muted);
	display: flex; gap: 6px; flex-wrap: wrap;
}

/* Plain post list (search, fallback) */
.sdt-shell__list {
	max-width: 760px; margin: 0 auto;
	display: flex; flex-direction: column; gap: 24px;
}
.sdt-shell__post {
	background: #fff; border: 1px solid var(--line);
	border-radius: var(--r-md); padding: 22px 26px;
}
.sdt-shell__post-title {
	margin: 0 0 8px; font-size: 20px; color: var(--navy); font-weight: 600;
}
.sdt-shell__post-title a:hover { color: var(--cyan); }
.sdt-shell__post-excerpt p { margin: 0; font-size: 14.5px; color: var(--muted); line-height: 1.55; }

.sdt-shell__empty {
	text-align: center; color: var(--muted); font-size: 16px;
	padding: 60px 20px;
}
.sdt-shell__pagination {
	margin: 48px auto 0;
	display: flex; gap: 8px; justify-content: center; flex-wrap: wrap;
}
.sdt-shell__pagination .page-numbers {
	padding: 8px 14px; border-radius: 8px;
	background: #fff; border: 1px solid var(--line);
	color: var(--ink); font-size: 14px;
	text-decoration: none;
}
.sdt-shell__pagination .page-numbers:hover { border-color: var(--cyan); color: var(--cyan); }
.sdt-shell__pagination .page-numbers.current {
	background: var(--navy); color: #fff; border-color: var(--navy);
}

.sdt-shell__search { display: flex; gap: 10px; max-width: 520px; margin: 18px auto 0; flex-wrap: wrap; }
.sdt-shell__search-input {
	flex: 1; min-width: 0;
	padding: 12px 16px; border-radius: 10px;
	border: 1px solid var(--line); background: #fff;
	font: inherit; font-size: 15px; color: var(--ink);
	outline: none;
}
.sdt-shell__search-input:focus {
	border-color: var(--cyan);
	box-shadow: 0 0 0 4px rgba(6,182,212,.12);
}

@media (max-width: 760px) {
	.sdt-shell { padding: 56px 0 72px; }
	.sdt-shell__grid { grid-template-columns: 1fr; }
}

/* =============================================================================
 * Blog filter bar, search + category pills.
 * Shared by home.php (/blog/), archive.php, search.php via blog-filter.php.
 * =========================================================================== */

.sdt-shell__filter {
	max-width: 900px;
	margin: 0 auto 36px;
	display: flex; flex-direction: column; gap: 18px;
}

.sdt-shell__filter-search { width: 100%; }

.sdt-shell__filter-search-label {
	position: absolute; width: 1px; height: 1px;
	padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0);
	white-space: nowrap; border: 0;
}

.sdt-shell__filter-search-row {
	display: flex; align-items: stretch; gap: 8px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 6px 6px 6px 14px;
	transition: border-color .15s ease, box-shadow .15s ease;
}

.sdt-shell__filter-search-row:focus-within {
	border-color: var(--cyan);
	box-shadow: 0 0 0 4px rgba(6,182,212,.12);
}

.sdt-shell__filter-search-icon {
	display: inline-flex; align-items: center;
	color: var(--muted);
}

.sdt-shell__filter-search-input {
	flex: 1; min-width: 0;
	padding: 10px 6px;
	border: 0; outline: 0; background: transparent;
	font: inherit; font-size: 15px; color: var(--ink);
}

.sdt-shell__filter-search-input::placeholder { color: var(--muted); }

.sdt-shell__filter-search-btn {
	display: inline-flex; align-items: center; justify-content: center;
	padding: 10px 22px;
	border: 0; border-radius: 8px;
	background: var(--navy); color: #fff;
	font: inherit; font-weight: 600; font-size: 14px;
	cursor: pointer;
	transition: background .15s ease;
}

.sdt-shell__filter-search-btn:hover { background: #142149; }

.sdt-shell__filter-cats {
	display: flex; flex-wrap: wrap; gap: 8px;
	justify-content: center;
}

.sdt-shell__filter-pill {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 8px 14px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	font-size: 13px; font-weight: 600;
	color: var(--ink);
	text-decoration: none;
	transition: border-color .15s ease, background .15s ease, color .15s ease, transform .15s ease;
}

.sdt-shell__filter-pill:hover {
	border-color: var(--cyan);
	color: var(--cyan);
	transform: translateY(-1px);
}

.sdt-shell__filter-pill.is-active {
	background: var(--navy);
	border-color: var(--navy);
	color: #fff;
}

.sdt-shell__filter-pill.is-active:hover {
	background: #142149;
	border-color: #142149;
	color: #fff;
}

.sdt-shell__filter-pill-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; padding: 0 6px; height: 18px;
	background: var(--paper-2);
	border-radius: 999px;
	font-size: 11px; font-weight: 700;
	color: var(--muted);
}

.sdt-shell__filter-pill.is-active .sdt-shell__filter-pill-count {
	background: rgba(255,255,255,.15);
	color: #fff;
}

@media (max-width: 760px) {
	.sdt-shell__filter { gap: 14px; margin-bottom: 28px; }
	.sdt-shell__filter-search-btn { padding: 10px 16px; }
	.sdt-shell__filter-cats { justify-content: flex-start; }
}

/* =============================================================================
 * Blog single, 2-column layout with sticky sidebar (TOC + CTA) + author box.
 * Used by single.php. Wraps the existing .sdt-shell prose styles.
 * =========================================================================== */

.sdt-shell--post { padding: 56px 0 96px; }

.sdt-post__head {
	max-width: 760px;
	margin: 0 auto 36px;
	text-align: center;
}
.sdt-post__crumbs {
	display: flex; justify-content: center; gap: 8px;
	flex-wrap: wrap; margin-bottom: 14px;
}
.sdt-post__crumb {
	display: inline-block;
	padding: 4px 12px;
	border-radius: 999px;
	background: rgba(6,182,212,.08);
	color: var(--cyan);
	font-size: 12px; font-weight: 600;
	text-transform: uppercase; letter-spacing: .06em;
	text-decoration: none;
}
.sdt-post__crumb:hover { background: rgba(6,182,212,.16); }
.sdt-post__title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(30px, 4.2vw, 44px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.15;
	color: var(--navy);
	margin: 0 0 18px;
}
.sdt-post__meta {
	color: var(--muted);
	font-size: 14px;
	display: flex; justify-content: center; gap: 8px; flex-wrap: wrap;
}
.sdt-post__sep { opacity: .5; }

.sdt-post__hero {
	max-width: 1000px;
	margin: 0 auto 48px;
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: var(--shadow-md);
}
.sdt-post__hero img { display: block; width: 100%; height: auto; }

.sdt-post__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 300px;
	gap: 56px;
	max-width: 1180px;
	margin: 0 auto;
	align-items: start;
}

.sdt-post__article { min-width: 0; }
.sdt-post__content { font-size: 17px; line-height: 1.7; color: var(--ink); }
.sdt-post__content h2 {
	font-size: 26px; font-weight: 700; letter-spacing: -.015em;
	color: var(--navy);
	margin: 48px 0 16px;
	scroll-margin-top: 100px;
}
.sdt-post__content h3 {
	font-size: 20px; font-weight: 600;
	color: var(--navy);
	margin: 32px 0 12px;
	scroll-margin-top: 100px;
}
.sdt-post__content p { margin: 0 0 1.25em; }
.sdt-post__content a { color: var(--cyan); text-decoration: underline; text-underline-offset: 2px; }
.sdt-post__content a:hover { color: #0891b2; }
.sdt-post__content ul, .sdt-post__content ol { margin: 0 0 1.25em; padding-left: 1.5em; }
.sdt-post__content li { margin-bottom: .4em; }
.sdt-post__content blockquote {
	border-left: 3px solid var(--cyan);
	padding: 4px 0 4px 20px;
	margin: 28px 0;
	font-style: italic; color: #475569;
}
.sdt-post__content code {
	background: var(--paper-2);
	padding: 2px 6px; border-radius: 6px;
	font-family: 'JetBrains Mono', monospace;
	font-size: .9em; color: var(--navy);
}
.sdt-post__content pre {
	background: #0a1733; color: #e2e8f0;
	padding: 20px 24px; border-radius: 12px;
	overflow-x: auto; font-size: 14px; line-height: 1.6;
	margin: 28px 0;
}
.sdt-post__content pre code { background: transparent; color: inherit; padding: 0; }
.sdt-post__content img { max-width: 100%; height: auto; border-radius: 12px; margin: 28px 0; }

.sdt-post__tags {
	margin-top: 40px; padding-top: 28px;
	border-top: 1px solid var(--line);
	display: flex; gap: 8px; flex-wrap: wrap;
}
.sdt-post__tag {
	display: inline-block;
	padding: 6px 12px;
	border-radius: 999px;
	background: var(--paper-2);
	color: var(--muted);
	font-size: 13px; font-weight: 500;
	text-decoration: none;
	transition: background .15s, color .15s;
}
.sdt-post__tag:hover { background: rgba(6,182,212,.12); color: var(--cyan); }

/* Sidebar rail + inner sticky wrapper */
.sdt-post__rail { position: relative; }
.sdt-post__rail-inner {
	position: sticky;
	top: 96px; /* clears the sticky nav */
	display: flex;
	flex-direction: column;
	gap: 24px;
	max-height: calc(100vh - 120px);
	overflow-y: auto;
	scrollbar-width: thin;
}

/* TOC */
.sdt-toc {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 18px 20px;
}
.sdt-toc__label {
	font-size: 11px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em;
	color: var(--cyan);
	margin-bottom: 12px;
}
.sdt-toc__list {
	list-style: none; margin: 0; padding: 0;
	font-size: 13.5px; line-height: 1.45;
}
.sdt-toc__item { margin: 0 0 8px; }
.sdt-toc__item--h3 { padding-left: 14px; }
.sdt-toc__link {
	display: block;
	color: var(--muted);
	text-decoration: none;
	padding: 4px 8px; border-radius: 6px;
	transition: background .15s, color .15s;
	border-left: 2px solid transparent;
	margin-left: -10px;
	padding-left: 8px;
}
.sdt-toc__link:hover {
	color: var(--navy);
	background: var(--paper-2);
}
.sdt-toc__link.is-active {
	color: var(--cyan);
	border-left-color: var(--cyan);
	background: rgba(6,182,212,.06);
	font-weight: 600;
}

/* CTA card */
.sdt-cta-card {
	background: linear-gradient(180deg, #0a1733, #1e293b);
	color: #fff;
	border-radius: var(--r-lg);
	padding: 24px;
	box-shadow: var(--shadow-md);
}
.sdt-cta-card__kicker {
	font-size: 11px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em;
	color: var(--cyan);
	margin-bottom: 10px;
}
.sdt-cta-card__title {
	font-size: 18px; font-weight: 700; line-height: 1.3;
	margin: 0 0 10px; letter-spacing: -.01em;
}
.sdt-cta-card__desc {
	font-size: 13.5px; line-height: 1.55;
	color: #cbd5e1;
	margin: 0 0 18px;
}
.sdt-cta-card__btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 10px 18px;
	background: var(--yellow);
	color: var(--navy);
	border-radius: 10px;
	font-weight: 700; font-size: 14px;
	text-decoration: none;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px -10px rgba(250,204,21,.5);
	transition: transform .12s, background .15s;
}
.sdt-cta-card__btn:hover { background: #ffd83a; transform: translateY(-1px); }

/* =============================================================================
 * CTA card variants: animated feature mockup between title and description.
 * Pure CSS animations, looped indefinitely with a long idle phase so they
 * read as ambient. Reduced-motion preference disables them.
 * =========================================================================== */

.sdt-cta-card__mockup {
	margin: 14px 0 16px;
	padding: 14px;
	background: rgba(255,255,255,0.04);
	border: 1px solid rgba(255,255,255,0.08);
	border-radius: 10px;
	overflow: hidden;
}

/* ── Mockup: AI SEO Audit ─────────────────────────────────────────────────── */
.sdt-mockup--audit { display: flex; flex-direction: column; gap: 10px; font-size: 12px; }
.sdt-mockup__row { display: flex; align-items: center; justify-content: space-between; color: #cbd5e1; }
.sdt-mockup__label { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: #94a3b8; font-weight: 700; }
.sdt-mockup__score { font-size: 22px; font-weight: 800; color: var(--yellow); letter-spacing: -.02em;
	animation: sdtAuditCount 4s ease-out 0.4s infinite;
}
.sdt-mockup__bar { height: 6px; background: rgba(255,255,255,0.08); border-radius: 999px; overflow: hidden; }
.sdt-mockup__bar-fill {
	display: block; height: 100%; width: 47%;
	background: linear-gradient(90deg, #06b6d4, #facc15);
	border-radius: 999px;
	animation: sdtAuditBar 4s ease-out 0.4s infinite;
}
.sdt-mockup__checks { display: flex; gap: 6px; }
.sdt-mockup__check {
	font-size: 10px; font-weight: 700; letter-spacing: .05em; text-transform: uppercase;
	padding: 4px 8px; border-radius: 999px;
	background: rgba(6,182,212,0.12); color: #67e8f9;
	opacity: 0;
}
.sdt-mockup__check--1 { animation: sdtFadeIn .5s ease-out 1.2s infinite; }
.sdt-mockup__check--2 { animation: sdtFadeIn .5s ease-out 1.6s infinite; }
.sdt-mockup__check--3 { animation: sdtFadeIn .5s ease-out 2.0s infinite; }
@keyframes sdtAuditBar {
	0%   { width: 47%; }
	60%  { width: 92%; }
	100% { width: 92%; }
}
@keyframes sdtAuditCount {
	/* Visually counts via a CSS scaling trick: the number text is set to 47 in
	   HTML; we use scale + content-visibility to swap the rendered number with
	   the data-end value at the 60% mark. */
	0%, 100% { color: #94a3b8; }
	60%, 99% { color: var(--yellow); }
}
.sdt-mockup__score { position: relative; }
.sdt-mockup__score::after {
	content: attr(data-end);
	position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: flex-end;
	color: var(--yellow);
	opacity: 0;
	animation: sdtScoreSwap 4s ease-out 0.4s infinite;
}
@keyframes sdtScoreSwap {
	0%, 55% { opacity: 0; }
	60%, 100% { opacity: 1; }
}
.sdt-mockup__score { color: #94a3b8; }

/* ── Mockup: Business Claims ──────────────────────────────────────────────── */
.sdt-mockup--claim { display: flex; flex-direction: column; gap: 10px; }
.sdt-mockup__email {
	display: flex; align-items: center; gap: 10px;
	color: #cbd5e1; font-size: 13px; font-weight: 600;
	padding: 8px 10px;
	background: rgba(255,255,255,0.06);
	border-radius: 8px;
	animation: sdtEmailPulse 3.5s ease-in-out infinite;
}
.sdt-mockup__email svg { color: var(--cyan); }
@keyframes sdtEmailPulse {
	0%, 100% { transform: translateY(0); box-shadow: 0 0 0 0 rgba(6,182,212,0); }
	30%      { transform: translateY(-2px); box-shadow: 0 0 0 4px rgba(6,182,212,0.18); }
	60%      { transform: translateY(0); box-shadow: 0 0 0 0 rgba(6,182,212,0); }
}
.sdt-mockup__check-row { display: flex; gap: 6px; }
.sdt-mockup__pill {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 10px; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
	padding: 4px 8px; border-radius: 999px;
	background: rgba(255,255,255,0.06); color: #94a3b8;
	opacity: 0;
}
.sdt-mockup__pill--1 { animation: sdtFadeIn .5s ease-out 0.6s infinite; }
.sdt-mockup__pill--2 { animation: sdtFadeIn .5s ease-out 1.4s infinite; }
.sdt-mockup__pill--3 { animation: sdtClaimedIn .6s ease-out 2.2s infinite; background: rgba(34,197,94,0.18); color: #86efac; }
.sdt-mockup__pill--3 svg { stroke: #86efac; }
@keyframes sdtClaimedIn {
	0%   { opacity: 0; transform: scale(0.7); }
	60%  { opacity: 1; transform: scale(1.1); }
	100% { opacity: 1; transform: scale(1); }
}

/* ── Mockup: Programmatic SEO Pages ───────────────────────────────────────── */
.sdt-mockup--psd { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; }
.sdt-mockup__pages { display: flex; flex-direction: column; gap: 4px; }
.sdt-mockup__page {
	font-size: 11px; color: #67e8f9; padding: 4px 8px;
	background: rgba(6,182,212,0.08); border-radius: 4px;
	opacity: 0; transform: translateX(-6px);
}
.sdt-mockup__page--1 { animation: sdtPageIn .5s ease-out 0.3s infinite; }
.sdt-mockup__page--2 { animation: sdtPageIn .5s ease-out 0.9s infinite; }
.sdt-mockup__page--3 { animation: sdtPageIn .5s ease-out 1.5s infinite; }
.sdt-mockup__page--4 { animation: sdtPageIn .5s ease-out 2.1s infinite; color: var(--yellow); background: rgba(250,204,21,0.08); }
@keyframes sdtPageIn {
	0%   { opacity: 0; transform: translateX(-6px); }
	60%  { opacity: 1; transform: translateX(0); }
	100% { opacity: 1; transform: translateX(0); }
}

/* ── Mockup: AI Semantic Search ───────────────────────────────────────────── */
.sdt-mockup--search { display: flex; flex-direction: column; gap: 10px; }
.sdt-mockup__search {
	display: flex; align-items: center; gap: 8px;
	padding: 8px 10px;
	background: rgba(255,255,255,0.06);
	border-radius: 8px;
	font-size: 12px; color: #e2e8f0;
}
.sdt-mockup__search svg { color: var(--cyan); flex-shrink: 0; }
.sdt-mockup__search-text {
	overflow: hidden; white-space: nowrap; min-height: 1em;
	animation: sdtTypeQuery 6s steps(20, end) infinite;
	width: 0;
}
.sdt-mockup__search-text::before { content: "best pizza near me"; }
.sdt-mockup__cursor {
	display: inline-block; width: 2px; height: 12px;
	background: var(--cyan);
	animation: sdtBlink 0.8s steps(2) infinite;
}
@keyframes sdtTypeQuery {
	0%, 5%   { width: 0; }
	45%      { width: 9em; }
	85%      { width: 9em; }
	100%     { width: 0; }
}
@keyframes sdtBlink { 0%, 50% { opacity: 1; } 50.01%, 100% { opacity: 0; } }
.sdt-mockup__results { display: flex; flex-direction: column; gap: 4px; }
.sdt-mockup__result {
	font-size: 11px; color: #cbd5e1; padding: 4px 8px;
	background: rgba(255,255,255,0.03);
	border-radius: 4px;
	border-left: 2px solid var(--cyan);
	opacity: 0;
}
.sdt-mockup__result--1 { animation: sdtFadeIn .5s ease-out 3.0s infinite; }
.sdt-mockup__result--2 { animation: sdtFadeIn .5s ease-out 3.4s infinite; }
.sdt-mockup__result--3 { animation: sdtFadeIn .5s ease-out 3.8s infinite; }

@keyframes sdtFadeIn {
	0%   { opacity: 0; transform: translateY(4px); }
	60%  { opacity: 1; transform: translateY(0); }
	100% { opacity: 1; transform: translateY(0); }
}

/* Card-level idle glow, all variants */
.sdt-cta-card {
	transition: transform .25s ease-out, box-shadow .25s ease-out;
	animation: sdtCardGlow 6s ease-in-out infinite;
}
.sdt-cta-card:hover { transform: translateY(-2px); }
@keyframes sdtCardGlow {
	0%, 100% { box-shadow: 0 12px 32px -18px rgba(6,182,212,0.0), var(--shadow-md); }
	50%      { box-shadow: 0 12px 32px -10px rgba(6,182,212,0.35), var(--shadow-md); }
}

/* Respect motion preferences. */
@media (prefers-reduced-motion: reduce) {
	.sdt-cta-card,
	.sdt-mockup *,
	.sdt-mockup__search-text,
	.sdt-mockup__cursor,
	.sdt-mockup__bar-fill,
	.sdt-mockup__score::after,
	.sdt-mockup__check,
	.sdt-mockup__pill,
	.sdt-mockup__page,
	.sdt-mockup__result,
	.sdt-mockup__email {
		animation: none !important;
		opacity: 1 !important;
		transform: none !important;
		width: auto !important;
	}
}

/* Author box */
.sdt-author {
	margin-top: 48px; padding: 24px;
	background: var(--paper-2);
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	display: flex; gap: 18px; align-items: flex-start;
}
.sdt-author__avatar img {
	width: 64px; height: 64px;
	border-radius: 50%;
	display: block;
}
.sdt-author__body { flex: 1; min-width: 0; }
.sdt-author__row {
	display: flex; align-items: baseline; gap: 12px;
	margin-bottom: 6px;
}
.sdt-author__name {
	font-weight: 700; font-size: 16px;
	color: var(--navy);
}
.sdt-author__more {
	font-size: 13px; color: var(--cyan);
	text-decoration: none;
}
.sdt-author__more:hover { text-decoration: underline; }
.sdt-author__bio {
	margin: 0;
	color: var(--muted);
	font-size: 14px; line-height: 1.55;
}

@media (max-width: 980px) {
	.sdt-post__layout { grid-template-columns: 1fr; gap: 40px; }
	.sdt-post__rail { order: 2; }
	.sdt-post__article { order: 1; }
	.sdt-post__rail-inner { position: static; max-height: none; overflow: visible; }
	.sdt-toc { display: none; } /* TOC takes too much room on mobile, drop it */
}
@media (max-width: 600px) {
	.sdt-shell--post { padding: 36px 0 64px; }
	.sdt-post__hero { margin-bottom: 32px; }
	.sdt-author { flex-direction: column; gap: 12px; }
}

/* =============================================================================
 * Support page (page-support.php) + SDP Support Tickets form theming.
 * =========================================================================== */

.sdt-shell--narrow { padding: 56px 0 96px; }
.sdt-support-shell { max-width: 720px; margin: 0 auto; }
.sdt-support-shell .ticket-form,
.sdt-support-shell #support-ticket-form-container {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 32px;
	box-shadow: var(--shadow-md);
}
.sdt-support-shell .form-row { margin: 0 0 18px; }
.sdt-support-shell .form-row label {
	display: block;
	font-size: 13px; font-weight: 600;
	color: var(--ink); margin-bottom: 6px;
}
.sdt-support-shell .required { color: #ef4444; }
.sdt-support-shell input[type="text"],
.sdt-support-shell input[type="email"],
.sdt-support-shell select,
.sdt-support-shell textarea {
	width: 100%;
	padding: 11px 14px;
	border: 1px solid var(--line-2);
	border-radius: 10px;
	background: #fff;
	font: inherit; font-size: 15px; color: var(--ink);
	outline: none;
	transition: border-color .15s, box-shadow .15s;
}
.sdt-support-shell input:focus,
.sdt-support-shell select:focus,
.sdt-support-shell textarea:focus {
	border-color: var(--cyan);
	box-shadow: 0 0 0 4px rgba(6,182,212,.12);
}
.sdt-support-shell textarea { min-height: 160px; resize: vertical; }
.sdt-support-shell .description {
	margin-top: 4px;
	color: var(--muted); font-size: 12.5px;
}
.sdt-support-shell .form-submit { margin-top: 6px; display: flex; align-items: center; gap: 12px; }
.sdt-support-shell .button.primary,
.sdt-support-shell button[type="submit"] {
	background: var(--yellow);
	color: var(--navy);
	border: 0;
	padding: 12px 22px;
	border-radius: 10px;
	font-weight: 700; font-size: 14.5px;
	cursor: pointer;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px -10px rgba(250,204,21,.5);
	transition: transform .12s, background .15s;
}
.sdt-support-shell .button.primary:hover,
.sdt-support-shell button[type="submit"]:hover {
	background: #ffd83a; transform: translateY(-1px);
}
.sdt-support-shell .form-message {
	padding: 14px 18px;
	border-radius: 10px;
	margin-bottom: 18px;
	font-size: 14px;
}
.sdt-support-shell .form-message.success { background: #ecfdf5; color: #065f46; border: 1px solid #a7f3d0; }
.sdt-support-shell .form-message.error   { background: #fef2f2; color: #991b1b; border: 1px solid #fecaca; }
.sdt-support-shell .ticket-success {
	background: rgba(6,182,212,.06);
	border: 1px solid rgba(6,182,212,.25);
	border-radius: var(--r-lg);
	padding: 32px; text-align: center;
}
.sdt-support-shell .ticket-success h3 { color: var(--navy); font-size: 22px; margin: 12px 0 8px; }
.sdt-support-shell .ticket-reference strong {
	display: inline-block;
	padding: 4px 10px;
	border-radius: 6px;
	background: var(--navy); color: #fff;
	font-family: 'JetBrains Mono', monospace;
	font-size: 13px;
}
.sdt-support-faq { margin-top: 56px; padding-top: 40px; border-top: 1px solid var(--line); }
.sdt-shell__h2 {
	font-size: 22px; font-weight: 700; color: var(--navy);
	margin: 0 0 24px; letter-spacing: -.01em;
}

/* =============================================================================
 * Single EDD download (single-download.php).
 * =========================================================================== */

.sdt-shell--product { padding: 56px 0 96px; }
.sdt-product__head { text-align: center; max-width: 720px; margin: 0 auto 40px; }
.sdt-product__title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(32px, 4.5vw, 48px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.1;
	color: var(--navy);
	margin: 8px 0 14px;
}
.sdt-product__sub {
	color: var(--muted);
	font-size: 17px; line-height: 1.55;
}
.sdt-product__layout {
	display: grid;
	grid-template-columns: minmax(0, 1fr) 340px;
	gap: 56px;
	max-width: 1180px; margin: 0 auto;
	align-items: start;
}
.sdt-product__main { min-width: 0; }
.sdt-product__hero {
	border-radius: var(--r-xl);
	overflow: hidden;
	margin-bottom: 36px;
	box-shadow: var(--shadow-md);
}
.sdt-product__hero img { width: 100%; height: auto; display: block; }
.sdt-product__content { font-size: 16.5px; line-height: 1.7; color: var(--ink); }
.sdt-product__content h2 {
	font-size: 24px; font-weight: 700; color: var(--navy);
	margin: 36px 0 14px; letter-spacing: -.015em;
}
.sdt-product__content h3 {
	font-size: 19px; font-weight: 600; color: var(--navy);
	margin: 28px 0 10px;
}
.sdt-product__content ul, .sdt-product__content ol { margin: 0 0 1.2em; padding-left: 1.4em; }
.sdt-product__content li { margin-bottom: .4em; }
.sdt-product__content p { margin: 0 0 1.1em; }
.sdt-product__content strong { color: var(--navy); }

/* Buy card */
.sdt-product__rail { position: relative; }
.sdt-product__buy-card {
	position: sticky;
	top: 96px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 28px;
	box-shadow: var(--shadow-md);
}
.sdt-product__buy-kicker {
	font-size: 11px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em;
	color: var(--cyan);
	margin-bottom: 6px;
}
.sdt-product__buy-name {
	font-size: 22px; font-weight: 700;
	color: var(--navy); margin-bottom: 12px;
}
.sdt-product__buy-price {
	font-size: 34px; font-weight: 800; letter-spacing: -.02em;
	color: var(--navy);
	margin: 0 0 24px;
}
.sdt-product__buy-period {
	font-size: 16px; font-weight: 500; color: var(--muted);
	margin-left: 6px;
}
.sdt-product__buy-btn {
	display: block; width: 100%;
	text-align: center;
	background: var(--yellow) !important;
	color: var(--navy) !important;
	padding: 14px 22px !important;
	border-radius: 12px !important;
	font-weight: 700 !important; font-size: 15px !important;
	border: 0 !important;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px -10px rgba(250,204,21,.5) !important;
	transition: transform .12s, background .15s !important;
}
.sdt-product__buy-btn:hover {
	background: #ffd83a !important;
	transform: translateY(-1px);
}
.sdt-product__buy-trust {
	list-style: none; padding: 0; margin: 22px 0 0;
	color: var(--muted); font-size: 13.5px; line-height: 1.45;
}
.sdt-product__buy-trust li {
	display: flex; align-items: center; gap: 8px;
	padding: 6px 0;
}
.sdt-product__buy-trust li svg { color: var(--cyan); flex-shrink: 0; }
.sdt-product__buy-secondary {
	margin-top: 18px;
	padding-top: 18px;
	border-top: 1px solid var(--line);
	font-size: 13.5px;
}
.sdt-product__buy-secondary a {
	color: var(--cyan);
	text-decoration: none;
}
.sdt-product__buy-secondary a:hover { text-decoration: underline; }

/* =============================================================================
 * EDD download archive (archive-download.php).
 * =========================================================================== */

.sdt-shell--catalog { padding: 56px 0 96px; }
.sdt-catalog__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 28px;
	max-width: 1100px; margin: 0 auto;
}
.sdt-catalog__card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 28px;
	display: flex; flex-direction: column;
	transition: border-color .2s, transform .2s, box-shadow .2s;
}
.sdt-catalog__card:hover {
	border-color: var(--cyan);
	transform: translateY(-2px);
	box-shadow: 0 12px 28px -16px rgba(6,182,212,.4);
}
.sdt-catalog__card-img { display: block; margin: -28px -28px 20px; border-radius: var(--r-xl) var(--r-xl) 0 0; overflow: hidden; }
.sdt-catalog__card-img img { width: 100%; height: 180px; object-fit: cover; display: block; }
.sdt-catalog__card-body { display: flex; flex-direction: column; flex: 1; }
.sdt-catalog__card-title {
	font-size: 22px; font-weight: 700;
	color: var(--navy);
	margin: 0 0 8px; letter-spacing: -.015em;
}
.sdt-catalog__card-title a { color: inherit; text-decoration: none; }
.sdt-catalog__card-title a:hover { color: var(--cyan); }
.sdt-catalog__card-excerpt {
	color: var(--muted);
	font-size: 14.5px; line-height: 1.55;
	margin: 0 0 16px;
	flex: 1;
}
.sdt-catalog__card-price {
	font-size: 26px; font-weight: 800; letter-spacing: -.015em;
	color: var(--navy);
	margin: 0 0 18px;
}
.sdt-catalog__card-period {
	font-size: 14px; font-weight: 500; color: var(--muted);
	margin-left: 4px;
}
.sdt-catalog__card-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 10px 18px;
	background: var(--navy);
	color: #fff !important;
	border-radius: 10px;
	font-weight: 600; font-size: 14px;
	text-decoration: none;
	align-self: flex-start;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.12), 0 1px 2px rgba(10,23,51,.2);
	transition: transform .12s, background .15s;
}
.sdt-catalog__card-btn:hover { background: #050e23; transform: translateY(-1px); }

@media (max-width: 900px) {
	.sdt-product__layout { grid-template-columns: 1fr; gap: 36px; }
	.sdt-product__buy-card { position: static; }
}
@media (max-width: 600px) {
	.sdt-shell--narrow, .sdt-shell--product, .sdt-shell--catalog { padding: 36px 0 64px; }
	.sdt-support-shell .ticket-form, .sdt-support-shell #support-ticket-form-container { padding: 22px; }
}

/* =============================================================================
 * Support centre — restructured hero + FAQ + ticket form sections.
 * Uses the SDP Support Tickets plugin's shortcodes underneath.
 * =========================================================================== */

.sdt-support { background: #fff; }

.sdt-support__hero {
	padding: 80px 0 48px;
	background:
		radial-gradient(ellipse at top right, rgba(6,182,212,.06), transparent 60%),
		radial-gradient(ellipse at bottom left, rgba(250,204,21,.05), transparent 50%),
		#fafcff;
	text-align: center;
}
.sdt-support__title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(32px, 5vw, 52px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.1;
	color: var(--navy);
	margin: 8px 0 14px;
}
.sdt-support__sub {
	color: var(--muted);
	font-size: 18px; line-height: 1.55;
	max-width: 580px; margin: 0 auto;
}
.sdt-support__quick {
	display: flex; justify-content: center; gap: 12px;
	margin-top: 28px; flex-wrap: wrap;
}

.sdt-support__faq {
	padding: 64px 0 48px;
}
.sdt-support__faq .section-head { text-align: center; margin-bottom: 40px; }

/* Documentation callout (between FAQ and ticket form). */
.sdt-support__docs {
	padding: 48px 0;
	background: var(--paper-2);
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
}
.sdt-support__docs .section-head { text-align: center; margin-bottom: 32px; }
.sdt-support-docs__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 16px;
	margin-bottom: 32px;
}
.sdt-support-docs__card {
	display: flex;
	flex-direction: column;
	gap: 6px;
	padding: 20px 22px;
	background: var(--paper);
	border: 1px solid var(--line);
	border-radius: var(--r-md);
	text-decoration: none;
	transition: border-color .15s, box-shadow .15s, transform .15s;
}
.sdt-support-docs__card:hover {
	border-color: var(--cyan);
	box-shadow: 0 4px 18px rgba(6,182,212,.1);
	transform: translateY(-2px);
}
.sdt-support-docs__name { font-weight: 700; color: var(--ink); font-size: .98rem; }
.sdt-support-docs__desc { font-size: .84rem; color: var(--muted); line-height: 1.5; }
.sdt-support-docs__count {
	font-size: .7rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
	color: var(--cyan); margin-top: 2px;
}
.sdt-support-docs__cta { text-align: center; }

.sdt-support__form-section {
	padding: 48px 0 96px;
	background: linear-gradient(180deg, #fafcff, #fff);
}
.sdt-support__form-section .section-head { text-align: center; margin-bottom: 32px; }

/* Override plugin FAQ styling so it matches the SDP brand and so the
 * .active expansion is unambiguous regardless of other CSS on the page. */
.sdt-support .support-faq > h2,
.sdt-support .faq-items > h2 { display: none; } /* plugin renders its own H2, drop it (we have a section-head) */

.sdt-support .faq-items {
	max-width: 760px;
	margin: 0 auto;
}
.sdt-support .faq-item {
	background: #fff;
	border: 1px solid var(--line) !important;
	border-radius: var(--r-lg) !important;
	margin-bottom: 12px !important;
	overflow: hidden !important;
	transition: border-color .15s, box-shadow .15s;
}
.sdt-support .faq-item:hover { border-color: var(--cyan) !important; }
.sdt-support .faq-item.active {
	border-color: var(--cyan) !important;
	box-shadow: 0 4px 16px -8px rgba(6,182,212,.25);
}
.sdt-support .faq-question {
	padding: 18px 22px !important;
	background: #fff !important;
	cursor: pointer;
	display: flex !important; align-items: center !important; justify-content: space-between !important;
	gap: 16px;
	outline: none;
}
.sdt-support .faq-question:hover { background: #fafcff !important; }
.sdt-support .faq-question:focus-visible { background: rgba(6,182,212,.06) !important; }
.sdt-support .faq-question h3 {
	margin: 0 !important;
	font-size: 16.5px !important;
	font-weight: 600 !important;
	color: var(--navy) !important;
	letter-spacing: -.005em;
	line-height: 1.4;
}
.sdt-support .toggle-icon {
	width: 28px; height: 28px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
	background: var(--paper-2);
	color: var(--cyan);
	font-size: 12px;
	flex-shrink: 0;
	transition: transform .2s, background .15s;
}
.sdt-support .faq-item.active .toggle-icon {
	background: var(--cyan);
	color: #fff;
	transform: rotate(45deg);
}

/* The expansion — explicit + !important so plugin/transition rules can't
 * leave answers permanently collapsed. */
.sdt-support .faq-answer {
	padding: 0 22px !important;
	max-height: 0 !important;
	overflow: hidden !important;
	transition: max-height .35s ease, padding .25s ease !important;
	color: var(--ink);
	font-size: 15px;
	line-height: 1.6;
}
.sdt-support .faq-item.active .faq-answer {
	max-height: 1200px !important;
	padding: 0 22px 20px !important;
}
.sdt-support .faq-answer p { margin: 0 0 .85em; }
.sdt-support .faq-answer p:last-child { margin-bottom: 0; }
.sdt-support .faq-answer a { color: var(--cyan); }

@media (max-width: 600px) {
	.sdt-support__hero { padding: 56px 0 32px; }
	.sdt-support__faq, .sdt-support__form-section { padding: 40px 0 56px; }
	.sdt-support__quick { flex-direction: column; gap: 8px; }
	.sdt-support__quick .btn { width: 100%; justify-content: center; }
}

/* =============================================================================
 * Blog single hero, faint 56×56 lattice fading vertically.
 * Mirrors .hero-bg-grid::after on the marketing landing, but with a linear
 * vertical-fade mask so the grid sits behind the title block and disappears
 * by the time the article content starts.
 * =========================================================================== */

.sdt-shell--post { position: relative; overflow: hidden; }
.sdt-shell--post::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 540px;
	pointer-events: none;
	z-index: 0;
	background-image:
		linear-gradient(to right,  rgba(10,23,51,.055) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(10,23,51,.055) 1px, transparent 1px);
	background-size: 56px 56px;
	background-position: center top;
	-webkit-mask-image: linear-gradient(to bottom, #000 0%, #000 55%, transparent 100%);
	        mask-image: linear-gradient(to bottom, #000 0%, #000 55%, transparent 100%);
}

/* Hero soft glow behind the title so the lattice doesn't feel cold. */
.sdt-shell--post::after {
	content: "";
	position: absolute;
	top: -40px; left: 50%; transform: translateX(-50%);
	width: 90%; max-width: 1100px; height: 380px;
	pointer-events: none; z-index: 0;
	background:
		radial-gradient(ellipse 70% 60% at 50% 0%, rgba(6,182,212,.10), transparent 60%),
		radial-gradient(ellipse 50% 40% at 80% 30%, rgba(250,204,21,.08), transparent 65%);
}

/* Make sure all post content sits above the lattice. */
.sdt-shell--post > .container { position: relative; z-index: 1; }

/* =============================================================================
 * Single download (conversion-focused) — replaces the earlier 2-col layout.
 * Hero band → feature cards → compare matrix → buyer FAQ → final CTA.
 * =========================================================================== */

.sdt-product { background: #fff; }

/* ── Hero band ─────────────────────────────────────────────────────────── */
.sdt-product__hero {
	position: relative;
	padding: 88px 0 64px;
	overflow: hidden;
	background:
		radial-gradient(ellipse 70% 50% at 30% 0%,  rgba(6,182,212,.12), transparent 60%),
		radial-gradient(ellipse 50% 40% at 90% 20%, rgba(250,204,21,.10), transparent 65%),
		linear-gradient(180deg, #fafcff, #ffffff 70%);
}
.sdt-product__hero::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background-image:
		linear-gradient(to right,  rgba(10,23,51,.05) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(10,23,51,.05) 1px, transparent 1px);
	background-size: 56px 56px;
	-webkit-mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
	        mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
}
.sdt-product__hero > .container { position: relative; }

.sdt-product__hero-grid {
	display: grid; grid-template-columns: 1.15fr .85fr;
	gap: 64px; align-items: center;
}
.sdt-product__hero-copy { min-width: 0; }
.sdt-product__title {
	font-family: 'Inter', sans-serif;
	font-size: clamp(36px, 5vw, 56px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.05;
	color: var(--navy);
	margin: 12px 0 16px;
}
.sdt-product__tagline {
	color: var(--ink);
	font-size: 18px; line-height: 1.55;
	margin: 0 0 28px;
	max-width: 540px;
}

.sdt-product__buy-row {
	display: flex; align-items: center; gap: 24px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 18px 22px;
	box-shadow: 0 12px 32px -20px rgba(10,23,51,.25);
	margin-bottom: 18px;
	flex-wrap: wrap;
}
.sdt-product__price-block { display: flex; flex-direction: column; }
.sdt-product__price {
	font-size: 36px; font-weight: 800; letter-spacing: -.02em;
	color: var(--navy);
	line-height: 1;
}
.sdt-product__price .edd_price { color: inherit; }
.sdt-product__price-period {
	font-size: 13px; color: var(--muted); margin-top: 4px;
}
.sdt-product__buy-action { flex: 1; }
.sdt-product__hero-btn {
	display: inline-block !important;
	background: var(--yellow) !important;
	color: var(--navy) !important;
	padding: 14px 28px !important;
	border-radius: 12px !important;
	font-weight: 700 !important; font-size: 15.5px !important;
	border: 0 !important;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px -10px rgba(250,204,21,.55) !important;
	text-decoration: none !important;
	transition: transform .12s, background .15s !important;
	white-space: nowrap;
}
.sdt-product__hero-btn:hover {
	background: #ffd83a !important;
	transform: translateY(-1px);
}

.sdt-product__trust-row {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; gap: 18px;
	color: var(--muted); font-size: 14px;
}
.sdt-product__trust-row li {
	display: inline-flex; align-items: center; gap: 6px;
}
.sdt-product__trust-row svg { color: var(--cyan); }

/* Hero visual card — the big "tier" mockup on the right */
.sdt-product__hero-visual {
	position: relative;
	min-width: 0;
}
.sdt-product__visual-badge {
	position: absolute; top: -16px; left: 50%; transform: translateX(-50%);
	z-index: 3;
	background: var(--yellow);
	color: var(--navy);
	font-size: 11px; font-weight: 800;
	letter-spacing: .12em;
	padding: 6px 14px;
	border-radius: 999px;
	box-shadow: 0 6px 14px -6px rgba(250,204,21,.6);
}
.sdt-product__visual-glow {
	position: absolute; inset: -20px;
	background: radial-gradient(circle at 50% 50%, rgba(6,182,212,.16), transparent 65%);
	filter: blur(20px);
	pointer-events: none;
}
.sdt-product__hero-visual[data-color="yellow"] .sdt-product__visual-glow {
	background: radial-gradient(circle at 50% 50%, rgba(250,204,21,.22), transparent 65%);
}
.sdt-product__hero-visual[data-color="navy"] .sdt-product__visual-glow {
	background: radial-gradient(circle at 50% 50%, rgba(10,23,51,.14), transparent 65%);
}

.sdt-product__visual-card {
	position: relative; z-index: 2;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 24px;
	padding: 36px 32px;
	text-align: center;
	box-shadow: 0 22px 48px -28px rgba(10,23,51,.35);
	transform: rotate(-1.5deg);
	transition: transform .25s ease;
}
.sdt-product__visual-card:hover { transform: rotate(0deg); }

.sdt-product__visual-icon {
	width: 78px; height: 78px;
	margin: 0 auto 20px;
	border-radius: 22px;
	display: grid; place-items: center;
	background: linear-gradient(135deg, var(--cyan), #0891b2);
	color: #fff;
	box-shadow: 0 8px 20px -10px rgba(6,182,212,.6);
}
.sdt-product__hero-visual[data-color="yellow"] .sdt-product__visual-icon {
	background: linear-gradient(135deg, var(--yellow), #facc15);
	color: var(--navy);
	box-shadow: 0 8px 20px -10px rgba(250,204,21,.6);
}
.sdt-product__hero-visual[data-color="navy"] .sdt-product__visual-icon {
	background: linear-gradient(135deg, var(--navy), #050e23);
	color: #fff;
}

.sdt-product__visual-name {
	font-size: 22px; font-weight: 800; letter-spacing: -.01em;
	color: var(--navy);
}
.sdt-product__visual-tier {
	font-size: 12px;
	color: var(--muted);
	text-transform: uppercase; letter-spacing: .08em;
	margin: 6px 0 18px;
}
.sdt-product__visual-price {
	font-size: 28px; font-weight: 800; letter-spacing: -.02em;
	color: var(--navy);
	margin-bottom: 18px;
}
.sdt-product__visual-per {
	font-size: 13px; font-weight: 500; color: var(--muted);
	margin-left: 4px;
}
.sdt-product__visual-marks {
	display: flex; justify-content: center; gap: 4px;
}
.sdt-product__visual-mark {
	width: 22px; height: 4px;
	border-radius: 2px;
	background: linear-gradient(90deg, var(--cyan), var(--cyan-2, var(--cyan)));
	opacity: .85;
}
.sdt-product__hero-visual[data-color="yellow"] .sdt-product__visual-mark {
	background: linear-gradient(90deg, var(--yellow), #facc15);
}
.sdt-product__hero-visual[data-color="navy"] .sdt-product__visual-mark {
	background: linear-gradient(90deg, var(--navy), #1e293b);
}

/* ── Features grid ─────────────────────────────────────────────────────── */
.sdt-product__features { padding: 80px 0 56px; }
.sdt-product__features .section-head { text-align: center; margin-bottom: 48px; }
.sdt-product__features-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
	max-width: 1100px; margin: 0 auto;
}
.sdt-product__feature-card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 24px 22px;
	transition: border-color .2s, transform .2s, box-shadow .2s;
}
.sdt-product__feature-card:hover {
	border-color: var(--cyan);
	transform: translateY(-3px);
	box-shadow: 0 14px 28px -18px rgba(6,182,212,.32);
}
.sdt-product__feature-icon {
	width: 44px; height: 44px;
	border-radius: 12px;
	background: rgba(6,182,212,.10);
	color: var(--cyan);
	display: grid; place-items: center;
	margin-bottom: 16px;
}
.sdt-product__feature-title {
	font-size: 16px; font-weight: 700;
	color: var(--navy);
	margin: 0 0 6px;
	letter-spacing: -.005em;
}
.sdt-product__feature-desc {
	color: var(--muted);
	font-size: 14px; line-height: 1.55;
	margin: 0;
}

/* ── Compare matrix ────────────────────────────────────────────────────── */
.sdt-product__compare {
	padding: 56px 0 80px;
	background: linear-gradient(180deg, #fafcff 0%, #ffffff 100%);
}
.sdt-product__compare .section-head { text-align: center; margin-bottom: 40px; }

.sdt-compare {
	max-width: 980px; margin: 0 auto;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: 0 12px 32px -22px rgba(10,23,51,.18);
}
.sdt-compare__row {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	align-items: stretch;
	border-bottom: 1px solid var(--line);
}
.sdt-compare__row:last-child { border-bottom: 0; }
.sdt-compare__row--head { background: var(--paper-2); }
.sdt-compare__row--foot { background: #fafcff; }
.sdt-compare__cell {
	padding: 14px 18px;
	font-size: 14px;
	color: var(--ink);
	display: flex; align-items: center; justify-content: center;
	text-align: center;
}
.sdt-compare__cell--label {
	justify-content: flex-start; text-align: left;
	color: var(--navy); font-weight: 500;
}
.sdt-compare__cell--col { padding: 18px; }
.sdt-compare__cell.is-current {
	background: rgba(6,182,212,.05);
	box-shadow: inset 2px 0 0 var(--cyan), inset -2px 0 0 var(--cyan);
}
.sdt-compare__row--head .sdt-compare__cell.is-current { box-shadow: inset 2px 0 0 var(--cyan), inset -2px 0 0 var(--cyan), inset 0 2px 0 var(--cyan); }
.sdt-compare__row--foot .sdt-compare__cell.is-current { box-shadow: inset 2px 0 0 var(--cyan), inset -2px 0 0 var(--cyan), inset 0 -2px 0 var(--cyan); }

.sdt-compare__col-name {
	font-size: 17px; font-weight: 700;
	color: var(--navy);
	display: flex; flex-direction: column; align-items: center; gap: 6px;
}
.sdt-compare__col-tag {
	font-size: 10px; font-weight: 700; letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--cyan);
	padding: 2px 8px;
	background: rgba(6,182,212,.12);
	border-radius: 999px;
}
.sdt-compare__yes {
	display: inline-grid; place-items: center;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: rgba(6,182,212,.12);
	color: var(--cyan);
}
.sdt-compare__no { color: #cbd5e1; font-weight: 700; }
.sdt-compare__val { font-weight: 600; color: var(--navy); }
.sdt-compare__here {
	font-size: 12px; font-weight: 700; letter-spacing: .04em;
	color: var(--cyan); text-transform: uppercase;
}
.sdt-compare__switch {
	font-size: 13px; font-weight: 600;
	color: var(--cyan); text-decoration: none;
}
.sdt-compare__switch:hover { text-decoration: underline; }

/* ── Buyer FAQ ─────────────────────────────────────────────────────────── */
.sdt-product__faq { padding: 64px 0 56px; }
.sdt-product__faq .section-head { text-align: center; margin-bottom: 32px; }
.sdt-product__faq-list { max-width: 760px; margin: 0 auto; }
.sdt-product__faq-item {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	margin-bottom: 12px;
	overflow: hidden;
	transition: border-color .15s, box-shadow .15s;
}
.sdt-product__faq-item:hover { border-color: var(--cyan); }
.sdt-product__faq-item.open {
	border-color: var(--cyan);
	box-shadow: 0 4px 16px -8px rgba(6,182,212,.25);
}
.sdt-product__faq-q {
	width: 100%;
	background: #fff; border: 0; cursor: pointer;
	padding: 18px 22px;
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px;
	font: inherit; text-align: left;
	font-weight: 600; color: var(--navy); font-size: 16px;
}
.sdt-product__faq-q:hover { background: #fafcff; }
.sdt-product__faq-plus {
	width: 28px; height: 28px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 50%;
	background: var(--paper-2);
	color: var(--cyan);
	flex-shrink: 0;
	transition: transform .2s, background .15s, color .15s;
}
.sdt-product__faq-item.open .sdt-product__faq-plus {
	background: var(--cyan); color: #fff; transform: rotate(45deg);
}
.sdt-product__faq-a {
	max-height: 0; overflow: hidden;
	padding: 0 22px;
	color: var(--ink); font-size: 14.5px; line-height: 1.6;
	transition: max-height .35s ease, padding .25s ease;
}
.sdt-product__faq-item.open .sdt-product__faq-a {
	max-height: 800px;
	padding: 0 22px 18px;
}
.sdt-product__faq-a a { color: var(--cyan); }

/* ── Final CTA strip ───────────────────────────────────────────────────── */
.sdt-product__final {
	padding: 64px 0 88px;
	text-align: center;
	background:
		radial-gradient(ellipse 60% 50% at 50% 0%, rgba(6,182,212,.10), transparent 60%),
		linear-gradient(180deg, #fafcff, #fff);
}
.sdt-product__final-title {
	font-size: clamp(28px, 4vw, 38px);
	font-weight: 700; letter-spacing: -.02em;
	color: var(--navy);
	margin: 0 0 12px;
}
.sdt-product__final-sub {
	font-size: 16px; color: var(--muted);
	margin: 0 0 28px;
	max-width: 560px; margin-left: auto; margin-right: auto;
}
.sdt-product__final-cta { margin-bottom: 14px; }
.sdt-product__final-btn {
	background: var(--yellow) !important;
	color: var(--navy) !important;
	padding: 16px 32px !important;
	border-radius: 12px !important;
	font-weight: 700 !important; font-size: 16px !important;
	border: 0 !important;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 10px 22px -12px rgba(250,204,21,.55) !important;
	text-decoration: none !important;
	transition: transform .12s, background .15s !important;
}
.sdt-product__final-btn:hover { background: #ffd83a !important; transform: translateY(-1px); }
.sdt-product__final-meta {
	font-size: 13px; color: var(--muted);
}
.sdt-product__final-meta a { color: var(--cyan); }

/* ── Sticky mobile buy bar ─────────────────────────────────────────────── */
.sdt-product__sticky {
	position: fixed; bottom: 0; left: 0; right: 0;
	background: #fff;
	border-top: 1px solid var(--line);
	box-shadow: 0 -10px 24px -16px rgba(10,23,51,.18);
	padding: 12px 0;
	z-index: 100;
	transform: translateY(110%);
	transition: transform .25s ease;
}
.sdt-product__sticky.is-visible { transform: translateY(0); }
.sdt-product__sticky .sdt-product__hero-btn {
	display: block !important;
	width: 100%; text-align: center;
}

/* ── Responsive ────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
	.sdt-product__hero-grid { grid-template-columns: 1fr; gap: 40px; }
	.sdt-product__features-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 720px) {
	.sdt-product__hero { padding: 56px 0 40px; }
	.sdt-product__features { padding: 56px 0 40px; }
	.sdt-product__compare { padding: 40px 0 56px; }
	.sdt-product__features-grid { grid-template-columns: 1fr; }
	.sdt-compare__row {
		grid-template-columns: 1fr;
	}
	.sdt-compare__cell { justify-content: space-between; padding: 12px 18px; }
	.sdt-compare__cell--col { padding: 18px; justify-content: center; }
	.sdt-compare__cell--label { background: var(--paper-2); font-weight: 600; }
	.sdt-product__buy-row { flex-direction: column; align-items: stretch; }
	.sdt-product__hero-btn { display: block !important; text-align: center; width: 100%; }
	.sdt-product__visual-card { transform: rotate(0); }
}

/* =============================================================================
 * Product page v2 — EDD button isolation + FOMO cards + locked tier cards.
 * =========================================================================== */

/* ── EDD button isolation ──────────────────────────────────────────────── */
/* EDD's edd_get_purchase_link outputs:
 *   - a real <button class="edd-add-to-cart button blue ...">
 *   - a no-js <input type="submit" class="edd-no-js button blue ...">
 *   - a hidden <a class="edd_go_to_checkout button blue ...">
 * Wrapped in .sdt-edd-buy so we can target hard.
 */
.sdt-edd-buy { display: inline-block; }
.sdt-edd-buy form.edd_download_purchase_form { margin: 0; padding: 0; }
.sdt-edd-buy .edd_purchase_submit_wrapper { display: inline-flex; align-items: center; gap: 8px; }

/* VISUAL ONLY — no `display` here, so we don't override the no-JS
 * input's hide rule or EDD's inline style="display:none" on the
 * Checkout link. Display rules are scoped below to the visible
 * <button> only. */
.sdt-edd-buy .sdt-cta-btn {
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--yellow) !important;
	color: var(--navy) !important;
	padding: 14px 28px !important;
	border-radius: 12px !important;
	font: inherit !important;
	font-weight: 700 !important;
	font-size: 15.5px !important;
	line-height: 1 !important;
	border: 0 !important;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 8px 18px -10px rgba(250,204,21,.55) !important;
	text-decoration: none !important;
	cursor: pointer;
	transition: transform .12s, background .15s !important;
	white-space: nowrap;
	min-height: 0 !important;
}

/* Display rule, ONLY on the visible <button>. Not on the no-js <input>
 * or the hidden checkout <a>. */
.sdt-edd-buy button.sdt-cta-btn {
	display: inline-flex !important;
}

/* Always hide the no-JS fallback. Tag selector + class beats the broad
 * .sdt-cta-btn visual rule (which doesn't set display anyway). */
.sdt-edd-buy input.edd-no-js,
.sdt-edd-buy input[type="submit"].edd-no-js {
	display: none !important;
}

/* Hide the "Go to checkout" link by default. EDD outputs it with inline
 * style="display:none;" and toggles to display:inline via JS after a
 * successful add-to-cart. We don't set !important so EDD's inline
 * style remains authoritative. */
.sdt-edd-buy a.edd_go_to_checkout {
	display: none;
}

.sdt-edd-buy button.sdt-cta-btn:hover {
	background: #ffd83a !important;
	transform: translateY(-1px);
	color: var(--navy) !important;
}

/* "Added to cart" confirmation chip */
.sdt-edd-buy .edd-cart-ajax-alert .edd-cart-added-alert {
	display: none;
	align-items: center;
	gap: 6px;
	padding: 8px 14px;
	background: #ecfdf5;
	color: #065f46;
	border-radius: 999px;
	font-size: 13px;
	font-weight: 600;
}
.sdt-edd-buy .edd-cart-ajax-alert .edd-cart-added-alert svg { color: #10b981; }

/* "Checkout" link that appears after add-to-cart */
.sdt-edd-buy .edd_go_to_checkout {
	margin-left: 8px;
}

/* Loading spinner inside button */
.sdt-edd-buy .edd-loading {
	width: 14px;
	height: 14px;
	border: 2px solid currentColor;
	border-right-color: transparent;
	border-radius: 50%;
	display: none;
	animation: sdt-spin 0.6s linear infinite;
}
.sdt-edd-buy .edd-loading[aria-label] { display: none; }
.sdt-edd-buy button.edd-loading-active .edd-loading { display: inline-block; }
@keyframes sdt-spin { to { transform: rotate(360deg); } }

/* Final CTA variant: larger */
.sdt-edd-buy--final .sdt-cta-btn--final {
	padding: 16px 36px !important;
	font-size: 16.5px !important;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 10px 22px -12px rgba(250,204,21,.6) !important;
}

/* ── Hero buy row tighter layout ───────────────────────────────────────── */
.sdt-product__buy-row {
	display: flex;
	align-items: stretch;
	gap: 0;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 0;
	box-shadow: 0 12px 32px -20px rgba(10,23,51,.25);
	margin-bottom: 20px;
	overflow: hidden;
	max-width: 520px;
}
.sdt-product__price-block {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 18px 24px;
	border-right: 1px solid var(--line);
	flex-shrink: 0;
	background: linear-gradient(180deg, #fafcff, #fff);
}
.sdt-product__price {
	font-size: 32px;
	font-weight: 800;
	letter-spacing: -.02em;
	color: var(--navy);
	line-height: 1;
}
.sdt-product__price .edd_price { color: inherit; font-weight: inherit; }
.sdt-product__price-period {
	font-size: 12px;
	color: var(--muted);
	margin-top: 4px;
	white-space: nowrap;
}
.sdt-product__buy-action {
	flex: 1;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 12px 16px;
}
.sdt-product__buy-action .sdt-edd-buy,
.sdt-product__buy-action .sdt-edd-buy .edd_purchase_submit_wrapper {
	width: 100%;
}
.sdt-product__buy-action .sdt-cta-btn {
	width: 100%;
}

/* Trust row chips */
.sdt-product__trust-row {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 8px;
}
.sdt-product__trust-row li {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 6px 12px;
	background: rgba(6,182,212,.08);
	border: 1px solid rgba(6,182,212,.18);
	border-radius: 999px;
	color: var(--ink);
	font-size: 13px;
	font-weight: 500;
}
.sdt-product__trust-row svg { color: var(--cyan); flex-shrink: 0; }

/* ── Feature card proof tags ───────────────────────────────────────────── */
.sdt-product__feature-card {
	position: relative;
	display: flex;
	flex-direction: column;
}
.sdt-product__feature-proof {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	margin-top: 14px;
	padding: 5px 10px 5px 8px;
	background: rgba(6,182,212,.08);
	border: 1px solid rgba(6,182,212,.2);
	color: var(--cyan);
	border-radius: 999px;
	font-size: 11.5px;
	font-weight: 700;
	letter-spacing: .02em;
	align-self: flex-start;
	text-transform: uppercase;
}
.sdt-product__feature-proof svg { color: var(--cyan); flex-shrink: 0; }

/* Subtle diagonal shimmer behind the icon, only on hover */
.sdt-product__feature-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 60px;
	background: linear-gradient(135deg, rgba(6,182,212,0) 0%, rgba(6,182,212,0) 60%, rgba(6,182,212,.06) 100%);
	border-radius: var(--r-lg) var(--r-lg) 0 0;
	pointer-events: none;
	opacity: 0;
	transition: opacity .2s ease;
}
.sdt-product__feature-card:hover::before { opacity: 1; }

/* ── "What you'd unlock" locked cards ──────────────────────────────────── */
.sdt-product__missing {
	padding: 56px 0 80px;
	background:
		repeating-linear-gradient(135deg, rgba(10,23,51,.018) 0 1px, transparent 1px 8px),
		linear-gradient(180deg, #fff 0%, #fafcff 100%);
}
.sdt-product__missing .section-head { text-align: center; margin-bottom: 36px; }
.sdt-product__missing-kicker {
	color: #b91c1c !important;
	background: rgba(254,202,202,.6);
	padding: 6px 12px;
	border-radius: 999px;
	display: inline-block;
}

.sdt-product__missing-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 18px;
	max-width: 900px;
	margin: 0 auto 36px;
}
.sdt-product__missing-card {
	position: relative;
	background: #fff;
	border: 1px dashed #cbd5e1;
	border-radius: var(--r-lg);
	padding: 24px 22px 22px;
	overflow: hidden;
}
.sdt-product__missing-card::after {
	/* faint diagonal hatch behind, signals "locked" */
	content: "";
	position: absolute; inset: 0;
	background: repeating-linear-gradient(45deg, rgba(10,23,51,0) 0 6px, rgba(10,23,51,.02) 6px 12px);
	pointer-events: none;
}
.sdt-product__missing-tag {
	position: relative; z-index: 1;
	display: inline-flex; align-items: center; gap: 5px;
	padding: 4px 10px;
	background: var(--navy);
	color: var(--yellow);
	border-radius: 999px;
	font-size: 10.5px;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
	margin-bottom: 14px;
}
.sdt-product__missing-tag svg { color: var(--yellow); }
.sdt-product__feature-icon--locked {
	background: rgba(10,23,51,.06);
	color: #94a3b8;
}
.sdt-product__missing-card .sdt-product__feature-title { color: var(--navy); }
.sdt-product__missing-card .sdt-product__feature-desc { color: var(--muted); }

.sdt-product__missing-cta-wrap { text-align: center; }
.sdt-product__missing-cta {
	display: inline-flex; align-items: center; gap: 8px;
	background: var(--navy);
	color: #fff !important;
	padding: 14px 28px;
	border-radius: 12px;
	font-weight: 700;
	font-size: 15px;
	text-decoration: none;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.1), 0 8px 18px -10px rgba(10,23,51,.4);
	transition: transform .12s, background .15s;
}
.sdt-product__missing-cta:hover {
	background: #050e23;
	transform: translateY(-1px);
}

/* Responsive */
@media (max-width: 720px) {
	.sdt-product__buy-row { max-width: 100%; }
	.sdt-product__price-block { padding: 16px 18px; }
	.sdt-product__missing-grid { grid-template-columns: 1fr; }
}

/* =============================================================================
 * Inline SVG thumbnail fallback (sdp_post_thumbnail). Renders for posts that
 * don't have a featured image — see functions.php helper.
 * =========================================================================== */

.sdt-svg-thumb {
	display: block;
	width: 100%;
	height: auto;
	border-radius: inherit;
}

/* In the blog card, force the SVG to fill the image slot at the same aspect
 * ratio a real featured image would take. */
.sdt-shell__card-img .sdt-svg-thumb {
	aspect-ratio: 16 / 9;
	object-fit: cover;
	background: #0a1733;
}

/* In the single-post hero, larger height. */
.sdt-post__hero .sdt-svg-thumb {
	aspect-ratio: 16 / 8;
	object-fit: cover;
}

/* =============================================================================
 * Nav mega-dropdown — Directory Plugin
 * =========================================================================== */

.nav-dd { position: relative; }

/* The trigger is now a group: link to the hub on the left, caret toggle
 * on the right. Visually unified, behaviourally split. */
.nav-dd__trigger {
	display: inline-flex; align-items: stretch;
	font-size: 14.5px; font-weight: 500;
	color: var(--ink);
	border-radius: 8px;
	transition: color .15s;
}
.nav-dd__link {
	color: inherit;
	text-decoration: none;
	padding: 4px 0 4px 2px;
	display: inline-flex; align-items: center;
	transition: color .15s, opacity .15s;
	opacity: .82;
}
.nav-dd__link:hover,
.nav-dd[data-open] .nav-dd__link { color: var(--cyan); opacity: 1; }

.nav-dd__caret {
	background: none; border: 0; padding: 4px 4px 4px 8px;
	margin-left: 4px;
	color: inherit; cursor: pointer;
	display: inline-flex; align-items: center;
	border-left: 1px solid transparent;
	transition: border-color .15s, color .15s;
}
.nav-dd__caret:hover,
.nav-dd[data-open] .nav-dd__caret {
	color: var(--cyan);
	border-left-color: var(--line);
}
.nav-dd__caret svg { transition: transform .2s; }
.nav-dd[data-open] .nav-dd__caret svg { transform: rotate(180deg); }

.nav-dd__panel {
	position: absolute;
	/* No visual gap: the panel touches the nav bar. Visual breathing room
	 * is created with padding-top inside the panel. This kills the dead
	 * zone that was causing mouseleave to fire mid-hover. */
	top: 100%;
	left: 50%;
	transform: translateX(-50%) translateY(-8px);
	width: min(1000px, 95vw);
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	box-shadow: 0 20px 48px -16px rgba(10,23,51,.2);
	opacity: 0; pointer-events: none;
	transition: opacity .18s ease, transform .18s ease;
	z-index: 100;
	margin-top: 8px; /* slight visual separation, inside the .nav-dd box */
}
/* Invisible bridge above the panel so the cursor crossing the small margin-top
 * still keeps the hover state on .nav-dd. */
.nav-dd__panel::before {
	content: "";
	position: absolute;
	top: -14px; left: 0; right: 0;
	height: 14px;
	background: transparent;
}
.nav-dd[data-open] .nav-dd__panel {
	opacity: 1; pointer-events: auto;
	transform: translateX(-50%) translateY(0);
}
.nav-dd__inner {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;            /* dividers come from border-right on the columns */
	padding: 24px 0;
}
.nav-dd__col {
	padding: 0 20px;
	border-right: 1px solid var(--line);
	position: relative;
}
.nav-dd__col:last-child { border-right: 0; }

/* Colored top bar per column (cyan for core, yellow for AI, navy for pro)
 * gives visual separation without competing with content. */
.nav-dd__col::before {
	content: "";
	position: absolute;
	top: -4px; left: 20px; right: 20px;
	height: 3px;
	border-radius: 999px;
}
.nav-dd__col:nth-child(1)::before { background: var(--cyan); }
.nav-dd__col:nth-child(2)::before { background: var(--yellow); }
.nav-dd__col:nth-child(3)::before { background: var(--navy); }

.nav-dd__col-head {
	font-size: 11px; font-weight: 700;
	text-transform: uppercase; letter-spacing: .08em;
	color: var(--muted);
	padding: 0 8px 10px;
	margin-bottom: 6px;
	border-bottom: 1px solid var(--line);
}
.nav-dd__col:nth-child(1) .nav-dd__col-head { color: var(--cyan); }
.nav-dd__col:nth-child(2) .nav-dd__col-head { color: #b88a00; }   /* darker yellow for legibility on white */
.nav-dd__col:nth-child(3) .nav-dd__col-head { color: var(--navy); }
.nav-dd__item {
	display: flex; gap: 12px; align-items: flex-start;
	padding: 10px 12px;
	border-radius: 10px;
	color: var(--ink); text-decoration: none;
	transition: background .12s;
}
.nav-dd__item:hover {
	background: rgba(6,182,212,.06);
}
.nav-dd__item-icon {
	flex-shrink: 0;
	width: 32px; height: 32px;
	border-radius: 8px;
	background: rgba(6,182,212,.10);
	color: var(--cyan);
	display: grid; place-items: center;
}
.nav-dd__item-body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.nav-dd__item-name {
	font-size: 13.5px; font-weight: 600; color: var(--navy);
	line-height: 1.3;
}
.nav-dd__item-tag {
	font-size: 12px; color: var(--muted);
	line-height: 1.35;
}
.nav-dd__foot {
	border-top: 1px solid var(--line);
	padding: 14px 24px;
	background: var(--paper-2);
	border-radius: 0 0 var(--r-xl) var(--r-xl);
	text-align: center;
}
.nav-dd__foot-link {
	display: inline-flex; align-items: center; gap: 6px;
	color: var(--cyan); font-weight: 600; font-size: 13.5px;
	text-decoration: none;
}
.nav-dd__foot-link:hover { color: var(--navy); }

@media (max-width: 900px) {
	.nav-dd__panel { width: 92vw; }
	.nav-dd__inner { grid-template-columns: 1fr; gap: 4px; }
}

/* =============================================================================
 * /directory-plugin/ hub page
 * =========================================================================== */

.sdt-plugin-hub { background: #fff; }
.sdt-plugin-hub__hero {
	padding: 88px 0 56px;
	background:
		radial-gradient(ellipse 70% 50% at 30% 0%,  rgba(6,182,212,.12), transparent 60%),
		radial-gradient(ellipse 50% 40% at 90% 20%, rgba(250,204,21,.10), transparent 65%),
		linear-gradient(180deg, #fafcff, #ffffff 70%);
	position: relative; overflow: hidden;
}
.sdt-plugin-hub__hero::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background-image:
		linear-gradient(to right,  rgba(10,23,51,.05) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(10,23,51,.05) 1px, transparent 1px);
	background-size: 56px 56px;
	-webkit-mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
	        mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
}
.sdt-plugin-hub__hero > .container { position: relative; }
.sdt-plugin-hub__title {
	font-size: clamp(34px, 5vw, 52px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.05;
	color: var(--navy);
	margin: 12px 0 16px;
}
.sdt-plugin-hub__sub {
	font-size: 17px; color: var(--ink);
	max-width: 640px; margin: 0 auto 28px; line-height: 1.55;
}
.sdt-plugin-hub__cta {
	display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}

.sdt-plugin-hub__group {
	padding: 64px 0 32px;
}
.sdt-plugin-hub__group[data-group="ai"] { background: linear-gradient(180deg, #ffffff, #fafcff); }
.sdt-plugin-hub__group[data-group="pro"] { background: linear-gradient(180deg, #fafcff, #ffffff); }
.sdt-plugin-hub__group-head { text-align: center; margin-bottom: 32px; }
.sdt-plugin-hub__grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 14px;
	max-width: 1180px; margin: 0 auto;
}
.sdt-plugin-hub__card {
	display: flex; align-items: center; gap: 14px;
	padding: 18px 20px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	color: var(--ink);
	text-decoration: none;
	transition: border-color .15s, transform .15s, box-shadow .15s;
}
.sdt-plugin-hub__card:hover {
	border-color: var(--cyan);
	transform: translateY(-2px);
	box-shadow: 0 12px 24px -16px rgba(6,182,212,.3);
}
.sdt-plugin-hub__card-icon {
	flex-shrink: 0;
	width: 38px; height: 38px;
	border-radius: 10px;
	background: rgba(6,182,212,.10);
	color: var(--cyan);
	display: grid; place-items: center;
}
.sdt-plugin-hub__card-body { flex: 1; min-width: 0; }
.sdt-plugin-hub__card-name { font-size: 14.5px; font-weight: 700; color: var(--navy); }
.sdt-plugin-hub__card-sub  { font-size: 12.5px; color: var(--muted); margin-top: 2px; }
.sdt-plugin-hub__card-arrow { color: var(--muted); flex-shrink: 0; }
.sdt-plugin-hub__card:hover .sdt-plugin-hub__card-arrow { color: var(--cyan); }

.sdt-plugin-hub__final {
	padding: 64px 0 96px;
	text-align: center;
	background:
		radial-gradient(ellipse 60% 50% at 50% 0%, rgba(6,182,212,.10), transparent 60%),
		linear-gradient(180deg, #fafcff, #fff);
}
.sdt-plugin-hub__final-title {
	font-size: clamp(28px, 4vw, 38px);
	font-weight: 700; letter-spacing: -.02em;
	color: var(--navy); margin: 0 0 12px;
}
.sdt-plugin-hub__final-sub {
	font-size: 16px; color: var(--muted);
	margin: 0 0 28px;
	max-width: 580px; margin-left: auto; margin-right: auto;
}

@media (max-width: 980px) { .sdt-plugin-hub__grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .sdt-plugin-hub__grid { grid-template-columns: 1fr; } }

/* =============================================================================
 * /directory-plugin/{feature}/ pages
 * =========================================================================== */

.sdt-feature { background: #fff; }

/* Hero band */
.sdt-feature__hero {
	padding: 88px 0 64px;
	background:
		radial-gradient(ellipse 70% 50% at 30% 0%,  rgba(6,182,212,.12), transparent 60%),
		radial-gradient(ellipse 50% 40% at 90% 20%, rgba(250,204,21,.10), transparent 65%),
		linear-gradient(180deg, #fafcff, #ffffff 70%);
	position: relative; overflow: hidden;
}
.sdt-feature__hero::before {
	content: ""; position: absolute; inset: 0; pointer-events: none;
	background-image:
		linear-gradient(to right,  rgba(10,23,51,.05) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(10,23,51,.05) 1px, transparent 1px);
	background-size: 56px 56px;
	-webkit-mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
	        mask-image: radial-gradient(ellipse 85% 70% at 50% 40%, #000 30%, transparent 75%);
}
.sdt-feature__hero > .container { position: relative; }
.sdt-feature__hero-grid {
	display: grid; grid-template-columns: 1.05fr 1fr;
	gap: 56px; align-items: center;
}
.sdt-feature__eyebrow {
	background: rgba(6,182,212,.10);
	padding: 6px 14px;
	border-radius: 999px;
	display: inline-block;
}
.sdt-feature__title {
	font-size: clamp(32px, 4.8vw, 52px);
	font-weight: 700; letter-spacing: -.02em; line-height: 1.05;
	color: var(--navy);
	margin: 14px 0 16px;
}
.sdt-feature__tagline {
	font-size: 18px; color: var(--ink); line-height: 1.55;
	margin: 0 0 28px; max-width: 540px;
}
.sdt-feature__cta-row {
	display: flex; gap: 12px; flex-wrap: wrap;
	margin-bottom: 20px;
}
.sdt-feature__trust {
	list-style: none; margin: 0; padding: 0;
	display: flex; flex-wrap: wrap; gap: 14px;
	color: var(--muted); font-size: 13.5px;
}
.sdt-feature__trust li { display: inline-flex; align-items: center; gap: 6px; }
.sdt-feature__trust svg { color: var(--cyan); }
.sdt-feature__trust strong { color: var(--navy); }

/* Cards grid */
.sdt-feature__cards { padding: 80px 0 56px; }
.sdt-feature__cards .section-head { text-align: center; margin-bottom: 48px; }
.sdt-feature__cards-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
	max-width: 1100px; margin: 0 auto;
}
.sdt-feature__card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 24px 22px;
	display: flex; flex-direction: column;
	transition: border-color .2s, transform .2s, box-shadow .2s;
}
.sdt-feature__card:hover {
	border-color: var(--cyan);
	transform: translateY(-3px);
	box-shadow: 0 14px 28px -18px rgba(6,182,212,.32);
}
.sdt-feature__card-icon {
	width: 44px; height: 44px;
	border-radius: 12px;
	background: rgba(6,182,212,.10); color: var(--cyan);
	display: grid; place-items: center;
	margin-bottom: 16px;
}
.sdt-feature__card-title {
	font-size: 16.5px; font-weight: 700; color: var(--navy);
	margin: 0 0 6px; letter-spacing: -.005em;
}
.sdt-feature__card-desc {
	color: var(--muted); font-size: 14px; line-height: 1.55;
	margin: 0 0 14px;
}
.sdt-feature__card-proof {
	display: inline-flex; align-items: center; gap: 5px;
	padding: 5px 10px 5px 8px;
	background: rgba(6,182,212,.08);
	border: 1px solid rgba(6,182,212,.2);
	color: var(--cyan);
	border-radius: 999px;
	font-size: 11.5px; font-weight: 700;
	letter-spacing: .02em; text-transform: uppercase;
	align-self: flex-start; margin-top: auto;
}

/* How it works */
.sdt-feature__how {
	padding: 56px 0;
	background: linear-gradient(180deg, #fafcff, #ffffff);
}
.sdt-feature__how .section-head { text-align: center; margin-bottom: 36px; }
.sdt-feature__how-list {
	list-style: none; margin: 0; padding: 0;
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px;
	max-width: 1000px; margin: 0 auto;
}
.sdt-feature__how-step {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 24px;
	position: relative;
}
.sdt-feature__how-num {
	display: inline-grid; place-items: center;
	width: 32px; height: 32px;
	border-radius: 50%;
	background: var(--navy); color: var(--yellow);
	font-weight: 800; font-size: 14px;
	margin-bottom: 12px;
}
.sdt-feature__how-title {
	font-size: 17px; font-weight: 700; color: var(--navy);
	margin: 0 0 6px; letter-spacing: -.005em;
}
.sdt-feature__how-desc {
	color: var(--muted); font-size: 14px; line-height: 1.55; margin: 0;
}

/* Comparison */
.sdt-feature__compare {
	padding: 56px 0;
}
.sdt-feature__compare .section-head { text-align: center; margin-bottom: 36px; }
.sdt-feature__compare-table {
	max-width: 880px; margin: 0 auto;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: 0 12px 32px -22px rgba(10,23,51,.18);
}
.sdt-feature__compare-row {
	display: grid; grid-template-columns: 1.2fr 1fr 1fr;
	align-items: stretch;
	border-bottom: 1px solid var(--line);
}
.sdt-feature__compare-row:last-child { border-bottom: 0; }
.sdt-feature__compare-row--head { background: var(--paper-2); }
.sdt-feature__compare-cell {
	padding: 14px 18px; font-size: 14px;
	display: flex; align-items: center; gap: 6px;
}
.sdt-feature__compare-cell--label { color: var(--navy); font-weight: 500; }
.sdt-feature__compare-cell--sdp {
	color: var(--navy); font-weight: 600;
	background: rgba(6,182,212,.04);
}
.sdt-feature__compare-cell--sdp svg { color: var(--cyan); flex-shrink: 0; }
.sdt-feature__compare-row--head .sdt-feature__compare-cell--sdp { color: var(--cyan); font-weight: 800; }
.sdt-feature__compare-cell--other { color: var(--muted); }

/* Related features */
.sdt-feature__related {
	padding: 56px 0;
	background: linear-gradient(180deg, #ffffff, #fafcff);
}
.sdt-feature__related .section-head { text-align: center; margin-bottom: 32px; }
.sdt-feature__related-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
	max-width: 1000px; margin: 0 auto;
}
.sdt-feature__related-card {
	display: flex; align-items: center; gap: 14px;
	padding: 18px 20px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	color: var(--ink); text-decoration: none;
	transition: border-color .15s, transform .15s, box-shadow .15s;
}
.sdt-feature__related-card:hover {
	border-color: var(--cyan);
	transform: translateY(-2px);
	box-shadow: 0 10px 22px -16px rgba(6,182,212,.3);
}
.sdt-feature__related-icon {
	flex-shrink: 0;
	width: 36px; height: 36px;
	border-radius: 10px;
	background: rgba(6,182,212,.10); color: var(--cyan);
	display: grid; place-items: center;
}
.sdt-feature__related-body { flex: 1; min-width: 0; }
.sdt-feature__related-label { font-size: 14px; font-weight: 700; color: var(--navy); }
.sdt-feature__related-tag { font-size: 12px; color: var(--muted); margin-top: 2px; }

/* Final CTA */
.sdt-feature__final {
	padding: 56px 0 88px;
	text-align: center;
	background:
		radial-gradient(ellipse 60% 50% at 50% 0%, rgba(6,182,212,.10), transparent 60%),
		linear-gradient(180deg, #fafcff, #fff);
}
.sdt-feature__final-title {
	font-size: clamp(26px, 3.8vw, 36px);
	font-weight: 700; letter-spacing: -.02em;
	color: var(--navy); margin: 0 0 12px;
}
.sdt-feature__final-sub {
	font-size: 16px; color: var(--muted);
	margin: 0 0 28px; max-width: 560px;
	margin-left: auto; margin-right: auto;
}
.sdt-feature__final-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 14px; }
.sdt-feature__final-meta { font-size: 13px; color: var(--muted); }
.sdt-feature__final-meta a { color: var(--cyan); }

@media (max-width: 980px) {
	.sdt-feature__hero-grid { grid-template-columns: 1fr; gap: 40px; }
	.sdt-feature__cards-grid { grid-template-columns: repeat(2, 1fr); }
	.sdt-feature__how-list { grid-template-columns: 1fr; }
	.sdt-feature__related-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
	.sdt-feature__hero { padding: 56px 0 40px; }
	.sdt-feature__cards-grid { grid-template-columns: 1fr; }
	.sdt-feature__compare-row { grid-template-columns: 1fr; }
	.sdt-feature__compare-cell--label { background: var(--paper-2); }
}

/* =============================================================================
 * Feature visuals (sdt-fv) — inline SVG / DOM mockups of plugin admin screens
 * =========================================================================== */

.sdt-fv {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	box-shadow: 0 22px 48px -28px rgba(10,23,51,.35);
	padding: 22px;
	font-size: 13.5px;
	color: var(--ink);
	max-width: 100%;
}
.sdt-fv__chrome {
	display: flex; align-items: center; gap: 6px;
	padding-bottom: 14px; margin-bottom: 14px;
	border-bottom: 1px solid var(--line);
}
.sdt-fv__chrome span {
	width: 10px; height: 10px; border-radius: 50%; background: #cbd5e1;
}
.sdt-fv__chrome span:nth-child(1) { background: #f87171; }
.sdt-fv__chrome span:nth-child(2) { background: #fbbf24; }
.sdt-fv__chrome span:nth-child(3) { background: #34d399; }
.sdt-fv__chrome-url {
	flex: 1; text-align: center;
	font-size: 12px; color: var(--muted);
	background: var(--paper-2);
	padding: 4px 12px; border-radius: 999px;
}

/* shared bits */
.sdt-fv__chip {
	display: inline-flex; align-items: center; gap: 4px;
	padding: 4px 10px;
	background: var(--paper-2);
	color: var(--ink);
	border-radius: 999px;
	font-size: 11.5px; font-weight: 600;
}
.sdt-fv__chip--ai { background: rgba(6,182,212,.10); color: var(--cyan); }
.sdt-fv__chip--add { background: rgba(6,182,212,.10); color: var(--cyan); border: 1px dashed rgba(6,182,212,.4); }
.sdt-fv__chip--mini { font-size: 10.5px; padding: 2px 8px; }
.sdt-fv__pill { padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 700; }
.sdt-fv__pill--ok { background: #ecfdf5; color: #065f46; }
.sdt-fv__btn {
	background: var(--yellow); color: var(--navy);
	border: 0; padding: 8px 16px;
	border-radius: 8px;
	font-weight: 700; font-size: 12.5px;
	cursor: default;
}
.sdt-fv__btn--ai { background: var(--cyan); color: #fff; }
.sdt-fv__btn--ok { background: #10b981; color: #fff; }
.sdt-fv__btn--cta { background: var(--navy); color: #fff; }
.sdt-fv__btn--ghost { background: transparent; color: var(--muted); border: 1px solid var(--line); }
.sdt-fv__btn--small { padding: 6px 12px; font-size: 11.5px; }
.sdt-fv__input {
	padding: 8px 12px;
	background: var(--paper-2);
	border-radius: 8px;
	font-size: 12.5px; color: var(--ink);
}
.sdt-fv__input--lg { min-height: 48px; }
.sdt-fv__row { margin-bottom: 12px; }
.sdt-fv__row label { display: block; font-size: 11px; color: var(--muted); margin-bottom: 4px; text-transform: uppercase; letter-spacing: .05em; }
.sdt-fv__row--actions { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; margin-bottom: 0; }
.sdt-fv__table { width: 100%; border-collapse: collapse; font-size: 12.5px; }
.sdt-fv__table th, .sdt-fv__table td { padding: 8px 6px; text-align: left; }
.sdt-fv__table th {
	font-size: 10.5px; color: var(--muted);
	text-transform: uppercase; letter-spacing: .05em;
	border-bottom: 1px solid var(--line);
}
.sdt-fv__table td { border-bottom: 1px solid var(--paper-2); }

/* default fallback */
.sdt-fv--default .sdt-fv__title { font-size: 18px; font-weight: 800; color: var(--navy); }
.sdt-fv--default .sdt-fv__sub { color: var(--muted); font-size: 13px; margin-top: 4px; }
.sdt-fv--default .sdt-fv__body { padding-top: 8px; }

/* admin / listings */
.sdt-fv--admin .sdt-fv__topbar { display: flex; justify-content: space-between; margin-bottom: 16px; }
.sdt-fv--admin .sdt-fv__topbar-title { font-weight: 700; color: var(--navy); }
.sdt-fv--admin .sdt-fv__topbar-link { color: var(--cyan); font-size: 12px; }
.sdt-fv--admin .sdt-fv__stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 16px; }
.sdt-fv--admin .sdt-fv__stat { padding: 12px; background: var(--paper-2); border-radius: 10px; }
.sdt-fv--admin .sdt-fv__stat-n { font-weight: 800; font-size: 20px; color: var(--navy); }
.sdt-fv--admin .sdt-fv__stat-l { font-size: 11px; color: var(--muted); }

/* form */
.sdt-fv--form .sdt-fv__form-header { font-weight: 700; color: var(--navy); margin-bottom: 12px; font-size: 15px; }

/* reviews */
.sdt-fv--reviews .sdt-fv__rating-head {
	display: flex; align-items: baseline; gap: 10px;
	padding-bottom: 12px; margin-bottom: 14px;
	border-bottom: 1px solid var(--line);
}
.sdt-fv--reviews .sdt-fv__rating-score { font-size: 32px; font-weight: 800; color: var(--navy); }
.sdt-fv--reviews .sdt-fv__rating-stars { color: var(--yellow); letter-spacing: 2px; }
.sdt-fv--reviews .sdt-fv__rating-count { color: var(--muted); font-size: 12px; }
.sdt-fv__review { margin-bottom: 14px; }
.sdt-fv__review-stars { color: var(--yellow); font-size: 12px; letter-spacing: 1px; }
.sdt-fv__review-author { font-size: 11.5px; color: var(--muted); }
.sdt-fv__review-body { font-size: 13px; line-height: 1.5; color: var(--ink); margin: 6px 0; }
.sdt-fv__review-reply {
	margin-top: 6px; padding: 8px 12px;
	background: var(--paper-2); border-left: 2px solid var(--cyan);
	font-size: 12px; color: var(--ink); border-radius: 0 6px 6px 0;
}

/* claim */
.sdt-fv--claim { text-align: center; background: linear-gradient(180deg, #fff, #fafcff); padding: 32px 24px; }
.sdt-fv--claim .sdt-fv__claim-icon { width: 56px; height: 56px; margin: 0 auto 14px; color: var(--navy); display: grid; place-items: center; background: rgba(6,182,212,.10); border-radius: 50%; }
.sdt-fv--claim .sdt-fv__claim-title { font-size: 20px; font-weight: 800; color: var(--navy); margin-bottom: 8px; }
.sdt-fv--claim .sdt-fv__claim-desc { color: var(--muted); font-size: 13.5px; line-height: 1.55; margin-bottom: 16px; }
.sdt-fv--claim .sdt-fv__claim-btn {
	background: var(--navy); color: #fff; border: 0;
	padding: 12px 24px; border-radius: 10px;
	font-weight: 700; font-size: 14px;
	display: inline-flex; align-items: center; gap: 8px;
	cursor: default;
}
.sdt-fv--claim .sdt-fv__claim-btn svg { color: var(--yellow); }
.sdt-fv--claim .sdt-fv__claim-meta { font-size: 11.5px; color: var(--muted); margin-top: 12px; }

/* taxonomy tree */
.sdt-fv--tree .sdt-fv__tree-title { font-weight: 700; color: var(--navy); margin-bottom: 12px; }
.sdt-fv--tree .sdt-fv__tree { list-style: none; padding: 0; margin: 0; font-size: 13px; }
.sdt-fv--tree .sdt-fv__tree li { padding: 4px 0; color: var(--navy); }
.sdt-fv--tree .sdt-fv__tree ul { list-style: none; padding-left: 18px; margin: 0; }
.sdt-fv--tree .sdt-fv__tree ul li { color: var(--ink); font-size: 12.5px; }
.sdt-fv--tree .sdt-fv__tree span { color: var(--muted); font-size: 11.5px; }

/* map */
.sdt-fv--map { padding: 0; overflow: hidden; }
.sdt-fv--map svg { display: block; width: 100%; }
.sdt-fv--map .sdt-fv__map-bar { padding: 12px; display: flex; gap: 6px; background: #fff; border-top: 1px solid var(--line); }

/* import drop */
.sdt-fv--drop { padding: 24px; }
.sdt-fv--drop .sdt-fv__drop-title { font-weight: 700; color: var(--navy); font-size: 15px; }
.sdt-fv--drop .sdt-fv__drop-sub { color: var(--muted); font-size: 12.5px; margin-bottom: 14px; }
.sdt-fv--drop .sdt-fv__drop-zone {
	border: 1.5px dashed #cbd5e1;
	border-radius: 12px;
	padding: 28px 18px;
	text-align: center;
}
.sdt-fv--drop .sdt-fv__drop-icon { font-size: 28px; color: var(--cyan); margin-bottom: 8px; }
.sdt-fv--drop .sdt-fv__drop-h { font-weight: 700; color: var(--navy); font-size: 14px; }
.sdt-fv--drop .sdt-fv__drop-meta { color: var(--muted); font-size: 11.5px; margin-top: 4px; }
.sdt-fv--drop .sdt-fv__drop-progress { margin-top: 14px; }
.sdt-fv--drop .sdt-fv__drop-bar { height: 6px; background: var(--paper-2); border-radius: 999px; overflow: hidden; margin-bottom: 6px; }
.sdt-fv--drop .sdt-fv__drop-fill { height: 100%; width: 68%; background: linear-gradient(90deg, var(--cyan), #0891b2); border-radius: 999px; }
.sdt-fv--drop .sdt-fv__drop-stats { font-size: 11.5px; color: var(--muted); }

/* fields builder */
.sdt-fv--builder .sdt-fv__builder-head { display: flex; justify-content: space-between; margin-bottom: 14px; }
.sdt-fv--builder .sdt-fv__builder-title { font-weight: 700; color: var(--navy); }
.sdt-fv--builder .sdt-fv__builder-list { list-style: none; padding: 0; margin: 0; }
.sdt-fv--builder .sdt-fv__builder-list li {
	display: flex; justify-content: space-between; align-items: center;
	padding: 9px 12px;
	border-bottom: 1px solid var(--paper-2);
}
.sdt-fv--builder .sdt-fv__builder-name { color: var(--navy); font-weight: 600; font-size: 13px; }
.sdt-fv--builder .sdt-fv__builder-type {
	padding: 3px 9px; background: var(--paper-2);
	border-radius: 999px; font-size: 11px; color: var(--muted);
}

/* search */
.sdt-fv--search .sdt-fv__search-input {
	display: flex; align-items: center; gap: 8px;
	padding: 10px 14px;
	background: var(--paper-2);
	border-radius: 10px;
	margin-bottom: 12px;
	font-size: 13.5px; color: var(--ink);
}
.sdt-fv--search .sdt-fv__search-input svg { color: var(--muted); flex-shrink: 0; }
.sdt-fv--search .sdt-fv__search-banner {
	padding: 10px 14px;
	background: rgba(6,182,212,.06);
	border: 1px solid rgba(6,182,212,.2);
	border-radius: 10px;
	font-size: 12.5px;
	margin-bottom: 12px;
	display: flex; align-items: center; gap: 8px;
}
.sdt-fv--search .sdt-fv__search-banner svg { color: var(--cyan); flex-shrink: 0; }
.sdt-fv__search-row {
	display: flex; align-items: center; gap: 12px;
	padding: 10px;
	border-radius: 10px;
	background: #fff;
	border: 1px solid var(--paper-2);
	margin-bottom: 6px;
}
.sdt-fv__search-thumb { width: 44px; height: 44px; border-radius: 8px; background: linear-gradient(135deg, var(--cyan), #0891b2); flex-shrink: 0; }
.sdt-fv__search-body { flex: 1; min-width: 0; }
.sdt-fv__search-name { font-weight: 700; color: var(--navy); font-size: 13px; }
.sdt-fv__search-meta { color: var(--muted); font-size: 11.5px; }
.sdt-fv__search-match {
	padding: 3px 10px; background: var(--navy); color: var(--yellow);
	border-radius: 999px; font-size: 11px; font-weight: 800;
}

/* description / meta / faq / category-pick / enricher cards — minimal */
.sdt-fv--desc .sdt-fv__desc-head,
.sdt-fv--faqs .sdt-fv__faqs-head,
.sdt-fv--meta .sdt-fv__meta-head,
.sdt-fv--tags .sdt-fv__tags-head,
.sdt-fv--catpick .sdt-fv__catpick-head,
.sdt-fv--enricher .sdt-fv__enricher-head,
.sdt-fv--edd .sdt-fv__edd-head,
.sdt-fv--pgrid .sdt-fv__pgrid-head,
.sdt-fv--analytics .sdt-fv__analytics-head,
.sdt-fv--audit .sdt-fv__audit-head,
.sdt-fv--blocks .sdt-fv__blocks-head,
.sdt-fv--elementor .sdt-fv__el-head {
	display: flex; gap: 8px; align-items: center;
	margin-bottom: 14px;
	flex-wrap: wrap;
}
.sdt-fv--desc .sdt-fv__desc-input { margin-bottom: 12px; }
.sdt-fv--desc .sdt-fv__btn--ai { width: 100%; padding: 10px; margin-bottom: 12px; }
.sdt-fv--desc .sdt-fv__desc-output {
	padding: 12px; background: var(--paper-2);
	border-radius: 8px; font-size: 13px; line-height: 1.55; color: var(--ink);
}

/* faq styles */
.sdt-fv--faqs .sdt-fv__faqs-styles { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; margin-bottom: 14px; }
.sdt-fv--faqs .sdt-fv__faqs-style {
	padding: 8px; text-align: center;
	background: var(--paper-2); border-radius: 8px;
	font-size: 11px; color: var(--muted); font-weight: 600;
	border: 2px solid transparent;
}
.sdt-fv--faqs .sdt-fv__faqs-style--active {
	background: rgba(6,182,212,.08); color: var(--cyan); border-color: var(--cyan);
}
.sdt-fv__faq-item { padding: 10px 12px; border: 1px solid var(--line); border-radius: 8px; margin-bottom: 6px; }
.sdt-fv__faq-item--open { border-color: var(--cyan); background: rgba(6,182,212,.04); }
.sdt-fv__faq-q { font-weight: 600; color: var(--navy); font-size: 12.5px; }
.sdt-fv__faq-a { color: var(--muted); font-size: 12px; margin-top: 6px; line-height: 1.5; }

/* meta serp */
.sdt-fv--meta .sdt-fv__serp { padding: 14px; background: var(--paper-2); border-radius: 10px; }
.sdt-fv--meta .sdt-fv__serp-url { color: #16a34a; font-size: 11.5px; }
.sdt-fv--meta .sdt-fv__serp-title { color: #1a0dab; font-size: 15px; font-weight: 600; margin: 4px 0; }
.sdt-fv--meta .sdt-fv__serp-desc { color: #475569; font-size: 12.5px; line-height: 1.5; }
.sdt-fv--meta .sdt-fv__serp-rating { color: var(--yellow); font-size: 12px; margin-top: 6px; }

/* tags */
.sdt-fv--tags .sdt-fv__tags-section { margin-bottom: 12px; }
.sdt-fv--tags .sdt-fv__tags-label { font-size: 11px; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px; }
.sdt-fv--tags .sdt-fv__tags-list { display: flex; flex-wrap: wrap; gap: 6px; }
.sdt-fv__tag { padding: 4px 10px; border-radius: 999px; font-size: 11.5px; font-weight: 600; }
.sdt-fv__tag--ok { background: rgba(16,185,129,.10); color: #065f46; }
.sdt-fv__tag--new { background: rgba(6,182,212,.10); color: var(--cyan); border: 1px dashed rgba(6,182,212,.4); }

/* enricher */
.sdt-fv__toggle { padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: .04em; }
.sdt-fv__toggle--on { background: #ecfdf5; color: #065f46; }
.sdt-fv__toggle--off { background: var(--paper-2); color: var(--muted); }

/* category pick */
.sdt-fv--catpick .sdt-fv__catpick-input { margin-bottom: 14px; }
.sdt-fv--catpick .sdt-fv__catpick-result { padding: 14px; background: rgba(6,182,212,.05); border: 1px solid rgba(6,182,212,.2); border-radius: 10px; }
.sdt-fv--catpick .sdt-fv__catpick-path { color: var(--navy); font-weight: 700; font-size: 13.5px; margin-bottom: 10px; }
.sdt-fv--catpick .sdt-fv__catpick-path span { color: var(--muted); margin: 0 4px; font-weight: 400; }
.sdt-fv--catpick .sdt-fv__catpick-actions { display: flex; gap: 8px; }

/* audit */
.sdt-fv--audit .sdt-fv__audit-head { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 18px; }
.sdt-fv--audit .sdt-fv__audit-label { color: var(--muted); font-size: 11px; text-transform: uppercase; letter-spacing: .06em; }
.sdt-fv--audit .sdt-fv__audit-score { font-size: 36px; font-weight: 800; color: var(--navy); line-height: 1; }
.sdt-fv--audit .sdt-fv__audit-score span { font-size: 14px; color: var(--muted); font-weight: 500; }
.sdt-fv--audit .sdt-fv__audit-tag { color: var(--cyan); font-size: 11px; font-weight: 700; text-transform: uppercase; margin-top: 4px; }
.sdt-fv--audit .sdt-fv__audit-row { display: grid; grid-template-columns: 1.4fr 1fr 60px; gap: 10px; align-items: center; padding: 6px 0; font-size: 12px; }
.sdt-fv--audit .sdt-fv__audit-name { color: var(--ink); }
.sdt-fv--audit .sdt-fv__audit-bar { height: 6px; background: var(--paper-2); border-radius: 999px; overflow: hidden; }
.sdt-fv--audit .sdt-fv__audit-fill { height: 100%; border-radius: 999px; }
.sdt-fv--audit .sdt-fv__audit-fill--pass { background: #10b981; }
.sdt-fv--audit .sdt-fv__audit-fill--warn { background: var(--yellow); }
.sdt-fv--audit .sdt-fv__audit-fill--fail { background: #ef4444; }
.sdt-fv--audit .sdt-fv__audit-pill { padding: 2px 8px; border-radius: 999px; font-size: 10px; font-weight: 800; text-align: center; }
.sdt-fv--audit .sdt-fv__audit-pill--pass { background: #ecfdf5; color: #065f46; }
.sdt-fv--audit .sdt-fv__audit-pill--warn { background: #fefce8; color: #854d0e; }
.sdt-fv--audit .sdt-fv__audit-pill--fail { background: #fef2f2; color: #991b1b; }

/* programmatic pages */
.sdt-fv--pgrid .sdt-fv__pgrid-row { display: flex; align-items: center; gap: 10px; padding: 8px 4px; border-bottom: 1px solid var(--paper-2); font-size: 12.5px; }
.sdt-fv--pgrid .sdt-fv__pgrid-tick { color: #10b981; font-weight: 800; }
.sdt-fv--pgrid .sdt-fv__pgrid-title { flex: 1; color: var(--navy); font-weight: 600; }

/* analytics chart */
.sdt-fv--analytics .sdt-fv__analytics-stats { display: flex; gap: 18px; font-size: 12.5px; flex-wrap: wrap; }
.sdt-fv--analytics .sdt-fv__analytics-stats div { display: flex; flex-direction: column; }
.sdt-fv--analytics .sdt-fv__analytics-stats b { font-size: 20px; color: var(--navy); font-weight: 800; }
.sdt-fv--analytics .sdt-fv__analytics-stats span { font-size: 11px; color: var(--muted); }
.sdt-fv--analytics .sdt-fv__chart {
	display: flex; align-items: flex-end; gap: 3px;
	height: 110px;
	margin-top: 14px;
	padding-top: 6px;
	border-top: 1px solid var(--paper-2);
}
.sdt-fv--analytics .sdt-fv__chart-bar {
	flex: 1; background: linear-gradient(180deg, var(--cyan), #0891b2);
	border-radius: 2px 2px 0 0;
	min-height: 4px;
}

/* edd products */
.sdt-fv--edd .sdt-fv__edd-row {
	display: grid; grid-template-columns: 1fr auto auto; gap: 12px;
	align-items: center; padding: 10px 4px;
	border-bottom: 1px solid var(--paper-2); font-size: 13px;
}
.sdt-fv--edd .sdt-fv__edd-name { color: var(--navy); font-weight: 600; }
.sdt-fv--edd .sdt-fv__edd-price { color: var(--navy); font-weight: 800; }
.sdt-fv--edd .sdt-fv__edd-footer {
	margin-top: 14px; padding: 10px 14px;
	background: rgba(6,182,212,.06);
	border-radius: 8px;
	font-size: 12px; color: var(--cyan); font-weight: 600;
}

/* wizard */
.sdt-fv--wizard .sdt-fv__wizard-head { text-align: center; margin-bottom: 14px; }
.sdt-fv--wizard .sdt-fv__wizard-title { font-weight: 800; color: var(--navy); font-size: 15px; }
.sdt-fv--wizard .sdt-fv__wizard-sub { color: var(--muted); font-size: 12px; }
.sdt-fv--wizard .sdt-fv__wizard-steps {
	list-style: none; padding: 0; margin: 0 0 18px;
	display: flex; justify-content: space-between; align-items: center;
}
.sdt-fv__wizard-step { display: flex; flex-direction: column; align-items: center; gap: 4px; flex: 1; font-size: 10px; }
.sdt-fv__wizard-num {
	width: 24px; height: 24px; border-radius: 50%;
	background: var(--paper-2); color: var(--muted);
	display: grid; place-items: center; font-weight: 800; font-size: 11px;
}
.sdt-fv__wizard-step--done .sdt-fv__wizard-num { background: var(--cyan); color: #fff; }
.sdt-fv__wizard-step--active .sdt-fv__wizard-num { background: var(--navy); color: var(--yellow); box-shadow: 0 0 0 4px rgba(10,23,51,.1); }
.sdt-fv__wizard-step--active .sdt-fv__wizard-label { color: var(--navy); font-weight: 700; }
.sdt-fv__wizard-step--done .sdt-fv__wizard-label { color: var(--ink); }
.sdt-fv__wizard-step--pending .sdt-fv__wizard-label { color: var(--muted); }
.sdt-fv--wizard .sdt-fv__wizard-body { padding: 14px; background: var(--paper-2); border-radius: 10px; }
.sdt-fv--wizard .sdt-fv__wizard-step-title { font-weight: 700; color: var(--navy); margin-bottom: 8px; font-size: 13px; }
.sdt-fv--wizard .sdt-fv__wizard-body .sdt-fv__btn { width: 100%; margin-top: 10px; }

/* blocks inserter */
.sdt-fv--blocks .sdt-fv__blocks-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; }
.sdt-fv--blocks .sdt-fv__block {
	background: var(--paper-2); padding: 14px 10px;
	border-radius: 10px; text-align: center;
	border: 1px solid var(--line);
}
.sdt-fv--blocks .sdt-fv__block-icon { font-size: 22px; margin-bottom: 6px; }
.sdt-fv--blocks .sdt-fv__block-name { font-weight: 700; color: var(--navy); font-size: 12px; }
.sdt-fv--blocks .sdt-fv__block-sub { color: var(--muted); font-size: 10.5px; margin-top: 2px; }

/* elementor */
.sdt-fv--elementor .sdt-fv__el-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; }
.sdt-fv--elementor .sdt-fv__el-widget {
	display: flex; align-items: center; gap: 8px;
	padding: 10px 12px;
	background: var(--paper-2);
	border-radius: 8px;
}
.sdt-fv--elementor .sdt-fv__el-widget-icon { width: 26px; height: 26px; border-radius: 6px; background: rgba(6,182,212,.10); color: var(--cyan); display: grid; place-items: center; }
.sdt-fv--elementor .sdt-fv__el-widget-name { font-size: 12px; color: var(--navy); font-weight: 600; }

/* =============================================================================
 * BOFU FAQ grid on /support/ — 3×5 on desktop, native <details> accordion
 * Schema-friendly markup (FAQPage JSON-LD lives in page-support.php head).
 * =========================================================================== */

.sdt-bofu-faq {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	max-width: 1180px;
	margin: 0 auto;
}
.sdt-bofu-faq__item {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	transition: border-color .15s, box-shadow .15s, transform .15s;
	align-self: start;
	overflow: hidden;
}
.sdt-bofu-faq__item:hover {
	border-color: var(--cyan);
	transform: translateY(-1px);
}
.sdt-bofu-faq__item[open] {
	border-color: var(--cyan);
	box-shadow: 0 6px 18px -10px rgba(6,182,212,.25);
}
.sdt-bofu-faq__q {
	cursor: pointer;
	padding: 16px 18px;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 12px;
	color: var(--navy);
	font-weight: 600;
	font-size: 14.5px;
	line-height: 1.35;
	letter-spacing: -.005em;
	list-style: none;
}
.sdt-bofu-faq__q::-webkit-details-marker { display: none; }
.sdt-bofu-faq__q::marker { display: none; content: ""; }
.sdt-bofu-faq__q:focus-visible {
	outline: 2px solid var(--cyan);
	outline-offset: -2px;
	border-radius: var(--r-lg);
}
.sdt-bofu-faq__q-text { flex: 1; min-width: 0; }
.sdt-bofu-faq__q-icon {
	flex-shrink: 0;
	width: 24px; height: 24px;
	display: inline-grid; place-items: center;
	border-radius: 50%;
	background: var(--paper-2);
	color: var(--cyan);
	transition: transform .2s, background .15s, color .15s;
}
.sdt-bofu-faq__item[open] .sdt-bofu-faq__q-icon {
	background: var(--cyan);
	color: #fff;
	transform: rotate(45deg);
}
.sdt-bofu-faq__a {
	padding: 0 18px 18px;
	font-size: 13.5px;
	line-height: 1.6;
	color: var(--ink);
}
.sdt-bofu-faq__a a { color: var(--cyan); }

@media (max-width: 980px) {
	.sdt-bofu-faq { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
	.sdt-bofu-faq { grid-template-columns: 1fr; gap: 10px; }
	.sdt-bofu-faq__q { font-size: 14px; padding: 14px 16px; }
	.sdt-bofu-faq__a { padding: 0 16px 14px; }
}

/* =============================================================================
 * Blog content shortcodes + h2/h3 + table + author box upgrades.
 * Scoped to .sdt-post__content so they only apply inside blog posts.
 * =========================================================================== */

/* ── [tldr] callout box ───────────────────────────────────────────────────── */
.sdt-tldr {
	position: relative;
	margin: 32px 0 36px;
	padding: 0;
	background: linear-gradient(135deg, #fafcff 0%, #fff 100%);
	border: 1px solid rgba(6,182,212,.25);
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: 0 12px 28px -18px rgba(6,182,212,.25);
}
.sdt-tldr::before {
	content: "";
	position: absolute;
	top: 0; left: 0; width: 4px; height: 100%;
	background: linear-gradient(180deg, var(--cyan), var(--yellow));
}
.sdt-tldr__head {
	display: flex; align-items: center; gap: 10px;
	padding: 16px 24px 14px;
	border-bottom: 1px solid rgba(6,182,212,.15);
	background:
		linear-gradient(180deg, rgba(6,182,212,.06), transparent),
		#fff;
}
.sdt-tldr__head-mark {
	display: inline-grid; place-items: center;
	width: 26px; height: 26px;
	border-radius: 50%;
	background: var(--cyan);
	color: #fff;
}
.sdt-tldr__head-text {
	font-size: 14px;
	font-weight: 800;
	letter-spacing: .04em;
	text-transform: uppercase;
	color: var(--navy);
}
.sdt-tldr__body {
	padding: 20px 24px 22px;
	color: var(--ink);
	font-size: 16px;
	line-height: 1.6;
}
/* The shortcode renders bullet lines as <ul.sdt-tldr__list>><li>; loose
   paragraphs (non-bullet lines) still fall back to <p>. Both get the same
   brand pin icon as the list marker. */
.sdt-tldr__body .sdt-tldr__list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.sdt-tldr__body .sdt-tldr__list li,
.sdt-tldr__body p {
	position: relative;
	margin: 0 0 14px;
	padding-left: 30px;
}
.sdt-tldr__body .sdt-tldr__list li:last-child,
.sdt-tldr__body p:last-child { margin-bottom: 0; }
.sdt-tldr__body .sdt-tldr__list li::before,
.sdt-tldr__body p::before {
	content: "";
	position: absolute; left: 0; top: 6px;
	width: 18px; height: 18px;
	background: var(--cyan);
	-webkit-mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'><path d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/></svg>");
	        mask-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='currentColor'><path d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5a2.5 2.5 0 1 1 0-5 2.5 2.5 0 0 1 0 5z'/></svg>");
	-webkit-mask-size: contain; mask-size: contain;
	-webkit-mask-repeat: no-repeat; mask-repeat: no-repeat;
}
.sdt-tldr__body strong { color: var(--navy); font-weight: 700; }
.sdt-tldr__body a { color: var(--cyan); }

/* ── [pricing] block ──────────────────────────────────────────────────────── */
.sdt-pricing-block {
	margin: 32px 0 36px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	overflow: hidden;
	box-shadow: 0 16px 36px -22px rgba(10,23,51,.22);
}
.sdt-pricing-block__head {
	display: grid;
	grid-template-columns: 1.2fr 1fr 2fr;
	background: linear-gradient(180deg, var(--navy), #050e23);
	color: #fff;
}
.sdt-pricing-block__col-head {
	padding: 14px 18px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: rgba(255,255,255,.7);
}
.sdt-pricing-block__col-head--price { color: var(--yellow); }
.sdt-pricing-block__row {
	display: grid;
	grid-template-columns: 1.2fr 1fr 2fr;
	border-bottom: 1px solid var(--line);
	transition: background .15s, box-shadow .15s, transform .15s;
}
.sdt-pricing-block__row:last-child { border-bottom: 0; }
.sdt-pricing-block__row:hover {
	background: rgba(6,182,212,.04);
	box-shadow: inset 4px 0 0 var(--cyan);
}
.sdt-pricing-block__cell {
	padding: 16px 18px;
	font-size: 15px;
	color: var(--ink);
	display: flex; align-items: center;
}
.sdt-pricing-block__cell--tier {
	font-weight: 700;
	color: var(--navy);
	font-size: 16px;
}
.sdt-pricing-block__cell--price {
	font-weight: 800;
	color: var(--navy);
	font-size: 19px;
	letter-spacing: -.01em;
}

/* ── H2 / H3 enhanced styles inside post content ─────────────────────────── */
.sdt-post__content h2 {
	position: relative;
	font-family: 'Inter', sans-serif;
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -.02em;
	line-height: 1.2;
	color: var(--navy);
	margin: 56px 0 18px;
	padding: 4px 0 4px 18px;
	scroll-margin-top: 100px;
}
.sdt-post__content h2::before {
	content: "";
	position: absolute;
	left: 0; top: 8px; bottom: 8px;
	width: 4px;
	background: linear-gradient(180deg, var(--cyan), var(--yellow));
	border-radius: 2px;
}
.sdt-post__content h2::after {
	content: "";
	position: absolute;
	left: 18px; right: 0; bottom: -10px;
	height: 1px;
	background: linear-gradient(90deg, var(--line), transparent 60%);
}

.sdt-post__content h3 {
	font-family: 'Inter', sans-serif;
	font-size: 21px;
	font-weight: 700;
	letter-spacing: -.01em;
	line-height: 1.3;
	color: var(--navy);
	margin: 36px 0 12px;
	padding: 0 0 4px;
	scroll-margin-top: 100px;
	border-bottom: 1px dashed var(--line);
}

.sdt-post__content h4 {
	font-size: 17px;
	font-weight: 700;
	color: var(--navy);
	margin: 28px 0 10px;
}

/* ── Default table styling inside post content ───────────────────────────── */
.sdt-post__content table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 28px 0;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	overflow: hidden;
	box-shadow: 0 12px 28px -20px rgba(10,23,51,.18);
}
.sdt-post__content table thead {
	background: linear-gradient(180deg, var(--paper-2), #fff);
}
.sdt-post__content table th {
	padding: 14px 18px;
	text-align: left;
	font-size: 13px;
	font-weight: 800;
	color: var(--navy);
	letter-spacing: .04em;
	text-transform: uppercase;
	border-bottom: 1px solid var(--line);
}
.sdt-post__content table td {
	padding: 14px 18px;
	font-size: 15px;
	color: var(--ink);
	border-bottom: 1px solid var(--paper-2);
	transition: background .12s;
}
.sdt-post__content table tr:last-child td { border-bottom: 0; }
.sdt-post__content table tbody tr {
	transition: transform .15s, box-shadow .15s, background .15s;
}
.sdt-post__content table tbody tr:hover {
	background: rgba(6,182,212,.04);
	box-shadow: inset 3px 0 0 var(--cyan);
}
.sdt-post__content table tbody tr:hover td {
	color: var(--navy);
}
.sdt-post__content table tbody tr:nth-child(even) {
	background: rgba(10,23,51,.015);
}
.sdt-post__content table tbody tr:nth-child(even):hover {
	background: rgba(6,182,212,.06);
}

/* Pricing block overrides on mobile */
@media (max-width: 640px) {
	.sdt-pricing-block__head,
	.sdt-pricing-block__row { grid-template-columns: 1fr; }
	.sdt-pricing-block__row { padding: 4px 0; }
	.sdt-pricing-block__cell { padding: 8px 18px; }
	.sdt-pricing-block__cell--tier { padding-top: 14px; font-size: 18px; }
	.sdt-pricing-block__cell--price { padding-top: 4px; font-size: 22px; }

	.sdt-post__content table { font-size: 13.5px; }
	.sdt-post__content table th,
	.sdt-post__content table td { padding: 10px 12px; }
}

/* ── Auto-bolded number phrases ──────────────────────────────────────────── */
.sdp-num-bold {
	font-weight: 700;
	color: var(--navy);
	background: linear-gradient(180deg, transparent 70%, rgba(250,204,21,.32) 70%);
	padding: 0 2px;
	border-radius: 2px;
}

/* ── Author box (AGM-aware upgrade) ──────────────────────────────────────── */
.sdt-author {
	margin-top: 48px;
	padding: 24px 26px;
	background: linear-gradient(180deg, var(--paper-2), #fff);
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	display: grid;
	grid-template-columns: 96px 1fr;
	gap: 22px;
	align-items: flex-start;
	box-shadow: 0 14px 32px -22px rgba(10,23,51,.18);
}
.sdt-author__avatar img {
	width: 96px; height: 96px;
	border-radius: 50%;
	display: block;
	border: 3px solid #fff;
	box-shadow: 0 8px 20px -10px rgba(10,23,51,.25);
}
.sdt-author__body { min-width: 0; }
.sdt-author__head {
	display: flex; align-items: flex-start; justify-content: space-between;
	gap: 16px; margin-bottom: 8px;
}
.sdt-author__nameline { display: flex; flex-direction: column; gap: 2px; }
.sdt-author__name {
	font-size: 18px; font-weight: 800;
	color: var(--navy);
	letter-spacing: -.01em;
}
.sdt-author__title {
	font-size: 13px;
	color: var(--muted);
}
.sdt-author__more {
	display: inline-flex; align-items: center; gap: 4px;
	font-size: 12.5px; font-weight: 600;
	color: var(--cyan);
	text-decoration: none;
	white-space: nowrap;
	flex-shrink: 0;
}
.sdt-author__more:hover { text-decoration: underline; }
.sdt-author__bio {
	margin: 4px 0 14px;
	color: var(--ink);
	font-size: 14.5px;
	line-height: 1.55;
}
.sdt-author__meta {
	display: flex; flex-direction: column; gap: 6px;
	margin: 0 0 14px;
}
.sdt-author__meta-row {
	display: flex; align-items: baseline; gap: 10px;
	flex-wrap: wrap;
}
.sdt-author__meta-label {
	font-size: 10.5px;
	font-weight: 800;
	letter-spacing: .08em;
	text-transform: uppercase;
	color: var(--muted);
	flex-shrink: 0;
	min-width: 86px;
}
.sdt-author__chips { display: flex; flex-wrap: wrap; gap: 5px; }
.sdt-author__chip {
	padding: 3px 9px;
	background: rgba(6,182,212,.10);
	border: 1px solid rgba(6,182,212,.22);
	color: var(--cyan);
	border-radius: 999px;
	font-size: 11.5px;
	font-weight: 600;
}
.sdt-author__chip--cred {
	background: rgba(250,204,21,.14);
	border-color: rgba(250,204,21,.4);
	color: #92580c;
}
.sdt-author__edu {
	font-size: 13px;
	color: var(--navy);
	font-weight: 600;
}
.sdt-author__socials {
	display: flex; flex-wrap: wrap; gap: 6px;
	padding-top: 14px;
	border-top: 1px solid var(--line);
}
.sdt-author__social {
	display: inline-flex; align-items: center;
	padding: 5px 11px;
	background: #fff;
	border: 1px solid var(--line);
	color: var(--navy);
	border-radius: 999px;
	font-size: 11.5px;
	font-weight: 700;
	letter-spacing: .02em;
	text-decoration: none;
	transition: background .12s, color .12s, border-color .12s, transform .12s;
}
.sdt-author__social:hover {
	background: var(--navy);
	color: var(--yellow);
	border-color: var(--navy);
	transform: translateY(-1px);
}

@media (max-width: 600px) {
	.sdt-author {
		grid-template-columns: 1fr;
		text-align: center;
	}
	.sdt-author__avatar { margin: 0 auto; }
	.sdt-author__head { justify-content: center; flex-wrap: wrap; }
	.sdt-author__meta-row { justify-content: center; }
	.sdt-author__socials { justify-content: center; }
}

/* =============================================================================
 * [protip] — compact callout (lightbulb / sparkle icon)
 * =========================================================================== */

.sdt-protip {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 16px;
	margin: 28px 0;
	padding: 18px 22px;
	background: linear-gradient(135deg, #fef9c3 0%, #fffaef 100%);
	border: 1px solid rgba(250,204,21,.45);
	border-left: 4px solid var(--yellow);
	border-radius: var(--r-lg);
}
.sdt-protip__icon {
	display: inline-grid; place-items: center;
	width: 36px; height: 36px;
	border-radius: 50%;
	background: var(--yellow);
	color: var(--navy);
	flex-shrink: 0;
	margin-top: 2px;
}
.sdt-protip__title {
	font-size: 12px; font-weight: 800;
	text-transform: uppercase; letter-spacing: .08em;
	color: #92580c;
	margin-bottom: 4px;
}
.sdt-protip__content {
	color: var(--ink);
	font-size: 15.5px; line-height: 1.55;
}
.sdt-protip__content p { margin: 0 0 8px; }
.sdt-protip__content p:last-child { margin-bottom: 0; }
.sdt-protip__content a { color: var(--cyan); }

/* =============================================================================
 * [proscons] — two-column comparison, one bullet per line
 * =========================================================================== */

.sdt-proscons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 16px;
	margin: 28px 0;
}
.sdt-proscons__col {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 20px 22px;
	transition: border-color .15s, box-shadow .15s, transform .15s;
}
.sdt-proscons__col--pros {
	background: linear-gradient(180deg, #ecfdf5 0%, #fff 80%);
	border-color: rgba(16,185,129,.3);
}
.sdt-proscons__col--cons {
	background: linear-gradient(180deg, #fef2f2 0%, #fff 80%);
	border-color: rgba(239,68,68,.3);
}
.sdt-proscons__col-head {
	display: inline-flex; align-items: center; gap: 8px;
	margin: 0 0 14px;
	font-size: 13px; font-weight: 800;
	letter-spacing: .06em;
	text-transform: uppercase;
	color: var(--navy);
}
.sdt-proscons__col-mark {
	display: inline-grid; place-items: center;
	width: 24px; height: 24px;
	border-radius: 50%;
	color: #fff;
}
.sdt-proscons__col--pros .sdt-proscons__col-mark { background: #10b981; }
.sdt-proscons__col--cons .sdt-proscons__col-mark { background: #ef4444; transform: rotate(45deg); }
.sdt-proscons__list {
	list-style: none;
	padding: 0; margin: 0;
}
.sdt-proscons__list li {
	position: relative;
	padding: 8px 0 8px 22px;
	color: var(--ink);
	font-size: 15px; line-height: 1.5;
	border-bottom: 1px solid rgba(10,23,51,.06);
}
.sdt-proscons__list li:last-child { border-bottom: 0; }
.sdt-proscons__list li::before {
	content: ""; position: absolute;
	left: 0; top: 14px;
	width: 12px; height: 12px;
	border-radius: 50%;
}
.sdt-proscons__col--pros .sdt-proscons__list li::before {
	background: #10b981;
	box-shadow: 0 0 0 3px rgba(16,185,129,.15);
}
.sdt-proscons__col--cons .sdt-proscons__list li::before {
	background: #ef4444;
	box-shadow: 0 0 0 3px rgba(239,68,68,.15);
}

@media (max-width: 720px) {
	.sdt-proscons { grid-template-columns: 1fr; }
}

/* =============================================================================
 * [cta] — mid-article call to action
 * =========================================================================== */

.sdt-incta {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 24px;
	align-items: center;
	margin: 36px 0;
	padding: 28px 32px;
	background: linear-gradient(135deg, var(--navy) 0%, #1e293b 100%);
	color: #fff;
	border-radius: var(--r-xl);
	box-shadow: 0 18px 40px -22px rgba(10,23,51,.5);
	position: relative;
	overflow: hidden;
}
.sdt-incta::before {
	content: "";
	position: absolute;
	top: -40px; right: -30px;
	width: 200px; height: 200px;
	background: radial-gradient(circle, rgba(6,182,212,.18), transparent 70%);
	pointer-events: none;
}
.sdt-incta__body { position: relative; min-width: 0; }
.sdt-incta__kicker {
	font-size: 11px; font-weight: 800;
	letter-spacing: .12em; text-transform: uppercase;
	color: var(--cyan);
	margin-bottom: 8px;
}
.sdt-incta__title {
	font-size: 22px; font-weight: 800;
	color: #fff;
	letter-spacing: -.01em;
	line-height: 1.2;
	margin: 0 0 8px;
}
.sdt-incta__sub {
	font-size: 14.5px; line-height: 1.55;
	color: rgba(255,255,255,.85);
	margin: 0;
}
.sdt-incta__extra { margin-top: 12px; font-size: 14px; color: rgba(255,255,255,.78); }
.sdt-incta__extra a { color: var(--yellow); }

.sdt-incta__action { position: relative; flex-shrink: 0; }
.sdt-incta__btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 14px 24px;
	background: var(--yellow);
	color: var(--navy) !important;
	border-radius: 12px;
	font-weight: 800; font-size: 15px;
	text-decoration: none;
	box-shadow: inset 0 1px 0 rgba(255,255,255,.5), 0 12px 28px -14px rgba(250,204,21,.6);
	transition: transform .12s, background .15s;
	white-space: nowrap;
}
.sdt-incta__btn:hover {
	background: #ffd83a;
	transform: translateY(-1px);
}

@media (max-width: 720px) {
	.sdt-incta {
		grid-template-columns: 1fr;
		padding: 24px;
		text-align: center;
	}
	.sdt-incta__btn { width: 100%; justify-content: center; }
}

/* =============================================================================
 * Sidebar cutoff fix: let the rail scroll the page naturally instead of
 * clipping the CTA card when sticky overflows the viewport.
 * =========================================================================== */

.sdt-post__rail-inner {
	/* Was: max-height: calc(100vh - 120px); overflow-y: auto;
	 * Now: let everything be visible. If the rail is taller than the
	 * viewport, the user scrolls the page; sticky still keeps the top
	 * pinned until it runs out of room. */
	max-height: none;
	overflow: visible;
}

/* =============================================================================
 * Custom Directory development form, /custom-directory/.
 * Mirrors Directorist's structure in SDP brand palette.
 * =========================================================================== */

.sdt-cd { color: var(--ink); }
.sdt-cd .container { max-width: 1100px; }

.sdt-cd__hero {
	padding: 64px 0 36px;
	background:
		radial-gradient(900px 500px at 80% -10%, rgba(6,182,212,.10), transparent 60%),
		linear-gradient(180deg, #f8faff 0%, #fff 100%);
	text-align: center;
}
.sdt-cd__kicker {
	display: inline-block;
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .14em;
	color: var(--cyan);
	margin-bottom: 14px;
}
.sdt-cd__title {
	font-size: clamp(32px, 5vw, 52px);
	font-weight: 800;
	letter-spacing: -.025em;
	line-height: 1.05;
	color: var(--navy);
	margin: 0 0 18px;
}
.sdt-cd__sub {
	font-size: 17px;
	line-height: 1.55;
	color: var(--muted);
	max-width: 620px;
	margin: 0 auto;
}

.sdt-cd__body { padding: 48px 0 80px; }
.sdt-cd__layout {
	display: grid;
	grid-template-columns: 360px 1fr;
	gap: 48px;
	align-items: start;
}

.sdt-cd__sidebar { position: sticky; top: 100px; }
.sdt-cd__h2 {
	font-size: 17px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--navy);
	margin: 0 0 14px;
}
.sdt-cd__h2:not(:first-child) { margin-top: 32px; }
.sdt-cd__services {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-direction: column;
	gap: 14px;
}
.sdt-cd__services li {
	font-size: 14px;
	line-height: 1.55;
	color: var(--ink);
	padding-left: 16px;
	border-left: 2px solid var(--cyan);
}
.sdt-cd__services strong {
	color: var(--navy);
	font-weight: 700;
}
.sdt-cd__steps {
	margin: 0;
	padding: 0 0 0 18px;
	display: flex;
	flex-direction: column;
	gap: 8px;
	font-size: 14px;
	line-height: 1.55;
	color: var(--ink);
}

.sdt-cd__form-wrap {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 32px 36px;
	box-shadow: 0 18px 42px -28px rgba(10,23,51,.20);
	position: relative;
}
.sdt-cd__form-wrap::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, var(--cyan), var(--yellow));
	border-radius: var(--r-xl) var(--r-xl) 0 0;
}

.sdt-cd__form { display: flex; flex-direction: column; gap: 20px; }
.sdt-cd__field { display: flex; flex-direction: column; gap: 6px; }
.sdt-cd__field label {
	font-size: 13px;
	font-weight: 700;
	color: var(--navy);
	letter-spacing: .01em;
}
.sdt-cd__req { color: var(--cyan); font-weight: 700; margin-left: 2px; }
.sdt-cd__field input[type="text"],
.sdt-cd__field input[type="email"],
.sdt-cd__field select,
.sdt-cd__field textarea {
	font-family: inherit;
	font-size: 15px;
	color: var(--ink);
	padding: 11px 14px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 10px;
	transition: border-color .15s, box-shadow .15s;
	width: 100%;
	box-sizing: border-box;
}
.sdt-cd__field textarea { resize: vertical; min-height: 140px; }
.sdt-cd__field select {
	-webkit-appearance: none;
	appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2306b6d4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 16px;
	padding-right: 38px;
}
.sdt-cd__field input:focus,
.sdt-cd__field select:focus,
.sdt-cd__field textarea:focus {
	outline: none;
	border-color: var(--cyan);
	box-shadow: 0 0 0 3px rgba(6,182,212,.18);
}
.sdt-cd__field--file input[type="file"] {
	padding: 10px 14px;
	font-size: 14px;
	background: var(--paper-2);
	border: 1px dashed var(--line);
	border-radius: 10px;
	cursor: pointer;
}
.sdt-cd__field small { color: var(--muted); font-size: 12.5px; line-height: 1.5; }

/* Honeypot: visually + accessibly hidden */
.sdt-cd__hp {
	position: absolute;
	left: -9999px;
	width: 1px; height: 1px;
	overflow: hidden;
}

.sdt-cd__submit {
	align-self: flex-start;
	padding: 13px 28px;
	font-size: 15px;
	margin-top: 6px;
}
.sdt-cd__legal {
	font-size: 12.5px;
	color: var(--muted);
	margin: 0;
}
.sdt-cd__legal a { color: var(--cyan); text-decoration: none; font-weight: 600; }
.sdt-cd__legal a:hover { color: var(--navy); }

.sdt-cd__error {
	padding: 14px 16px;
	background: rgba(239,68,68,.08);
	border: 1px solid rgba(239,68,68,.25);
	color: #991b1b;
	border-radius: 10px;
	font-size: 14px;
	margin-bottom: 20px;
}
.sdt-cd__success {
	text-align: center;
	padding: 24px;
}
.sdt-cd__success svg { color: #22c55e; margin-bottom: 14px; }
.sdt-cd__success h2 {
	font-size: 24px;
	font-weight: 800;
	color: var(--navy);
	letter-spacing: -.01em;
	margin: 0 0 10px;
}
.sdt-cd__success p {
	font-size: 15px;
	line-height: 1.6;
	color: var(--ink);
	margin: 0;
}
.sdt-cd__success p a { color: var(--cyan); font-weight: 600; }

@media (max-width: 960px) {
	.sdt-cd__layout { grid-template-columns: 1fr; gap: 32px; }
	.sdt-cd__sidebar { position: static; }
}
@media (max-width: 600px) {
	.sdt-cd__form-wrap { padding: 24px; }
}

/* =============================================================================
 * Single comparison page, /comparison/smart-directory-pro-vs-{slug}/.
 * Two-column body with sticky animated sidebar, brand-aligned hero.
 * =========================================================================== */

.sdt-cmp-vs { color: var(--ink); }
.sdt-cmp-vs .container { max-width: 1200px; }

/* Hero */
.sdt-cmp-vs__hero {
	padding: 64px 0 48px;
	background:
		radial-gradient(1200px 600px at 80% -10%, rgba(6,182,212,.10), transparent 60%),
		radial-gradient(900px 600px at 0% 110%, rgba(250,204,21,.07), transparent 60%),
		linear-gradient(180deg, #f8faff 0%, #fff 100%);
	text-align: center;
}
.sdt-cmp-vs__title {
	font-size: clamp(32px, 5vw, 56px);
	font-weight: 800; letter-spacing: -.025em; line-height: 1.05;
	color: var(--navy);
	margin: 12px 0 16px;
}
.sdt-cmp-vs__title-vs {
	font-family: 'Instrument Serif', Georgia, serif;
	font-weight: 400; font-style: italic;
	color: var(--cyan); letter-spacing: 0;
	padding: 0 6px;
}
.sdt-cmp-vs__sub {
	font-size: 17px; line-height: 1.55; color: var(--muted);
	max-width: 720px; margin: 0 auto 36px;
}

/* Hero head-to-head */
.sdt-cmp-vs__head {
	display: grid; grid-template-columns: 1fr auto 1fr;
	gap: 20px; align-items: center;
	max-width: 760px; margin: 0 auto 32px;
	background: #fff; border: 1px solid var(--line); border-radius: var(--r-xl);
	padding: 22px 18px; box-shadow: 0 18px 42px -28px rgba(10,23,51,.20);
	position: relative; overflow: hidden;
}
.sdt-cmp-vs__head::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, var(--cyan), var(--yellow));
}
.sdt-cmp-vs__side { display: flex; flex-direction: column; align-items: center; gap: 6px; text-align: center; }
.sdt-cmp-vs__avatar {
	width: 56px; height: 56px; border-radius: 50%;
	display: grid; place-items: center;
	font-size: 22px; font-weight: 800; color: #fff;
	margin-bottom: 4px;
	overflow: hidden;
}
.sdt-cmp-vs__avatar img {
	width: 60%; height: 60%;
	object-fit: contain;
	display: block;
}
.sdt-cmp-vs__avatar--sdp  {
	background: linear-gradient(135deg, var(--cyan), #0891b2);
	padding: 8px;
	box-shadow: inset 0 0 0 2px rgba(255,255,255,.25);
}
.sdt-cmp-vs__avatar--sdp img {
	width: 100%; height: 100%;
	filter: drop-shadow(0 1px 2px rgba(0,0,0,.15));
}
.sdt-cmp-vs__avatar--them {
	background: #fff;
	border: 1px solid var(--line);
	box-shadow: 0 1px 3px rgba(10,23,51,.08);
	padding: 8px;
}
.sdt-cmp-vs__avatar--them img { width: 100%; height: 100%; }
.sdt-cmp-vs__avatar--them span { color: var(--navy); font-weight: 800; }
.sdt-cmp-vs__name  { font-size: 15px; font-weight: 700; color: var(--navy); }
.sdt-cmp-vs__stars { font-size: 13px; color: var(--yellow); letter-spacing: -1px; }
.sdt-cmp-vs__stars span { color: var(--muted); margin-left: 4px; letter-spacing: 0; }
.sdt-cmp-vs__price { font-size: 12px; color: var(--muted); }

.sdt-cmp-vs__divider {
	display: flex; flex-direction: column; align-items: center; gap: 10px;
}
.sdt-cmp-vs__divider > span:first-child {
	font-size: 13px; font-weight: 800; letter-spacing: .12em; color: var(--muted);
	padding: 6px 12px; background: var(--paper-2); border-radius: 999px;
}
.sdt-cmp-vs__verdict-badge {
	font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .1em;
	padding: 5px 10px; border-radius: 999px;
	white-space: nowrap;
}
.sdt-cmp-vs__verdict-badge--sdp_edges { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp-vs__verdict-badge--close     { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp-vs__verdict-badge--tie       { background: rgba(148,163,184,.20); color: #475569; }
.sdt-cmp-vs__verdict-badge--they_edge { background: rgba(250,204,21,.22); color: #92400e; }
.sdt-cmp-vs__verdict-badge--outdated  { background: rgba(239,68,68,.12);  color: #b91c1c; }

.sdt-cmp-vs__hero-actions {
	display: flex; gap: 12px; justify-content: center; flex-wrap: wrap;
}

/* Body layout */
.sdt-cmp-vs__body { padding: 48px 0; }
.sdt-cmp-vs__layout {
	display: grid; grid-template-columns: minmax(0, 1fr) 320px;
	gap: 48px;
	align-items: start;
}
.sdt-cmp-vs__main {
	min-width: 0;
}
.sdt-cmp-vs__main h2 {
	font-size: clamp(24px, 2.6vw, 30px);
	font-weight: 800; color: var(--navy); letter-spacing: -.015em;
	margin: 40px 0 14px;
	scroll-margin-top: 100px;
}
.sdt-cmp-vs__main h2:first-of-type { margin-top: 24px; }
.sdt-cmp-vs__main p {
	font-size: 16px; line-height: 1.7; color: var(--ink);
	margin: 0 0 16px;
}
.sdt-cmp-vs__main p strong { color: var(--navy); }

/* Sidebar rail */
.sdt-cmp-vs__rail { position: relative; }
.sdt-cmp-vs__rail-inner {
	position: sticky;
	top: 96px;
	display: flex; flex-direction: column; gap: 24px;
}

/* Reuse vs-table style for the feature comparison */
.sdt-cmp-vs__main .sdt-vs-table { margin: 8px 0 24px; }
.sdt-cmp-vs__main .sdt-vs-table table {
	width: 100%; border-collapse: collapse;
	background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg);
	overflow: hidden;
}
.sdt-cmp-vs__main .sdt-vs-table th,
.sdt-cmp-vs__main .sdt-vs-table td {
	padding: 12px 16px; text-align: left;
	font-size: 14.5px; line-height: 1.5;
	border-bottom: 1px solid var(--line);
	vertical-align: top;
}
.sdt-cmp-vs__main .sdt-vs-table th {
	background: var(--paper-2);
	font-weight: 800; color: var(--navy); font-size: 13px;
	text-transform: uppercase; letter-spacing: .04em;
}
.sdt-cmp-vs__main .sdt-vs-table td:first-child {
	font-weight: 700; color: var(--navy); width: 26%;
	background: rgba(6,182,212,.03);
}
.sdt-cmp-vs__main .sdt-vs-table td:nth-child(2) {
	background: rgba(6,182,212,.04);
}
.sdt-cmp-vs__main .sdt-vs-table tr:last-child td { border-bottom: 0; }

/* Blockquote inside the comparison body inherits the existing wp-block-quote
   style; we just nudge spacing. */
.sdt-cmp-vs__main blockquote.wp-block-quote {
	margin: 18px 0 24px;
}

/* Responsive */
@media (max-width: 980px) {
	.sdt-cmp-vs__layout { grid-template-columns: 1fr; gap: 32px; }
	.sdt-cmp-vs__rail { order: 2; }
	.sdt-cmp-vs__rail-inner { position: static; }
}
@media (max-width: 640px) {
	.sdt-cmp-vs__head { grid-template-columns: 1fr; }
	.sdt-cmp-vs__divider { flex-direction: row; justify-content: center; }
}

/* =============================================================================
 * Comparisons hub at /comparisons/. SDP brand palette (navy / cyan / yellow)
 * applied to a multi-section landing rebuilt from a design reference.
 * =========================================================================== */

.sdt-cmp { color: var(--ink); }
.sdt-cmp .container { max-width: 1200px; }

.sdt-cmp__kicker {
	display: inline-block;
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .14em;
	color: var(--cyan);
	margin-bottom: 14px;
}
.sdt-cmp__kicker--on-dark { color: #facc15; }

.sdt-cmp__h2 {
	font-size: clamp(28px, 3.4vw, 40px);
	font-weight: 800;
	letter-spacing: -.02em;
	line-height: 1.15;
	color: var(--navy);
	margin: 0 0 18px;
}

.sdt-cmp__section-head {
	display: flex; align-items: flex-end; justify-content: space-between;
	gap: 24px; margin-bottom: 32px;
	flex-wrap: wrap;
}
.sdt-cmp__section-link {
	font-size: 14px; font-weight: 700; color: var(--cyan);
	text-decoration: none;
}
.sdt-cmp__section-link:hover { color: var(--navy); }

.sdt-cmp__lede { font-size: 17px; line-height: 1.6; color: var(--muted); margin: 0; max-width: 640px; }

/* ── 1. HERO ──────────────────────────────────────────────────────────────── */
.sdt-cmp__hero {
	padding: 72px 0 56px;
	background:
		radial-gradient(1200px 600px at 80% -10%, rgba(6,182,212,.10), transparent 60%),
		radial-gradient(900px 600px at 0% 110%, rgba(250,204,21,.07), transparent 60%),
		linear-gradient(180deg, #f8faff 0%, #fff 100%);
}
.sdt-cmp__hero-grid {
	display: grid;
	grid-template-columns: 1fr 360px;
	gap: 56px;
	align-items: start;
}
.sdt-cmp__title {
	font-size: clamp(40px, 5.5vw, 64px);
	font-weight: 800;
	letter-spacing: -.025em;
	line-height: 1.05;
	color: var(--navy);
	margin: 0 0 20px;
}
.sdt-cmp__title-em {
	font-family: 'Instrument Serif', Georgia, serif;
	font-weight: 400;
	font-style: italic;
	color: var(--cyan);
	letter-spacing: 0;
}
.sdt-cmp__hero-body {
	font-size: 18px; line-height: 1.6;
	color: var(--muted);
	max-width: 580px;
	margin: 0 0 28px;
}
.sdt-cmp__hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }

/* Tally aside (Editor's tally) */
.sdt-cmp__tally {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 22px 24px;
	box-shadow: 0 18px 42px -28px rgba(10,23,51,.25);
	position: relative;
	overflow: hidden;
}
.sdt-cmp__tally::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 4px;
	background: linear-gradient(90deg, var(--cyan), var(--yellow));
}
.sdt-cmp__tally-kicker {
	font-size: 11px; text-transform: uppercase; letter-spacing: .08em;
	font-weight: 800; color: var(--cyan); margin-bottom: 2px;
}
.sdt-cmp__tally-month {
	font-size: 13px; color: var(--muted); margin-bottom: 14px;
}
.sdt-cmp__tally-rows { display: flex; flex-direction: column; gap: 10px; }
.sdt-cmp__tally-row {
	display: flex; justify-content: space-between; align-items: baseline;
	padding: 10px 14px;
	background: var(--paper-2);
	border-radius: 10px;
	font-size: 14px; font-weight: 600; color: var(--navy);
	border-left: 3px solid var(--cyan);
}
.sdt-cmp__tally-row--win   { border-left-color: var(--cyan); }
.sdt-cmp__tally-row--loss  { border-left-color: var(--yellow); }
.sdt-cmp__tally-row--tie   { border-left-color: #94a3b8; }
.sdt-cmp__tally-row--dead  { border-left-color: #e2e8f0; color: var(--muted); }
.sdt-cmp__tally-num {
	font-size: 22px; font-weight: 800; color: var(--navy);
	letter-spacing: -.02em;
}
.sdt-cmp__tally-num sup { font-size: 11px; font-weight: 600; color: var(--muted); margin-left: 2px; }
.sdt-cmp__tally-note { margin: 14px 0 0; font-size: 13px; color: var(--muted); line-height: 1.5; }

/* ── 2. DISCLOSURE ───────────────────────────────────────────────────────── */
.sdt-cmp__disclosure { padding: 56px 0; }
.sdt-cmp__disclosure-body {
	font-size: 17px; line-height: 1.65; color: var(--ink);
	max-width: 760px; margin: 0 0 32px;
}
.sdt-cmp__stats {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
	gap: 16px;
}
.sdt-cmp__stat {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 18px 20px;
}
.sdt-cmp__stat strong {
	display: block; font-size: 32px; font-weight: 800;
	color: var(--navy); letter-spacing: -.02em; line-height: 1; margin-bottom: 6px;
}
.sdt-cmp__stat span { font-size: 13px; color: var(--muted); }

/* ── 3. MOST-SEARCHED MATCHUPS (head-to-head VS cards) ───────────────────── */
.sdt-cmp__featured { padding: 56px 0; background: linear-gradient(180deg, transparent, #f8faff 50%, transparent); }
.sdt-cmp__featured-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(340px, 1fr));
	gap: 24px;
}
.sdt-cmp__vs {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	padding: 24px;
	box-shadow: 0 18px 42px -28px rgba(10,23,51,.20);
	display: flex; flex-direction: column; gap: 18px;
	position: relative;
	overflow: hidden;
}
.sdt-cmp__vs::before {
	content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, var(--cyan), var(--yellow));
}
.sdt-cmp__vs-tag {
	font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em;
	color: var(--muted);
}
.sdt-cmp__vs-tag::after { content: " "; }
.sdt-cmp__vs-head {
	display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 14px;
	padding: 8px 0 16px;
	border-bottom: 1px dashed var(--line);
}
.sdt-cmp__vs-side { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 4px; }
.sdt-cmp__vs-avatar {
	width: 44px; height: 44px; border-radius: 50%;
	display: grid; place-items: center;
	font-size: 18px; font-weight: 800; letter-spacing: -.01em;
	color: #fff; margin-bottom: 4px;
	overflow: hidden;
}
.sdt-cmp__vs-avatar img {
	width: 100%; height: 100%;
	object-fit: contain;
	display: block;
}
.sdt-cmp__vs-avatar--sdp {
	background: linear-gradient(135deg, var(--cyan), #0891b2);
	padding: 7px;
	box-shadow: inset 0 0 0 2px rgba(255,255,255,.25);
}
.sdt-cmp__vs-avatar--sdp img { filter: drop-shadow(0 1px 2px rgba(0,0,0,.15)); }
.sdt-cmp__vs-avatar--them {
	background: #fff;
	border: 1px solid var(--line);
	box-shadow: 0 1px 3px rgba(10,23,51,.08);
	padding: 7px;
}
.sdt-cmp__vs-avatar--them span { color: var(--navy); font-weight: 800; }
.sdt-cmp__vs-name  { font-size: 14px; font-weight: 700; color: var(--navy); }
.sdt-cmp__vs-stars { font-size: 12px; color: var(--yellow); letter-spacing: -1px; }
.sdt-cmp__vs-stars span { color: var(--muted); margin-left: 4px; letter-spacing: 0; }
.sdt-cmp__vs-price { font-size: 12px; color: var(--muted); }
.sdt-cmp__vs-divider {
	font-size: 12px; font-weight: 800; letter-spacing: .12em; color: var(--muted);
	padding: 6px 10px; background: var(--paper-2); border-radius: 999px;
}

.sdt-cmp__vs-badge {
	align-self: flex-start;
	font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em;
	padding: 5px 10px; border-radius: 999px;
}
.sdt-cmp__vs-badge--sdp_edges { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp__vs-badge--close     { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp__vs-badge--tie       { background: rgba(148,163,184,.18); color: #475569; }
.sdt-cmp__vs-badge--they_edge { background: rgba(250,204,21,.20); color: #92400e; }
.sdt-cmp__vs-badge--outdated  { background: rgba(239,68,68,.12);  color: #b91c1c; }

.sdt-cmp__vs-desc { margin: 0; font-size: 14.5px; line-height: 1.55; color: var(--ink); }
.sdt-cmp__vs-picks { display: flex; flex-direction: column; gap: 12px; }
.sdt-cmp__vs-pick { background: var(--paper-2); border-radius: 10px; padding: 12px 14px; }
.sdt-cmp__vs-pick-h { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); font-weight: 700; margin-bottom: 4px; }
.sdt-cmp__vs-pick-h strong { color: var(--navy); }
.sdt-cmp__vs-pick p { margin: 0; font-size: 13.5px; line-height: 1.5; color: var(--ink); }

.sdt-cmp__vs-footer {
	margin-top: auto; padding-top: 16px;
	border-top: 1px dashed var(--line);
	display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.sdt-cmp__vs-stat { font-size: 11px; color: var(--muted); letter-spacing: .05em; }
.sdt-cmp__vs-link { font-size: 13px; font-weight: 700; color: var(--cyan); text-decoration: none; white-space: nowrap; }
.sdt-cmp__vs-link:hover { color: var(--navy); }

/* ── 4. THE INDEX (full grid with controls) ──────────────────────────────── */
.sdt-cmp__index { padding: 56px 0; }
.sdt-cmp__controls {
	display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 16px;
	align-items: center;
}
.sdt-cmp__search {
	flex: 1; min-width: 240px;
	padding: 12px 18px;
	font-size: 14px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	color: var(--ink);
	transition: border-color .15s, box-shadow .15s;
}
.sdt-cmp__search:focus {
	outline: none;
	border-color: var(--cyan);
	box-shadow: 0 0 0 3px rgba(6,182,212,.18);
}
.sdt-cmp__sort { display: flex; align-items: center; gap: 8px; }
.sdt-cmp__sort label { font-size: 13px; color: var(--muted); font-weight: 600; }
.sdt-cmp__sort select {
	padding: 11px 32px 11px 14px;
	font-size: 14px; font-weight: 600;
	background: #fff;
	border: 1px solid var(--line); border-radius: 999px;
	color: var(--navy);
	-webkit-appearance: none;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2306b6d4' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");
	background-repeat: no-repeat; background-position: right 12px center;
	background-size: 14px;
	cursor: pointer;
}

.sdt-cmp__filters { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
.sdt-cmp__pill {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 9px 16px;
	background: #fff;
	border: 1px solid var(--line); border-radius: 999px;
	font-size: 13px; font-weight: 600; color: var(--muted);
	cursor: pointer;
	transition: border-color .15s, color .15s, background .15s;
}
.sdt-cmp__pill:hover { color: var(--navy); border-color: var(--navy); }
.sdt-cmp__pill.is-active { background: var(--navy); color: #fff; border-color: var(--navy); }
.sdt-cmp__pill span {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; height: 22px; padding: 0 7px;
	background: rgba(0,0,0,.08); border-radius: 999px;
	font-size: 10px; font-weight: 700;
}
.sdt-cmp__pill.is-active span { background: rgba(255,255,255,.18); }

.sdt-cmp__count { font-size: 13px; color: var(--muted); margin-bottom: 20px; }
.sdt-cmp__count #sdt-cmp-count { color: var(--navy); font-weight: 700; }

.sdt-cmp__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
	gap: 20px;
}

.sdt-cmp__card {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	overflow: hidden;
	transition: transform .2s, box-shadow .2s, border-color .2s;
	display: flex; flex-direction: column;
}
.sdt-cmp__card:hover {
	transform: translateY(-3px);
	border-color: var(--cyan);
	box-shadow: 0 18px 32px -18px rgba(6,182,212,.30);
}
.sdt-cmp__card-shot {
	display: block;
	aspect-ratio: 5 / 3;
	background: linear-gradient(135deg, #0e2245, #0891b2);
	overflow: hidden;
	position: relative;
}
.sdt-cmp__card-shot img {
	display: block; width: 100%; height: 100%;
	object-fit: cover; object-position: top center;
	transition: transform .4s ease-out;
}
.sdt-cmp__card:hover .sdt-cmp__card-shot img { transform: scale(1.04); }
.sdt-cmp__card-body {
	padding: 18px 20px 20px;
	flex: 1; display: flex; flex-direction: column;
}
.sdt-cmp__card-head {
	display: flex; justify-content: space-between; align-items: flex-start;
	gap: 10px; margin-bottom: 10px;
}
.sdt-cmp__card-title {
	font-size: 18px; font-weight: 700; color: var(--navy);
	letter-spacing: -.01em; margin: 0;
}
.sdt-cmp__card-verdict {
	font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em;
	padding: 4px 9px; border-radius: 999px;
	white-space: nowrap;
}
.sdt-cmp__card-verdict--sdp_edges { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp__card-verdict--close     { background: rgba(6,182,212,.12);  color: #0891b2; }
.sdt-cmp__card-verdict--tie       { background: rgba(148,163,184,.20); color: #475569; }
.sdt-cmp__card-verdict--they_edge { background: rgba(250,204,21,.22); color: #92400e; }
.sdt-cmp__card-verdict--outdated  { background: rgba(239,68,68,.12);  color: #b91c1c; }

.sdt-cmp__card-desc {
	font-size: 13.5px; line-height: 1.5; color: var(--muted);
	margin: 0 0 14px;
	display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
	overflow: hidden;
}
.sdt-cmp__card-stats {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 10px; padding: 12px 0;
	border-top: 1px dashed var(--line);
	border-bottom: 1px dashed var(--line);
	margin-bottom: 14px;
}
.sdt-cmp__card-stats div { font-size: 13px; color: var(--ink); }
.sdt-cmp__card-stat-label {
	display: block; font-size: 10px; text-transform: uppercase; letter-spacing: .08em;
	color: var(--muted); margin-bottom: 2px; font-weight: 700;
}
.sdt-cmp__card-stats strong { font-weight: 700; color: var(--navy); font-size: 14px; }
.sdt-cmp__card-stat-sub { display: block; font-size: 11px; color: var(--muted); margin-top: 1px; }

.sdt-cmp__card-foot {
	margin-top: auto;
	display: flex; justify-content: space-between; align-items: center; gap: 10px;
}
.sdt-cmp__card-tags { font-size: 11px; color: var(--muted); letter-spacing: .04em; }
.sdt-cmp__card-cta {
	font-size: 13px; font-weight: 700; color: var(--cyan);
	text-decoration: none; white-space: nowrap;
}
.sdt-cmp__card-cta:hover { color: var(--navy); }

/* ── 5. BUYING GUIDES ────────────────────────────────────────────────────── */
.sdt-cmp__guides { padding: 56px 0; background: linear-gradient(180deg, #f8faff, transparent); }
.sdt-cmp__guides-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
	gap: 18px;
}
.sdt-cmp__guide {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 22px;
	text-decoration: none;
	color: inherit;
	display: flex; flex-direction: column; gap: 10px;
	transition: transform .2s, border-color .2s, box-shadow .2s;
}
.sdt-cmp__guide:hover {
	transform: translateY(-3px);
	border-color: var(--navy);
	box-shadow: 0 18px 32px -22px rgba(10,23,51,.25);
}
.sdt-cmp__guide-num {
	font-family: 'Instrument Serif', Georgia, serif;
	font-size: 42px; font-weight: 400; color: var(--cyan);
	line-height: 1; letter-spacing: -.02em;
	display: flex; align-items: baseline; gap: 8px;
}
.sdt-cmp__guide-num span {
	font-family: 'Inter', sans-serif;
	font-size: 11px; font-weight: 800; letter-spacing: .12em;
	text-transform: uppercase; color: var(--muted);
}
.sdt-cmp__guide-title {
	font-size: 18px; font-weight: 700; letter-spacing: -.01em;
	color: var(--navy); margin: 0;
}
.sdt-cmp__guide-desc { margin: 0; font-size: 13.5px; line-height: 1.55; color: var(--muted); }

/* ── 6. BROWSE BY NICHE ──────────────────────────────────────────────────── */
.sdt-cmp__niches { padding: 56px 0; }
.sdt-cmp__niche-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
	gap: 20px;
}
.sdt-cmp__niche {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	padding: 22px;
}
.sdt-cmp__niche-kicker {
	font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .08em;
	color: var(--cyan); margin-bottom: 6px;
}
.sdt-cmp__niche-title {
	font-size: 17px; font-weight: 700; color: var(--navy);
	letter-spacing: -.01em; margin: 0 0 14px;
}
.sdt-cmp__niche ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.sdt-cmp__niche li a {
	display: flex; justify-content: space-between; align-items: center;
	gap: 12px; padding: 8px 10px; margin: 0 -10px; border-radius: 8px;
	font-size: 14px; color: var(--ink); font-weight: 600;
	text-decoration: none;
	transition: background .15s, color .15s;
}
.sdt-cmp__niche li a:hover { background: var(--paper-2); color: var(--navy); }
.sdt-cmp__niche-price { font-size: 12px; color: var(--muted); font-weight: 600; }

/* ── 7. EDITORIAL RUBRIC FAQ ─────────────────────────────────────────────── */
.sdt-cmp__rubric { padding: 56px 0; background: var(--paper-2); }
.sdt-cmp__rubric-list { max-width: 820px; }
.sdt-cmp__rubric-item {
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	margin-bottom: 12px;
	transition: border-color .15s;
}
.sdt-cmp__rubric-item[open] { border-color: var(--cyan); }
.sdt-cmp__rubric-item summary {
	list-style: none;
	cursor: pointer;
	padding: 18px 22px;
	font-size: 15.5px; font-weight: 700;
	color: var(--navy);
	display: flex; align-items: center; justify-content: space-between; gap: 16px;
}
.sdt-cmp__rubric-item summary::-webkit-details-marker { display: none; }
.sdt-cmp__rubric-item summary::after {
	content: "+"; font-size: 22px; font-weight: 600; color: var(--cyan);
	transition: transform .2s;
}
.sdt-cmp__rubric-item[open] summary::after { content: "−"; }
.sdt-cmp__rubric-item p { margin: 0 22px 18px; font-size: 14.5px; line-height: 1.6; color: var(--ink); }

/* ── 8. CLOSING CTA ─────────────────────────────────────────────────────── */
.sdt-cmp__close {
	padding: 72px 0;
	background:
		radial-gradient(800px 400px at 50% 0%, rgba(6,182,212,.15), transparent 70%),
		linear-gradient(180deg, #0a1733, #1e293b);
	color: #fff;
}
.sdt-cmp__close-inner { text-align: center; max-width: 720px; margin: 0 auto; }
.sdt-cmp__close-title {
	font-size: clamp(28px, 4vw, 44px);
	font-weight: 800; letter-spacing: -.02em; line-height: 1.15;
	color: #fff; margin: 12px 0 16px;
}
.sdt-cmp__close-body { font-size: 17px; line-height: 1.55; color: #cbd5e1; margin: 0 auto 28px; max-width: 600px; }
.sdt-cmp__close-actions { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-bottom: 28px; }
/* Ghost button variant used on the closing CTA dark gradient. */
.sdt-cmp__close-ghost {
	background: rgba(255,255,255,.06);
	color: #fff;
	border: 1px solid rgba(255,255,255,.18);
}
.sdt-cmp__close-ghost:hover { background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.32); }
.sdt-cmp__close-badges {
	display: flex; flex-wrap: wrap; gap: 12px 28px; justify-content: center;
	font-size: 13px; color: #cbd5e1;
}

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 980px) {
	.sdt-cmp__hero-grid { grid-template-columns: 1fr; gap: 32px; }
	.sdt-cmp__tally { order: -1; }
}
@media (max-width: 600px) {
	.sdt-cmp__hero { padding: 48px 0 40px; }
	.sdt-cmp__disclosure, .sdt-cmp__featured, .sdt-cmp__index, .sdt-cmp__guides, .sdt-cmp__niches, .sdt-cmp__rubric, .sdt-cmp__close { padding: 40px 0; }
	.sdt-cmp__vs-head { grid-template-columns: 1fr; gap: 18px; }
	.sdt-cmp__vs-divider { justify-self: center; }
	.sdt-cmp__card-stats { grid-template-columns: 1fr; gap: 8px; }
}

/* =============================================================================
 * Competitor archive hub at /competitor/.
 * Hero + filter buttons + card grid + closing CTA.
 * =========================================================================== */

.sdt-shell--comp-hub { padding: 64px 0 96px; }

.sdt-comp-hub__head {
	max-width: 720px;
	margin: 0 auto 48px;
	text-align: center;
}
.sdt-comp-hub__title {
	font-size: clamp(32px, 4.5vw, 48px);
	font-weight: 800;
	letter-spacing: -.02em;
	line-height: 1.1;
	color: var(--navy);
	margin: 12px 0 16px;
}
.sdt-comp-hub__sub {
	font-size: 17px;
	line-height: 1.6;
	color: var(--muted);
	margin: 0 auto 24px;
}

.sdt-comp-hub__filters {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 8px;
	margin-top: 28px;
}
.sdt-comp-hub__filter {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 10px 18px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: 999px;
	font-size: 14px;
	font-weight: 600;
	color: var(--muted);
	cursor: pointer;
	transition: border-color .15s, color .15s, background .15s, transform .15s;
}
.sdt-comp-hub__filter:hover { color: var(--navy); border-color: var(--navy); }
.sdt-comp-hub__filter.is-active {
	background: var(--navy);
	color: #fff;
	border-color: var(--navy);
}
.sdt-comp-hub__filter-count {
	display: inline-flex; align-items: center; justify-content: center;
	min-width: 22px; height: 22px;
	padding: 0 7px;
	background: rgba(0,0,0,.08);
	border-radius: 999px;
	font-size: 11px;
	font-weight: 700;
}
.sdt-comp-hub__filter.is-active .sdt-comp-hub__filter-count {
	background: rgba(255,255,255,.18);
}

.sdt-comp-hub__grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
	gap: 20px;
	margin-bottom: 64px;
}

.sdt-comp-card {
	display: flex;
	flex-direction: column;
	padding: 24px;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-lg);
	text-decoration: none;
	color: inherit;
	transition: transform .2s ease-out, border-color .2s ease-out, box-shadow .2s ease-out;
	position: relative;
	overflow: hidden;
}
.sdt-comp-card::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0; height: 3px;
	background: linear-gradient(90deg, var(--cyan), var(--yellow));
	opacity: 0;
	transition: opacity .2s ease-out;
}
.sdt-comp-card:hover {
	transform: translateY(-3px);
	border-color: var(--cyan);
	box-shadow: 0 16px 32px -16px rgba(6,182,212,.25);
}
.sdt-comp-card:hover::before { opacity: 1; }

.sdt-comp-card__head {
	display: flex;
	flex-direction: column;
	gap: 6px;
	margin-bottom: 14px;
}
.sdt-comp-card__title {
	font-size: 19px;
	font-weight: 700;
	letter-spacing: -.01em;
	color: var(--navy);
	margin: 0;
}
.sdt-comp-card__type {
	display: inline-flex;
	align-self: flex-start;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .06em;
	color: var(--cyan);
	background: rgba(6,182,212,.08);
	padding: 3px 9px;
	border-radius: 999px;
	max-width: 100%;
}

.sdt-comp-card__stats {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 14px;
	font-size: 13px;
	color: var(--muted);
	margin-bottom: 12px;
}
.sdt-comp-card__stat {
	display: inline-flex;
	align-items: center;
	gap: 4px;
	font-weight: 600;
}
.sdt-comp-card__stat svg { color: var(--yellow); }
.sdt-comp-card__stat--price { color: var(--navy); }

.sdt-comp-card__excerpt {
	flex: 1;
	font-size: 14px;
	line-height: 1.55;
	color: var(--muted);
	margin: 0 0 16px;
}

.sdt-comp-card__cta {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 13px;
	font-weight: 700;
	color: var(--cyan);
}
.sdt-comp-card:hover .sdt-comp-card__cta { color: var(--navy); }
.sdt-comp-card:hover .sdt-comp-card__cta svg { transform: translateX(3px); }
.sdt-comp-card__cta svg { transition: transform .2s ease-out; }

.sdt-comp-hub__bottom-cta {
	margin-top: 32px;
	padding: 40px 32px;
	background: linear-gradient(180deg, #0a1733, #1e293b);
	color: #fff;
	border-radius: var(--r-xl);
	text-align: center;
}
.sdt-comp-hub__bottom-cta h2 {
	color: #fff;
	font-size: 28px;
	font-weight: 800;
	letter-spacing: -.01em;
	margin: 0 0 12px;
}
.sdt-comp-hub__bottom-cta p {
	max-width: 640px;
	margin: 0 auto 24px;
	color: #cbd5e1;
	font-size: 16px;
	line-height: 1.6;
}
.sdt-comp-hub__bottom-cta-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
}

@media (max-width: 600px) {
	.sdt-shell--comp-hub { padding: 40px 0 64px; }
	.sdt-comp-hub__head { margin-bottom: 32px; }
	.sdt-comp-hub__bottom-cta { padding: 28px 20px; }
}

/* =============================================================================
 * Brand logo (img-based, replaces icon+text combo in nav + footer)
 * =========================================================================== */

.brand { display: inline-flex; align-items: center; line-height: 0; }
.brand-logo {
	display: block;
	height: 36px;
	width: auto;
	max-width: 220px;
	object-fit: contain;
}
.brand-logo--light {
	/* Footer (dark bg): the "dark" file variant has white text. */
	filter: none;
}
@media (max-width: 600px) {
	.brand-logo { height: 30px; }
}

/* =============================================================================
 * [faq] shortcode — brand accordion + FAQPage schema
 * =========================================================================== */

.sdt-faq {
	margin: 36px 0;
	background: #fff;
	border: 1px solid var(--line);
	border-radius: var(--r-xl);
	box-shadow: 0 16px 36px -22px rgba(10,23,51,.18);
	overflow: hidden;
}
.sdt-faq__head {
	display: flex; align-items: center; gap: 10px;
	padding: 18px 24px;
	background: linear-gradient(180deg, rgba(6,182,212,.08), #fff);
	border-bottom: 1px solid var(--line);
}
.sdt-faq__head-mark {
	display: inline-grid; place-items: center;
	width: 30px; height: 30px;
	border-radius: 50%;
	background: var(--cyan); color: #fff;
}
.sdt-faq__head-text {
	font-size: 14px; font-weight: 800;
	letter-spacing: .06em; text-transform: uppercase;
	color: var(--navy);
}
.sdt-faq__list { padding: 6px 0; }
.sdt-faq__item {
	border-bottom: 1px solid var(--line);
	transition: background .12s;
}
.sdt-faq__item:last-child { border-bottom: 0; }
.sdt-faq__item[open] {
	background: linear-gradient(180deg, rgba(6,182,212,.04), transparent);
}
.sdt-faq__q {
	display: flex; align-items: flex-start; justify-content: space-between;
	gap: 16px;
	padding: 18px 24px;
	cursor: pointer;
	color: var(--navy);
	font-weight: 700;
	font-size: 16.5px;
	line-height: 1.4;
	letter-spacing: -.005em;
	list-style: none;
	outline: none;
}
.sdt-faq__q::-webkit-details-marker { display: none; }
.sdt-faq__q::marker { content: ""; }
.sdt-faq__q:focus-visible {
	background: rgba(6,182,212,.06);
	box-shadow: inset 3px 0 0 var(--cyan);
}
.sdt-faq__q-text { flex: 1; min-width: 0; }
.sdt-faq__q-icon {
	flex-shrink: 0;
	width: 28px; height: 28px;
	display: inline-grid; place-items: center;
	border-radius: 50%;
	background: var(--paper-2);
	color: var(--cyan);
	transition: transform .25s, background .15s, color .15s;
}
.sdt-faq__item[open] .sdt-faq__q-icon {
	background: var(--cyan);
	color: #fff;
	transform: rotate(45deg);
}
.sdt-faq__a {
	padding: 0 24px 22px;
	color: var(--ink);
	font-size: 15.5px;
	line-height: 1.65;
}
.sdt-faq__a p { margin: 0 0 .85em; }
.sdt-faq__a p:last-child { margin-bottom: 0; }
.sdt-faq__a a { color: var(--cyan); }
.sdt-faq__a strong { color: var(--navy); }
.sdt-faq__a code {
	background: var(--paper-2);
	padding: 1px 6px;
	border-radius: 4px;
	font-size: .92em;
	font-family: 'JetBrains Mono', monospace;
	color: var(--navy);
}

@media (max-width: 600px) {
	.sdt-faq__head { padding: 14px 18px; }
	.sdt-faq__q { padding: 14px 18px; font-size: 15.5px; }
	.sdt-faq__a { padding: 0 18px 16px; font-size: 14.5px; }
}

/* =============================================================================
 * CTA dark-on-dark fix: the previous .sdt-incta__title was <h3>, which
 * the blog-prose H3 selector painted navy. Element is now <div>, but we
 * also bump specificity here so any future hover/focus/global theme rules
 * can't repaint the title invisible.
 * =========================================================================== */

.sdt-incta .sdt-incta__title,
.sdt-post__content .sdt-incta__title {
	color: #ffffff !important;
	border: 0;
	padding: 0;
	margin: 0 0 8px;
	font-size: 22px;
	font-weight: 800;
	letter-spacing: -.01em;
	line-height: 1.2;
}
.sdt-incta .sdt-incta__sub,
.sdt-post__content .sdt-incta__sub {
	color: rgba(255,255,255,.85);
}
.sdt-incta .sdt-incta__kicker,
.sdt-post__content .sdt-incta__kicker {
	color: var(--cyan);
}
