@import url("colors_and_type.css");

html, body { background: var(--bg-page); min-height: 100%; }
html { scroll-behavior: smooth; }
body { overflow-x: hidden; }

/* ============================================================
 * BG WASH — production-faithful animated dual-layer pastel
 * ============================================================ */
.bg-wash { position: fixed; inset: 0; pointer-events: none; z-index: -1; }
.bg-wash::before, .bg-wash::after { content: ""; position: absolute; inset: 0; }
.bg-wash::before {
  background:
    radial-gradient(900px 700px at 20% 30%, rgba(207,232,218,.85) 0%, transparent 60%),
    radial-gradient(1000px 800px at 80% 20%, rgba(226,216,240,.78) 0%, transparent 62%);
  animation: wash-drift-a 22s ease-in-out infinite alternate;
}
.bg-wash::after {
  background:
    radial-gradient(1100px 900px at 60% 85%, rgba(242,227,212,.80) 0%, transparent 60%),
    radial-gradient(800px 700px at 10% 90%,  rgba(217,239,227,.70) 0%, transparent 62%),
    radial-gradient(700px 600px at 90% 60%,  rgba(227,217,238,.70) 0%, transparent 62%);
  animation: wash-drift-b 28s ease-in-out infinite alternate;
}
@keyframes wash-drift-a { 0%{transform:translate3d(0,0,0) scale(1);} 50%{transform:translate3d(4%,-2%,0) scale(1.08);} 100%{transform:translate3d(-3%,3%,0) scale(1.04);} }
@keyframes wash-drift-b { 0%{transform:translate3d(0,0,0) scale(1.05);} 50%{transform:translate3d(-4%,2%,0) scale(1);} 100%{transform:translate3d(3%,-3%,0) scale(1.08);} }
@keyframes hero-rise { 0% { opacity: 0; transform: translateY(14px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes hero-fade { 0% { opacity: 0; } 100% { opacity: 1; } }
@keyframes slide-up { 0% { opacity: 0; transform: translateY(8px); } 100% { opacity: 1; transform: translateY(0); } }
@keyframes pulse-dot { 0%,100% { opacity: .55; transform: scale(1); } 50% { opacity: 1; transform: scale(1.4); } }

/* ============================================================
 * WRAP / NAV / FOOTER
 * ============================================================ */
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 clamp(20px, 3vw, 40px); }

.nav {
  position: sticky; top: 0; z-index: 40;
  padding-top: 18px; padding-bottom: 4px;
  transition: padding .25s ease;
}
.nav--scrolled { padding-top: 10px; }
.nav__inner {
  display: flex; align-items: center; justify-content: space-between;
  background: rgba(255,255,255,.68);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 999px;
  padding: 7px 7px 7px 22px;
  box-shadow: var(--shadow-nav);
  gap: 16px;
  transition: padding .25s ease, background .25s ease, box-shadow .25s ease;
}
.nav--scrolled .nav__inner {
  padding: 5px 6px 5px 18px;
  background: rgba(255,255,255,.86);
  box-shadow: 0 8px 28px -10px rgba(17,19,24,.14);
}
.nav__inner .brand { font-size: 26px; transition: font-size .25s ease; }
.nav--scrolled .nav__inner .brand { font-size: 22px; }

/* Links */
.nav__links { display: flex; gap: 2px; align-items: center; font: 500 13px var(--sans); color: var(--fg-dim); }
.nav__link {
  position: relative;
  padding: 8px 12px;
  border-radius: 999px;
  transition: background .15s, color .15s;
  cursor: pointer;
  letter-spacing: 0;
}
.nav__link:hover { background: rgba(17,19,24,.04); color: var(--fg); }
.nav__link.is-active {
  background: var(--fg);
  color: #F2EFE9;
  font-weight: 600;
  letter-spacing: .01em;
}

/* Vertical group separator */
.nav__sep {
  width: 1px; height: 16px;
  background: var(--rule-strong);
  margin: 0 6px;
  opacity: .55;
}

/* Actions container (CmdkHint + CTA + burger) */
.nav__actions { display: flex; align-items: center; gap: 8px; }

/* Hamburger — only visible on mobile */
.nav__burger {
  display: none;
  flex-direction: column; justify-content: center; gap: 4px;
  width: 40px; height: 40px;
  border-radius: 999px;
  background: rgba(17,19,24,.04);
  border: 1px solid var(--rule);
  padding: 10px;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.nav__burger:hover { background: var(--fg); border-color: var(--fg); }
.nav__burger:hover span { background: #F2EFE9; }
.nav__burger span {
  width: 16px; height: 1.5px;
  background: var(--fg);
  border-radius: 2px;
  transition: transform .25s, opacity .15s, background .15s;
  transform-origin: center;
}
.nav__burger.is-open span:nth-child(1) { transform: translateY(5.5px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2) { opacity: 0; }
.nav__burger.is-open span:nth-child(3) { transform: translateY(-5.5px) rotate(-45deg); }

/* Mobile breakpoints */
@media (max-width: 1180px) {
  .nav__links { font-size: 12.5px; gap: 0; }
  .nav__link { padding: 7px 10px; }
  .nav__sep { margin: 0 4px; }
}
@media (max-width: 1060px) {
  /* Tuck the CTA's label to give links room */
  .nav__actions .cmdk-hint { display: none; }
}
@media (max-width: 980px) {
  .nav__links { display: none; }
  .nav__burger { display: inline-flex; }
  .nav__actions .btn--pill { display: none; }
}
@media (max-width: 600px) {
  .nav__inner { padding: 6px 6px 6px 18px; gap: 8px; }
  .nav__inner .brand { font-size: 22px; }
}

/* ============ NAV DRAWER (mobile) ============ */
.nav-drawer {
  position: fixed; inset: 0;
  background: rgba(17,19,24,.32);
  backdrop-filter: blur(6px);
  z-index: 60;
  display: flex; justify-content: flex-end;
  animation: hero-fade .18s ease both;
}
.nav-drawer__panel {
  width: min(420px, 100%);
  height: 100%;
  background: rgba(250,249,247,.96);
  backdrop-filter: blur(24px);
  border-left: 1px solid var(--rule);
  display: flex; flex-direction: column;
  box-shadow: -28px 0 60px -20px rgba(17,19,24,.30);
  animation: nav-slide-in .28s cubic-bezier(.2,.8,.2,1) both;
}
@keyframes nav-slide-in {
  0%   { transform: translateX(16px); opacity: 0; }
  100% { transform: translateX(0);     opacity: 1; }
}
.nav-drawer__head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 24px;
  border-bottom: 1px solid var(--rule);
}
.nav-drawer__close {
  font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(17,19,24,.05); color: var(--fg-dim);
  cursor: pointer;
  transition: background .15s, color .15s;
}
.nav-drawer__close:hover { background: var(--fg); color: #F2EFE9; }
.nav-drawer__body { flex: 1; overflow: auto; padding: 14px 18px; display: flex; flex-direction: column; gap: 18px; }
.nav-drawer__group h6 {
  font: 500 10.5px var(--mono); letter-spacing: .18em; text-transform: uppercase;
  color: var(--fg-mute); margin: 0 6px 8px; font-weight: 500;
}
.nav-drawer__group ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 2px; }
.nav-drawer__group a {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  color: var(--fg);
  transition: background .15s, color .15s;
}
.nav-drawer__group a:hover { background: rgba(17,19,24,.04); }
.nav-drawer__group a.is-active { background: var(--fg); color: #F2EFE9; }
.nav-drawer__group a span { font: 600 16px var(--sans); }
.nav-drawer__group a small {
  display: block;
  font: 500 11px var(--mono); letter-spacing: .08em; text-transform: uppercase;
  color: var(--fg-mute); margin-top: 2px;
  grid-column: 1;
}
.nav-drawer__group a.is-active small { color: rgba(242,239,233,.7); }
.nav-drawer__foot {
  padding: 16px 18px;
  border-top: 1px solid var(--rule);
}
.nav-drawer__foot .btn { width: 100%; justify-content: center; }

.site-footer { padding: 56px 0 42px; border-top: 1px solid var(--rule); margin-top: 64px; }
.site-footer__inner { display: flex; justify-content: space-between; gap: 32px; align-items: flex-start; flex-wrap: wrap; }
.site-footer .brand { font-size: 24px; }
.site-footer p { max-width: 46ch; margin: 12px 0 0; color: var(--fg-dim); font-size: 14px; line-height: 1.55; }
.site-footer__sig { font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); margin-top: 14px; }
.site-footer__cols { display: grid; grid-template-columns: repeat(3, auto); gap: 0 56px; }
.site-footer__cols h6 { font: 500 10.5px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 12px; font-weight: 500; }
.site-footer__cols nav { display: flex; flex-direction: column; gap: 8px; color: var(--fg-dim); font-size: 14px; }
.site-footer__cols nav a:hover { color: var(--fg); }
.site-footer__byoa { font-style: italic; }
@media (max-width: 700px) { .site-footer__cols { grid-template-columns: 1fr 1fr; gap: 24px; } }

/* ============================================================
 * BUTTONS
 * ============================================================ */
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  height: 44px; padding: 0 20px; border-radius: 999px;
  font: 500 14px var(--sans);
  border: 1px solid transparent;
  cursor: pointer;
  transition: transform .15s, box-shadow .2s, background .2s, color .2s, border-color .2s;
  white-space: nowrap;
}
.btn:disabled { opacity: .45; cursor: not-allowed; }
.btn--pill { background: var(--green-pill); color: var(--green-pill-ink); border-color: var(--green-pill); }
.btn--pill:hover:not(:disabled) { background: #0f2b22; transform: translateY(-1px); box-shadow: 0 12px 24px -12px rgba(17,19,24,.30); }
.btn--ghost { background: rgba(255,255,255,.6); backdrop-filter: blur(8px); color: var(--fg); border-color: var(--rule-strong); }
.btn--ghost:hover { background: #fff; border-color: var(--fg); }
.btn--outline { border-color: var(--rule-strong); color: var(--fg); background: transparent; }
.btn--outline:hover { border-color: var(--fg); background: rgba(255,255,255,.5); }
.btn--ink-dim { background: rgba(216,230,211,.14); color: var(--emerald-ink); border-color: rgba(216,230,211,.3); backdrop-filter: blur(4px); }
.btn--ink-dim:hover:not(:disabled) { background: rgba(216,230,211,.22); }
.btn--lg { height: 56px; padding: 0 28px; font: 700 17px var(--display); letter-spacing: .04em; text-transform: uppercase; }
.btn--lg.btn--pill { box-shadow: 0 10px 30px -10px rgba(22,58,46,.55); }

/* ============================================================
 * HERO (Home + page hero shared base)
 * ============================================================ */
.hero { padding: clamp(38px, 5vw, 56px) 0 clamp(54px, 7vw, 72px); }
.hero__top { display: flex; align-items: center; justify-content: space-between; padding-bottom: 36px; animation: hero-fade 1.2s ease both; }
.hero__eyebrow { display: inline-flex; align-items: center; gap: 12px; }
.hero__eyebrow::before { content: ""; width: 28px; height: 1px; background: var(--fg-mute); display: inline-block; }
.hero__title {
  font: 800 clamp(3.5rem, 8.5vw, 8.25rem)/0.9 var(--display);
  text-transform: uppercase;
  letter-spacing: 0;
  margin: 0;
  max-width: 14ch;
  background: var(--hero-grad);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) both;
}
.hero__title .glow {
  background: var(--glow-grad); background-size: 220% 100%;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
  animation: glow-shift 10s ease-in-out infinite;
  font-style: normal;
}
.hero__sub-row {
  margin-top: clamp(28px, 4vw, 38px);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(280px, .85fr); gap: 32px; align-items: end;
  padding-top: 22px; border-top: 1px solid var(--rule);
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) .2s both;
}
@media (max-width: 880px) { .hero__sub-row { grid-template-columns: 1fr; } }
.hero__sub { font: 400 1.0625rem/1.55 var(--sans); color: rgba(17,19,24,.82); max-width: 58ch; margin: 0; }
.hero__ctas { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 880px) { .hero__ctas { justify-content: flex-start; } }
.hero__ticker {
  margin-top: clamp(34px, 5vw, 48px);
  background: rgba(255,255,255,.5);
  backdrop-filter: blur(6px);
  border: 1px solid var(--rule);
  border-radius: 16px;
  display: grid; grid-template-columns: repeat(4, 1fr);
  animation: hero-rise 1.1s cubic-bezier(.2,.8,.2,1) .35s both;
}
.hero__ticker > div { padding: 18px 22px; border-left: 1px solid var(--rule); display: flex; flex-direction: column; gap: 4px; }
.hero__ticker > div:first-child { border-left: 0; }
.hero__ticker .num { font: 500 11px var(--mono); letter-spacing: .14em; color: var(--fg-mute); }
.hero__ticker .lbl { font: 800 15px/1.1 var(--display); letter-spacing: .04em; text-transform: uppercase; margin-top: 6px; }
.hero__ticker .desc { font: 400 11.5px/1.35 var(--sans); color: var(--fg-dim); margin-top: 2px; }

/* ============================================================
 * SECTION + GRID + TILE
 * ============================================================ */
.sec { padding: clamp(54px, 7vw, 76px) 0; }
.sec--narrow { padding: clamp(32px, 5vw, 56px) 0; }
.sec__head { text-align: center; max-width: 880px; margin: 0 auto; }
.sec__head--left { text-align: left; margin-left: 0; max-width: 100%; }
.sec__head .eyebrow { margin-bottom: 16px; }
.sec__title { font: 700 clamp(2.5rem, 4.5vw, 4.25rem)/0.98 var(--display); text-transform: uppercase; margin: 0; }
.sec__title em.glow { font-style: normal; background: var(--glow-grad); background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; animation: glow-shift 10s ease-in-out infinite; }
.caps-sub { max-width: 48ch; margin: 18px auto 0; font: 400 1rem/1.55 var(--sans); color: var(--fg-dim); }
.sec__head--left .caps-sub { margin-left: 0; }
.caps-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-top: 36px; }
.caps-grid--2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.caps-grid--4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 880px) { .caps-grid, .caps-grid--2, .caps-grid--4 { grid-template-columns: 1fr; } }
.sec__closer { text-align: center; margin-top: 30px; font: 500 11px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); }

