/* â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•
   Design Buddy â€” Marketing Website Styles
   Liquid Glass Â· DM Sans + DM Mono Â· Dark void
   â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â•â• */

/* â”€â”€ 1. Tokens â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root {
  /* Base palette */
  --bg:            #060610;
  --bg-soft:       #0c0c1e;
  --text:          #E8EAF2;
  --text-muted:    #5A5C72;
  --text-soft:     #9698AC;

  /* Accents â€” creative freedom, vivid on dark */
  --indigo:        #6366f1;
  --violet:        #8b5cf6;
  --cyan:          #22d3ee;
  --teal:          #10b981;
  --amber:         #f59e0b;
  --rose:          #e879a0;
  --red:           #ef4444;
  --blue:          #3b82f6;

  /* Gradients */
  --grad-primary:  linear-gradient(135deg, #6366f1, #8b5cf6 50%, #22d3ee);
  --grad-glow:     linear-gradient(135deg, rgba(99,102,241,0.4), rgba(34,211,238,0.3));
  --grad-hero:     linear-gradient(135deg, #a78bfa, #67e8f9);

  /* Glass surfaces â€” Liquid Glass system */
  --g-card-fill:   rgba(255,255,255,0.042);
  --g-card-blur:   blur(24px) saturate(1.2);
  --g-card-border: rgba(255,255,255,0.08);
  --g-card-hi:     inset 0 1px 0 rgba(255,255,255,0.07);
  --g-card-shadow: 0 4px 24px rgba(0,0,0,0.36);

  --g-ghost-fill:  rgba(255,255,255,0.055);
  --g-ghost-blur:  blur(12px);
  --g-ghost-border:rgba(255,255,255,0.08);

  --g-accent-fill: rgba(99,102,241,0.15);
  --g-accent-blur: blur(14px) saturate(1.3);
  --g-accent-border:rgba(99,102,241,0.35);
  --g-accent-hi:   inset 0 1px 0 rgba(255,255,255,0.22);
  --g-accent-glow: 0 6px 24px rgba(99,102,241,0.28);

  --border-dim:    rgba(255,255,255,0.06);
  --border-soft:   rgba(255,255,255,0.08);
  --border-hover:  rgba(255,255,255,0.16);

  /* Typography */
  --font-sans: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono: 'DM Mono', ui-monospace, 'SF Mono', monospace;

  /* Type scale */
  --fs-xl:   clamp(3.6rem, 8.5vw, 8rem);
  --fs-lg:   clamp(2.4rem, 5vw, 5rem);
  --fs-md:   clamp(1.6rem, 2.8vw, 2.4rem);
  --fs-base: 1.0625rem;
  --fs-sm:   0.9375rem;
  --fs-xs:   0.8125rem;
  --fs-2xs:  0.75rem;

  /* Spacing */
  --s1:  4px;  --s2:  8px;   --s3:  12px;
  --s4:  16px; --s5:  24px;  --s6:  32px;
  --s7:  48px; --s8:  64px;  --s9:  96px;
  --s10: 128px;

  /* Radius */
  --r-sm: 8px;   --r-md: 12px;
  --r-lg: 16px;  --r-xl: 24px;

  /* Motion */
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-std: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-in:  cubic-bezier(0.4, 0, 1, 1);
  --dur-fast: 120ms;
  --dur:      220ms;
  --dur-slow: 600ms;
}

/* â”€â”€ 2. Reset & base â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
  overscroll-behavior: none;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-sans);
  font-size: var(--fs-base);
  font-weight: 400;
  line-height: 1.6;
  text-rendering: geometricPrecision;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  overscroll-behavior: none;
}

body.custom-cursor { cursor: none; }
body.custom-cursor button { cursor: none; }

img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { background: none; border: none; font: inherit; }
ul, ol { list-style: none; }
em { font-style: normal; }
strong { font-weight: 600; }

:focus-visible {
  outline: 2px solid var(--indigo);
  outline-offset: 3px;
  border-radius: 4px;
}

/* â”€â”€ 3. Scroll progress line â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.scroll-progress {
  position: fixed;
  top: 0; left: 0;
  height: 2px;
  width: 100%;
  background: var(--grad-primary);
  transform-origin: left;
  transform: scaleX(0);
  z-index: 9999;
  pointer-events: none;
}

@supports (animation-timeline: scroll()) {
  .scroll-progress {
    animation: grow linear both;
    animation-timeline: scroll(root);
  }
}

@keyframes grow {
  from { transform: scaleX(0); }
  to   { transform: scaleX(1); }
}

/* â”€â”€ 4. Custom cursor â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.cursor-dot,
.cursor-ring {
  position: fixed;
  top: 0; left: 0;
  border-radius: 50%;
  pointer-events: none;
  z-index: 9998;
  transform: translate(-50%, -50%);
  transition: opacity 0.3s;
}

.cursor-dot {
  width: 6px; height: 6px;
  background: var(--text);
}

.cursor-ring {
  width: 28px; height: 28px;
  border: 1.5px solid rgba(232,234,242,0.4);
  transition: width 0.2s var(--ease-out), height 0.2s var(--ease-out),
              border-color 0.2s, background 0.2s;
}

.cursor-ring.cursor-ring--hover {
  width: 44px; height: 44px;
  border-color: var(--indigo);
  background: rgba(99,102,241,0.06);
}

.cursor-ring.cursor-ring--click {
  width: 18px; height: 18px;
  background: rgba(99,102,241,0.2);
}

@media (pointer: coarse) {
  .cursor-dot, .cursor-ring { display: none; }
}

/* â”€â”€ 5. Ambient blobs â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.ambient {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}

.blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.75;
}

.blob--1 {
  width: 700px; height: 700px;
  background: radial-gradient(circle at 50% 50%, rgba(99,102,241,0.18) 0%, transparent 70%);
  top: -250px; left: -150px;
  animation: blobDrift1 32s ease-in-out infinite alternate;
}
.blob--2 {
  width: 550px; height: 550px;
  background: radial-gradient(circle at 50% 50%, rgba(139,92,246,0.15) 0%, transparent 70%);
  top: 20%; right: -200px;
  animation: blobDrift2 28s ease-in-out infinite alternate;
}
.blob--3 {
  width: 480px; height: 480px;
  background: radial-gradient(circle at 50% 50%, rgba(34,211,238,0.10) 0%, transparent 70%);
  bottom: 10%; left: 10%;
  animation: blobDrift3 38s ease-in-out infinite alternate;
}
.blob--4 {
  width: 420px; height: 420px;
  background: radial-gradient(circle at 50% 50%, rgba(232,121,160,0.10) 0%, transparent 70%);
  top: 60%; right: 30%;
  animation: blobDrift4 26s ease-in-out infinite alternate;
}
.blob--5 {
  width: 350px; height: 350px;
  background: radial-gradient(circle at 50% 50%, rgba(16,185,129,0.08) 0%, transparent 70%);
  bottom: 30%; right: 10%;
  animation: blobDrift5 42s ease-in-out infinite alternate;
}

@keyframes blobDrift1 {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(80px, 60px) scale(1.1); }
}
@keyframes blobDrift2 {
  from { transform: translate(0, 0) scale(1.05); }
  to   { transform: translate(-60px, 80px) scale(0.95); }
}
@keyframes blobDrift3 {
  from { transform: translate(0, 0) scale(1); }
  to   { transform: translate(50px, -70px) scale(1.08); }
}
@keyframes blobDrift4 {
  from { transform: translate(0, 0) scale(0.9); }
  to   { transform: translate(-40px, 50px) scale(1.05); }
}
@keyframes blobDrift5 {
  from { transform: translate(0, 0) scale(1.02); }
  to   { transform: translate(60px, -40px) scale(0.95); }
}

/* â”€â”€ 6. Glass utility classes â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.gcard {
  background: var(--g-card-fill);
  backdrop-filter: var(--g-card-blur);
  -webkit-backdrop-filter: var(--g-card-blur);
  border: 1px solid var(--g-card-border);
  box-shadow: var(--g-card-hi), var(--g-card-shadow);
}

.gghost {
  background: var(--g-ghost-fill);
  backdrop-filter: var(--g-ghost-blur);
  -webkit-backdrop-filter: var(--g-ghost-blur);
  border: 1px solid var(--g-ghost-border);
}

.gaccent {
  background: var(--g-accent-fill);
  backdrop-filter: var(--g-accent-blur);
  -webkit-backdrop-filter: var(--g-accent-blur);
  border: 1px solid var(--g-accent-border);
  box-shadow: var(--g-accent-hi), var(--g-accent-glow);
}

/* no backdrop-filter fallback */
@supports not (backdrop-filter: blur(1px)) {
  .gcard   { background: rgba(18,18,36,0.88); }
  .gghost  { background: rgba(24,24,44,0.82); }
  .gaccent { background: rgba(30,30,70,0.85); }
}

/* â”€â”€ 7. Layout helpers â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.container {
  width: min(1200px, 100% - clamp(32px, 5vw, 96px) * 2);
  margin-inline: auto;
}

.section-header {
  max-width: 720px;
  margin-bottom: clamp(48px, 8vh, 96px);
}

.eyebrow {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--indigo);  margin-bottom: var(--s3);
}

.section-title {
  font-size: var(--fs-lg);
  font-weight: 300;
  letter-spacing: -0.04em;
  line-height: 1.05;
  color: var(--text);
  margin-bottom: var(--s4);
}

.section-sub {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  line-height: 1.7;
  max-width: 560px;
}

.grad-text {
  background: var(--grad-hero);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}

/* â”€â”€ 8. Buttons â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--s2);
  padding: 11px 22px;
  border-radius: var(--r-sm);
  font-family: var(--font-sans);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: background var(--dur) var(--ease-std),
              border-color var(--dur) var(--ease-std),
              box-shadow var(--dur) var(--ease-std),
              transform var(--dur-fast) var(--ease-std);
  white-space: nowrap;
}

.btn:active { transform: scale(0.97); }

.btn--primary {
  background: var(--g-accent-fill);
  border: 1px solid var(--g-accent-border);
  box-shadow: var(--g-accent-hi), var(--g-accent-glow);
  color: #c4cbff;
  backdrop-filter: var(--g-accent-blur);
  -webkit-backdrop-filter: var(--g-accent-blur);
}
.btn--primary:hover {
  background: rgba(99,102,241,0.24);
  border-color: rgba(99,102,241,0.5);
  box-shadow: var(--g-accent-hi), 0 8px 32px rgba(99,102,241,0.38);
}

.btn--ghost {
  background: var(--g-ghost-fill);
  border: 1px solid var(--g-ghost-border);
  color: var(--text-soft);
  backdrop-filter: var(--g-ghost-blur);
  -webkit-backdrop-filter: var(--g-ghost-blur);
}
.btn--ghost:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--border-hover);
  color: var(--text);
}

.btn--cta {
  background: var(--g-accent-fill);
  border: 1px solid var(--g-accent-border);
  box-shadow: var(--g-accent-hi), var(--g-accent-glow);
  color: #c4cbff;
  backdrop-filter: var(--g-accent-blur);
  -webkit-backdrop-filter: var(--g-accent-blur);
}
.btn--cta:hover {
  background: rgba(99,102,241,0.26);
  border-color: rgba(99,102,241,0.5);
}

/* â”€â”€ 9. Badge / pill â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 99px;
  font-size: var(--fs-2xs);
  font-weight: 500;
  background: var(--g-ghost-fill);
  border: 1px solid var(--g-ghost-border);
  color: var(--text-soft);
  backdrop-filter: var(--g-ghost-blur);
  -webkit-backdrop-filter: var(--g-ghost-blur);
}
.badge--mono { font-family: var(--font-mono); font-size: 12px; }
.badge--ok {
  background: rgba(16,185,129,0.12);
  border-color: rgba(16,185,129,0.22);
  color: #6ee7b7;
}

/* â”€â”€ 10. Nav â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(6,6,16,0.70);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur) var(--ease-std);
}
.nav.nav--scrolled {
  border-bottom-color: var(--border-dim);
}

.nav__inner {
  display: flex;
  align-items: center;
  gap: var(--s5);
  height: 56px;
  padding-inline: clamp(20px, 4vw, 48px);
  max-width: 1296px;
  margin-inline: auto;
}

.nav__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

/* Valemor Design Studio — Orbitron futuristic wordmark */
.nav__studio {
  font-family: 'Orbitron', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text);
  line-height: 1;
}
.nav__studio-accent {
  background: var(--grad-hero);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* Footer studio wordmark */
.footer__studio {
  font-family: 'Orbitron', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text);
}
.footer__studio-accent {
  background: var(--grad-hero);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.nav__links {
  display: flex;
  gap: var(--s5);
  margin-left: auto;
}
.nav__links a {
  font-size: var(--fs-xs);
  color: var(--text-soft);
  transition: color var(--dur-fast);
}
.nav__links a:hover { color: var(--text); }

.nav__cta { margin-left: var(--s4); font-size: var(--fs-2xs); }

.nav__burger {
  display: none;
  margin-left: auto;
  flex-direction: column;
  gap: 5px;
  padding: 8px;
  border-radius: var(--r-sm);
}
.nav__burger span {
  display: block;
  width: 20px;
  height: 1.5px;
  background: var(--text-soft);
  transition: transform var(--dur) var(--ease-std), opacity var(--dur);
  border-radius: 2px;
}

/* Mobile menu */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: var(--s4);
  padding: var(--s8) clamp(24px, 6vw, 48px);
  background: rgba(6,6,16,0.96);
  backdrop-filter: blur(30px);
  -webkit-backdrop-filter: blur(30px);
  transform: translateX(100%);
  transition: transform 0.4s var(--ease-out);
}
.mobile-menu.is-open { transform: translateX(0); }

