/* ============================================================
   OPSOR · v3 CINEMA — sections
   hero · dir-marquee · constat · agents · ops · cockpit ·
   scenarios · conn · mid-cta · steps · pricing · trust · faq · final
   ============================================================ */

/* ---------- HERO — conversational ---------- */
.hero-conv{
  position:relative;z-index:2;
  min-height:100vh;
  padding:100px 32px 0;
  display:flex;flex-direction:column;align-items:center;gap:32px;
  max-width:var(--max);margin:0 auto;
  perspective:2200px;
  perspective-origin:50% 35%;
}

/* Manifesto XXL — remplit ~75vh, mockup peek dessous */
.hero-conv-head{
  min-height:74vh;
  display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;gap:36px;
  max-width:1280px;width:100%;
}

/* Conversation card — flagship, allongé en longueur, tilt au scroll */
.hero-conv-card{
  width:min(94vw,1180px);
  background:linear-gradient(180deg,#1c1c24 0%,#14141b 100%);
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  box-shadow:
    0 1px 0 rgba(255,255,255,.04) inset,
    0 40px 100px -20px rgba(0,0,0,.75),
    0 0 100px rgba(124,92,255,.1);
  overflow:hidden;
  display:flex;flex-direction:column;
  min-height:560px;aspect-ratio:16/8;
  position:relative;
  transform-style:preserve-3d;
  transform:rotateX(var(--rx,0deg)) scale(var(--sc,1));
  transform-origin:50% 100%;
  will-change:transform;
}
.hero-conv-card::before{
  content:'';position:absolute;inset:0;border-radius:20px;pointer-events:none;
  background:linear-gradient(180deg,rgba(255,255,255,.04),transparent 25%);
  z-index:1;
}

.hero-conv-top{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 20px;border-bottom:1px solid var(--line);
  background:rgba(0,0,0,.2);position:relative;z-index:2;
}
/* Identity block — left side: Opsor brand + connection status */
.hero-conv-brand{
  display:inline-flex;align-items:center;gap:10px;
  font-size:13px;font-weight:500;
}
.hero-conv-brand-orb{
  width:10px;height:10px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%,#fff,var(--brand) 70%);
  box-shadow:0 0 10px rgba(124,92,255,.55);
}
.hero-conv-brand-name{font-family:'Fraunces',serif;font-weight:400;font-size:15px}
.hero-conv-brand-name em{color:var(--brand-bright);font-style:italic;font-weight:300;margin-left:-2px}
.hero-conv-brand-status{
  font-size:9.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);
  display:inline-flex;align-items:center;gap:6px;margin-left:4px;
}
.hero-conv-brand-status::before{
  content:'';width:5px;height:5px;border-radius:50%;
  background:#10B978;box-shadow:0 0 6px #10B978;
  animation:pulseDot 1.6s infinite;
}

/* Skills (capabilities popup) launcher button */
.hero-conv-skills-btn{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px 6px 9px;border-radius:999px;
  background:rgba(124,92,255,.1);border:1px solid rgba(124,92,255,.28);
  color:var(--brand-bright);font-size:11.5px;font-weight:500;
  font-family:'JetBrains Mono',monospace;letter-spacing:.08em;text-transform:uppercase;
  cursor:pointer;
  transition:background .3s,border-color .3s,transform .25s var(--e-spring);
}
.hero-conv-skills-btn:hover{transform:translateY(-1px);background:rgba(124,92,255,.18)}
.hero-conv-skills-btn svg{color:var(--brand-bright)}
.hero-conv-skills-btn.flash{
  animation:skillsBtnFlash 1.1s var(--e-out);
}
@keyframes skillsBtnFlash{
  0%  {background:rgba(124,92,255,.1);border-color:rgba(124,92,255,.28);box-shadow:0 0 0 0 rgba(124,92,255,0)}
  30% {background:rgba(124,92,255,.45);border-color:rgba(255,255,255,.6);box-shadow:0 0 0 8px rgba(124,92,255,.15)}
  100%{background:rgba(124,92,255,.1);border-color:rgba(124,92,255,.28);box-shadow:0 0 0 0 rgba(124,92,255,0)}
}

