/* ============================================================
   OPSOR · v3 CINEMA — pages (inner pages shared blocks)
   page-hero · crumb · feature-grid · spec-table · timeline · legal · cta-band
   ============================================================ */

/* ---------- PAGE HERO — inner pages ---------- */
.page-hero{
  position:relative;z-index:2;
  padding:160px 32px 80px;
  max-width:var(--max);margin:0 auto;
}
.page-hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  margin-bottom:36px;
}
.page-hero-eyebrow .crumb{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.page-hero-eyebrow .crumb a{color:var(--ink-2);transition:color .25s}
.page-hero-eyebrow .crumb a:hover{color:var(--brand-bright)}
.page-hero-eyebrow .crumb .sep{color:var(--brand);margin:0 10px;font-weight:300}

.page-hero-h{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(64px,10vw,168px);line-height:.92;letter-spacing:-.045em;
  max-width:18ch;margin:0;
}
.page-hero-h em{color:var(--sand);font-weight:300}
.page-hero-sub{
  font-size:clamp(17px,1.4vw,21px);line-height:1.5;color:var(--ink-2);
  max-width:64ch;margin-top:32px;
  font-family:'Fraunces',serif;font-weight:300;
}
.page-hero-meta{
  margin-top:48px;
  display:flex;gap:32px;flex-wrap:wrap;align-items:center;
  padding-top:32px;border-top:1px solid var(--line);
}
.page-hero-meta-item{display:flex;flex-direction:column;gap:4px}
.page-hero-meta-item .mono{color:var(--ink-3)}
.page-hero-meta-item .val{font-family:'Fraunces',serif;font-size:22px;letter-spacing:-.01em}
.page-hero-meta-item .val em{color:var(--brand-bright)}

@media(max-width:760px){
  .page-hero{padding:120px 22px 64px}
  .page-hero-meta{gap:20px}
}

/* ---------- FEATURE GRID — generic card grid ---------- */
.fgrid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  max-width:var(--max);margin:0 auto;
}
.fgrid-2{grid-template-columns:repeat(2,1fr)}
.fgrid-4{grid-template-columns:repeat(4,1fr)}

.fcard{
  background:var(--bg);
  padding:48px 40px;
  display:flex;flex-direction:column;gap:20px;
  position:relative;overflow:hidden;
  transition:background .45s var(--e-out);
}
.fcard:hover{background:var(--bg-2)}
.fcard-num{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.fcard-glyph{
  width:56px;height:56px;border-radius:16px;
  background:rgba(124,92,255,.08);border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--brand-bright);
}
.fcard-glyph svg{width:24px;height:24px}
.fcard-h{
  font-family:'Fraunces',serif;font-size:28px;line-height:1.1;letter-spacing:-.015em;
}
.fcard-h em{color:var(--sand);font-weight:300}
.fcard-p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.fcard-list{display:flex;flex-direction:column;gap:6px;margin-top:8px}
.fcard-list li{
  display:flex;gap:10px;align-items:flex-start;
  font-size:13px;color:var(--ink-2);line-height:1.5;
}
.fcard-list li::before{
  content:'';flex-shrink:0;width:5px;height:5px;border-radius:50%;
  background:var(--brand-bright);margin-top:7px;
}
.fcard-foot{
  margin-top:auto;padding-top:18px;
  display:flex;justify-content:space-between;align-items:center;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);
}
.fcard-foot .arr{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line-2);
  display:grid;place-items:center;color:var(--ink-2);
  transition:transform .35s var(--e-spring),background .3s,border-color .3s,color .3s;
}
.fcard:hover .fcard-foot .arr{
  background:var(--brand);border-color:var(--brand);color:#fff;
  transform:rotate(-45deg);
}

@media(max-width:1100px){.fgrid,.fgrid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:680px){.fgrid,.fgrid-2,.fgrid-4{grid-template-columns:1fr}.fcard{padding:36px 28px}}

