/* ============================================================
   RattusWMS v2 — Home sections
   ============================================================ */

/* ============================================================
   HERO
   ============================================================ */
.hero{ padding:72px 0 0; }
.hero-copy{ max-width:880px; }
.eyebrow-line{ display:flex; align-items:center; gap:14px; margin-bottom:26px; }
.eyebrow-line .lab{ font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.12em; text-transform:uppercase; color:var(--blue-700); }
.eyebrow-line .ln{ flex:1; height:1px; background:var(--line); max-width:120px; }
.eyebrow-line .coord{ font-family:var(--mono); font-size:11.5px; color:var(--ink-4); }
.hero h1{ font-size:clamp(40px,6.1vw,76px); font-weight:600; line-height:.99; letter-spacing:-.035em; }
.hero h1 em{ font-style:normal; color:var(--blue-700); }
.hero-sub{ margin-top:26px; max-width:600px; font-size:clamp(17px,1.5vw,20px); line-height:1.55; color:var(--ink-3); }
.hero-cta{ display:flex; align-items:center; gap:13px; margin-top:32px; flex-wrap:wrap; }
.hero-micro{ display:flex; align-items:center; gap:10px; margin-top:22px; font-family:var(--mono); font-size:12.5px; color:var(--ink-4); }
.hero-micro .tick{ color:var(--mint); }

/* ---- stage: console + phone + annotations ---- */
.stage{ position:relative; margin-top:64px; padding-bottom:110px; }
.stage::after{ content:''; position:absolute; left:46%; bottom:60px; transform:translateX(-50%); width:64%; height:55%; background:radial-gradient(50% 50% at 50% 50%,rgba(0,70,135,.14),transparent 70%); filter:blur(44px); z-index:0; }
.stage-inner{ position:relative; z-index:1; max-width:1080px; margin:0 auto; }