/* Capabilities popup overlay — appears when "compétences" button is clicked */
.hero-conv-cap-pop{
  position:absolute;top:64px;right:18px;z-index:6;
  width:min(360px,80%);
  background:linear-gradient(180deg,#1f1f29,#16161e);
  border:1px solid rgba(124,92,255,.3);border-radius:18px;
  box-shadow:0 30px 80px rgba(0,0,0,.6),0 0 0 1px rgba(255,255,255,.03) inset;
  padding:16px;
  opacity:0;transform:translateY(-8px) scale(.96);transform-origin:100% 0%;pointer-events:none;
  transition:opacity .35s var(--e-spring),transform .35s var(--e-spring);
}
.hero-conv-cap-pop.show{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}
.hero-conv-cap-pop-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:0 4px 12px;
  border-bottom:1px solid var(--line);margin-bottom:12px;
}
.hero-conv-cap-pop-title{
  font-family:'Fraunces',serif;font-size:14px;letter-spacing:-.005em;color:var(--ink);
}
.hero-conv-cap-pop-title em{color:var(--brand-bright);font-weight:300}
.hero-conv-cap-pop-tag{
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.hero-conv-cap-grid{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.hero-conv-cap-card{
  padding:9px 10px;border-radius:10px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  display:flex;flex-direction:column;gap:6px;
  transition:background .25s,border-color .25s,transform .2s var(--e-spring);
}
.hero-conv-cap-card.armed{background:rgba(124,92,255,.18);border-color:rgba(124,92,255,.55);transform:translateY(-1px)}
.hero-conv-cap-name{
  font-size:11px;line-height:1.2;color:var(--ink);font-weight:500;
  font-family:'Inter',sans-serif;
}
.hero-conv-cap-launch{
  align-self:flex-start;
  font-family:'JetBrains Mono',monospace;font-size:9px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-3);padding:3px 8px;border-radius:6px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
}
.hero-conv-cap-card.armed .hero-conv-cap-launch{
  background:var(--brand);border-color:var(--brand);color:#fff;
}

@media(max-width:600px){
  .hero-conv-cap-pop{width:calc(100% - 28px);right:14px;left:14px;top:60px}
  .hero-conv-brand-status{display:none}
}

/* "compétence lancée · X" tag in the stream */
.hero-conv-launched{
  align-self:flex-start;display:inline-flex;align-items:center;gap:8px;
  padding:5px 12px 5px 10px;border-radius:999px;
  background:rgba(124,92,255,.12);border:1px solid rgba(124,92,255,.35);
  color:var(--brand-bright);
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;
  opacity:0;transform:translateY(8px);
  transition:opacity .35s,transform .35s;
}
.hero-conv-launched.show{opacity:1;transform:translateY(0)}
.hero-conv-launched svg{flex-shrink:0}
.hero-conv-launched b{color:var(--ink);font-weight:600}
/* 3 dots faux-traffic-light, pure deco UI (no text) */
.hero-conv-dots{display:flex;gap:6px}
.hero-conv-dots span{
  width:9px;height:9px;border-radius:50%;
  background:rgba(255,255,255,.1);
}
.hero-conv-dots span:nth-child(1){background:rgba(255,95,87,.55)}
.hero-conv-dots span:nth-child(2){background:rgba(254,188,46,.55)}
.hero-conv-dots span:nth-child(3){background:rgba(40,200,64,.55)}

/* Stream */
.hero-conv-stream{
  flex:1;padding:28px 24px;display:flex;flex-direction:column;gap:16px;
  position:relative;z-index:2;overflow:hidden;
}
.hero-conv-msg-user{
  align-self:flex-end;max-width:70%;
  background:rgba(255,255,255,.05);border:1px solid var(--line);
  border-radius:14px;padding:10px 14px;
  font-size:14px;line-height:1.5;color:var(--ink);
  font-family:'Inter',sans-serif;letter-spacing:-.005em;
  opacity:0;transform:translateY(8px);
  transition:opacity .4s,transform .4s;
}
.hero-conv-msg-user.show{opacity:1;transform:translateY(0)}
.hero-conv-msg-agent{
  display:flex;gap:12px;align-items:flex-start;
  opacity:0;transform:translateY(8px);
  transition:opacity .4s,transform .4s;
}
.hero-conv-msg-agent.show{opacity:1;transform:translateY(0)}
.hero-conv-avatar{
  width:26px;height:26px;flex-shrink:0;border-radius:50%;
  background:linear-gradient(135deg,var(--brand),var(--brand-deep));
  display:grid;place-items:center;color:#fff;
}
.hero-conv-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}
.hero-conv-text{
  font-size:14px;line-height:1.55;color:var(--ink);
  font-family:'Inter',sans-serif;letter-spacing:-.005em;min-height:1em;
}
.hero-conv-text strong{font-weight:600}
.hero-conv-text .caret{
  display:inline-block;width:1.5px;height:14px;background:var(--brand-bright);
  margin-left:1px;vertical-align:-2px;animation:caretBlink 1s steps(2) infinite;
}
@keyframes caretBlink{0%,50%{opacity:1}51%,100%{opacity:0}}

/* Tool chips */
.hero-conv-chips{display:flex;gap:6px;flex-wrap:wrap}
.hero-conv-chip{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px 4px 4px;border-radius:999px;
  background:rgba(255,255,255,.04);border:1px solid var(--line);
  font-size:11px;color:var(--ink-2);font-weight:500;
  font-family:'Inter',sans-serif;
  opacity:0;transform:scale(.95);
  transition:opacity .3s,transform .3s,background .3s,border-color .3s,color .3s;
}
.hero-conv-chip.show{opacity:1;transform:scale(1)}
.hero-conv-chip.success{border-color:rgba(16,185,120,.3);color:var(--success);background:rgba(16,185,120,.1)}
.hero-conv-chip.running{border-color:rgba(124,92,255,.3);color:var(--brand-bright);background:rgba(124,92,255,.1)}
.hero-conv-chip-logo{
  width:16px;height:16px;border-radius:4px;background:#fff;padding:2px;
  display:grid;place-items:center;
}
.hero-conv-chip-logo img{width:100%;height:100%;object-fit:contain}
.hero-conv-spinner{
  width:9px;height:9px;border-radius:50%;
  border:1.3px solid currentColor;border-top-color:transparent;
  animation:heroSpin 1s linear infinite;
}
@keyframes heroSpin{to{transform:rotate(360deg)}}
.hero-conv-check svg{width:11px;height:11px}

