/* ===== HOME V2 — two-product positioning ===== */

/* -------- HERO -------- */
.hero2{ padding-top:clamp(130px,17vh,190px); padding-bottom:clamp(48px,7vw,96px); overflow:hidden; }
.hero2-aurora{
  position:absolute; inset:-12% -10% auto -10%; height:110%; z-index:-1; pointer-events:none;
  background:
    radial-gradient(720px 460px at 16% 12%, rgba(243,100,49,.14), transparent 62%),
    radial-gradient(640px 420px at 86% 30%, rgba(224,123,58,.10), transparent 60%);
  filter:blur(10px);
}
.hero2-grid{
  display:grid; grid-template-columns:1.08fr .92fr; gap:clamp(32px,5vw,72px);
  align-items:center;
}
.hero2-copy{ max-width:640px; }
.h-hero2{ font-size:clamp(36px, 4.7vw, 64px); margin:clamp(22px,2.6vw,30px) 0 0; }
.h-hero2 .accent{ color:var(--aqua); }
.h-hero2 .l2{ display:block; color:var(--fg); }
.hero2-lead{ margin-top:24px; max-width:520px; }
.hero2-lead b{ color:var(--fg); font-weight:600; }

/* hero stage overlays (digital-human video) */
.sp-pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 13px; border-radius:999px;
  background:rgba(7,9,14,.62); border:1px solid var(--line-2);
  backdrop-filter:blur(10px);
  font-family:'Sora',sans-serif; font-size:12px; font-weight:600; color:var(--fg);
}
.stage-qa{
  position:absolute; left:14px; right:14px; bottom:15px; z-index:3;
  display:flex; flex-direction:column; gap:7px;
}
.stage-qa .msg{ font-size:12px; backdrop-filter:blur(10px); }
.stage-qa .msg.user{ background:rgba(7,9,14,.68); border:1px solid var(--line); color:var(--fg-soft); }
.stage-qa .msg.ai{ background:rgba(38,16,7,.78); }
.stage-qa .src-chip{ background:rgba(7,9,14,.68); backdrop-filter:blur(10px); }
/* default: original 9:16 portrait stage (from home.css) */
.hero2-grid .stage{ width:min(100%,380px); }
body[data-video-shape="square"] .hero2-grid .stage{ width:min(100%,500px); aspect-ratio:1/1; }
body[data-video-shape="square"] .hero2-grid video.stage-human{ object-position:center 24%; }
body[data-video-shape="wide"] .hero2-grid .stage{ width:100%; aspect-ratio:16/9; }
body[data-video-shape="wide"] .hero2-grid video.stage-human{ object-position:center 20%; }
body[data-qa="off"] .stage-qa{ display:none; }

/* product index rows — editorial hairline list, not boxes */
.hero2-products{
  display:grid; grid-template-columns:1fr 1fr; gap:0 64px;
  margin-top:clamp(48px,6vw,80px);
}
.pcard{
  position:relative; display:grid; grid-template-columns:auto 1fr;
  gap:0 20px; align-items:start;
  padding:26px 4px 8px; border-top:1px solid var(--line-2);
}
.pcard::before{
  content:""; position:absolute; top:-1px; left:0; height:1px; width:0;
  background:linear-gradient(90deg, var(--aqua), rgba(243,100,49,.25));
  transition:width .55s cubic-bezier(.22,1,.36,1);
}
.pcard:hover::before{ width:100%; }
.pcard .p-idx{
  font-family:'Space Mono',monospace; font-size:12px; font-weight:700;
  letter-spacing:.12em; color:var(--muted); padding-top:5px;
  transition:color .3s;
}
.pcard:hover .p-idx{ color:var(--aqua); }
.pcard h3{
  display:flex; align-items:center; gap:12px;
  font-size:20px; letter-spacing:-.02em;
}
.p-arrow{
  width:17px; height:17px; flex:none; color:var(--aqua);
  opacity:0; transform:translateX(-8px);
  transition:opacity .3s, transform .35s cubic-bezier(.22,1,.36,1);
}
.pcard:hover .p-arrow{ opacity:1; transform:none; }
.pcard p{ color:var(--muted); font-size:14.5px; line-height:1.6; margin-top:9px; max-width:420px; }