.tile {
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 20px;
  box-shadow: var(--shadow-card);
  padding: 28px;
  transition: transform .25s, box-shadow .25s;
  display: flex; flex-direction: column; gap: 4px;
}
.tile:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.tile h3 { font: 700 1.875rem/1 var(--display); text-transform: uppercase; margin: 12px 0 8px; letter-spacing: 0; }
.tile p  { font: 400 .9375rem/1.5 var(--sans); color: var(--fg-dim); margin: 0; }
.tile__more { display: inline-flex; align-items: center; gap: 6px; margin-top: 18px; font: 500 12.5px var(--sans); color: var(--fg); }
.tile--feature {
  background-color: var(--emerald);
  background-image:
    linear-gradient(135deg, rgba(8,28,22,.45), rgba(8,28,22,0)),
    url("assets/emerald-grain.png");
  background-size: cover, 220px 220px;
  color: var(--emerald-ink);
  border-color: rgba(216,230,211,.18);
  box-shadow: var(--shadow-feature);
}
.tile--feature h3 { color: var(--emerald-mint); }
.tile--feature p  { color: rgba(216,230,211,.85); }
.tile--feature .eyebrow { color: rgba(216,230,211,.7); }
.tile--feature .tile__more { color: var(--emerald-mint); }

/* ============================================================
 * PILLS / BADGES / TAGS
 * ============================================================ */
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 10px; border-radius: 999px; background: var(--green-pill); color: var(--green-pill-ink); font: 500 10.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.pill--boost { background: rgba(143,207,176,.14); color: var(--emerald-mint); border: 1px solid rgba(143,207,176,.36); }
.pill--ghost { background: rgba(255,255,255,.6); color: var(--fg); border: 1px solid var(--rule); }
.tag { display: inline-block; font: 500 10.5px var(--mono); letter-spacing: .04em; padding: 3px 8px; border: 1px solid var(--rule); border-radius: 999px; color: var(--fg-dim); text-transform: uppercase; }