/* Thinking dots */
.hero-conv-thinking{display:flex;gap:3px;align-items:center;padding:4px 0}
.hero-conv-thinking span{
  width:5px;height:5px;border-radius:50%;background:var(--ink-3);
  animation:thinkPulse 1.4s infinite;
}
.hero-conv-thinking span:nth-child(2){animation-delay:.2s}
.hero-conv-thinking span:nth-child(3){animation-delay:.4s}
@keyframes thinkPulse{0%,80%,100%{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1.2)}}

/* Composer */
.hero-conv-composer{
  display:flex;align-items:center;gap:8px;
  margin:0 16px 16px;padding:10px 12px;
  background:rgba(255,255,255,.025);border:1px solid var(--line);border-radius:14px;
  position:relative;z-index:2;
  transition:background .3s,border-color .3s;
}
.hero-conv-composer.focus{background:rgba(124,92,255,.05);border-color:rgba(124,92,255,.3)}
.hero-conv-action{
  display:grid;place-items:center;width:24px;height:24px;color:var(--ink-3);
}
.hero-conv-input{
  flex:1;font-size:13.5px;color:var(--ink);min-height:18px;
  font-family:'Inter',sans-serif;letter-spacing:-.005em;
}
.hero-conv-input.empty{color:var(--ink-3)}
.hero-conv-input .typing-caret{
  display:inline-block;width:1.5px;height:13px;background:var(--brand-bright);
  margin-left:1px;vertical-align:-2px;animation:caretBlink 1s steps(2) infinite;
}
.hero-conv-send{
  width:28px;height:28px;border-radius:50%;
  background:rgba(255,255,255,.08);color:var(--ink-3);
  display:grid;place-items:center;flex-shrink:0;
  transition:all .3s var(--e-spring);
}
.hero-conv-send.active{background:var(--ink);color:var(--bg)}

/* Head (top) — manifesto XXL qui domine le fold (2 lignes) */
.hero-conv-tagline{
  font-size:clamp(80px,15vw,260px);
  line-height:.9;letter-spacing:-.045em;margin:0;
  max-width:none;
}
.hero-conv-tagline em{color:var(--sand)}
.hero-conv-baseline{
  font-size:clamp(18px,1.6vw,26px);color:var(--ink-2);
  max-width:720px;line-height:1.4;
  font-family:'Fraunces',serif;font-weight:300;
}

/* Foot (below mockup) — CTA only */
.hero-conv-foot{
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;justify-content:center;
}
.hero-conv-stars{display:flex;flex-direction:column;align-items:flex-start;gap:2px;font-size:12px;color:var(--ink-2)}
.hero-conv-stars span:first-child{color:var(--sand);letter-spacing:2px}
.hero-conv-stars-tx{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}

@media(max-width:880px){
  .hero-conv-card{min-height:480px;aspect-ratio:auto}
  .hero-conv-stream{padding:20px 16px}
  .hero-conv-composer{margin:0 12px 12px}
  .hero-conv-foot{flex-direction:column;gap:14px}
  .hero-conv-stars{align-items:center;text-align:center}
}

/* Legacy hero rules — kept off (selectors no longer in DOM) */
.hero{
  position:relative;z-index:2;
  min-height:100vh;
  padding:120px 32px 40px;
  display:grid;grid-template-rows:1fr auto auto;gap:32px;
  max-width:var(--max);margin:0 auto;
}
.hero-stage{
  position:relative;
  display:flex;flex-direction:column;align-items:flex-start;
  width:fit-content;margin:0 auto;
  justify-self:center;align-self:center;
  padding:0;gap:0;
}
.hero-line{
  font-size:clamp(56px,11.5vw,196px);line-height:.82;letter-spacing:-.045em;
  position:relative;z-index:2;margin:0;white-space:nowrap;
}
.line-1{margin-left:0}
.line-2{margin-left:1.6em;margin-top:-.18em}
.line-3{margin-left:3.2em;margin-top:-.18em}
.hero-line em{display:inline-block}
.hero-word{display:inline-block;overflow:hidden;line-height:1}
.hero-word > span{display:inline-block}

.hero-foot{
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:center;gap:48px;
  padding-top:24px;
}
.hero-baseline{
  font-size:clamp(14px,1.2vw,17px);color:var(--ink-2);max-width:440px;line-height:1.5;
}
.hero-foot .btn-pill{justify-self:end}
.hero-stars{display:flex;flex-direction:column;align-items:flex-end;gap:2px;font-size:12px;color:var(--ink-2)}
.hero-stars span:first-child{color:var(--sand);letter-spacing:2px}