.mobile-menu__close {
  position: absolute;
  top: 20px; right: 20px;
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-soft);
  font-size: 20px;
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
}
.mobile-menu__link {
  font-size: clamp(1.4rem, 4vw, 2rem);
  font-weight: 300;
  letter-spacing: -0.02em;
  color: var(--text-soft);
  transition: color var(--dur-fast);
}
.mobile-menu__link:hover { color: var(--text); }
.mobile-menu__cta { margin-top: var(--s4); }

/* â”€â”€ 11. Hero â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.hero {
  min-height: 110rem;
  padding-top: clamp(80px, 14vh, 140px);
  padding-bottom: clamp(160px, 22vh, 240px);
  overflow: visible;
  position: relative;
}

/* Perspective container — drives the 3-D tilt of the card */
.hero__scroll-inner {
  width: min(900px, 100% - clamp(32px, 5vw, 96px) * 2);
  margin-inline: auto;
  perspective: 1000px;
  perspective-origin: 50% 0%;
}

/* Centered text block that translates up on scroll */
.hero__header {
  text-align: center;
  margin-bottom: clamp(40px, 6vh, 72px);
}

/* Scroll-driven tilt card */
.hero__scroll-card {
  margin-top: -48px;
  opacity: 0;
  animation: fadeIn 0.8s var(--ease-out) 0.6s forwards;
  will-change: transform;
  transform: rotateX(20deg) scale(1.05);
  transform-origin: 50% 0%;
}