/* Attribution badges — color system tweakable via --attr-* */
.attr {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  font: 500 10.5px var(--mono);
  letter-spacing: .08em;
  text-transform: uppercase;
  border: 1px solid;
  background: var(--attr-bg, rgba(143,207,176,.14));
  color: var(--attr-ink, #1D5E4E);
  border-color: var(--attr-edge, rgba(143,207,176,.5));
}
.attr::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: var(--attr-dot, currentColor); box-shadow: 0 0 8px var(--attr-dot, currentColor); }

/* Default (mint/violet/amber/neutral) */
.attr--owned       { --attr-bg: var(--attr-owned-bg, rgba(143,207,176,.14)); --attr-ink: var(--attr-owned-ink, #1D5E4E); --attr-edge: var(--attr-owned-edge, rgba(143,207,176,.5)); --attr-dot: var(--attr-owned-dot, #1D5E4E); }
.attr--authorized  { --attr-bg: var(--attr-auth-bg, rgba(110,91,224,.10));  --attr-ink: var(--attr-auth-ink, #4A3CB8);  --attr-edge: var(--attr-auth-edge, rgba(110,91,224,.4));  --attr-dot: var(--attr-auth-dot, #6E5BE0); }
.attr--inspired    { --attr-bg: var(--attr-insp-bg, rgba(245,158,11,.10));  --attr-ink: var(--attr-insp-ink, #92400E);  --attr-edge: var(--attr-insp-edge, rgba(245,158,11,.4));  --attr-dot: var(--attr-insp-dot, #D97706); }
.attr--unverified  { --attr-bg: rgba(17,19,24,.05); --attr-ink: var(--fg-dim); --attr-edge: var(--rule-strong); --attr-dot: var(--fg-mute); }

/* Alt palette: teal-monochrome (proof-first variant — all credentials sit on emerald-family tones) */
.attr-palette-mono {
  --attr-owned-bg: rgba(14,60,53,.10);  --attr-owned-ink: #0E3C35;   --attr-owned-edge: rgba(14,60,53,.30); --attr-owned-dot: #0E3C35;
  --attr-auth-bg:  rgba(14,60,53,.06);  --attr-auth-ink: #1D5E4E;   --attr-auth-edge: rgba(14,60,53,.22); --attr-auth-dot: #1D5E4E;
  --attr-insp-bg:  rgba(14,60,53,.04);  --attr-insp-ink: #5B5F66;   --attr-insp-edge: rgba(14,60,53,.16); --attr-insp-dot: #8A8D94;
}

/* Alt palette: traffic (clearer hierarchy — owned green, inspired amber stays, but auth uses indigo) */
.attr-palette-traffic {
  --attr-owned-bg: rgba(34,139,98,.14); --attr-owned-ink: #176442;  --attr-owned-edge: rgba(34,139,98,.42); --attr-owned-dot: #1F8A5B;
  --attr-auth-bg:  rgba(64,99,201,.10); --attr-auth-ink: #2A4D9E;  --attr-auth-edge: rgba(64,99,201,.36);   --attr-auth-dot: #4063C9;
  --attr-insp-bg:  rgba(214,138,40,.10); --attr-insp-ink: #84490B; --attr-insp-edge: rgba(214,138,40,.40);  --attr-insp-dot: #C57414;
}

/* ============================================================
 * BUILD / BRING / HIRE / BACK rail visual
 * ============================================================ */
.bbhb {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin-top: 36px;
}
@media (max-width: 980px) { .bbhb { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .bbhb { grid-template-columns: 1fr; } }
.bbhb__card {
  position: relative;
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 22px 22px 26px;
  box-shadow: var(--shadow-card);
  min-height: 280px;
  display: flex; flex-direction: column;
  transition: transform .25s, box-shadow .25s, background .25s;
  cursor: pointer;
}
.bbhb__card:hover { transform: translateY(-3px); box-shadow: var(--shadow-card-hover); }
.bbhb__card.is-active { background: rgba(255,255,255,.78); box-shadow: var(--shadow-card-hover); }
.bbhb__verb { font: 800 clamp(2.5rem, 4.2vw, 3.5rem)/0.9 var(--display); text-transform: uppercase; margin: 0 0 6px; }
.bbhb__num { font: 500 10px var(--mono); letter-spacing: .18em; color: var(--fg-mute); text-transform: uppercase; }
.bbhb__lede { font: 500 14px/1.4 var(--sans); color: var(--fg); margin: 12px 0 4px; max-width: 22ch; }
.bbhb__copy { font: 400 13px/1.5 var(--sans); color: var(--fg-dim); margin: 0; }
.bbhb__route { margin-top: auto; padding-top: 16px; font: 500 10.5px var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-mute); display: flex; align-items: center; gap: 8px; }
.bbhb__route .glow-arrow { color: var(--fg); }
.bbhb__viz { height: 92px; display: flex; align-items: center; justify-content: center; margin: 12px 0 6px; }
.bbhb__viz svg { width: 100%; height: 100%; }

/* ============================================================
 * TWO DOORS — Foundry vs BYAA parallel paths
 * ============================================================ */
.two-doors {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
  margin-top: 36px;
  position: relative;
}
@media (max-width: 880px) { .two-doors { grid-template-columns: 1fr; } }
.door {
  position: relative;
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  padding: 32px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column;
  min-height: 460px;
}
.door:hover { box-shadow: var(--shadow-card-hover); }
.door--byoa {
  background-color: rgba(255,255,255,.6);
  background-image: linear-gradient(140deg, rgba(245,238,228,.55), rgba(217,239,227,.35));
}
.door--foundry {
  background-image: linear-gradient(140deg, rgba(227,217,238,.45), rgba(255,255,255,.45));
}
.door__num { font: 500 10.5px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); }
.door__title { font: 800 clamp(2.5rem, 4.2vw, 3.75rem)/0.92 var(--display); text-transform: uppercase; margin: 14px 0 10px; }
.door__sub { font: 400 15px/1.55 var(--sans); color: var(--fg-dim); margin: 0 0 18px; max-width: 36ch; }
.door__steps { list-style: none; margin: 0 0 20px; padding: 0; display: flex; flex-direction: column; gap: 8px; }
.door__step { display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 9px 0; border-top: 1px solid var(--rule); align-items: baseline; }
.door__step:first-child { border-top: 0; }
.door__step-num { font: 500 10.5px var(--mono); letter-spacing: .12em; color: var(--fg-mute); }
.door__step-text { font: 400 13.5px/1.45 var(--sans); color: var(--fg); }
.door__step-text strong { font-weight: 600; }
.door__cta { margin-top: auto; display: flex; gap: 10px; flex-wrap: wrap; }
.two-doors__engine {
  grid-column: 1 / -1;
  display: flex; align-items: center; gap: 12px;
  margin-top: 4px;
  padding: 14px 20px;
  background: rgba(14,60,53,.04);
  border: 1px solid rgba(14,60,53,.15);
  border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--emerald);
  justify-content: center;
}
.two-doors__engine::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--emerald-mint);
  box-shadow: 0 0 12px var(--emerald-mint);
  animation: pulse-dot 2.4s ease-in-out infinite;
}

/* ============================================================
 * PIPELINE (4-stage: Source → Agent Source → Imported Agent → Org listing)
 * ============================================================ */
.pipeline {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 0; margin-top: 36px;
  background: rgba(255,255,255,.5);
  backdrop-filter: blur(12px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  overflow: hidden;
}
@media (max-width: 960px) { .pipeline { grid-template-columns: 1fr 1fr; } }
.pipeline__stage {
  padding: 24px 22px;
  border-left: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 10px;
  position: relative;
  min-height: 240px;
  transition: background .25s;
}
.pipeline__stage:first-child { border-left: 0; }
.pipeline__stage:hover { background: rgba(255,255,255,.4); }
.pipeline__num { font: 500 10.5px var(--mono); letter-spacing: .18em; color: var(--fg-mute); }
.pipeline__title { font: 700 1.125rem/1.05 var(--display); text-transform: uppercase; margin: 0; letter-spacing: 0; }
.pipeline__copy { font: 400 12.5px/1.5 var(--sans); color: var(--fg-dim); margin: 0; }
.pipeline__chip {
  margin-top: auto;
  display: inline-flex; align-items: center; gap: 6px; align-self: flex-start;
  padding: 4px 10px; border-radius: 999px;
  font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase;
  background: rgba(255,255,255,.7); border: 1px solid var(--rule); color: var(--fg-dim);
}
.pipeline__stage--active .pipeline__chip { background: var(--emerald); color: var(--emerald-ink); border-color: var(--emerald); }
.pipeline__arrow {
  position: absolute; right: -8px; top: 38px;
  width: 16px; height: 16px; border-radius: 50%;
  background: rgba(255,255,255,.92); border: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: center;
  z-index: 2; color: var(--fg-mute); font-size: 10px;
}
.pipeline__stage:last-child .pipeline__arrow { display: none; }

/* ============================================================
 * AGENT SOURCE PREVIEW CARD (3 variants)
 * ============================================================ */
.asc {
  background: rgba(255,255,255,.78);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 24px;
  box-shadow: var(--shadow-card);
}
.asc__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.asc__head .source { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc__name { font: 800 28px/1 var(--display); text-transform: uppercase; margin: 14px 0 6px; }
.asc__voice { font: 400 14px/1.5 var(--sans); color: var(--fg-dim); margin: 0 0 18px; font-style: italic; max-width: 50ch; }

/* Variant A — Grid */
.asc--grid .asc__fields { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.asc__field { background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 14px; padding: 12px 14px; }
.asc__field .k { font: 500 9.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc__field .v { font: 500 13px/1.4 var(--sans); color: var(--fg); margin-top: 4px; display: block; }
.asc__progress { margin-top: 18px; }
.asc__progress .label { display: flex; justify-content: space-between; font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 8px; }
.asc__progress .bar { height: 6px; background: rgba(17,19,24,.08); border-radius: 999px; overflow: hidden; }
.asc__progress .fill { height: 100%; background: var(--glow-grad); background-size: 220% 100%; animation: glow-shift 10s ease-in-out infinite; border-radius: 999px; transition: width .8s cubic-bezier(.2,.8,.2,1); }
.asc__gaps { margin-top: 16px; display: flex; flex-wrap: wrap; gap: 6px; }
.asc__gap {
  font: 500 10.5px var(--mono); letter-spacing: .04em;
  padding: 4px 10px 4px 8px; border-radius: 999px;
  background: rgba(217,119,6,.08); color: #92400E;
  border: 1px dashed rgba(217,119,6,.45);
  text-transform: lowercase;
  display: inline-flex; align-items: center; gap: 6px;
}
.asc__gap::before { content: "?"; font-weight: 700; }
.asc__gap.is-filled { background: rgba(143,207,176,.14); color: #1D5E4E; border-style: solid; border-color: rgba(143,207,176,.4); }
.asc__gap.is-filled::before { content: "✓"; }

/* Variant B — Spec sheet */
.asc--spec .asc__rows { display: grid; grid-template-columns: 1fr; }
.asc--spec .asc__rows .row { display: grid; grid-template-columns: 120px 1fr; gap: 16px; padding: 11px 0; border-top: 1px solid var(--rule); align-items: baseline; }
.asc--spec .asc__rows .row:first-child { border-top: 0; }
.asc--spec .asc__rows .k { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.asc--spec .asc__rows .v { font: 400 13.5px/1.45 var(--sans); color: var(--fg); }
.asc--spec .asc__rows .v .pill-small { display: inline-flex; align-items: center; gap: 4px; padding: 2px 8px; border-radius: 999px; font: 500 9.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; background: rgba(255,255,255,.6); border: 1px solid var(--rule); color: var(--fg-dim); margin-right: 4px; }

/* Variant C — Voice-first */
.asc--voice .asc__voice-large {
  font: 400 18px/1.45 var(--sans);
  color: var(--fg);
  margin: 0 0 22px;
  padding-left: 18px;
  border-left: 2px solid var(--emerald-mint);
  max-width: 56ch;
}
.asc--voice .asc__voice-large em { color: var(--emerald); font-style: italic; font-weight: 500; }
.asc--voice .asc__samples { display: flex; gap: 8px; flex-wrap: wrap; }
.asc--voice .asc__sample { font: 400 12px/1.4 var(--sans); color: var(--fg-dim); background: rgba(255,255,255,.5); border: 1px solid var(--rule); border-radius: 12px; padding: 8px 12px; max-width: 32ch; }

/* ============================================================
 * IMPORTED AGENT CARD (emerald)
 * ============================================================ */
.iac {
  background-color: var(--emerald);
  background-image: linear-gradient(135deg, rgba(8,28,22,.45), rgba(8,28,22,0)), url("assets/emerald-grain.png");
  background-size: cover, 220px 220px;
  color: var(--emerald-ink);
  border: 1px solid rgba(216,230,211,.18);
  border-radius: 22px;
  padding: 22px 24px;
  box-shadow: var(--shadow-feature);
}
.iac__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.iac__src { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.7); }
.iac__name { font: 800 30px/1 var(--display); text-transform: uppercase; margin: 12px 0 4px; color: var(--emerald-mint); }
.iac__role { font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.8); }
.iac__grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 6px; margin-top: 16px; }
.iac__field { background: rgba(216,230,211,.08); border: 1px solid rgba(216,230,211,.18); border-radius: 12px; padding: 10px 12px; }
.iac__field .k { font: 500 9.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: rgba(216,230,211,.6); }
.iac__field .v { font: 500 13px/1.35 var(--sans); color: #F2EFE9; margin-top: 4px; display: block; }
.iac__foot { display: flex; align-items: center; justify-content: space-between; margin-top: 16px; gap: 12px; flex-wrap: wrap; }
.iac__meta { font: 400 11px var(--mono); letter-spacing: .04em; color: rgba(216,230,211,.65); }

/* Emerald variant of attribution badge */
.iac .attr--authorized { background: rgba(110,91,224,.20); color: #D6CCFC; border-color: rgba(180,162,255,.45); }
.iac .attr--authorized::before { background: #D6CCFC; box-shadow: 0 0 8px rgba(214,204,252,.5); }
.iac .attr--owned { background: rgba(143,207,176,.18); color: #B8E8CB; border-color: rgba(143,207,176,.42); }
.iac .attr--owned::before { background: #8FCFB0; box-shadow: 0 0 8px rgba(143,207,176,.6); }
.iac .attr--inspired { background: rgba(245,158,11,.18); color: #F5C97A; border-color: rgba(245,158,11,.45); }
.iac .attr--inspired::before { background: #F5C97A; box-shadow: 0 0 8px rgba(245,201,122,.55); }

/* ============================================================
 * CONNECT SKILL SOCKET DIAGRAM
 * ============================================================ */
.css-diagram {
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 24px;
  box-shadow: var(--shadow-card);
}
.css-diagram__head { display: flex; justify-content: space-between; align-items: center; gap: 12px; flex-wrap: wrap; margin-bottom: 18px; }
.css-diagram__head .lbl { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.css-diagram__head .gates-summary { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--emerald); }
.css-flow { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 14px; background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 16px; }
.css-pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 12px; border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .04em;
  background: rgba(255,255,255,.7); border: 1px solid var(--rule);
  color: var(--fg); white-space: nowrap;
}
.css-pill.native { background: rgba(143,207,176,.18); color: #1D5E4E; border-color: rgba(143,207,176,.5); }
.css-pill.skill  { background: rgba(110,91,224,.12); color: #4A3CB8; border-color: rgba(110,91,224,.4); }
.css-pill.ext    { background: rgba(17,19,24,.06); color: var(--fg-dim); border-color: var(--rule-strong); border-style: dashed; }
.css-arrow { font: 700 16px var(--display); color: var(--fg-mute); }
.css-gates { display: flex; gap: 4px; flex-wrap: wrap; margin-top: 12px; }
.css-gate {
  font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px;
  background: rgba(14,60,53,.06); color: var(--emerald); border: 1px solid rgba(14,60,53,.18);
}
.css-desc { font: 400 13px/1.5 var(--sans); color: var(--fg-dim); margin: 14px 0 0; max-width: 60ch; }

/* ============================================================
 * IMPORTER GRID (six source cards) — 2 layout variants
 * ============================================================ */
.imp-grid {
  display: grid; gap: 10px;
  margin-top: 30px;
}
.imp-grid--3 { grid-template-columns: repeat(3, 1fr); }
.imp-grid--2 { grid-template-columns: repeat(2, 1fr); }
@media (max-width: 880px) { .imp-grid--3, .imp-grid--2 { grid-template-columns: 1fr; } }
.imp-card {
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 18px;
  padding: 20px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: 8px;
  transition: transform .25s, box-shadow .25s;
  cursor: pointer;
  position: relative;
  min-height: 168px;
}
.imp-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.imp-card__head { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.imp-card__icon { width: 38px; height: 38px; border-radius: 12px; background: linear-gradient(135deg, rgba(207,232,218,.95), rgba(226,216,240,.85)); display: flex; align-items: center; justify-content: center; color: var(--fg); }
.imp-card__icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.imp-card__title { font: 700 1.125rem/1.05 var(--display); text-transform: uppercase; margin: 8px 0 4px; letter-spacing: 0; }
.imp-card__inputs { font: 400 12.5px/1.45 var(--sans); color: var(--fg-dim); margin: 0; }
.imp-card__foot { display: flex; justify-content: space-between; align-items: center; margin-top: auto; padding-top: 12px; gap: 8px; flex-wrap: wrap; }
.imp-card__proof { font: 500 9.5px var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-mute); }
.imp-card__arrow { font: 700 14px var(--display); color: var(--fg-mute); }
.imp-card.is-recommended { background: rgba(255,255,255,.85); border-color: rgba(14,60,53,.25); }
.imp-card.is-recommended::after { content: "RECOMMENDED"; position: absolute; top: 14px; right: 14px; font: 500 9px var(--mono); letter-spacing: .14em; padding: 3px 8px; border-radius: 999px; background: var(--emerald); color: var(--emerald-ink); }

/* ============================================================
 * DESCRIPTION IMPORTER — multi-step flow
 * ============================================================ */
.imp-flow { display: grid; grid-template-columns: 280px 1fr; gap: 20px; align-items: start; }
@media (max-width: 980px) { .imp-flow { grid-template-columns: 1fr; } }

.imp-stepper {
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 20px;
  position: sticky; top: 110px;
  box-shadow: var(--shadow-card);
}
.imp-stepper h6 { font: 500 10.5px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); margin: 0 0 16px; font-weight: 500; }
.imp-stepper__list { list-style: none; margin: 0; padding: 0; }
.imp-stepper__item {
  display: grid; grid-template-columns: 28px 1fr; gap: 12px;
  padding: 12px 0; align-items: start;
  border-top: 1px solid var(--rule);
  position: relative;
  cursor: pointer;
}
.imp-stepper__item:first-child { border-top: 0; }
.imp-stepper__num {
  width: 26px; height: 26px; border-radius: 50%;
  background: rgba(17,19,24,.05); color: var(--fg-mute);
  display: flex; align-items: center; justify-content: center;
  font: 500 11px var(--mono); letter-spacing: 0;
  border: 1px solid var(--rule);
  transition: background .2s, color .2s, border-color .2s;
}
.imp-stepper__item.is-current .imp-stepper__num { background: var(--fg); color: #F2EFE9; border-color: var(--fg); }
.imp-stepper__item.is-done .imp-stepper__num { background: var(--emerald-mint); color: var(--emerald); border-color: var(--emerald-mint); }
.imp-stepper__item.is-done .imp-stepper__num::before { content: "✓"; }
.imp-stepper__item.is-done .imp-stepper__num span { display: none; }
.imp-stepper__label {
  font: 500 13px var(--sans);
  color: var(--fg-dim);
  padding-top: 4px;
}
.imp-stepper__item.is-current .imp-stepper__label { color: var(--fg); font-weight: 600; }
.imp-stepper__item.is-done .imp-stepper__label { color: var(--fg); }
.imp-stepper__hint { font: 400 11.5px/1.4 var(--sans); color: var(--fg-mute); margin-top: 2px; }

.imp-panel {
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  padding: clamp(24px, 3vw, 36px);
  box-shadow: var(--shadow-card);
  min-height: 580px;
  position: relative;
  overflow: hidden;
}
.imp-panel__title { font: 700 1.75rem/1.05 var(--display); text-transform: uppercase; margin: 0 0 8px; }
.imp-panel__sub { font: 400 14px/1.55 var(--sans); color: var(--fg-dim); margin: 0 0 22px; max-width: 56ch; }
.imp-panel__nav { display: flex; justify-content: space-between; gap: 12px; margin-top: 28px; padding-top: 22px; border-top: 1px solid var(--rule); }

.imp-textarea {
  width: 100%;
  min-height: 220px;
  background: rgba(255,255,255,.7);
  border: 1px solid var(--rule-strong);
  border-radius: 16px;
  padding: 18px;
  font: 400 15px/1.55 var(--sans);
  color: var(--fg);
  resize: vertical;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.imp-textarea:focus { border-color: var(--fg); box-shadow: 0 0 0 3px rgba(17,19,24,.06); }
.imp-textarea::placeholder { color: var(--fg-mute); }
.imp-hint-row { display: flex; justify-content: space-between; margin-top: 10px; font: 400 12px var(--sans); color: var(--fg-mute); }
.imp-chips { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 16px; }
.imp-chip {
  font: 500 11px var(--mono); letter-spacing: .04em;
  padding: 6px 12px; border-radius: 999px;
  background: rgba(255,255,255,.55); border: 1px solid var(--rule);
  color: var(--fg-dim); cursor: pointer; text-transform: uppercase;
  transition: background .15s, color .15s, border-color .15s;
}
.imp-chip:hover { background: var(--fg); color: #F2EFE9; border-color: var(--fg); }

/* File drop zone */
.imp-drop {
  border: 1.5px dashed var(--rule-strong);
  border-radius: 16px;
  padding: 20px;
  background: rgba(255,255,255,.4);
  display: flex; align-items: center; gap: 14px;
  margin-top: 14px;
  cursor: pointer;
  transition: border-color .2s, background .2s;
}
.imp-drop:hover, .imp-drop.is-dragover { border-color: var(--emerald); background: rgba(143,207,176,.08); }
.imp-drop__icon { width: 36px; height: 36px; border-radius: 10px; background: rgba(255,255,255,.7); border: 1px solid var(--rule); display: flex; align-items: center; justify-content: center; color: var(--fg-dim); }
.imp-drop__icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.imp-drop__copy { font: 400 13px/1.4 var(--sans); color: var(--fg-dim); }
.imp-drop__copy strong { display: block; color: var(--fg); font-weight: 600; font-size: 14px; margin-bottom: 2px; }
.imp-file-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 10px; border-radius: 999px;
  background: rgba(143,207,176,.18); color: #1D5E4E;
  border: 1px solid rgba(143,207,176,.5);
  font: 500 11.5px var(--mono); letter-spacing: .04em;
}
.imp-file-pill__x { cursor: pointer; opacity: .6; font-size: 14px; }
.imp-file-pill__x:hover { opacity: 1; }

/* Processing animation */
.imp-processing { padding: 40px 24px; display: flex; flex-direction: column; align-items: center; gap: 18px; }
.imp-processing__title { font: 700 1.5rem/1.05 var(--display); text-transform: uppercase; margin: 0; text-align: center; }
.imp-processing__step { font: 500 11px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); animation: slide-up .4s ease both; }
.imp-processing__dots { display: flex; gap: 8px; margin-top: 8px; }
.imp-processing__dots span { width: 8px; height: 8px; border-radius: 50%; background: var(--fg-mute); animation: pulse-dot 1.4s ease-in-out infinite; }
.imp-processing__dots span:nth-child(2) { animation-delay: .2s; background: var(--emerald-mint); }
.imp-processing__dots span:nth-child(3) { animation-delay: .4s; background: var(--violet); }

/* Form fields (gap-fill) */
.imp-fields { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 14px; }
@media (max-width: 720px) { .imp-fields { grid-template-columns: 1fr; } }
.imp-field { display: flex; flex-direction: column; gap: 6px; }
.imp-field label { font: 500 10.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); }
.imp-field input, .imp-field select, .imp-field textarea {
  background: rgba(255,255,255,.7); border: 1px solid var(--rule-strong); border-radius: 12px;
  padding: 11px 14px; font: 400 14px var(--sans); color: var(--fg); outline: none;
  transition: border-color .15s, box-shadow .15s;
}
.imp-field input:focus, .imp-field select:focus, .imp-field textarea:focus { border-color: var(--fg); box-shadow: 0 0 0 3px rgba(17,19,24,.06); }

/* Policy radio */
.imp-policies { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; margin-top: 14px; }
@media (max-width: 720px) { .imp-policies { grid-template-columns: 1fr; } }
.imp-policy {
  border: 1px solid var(--rule-strong);
  background: rgba(255,255,255,.55);
  border-radius: 14px; padding: 16px;
  cursor: pointer; transition: all .2s;
  display: flex; flex-direction: column; gap: 6px;
}
.imp-policy:hover { background: rgba(255,255,255,.78); }
.imp-policy.is-selected { background: var(--fg); color: #F2EFE9; border-color: var(--fg); }
.imp-policy__name { font: 700 1.125rem/1 var(--display); text-transform: uppercase; }
.imp-policy__desc { font: 400 12.5px/1.4 var(--sans); color: var(--fg-dim); }
.imp-policy.is-selected .imp-policy__desc { color: rgba(242,239,233,.78); }
.imp-policy__rules { font: 500 10px var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg-mute); margin-top: 4px; }
.imp-policy.is-selected .imp-policy__rules { color: rgba(242,239,233,.6); }

/* Sandbox chat */
.imp-sandbox { background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 18px; padding: 18px; margin-top: 14px; max-height: 320px; overflow: auto; display: flex; flex-direction: column; gap: 10px; }
.imp-sandbox__msg { padding: 10px 14px; border-radius: 14px; max-width: 80%; font: 400 13.5px/1.45 var(--sans); animation: slide-up .3s ease both; }
.imp-sandbox__msg.user { background: var(--fg); color: #F2EFE9; align-self: flex-end; border-bottom-right-radius: 4px; }
.imp-sandbox__msg.agent { background: rgba(255,255,255,.85); border: 1px solid var(--rule); align-self: flex-start; border-bottom-left-radius: 4px; }
.imp-sandbox__msg.agent::before { content: ""; display: block; width: 28px; height: 1px; background: var(--emerald-mint); margin-bottom: 6px; }
.imp-sandbox__compose { display: flex; gap: 8px; margin-top: 14px; }
.imp-sandbox__compose input { flex: 1; background: rgba(255,255,255,.78); border: 1px solid var(--rule-strong); border-radius: 999px; padding: 10px 16px; font: 400 13.5px var(--sans); color: var(--fg); outline: none; }
.imp-sandbox__compose input:focus { border-color: var(--fg); }
.imp-sandbox__typing { display: inline-flex; gap: 4px; padding: 10px 14px; }
.imp-sandbox__typing span { width: 6px; height: 6px; border-radius: 50%; background: var(--fg-mute); animation: pulse-dot 1.2s ease-in-out infinite; }
.imp-sandbox__typing span:nth-child(2) { animation-delay: .15s; }
.imp-sandbox__typing span:nth-child(3) { animation-delay: .3s; }

/* Final imported agent reveal */
.imp-final {
  display: grid; grid-template-columns: 1fr; gap: 20px;
  animation: slide-up .6s ease both;
}
.imp-final__hero { text-align: center; padding: 12px 0 22px; }
.imp-final__check {
  width: 56px; height: 56px; border-radius: 50%;
  background: var(--emerald-mint); color: var(--emerald);
  display: inline-flex; align-items: center; justify-content: center;
  font: 700 26px var(--display);
  margin-bottom: 14px;
  box-shadow: 0 8px 20px -8px rgba(143,207,176,.6);
}
.imp-final__title { font: 800 2.25rem/1.05 var(--display); text-transform: uppercase; margin: 0; }
.imp-final__sub { font: 400 14.5px/1.55 var(--sans); color: var(--fg-dim); margin: 8px auto 0; max-width: 50ch; }
.imp-final__actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 22px;
}
.imp-final__actions--founder { grid-template-columns: 1.25fr 1fr 1fr; }
@media (max-width: 820px) {
  .imp-final__actions, .imp-final__actions--founder { grid-template-columns: 1fr; }
}
.imp-final__action {
  background: rgba(255,255,255,.7); border: 1px solid var(--rule);
  border-radius: 16px; padding: 18px;
  cursor: pointer; transition: all .2s;
  text-align: left;
}
.imp-final__action:hover { background: #fff; border-color: var(--fg); transform: translateY(-2px); }
.imp-final__action h4 { font: 700 1.125rem/1.05 var(--display); text-transform: uppercase; margin: 0 0 6px; }
.imp-final__action p { font: 400 12.5px/1.4 var(--sans); color: var(--fg-dim); margin: 0; }

/* ============================================================
 * SCENARIOS — three starting points (Idea / Agent-as-worker / Agent-as-CEO)
 * ============================================================ */
.scenarios { display: grid; grid-template-columns: 1fr 1.15fr 1fr; gap: 14px; margin-top: 36px; align-items: stretch; }
@media (max-width: 980px) { .scenarios { grid-template-columns: 1fr; } }
.scen {
  background: rgba(255,255,255,.6);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 22px;
  padding: 26px;
  box-shadow: var(--shadow-card);
  display: flex; flex-direction: column; gap: 12px;
  transition: transform .25s, box-shadow .25s;
  position: relative;
}
.scen:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); }
.scen__lede { font: 500 11px var(--mono); letter-spacing: .18em; text-transform: uppercase; color: var(--fg-mute); }
.scen__title { font: 800 clamp(1.5rem, 2.6vw, 2.1rem)/1 var(--display); text-transform: uppercase; margin: 6px 0 4px; max-width: 14ch; }
.scen__copy { font: 400 14px/1.5 var(--sans); color: var(--fg-dim); margin: 0; max-width: 36ch; }
.scen__viz { margin: 8px 0 4px; }
.scen__example {
  margin-top: auto;
  padding: 12px 14px;
  background: rgba(17,19,24,.04);
  border: 1px solid var(--rule);
  border-radius: 14px;
  font: 400 12.5px/1.45 var(--sans); color: var(--fg);
}
.scen__example b { font-weight: 600; }
.scen__example span { display: block; font: 500 9.5px var(--mono); letter-spacing: .14em; text-transform: uppercase; color: var(--fg-mute); margin-bottom: 4px; }
.scen--ceo {
  background-image: linear-gradient(140deg, rgba(245,238,228,.55), rgba(227,217,238,.45));
  border-color: rgba(110,91,224,.30);
}
.scen--ceo .scen__title { color: var(--fg); }
.scen--ceo .scen__example { background: rgba(110,91,224,.06); border-color: rgba(110,91,224,.25); }
.scen__cta { display: inline-flex; align-items: center; gap: 6px; font: 500 11.5px var(--mono); letter-spacing: .12em; text-transform: uppercase; color: var(--fg); padding-top: 4px; }

/* Founder Agent visual — agent + team beneath */
.founder-viz {
  display: flex; flex-direction: column; align-items: flex-start; gap: 8px;
  padding: 14px;
  background: rgba(255,255,255,.55);
  border: 1px solid var(--rule);
  border-radius: 14px;
  margin: 6px 0 10px;
}
.founder-viz__top {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 8px;
  background: var(--emerald);
  color: var(--emerald-ink);
  border-radius: 999px;
}
.founder-viz__top::before {
  content: ""; width: 18px; height: 18px; border-radius: 50%;
  background: var(--emerald-mint);
}
.founder-viz__top span { font: 500 10.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; }
.founder-viz__top b { font: 700 12px var(--display); letter-spacing: 0; text-transform: uppercase; }
.founder-viz__line { width: 1px; height: 14px; background: rgba(17,19,24,.18); margin-left: 22px; }
.founder-viz__team { display: flex; gap: 6px; flex-wrap: wrap; padding-left: 8px; }
.founder-viz__team span {
  font: 500 10px var(--mono); letter-spacing: .06em; text-transform: uppercase;
  padding: 4px 9px; border-radius: 999px;
  background: rgba(255,255,255,.78); border: 1px solid var(--rule); color: var(--fg-dim);
}

/* Three-scenario for /byoa: "what your agent becomes" */
.becomes { display: grid; grid-template-columns: 1fr 1.25fr 1fr; gap: 14px; margin-top: 36px; align-items: stretch; }
@media (max-width: 980px) { .becomes { grid-template-columns: 1fr; } }
.becomes .scen--ceo { background-image: linear-gradient(140deg, rgba(8,28,22,.92), rgba(8,28,22,.85)), url("assets/emerald-grain.png"); background-size: cover, 220px 220px; color: var(--emerald-ink); border-color: rgba(216,230,211,.18); box-shadow: var(--shadow-feature); }
.becomes .scen--ceo .scen__title { color: var(--emerald-mint); }
.becomes .scen--ceo .scen__copy { color: rgba(216,230,211,.85); }
.becomes .scen--ceo .scen__lede { color: rgba(216,230,211,.65); }
.becomes .scen--ceo .scen__cta { color: var(--emerald-mint); }
.becomes .scen--ceo .scen__example { background: rgba(216,230,211,.08); border-color: rgba(216,230,211,.18); color: rgba(216,230,211,.9); }
.becomes .scen--ceo .scen__example span { color: rgba(216,230,211,.65); }
.becomes .scen--ceo .founder-viz { background: rgba(216,230,211,.06); border-color: rgba(216,230,211,.18); }
.becomes .scen--ceo .founder-viz__top { background: var(--emerald-mint); color: var(--emerald); }
.becomes .scen--ceo .founder-viz__top::before { background: var(--emerald); }
.becomes .scen--ceo .founder-viz__line { background: rgba(216,230,211,.3); }
.becomes .scen--ceo .founder-viz__team span { background: rgba(216,230,211,.1); border-color: rgba(216,230,211,.22); color: rgba(216,230,211,.85); }
.cta {
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(18px);
  border: 1px solid var(--rule);
  border-radius: 24px;
  padding: clamp(40px, 6vw, 64px);
  text-align: center;
  box-shadow: var(--shadow-card);
}
.cta h2 { font: 800 clamp(2.5rem, 5vw, 5rem)/0.95 var(--display); text-transform: uppercase; margin: 0; max-width: 18ch; margin: 0 auto; }
.cta h2 .glow { font-style: normal; background: var(--glow-grad); background-size: 220% 100%; -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; animation: glow-shift 10s ease-in-out infinite; }
.cta p { margin: 22px auto 28px; max-width: 60ch; font: 400 1.0625rem/1.55 var(--sans); color: rgba(17,19,24,.82); }
.cta__ctas { display: flex; gap: 10px; flex-wrap: wrap; justify-content: center; }

/* BYOA hero variant selector */
.byoa-variant-tabs {
  display: inline-flex; gap: 4px;
  padding: 4px;
  background: rgba(255,255,255,.62);
  border: 1px solid var(--rule);
  border-radius: 999px;
  margin: 0 0 28px;
}
.byoa-variant-tabs button {
  padding: 7px 14px; border-radius: 999px;
  font: 500 11px var(--mono); letter-spacing: .14em; text-transform: uppercase;
  color: var(--fg-dim); cursor: pointer;
  transition: background .15s, color .15s;
}
.byoa-variant-tabs button.is-active { background: var(--fg); color: #F2EFE9; }

/* BYOA: source-card examples row (under hero variant) */
.byoa-source-strip {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 6px;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid var(--rule);
}
@media (max-width: 880px) { .byoa-source-strip { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 540px) { .byoa-source-strip { grid-template-columns: repeat(2, 1fr); } }
.byoa-source-card {
  background: rgba(255,255,255,.65);
  border: 1px solid var(--rule);
  border-radius: 14px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 6px;
  min-height: 84px;
  transition: background .2s, transform .2s;
}
.byoa-source-card:hover { background: rgba(255,255,255,.85); transform: translateY(-1px); }
.byoa-source-card__icon { width: 24px; height: 24px; color: var(--fg-dim); }
.byoa-source-card__icon svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.byoa-source-card__label { font: 500 11px var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg); }
.byoa-source-card__proof { font: 400 9.5px var(--mono); letter-spacing: .08em; text-transform: uppercase; color: var(--fg-mute); margin-top: auto; }

/* ============================================================
 * TINY UTILITIES
 * ============================================================ */
.eyebrow-row { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.eyebrow-row::before { content: ""; width: 22px; height: 1px; background: var(--fg-mute); display: inline-block; }
.sec--protocol {
  background-color: var(--emerald);
  background-image: linear-gradient(135deg, rgba(8,28,22,.55), rgba(8,28,22,0)), url("assets/emerald-grain.png");
  background-size: cover, 220px 220px;
  color: var(--emerald-ink);
  border-radius: 28px;
  padding: clamp(40px, 5vw, 64px);
  margin-top: 40px;
  position: relative;
}
.sec--protocol .sec__title { color: var(--emerald-ink); }
.sec--protocol .caps-sub { color: rgba(216,230,211,.85); }
.sec--protocol .eyebrow { color: rgba(216,230,211,.7); }

/* fade-in for view transitions */
.view { animation: hero-fade .4s ease both; }

/* ============================================================
 * MARKETPLACE TEASER on Home
 * ============================================================ */
.mkt-split { display: grid; grid-template-columns: 1.1fr 1fr; gap: 14px; align-items: stretch; margin-top: 36px; }
@media (max-width: 880px) { .mkt-split { grid-template-columns: 1fr; } }
.mkt-feature {
  background-color: var(--emerald);
  background-image: linear-gradient(135deg, rgba(8,28,22,.45), rgba(8,28,22,0)), url("assets/emerald-grain.png");
  background-size: cover, 220px 220px;
  color: var(--emerald-ink);
  border-radius: 22px;
  padding: 32px;
  display: flex; flex-direction: column; gap: 18px;
  box-shadow: var(--shadow-feature);
  position: relative; overflow: hidden;
  border: 1px solid rgba(216,230,211,.18);
}
.mkt-feature__head { display: flex; justify-content: space-between; align-items: center; opacity: .85; }
.mkt-feature__title { font: 800 clamp(2rem, 3.6vw, 3rem)/0.98 var(--display); text-transform: uppercase; color: var(--emerald-mint); margin: 0; }
.mkt-feature__body { font: 400 15px/1.55 var(--sans); color: rgba(216,230,211,.85); margin: 0; max-width: 44ch; }
.mkt-feature__offer { border: 1px solid rgba(216,230,211,.18); border-radius: 16px; background: rgba(216,230,211,.08); padding: 12px 14px; display: grid; gap: 5px; }
.mkt-feature__offer strong { color: #F2EFE9; font-size: 14px; line-height: 1.35; }
.mkt-feature__offer small { color: rgba(216,230,211,.68); font: 400 11px var(--mono); letter-spacing: .04em; }
.mkt-feature__foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; flex-wrap: wrap; margin-top: auto; padding-top: 6px; }
.mkt-feature__staff { display: flex; gap: 6px; flex-wrap: wrap; }

.mkt-menu { list-style: none; margin: 0; padding: 6px; background: rgba(255,255,255,.55); border: 1px solid var(--rule); border-radius: 22px; display: flex; flex-direction: column; gap: 2px; box-shadow: var(--shadow-card); max-height: 460px; overflow: auto; }
.mkt-menu__item { padding: 13px 16px; border-radius: 16px; cursor: pointer; transition: background .25s, color .25s; }
.mkt-menu__item:hover, .mkt-menu__item.is-active { background: var(--fg); color: #F2EFE9; }
.mkt-menu__row { display: grid; grid-template-columns: auto 1fr auto; gap: 14px; align-items: center; }
.mkt-menu__num { font: 500 11px var(--mono); letter-spacing: .14em; color: var(--fg-mute); min-width: 24px; }
.mkt-menu__item.is-active .mkt-menu__num { color: rgba(216,230,211,.7); }
.mkt-menu__title-row { display: flex; align-items: start; gap: 8px; justify-content: space-between; }
.mkt-menu__title { font: 700 1.125rem/1.05 var(--display); letter-spacing: .01em; text-transform: uppercase; margin: 0 0 3px; }
.mkt-menu__title-row span {
  border: 1px solid var(--rule); border-radius: 999px;
  color: var(--fg-mute);
  font: 500 9px var(--mono); letter-spacing: .08em;
  padding: 3px 7px; text-transform: uppercase;
  flex: 0 0 auto;
}
.mkt-menu__item.is-active .mkt-menu__title-row span { border-color: rgba(216,230,211,.22); color: rgba(216,230,211,.68); }
.mkt-menu__desc { font: 400 12.5px/1.45 var(--sans); color: var(--fg-dim); margin: 0; }
.mkt-menu__item.is-active .mkt-menu__desc { color: rgba(216,230,211,.7); }
.mkt-menu__arrow { font: 700 18px var(--display); opacity: .4; }
.mkt-menu__item.is-active .mkt-menu__arrow { opacity: 1; }