/* ---------- SECTION SHELL — generic ---------- */
.section{position:relative;z-index:2;padding:120px 0}
.section-head{
  max-width:var(--max);margin:0 auto 80px;
  padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:end;
}
.section-head-l{max-width:24ch}
.section-head-r{max-width:54ch;color:var(--ink-2);font-size:16px;line-height:1.6;font-family:'Fraunces',serif;font-weight:300;font-size:19px}
.section-head .big-title{font-size:clamp(40px,6vw,96px)}
@media(max-width:900px){
  .section{padding:80px 0}
  .section-head{grid-template-columns:1fr;gap:24px;margin-bottom:56px}
}

/* ---------- AGENTS PAGE — full agent profile ---------- */
.agent-prof{
  max-width:var(--max);margin:0 auto;padding:80px var(--gutter);
  border-top:1px solid var(--line);
  display:grid;grid-template-columns:5fr 7fr;gap:80px;
  position:relative;
}
.agent-prof[data-bg="violet"]::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 12% 30%,rgba(124,92,255,.16),transparent 50%);
}
.agent-prof[data-bg="sand"]::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse at 88% 70%,rgba(212,184,150,.12),transparent 50%);
}
.agent-prof-l{position:relative;z-index:2;display:flex;flex-direction:column;gap:24px}
.agent-prof-r{position:relative;z-index:2}

.agent-prof-tag{display:flex;align-items:center;gap:14px}
.agent-prof-tag .num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:48px;line-height:1;color:var(--brand-bright);
}
.agent-prof-tag .lbl{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}

.agent-prof-h{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(48px,6vw,84px);line-height:.95;letter-spacing:-.025em;
}
.agent-prof-h em{color:var(--sand);font-weight:300}
.agent-prof-p{font-size:17px;line-height:1.55;color:var(--ink-2);max-width:48ch}

.agent-prof-cta{margin-top:8px}
.agent-prof-cta .agent-demo{margin-right:12px;margin-bottom:8px}