/* Expand mockup to fill the wider card */
.hero__scroll-card .plugin-mockup {
  width: 100%;
  max-width: none;
}

.hero__scroll-card .pm__shell {
  height: auto;
}

.hero__scroll-card .pm__main {
  height: auto;
}

.hero__scroll-card .pm__content {
  overflow: visible;
  flex: none;
}

.hero__badge {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--s2);
  margin-bottom: var(--s5);
  opacity: 0;
  animation: fadeUp 0.6s var(--ease-out) 0.1s forwards;
}

.hero__title {
  font-size: var(--fs-xl);
  font-weight: 300;  line-height: 1.0;
  letter-spacing: -0.05em;
  color: var(--text);
  margin-bottom: var(--s5);
}

.hero__title .word {
  display: inline-block;
}

.hero__title .word-inner {
  display: inline-block;
  opacity: 0;
  transform: translateY(18px);
  animation: wordReveal 0.65s var(--ease-out) calc(0.1s + var(--i) * 0.055s) forwards;
}

@keyframes wordReveal {
  to { opacity: 1; transform: translateY(0); }
}

.hero__sub {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  line-height: 1.75;
  max-width: 520px;
  margin-inline: auto;
  margin-bottom: var(--s6);
  text-align: center;
  opacity: 0;
  animation: dissolve 1.3s ease 0.55s forwards;
}

@keyframes dissolve {
  from { opacity: 0; filter: blur(6px); }
  to   { opacity: 1; filter: blur(0px); }
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--s3);
  margin-bottom: var(--s4);
  opacity: 0;
  animation: fadeUp 0.6s var(--ease-out) 0.65s forwards;
}

.hero__meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--s3);
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--text-muted);
  opacity: 0;
  animation: fadeUp 0.6s var(--ease-out) 0.8s forwards;
}

@keyframes fadeUp {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes fadeIn {
  to { opacity: 1; }
}

/* â”€â”€ 12. Plugin mockup â€” faithful results page render â”€ */

/* Real plugin design tokens, scoped to the mockup */
.plugin-mockup {
  --pm-bg:      #07070E;
  --pm-accent:  #8AAAE0;
  --pm-ok:      #3EC97E;
  --pm-warn:    #F0A840;
  --pm-err:     #E86060;
  --pm-text:    #E4E6F0;
  --pm-text2:   #6A6C80;
  --pm-surface: rgba(255,255,255,0.042);
  --pm-border:  rgba(255,255,255,0.08);

  width: 552px;
  border-radius: 14px;
  background:
    radial-gradient(ellipse 55% 50% at 22% 28%, rgba(50,80,140,0.26) 0%, transparent 65%),
    radial-gradient(ellipse 50% 45% at 80% 75%, rgba(70,45,120,0.22) 0%, transparent 65%),
    var(--pm-bg);
  border: 1px solid rgba(255,255,255,0.09);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.07),
    0 32px 90px rgba(0,0,0,0.75),
    0 0 80px rgba(138,170,224,0.07);
  overflow: hidden;
  transition: transform 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
  transform-style: preserve-3d;
  position: relative;
  font-family: var(--font-sans);
}