/* -------- PRODUCT SECTIONS -------- */
.prod{ padding-block:clamp(80px,11vw,150px); }
.prod + .prod{ border-top:1px solid var(--line); }
.prod-band{ background:linear-gradient(180deg, transparent, rgba(243,100,49,.035) 30% 70%, transparent); }

.prod-head{ max-width:760px; }
.prod-head .h2{ margin:18px 0 0; }
.prod-head .lead{ margin-top:20px; }

.prod-grid{
  display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(36px,5vw,72px);
  align-items:center; margin-top:clamp(40px,5vw,64px);
}
.prod-grid.flip{ grid-template-columns:1.1fr 1fr; }
.prod-grid.flip .prod-copy{ order:2; }
.prod-grid.flip .prod-visual{ order:1; }

.prod-copy .diff{
  font-family:'Sora',sans-serif; font-weight:600; letter-spacing:-.025em;
  font-size:clamp(20px,1.9vw,26px); line-height:1.35; color:var(--fg);
}
.prod-copy .diff em{ font-style:normal; color:var(--aqua); }
.prod-copy > p{ color:var(--fg-soft); margin-top:18px; font-size:16px; line-height:1.65; }

.usecases{ display:flex; flex-wrap:wrap; gap:9px; margin-top:26px; }
.usecases .chip{ letter-spacing:.06em; font-size:11px; }
.prod-cta{ display:flex; gap:14px; margin-top:32px; flex-wrap:wrap; }

/* steps band (product 1) */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:clamp(44px,5vw,60px); }
.step{ padding:28px 26px 26px; position:relative; }
.step .s-num{
  font-family:'Space Mono',monospace; font-size:12px; font-weight:700;
  letter-spacing:.14em; color:var(--aqua);
  display:inline-flex; align-items:center; gap:10px;
}
.step .s-num::after{ content:""; width:30px; height:1.5px; background:linear-gradient(90deg, rgba(243,100,49,.6), transparent); }
.step h4{ font-family:'Sora',sans-serif; font-size:18.5px; font-weight:600; margin:16px 0 9px; }
.step p{ font-size:14.5px; color:var(--muted); }
.step code{
  font-family:'Space Mono',monospace; font-size:12px; color:var(--fg-soft);
  background:var(--surface-2); border:1px solid var(--line); border-radius:7px;
  padding:2px 7px; white-space:nowrap;
}

/* capability cards (product 2) reuse .step look via .caps */
.caps{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:clamp(44px,5vw,60px); }
.cap{ padding:28px 26px 26px; }
.cap .icon-tile{ width:46px; height:46px; border-radius:12px; }
.cap .icon-tile svg{ width:22px; height:22px; }
.cap h4{ font-family:'Sora',sans-serif; font-size:18.5px; font-weight:600; margin:18px 0 9px; }
.cap p{ font-size:14.5px; color:var(--muted); }

/* -------- MOCKUP: shared frame -------- */
.prod-visual{ position:relative; }
.mock{
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  border:1px solid var(--line-2); background:var(--ink-2);
  box-shadow:0 40px 110px -42px rgba(0,0,0,.85), 0 24px 70px -40px rgba(243,100,49,.25);
}
.mock-bar{
  display:flex; align-items:center; gap:12px;
  padding:11px 14px; border-bottom:1px solid var(--line);
  background:rgba(255,255,255,.025);
}
.mock-dots{ display:flex; gap:6px; }
.mock-dots i{ width:9px; height:9px; border-radius:50%; background:var(--line-2); }
.mock-url{
  flex:1; max-width:300px; display:flex; align-items:center; gap:7px;
  font-family:'Space Mono',monospace; font-size:11px; color:var(--muted);
  background:rgba(255,255,255,.04); border:1px solid var(--line);
  border-radius:999px; padding:5px 12px;
}
.mock-url svg{ width:11px; height:11px; flex:none; color:var(--muted-2); }

/* skeleton blocks */
.sk{ background:rgba(255,255,255,.07); border-radius:6px; }
.sk.dim{ background:rgba(255,255,255,.045); }