/* Capabilities — list with hover preview */
.caps{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.cap{
  display:grid;grid-template-columns:60px 1.2fr 1fr 70px;gap:24px;align-items:center;
  padding:20px 0;border-bottom:1px solid var(--line);
  cursor:pointer;
  transition:padding .35s var(--e-out),background .35s;
}
.cap:last-child{border-bottom:0}
.cap:hover{padding-left:14px;padding-right:14px;background:rgba(124,92,255,.05)}
.cap-num{font-family:'JetBrains Mono',monospace;font-size:12px;letter-spacing:.18em;color:var(--ink-3)}
.cap-name{font-family:'Fraunces',serif;font-size:22px;letter-spacing:-.01em;line-height:1.2}
.cap-name em{color:var(--brand-bright);font-weight:300}
.cap-tools{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.cap-tool{
  display:inline-flex;align-items:center;gap:6px;
  padding:4px 10px 4px 4px;border-radius:999px;
  background:rgba(255,255,255,.03);border:1px solid var(--line);
  font-size:11px;color:var(--ink-2);
  font-family:'JetBrains Mono',monospace;letter-spacing:.04em;
}
.cap-tool img{width:16px;height:16px;background:#fff;border-radius:4px;padding:2px}
.cap-arr{
  justify-self:end;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:999px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);
  color:var(--ink-2);
  font-family:'JetBrains Mono',monospace;font-size:9.5px;
  letter-spacing:.16em;text-transform:uppercase;
  transition:background .3s,border-color .3s,color .3s,transform .3s var(--e-spring);
}
.cap-arr::after{content:'↗';font-size:11px;letter-spacing:0;line-height:1}
.cap:hover .cap-arr{background:var(--brand);border-color:var(--brand);color:#fff;transform:translateX(-2px)}

@media(max-width:1000px){
  .agent-prof{grid-template-columns:1fr;gap:40px}
  .cap{grid-template-columns:auto 1fr;gap:14px}
  .cap-tools{grid-column:1 / -1;padding-left:60px;margin-top:-6px}
  .cap-arr{display:none}
}

/* ---------- INTEGRATIONS PAGE ---------- */
.intg-cats{
  display:flex;gap:8px;flex-wrap:wrap;
  max-width:var(--max);margin:0 auto 48px;padding:0 var(--gutter);
}
.intg-cat{
  padding:8px 16px;border-radius:999px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.02);
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);
  cursor:pointer;transition:all .3s var(--e-out);
}
.intg-cat:hover{color:var(--ink);border-color:var(--ink-2)}
.intg-cat.active{background:var(--brand);color:#fff;border-color:var(--brand)}

.intg-grid{
  display:grid;grid-template-columns:repeat(5,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  max-width:var(--max);margin:0 auto;
}
.intg-tile{
  background:var(--bg);
  padding:32px 22px;
  display:flex;flex-direction:column;gap:14px;align-items:flex-start;
  position:relative;overflow:hidden;
  transition:background .35s,transform .35s var(--e-out);
}
.intg-tile:hover{background:var(--bg-2)}
.intg-tile-logo{
  width:48px;height:48px;border-radius:14px;
  background:#fff;padding:10px;
  display:grid;place-items:center;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
}
.intg-tile-logo img{width:100%;height:100%;object-fit:contain}
.intg-tile-name{
  font-family:'Fraunces',serif;font-size:18px;letter-spacing:-.01em;
}
.intg-tile-cat{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);
}
.intg-tile-status{
  position:absolute;top:18px;right:18px;
  display:flex;align-items:center;gap:5px;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.intg-tile-status .led{
  width:6px;height:6px;border-radius:50%;
  background:#10B978;box-shadow:0 0 8px #10B978;
}
.intg-tile-status.soon .led{background:var(--ink-4);box-shadow:none}

.intg-grid.is-filtering .intg-tile{opacity:.18;transform:scale(.98)}
.intg-grid.is-filtering .intg-tile.match{opacity:1;transform:scale(1)}

@media(max-width:1100px){.intg-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.intg-grid{grid-template-columns:repeat(2,1fr)}.intg-tile{padding:24px 16px}}

/* ---------- SPEC TABLE — security ---------- */
.spec{
  max-width:1080px;margin:0 auto;padding:0 var(--gutter);
}
.spec-row{
  display:grid;grid-template-columns:240px 1fr auto;gap:32px;align-items:center;
  padding:28px 0;border-top:1px solid var(--line);
  font-family:'JetBrains Mono',monospace;
}
.spec-row:last-child{border-bottom:1px solid var(--line)}
.spec-key{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2)}
.spec-val{
  font-family:'Fraunces',serif;font-size:20px;letter-spacing:-.01em;
  text-transform:none;color:var(--ink);
}
.spec-val em{color:var(--brand-bright);font-weight:300}
.spec-tag{
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  padding:4px 10px;border-radius:999px;
  border:1px solid var(--line);background:rgba(255,255,255,.02);
}
.spec-tag.ok{color:#10B978;border-color:rgba(16,185,120,.3);background:rgba(16,185,120,.06)}
.spec-tag.fr{color:var(--sand);border-color:rgba(212,184,150,.3);background:rgba(212,184,150,.06)}

@media(max-width:760px){
  .spec-row{grid-template-columns:1fr;gap:8px;padding:20px 0}
  .spec-tag{justify-self:start}
}

/* Pillars (security 3-up cards) */
.pillars{
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.pillar{
  position:relative;padding:48px 40px;border-radius:32px;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));
  border:1px solid var(--line-2);overflow:hidden;
  display:flex;flex-direction:column;gap:20px;
  transition:transform .45s var(--e-out),border-color .45s,background .45s;
}
.pillar:hover{transform:translateY(-4px);border-color:rgba(124,92,255,.35)}
.pillar-glyph{
  width:64px;height:64px;border-radius:18px;
  background:rgba(124,92,255,.1);color:var(--brand-bright);
  display:grid;place-items:center;
}
.pillar-glyph svg{width:28px;height:28px}
.pillar-h{font-family:'Fraunces',serif;font-size:30px;line-height:1.1;letter-spacing:-.015em}
.pillar-h em{color:var(--sand);font-weight:300}
.pillar-p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
.pillar-tag{
  margin-top:auto;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
@media(max-width:1000px){.pillars{grid-template-columns:1fr;gap:16px}}

/* ---------- COMPARE TABLE — pricing ---------- */
.compare{
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.compare-table{
  width:100%;border-collapse:collapse;
  border:1px solid var(--line);
}
.compare-table thead th{
  text-align:left;padding:24px 28px;
  border-bottom:1px solid var(--line);
  font-family:'Fraunces',serif;font-size:24px;letter-spacing:-.01em;font-weight:400;
  background:rgba(255,255,255,.02);
}
.compare-table thead th.feat-h{
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-2);
  font-weight:500;
}
.compare-table thead th.popular{
  background:linear-gradient(180deg,rgba(124,92,255,.1),rgba(124,92,255,.02));
  position:relative;
}
.compare-table thead th.popular::after{
  content:'★ recommandé';
  position:absolute;top:8px;right:14px;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--brand-bright);
}
.compare-table tbody tr{border-top:1px solid var(--line)}
.compare-table tbody tr:hover{background:rgba(255,255,255,.015)}
.compare-table tbody td{
  padding:18px 28px;font-size:14.5px;color:var(--ink);
  vertical-align:middle;
}
.compare-table tbody td:first-child{color:var(--ink-2);font-size:14px}
.compare-table tbody tr.group td{
  background:rgba(0,0,0,.2);color:var(--ink-3);
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;padding:14px 28px;
}
.compare-check{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--brand-soft);color:var(--brand-bright)}
.compare-check svg{width:11px;height:11px}
.compare-no{color:var(--ink-4)}

@media(max-width:760px){
  .compare-table thead th,.compare-table tbody td{padding:14px 16px;font-size:13px}
  .compare-table thead th{font-size:18px}
}

/* ---------- TIMELINE — métier project journey ---------- */
.tl{
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  position:relative;
}
.tl::before{
  content:'';position:absolute;top:48px;left:48px;right:48px;height:1px;
  background:linear-gradient(90deg,var(--brand-soft),var(--brand) 50%,var(--brand-soft));
}
.tl-step{
  padding:0 14px;position:relative;
  display:flex;flex-direction:column;gap:14px;
}
.tl-dot{
  width:14px;height:14px;border-radius:50%;
  background:var(--bg);border:2px solid var(--brand);
  margin:42px 0 0;position:relative;z-index:2;
  box-shadow:0 0 0 6px var(--bg),0 0 24px rgba(124,92,255,.5);
}
.tl-num{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.tl-h{font-family:'Fraunces',serif;font-size:24px;letter-spacing:-.01em;line-height:1.1}
.tl-h em{color:var(--sand);font-weight:300}
.tl-p{font-size:13.5px;line-height:1.55;color:var(--ink-2);max-width:30ch}

@media(max-width:1000px){
  .tl{grid-template-columns:1fr;gap:24px}
  .tl::before{display:none}
  .tl-step{padding:24px 0;border-top:1px solid var(--line)}
  .tl-step:first-child{border-top:0}
  .tl-dot{margin:0}
}

/* ---------- LEGAL pages ---------- */
.legal{
  max-width:780px;margin:0 auto;padding:80px var(--gutter) 120px;
  position:relative;z-index:2;
  font-size:15.5px;line-height:1.75;color:var(--ink-2);
}
.legal h2{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:32px;letter-spacing:-.015em;line-height:1.1;
  margin:64px 0 18px;color:var(--ink);
}
.legal h2:first-child{margin-top:0}
.legal h2 em{color:var(--sand);font-weight:300}
.legal h3{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:21px;letter-spacing:-.01em;line-height:1.2;
  margin:36px 0 12px;color:var(--ink);
}
.legal p{margin-bottom:14px}
.legal a{color:var(--brand-bright);border-bottom:1px solid var(--brand-soft)}
.legal a:hover{color:var(--ink)}
.legal ul{display:flex;flex-direction:column;gap:6px;margin:14px 0 18px;padding-left:0}
.legal ul li{
  display:flex;gap:12px;
  padding-left:0;
}
.legal ul li::before{
  content:'—';color:var(--brand);flex-shrink:0;
}
.legal-meta{
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  padding-bottom:32px;margin-bottom:64px;
  border-bottom:1px solid var(--line);
}

/* ---------- CTA BAND — used on inner pages ---------- */
.cta-band{
  max-width:var(--max);margin:0 auto;padding:120px var(--gutter);
  display:grid;grid-template-columns:1.4fr 1fr;gap:64px;align-items:center;
  position:relative;z-index:2;
}
.cta-band-h{
  font-family:'Fraunces',serif;font-weight:400;
  font-size:clamp(44px,5.5vw,84px);line-height:.95;letter-spacing:-.03em;
}
.cta-band-h em{color:var(--brand-bright);font-weight:300}
.cta-band-r{display:flex;flex-direction:column;align-items:flex-start;gap:18px;max-width:42ch}
.cta-band-r p{font-size:15px;line-height:1.6;color:var(--ink-2)}
@media(max-width:900px){.cta-band{grid-template-columns:1fr;gap:32px;padding:80px var(--gutter)}}

/* ---------- ABOUT — manifesto + values ---------- */
.manifesto{
  max-width:1100px;margin:0 auto;padding:80px var(--gutter);
  font-family:'Fraunces',serif;font-weight:300;
  font-size:clamp(28px,3.6vw,52px);line-height:1.18;letter-spacing:-.015em;
  color:var(--ink-2);
}
.manifesto p{margin-bottom:36px}
.manifesto p strong{color:var(--ink);font-weight:400;font-style:italic}
.manifesto p em{color:var(--brand-bright);font-style:italic;font-weight:300}

.values{
  display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
  max-width:var(--max);margin:0 auto;
}
.value{
  background:var(--bg);padding:48px 36px;
  display:flex;flex-direction:column;gap:16px;
  transition:background .4s;
}
.value:hover{background:var(--bg-2)}
.value-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:60px;line-height:.9;color:var(--brand-bright);
}
.value-h{font-family:'Fraunces',serif;font-size:24px;letter-spacing:-.015em;line-height:1.15}
.value-p{font-size:14.5px;line-height:1.6;color:var(--ink-2)}
@media(max-width:900px){.values{grid-template-columns:1fr}}

/* ---------- CONTACT page ---------- */
.contact{
  max-width:var(--max);margin:0 auto;padding:60px var(--gutter) 120px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:80px;
  position:relative;z-index:2;
}
.contact-l{display:flex;flex-direction:column;gap:32px}
.contact-l-h{font-family:'Fraunces',serif;font-weight:400;font-size:clamp(40px,5vw,72px);line-height:.95;letter-spacing:-.03em}
.contact-l-h em{color:var(--sand);font-weight:300}
.contact-l-p{font-size:17px;line-height:1.55;color:var(--ink-2);max-width:46ch;font-family:'Fraunces',serif;font-weight:300}

.contact-channels{display:flex;flex-direction:column;gap:0;margin-top:8px}
.contact-channel{
  display:grid;grid-template-columns:48px 1fr auto;gap:18px;align-items:center;
  padding:22px 0;border-top:1px solid var(--line);
  text-decoration:none;color:inherit;
  transition:padding .35s var(--e-out);
}
.contact-channel:last-child{border-bottom:1px solid var(--line)}
.contact-channel:hover{padding-left:14px}
.contact-channel-ic{
  width:42px;height:42px;border-radius:12px;
  background:rgba(124,92,255,.08);color:var(--brand-bright);
  display:grid;place-items:center;
  border:1px solid var(--line-2);
}
.contact-channel-ic svg{width:18px;height:18px}
.contact-channel-text{display:flex;flex-direction:column;gap:2px}
.contact-channel-text .lbl{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.contact-channel-text .val{font-family:'Fraunces',serif;font-size:20px;letter-spacing:-.01em;color:var(--ink)}
.contact-channel-arr{
  width:32px;height:32px;border-radius:50%;
  border:1px solid var(--line-2);display:grid;place-items:center;color:var(--ink-2);
  transition:transform .3s var(--e-spring),background .3s,border-color .3s,color .3s;
}
.contact-channel:hover .contact-channel-arr{background:var(--brand);border-color:var(--brand);color:#fff;transform:rotate(-45deg)}

/* form */
.contact-form{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:32px;
  padding:40px;display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
.contact-form::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 80% 0%,rgba(124,92,255,.16),transparent 55%);
}
.contact-form > *{position:relative;z-index:2}
.contact-form-head{font-family:'Fraunces',serif;font-size:26px;letter-spacing:-.015em;line-height:1.1}
.contact-form-head em{color:var(--brand-bright);font-weight:300}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.field input,.field textarea,.field select{
  background:rgba(0,0,0,.3);border:1px solid var(--line);border-radius:12px;
  padding:14px 16px;color:var(--ink);font-family:'Satoshi',sans-serif;font-size:15px;
  outline:none;transition:border-color .3s,background .3s;
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand);background:rgba(124,92,255,.04)}
.field textarea{resize:vertical;min-height:120px;font-family:'Satoshi',sans-serif;line-height:1.5}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.contact-form button{margin-top:6px;align-self:flex-start}

@media(max-width:1000px){.contact{grid-template-columns:1fr;gap:48px}}
@media(max-width:600px){.field-row{grid-template-columns:1fr}.contact-form{padding:28px}}

/* ---------- OPS PAGE — runtime detail ---------- */
.runtime-grid{
  display:grid;grid-template-columns:1.2fr 1fr;gap:32px;
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.runtime-card{
  background:linear-gradient(180deg,#1d1d27,#15151c);
  border:1px solid var(--line-2);border-radius:28px;
  padding:36px;
  display:flex;flex-direction:column;gap:18px;
  position:relative;overflow:hidden;
}
.runtime-card.tall{grid-row:span 2}
.runtime-card-head{display:flex;justify-content:space-between;align-items:center}
.runtime-card-h{font-family:'Fraunces',serif;font-size:26px;letter-spacing:-.015em;line-height:1.1}
.runtime-card-h em{color:var(--brand-bright);font-weight:300}
.runtime-card-tag{
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.runtime-card-p{font-size:14px;line-height:1.55;color:var(--ink-2);max-width:42ch}

/* clock visual */
.clk{
  position:relative;width:100%;aspect-ratio:1.6/1;border-radius:18px;
  background:radial-gradient(circle at 50% 100%,rgba(124,92,255,.18),transparent 60%),rgba(0,0,0,.3);
  border:1px solid var(--line);
  overflow:hidden;
  display:grid;place-items:center;
}
.clk-time{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:clamp(48px,7vw,96px);line-height:1;letter-spacing:-.02em;color:var(--ink);
}
.clk-time em{color:var(--sand)}
.clk-sub{
  position:absolute;bottom:18px;left:18px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.clk-status{
  position:absolute;top:18px;right:18px;
  display:flex;align-items:center;gap:6px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:#10B978;
}
.clk-status .led{width:6px;height:6px;border-radius:50%;background:#10B978;box-shadow:0 0 8px #10B978;animation:pulseDot 1.5s infinite}

/* schedule rows */
.sched{display:flex;flex-direction:column;gap:8px;margin-top:6px}
.sched-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:14px;align-items:center;
  padding:12px 14px;border-radius:12px;background:rgba(255,255,255,.02);
  border:1px solid var(--line);
}
.sched-time{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:.14em;color:var(--brand-bright)}
.sched-task{font-size:13.5px;color:var(--ink)}
.sched-task .agent{color:var(--ink-3);font-size:11px;display:block;margin-top:2px;font-family:'JetBrains Mono',monospace;letter-spacing:.14em;text-transform:uppercase}
.sched-stat{
  font-family:'JetBrains Mono',monospace;font-size:9px;
  padding:3px 8px;border-radius:6px;letter-spacing:.16em;text-transform:uppercase;
}
.sched-stat.ok{background:rgba(16,185,120,.14);color:#10B978}
.sched-stat.run{background:rgba(124,92,255,.14);color:var(--brand-bright)}
.sched-stat.due{background:rgba(212,184,150,.14);color:var(--sand)}

@media(max-width:1000px){.runtime-grid{grid-template-columns:1fr}.runtime-card.tall{grid-row:auto}}

/* ---------- METIER ÉNERGIES — capability grid (12 skills) ---------- */
.cap-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--line);border:1px solid var(--line);
}
.cap-card{
  background:var(--bg);
  padding:32px 28px;
  display:flex;flex-direction:column;gap:12px;
  position:relative;overflow:hidden;
  transition:background .35s var(--e-out);
  cursor:default;
}
.cap-card:hover{background:var(--bg-2)}
.cap-card-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:32px;line-height:.9;color:var(--sand);
  margin-bottom:4px;
}
.cap-card-h{
  font-family:'Fraunces',serif;font-size:21px;letter-spacing:-.01em;line-height:1.15;
}
.cap-card-h em{color:var(--brand-bright);font-weight:300}
.cap-card-p{font-size:13.5px;line-height:1.55;color:var(--ink-2);flex:1}
.cap-card-tag{
  margin-top:auto;padding-top:12px;border-top:1px dashed var(--line);
  font-size:10px;color:var(--ink-3);
}
@media(max-width:1100px){.cap-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cap-grid{grid-template-columns:1fr}}

/* ---------- METIER HUB — vertical catalog ---------- */
.vert-catalog{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.vert-card{
  position:relative;border-radius:32px;
  padding:40px;border:1px solid var(--line-2);overflow:hidden;
  background:linear-gradient(180deg,rgba(255,255,255,.025),rgba(255,255,255,0));
  display:flex;flex-direction:column;gap:14px;min-height:300px;
  text-decoration:none;color:inherit;
  transition:transform .45s var(--e-out),border-color .45s,background .45s;
}
.vert-card.live{
  background:radial-gradient(circle at 80% 20%,rgba(212,184,150,.16),transparent 60%),linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  border-color:rgba(212,184,150,.35);
}
.vert-card.live:hover{transform:translateY(-4px);border-color:var(--sand)}
.vert-card.soon{opacity:.78}
.vert-card.open{
  background:radial-gradient(circle at 30% 80%,rgba(124,92,255,.18),transparent 60%),linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  border-style:dashed;border-color:rgba(124,92,255,.35);
}

.vert-card-status{
  position:absolute;top:18px;right:20px;
  display:inline-flex;align-items:center;gap:6px;
  font-family:'JetBrains Mono',monospace;font-size:9.5px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
.vert-card-status .led{
  width:6px;height:6px;border-radius:50%;
}
.vert-card.live .vert-card-status .led{background:#10B978;box-shadow:0 0 8px #10B978}
.vert-card.soon .vert-card-status .led{background:var(--ink-4)}
.vert-card.open .vert-card-status .led{background:var(--brand);box-shadow:0 0 8px var(--brand)}
.vert-card.live .vert-card-status{color:#10B978}

.vert-card-num{
  font-family:'Fraunces',serif;font-style:italic;font-weight:300;
  font-size:60px;line-height:.85;color:var(--brand-bright);
}
.vert-card.live .vert-card-num{color:var(--sand)}
.vert-card.open .vert-card-num{color:var(--brand-bright)}
.vert-card-h{
  font-family:'Fraunces',serif;font-size:38px;line-height:1;letter-spacing:-.02em;
}
.vert-card-h em{color:var(--sand);font-weight:300}
.vert-card.open .vert-card-h em{color:var(--brand-bright)}
.vert-card-p{font-size:14.5px;line-height:1.55;color:var(--ink-2);max-width:42ch}
.vert-card-stats{
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  font-size:12.5px;color:var(--ink-2);
  margin-top:auto;padding-top:12px;border-top:1px dashed var(--line-2);
}
.vert-card-stats b{color:var(--ink);font-weight:500}
.vert-card-stats .vert-card-dot{color:var(--brand);font-weight:300}
.vert-card-arr{
  align-self:flex-start;
  font-family:'JetBrains Mono',monospace;font-size:11px;
  letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink-2);margin-top:10px;
  transition:color .25s;
}
a.vert-card-arr:hover{color:var(--brand-bright)}
.vert-card.live:hover .vert-card-arr{color:var(--sand)}

@media(max-width:900px){.vert-catalog{grid-template-columns:1fr}}

/* ---------- METIER — vertical Énergies ---------- */
.metier-stack{
  display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--line);border:1px solid var(--line);
  max-width:var(--max);margin:0 auto;
}
.metier-row{
  background:var(--bg);padding:56px 40px;
  display:flex;flex-direction:column;gap:14px;
  position:relative;overflow:hidden;
  transition:background .4s;
}
.metier-row[data-bg="sand"]{background:radial-gradient(circle at 80% 20%,rgba(212,184,150,.12),transparent 55%),var(--bg)}
.metier-row[data-bg="violet"]{background:radial-gradient(circle at 20% 80%,rgba(124,92,255,.12),transparent 55%),var(--bg)}
.metier-row-num{font-family:'Fraunces',serif;font-style:italic;font-weight:300;font-size:54px;line-height:.95;color:var(--brand-bright)}
[data-bg="sand"] .metier-row-num{color:var(--sand)}
.metier-row-h{font-family:'Fraunces',serif;font-size:32px;letter-spacing:-.015em;line-height:1.1}
.metier-row-h em{color:var(--sand);font-weight:300}
.metier-row-p{font-size:14.5px;line-height:1.6;color:var(--ink-2);max-width:54ch}
.metier-row-tag{
  margin-top:auto;padding-top:24px;
  font-family:'JetBrains Mono',monospace;font-size:10px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
}
@media(max-width:900px){.metier-stack{grid-template-columns:1fr}}

/* ---------- USE CASES ---------- */
.uc-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:20px;
  max-width:var(--max);margin:0 auto;padding:0 var(--gutter);
}
.uc{
  position:relative;border-radius:32px;
  padding:40px;border:1px solid var(--line-2);overflow:hidden;
  display:flex;flex-direction:column;gap:18px;min-height:380px;
  transition:transform .45s var(--e-out),border-color .45s;
}
.uc[data-bg="violet"]{background:radial-gradient(circle at 30% 20%,rgba(124,92,255,.28),transparent 60%),#1a1a25}
.uc[data-bg="sand"]{background:radial-gradient(circle at 70% 80%,rgba(212,184,150,.22),transparent 60%),#1c1812}
.uc[data-bg="ink"]{background:radial-gradient(circle at 50% 50%,rgba(255,255,255,.06),transparent 60%),#15151c}
.uc:hover{transform:translateY(-4px);border-color:rgba(124,92,255,.35)}
.uc-meta{display:flex;justify-content:space-between;align-items:center}
.uc-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.uc-h{font-family:'Fraunces',serif;font-size:clamp(28px,3vw,42px);line-height:1.05;letter-spacing:-.025em}
.uc-h em{color:var(--sand);font-weight:300}
.uc-p{font-size:15px;line-height:1.55;color:var(--ink-2)}
.uc-out{
  margin-top:auto;padding:18px;border-radius:14px;
  background:rgba(0,0,0,.35);border:1px solid var(--line);
  font-size:13.5px;color:var(--ink);line-height:1.55;
}
.uc-out b{color:var(--brand-bright);font-weight:500}
.uc-out .label{
  display:block;
  font-family:'JetBrains Mono',monospace;font-size:9px;
  letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);
  margin-bottom:8px;
}
@media(max-width:900px){.uc-grid{grid-template-columns:1fr}.uc{padding:32px}}