/* Scan-line overlay â€” sweeps on state transition */
.pm__scan-line {
  position: absolute;
  left: 0; right: 0;
  height: 1.5px;
  background: linear-gradient(90deg, transparent 0%, rgba(138,170,224,0.65) 35%, rgba(138,170,224,0.35) 65%, transparent 100%);
  pointer-events: none;
  opacity: 0;
  z-index: 10;
}
.plugin-mockup.is-scanning .pm__scan-line {
  animation: pmScan 0.65s ease-in-out forwards;
}
@keyframes pmScan {
  0%   { top: 34px; opacity: 0; }
  8%   { opacity: 1; }
  92%  { opacity: 0.7; }
  100% { top: 100%; opacity: 0; }
}

/* Titlebar */
.pm__titlebar {
  display: flex;
  align-items: center;
  height: 34px;
  padding: 0 12px;
  background: rgba(3,3,10,0.88);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  gap: 8px;
  flex-shrink: 0;
}
.pm__win-dots { display: flex; gap: 5px; }
.pm__win-dots span {
  display: block;
  width: 8px; height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,0.10);
}
.pm__titlebar-center {
  display: flex; align-items: center; gap: 7px;
  margin: 0 auto;
}
.pm__logo-badge {
  width: 18px; height: 18px;
  border-radius: 5px;
  background: rgba(138,170,224,0.16);
  border: 1px solid rgba(138,170,224,0.28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.14);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-size: 6.5px;
  font-weight: 600;
  color: #b8ccee;
  letter-spacing: 0.04em;
}
.pm__title {
  font-size: 12px;
  font-weight: 500;
  color: var(--pm-text2);
  letter-spacing: -0.01em;
}
.pm__titlebar-right {
  display: flex; align-items: center; gap: 8px;
  color: var(--pm-text2);
  font-size: 12px;
}
.pm__ai-pulse {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--pm-ok);
  box-shadow: 0 0 5px rgba(62,201,126,0.55);
  animation: aiPulse 2s ease-in-out infinite;
}
@keyframes aiPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

/* Plugin shell: 44px sidebar + flex-1 main */
.pm__shell {
  display: grid;
  grid-template-columns: 44px 1fr;
  height: 500px;
}

/* 44px icon-only sidebar â€” faithful to real plugin */
.pm__sidebar {
  border-right: 1px solid rgba(255,255,255,0.05);
  padding: 10px 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
}
.pm__sb-icon {
  width: 32px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 6px;
  color: var(--pm-text2);
  font-size: 14px;
  cursor: default;
  transition: background 0.15s, color 0.15s;
}
.pm__sb-icon--active {
  background: rgba(138,170,224,0.14);
  color: var(--pm-accent);
  border: 1px solid rgba(138,170,224,0.20);
}

/* Main column */
.pm__main {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

/* Topbar (50px) â€” glass, scope toggle + run button */
.pm__topbar {
  height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 13px;
  background: rgba(255,255,255,0.016);
  border-bottom: 1px solid rgba(255,255,255,0.055);
  flex-shrink: 0;
  gap: 8px;
}
.pm__topbar-left {
  display: flex; align-items: center; gap: 6px;
}
.pm__sparkle-icon {
  font-size: 13px;
  color: var(--pm-accent);
  opacity: 0.85;
}
.pm__breadcrumb {
  font-size: 12px;
  font-weight: 500;
  color: var(--pm-text);
  letter-spacing: -0.01em;
}
.pm__topbar-right {
  display: flex; align-items: center; gap: 7px;
}
.pm__scope {
  display: flex;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 6px;
  overflow: hidden;
}
.pm__scope-opt {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 4px 9px;
  color: var(--pm-text2);
  cursor: default;
  white-space: nowrap;
}
.pm__scope-opt--active {
  background: rgba(138,170,224,0.14);
  color: var(--pm-accent);
}
.pm__run-btn {
  display: flex; align-items: center; gap: 5px;
  padding: 5px 10px;
  border-radius: 6px;
  background: rgba(138,170,224,0.14);
  border: 1px solid rgba(138,170,224,0.26);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.10);
  color: var(--pm-accent);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  cursor: default;
  white-space: nowrap;
}
.pm__run-btn .ph { font-size: 10px; }

/* Scrollable dashboard content */
.pm__content {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 11px 12px;
  scrollbar-width: none;
}
.pm__content::-webkit-scrollbar { display: none; }

/* Hero card â€” ScoreRing + verdict + chips */
.pm__hero-card {
  display: flex;
  align-items: center;
  gap: 15px;
  padding: 13px 14px;
  background: linear-gradient(158deg, rgba(255,255,255,0.092) 0%, rgba(255,255,255,0.032) 100%);
  border: 1px solid var(--pm-border);
  border-radius: 13px;
  flex-shrink: 0;
}

/* Score ring */
.pm__ring-wrap {
  position: relative;
  flex-shrink: 0;
}
.pm__ring-svg { display: block; }
.pm__ring-center {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  gap: 1px;
}
.pm__ring-grade {
  font-family: var(--font-mono);
  font-size: 26px;
  font-weight: 300;
  color: var(--pm-text);
  line-height: 1;
  transition: color 0.4s;
}
.pm__ring-sub {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--pm-text2);
  line-height: 1;
  transition: color 0.4s;
}