/* -------- MOCK 1: site + widget -------- */
.mock-site-body{ position:relative; padding:22px 22px 18px; min-height:420px; }
.mock-page{ display:grid; grid-template-columns:1fr 1.2fr; gap:18px; }
.mock-pimg{ aspect-ratio:4/3.4; border-radius:10px; background:linear-gradient(145deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); border:1px solid var(--line); position:relative; }
.mock-pimg::after{ content:""; position:absolute; inset:30% 32%; border-radius:8px; background:rgba(243,100,49,.14); border:1px solid rgba(243,100,49,.3); }
.mock-ptxt{ display:flex; flex-direction:column; gap:9px; padding-top:4px; }
.mock-ptxt .row{ display:flex; gap:8px; }
.mock-spec{ margin-top:10px; display:flex; flex-direction:column; gap:6px; }
.mock-spec .sk{ height:9px; }

.widget{
  position:absolute; right:16px; bottom:14px; width:min(62%, 268px); z-index:3;
  border-radius:16px; overflow:hidden;
  background:rgba(13,16,22,.92); border:1px solid var(--line-2);
  backdrop-filter:blur(14px);
  box-shadow:0 30px 70px -24px rgba(0,0,0,.9);
}
.widget-head{
  display:flex; align-items:center; gap:10px;
  padding:11px 13px; border-bottom:1px solid var(--line);
  background:rgba(243,100,49,.07);
}
.w-avatar{
  width:30px; height:30px; border-radius:50%; flex:none; position:relative; overflow:hidden;
  background:radial-gradient(circle at 50% 32%, #F0A35E 0%, #C9461C 55%, #7a2c12 100%);
}
.w-avatar::after{ /* abstract head+shoulders */
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  top:6px; width:11px; height:11px; border-radius:50%; background:rgba(10,12,16,.78);
  box-shadow:0 13px 0 4px rgba(10,12,16,.78);
}
.widget-head b{ font-family:'Sora',sans-serif; font-size:12.5px; font-weight:600; display:block; }
.widget-head span{ display:flex; align-items:center; gap:5px; font-size:10.5px; color:var(--muted); }
.w-on{ width:6px; height:6px; border-radius:50%; background:#4ade80; flex:none; }

.widget-chat{ padding:12px 12px 13px; display:flex; flex-direction:column; gap:8px; }
.msg{ max-width:88%; padding:8px 11px; border-radius:12px; font-size:11.5px; line-height:1.5; }
.msg.user{ align-self:flex-end; background:rgba(255,255,255,.09); color:var(--fg-soft); border-bottom-right-radius:4px; }
.msg.ai{ align-self:flex-start; background:rgba(243,100,49,.13); border:1px solid rgba(243,100,49,.22); color:var(--fg); border-bottom-left-radius:4px; }
.src-chip{
  align-self:flex-start; display:inline-flex; align-items:center; gap:6px;
  font-family:'Space Mono',monospace; font-size:9.5px; letter-spacing:.04em;
  color:var(--fg-soft); background:var(--surface); border:1px solid var(--line);
  border-radius:999px; padding:4px 9px;
}
.src-chip svg{ width:10px; height:10px; color:var(--aqua); flex:none; }
.widget-actions{ display:flex; gap:6px; padding:0 12px 12px; }
.widget-actions span{
  font-family:'Sora',sans-serif; font-size:10.5px; font-weight:600;
  padding:6px 10px; border-radius:999px; white-space:nowrap;
}
.widget-actions .wa-primary{ background:var(--aqua); color:#fff; }
.widget-actions .wa-ghost{ border:1px solid var(--line-2); color:var(--fg-soft); }

/* floating lead card */
.lead-float{
  position:absolute; left:-22px; top:50px; z-index:5;
  display:flex; align-items:center; gap:11px;
  padding:12px 15px; border-radius:14px;
  background:rgba(13,16,22,.85); border:1px solid var(--line-2);
  backdrop-filter:blur(14px); box-shadow:0 24px 60px -26px rgba(0,0,0,.85);
  animation:floaty 6s ease-in-out infinite;
}
.lead-float .lf-icon{
  width:32px; height:32px; border-radius:9px; flex:none;
  display:grid; place-items:center; background:rgba(74,222,128,.12);
  border:1px solid rgba(74,222,128,.35); color:#4ade80;
}
.lead-float .lf-icon svg{ width:16px; height:16px; }
.lead-float b{ display:block; font-family:'Sora',sans-serif; font-size:13px; font-weight:600; }
.lead-float span{ font-family:'Space Mono',monospace; font-size:10px; color:var(--muted); }

/* -------- MOCK photos (rendered images) -------- */
.mock-photo{
  position:relative; border-radius:var(--r-lg); overflow:hidden;
  box-shadow:0 40px 110px -42px rgba(0,0,0,.85), 0 24px 70px -40px rgba(243,100,49,.25);
}
.mock-photo .mock-img{ border-radius:0; box-shadow:none; }
.mock-img{
  display:block; width:100%; height:auto;
  border-radius:var(--r-lg);
  box-shadow:0 40px 110px -42px rgba(0,0,0,.85), 0 24px 70px -40px rgba(243,100,49,.25);
}

/* -------- MOCK 2: studio -------- */
.mock-studio-body{ display:grid; grid-template-columns:.9fr 1.4fr; gap:0; min-height:400px; }
.script-pane{ border-right:1px solid var(--line); padding:16px 16px 18px; display:flex; flex-direction:column; gap:8px; background:rgba(255,255,255,.015); }
.script-pane .file-tag{
  display:inline-flex; align-items:center; gap:7px; align-self:flex-start;
  font-family:'Space Mono',monospace; font-size:10px; color:var(--fg-soft);
  background:var(--surface); border:1px solid var(--line); border-radius:7px;
  padding:5px 9px; margin-bottom:6px;
}
.script-pane .file-tag svg{ width:11px; height:11px; color:var(--aqua); }
.script-line{ height:8px; border-radius:5px; background:rgba(255,255,255,.07); }
.script-line.short{ width:62%; }
.script-line.mid{ width:82%; }
.script-line.edit{
  background:rgba(243,100,49,.3); border:1px solid rgba(243,100,49,.45);
  height:10px; position:relative;
}
.script-line.edit::after{
  content:"edited"; position:absolute; right:-4px; top:-19px;
  font-family:'Space Mono',monospace; font-size:9px; letter-spacing:.08em;
  color:var(--aqua);
}
.gen-btn{
  margin-top:auto; align-self:stretch; text-align:center;
  font-family:'Sora',sans-serif; font-size:12px; font-weight:600;
  color:#fff; background:var(--aqua); border-radius:10px; padding:9px 10px;
}

.video-pane{ padding:16px; display:grid; grid-template-columns:1fr 1fr; gap:12px; align-content:start; }
.vtile{
  position:relative; border-radius:12px; overflow:hidden; aspect-ratio:16/10.5;
  background:linear-gradient(160deg, #181d27, #0e1116);
  border:1px solid var(--line);
}
.presenter{
  position:absolute; left:50%; bottom:0; transform:translateX(-50%);
  width:46%; aspect-ratio:1/1.05;
}
.presenter::before{ /* head */
  content:""; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:38%; aspect-ratio:1; border-radius:50%;
  background:radial-gradient(circle at 45% 35%, #F0A35E, #C9461C 70%);
}
.presenter::after{ /* shoulders */
  content:""; position:absolute; left:50%; bottom:-12%; transform:translateX(-50%);
  width:100%; height:58%; border-radius:48% 48% 0 0;
  background:linear-gradient(180deg, #D44E20, #8a3414);
}
.vtile .v-meta{
  position:absolute; left:8px; bottom:8px; z-index:2;
  font-family:'Space Mono',monospace; font-size:9.5px; letter-spacing:.06em;
  color:var(--fg); background:rgba(7,9,14,.7); border:1px solid var(--line);
  border-radius:999px; padding:3px 8px; backdrop-filter:blur(6px);
}
.vtile .v-cap{ /* caption bar suggestion */
  position:absolute; left:10%; right:10%; bottom:26px; height:6px; border-radius:4px;
  background:rgba(255,255,255,.16); z-index:1;
}
.vtile.rendering .presenter{ opacity:.35; }
.v-progress{
  position:absolute; inset:0; z-index:2; display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:8px;
  background:rgba(10,12,16,.55); backdrop-filter:blur(2px);
  font-family:'Space Mono',monospace; font-size:10px; color:var(--fg-soft);
}
.v-progress .bar{ width:56%; height:4px; border-radius:3px; background:rgba(255,255,255,.12); overflow:hidden; }
.v-progress .bar i{ display:block; height:100%; width:84%; border-radius:3px; background:var(--aqua); animation:renderBar 2.4s ease-in-out infinite alternate; }
@keyframes renderBar{ from{ width:72%; } to{ width:92%; } }

.update-float{
  position:absolute; right:-20px; bottom:46px; z-index:5;
  display:flex; align-items:center; gap:11px;
  padding:12px 15px; border-radius:14px;
  background:rgba(13,16,22,.85); border:1px solid var(--line-2);
  backdrop-filter:blur(14px); box-shadow:0 24px 60px -26px rgba(0,0,0,.85);
  animation:floaty 6s ease-in-out infinite; animation-delay:-2.5s;
}
.update-float .lf-icon{
  width:32px; height:32px; border-radius:9px; flex:none;
  display:grid; place-items:center; background:rgba(243,100,49,.12);
  border:1px solid rgba(243,100,49,.35); color:var(--aqua);
}
.update-float .lf-icon svg{ width:16px; height:16px; }
.update-float b{ display:block; font-family:'Sora',sans-serif; font-size:13px; font-weight:600; }
.update-float span{ font-family:'Space Mono',monospace; font-size:10px; color:var(--muted); }

/* -------- PLATFORM (engines) -------- */
.engines{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:54px; }
.engine{ padding:28px 24px 26px; }
.engine h4{ font-family:'Sora',sans-serif; font-size:17.5px; font-weight:600; margin:18px 0 8px; }
.engine h4 small{ display:block; font-family:'Space Mono',monospace; font-size:10px; font-weight:700; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); margin-top:5px; }
.engine p{ font-size:14px; color:var(--muted); }
.platform-note{
  margin-top:34px; text-align:center; font-size:14px; color:var(--muted);
}
.platform-note b{ color:var(--fg-soft); font-weight:600; }

/* -------- SOCIAL PROOF (logo wall) -------- */
.logo-row{ display:grid; grid-template-columns:repeat(6,1fr); gap:14px; margin-top:28px; }
.logo-ph{
  height:58px; display:grid; place-items:center;
  border:1px dashed var(--line-2); border-radius:12px; background:var(--surface);
  font-family:'Space Mono',monospace; font-size:9.5px; letter-spacing:.22em;
  text-transform:uppercase; color:var(--muted-2);
}

/* -------- TRY IT (self-serve entry) -------- */
.try{ margin-top:32px; }
.try-label{
  font-family:'Space Mono',monospace; font-size:11.5px; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--aqua);
}
.try-form{ display:flex; gap:10px; margin-top:14px; flex-wrap:wrap; }
.try-form input{
  flex:1; min-width:230px;
  background:var(--surface); border:1px solid var(--line-2); border-radius:999px;
  padding:13px 20px; color:var(--fg);
  font-family:'Hanken Grotesk',sans-serif; font-size:15px;
}
.try-form input::placeholder{ color:var(--muted); }
.try-form input:focus{ outline:none; border-color:var(--aqua); }
.try-note{
  display:block; margin-top:11px;
  font-family:'Space Mono',monospace; font-size:10px; letter-spacing:.1em;
  text-transform:uppercase; color:var(--muted-2);
}

/* knowledge-base build overlay */
.widget{ transition:opacity .4s var(--ease); }
.mock-url i{ font-style:normal; }
.kb-progress{
  position:absolute; inset:0; z-index:6;
  display:flex; align-items:center; justify-content:center;
  background:rgba(8,10,14,.8); backdrop-filter:blur(6px);
  opacity:0; pointer-events:none; transition:opacity .35s var(--ease);
}
.kb-progress.on{ opacity:1; }
.kbp-inner{ display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; max-width:80%; }
.kbp-spin{
  width:26px; height:26px; border-radius:50%;
  border:2.5px solid rgba(255,255,255,.15); border-top-color:var(--aqua);
  animation:spin .9s linear infinite;
}
.kbp-inner b{ font-family:'Sora',sans-serif; font-size:15px; font-weight:600; }
.kbp-inner span{ font-family:'Space Mono',monospace; font-size:10.5px; letter-spacing:.08em; color:var(--muted); text-transform:uppercase; }

/* -------- RESULTS / PROOF -------- */
.metrics{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:50px; }
.metric{ padding:32px 30px; }
.metric b{
  display:block; font-family:'Sora',sans-serif; font-weight:700;
  font-size:clamp(38px,4vw,54px); letter-spacing:-.04em; color:var(--aqua);
}
.metric span{ display:block; margin-top:10px; font-size:15px; color:var(--fg-soft); }
.case-card{
  margin-top:20px; padding:30px 32px;
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.cc-tag{
  font-family:'Space Mono',monospace; font-size:11px; font-weight:700;
  letter-spacing:.18em; text-transform:uppercase; color:var(--aqua);
}
.case-card p{ margin-top:12px; max-width:660px; color:var(--fg-soft); font-size:16px; }
.case-card .arrow-link{ flex:none; }
.results-note{
  margin-top:22px; font-family:'Space Mono',monospace; font-size:11px;
  letter-spacing:.05em; color:var(--muted-2);
}

/* -------- GUARDRAILS strip -------- */
.rails{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:22px; }
.rail{
  display:flex; gap:12px; align-items:flex-start;
  padding:18px 20px; border:1px solid var(--line); border-radius:var(--r-md); background:var(--surface);
}
.rail svg{ width:18px; height:18px; color:var(--aqua); flex:none; margin-top:3px; }
.rail b{ display:block; font-family:'Sora',sans-serif; font-size:14.5px; font-weight:600; }
.rail span{ display:block; margin-top:4px; font-size:12.5px; color:var(--muted); line-height:1.5; }

/* -------- HERO EMPHASIS MODES (Tweaks) -------- */
body[data-hero-mode="studio"] .hero2-products{ grid-template-columns:1fr; gap:0; }
body[data-hero-mode="studio"] #pcardStudio{ order:-1; }
body[data-hero-mode="studio"] #pcardStudio h3{ font-size:26px; }
body[data-hero-mode="studio"] #pcardStudio p{ max-width:560px; }
body[data-hero-mode="studio"] #pcardSpecialist{ padding-block:18px 14px; }
body[data-hero-mode="studio"] #pcardSpecialist p{ display:none; }
body[data-hero-mode="studio"] #pcardSpecialist h3{ font-size:16px; }
body[data-hero-mode="studio"] #pcardSpecialist h3::before{ content:"Also: "; color:var(--muted); font-weight:500; }

/* -------- MISC -------- */
.lang-toggle button:disabled{ opacity:.45; cursor:not-allowed; }
.ph-link{ font-size:13.5px; color:var(--muted-2); cursor:default; }

/* -------- GEO STRIP -------- */
.geo-strip{ text-align:center; }
.geo-strip .lead{ margin:16px auto 0; max-width:560px; }
.geo-row{ display:flex; justify-content:center; gap:18px; margin-top:38px; flex-wrap:wrap; }
.geo{
  display:flex; align-items:center; gap:14px; text-align:left;
  padding:18px 26px 18px 20px; border-radius:var(--r-md);
  background:var(--surface); border:1px solid var(--line);
}
.geo .g-flag{ font-size:26px; line-height:1; }
.geo b{ display:block; font-family:'Sora',sans-serif; font-size:16px; font-weight:600; }
.geo span{ font-family:'Space Mono',monospace; font-size:10.5px; letter-spacing:.08em; color:var(--muted); }

/* -------- RESPONSIVE -------- */
@media (max-width:1080px){
  .engines{ grid-template-columns:repeat(2,1fr); }
  .rails{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width:920px){
  .hero2-grid{ grid-template-columns:1fr; gap:48px; }
  .hero2-copy{ max-width:680px; }
  .hero2-grid .stage{ justify-self:center; }
  .metrics{ grid-template-columns:1fr; }
  .logo-row{ grid-template-columns:repeat(3,1fr); }
  .case-card{ flex-direction:column; align-items:flex-start; }
  .hero2-products{ grid-template-columns:1fr; }
  .prod-grid, .prod-grid.flip{ grid-template-columns:1fr; }
  .prod-grid.flip .prod-copy{ order:1; }
  .prod-grid.flip .prod-visual{ order:2; }
  .steps, .caps{ grid-template-columns:1fr; }
  .prod-visual .lead-float{ left:8px; top:auto; bottom:-18px; }
  .update-float{ right:8px; bottom:-18px; }
}
@media (max-width:600px){
  .prod-visual .lead-float, .update-float{ display:none; }
  .engines, .rails{ grid-template-columns:1fr; }
  .logo-row{ grid-template-columns:repeat(2,1fr); }
  .try-form input{ font-size:16px; min-width:0; }
  .try-form .btn{ width:100%; justify-content:center; }
  .mock-studio-body{ grid-template-columns:1fr; }
  .script-pane{ border-right:none; border-bottom:1px solid var(--line); }
  .geo-row{ flex-direction:column; align-items:stretch; }
}