.console{ background:var(--surface); border:1px solid var(--line-strong); border-radius:var(--r-lg); box-shadow:var(--sh-3); overflow:hidden; }
.cbar{ display:flex; align-items:center; gap:13px; padding:11px 16px; border-bottom:1px solid var(--line-2); background:linear-gradient(#fff,#fcfdfe); }
.cbar .dts{ display:flex; gap:6px; }
.cbar .dts i{ width:10px; height:10px; border-radius:50%; background:#dde2ea; }
.cbar .url{ font-family:var(--mono); font-size:12px; color:var(--ink-4); }
.cbar .cbar-r{ margin-left:auto; display:flex; align-items:center; gap:10px; }
.cbar .csearch{ font-family:var(--mono); font-size:11.5px; color:var(--ink-4); border:1px solid var(--line); border-radius:var(--r-sm); padding:5px 11px; background:var(--paper); }
.cbar .cav{ width:25px; height:25px; border-radius:50%; background:linear-gradient(135deg,var(--blue-600),var(--blue-900)); color:#fff; font-family:var(--display); font-size:10px; font-weight:700; display:flex; align-items:center; justify-content:center; }

.cbody{ display:grid; grid-template-columns:212px 1fr; min-height:498px; }
.cside{ border-right:1px solid var(--line-2); padding:16px 12px; background:#fcfdfe; }
.cwh{ display:flex; align-items:center; gap:9px; padding:9px 10px; border:1px solid var(--line); border-radius:var(--r-sm); margin-bottom:16px; background:#fff; }
.cwh .ci{ width:28px; height:28px; border-radius:var(--r-xs); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; }
.cwh .ci svg{width:15px;height:15px;}
.cwh b{ font-size:12.5px; display:block; line-height:1.2; }
.cwh span{ font-family:var(--mono); font-size:10px; color:var(--ink-4); }
.cwh .cc{ margin-left:auto; color:var(--ink-4); }
.cside .sl{ font-family:var(--mono); font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); padding:0 10px; margin:4px 0 8px; }
.cnav{ display:flex; flex-direction:column; gap:1px; }
.cnav a{ display:flex; align-items:center; gap:10px; padding:8px 10px; border-radius:var(--r-sm); font-size:13px; font-weight:500; color:var(--ink-2); }
.cnav a svg{ width:16px; height:16px; color:var(--ink-4); }
.cnav a.on{ background:var(--tint); color:var(--blue-700); font-weight:600; }
.cnav a.on svg{ color:var(--blue-700); }
.cnav a .bd{ margin-left:auto; font-family:var(--mono); font-size:10px; background:var(--blue-700); color:#fff; border-radius:var(--r-pill); padding:1px 7px; }

.cmain{ padding:20px 22px; background:var(--paper); min-width:0; }
.cmain-h{ display:flex; align-items:center; gap:11px; margin-bottom:16px; }
.cmain-h h3{ font-size:17px; font-weight:600; }
.cmain-h .live{ font-family:var(--mono); font-size:11px; color:var(--mint); border:1px solid var(--mint-soft); background:var(--mint-soft); border-radius:var(--r-pill); padding:3px 9px; display:inline-flex; gap:6px; align-items:center; }
.cmain-h .live::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--mint);}
.cmain-h .seg{ margin-left:auto; display:flex; border:1px solid var(--line); border-radius:var(--r-sm); overflow:hidden; }
.cmain-h .seg span{ font-family:var(--mono); font-size:11px; color:var(--ink-3); padding:5px 11px; background:#fff; }
.cmain-h .seg span.on{ background:var(--blue-700); color:#fff; }

.kpis{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; margin-bottom:12px; }
.kpi{ background:#fff; border:1px solid var(--line); border-radius:var(--r-sm); padding:13px; }
.kpi .kl{ font-size:11px; color:var(--ink-3); margin-bottom:7px; }
.kpi .kv{ font-family:var(--display); font-size:23px; font-weight:600; letter-spacing:-.02em; line-height:1; }
.kpi .kv small{ font-size:12px; color:var(--ink-4); font-weight:500; }
.kpi .kf{ display:flex; align-items:center; justify-content:space-between; margin-top:9px; }
.kpi .kd{ font-family:var(--mono); font-size:10.5px; color:var(--mint); }
.kspark{ width:54px; height:20px; }
.kspark path.l{ fill:none; stroke:var(--blue-500); stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.kspark path.a{ fill:url(#sf2); opacity:.45; }

.cpanels{ display:grid; grid-template-columns:1.12fr 1fr; gap:10px; }
.cpanel{ background:#fff; border:1px solid var(--line); border-radius:var(--r-sm); padding:15px; }
.cph{ display:flex; align-items:center; justify-content:space-between; margin-bottom:13px; }
.cph h4{ font-size:13px; font-weight:600; font-family:var(--body); }
.cph .mn{ font-family:var(--mono); font-size:10.5px; color:var(--ink-4); }
.cbars{ display:flex; align-items:flex-end; gap:6px; height:116px; }
.cbars .b{ flex:1; height:var(--h); background:var(--blue-100); border-radius:3px 3px 0 0; transform-origin:bottom; }
.cbars .b.pk{ background:linear-gradient(180deg,var(--blue-600),var(--blue-800)); }
.cbax{ display:flex; justify-content:space-between; margin-top:8px; font-family:var(--mono); font-size:9.5px; color:var(--ink-4); }
@keyframes bgrow{from{transform:scaleY(.55);}to{transform:scaleY(1);}}
@media (prefers-reduced-motion:no-preference){
  .cbars .b{ animation:bgrow .7s cubic-bezier(.16,1,.3,1) both; }
  .cbars .b:nth-child(1){animation-delay:.02s}.cbars .b:nth-child(2){animation-delay:.05s}.cbars .b:nth-child(3){animation-delay:.08s}.cbars .b:nth-child(4){animation-delay:.11s}.cbars .b:nth-child(5){animation-delay:.14s}.cbars .b:nth-child(6){animation-delay:.17s}.cbars .b:nth-child(7){animation-delay:.20s}.cbars .b:nth-child(8){animation-delay:.23s}.cbars .b:nth-child(9){animation-delay:.26s}.cbars .b:nth-child(10){animation-delay:.29s}
}
.ctab{ width:100%; border-collapse:collapse; font-size:12px; }
.ctab th{ text-align:left; font-family:var(--mono); font-size:9.5px; letter-spacing:.05em; text-transform:uppercase; color:var(--ink-4); font-weight:500; padding:0 0 8px; }
.ctab td{ padding:8px 0; border-top:1px solid var(--line-2); color:var(--ink-2); }
.ctab td.id{ font-family:var(--mono); color:var(--ink); }
.ctab td.cl{ color:var(--ink); font-weight:500; }
.ctab tr:first-child td{ border-top:none; }

/* phone overlapping */
.phone{ position:absolute; right:-14px; bottom:0; width:210px; background:#0a1422; border-radius:30px; padding:8px; box-shadow:var(--sh-3); z-index:3; }
.pscreen{ background:var(--paper); border-radius:23px; overflow:hidden; position:relative; }
.pnotch{ position:absolute; top:0; left:50%; transform:translateX(-50%); width:86px; height:16px; background:#0a1422; border-radius:0 0 10px 10px; z-index:5; }
.ptop{ display:flex; align-items:center; gap:8px; padding:13px 12px 9px; }
.ptop .pb{ width:24px; height:24px; border-radius:var(--r-xs); background:#fff; border:1px solid var(--line); display:flex; align-items:center; justify-content:center; color:var(--ink-2); }
.ptop .pb svg{width:13px;height:13px;}
.ptop b{ font-size:11.5px; display:block; line-height:1.2; }
.ptop span{ font-family:var(--mono); font-size:9px; color:var(--ink-4); }
.pprog{ height:3px; background:var(--line); margin:0 12px; border-radius:2px; overflow:hidden; }
.pprog i{ display:block; height:100%; width:62%; background:var(--blue-700); }
.pscan{ margin:11px 12px; background:#fff; border:1px solid var(--line); border-radius:var(--r-sm); padding:12px; text-align:center; }
.pscan .bc{ display:flex; align-items:flex-end; justify-content:center; gap:1.5px; height:34px; margin-bottom:8px; }
.pscan .bc i{ width:2px; background:var(--ink); }
.pscan .lc{ font-family:var(--mono); font-size:11px; font-weight:600; color:var(--blue-700); }
.pscan .hn{ font-size:9px; color:var(--ink-4); margin-top:2px; }
.plines{ padding:0 12px; display:flex; flex-direction:column; gap:6px; }
.pl{ display:flex; align-items:center; gap:8px; background:#fff; border:1px solid var(--line); border-radius:var(--r-xs); padding:7px 8px; }
.pl .pk{ width:16px; height:16px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex:none; }
.pl .pk svg{width:10px;height:10px;}
.pl.dn .pk{ background:var(--mint-soft); color:#0a8f68; } .pl.nw .pk{ background:var(--tint); color:var(--blue-700); border:1.5px solid var(--blue-300); } .pl.td .pk{ background:var(--paper-2); color:var(--ink-4); }
.pl b{ font-size:10.5px; font-weight:600; }
.pl .q{ margin-left:auto; font-family:var(--mono); font-size:10px; font-weight:600; color:var(--ink-2); }
.paction{ padding:11px 12px 14px; }
.paction .pbt{ width:100%; background:var(--blue-700); color:#fff; border:none; border-radius:var(--r-pill); padding:9px; font-family:var(--body); font-size:11.5px; font-weight:600; display:flex; align-items:center; justify-content:center; gap:6px; }
.paction .pbt svg{width:13px;height:13px;}

/* annotation callouts */
.annot{ position:absolute; z-index:4; font-family:var(--mono); font-size:11px; color:var(--ink-2); display:flex; align-items:center; gap:8px; }
.annot .pin{ width:9px; height:9px; border-radius:50%; border:2px solid var(--blue-700); background:#fff; flex:none; }
.annot .txt{ background:rgba(255,255,255,.86); backdrop-filter:blur(4px); border:1px solid var(--line); border-radius:var(--r-pill); padding:4px 11px; white-space:nowrap; box-shadow:var(--sh-1); }
.annot.a1{ top:96px; left:-86px; } .annot.a2{ top:300px; left:-70px; } .annot.a3{ top:150px; right:-92px; flex-direction:row-reverse; }
@media (max-width:1180px){ .annot{ display:none; } }
@media (max-width:780px){
  .cbody{ grid-template-columns:1fr; }
  .cside{ display:none; }
  .kpis{ grid-template-columns:1fr 1fr; }
  .cpanels{ grid-template-columns:1fr; }
  .phone{ position:relative; right:auto; bottom:auto; margin:18px auto 0; width:230px; }
  .stage{ padding-bottom:40px; }
}

/* ============================================================
   STRIP — built for
   ============================================================ */
.strip{ background:var(--surface); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.strip .wrap{ display:flex; align-items:center; gap:30px; padding:26px 0; flex-wrap:wrap; }
.strip .sl{ font-family:var(--mono); font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-4); white-space:nowrap; }
.strip .items{ display:flex; flex-wrap:wrap; gap:10px 22px; }
.strip .items span{ font-size:14.5px; font-weight:500; color:var(--ink-2); display:flex; align-items:center; gap:9px; }
.strip .items span::before{ content:''; width:5px; height:5px; background:var(--blue-300); border-radius:1px; }

/* ============================================================
   FLOW — dock-to-invoice process diagram (Visio-style)
   ============================================================ */
.pflow{ margin-top:8px; }
.prow{ display:flex; align-items:stretch; }
.prow.rev{ flex-direction:row-reverse; }
.pnode{ flex:1 1 0; min-width:0; background:#fff; border:1px solid var(--line); border-radius:var(--r-md); padding:18px 12px; text-align:center; box-shadow:var(--sh-1); display:flex; flex-direction:column; align-items:center; gap:9px; }
.pnode .pic{ width:42px; height:42px; border-radius:var(--r-sm); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; border:1px solid var(--blue-100); }
.pnode .pic svg{ width:21px; height:21px; }
.pnode b{ font-family:var(--display); font-size:13.5px; font-weight:600; }
.pnode span.fl{ font-family:var(--mono); font-size:10px; color:var(--ink-4); }

/* decision diamond */
.pdia{ flex:1 1 0; min-width:0; display:flex; align-items:center; justify-content:center; }
.pdia .d{ width:112px; height:112px; transform:rotate(45deg); background:linear-gradient(135deg,var(--tint),#fff); border:1px solid var(--blue-300); border-radius:14px; display:flex; align-items:center; justify-content:center; box-shadow:var(--sh-1); }
.pdia .d .in{ transform:rotate(-45deg); text-align:center; line-height:1.15; }
.pdia .d .in svg{ width:18px; height:18px; color:var(--blue-700); }
.pdia .d .in b{ display:block; font-family:var(--display); font-size:12.5px; font-weight:600; margin-top:3px; }
.pdia .d .in span{ font-family:var(--mono); font-size:9px; color:var(--ink-4); }

/* connectors */
.parrow{ position:relative; flex:0 0 44px; display:flex; align-items:center; justify-content:center; }
.parrow .ln{ height:2px; flex:1; background:var(--blue-300); }
.parrow .hd{ width:0; height:0; flex:none; }
.parrow.r .hd{ border-left:8px solid var(--blue-300); border-top:5px solid transparent; border-bottom:5px solid transparent; }
.parrow.l .hd{ border-right:8px solid var(--blue-300); border-top:5px solid transparent; border-bottom:5px solid transparent; }
.parrow .lbl{ position:absolute; top:50%; left:50%; transform:translate(-50%,-148%); font-family:var(--mono); font-size:9.5px; font-weight:500; color:var(--mint); background:var(--paper); padding:0 5px; white-space:nowrap; }

/* mid band: QC-hold branch + serpentine U-turn (columns mirror the rows) */
.pmid{ display:flex; align-items:stretch; height:122px; }
.pmid .mc{ flex:1 1 0; min-width:0; position:relative; }
.pmid .ms{ flex:0 0 44px; }
.pturn{ position:absolute; left:50%; top:-1px; bottom:-1px; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; }
.pturn .ln{ width:2px; flex:1; background:var(--blue-300); }
.pturn .hd{ width:0; height:0; border-top:8px solid var(--blue-300); border-left:5px solid transparent; border-right:5px solid transparent; }
.pbranch{ position:absolute; left:50%; top:0; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; }
.pbranch .dln{ position:relative; height:22px; border-left:2px dashed var(--amber); }
.pbranch .dln .lbl{ position:absolute; left:9px; top:1px; font-family:var(--mono); font-size:9.5px; font-weight:500; color:var(--amber); }
.phold{ display:flex; align-items:center; gap:10px; background:var(--amber-soft); border:1px solid #efd9ab; border-radius:var(--r-sm); padding:9px 13px; white-space:nowrap; box-shadow:var(--sh-1); }
.phold .hic{ width:28px; height:28px; border-radius:var(--r-xs); background:#fff; border:1px solid #efd9ab; color:var(--amber); display:flex; align-items:center; justify-content:center; }
.phold .hic svg{ width:15px; height:15px; }
.phold .ht{ display:flex; flex-direction:column; gap:1px; }
.phold b{ font-family:var(--display); font-size:12.5px; font-weight:600; line-height:1.2; }
.phold span{ font-family:var(--mono); font-size:9px; color:var(--ink-4); }

@media (max-width:820px){
  .prow, .prow.rev{ flex-direction:column; }
  .parrow{ flex-direction:column; flex-basis:30px; }
  .parrow .ln{ height:auto; width:2px; }
  .parrow.r .hd, .parrow.l .hd{ border:none; border-top:8px solid var(--blue-300); border-left:5px solid transparent; border-right:5px solid transparent; }
  .parrow .lbl{ position:static; transform:none; background:transparent; color:var(--mint); }
  .pmid{ flex-direction:column; height:auto; align-items:center; gap:0; }
  .pmid .ms, .pmid .mc:empty{ display:none; }
  .pmid .mc{ flex:none; }
  .pbranch{ position:relative; left:auto; transform:none; padding:6px 0; }
  .pturn{ position:relative; left:auto; top:auto; bottom:auto; transform:none; height:30px; }
}

/* ============================================================
   BENTO — configurable core
   ============================================================ */
.bento{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.bento .tcard{ padding:26px; }
.bento .bi{ width:40px; height:40px; border-radius:var(--r-sm); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; margin-bottom:16px; }
.bento .bi svg{ width:20px; height:20px; }
.bento h3{ font-size:18px; margin-bottom:8px; }
.bento p{ font-size:14.5px; color:var(--ink-3); line-height:1.55; }
.bento .big{ grid-column:span 2; display:grid; grid-template-columns:1fr 1fr; gap:26px; align-items:center; }
.bento .big h3{ font-size:21px; }
.rules{ background:var(--night); border-radius:var(--r-sm); padding:16px; border:1px solid var(--night-line); font-family:var(--mono); font-size:11.5px; line-height:1.75; color:var(--night-ink-2); }
.rules .k{color:#86b6e8;} .rules .v{color:#67dcb4;} .rules .c{color:#5d7290;} .rules .p{color:var(--night-ink);}
@media (max-width:920px){ .bento{ grid-template-columns:1fr 1fr; } .bento .big{ grid-column:span 2; } }
@media (max-width:600px){ .bento{ grid-template-columns:1fr; } .bento .big{ grid-column:span 1; grid-template-columns:1fr; } }

/* ============================================================
   MODULES
   ============================================================ */
.mods{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.mods .tcard{ padding:24px; display:flex; flex-direction:column; }
.mhead{ display:flex; align-items:center; gap:12px; margin-bottom:13px; }
.mcode{ font-family:var(--mono); font-size:11.5px; font-weight:600; letter-spacing:.04em; color:var(--blue-700); background:var(--tint); border:1px solid var(--blue-100); border-radius:var(--r-xs); padding:6px 9px; }
.mhead h3{ font-size:17px; }
.mods .tcard > p{ font-size:14px; color:var(--ink-3); line-height:1.55; margin-bottom:16px; }
.mtags{ display:flex; flex-wrap:wrap; gap:6px; margin-top:auto; }
.mtags span{ font-family:var(--mono); font-size:11px; color:var(--ink-3); background:var(--paper); border:1px solid var(--line-2); border-radius:var(--r-pill); padding:3px 9px; }
@media (max-width:920px){ .mods{ grid-template-columns:1fr 1fr; } }
@media (max-width:600px){ .mods{ grid-template-columns:1fr; } }

/* ============================================================
   CAPABILITIES
   ============================================================ */
.caps{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.cap{ display:flex; align-items:center; gap:12px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-sm); padding:14px 15px; transition:border-color .2s,transform .2s; }
.cap:hover{ border-color:var(--blue-300); transform:translateY(-2px); }
.cap .ci{ width:32px; height:32px; border-radius:var(--r-xs); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; flex:none; }
.cap .ci svg{ width:16px; height:16px; }
.cap b{ font-size:13px; font-weight:600; line-height:1.25; }
.cap.hot{ background:linear-gradient(135deg,var(--blue-700),var(--blue-600)); border-color:transparent; box-shadow:var(--sh-blue); }
.cap.hot b{ color:#fff; } .cap.hot .ci{ background:rgba(255,255,255,.16); color:#fff; }
@media (max-width:920px){ .caps{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:520px){ .caps{ grid-template-columns:1fr; } }

/* ============================================================
   AI
   ============================================================ */
.ai-grid{ display:grid; grid-template-columns:1fr 1.05fr; gap:56px; align-items:center; }
.ai-badge{ display:inline-flex; align-items:center; gap:8px; font-family:var(--mono); font-size:12px; color:var(--blue-700); border:1px solid var(--blue-100); background:var(--tint-2); border-radius:var(--r-pill); padding:6px 13px; margin-bottom:20px; }
.ai-badge svg{width:14px;height:14px;}
.ai-feat{ display:flex; flex-direction:column; gap:16px; margin-top:24px; }
.ai-feat .f{ display:flex; gap:13px; align-items:flex-start; }
.ai-feat .f .ic{ width:36px; height:36px; border-radius:var(--r-sm); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; flex:none; }
.ai-feat .f .ic svg{width:18px;height:18px;}
.ai-feat .f b{ font-size:15px; display:block; }
.ai-feat .f p{ font-size:14px; color:var(--ink-3); line-height:1.5; margin-top:2px; }
.chat{ background:var(--surface); border:1px solid var(--line-strong); border-radius:var(--r-lg); box-shadow:var(--sh-3); overflow:hidden; }
.chat-h{ display:flex; align-items:center; gap:10px; padding:14px 17px; border-bottom:1px solid var(--line-2); }
.chat-h .orb{ width:28px; height:28px; border-radius:50%; background:linear-gradient(135deg,var(--blue-500),var(--blue-900)); color:#fff; display:flex; align-items:center; justify-content:center; }
.chat-h .orb svg{width:15px;height:15px;}
.chat-h b{ font-size:13.5px; }
.chat-h .on{ margin-left:auto; font-family:var(--mono); font-size:10.5px; color:var(--mint); display:inline-flex; align-items:center; gap:5px; }
.chat-h .on::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--mint);}
.chat-b{ padding:18px; display:flex; flex-direction:column; gap:13px; background:var(--paper); }
.msg{ max-width:84%; font-size:13.5px; line-height:1.5; padding:11px 14px; border-radius:12px; }
.msg.u{ align-self:flex-end; background:var(--blue-700); color:#fff; border-bottom-right-radius:4px; }
.msg.b{ align-self:flex-start; background:#fff; border:1px solid var(--line); color:var(--ink-2); border-bottom-left-radius:4px; }
.msg.b .rows{ margin-top:9px; display:flex; flex-direction:column; gap:6px; }
.msg.b .rows .r{ display:flex; align-items:center; gap:8px; font-family:var(--mono); font-size:11px; color:var(--ink); background:var(--paper); border:1px solid var(--line-2); border-radius:var(--r-xs); padding:6px 9px; }
.msg.b .rows .r .status{ margin-left:auto; }
@media (max-width:860px){ .ai-grid{ grid-template-columns:1fr; gap:36px; } }

/* ============================================================
   WHY — dark blueprint band
   ============================================================ */
.why{ background:var(--night); color:var(--night-ink); position:relative; overflow:hidden; }
.why::before{ content:''; position:absolute; inset:0; background-image:linear-gradient(var(--night-grid) 1px,transparent 1px),linear-gradient(90deg,var(--night-grid) 1px,transparent 1px); background-size:34px 34px; -webkit-mask-image:radial-gradient(90% 90% at 80% 0%,#000,transparent 70%); mask-image:radial-gradient(90% 90% at 80% 0%,#000,transparent 70%); pointer-events:none; }
.why .wrap{ position:relative; z-index:1; }
.why .sec-head h2{ color:#fff; } .why .sec-head p{ color:var(--night-ink-2); } .why .sec-head .sec-no{ color:var(--blue-300); } .why .sec-head .sec-kicker{ color:var(--night-ink-2); }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.wcard{ background:rgba(255,255,255,.03); border:1px solid var(--night-line); border-radius:var(--r-md); padding:26px; }
.wcard .wi{ width:42px; height:42px; border-radius:var(--r-sm); background:rgba(42,111,184,.18); color:#88b2d8; display:flex; align-items:center; justify-content:center; margin-bottom:18px; }
.wcard .wi svg{width:21px;height:21px;}
.wcard h3{ color:#fff; font-size:18px; margin-bottom:9px; }
.wcard p{ color:var(--night-ink-2); font-size:14.5px; line-height:1.6; }
.why-foot{ display:flex; flex-wrap:wrap; gap:10px; margin-top:26px; align-items:center; }
.why-foot .cl{ font-family:var(--mono); font-size:11.5px; color:var(--night-ink-2); }
.cpill{ font-family:var(--mono); font-size:12px; color:var(--night-ink); border:1px solid var(--night-line); border-radius:var(--r-pill); padding:5px 12px; }
@media (max-width:800px){ .why-grid{ grid-template-columns:1fr; } }

/* ============================================================
   STEPS
   ============================================================ */
.steps{ display:grid; grid-template-columns:repeat(3,1fr); gap:14px; }
.step{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:28px; position:relative; }
.step .sn{ font-family:var(--mono); font-size:12px; font-weight:600; color:var(--blue-700); margin-bottom:18px; display:inline-block; border:1px solid var(--blue-100); background:var(--tint); border-radius:var(--r-xs); padding:4px 9px; }
.step h3{ font-size:18px; margin-bottom:8px; }
.step p{ font-size:14.5px; color:var(--ink-3); line-height:1.55; }
@media (max-width:800px){ .steps{ grid-template-columns:1fr; } }

/* ============================================================
   ROADMAP
   ============================================================ */
.roadmap{ display:flex; align-items:center; gap:26px; background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg); padding:30px 34px; flex-wrap:wrap; position:relative; overflow:hidden; }
.roadmap::after{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(10,30,70,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(10,30,70,.04) 1px,transparent 1px); background-size:30px 30px; -webkit-mask-image:linear-gradient(90deg,transparent,#000); mask-image:linear-gradient(90deg,transparent,#000); pointer-events:none; }
.roadmap > *{ position:relative; z-index:1; }
.roadmap .ri{ width:58px; height:58px; border-radius:var(--r-md); background:var(--tint); color:var(--blue-700); display:flex; align-items:center; justify-content:center; flex:none; }
.roadmap .ri svg{width:28px;height:28px;}
.roadmap .rt{ flex:1; min-width:240px; }
.roadmap .rp{ display:inline-flex; align-items:center; gap:7px; font-family:var(--mono); font-size:10.5px; font-weight:500; letter-spacing:.06em; text-transform:uppercase; color:var(--amber); background:var(--amber-soft); border:1px solid #f0dcb3; border-radius:var(--r-pill); padding:4px 11px; margin-bottom:11px; }
.roadmap h3{ font-size:21px; margin-bottom:6px; }
.roadmap p{ font-size:14.5px; color:var(--ink-3); line-height:1.55; max-width:620px; }

/* ============================================================
   FAQ
   ============================================================ */
.faq{ max-width:840px; margin:0 auto; }
.faq details{ border:1px solid var(--line); border-radius:var(--r-md); background:var(--surface); margin-bottom:10px; overflow:hidden; }
.faq details[open]{ border-color:var(--blue-300); }
.faq summary{ list-style:none; cursor:pointer; padding:20px 22px; display:flex; align-items:center; gap:18px; font-family:var(--display); font-size:16px; font-weight:600; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .fn{ font-family:var(--mono); font-size:12px; color:var(--blue-500); flex:none; }
.faq summary .fi{ margin-left:auto; flex:none; width:22px; height:22px; color:var(--blue-700); transition:transform .25s; }
.faq summary .fi svg{width:22px;height:22px;}
.faq details[open] summary .fi{ transform:rotate(45deg); }
.faq .fb{ padding:0 22px 20px 58px; }
.faq .fb p{ font-size:15px; color:var(--ink-3); line-height:1.6; }
@media (max-width:560px){ .faq .fb{ padding-left:22px; } }

/* ============================================================
   CTA
   ============================================================ */
.cta{ padding:104px 0; }
.cta-box{ position:relative; overflow:hidden; background:linear-gradient(135deg,var(--blue-900),var(--blue-700) 58%,var(--blue-600)); border-radius:var(--r-lg); padding:68px 56px; color:#fff; box-shadow:var(--sh-3); }
.cta-box::before{ content:''; position:absolute; inset:0; background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px); background-size:32px 32px; -webkit-mask-image:radial-gradient(80% 100% at 100% 0%,#000,transparent 70%); mask-image:radial-gradient(80% 100% at 100% 0%,#000,transparent 70%); pointer-events:none; }
.cta-box > *{ position:relative; z-index:1; }
.cta-box .kicker{ color:var(--blue-300); }
.cta-box h2{ color:#fff; font-size:clamp(30px,4vw,48px); margin-top:14px; max-width:16ch; }
.cta-box p{ color:rgba(255,255,255,.85); font-size:18px; max-width:540px; margin-top:16px; line-height:1.55; }
.cta-box .hero-cta{ margin-top:30px; }
@media (max-width:600px){ .cta-box{ padding:44px 26px; } }

/* ---- product video section ---- */
.video-frame{position:relative;aspect-ratio:16/9;border-radius:16px;overflow:hidden;
  border:1px solid var(--line-strong);box-shadow:0 30px 60px -28px rgba(10,22,38,.45);
  background:#000;cursor:pointer}
.video-frame img.thumb{width:100%;height:100%;object-fit:cover;display:block;opacity:.86;transition:opacity .3s,transform .6s}
.video-frame:hover img.thumb{opacity:.72;transform:scale(1.03)}
.video-frame .play{position:absolute;inset:0;margin:auto;width:84px;height:84px;border:0;cursor:pointer;
  background:var(--blue-700);border-radius:50%;display:grid;place-items:center;
  box-shadow:0 10px 30px -6px rgba(0,70,135,.7);transition:transform .2s,background .2s}
.video-frame:hover .play{transform:scale(1.08);background:var(--blue-600)}
.video-frame .play svg{width:30px;height:30px;margin-left:4px;fill:#fff}
.video-frame .play::after{content:"";position:absolute;inset:-10px;border-radius:50%;
  border:2px solid rgba(255,255,255,.35);animation:vpulse 2.4s ease-out infinite}
@keyframes vpulse{0%{transform:scale(.8);opacity:.7}70%{transform:scale(1.5);opacity:0}100%{opacity:0}}
.video-frame iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(prefers-reduced-motion:reduce){.video-frame .play::after{animation:none}}




/* video section — two column (text left, player right) */
.video-grid{ display:grid; grid-template-columns:0.85fr 1.15fr; gap:52px; align-items:center; }
.video-copy .sec-kicker{ font-family:var(--mono); font-size:12px; font-weight:500; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-4); display:block; margin-bottom:16px; }
.video-copy h2{ font-size:clamp(28px,3.4vw,42px); font-weight:600; letter-spacing:-.03em; line-height:1.05; }
.video-copy p{ margin-top:18px; font-size:17px; line-height:1.6; color:var(--ink-3); max-width:42ch; }
.video-copy .btn{ margin-top:26px; }
@media (max-width:860px){
  .video-grid{ grid-template-columns:1fr; gap:30px; }
  .video-copy p{ max-width:none; }
}