/* Hero meta */
.pm__hero-meta { flex: 1; min-width: 0; }
.pm__verdict {
  font-size: 12px;
  font-weight: 500;
  color: var(--pm-text);
  line-height: 1.4;
  margin-bottom: 7px;
  transition: opacity 0.3s;
}
.pm__frame-nm {
  display: flex; align-items: center; gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--pm-text2);
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.pm__frame-nm .ph { font-size: 10px; }
.pm__chips { display: flex; gap: 5px; }
.pm__chip {
  display: inline-flex; align-items: center; gap: 2px;
  padding: 3px 7px;
  border-radius: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
}
.pm__chip--err  { background: rgba(232,96,96,0.12);  border: 1px solid rgba(232,96,96,0.22);  color: #f0a0a0; }
.pm__chip--warn { background: rgba(240,168,64,0.12); border: 1px solid rgba(240,168,64,0.22); color: #f5c87a; }
.pm__chip--ok   { background: rgba(62,201,126,0.10); border: 1px solid rgba(62,201,126,0.20); color: #7de8a8; }

/* Category card grid â€” 2 columns */
.pm__cat-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 7px;
  flex-shrink: 0;
}
.pm__cat-card {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 10px 11px;
  background: linear-gradient(158deg, rgba(255,255,255,0.068) 0%, rgba(255,255,255,0.024) 100%);
  border: 1px solid var(--pm-border);
  border-radius: 11px;
}
.pm__cat-icon {
  width: 28px; height: 28px;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  transition: background 0.4s, border-color 0.4s, color 0.4s;
}
.pm__cat-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}
.pm__cat-hd {
  display: flex; align-items: baseline; gap: 5px;
}
.pm__cat-score {  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 300;
  color: var(--pm-text);
  line-height: 1;
  transition: color 0.4s;
}
.pm__cat-lbl {
  font-size: 11px;
  color: var(--pm-text2);
  white-space: nowrap;
}
.pm__cat-meter-bg {
  height: 2px;
  background: rgba(255,255,255,0.07);
  border-radius: 999px;
  overflow: hidden;
}
.pm__cat-meter {
  height: 100%;
  border-radius: 999px;
  width: 0%;
  transition: width 0.75s cubic-bezier(0.16,1,0.3,1), background-color 0.4s;
}
.pm__cat-mini { display: flex; gap: 8px; }
.pm__mini {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--pm-text2);
  display: flex; align-items: center; gap: 3px;
}
.pm__mini::before {
  content: '';
  display: inline-block;
  width: 4px; height: 4px;
  border-radius: 50%;
  flex-shrink: 0;
}
.pm__mini--ok::before   { background: var(--pm-ok); }
.pm__mini--warn::before { background: var(--pm-warn); }
.pm__mini--err::before  { background: var(--pm-err); }

/* Priority findings */
.pm__prio-wrap { flex-shrink: 0; }
.pm__prio-hd {
  display: flex; align-items: center; gap: 5px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pm-text2);
  margin-bottom: 6px;
}
.pm__prio-hd .ph { font-size: 10px; color: var(--pm-warn); }
.pm__prio-list {
  display: flex; flex-direction: column; gap: 4px;
  transition: opacity 0.3s;
}
.pm__prio-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 10px 8px 13px;
  background: rgba(255,255,255,0.026);
  border: 1px solid rgba(255,255,255,0.055);
  border-radius: 9px;
  position: relative;
  overflow: hidden;
}
.pm__prio-item::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 2.5px;
  border-radius: 0 1px 1px 0;
}
.pm__prio-item--err::before  { background: var(--pm-err);  box-shadow: 0 0 6px rgba(232,96,96,0.55); }
.pm__prio-item--warn::before { background: var(--pm-warn); box-shadow: 0 0 6px rgba(240,168,64,0.48); }
.pm__prio-item--info::before { background: var(--pm-ok);   box-shadow: 0 0 6px rgba(62,201,126,0.42); }
.pm__prio-badge {
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 5px;
  border-radius: 3px;
  flex-shrink: 0;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.pm__prio-badge--err  { background: rgba(232,96,96,0.14);  border: 1px solid rgba(232,96,96,0.24);  color: #f0a0a0; }
.pm__prio-badge--warn { background: rgba(240,168,64,0.14); border: 1px solid rgba(240,168,64,0.24); color: #f5c87a; }
.pm__prio-badge--info { background: rgba(62,201,126,0.10); border: 1px solid rgba(62,201,126,0.20); color: #7de8a8; }
.pm__prio-body {
  flex: 1; display: flex; flex-direction: column; min-width: 0;
}
.pm__prio-title {
  font-size: 12px;
  font-weight: 500;
  color: var(--pm-text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  line-height: 1.3;
}
.pm__prio-node {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--pm-text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}


/* â”€â”€ 13. Stats â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.stats {
  padding-block: clamp(48px, 8vh, 80px);
  border-top: 1px solid var(--border-dim);
  border-bottom: 1px solid var(--border-dim);
}

.stats__grid {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
}

.stats__item {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--s2);
  padding: var(--s4);
  text-align: center;
}

.stats__num {
  font-family: var(--font-mono);
  font-size: clamp(2.8rem, 5vw, 4.5rem);
  font-weight: 300;
  letter-spacing: -0.04em;
  line-height: 1;
  background: var(--grad-hero);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

.stats__num--text {
  font-size: clamp(2rem, 4vw, 3.5rem);
}

.stats__label {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--text-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.stats__divider {
  width: 1px;
  height: 60px;
  background: var(--border-dim);
  flex-shrink: 0;
}

/* â”€â”€ 14. Features bento â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.features {
  padding-block: clamp(80px, 12vh, 140px);
}

.bento {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  grid-auto-rows: minmax(180px, auto);
  gap: 16px;
  perspective: 1000px;
}

.bento__card {
  border-radius: var(--r-lg);
  padding: var(--s6);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  transition: border-color var(--dur) var(--ease-std),
              box-shadow var(--dur) var(--ease-std),
              transform var(--dur) var(--ease-out);
  transform-style: preserve-3d;
  perspective: 800px;
  overflow: hidden;
  position: relative;
}

.bento__card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--grad-glow);
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
}

.bento__card:hover::before { opacity: 0.04; }

.bento__card:hover {
  border-color: rgba(255,255,255,0.14);
  box-shadow: var(--g-card-hi), 0 8px 32px rgba(0,0,0,0.4);
}

/* Hero feature card */
.bento__card--hero {
  grid-column: span 4;
  grid-row: span 2;
  padding: var(--s8);
}

.bento__card--hero h3 {
  font-size: var(--fs-md);
  font-weight: 300;
  letter-spacing: -0.03em;
}

/* Remaining cards */
.bento__card:not(.bento__card--hero) {
  grid-column: span 2;
}

.bento__card-icon {
  font-size: 28px;
  color: var(--indigo);
  opacity: 0.8;
}

.bento__card-num {
  font-family: var(--font-mono);
  font-size: clamp(3rem, 6vw, 5rem);
  font-weight: 300;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-block: var(--s2);
}

.bento__card h3 {
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text);
}

.bento__card p {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: 1.7;
}

.bento__rule-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
  padding-top: var(--s4);
}

.rule-pill {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 4px;
  background: rgba(99,102,241,0.10);
  border: 1px solid rgba(99,102,241,0.18);
  color: #a5b4fc;
}

/* Card glare effect */
.bento__card .card__glare {
  position: absolute;
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.06), transparent 70%);
  pointer-events: none;
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.2s;
}
.bento__card:hover .card__glare { opacity: 1; }

/* â”€â”€ 15. How it works â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.how {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.how__layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
}

.how__sticky-col {
  position: sticky;
  top: calc(56px + 40px);
}

.how__panel {
  border-radius: var(--r-xl);
  padding: var(--s6);
  min-height: 340px;
  position: relative;
  overflow: hidden;
}

.how__visual {
  position: absolute;
  inset: var(--s6);
  display: flex;
  flex-direction: column;
  gap: var(--s4);
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.4s var(--ease-out), transform 0.4s var(--ease-out);
  pointer-events: none;
}

.how__visual--active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.how__vis-label {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-muted);
}

/* Step 1: scope toggle */
.how__scope-toggle {
  display: flex;
  gap: 2px;
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border-soft);
  border-radius: var(--r-sm);
  padding: 2px;
  width: fit-content;
}