/* subtle scan line — silent dynamism (no text) */
.hero-scan{
  position:relative;height:1px;background:var(--line);overflow:hidden;
}
.hero-scan span{
  position:absolute;top:-1px;left:-12%;height:3px;width:24%;
  background:linear-gradient(90deg,transparent,var(--brand-bright) 30%,#fff 50%,var(--brand-bright) 70%,transparent);
  filter:blur(.5px);
  animation:scanSweep 6s cubic-bezier(.4,0,.2,1) infinite;
}
@keyframes scanSweep{
  0%{left:-24%;opacity:0}
  10%{opacity:1}
  90%{opacity:1}
  100%{left:100%;opacity:0}
}

.hero-scroll{
  position:absolute;bottom:8px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;align-items:center;font-size:10px;color:var(--ink-3);
}
.hero-scroll span{animation:bobs 1.6s ease-in-out infinite}
@keyframes bobs{0%,100%{transform:translateY(0)}50%{transform:translateY(4px)}}

@media(max-width:900px){
  .hero{padding:96px 20px 24px}
  .line-2{margin-left:.8em;margin-top:-.1em}
  .line-3{margin-left:1.6em;margin-top:-.1em}
  .hero-line{font-size:clamp(56px,14vw,120px)}
  .hero-foot{grid-template-columns:1fr;gap:24px;align-items:start}
  .hero-foot .btn-pill{justify-self:start}
  .hero-stars{align-items:flex-start}
}

/* ---------- DIRECTIONAL MARQUEE — pain ---------- */
.dir-marquee{
  border-block:1px solid var(--line);overflow:hidden;
  padding:24px 0;background:rgba(0,0,0,.35);
  position:relative;z-index:2;
}
.dir-marquee-track{
  display:inline-flex;gap:36px;align-items:center;
  width:max-content;will-change:transform;white-space:nowrap;
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-.02em;
}
.dir-item{padding:0 8px}
.dir-item.ital em{color:var(--sand)}
.dir-dot{color:var(--brand);font-weight:300}

/* ---------- CONSTAT — sticky split-screen ---------- */
.constat{position:relative;padding:140px 0 80px;z-index:2}
.constat-intro{
  margin-bottom:96px;max-width:1280px;
  padding:0 var(--gutter);
}

.constat-split{
  display:grid;grid-template-columns:1fr 1.1fr;
  gap:80px;align-items:start;
  padding:0 var(--gutter);
}
.constat-split-left{position:relative}
.constat-split-sticky{
  /* Pinned via GSAP ScrollTrigger (see scripts/sticky-laptop.js) — more
     reliable than CSS position:sticky which is fragile with parent context. */
  position:relative;
}
.constat-split-right{display:flex;flex-direction:column}

.constat-split-right .stack-panel{
  padding:72px 0;
  border-top:1px solid var(--line);
  background:transparent;display:block;
}
.constat-split-right .stack-panel:first-child{border-top:0;padding-top:0}
.constat-split-right .stack-num{
  font-size:clamp(56px,5.5vw,84px);line-height:.85;color:var(--brand-bright);
  font-style:italic;font-weight:300;
  display:block;margin-bottom:24px;
}
.constat-split-right .stack-title{
  font-size:clamp(36px,4.2vw,64px);line-height:.95;letter-spacing:-.025em;margin:0;
}
.constat-split-right .stack-text{
  font-size:clamp(15px,1.15vw,18px);line-height:1.55;color:var(--ink-2);
  max-width:520px;margin:24px 0 0;
}
.constat-split-right .stack-list{
  display:flex;flex-direction:column;gap:8px;font-size:14.5px;color:var(--ink);
  margin-top:28px;max-width:520px;
}
.constat-split-right .stack-list li{display:flex;gap:12px;align-items:center;padding:10px 0;border-bottom:1px dashed var(--line)}
.constat-split-right .stack-list li::before{content:'→';color:var(--brand-bright)}
.constat-split-right .stack-tag{
  display:inline-block;color:var(--ink-3);margin-top:24px;font-size:11px;
  font-family:'JetBrains Mono',monospace;letter-spacing:.18em;text-transform:uppercase;
}

@media(max-width:1100px){
  .constat-split{grid-template-columns:1fr;gap:48px}
  .constat-split-sticky{position:relative;top:0}
}
@media(max-width:900px){
  .constat-split-right .stack-panel{padding:56px 0}
}

/* ---------- AGENTS — pinned panels overscroll ---------- */
.agents{position:relative;padding:160px 0 0;z-index:2}
.agents-intro{margin-bottom:120px;max-width:1280px}
.agents-stack{position:relative}
.agent-panel{
  position:relative;min-height:100vh;height:100vh;
  display:grid;grid-template-rows:auto 1fr;
  padding:32px 8vw 56px;
  border-top:1px solid var(--line-2);
  overflow:hidden;
  transform:translateZ(0);backface-visibility:hidden;
}
@media(max-height:820px){
  .agent-panel{padding:24px 8vw 40px}
  .agent-panel-title{font-size:clamp(40px,6.5vw,96px) !important;margin-bottom:14px}
  .agent-panel-text{font-size:15px !important;margin-bottom:16px}
  .agent-panel-body{gap:32px}
  .agent-demo-row{margin:12px 0 14px}
}
.agent-panel[data-bg="violet"]{background:radial-gradient(circle at 70% 30%,rgba(124,92,255,.28),transparent 55%),#181826;color:var(--ink)}
.agent-panel[data-bg="sand"]{background:radial-gradient(circle at 30% 70%,rgba(212,184,150,.22),transparent 55%),#1a1712;color:#F8EFDD}
.agent-panel[data-bg="ink"]{background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.07),transparent 55%),#15151c;color:var(--ink)}

.agent-panel-meta{display:flex;justify-content:space-between;align-items:center;font-size:12px}
.agent-panel-body{
  display:grid;grid-template-columns:auto 1fr;align-items:center;gap:48px;
  height:100%;padding-bottom:24px;
}
.agent-panel-glyph{
  width:clamp(96px,10vw,180px);height:clamp(96px,10vw,180px);
  border-radius:30px;
  background:rgba(255,255,255,.03);border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink);align-self:center;
}
.agent-panel-glyph svg{width:60%;height:60%}
.agent-panel-title{
  font-size:clamp(48px,8.5vw,140px);line-height:.88;letter-spacing:-.045em;
  margin-bottom:20px;grid-column:2;
}
.agent-panel-title em{color:var(--brand-bright)}
[data-bg="sand"] .agent-panel-title em{color:var(--sand)}
.agent-panel-text{font-size:clamp(16px,1.3vw,20px);line-height:1.5;max-width:600px;color:var(--ink-2);grid-column:2;margin-bottom:24px}
.agent-panel-skills{display:flex;flex-wrap:wrap;gap:8px;grid-column:2}
.agent-panel-skills li{
  padding:6px 14px;border-radius:999px;
  border:1px solid var(--line-2);
  font-size:12px;letter-spacing:.05em;
  font-family:'JetBrains Mono',monospace;text-transform:lowercase;
}

/* Demo button — placed above the subtitle */
.agent-demo-row{
  grid-column:2;
  display:flex;gap:12px;flex-wrap:wrap;
  margin:20px 0 24px;
  position:relative;z-index:5;
}
.agent-demo{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 20px 8px 8px;
  border-radius:999px;
  background:#fff;color:#13131A;
  font-size:13px;font-family:'Satoshi',sans-serif;font-weight:600;
  cursor:pointer;width:fit-content;
  box-shadow:0 8px 24px rgba(0,0,0,.4);
  transition:transform .3s var(--e-spring),box-shadow .3s,background .3s;
  border:0;
}
.agent-demo:hover{transform:translateY(-2px);box-shadow:0 14px 32px rgba(124,92,255,.35);background:var(--ink)}
.agent-demo-ic{
  width:30px;height:30px;border-radius:50%;
  background:var(--brand);color:#fff;
  display:grid;place-items:center;font-size:11px;
  transition:background .3s,transform .3s var(--e-spring);
}
.agent-demo:hover .agent-demo-ic{background:var(--brand-bright);transform:scale(1.08)}

@media(max-width:1100px){.agent-demo-row{grid-column:1}}

@media(max-width:1100px){
  .agent-panel-body{grid-template-columns:1fr;gap:24px;align-items:start;padding-top:24px}
  .agent-panel-title,.agent-panel-text,.agent-panel-skills{grid-column:1}
  .agent-panel-glyph{width:100px;height:100px;border-radius:18px}
}

/* ---------- OPS ---------- */
.ops{padding:160px 0 80px;position:relative;z-index:2}
.ops-intro{margin-bottom:120px}
.ops-block{
  display:grid;grid-template-columns:5fr 7fr;gap:80px;align-items:center;
  padding:80px var(--gutter);
  max-width:var(--max);margin:0 auto;
  border-top:1px solid var(--line);
}
.ops-block.reverse{grid-template-columns:7fr 5fr}
.ops-tag{display:block;margin-bottom:16px}
.ops-h{font-size:clamp(40px,6vw,96px);line-height:.92;letter-spacing:-.035em;margin-bottom:32px}
.ops-p{font-size:18px;line-height:1.5;color:var(--ink-2);margin-bottom:40px;max-width:480px}
.ops-points{display:flex;flex-direction:column;gap:18px}
.ops-points > div{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:flex-start;
  padding:14px 0;border-top:1px dashed var(--line-2);
}
.ops-points span.mono{color:var(--brand-bright);font-weight:600;align-self:center}
.ops-points p{font-size:15px;line-height:1.55;color:var(--ink-2)}
.ops-points b{color:var(--ink);font-weight:500}

.ops-figure{position:relative;border-radius:24px;overflow:hidden;border:1px solid var(--line-2);background:var(--bg-card);will-change:transform}
.ops-figure video{width:100%;aspect-ratio:16/10;object-fit:cover;display:block}
.ops-figure figcaption{
  position:absolute;left:18px;bottom:18px;
  padding:6px 12px;border-radius:999px;
  background:rgba(0,0,0,.6);backdrop-filter:blur(8px);
  color:var(--ink);
}

@media(max-width:900px){
  .ops-block,.ops-block.reverse{grid-template-columns:1fr;gap:40px;padding:48px 24px}
}

/* ---------- COCKPIT ---------- */
.cockpit{padding:160px 0;position:relative;z-index:2}
.cockpit-intro{margin-bottom:80px;max-width:1280px}
.cockpit-stage{
  display:grid;grid-template-columns:7fr 5fr;gap:48px;align-items:center;
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.brf-mock{
  position:relative;
  background:linear-gradient(180deg,#1f1f28 0%,#16161e 100%);
  border:1px solid var(--line-2);border-radius:24px;
  padding:32px;
  display:flex;flex-direction:column;gap:24px;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.5);
}
.brf-head{display:flex;justify-content:space-between;align-items:center}
.brf-head-left{display:flex;gap:14px;align-items:center}
.brf-head-ic{width:42px;height:42px;border-radius:12px;background:var(--brand-soft);color:var(--brand-bright);display:grid;place-items:center}
.brf-head-ic svg{width:22px;height:22px}
.brf-head-title{font-family:'Fraunces',serif;font-size:20px;letter-spacing:-.01em}
.brf-head-sub{font-size:11px;color:var(--ink-3)}
.brf-live{
  display:flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;
  background:rgba(16,185,120,.1);color:#10B978;
  font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.1em;
}
.brf-live-dot{width:6px;height:6px;border-radius:50%;background:#10B978;animation:pulseDot 1.5s infinite}
@keyframes pulseDot{0%,100%{opacity:1}50%{opacity:.4}}

.brf-row{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:stretch}
.brf-score{display:flex;align-items:center;gap:18px;padding:0 24px 0 0;border-right:1px solid var(--line)}
.brf-score-num{font-size:48px;line-height:1;letter-spacing:-.02em}
.brf-score-label{display:block;font-size:9px;color:var(--ink-3);margin-top:6px}

.brf-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.brf-stat{padding:14px;border:1px solid var(--line);border-radius:14px;background:rgba(255,255,255,.02)}
.brf-stat-top{display:flex;justify-content:space-between;font-size:10px;color:var(--ink-3);margin-bottom:8px}
.brf-badge{font-family:'JetBrains Mono',monospace;font-size:10px;padding:2px 7px;border-radius:6px}
.brf-badge.up{background:rgba(16,185,120,.14);color:#10B978}
.brf-badge.down{background:rgba(209,64,64,.14);color:var(--crimson)}
.brf-stat-val{font-size:28px;letter-spacing:-.02em;line-height:1}
.brf-stat-val.up{color:#10B978}
.brf-stat-val.down{color:var(--crimson)}
.brf-bar{height:3px;background:var(--line);border-radius:2px;margin-top:10px;overflow:hidden}
.brf-bar-fill{height:100%;background:var(--brand);border-radius:2px;width:0;transition:width 1.4s var(--e-out)}
.brf-bar-fill.warn{background:var(--crimson)}

.brf-bullets{display:flex;flex-direction:column;gap:8px}
.brf-bullets li{display:flex;gap:12px;align-items:flex-start;padding:10px 14px;border-radius:10px;background:rgba(255,255,255,.025);font-size:13px;line-height:1.45;color:var(--ink-2)}
.brf-bullets b{color:var(--ink)}
.brf-mark{flex-shrink:0;width:20px;height:20px;border-radius:6px;display:grid;place-items:center;font-size:11px;font-weight:600;font-family:'JetBrains Mono',monospace}
.brf-mark.warn{background:rgba(209,64,64,.18);color:var(--crimson)}
.brf-mark.ok{background:rgba(16,185,120,.18);color:#10B978}
.brf-mark.cash{background:rgba(124,92,255,.18);color:var(--brand-bright)}
.brf-scan{
  position:absolute;left:0;right:0;height:80px;
  background:linear-gradient(180deg,transparent,rgba(124,92,255,.12),transparent);
  pointer-events:none;will-change:transform;top:-80px;
}

.cockpit-side{padding:0 0 0 32px;border-left:1px solid var(--line)}
.cockpit-side-num{font-size:clamp(80px,12vw,200px);line-height:.85;letter-spacing:-.04em;color:var(--sand)}
.cockpit-side-text{font-family:'Fraunces',serif;font-size:clamp(20px,2vw,32px);line-height:1.2;letter-spacing:-.01em;color:var(--ink);margin:24px 0}

@media(max-width:1100px){.cockpit-stage{grid-template-columns:1fr}.cockpit-side{padding:32px 0 0;border-left:0;border-top:1px solid var(--line)}}

/* ---------- SCENARIOS — pinned horizontal ---------- */
.scenarios{position:relative;z-index:2;padding:120px 0 0}
.scenarios-intro{margin-bottom:80px;max-width:1280px;padding:0 var(--gutter)}
/* No CSS sticky / fixed height — GSAP ScrollTrigger handles pin + spacer.
   Avoids conflicts where the section overlaps the next one on pin release. */
.scen-pin-wrap{position:relative}
.scen-pin-track{height:100vh;overflow:hidden;display:flex;align-items:center}
.scen-pin-row{display:flex;gap:32px;padding:0 6vw;will-change:transform}
.scen-card{
  flex:0 0 clamp(360px,68vw,820px);
  height:72vh;max-height:680px;
  padding:48px;border-radius:32px;
  border:1px solid var(--line-2);
  display:flex;flex-direction:column;gap:24px;
  position:relative;overflow:hidden;
}
.scen-card[data-bg="violet"]{background:radial-gradient(circle at 30% 20%,rgba(124,92,255,.38),transparent 60%),#1a1a25}
.scen-card[data-bg="sand"]{background:radial-gradient(circle at 70% 80%,rgba(212,184,150,.26),transparent 60%),#1c1812}
.scen-card[data-bg="ink"]{background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.08),transparent 60%),#16161d}
.scen-tag{color:var(--ink-3)}
.scen-h{font-size:clamp(36px,4.5vw,68px);line-height:.95;letter-spacing:-.025em}
.scen-msg{padding:24px;border-radius:18px;background:rgba(0,0,0,.4);border:1px solid var(--line-2);margin-top:auto}
.scen-agent{margin-bottom:10px;color:var(--brand-bright)}
.scen-msg p{font-size:15px;line-height:1.55;color:var(--ink)}
.scen-msg b{color:var(--ink);font-weight:500}
.scen-tools{display:flex;gap:10px;flex-wrap:wrap}
.tool-tile{display:flex;gap:8px;align-items:center;padding:8px 12px;border-radius:10px;background:#fff;color:#000;font-size:12px;font-weight:500}
.tool-tile img{width:18px;height:18px}

/* ---------- CONNEXIONS — orbital integrations ---------- */
.conn{padding:60px 0 80px;position:relative;z-index:2}
.conn-intro{margin-bottom:48px;max-width:1280px;padding:0 var(--gutter)}
.conn-intro .big-sub{margin-top:18px}

.conn-orbit-wrap{
  display:grid;place-items:center;
  padding:32px 24px;
}
.conn-orbit{
  position:relative;
  width:min(640px,82vw);
  aspect-ratio:1;
}

/* Orbit guide circles (dashed decorative) */
.orbit-circle{
  position:absolute;border:1px dashed rgba(255,255,255,.07);border-radius:50%;
  pointer-events:none;
}
.orbit-c1{inset:24%}
.orbit-c2{inset:6%}

/* Center — Opsor brand (logo nu sans fond) */
.orbit-center{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:18%;aspect-ratio:1;
  display:grid;place-items:center;
  z-index:5;
}
.orbit-center img{
  width:100%;height:100%;display:block;object-fit:contain;
  filter:drop-shadow(0 0 30px rgba(124,92,255,.55));
}
.orbit-pulse{
  position:absolute;inset:-12%;border-radius:50%;
  border:1px solid rgba(124,92,255,.35);
  animation:orbitPulse 3s ease-out infinite;
  pointer-events:none;
}
@keyframes orbitPulse{
  0%{transform:scale(1);opacity:.6}
  100%{transform:scale(1.6);opacity:0}
}

/* Rings — radius en pixels via calc (les % de translate sont relatifs à l'élément) */
.orbit-ring{
  position:absolute;inset:0;
  list-style:none;margin:0;padding:0;
  will-change:transform;
}
.orbit-ring-1{
  animation:orbitSpin 60s linear infinite;
  --orbit-r:calc(min(640px,82vw) * 0.28);
}
.orbit-ring-2{
  animation:orbitSpin 90s linear infinite reverse;
  --orbit-r:calc(min(640px,82vw) * 0.46);
}
@keyframes orbitSpin{
  from{transform:rotate(0deg)}
  to  {transform:rotate(360deg)}
}
@keyframes orbitSpinR{
  from{transform:rotate(0deg)}
  to  {transform:rotate(-360deg)}
}

.orbit-item{
  position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%) rotate(var(--a)) translateY(calc(var(--orbit-r) * -1));
  will-change:transform;
}
.orbit-item-inner{
  display:grid;place-items:center;
  width:48px;height:48px;border-radius:14px;
  background:#fff;
  box-shadow:
    0 0 0 1px rgba(0,0,0,.04),
    0 6px 18px rgba(0,0,0,.4),
    0 1px 0 rgba(255,255,255,.6) inset;
  padding:9px;
  transition:transform .35s var(--e-spring),box-shadow .35s;
}
/* Counter-rotation: explicit animation to keep logos upright while ring spins */
.orbit-ring-1 .orbit-item-inner{animation:orbitSpinR 60s linear infinite}
.orbit-ring-2 .orbit-item-inner{animation:orbitSpin   90s linear infinite}
.orbit-item-inner:hover{
  transform:scale(1.18);
  box-shadow:
    0 0 0 1px rgba(124,92,255,.4),
    0 12px 28px rgba(124,92,255,.4),
    0 1px 0 rgba(255,255,255,.6) inset;
}
.orbit-item-inner img{width:100%;height:100%;object-fit:contain}

/* Inner ring : tiles slightly bigger */
.orbit-ring-1 .orbit-item-inner{width:56px;height:56px;border-radius:16px;padding:11px}

.conn-cats{display:flex;gap:18px;justify-content:center;margin-top:48px;flex-wrap:wrap}
.conn-cats .cat-dot{color:var(--brand);font-weight:300}

@media(max-width:760px){
  .conn-orbit{width:min(420px,86vw)}
  .orbit-ring-1 .orbit-item-inner{width:44px;height:44px;border-radius:12px}
  .orbit-item-inner{width:38px;height:38px;border-radius:11px;padding:7px}
}

/* ---------- MID CTA ---------- */
.mid-cta{position:relative;padding:200px 32px;text-align:center;overflow:hidden;z-index:2}
.mid-cta-glow{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);
  width:120%;height:50%;
  background:radial-gradient(ellipse,var(--brand) 0%,transparent 60%);
  filter:blur(100px);opacity:.35;pointer-events:none;
}
.mid-cta-eyebrow{margin-bottom:32px;color:var(--ink-3)}
.mid-cta-h{font-size:clamp(72px,14vw,220px);line-height:.88;letter-spacing:-.045em;margin-bottom:48px}
.mid-cta-h em{color:var(--sand)}
.mid-cta-fp{margin-top:24px;color:var(--ink-3)}

/* ---------- STEPS ---------- */
.steps{padding:160px var(--gutter);position:relative;z-index:2}
.steps-intro{margin-bottom:80px;max-width:760px}
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.step{padding:48px;background:var(--bg);display:flex;flex-direction:column;gap:24px;transition:background .4s}
.step:hover{background:var(--bg-2)}
.step-num{font-size:80px;line-height:.9;color:var(--brand-bright);font-style:italic;font-weight:300}
.step-h{font-family:'Fraunces',serif;font-size:28px;line-height:1.1;letter-spacing:-.01em}
.step-p{font-size:15px;line-height:1.55;color:var(--ink-2)}
@media(max-width:900px){.steps-grid{grid-template-columns:1fr}}

/* ---------- PRICING ---------- */
.pricing{padding:160px var(--gutter);position:relative;z-index:2}
.pricing-intro{margin-bottom:80px}
.pricing-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1120px;margin:0 auto}
.plan{
  position:relative;padding:48px;border:1px solid var(--line-2);border-radius:32px;
  background:var(--bg-2);
  display:flex;flex-direction:column;gap:32px;
}
.plan-feature{
  background:linear-gradient(180deg,rgba(124,92,255,.08) 0%,var(--bg-2) 100%);
  border-color:rgba(124,92,255,.35);
}
.plan-flag{position:absolute;top:24px;right:24px;padding:6px 12px;border-radius:999px;background:var(--brand-soft);color:var(--brand-bright)}
.plan-name{font-size:36px;letter-spacing:-.02em}
.plan-tagline{color:var(--ink-2);font-size:14px;margin-top:4px}
.plan-price{display:flex;align-items:baseline;gap:8px}
.plan-price .display{font-size:80px;line-height:.95;letter-spacing:-.03em}
.plan-price .display em{color:var(--sand)}
.plan-cur{font-size:24px;color:var(--ink-2)}
.plan-period{color:var(--ink-3);align-self:flex-end}
.plan-feats{display:flex;flex-direction:column;gap:14px;font-size:15px;color:var(--ink)}
.plan-feats li{display:flex;gap:12px;align-items:flex-start;padding-bottom:14px;border-bottom:1px dashed var(--line-2)}
.plan-feats li::before{content:'';flex-shrink:0;width:18px;height:18px;border-radius:50%;background:var(--brand-soft);position:relative;margin-top:2px}
.plan-feats li::after{content:'';position:absolute;width:10px;height:6px;border-left:2px solid var(--brand-bright);border-bottom:2px solid var(--brand-bright);transform:rotate(-45deg);margin-left:4px;margin-top:6px}
.plan-feats b{color:var(--ink);font-weight:500}
.plan a.btn{align-self:flex-start;margin-top:auto}
@media(max-width:900px){.pricing-grid{grid-template-columns:1fr}}

/* ---------- TRUST ---------- */
.trust{padding:120px var(--gutter)}
.trust-row{display:flex;align-items:center;gap:32px;justify-content:center;flex-wrap:wrap}
.trust-item{display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}
.trust-num{font-size:clamp(40px,5vw,72px);line-height:1;letter-spacing:-.02em}
.trust-num em{color:var(--brand-bright)}
.trust-line{flex:1;height:1px;background:var(--line);min-width:60px;max-width:120px}

/* ---------- FAQ ---------- */
.faq{padding:160px var(--gutter)}
.faq-intro{margin-bottom:64px}
.faq-list{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.faq-i{border-bottom:1px solid var(--line);transition:background .3s}
.faq-i[open]{background:rgba(124,92,255,.04)}
.faq-i summary{
  list-style:none;padding:24px 0;cursor:pointer;
  display:grid;grid-template-columns:50px 1fr 30px;align-items:center;gap:24px;
  font-family:'Fraunces',serif;font-size:clamp(20px,2vw,28px);
  letter-spacing:-.01em;line-height:1.2;
  transition:padding .3s;
}
.faq-i summary::-webkit-details-marker{display:none}
.faq-i summary span.mono{color:var(--ink-3)}
.faq-i[open] summary span.mono{color:var(--brand-bright)}
.faq-pm{font-family:'Fraunces',serif;font-style:italic;font-weight:300;text-align:right;color:var(--ink-2);transition:transform .4s var(--e-spring)}
.faq-i[open] .faq-pm{transform:rotate(135deg);color:var(--brand-bright)}
.faq-a{padding:0 24px 32px 74px;color:var(--ink-2);font-size:15px;line-height:1.65;max-width:760px}
.faq-a p+p{margin-top:12px}
.faq-a a{color:var(--brand-bright);border-bottom:1px solid var(--brand-soft)}

/* ---------- FINAL CTA ---------- */
.final{padding:160px var(--gutter)}
.final-card{
  padding:96px 48px;border-radius:48px;
  background:radial-gradient(circle at 20% 20%,rgba(124,92,255,.32) 0%,transparent 60%),linear-gradient(135deg,#211b32,#16161d);
  border:1px solid rgba(124,92,255,.3);
  text-align:center;position:relative;overflow:hidden;
}
.final-h{font-size:clamp(56px,9vw,144px);line-height:.92;letter-spacing:-.04em;margin-bottom:24px}
.final-h em{color:var(--sand)}
.final-p{font-size:17px;color:var(--ink-2);max-width:560px;margin:0 auto 40px}
.final-fp{margin-top:28px;color:var(--ink-3)}