.scope-btn {
  padding: 5px 12px;
  border-radius: 6px;
  font-size: 12px;
  color: var(--text-muted);
  transition: all 0.2s;
}
.scope-btn--active {
  background: rgba(99,102,241,0.16);
  border: 1px solid rgba(99,102,241,0.28);
  color: #c4cbff;
}

.how__frame-preview {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
}

.frame-box {
  width: 100%;
  max-width: 260px;
  border-radius: 10px;
  overflow: hidden;
}
.frame-box--selected {
  border: 1.5px solid rgba(99,102,241,0.5);
  box-shadow: 0 0 0 3px rgba(99,102,241,0.10);
}
.frame-box__label {
  background: rgba(99,102,241,0.12);
  padding: 6px 10px;
  font-size: 12px;
  font-family: var(--font-mono);
  color: #a5b4fc;
  border-bottom: 1px solid rgba(99,102,241,0.15);
}
.frame-box__inner {
  padding: 12px;
  background: rgba(255,255,255,0.02);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.frame-line {
  height: 8px;
  background: rgba(255,255,255,0.08);
  border-radius: 3px;
  width: 100%;
}
.frame-line--short  { width: 70%; }
.frame-line--shorter { width: 45%; }

/* Step 2: audit progress */
.how__audit-progress {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.audit-rule {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-soft);
  animation: ruleEnter 0.3s var(--ease-out) var(--delay, 0s) both;
}

@keyframes ruleEnter {
  from { opacity: 0; transform: translateX(-8px); }
  to   { opacity: 1; transform: translateX(0); }
}

.audit-rule .ph-check-circle { color: var(--teal); }
.audit-rule .ph-warning       { color: var(--amber); }
.audit-rule--running { color: var(--text-muted); }

.audit-spinner {
  display: inline-block;
  width: 12px; height: 12px;
  border: 1.5px solid rgba(99,102,241,0.3);
  border-top-color: var(--indigo);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

.how__progress-bar {
  height: 2px;
  background: rgba(255,255,255,0.07);
  border-radius: 2px;
  overflow: hidden;
  margin-top: var(--s3);
}
.how__progress-fill {
  height: 100%;
  background: var(--grad-primary);
  border-radius: 2px;
  width: 70%;
  animation: progressPulse 2s ease-in-out infinite;
}
@keyframes progressPulse {
  0%, 100% { width: 65%; }
  50%       { width: 85%; }
}
/* Step 3: fix list */
.how__fix-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.fix-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s3);
}

.fix-chip {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 4px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.fix-chip--warn { background: rgba(245,158,11,0.10); border: 1px solid rgba(245,158,11,0.18); color: #fcd34d; }
.fix-chip--done { background: rgba(16,185,129,0.10); border: 1px solid rgba(16,185,129,0.18); color: #6ee7b7; }

.fix-btn {
  padding: 4px 10px;
  border-radius: 5px;
  font-size: 12px;
  font-weight: 500;
  background: rgba(99,102,241,0.15);
  border: 1px solid rgba(99,102,241,0.28);
  color: #c4cbff;
}
.fix-done {
  font-family: var(--font-mono);
  font-size: 12px;
  color: #6ee7b7;
}
.fix-item--done { opacity: 0.65; }

.how__score-update {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 12px;
  background: rgba(16,185,129,0.07);
  border: 1px solid rgba(16,185,129,0.14);
  border-radius: 8px;
  margin-top: auto;
}

.score-label {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.score-val {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-soft);
}
.score-val strong {
  color: var(--teal);
  font-weight: 500;
}

/* Steps column */
.how__steps {
  display: flex;
  flex-direction: column;
}

.how__step {
  padding-block: clamp(48px, 8vh, 80px);
  border-bottom: 1px solid var(--border-dim);
  opacity: 0.5;
  transition: opacity 0.4s var(--ease-std);
}
.how__step:last-child { border-bottom: none; }
.how__step.is-active  { opacity: 1; }

.how__step-inner {
  display: flex;
  gap: var(--s5);
  align-items: flex-start;
}

.how__num {
  font-family: var(--font-mono);
  font-size: clamp(3.5rem, 6vw, 5.5rem);
  font-weight: 300;
  letter-spacing: -0.05em;
  line-height: 1;
  flex-shrink: 0;
}

.how__step-body h3 {
  font-size: var(--fs-md);
  font-weight: 300;
  letter-spacing: -0.03em;
  color: var(--text);
  margin-bottom: var(--s3);
}

.how__step-body p {
  font-size: var(--fs-sm);
  color: var(--text-soft);
  line-height: 1.75;
}

/* â”€â”€ 16. Audit categories â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.categories {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.cat-card {
  border-radius: var(--r-lg);
  padding: var(--s6);
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  transition: border-color var(--dur) var(--ease-std),
              transform var(--dur) var(--ease-out);
}
.cat-card:hover {
  border-color: rgba(255,255,255,0.14);
  transform: translateY(-3px);
}

.cat-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.cat-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--cat-color, #6366f1);
  animation: dotFloat 3s ease-in-out infinite;
  animation-delay: calc(var(--i, 0) * 0.5s);
}

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

.cat-weight {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
}

.cat-card h3 {
  font-size: var(--fs-xs);
  font-weight: 500;
  color: var(--text);
  letter-spacing: -0.01em;
}

.cat-card p {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.65;
  flex: 1;
}

.cat-footer {
  display: flex;
  flex-direction: column;
  gap: var(--s2);
  margin-top: auto;
  padding-top: var(--s3);
}

.cat-rules {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: var(--s2);
}

.cat-bar-track {
  height: 2px;
  background: rgba(255,255,255,0.07);
  border-radius: 2px;
  overflow: hidden;
}

.cat-bar-fill {
  height: 100%;
  border-radius: 2px;
  transition: width 0.8s var(--ease-out);
}

.cat-card--optional { opacity: 0.7; }
.cat-optional-badge {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-muted);
  border: 1px solid var(--border-soft);
  padding: 2px 6px;
  border-radius: 3px;
}

/* â”€â”€ 17. AI providers marquee â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.providers {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.marquee-wrap {
  margin-block: clamp(40px, 6vh, 64px);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.marquee {
  overflow: hidden;
}

.marquee__inner {
  display: flex;
  gap: 0;
  width: max-content;
  will-change: transform;
}

.marquee--left  .marquee__inner { animation: marqueeLeft  45s linear infinite; }
.marquee--right .marquee__inner { animation: marqueeRight 40s linear infinite; }

.marquee:hover .marquee__inner { animation-play-state: paused; }

.marquee__row {
  display: flex;
  gap: 14px;
  flex-shrink: 0;
  padding-right: 14px;
}

@keyframes marqueeLeft {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
@keyframes marqueeRight {
  from { transform: translateX(-50%); }
  to   { transform: translateX(0); }
}

.provider-pill {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 13px 22px;
  border-radius: 99px;
  font-size: 15px;
  font-weight: 400;
  color: var(--text-soft);
  white-space: nowrap;
  transition: border-color var(--dur), color var(--dur);
}
.provider-pill:hover {
  border-color: var(--border-hover);
  color: var(--text);
}
.provider-pill--local {
  background: rgba(16,185,129,0.06);
  border-color: rgba(16,185,129,0.15);
  color: #6ee7b7;
}

.pill-logo {
  width: 20px;
  height: 20px;
  flex-shrink: 0;
  display: block;
}

.providers__note {
  font-family: var(--font-mono);
  font-size: var(--fs-2xs);
  color: var(--text-muted);
  text-align: center;
  margin-top: var(--s2);
}

/* â”€â”€ 18. Scoring â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.scoring {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.scoring__layout {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: start;
}

.scoring__grade-bar-wrap {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  margin-bottom: var(--s5);
}

.scoring__grade-bar {
  display: flex;
  height: 28px;
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.06);
}

.grade-seg {
  flex: 1;
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 0.5s var(--ease-out);
}
.grade-seg.is-visible { transform: scaleX(1); }

.scoring__grade-labels {
  display: flex;
  justify-content: space-between;
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
}

.label-range {
  font-size: 12px;
  opacity: 0.6;
  margin-left: 3px;
}

.scoring__note {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: 1.7;
}

.scoring__weights-title {
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--text);
  margin-bottom: var(--s4);
}

.severity-list {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
  margin-bottom: var(--s5);
}

.severity-item {
  display: flex;
  align-items: center;
  gap: var(--s3);
}

.sev-chip {
  font-family: var(--font-mono);
  font-size: 12px;
  padding: 4px 8px;
  border-radius: 4px;
  width: 70px;
  flex-shrink: 0;
  text-align: center;
}
.sev-chip--err  { background: rgba(239,68,68,0.10);  border: 1px solid rgba(239,68,68,0.18);  color: #fca5a5; }
.sev-chip--warn { background: rgba(245,158,11,0.10); border: 1px solid rgba(245,158,11,0.18); color: #fcd34d; }
.sev-chip--info { background: rgba(16,185,129,0.10); border: 1px solid rgba(16,185,129,0.18); color: #6ee7b7; }

.sev-bar-wrap {
  flex: 1;
  height: 4px;
  background: rgba(255,255,255,0.07);
  border-radius: 2px;
  overflow: hidden;
}

.sev-bar {
  height: 100%;
  width: 100%;
  border-radius: 2px;
  background: linear-gradient(to right,
    #10b981  0%,
    #84cc16 30%,
    #f59e0b 55%,
    #f97316 75%,
    #ef4444 100%
  );
  transform: scaleX(0);
  transform-origin: left;
  transition: transform 1.6s cubic-bezier(0.16, 1, 0.3, 1);
}

.sev-pts {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  width: 28px;
  text-align: right;
}

.scoring__weight-note {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: 1.7;
}

/* â”€â”€ 19. Pricing â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.pricing {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.pricing__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  max-width: 860px;
  margin-inline: auto;
}

.price-card {
  border-radius: var(--r-xl);
  padding: var(--s7);
  display: flex;
  flex-direction: column;
  gap: var(--s5);
  position: relative;
}

.price-card--pro {
  border-color: rgba(99,102,241,0.35);
  background: rgba(99,102,241,0.06);
}
.price-card--pro::before {
  content: '';
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  background: linear-gradient(135deg, rgba(99,102,241,0.2), rgba(34,211,238,0.1));
  z-index: -1;
  border-radius: var(--r-xl);
  pointer-events: none;
}

.price-card__badge {
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 500;
  padding: 4px 14px;
  border-radius: 99px;
  background: var(--grad-primary);
  color: white;
  white-space: nowrap;
  letter-spacing: 0.04em;
}

.price-card__top h3 {
  font-size: var(--fs-md);
  font-weight: 300;
  letter-spacing: -0.03em;
  margin-bottom: var(--s3);
}

.price-card__price {
  margin-bottom: var(--s3);
}
.price-num {
  font-family: var(--font-mono);
  font-size: clamp(2rem, 4vw, 3rem);
  font-weight: 300;
  letter-spacing: -0.04em;
}
.price-period {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  margin-left: 4px;
}
.price-card__desc {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  line-height: 1.6;
}

.price-card__features {
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}

.price-card__features li {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: var(--fs-xs);
  color: var(--text-soft);
}
.price-card__features li .ph {
  color: var(--teal);
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}

.price-card__btn {
  width: 100%;
  justify-content: center;
}

.price-card__note {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  text-align: center;
  letter-spacing: 0.02em;
}

/* Pro card pulse animation */
@keyframes proPulse {
  0%   { box-shadow: 0 0 0 0 rgba(99,102,241,0.3); }
  70%  { box-shadow: 0 0 0 12px rgba(99,102,241,0); }
  100% { box-shadow: 0 0 0 0 rgba(99,102,241,0); }
}

/* â”€â”€ 20. FAQ â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.faq {
  padding-block: clamp(80px, 12vh, 140px);
  border-top: 1px solid var(--border-dim);
}

.faq__list {
  max-width: 720px;
}

.accordion {
  border-bottom: 1px solid var(--border-soft);
}
.accordion:first-child { border-top: 1px solid var(--border-soft); }

.accordion summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--s4);
  padding-block: var(--s5);
  font-size: var(--fs-sm);
  font-weight: 400;
  color: var(--text-soft);
  list-style: none;
  transition: color var(--dur-fast);
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary:hover { color: var(--text); }
.accordion[open] summary { color: var(--text); }

.accordion summary::after {
  content: '+';
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 300;
  color: var(--indigo);
  flex-shrink: 0;
  transition: transform 0.25s var(--ease-out), opacity 0.25s;
  line-height: 1;
}
.accordion[open] summary::after {
  content: 'âˆ’';
  transform: rotate(0deg);
}

.accordion__body {
  padding-bottom: var(--s5);
}
.accordion__body p {
  font-size: var(--fs-sm);
  color: var(--text-muted);
  line-height: 1.75;
  max-width: 620px;
}
/* â”€â”€ 21. Footer â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.footer {
  border-top: 1px solid var(--border-dim);
  padding-block: clamp(40px, 6vh, 64px);
}

.footer__inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--s8);
  margin-bottom: var(--s6);
}

.footer__left {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.footer__logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: var(--fs-xs);
  font-weight: 600;
  letter-spacing: -0.01em;
}
.footer__tagline {
  font-size: var(--fs-xs);
  color: var(--text-muted);
}

.footer__links {
  display: flex;
  gap: clamp(32px, 4vw, 64px);
}

.footer__col {
  display: flex;
  flex-direction: column;
  gap: var(--s3);
}
.footer__col-title {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}
.footer__col a {
  font-size: var(--fs-xs);
  color: var(--text-muted);
  transition: color var(--dur-fast);
}
.footer__col a:hover { color: var(--text); }

.footer__bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-top: var(--s5);
  border-top: 1px solid var(--border-dim);
}
.footer__copy, .footer__stack {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--text-muted);
  letter-spacing: 0.04em;
}

/* â”€â”€ 22. Reveal animations â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
[data-reveal] {
  opacity: 0;
  transform: translateY(20px) scale(0.98);
}

[data-reveal].is-visible {
  animation: revealIn 0.7s var(--ease-out) calc(var(--i, 0) * 80ms) forwards;
}

@keyframes revealIn {
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* CSS scroll-driven reveal (progressive enhancement) */
@supports (animation-timeline: view()) {
  [data-reveal] {
    animation: revealIn linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
  }
  [data-reveal].is-visible {
    animation: revealIn linear both;
    animation-timeline: view();
    animation-range: entry 0% entry 35%;
  }
}

/* â”€â”€ 23. Responsive â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 1024px) {
  .bento { grid-template-columns: repeat(4, 1fr); }
  .bento__card--hero { grid-column: span 4; }
  .bento__card:not(.bento__card--hero) { grid-column: span 2; }
  .cat-grid { grid-template-columns: repeat(2, 1fr); }
  .scoring__layout { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  /* Layout */
  .hero { min-height: 60rem; }
  .hero__scroll-card { margin-top: -24px; }
  .plugin-mockup { width: 100%; }
  .hero__scroll-card .pm__shell { height: 360px; }
  .pm__sidebar { display: none; }
  .pm__shell { grid-template-columns: 1fr; }

  .stats__grid { flex-wrap: wrap; gap: var(--s5); }
  .stats__item { flex: 1 1 40%; }
  .stats__divider { display: none; }

  .bento { grid-template-columns: 1fr; gap: 12px; }
  .bento__card, .bento__card--hero { grid-column: span 1; grid-row: span 1; }
  .bento__card--hero { padding: var(--s6); }

  .how__layout { grid-template-columns: 1fr; }
  .how__sticky-col { position: static; margin-bottom: var(--s6); }
  .how__panel { min-height: 240px; }

  .cat-grid { grid-template-columns: 1fr; }
  .pricing__grid { grid-template-columns: 1fr; }

  .footer__inner { flex-direction: column; gap: var(--s6); }
  .footer__links { flex-wrap: wrap; gap: var(--s5); }

  /* Nav */
  .nav__links { display: none; }
  .nav__cta { display: none; }
  .nav__burger { display: flex; }

  .scoring__layout { grid-template-columns: 1fr; }

}

/* â”€â”€ 24. Reduced motion â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  [data-reveal] {
    opacity: 1 !important;
    transform: none !important;
  }
  .blob { animation: none !important; }
  .scroll-progress { animation: none !important; }
}

