/* BBE Buddy — product components
   ============================================================ */

/* ---------- HERO (homepage) ---------- */
.hero{ background:var(--teal); color:#fff; padding:128px 0 0; position:relative; overflow:hidden; }
.hero::after{ content:""; position:absolute; right:-140px; top:-120px; width:460px; height:460px; border-radius:50%; background:color-mix(in srgb,#fff 7%,transparent); }
.hero .eyebrow{ font-size:14px; color:var(--gold); display:inline-flex; align-items:center; gap:10px; text-transform:uppercase; letter-spacing:.14em; font-weight:700; }
.hero .eyebrow::before{ content:""; width:30px; height:3px; background:var(--gold); border-radius:2px; }
.hero h1{ font-size:clamp(44px,6.4vw,96px); font-weight:900; letter-spacing:-0.04em; margin:22px 0 0; max-width:15ch; line-height:1.0; }
.hero h1 .o{ color:var(--gold); }
.hero-bottom{ display:grid; grid-template-columns:1fr auto; gap:40px; align-items:end; margin-top:34px; padding-bottom:46px; position:relative; }
.hero p.lead{ font-size:21px; color:color-mix(in srgb,#fff 88%,transparent); max-width:46ch; margin:0; }
.hero p.lead b{ color:#fff; font-weight:700; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; }

/* ---------- stats strip ---------- */
.stats{ background:var(--paper-2); border-bottom:1px solid var(--line); }
.stats .row{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; }
.stats .s{ padding:34px 30px; }
.stats .s + .s{ box-shadow:-1px 0 0 var(--line); }
.stats .s b{ font-family:var(--font-display); font-weight:900; font-size:clamp(30px,3.4vw,46px); letter-spacing:-0.03em; color:var(--teal); display:block; line-height:1; }
.stats .s span{ font-size:15px; color:var(--ink-2); display:block; margin-top:10px; }
@media (max-width:820px){ .stats .row{ grid-template-columns:1fr 1fr; } }

/* ---------- the idea / closed-book principle ---------- */
.idea-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:60px; align-items:center; }
.idea-grid .body p{ font-size:19px; color:var(--ink-2); }
.idea-grid .body p + p{ margin-top:16px; }
.idea-grid .body b{ color:var(--ink); font-weight:700; }
.principle-card{ background:var(--ink); color:#fff; border-radius:20px; padding:40px; position:relative; overflow:hidden; }
.principle-card .q{ font-family:var(--font-display); font-weight:900; font-size:clamp(26px,2.6vw,34px); letter-spacing:-0.02em; line-height:1.12; }
.principle-card .q .g{ color:var(--gold); }
.principle-card .ask{ margin-top:22px; padding:16px 18px; border-radius:12px; background:color-mix(in srgb,#fff 7%,transparent); border:1px solid color-mix(in srgb,#fff 14%,transparent); font-size:16px; color:color-mix(in srgb,#fff 88%,transparent); }
.principle-card .ask .who{ font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:var(--mint); display:block; margin-bottom:8px; }
.principle-card .foot{ margin-top:24px; display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:800; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,#fff 64%,transparent); }
.principle-card .foot .sq{ width:11px; height:11px; border-radius:3px; }

/* ---------- KB GROUNDING DIAGRAM (premium illustration) ---------- */
.kb-diagram{
  position:relative; color:#fff; border-radius:22px; padding:28px 28px 26px;
  background:
    radial-gradient(120% 90% at 80% -10%, color-mix(in srgb,var(--teal) 42%, var(--ink)) 0%, var(--ink) 58%);
  box-shadow:
    0 1px 0 0 color-mix(in srgb,#fff 14%,transparent) inset,
    0 40px 80px -44px rgba(28,43,39,.7),
    0 12px 28px -22px rgba(28,43,39,.5);
  overflow:hidden;
}
.kb-diagram::after{ content:""; position:absolute; right:-90px; top:-90px; width:260px; height:260px; border-radius:50%; background:color-mix(in srgb,#fff 6%,transparent); pointer-events:none; }
.kb-head{ position:relative; font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.16em; text-transform:uppercase; color:color-mix(in srgb,#fff 62%,transparent); display:flex; align-items:center; gap:9px; }
.kb-head .kb-dot{ width:8px; height:8px; border-radius:50%; background:var(--mint); box-shadow:0 0 0 4px color-mix(in srgb,var(--mint) 24%,transparent); }

.kb-tier{ display:flex; align-items:center; gap:14px; margin-top:16px; }
.kb-tier-lab{ font-family:var(--font-display); font-weight:800; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:color-mix(in srgb,#fff 52%,transparent); width:88px; flex:none; }
.kb-chips{ display:flex; gap:9px; flex:1; }
.kb-chip{ display:inline-flex; align-items:center; gap:9px; flex:1; font-family:var(--font-body); font-weight:600; font-size:13px; padding:11px 13px; border-radius:11px; background:color-mix(in srgb,#fff 7%,transparent); border:1px solid color-mix(in srgb,#fff 13%,transparent); box-shadow:0 1px 0 0 color-mix(in srgb,#fff 8%,transparent) inset; }
.kb-chip i{ width:10px; height:10px; border-radius:3px; flex:none; }

.kb-merge{ display:block; width:100%; height:42px; margin:2px 0 -4px; }
.kb-merge path{ fill:none; stroke:color-mix(in srgb,var(--mint) 75%,transparent); stroke-width:1.4; stroke-dasharray:4 5; opacity:.7; animation:kbflow 1.1s linear infinite; }
@keyframes kbflow{ to{ stroke-dashoffset:-18; } }

.kb-core{ display:flex; align-items:center; justify-content:center; gap:10px; margin:0 auto; width:max-content; font-family:var(--font-display); font-weight:800; font-size:13px; letter-spacing:.04em; color:#fff; padding:10px 20px; border-radius:100px; background:linear-gradient(180deg, var(--teal), var(--teal-d)); box-shadow:0 10px 24px -14px rgba(0,0,0,.6), 0 1px 0 0 color-mix(in srgb,#fff 22%,transparent) inset; }
.kb-core .kb-core-ic{ color:var(--gold); font-size:14px; }

.kb-answer{ margin-top:18px; padding:16px 18px; border-radius:14px; background:color-mix(in srgb,#fff 6%,transparent); border:1px solid color-mix(in srgb,#fff 13%,transparent); }
.kb-q-tag{ font-size:14px; color:color-mix(in srgb,#fff 90%,transparent); line-height:1.4; margin-bottom:14px; }
.kb-q-tag .who{ display:block; font-family:var(--font-display); font-weight:800; font-size:10px; letter-spacing:.16em; text-transform:uppercase; color:var(--mint); margin-bottom:7px; }
.kb-ans-row{ display:flex; align-items:center; gap:7px; margin-top:9px; }
.kb-ans-line{ height:8px; border-radius:5px; background:color-mix(in srgb,#fff 22%,transparent); }
.kb-ans-line.w1{ width:92%; } .kb-ans-line.w2{ width:54%; } .kb-ans-line.w3{ width:74%; }
.kb-ref{ display:inline-grid; place-items:center; min-width:18px; height:18px; padding:0 5px; border-radius:5px; background:color-mix(in srgb,var(--mint) 26%,transparent); color:#cfeee6; font-family:var(--font-display); font-weight:800; font-size:11px; }
.kb-conf{ display:flex; align-items:center; gap:10px; margin-top:14px; padding-top:13px; border-top:1px dashed color-mix(in srgb,#fff 16%,transparent); }
.kb-conf-lab{ font-family:var(--font-display); font-weight:800; font-size:10px; letter-spacing:.12em; text-transform:uppercase; color:color-mix(in srgb,#fff 52%,transparent); }
.kb-band{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.06em; text-transform:uppercase; padding:5px 11px; border-radius:100px; background:color-mix(in srgb,var(--mint) 22%,transparent); color:#bfe9df; }
.kb-band i{ width:7px; height:7px; border-radius:50%; background:currentColor; }

.kb-diagram .foot{ margin-top:20px; display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:color-mix(in srgb,#fff 60%,transparent); }
.kb-diagram .foot .sq{ width:11px; height:11px; border-radius:3px; }

/* pull quote / belief band (gold) */
.belief{ background:var(--gold); }
.belief blockquote{ margin:0; font-family:var(--font-display); font-weight:900; font-size:clamp(32px,4.4vw,60px); line-height:1.07; letter-spacing:-0.03em; color:var(--ink); max-width:20ch; }
.belief .src{ margin-top:24px; font-size:18px; color:color-mix(in srgb,var(--ink) 72%,transparent); max-width:60ch; }

/* ---------- 3 products grid ---------- */
.prods{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:54px; background:var(--line); border:1px solid var(--line); border-radius:18px; overflow:hidden; }
.prod-cell{ background:var(--paper); padding:38px 32px; transition:background .2s; display:flex; flex-direction:column; }
.prod-cell:hover{ background:var(--card); }
.prod-cell .no{ font-family:var(--font-display); font-weight:900; font-size:13px; letter-spacing:.08em; color:var(--ink-2); display:flex; align-items:center; gap:10px; }
.prod-cell .no .sq{ width:13px; height:13px; border-radius:3px; }
.prod-cell h3{ font-size:24px; margin:18px 0 0; }
.prod-cell p{ font-size:15.5px; color:var(--ink-2); margin:12px 0 0; }
.prod-cell .more{ margin-top:auto; padding-top:22px; font-family:var(--font-display); font-weight:700; font-size:15px; color:var(--teal); display:inline-flex; align-items:center; gap:7px; }
@media (max-width:900px){ .prods{ grid-template-columns:1fr; } }

/* ---------- proof points (4-up on ink) ---------- */
.proof{ background:var(--ink); color:#fff; }
.proof .kicker{ color:var(--gold); } .proof .kicker::before{ background:var(--gold); }
.proof .sec-head h2{ color:#fff; } .proof .sec-head p{ color:color-mix(in srgb,#fff 74%,transparent); }
.proof-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; margin-top:52px; }
.pp{ background:color-mix(in srgb,#fff 6%,transparent); border:1px solid color-mix(in srgb,#fff 14%,transparent); border-radius:14px; padding:28px 26px; }
.pp .big{ font-family:var(--font-display); font-weight:900; font-size:40px; letter-spacing:-0.03em; line-height:1; }
.pp.c-gold .big{ color:var(--gold); } .pp.c-coral .big{ color:var(--coral); } .pp.c-mint .big{ color:var(--mint); } .pp.c-teal .big{ color:#7fd1bd; }
.pp h4{ font-size:17px; margin:14px 0 0; color:#fff; }
.pp p{ font-size:13.5px; color:color-mix(in srgb,#fff 68%,transparent); margin:9px 0 0; }
.pp .cite{ font-family:var(--font-display); font-weight:800; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; color:color-mix(in srgb,#fff 44%,transparent); margin-top:14px; display:block; }
.proof .coach{ margin-top:24px; background:color-mix(in srgb,var(--teal) 26%,transparent); border:1px solid color-mix(in srgb,var(--mint) 40%,transparent); border-radius:16px; padding:32px 36px; display:flex; gap:34px; align-items:center; flex-wrap:wrap; }
.proof .coach .q{ font-family:var(--font-display); font-weight:900; font-size:clamp(22px,2.4vw,30px); letter-spacing:-0.02em; line-height:1.12; max-width:22ch; }
.proof .coach .q .y{ color:var(--gold); }
.proof .coach p{ font-size:15px; color:color-mix(in srgb,#fff 78%,transparent); max-width:42ch; flex:1; min-width:260px; }
@media (max-width:900px){ .proof-grid{ grid-template-columns:1fr 1fr; } }

/* ---------- CTA band ---------- */
.cta{ background:var(--teal); color:#fff; padding:108px 0; text-align:center; position:relative; overflow:hidden; }
.cta .stripe{ position:absolute; top:0; left:0; right:0; }
.cta h2{ font-size:clamp(36px,4.8vw,68px); font-weight:900; letter-spacing:-0.035em; max-width:18ch; margin:0 auto; }
.cta p{ font-size:20px; color:color-mix(in srgb,#fff 86%,transparent); margin:20px auto 0; max-width:48ch; }
.cta .row{ display:flex; gap:14px; justify-content:center; margin-top:34px; flex-wrap:wrap; }

/* ============================================================
   INTERACTIVE CHAT DEMO
   ============================================================ */
.chat-shell{ display:grid; grid-template-columns:1.55fr 1fr; gap:0; background:var(--card); border:1px solid var(--line); border-radius:20px; overflow:hidden; box-shadow:0 30px 70px -50px rgba(28,43,39,.5); }
.chat-main{ display:flex; flex-direction:column; min-height:560px; }
.chat-top{ display:flex; align-items:center; justify-content:space-between; gap:14px; padding:16px 22px; border-bottom:1px solid var(--line); background:var(--paper); }
.chat-top .who{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; font-size:14px; letter-spacing:.04em; }
.chat-top .who .av{ width:30px; height:30px; border-radius:8px; background:var(--teal); display:grid; place-items:center; }
.chat-top .who .av span{ display:block; width:13px; height:13px; }
.chat-top .badge{ font-family:var(--font-display); font-weight:800; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); display:inline-flex; align-items:center; gap:7px; }
.chat-top .badge .d{ width:7px; height:7px; border-radius:50%; background:var(--mint); }

.chat-thread{ flex:1; overflow-y:auto; padding:26px 24px; display:flex; flex-direction:column; gap:20px; background:var(--paper); }
.chat-thread::-webkit-scrollbar{ width:8px; } .chat-thread::-webkit-scrollbar-thumb{ background:var(--line); border-radius:8px; }

.msg{ max-width:90%; }
.msg.user{ align-self:flex-end; background:var(--teal); color:#fff; padding:13px 18px; border-radius:16px 16px 4px 16px; font-size:15.5px; font-weight:500; box-shadow:0 8px 20px -14px rgba(31,110,88,.7); }
.msg.bot{ align-self:flex-start; width:100%; max-width:100%; }

/* thinking trace */
.trace{ display:flex; flex-direction:column; gap:9px; margin-bottom:6px; }
.trace .step{ display:flex; align-items:center; gap:11px; font-family:var(--font-display); font-weight:800; font-size:11.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); opacity:.4; transition:opacity .3s, color .3s; }
.trace .step.active{ opacity:1; color:var(--teal); }
.trace .step.done{ opacity:1; color:var(--ink-2); }
.trace .step .ic{ width:18px; height:18px; border-radius:50%; border:2px solid currentColor; display:grid; place-items:center; flex:none; position:relative; }
.trace .step.active .ic{ border-style:dashed; animation:spin 1.2s linear infinite; }
.trace .step.done .ic{ background:var(--teal); border-color:var(--teal); }
.trace .step.done .ic::after{ content:"✓"; color:#fff; font-size:10px; font-family:var(--font-body); }
@keyframes spin{ to{ transform:rotate(360deg); } }
.trace .note{ font-size:13px; color:var(--ink-2); font-family:var(--font-body); font-weight:400; letter-spacing:0; text-transform:none; margin-left:6px; opacity:.8; }

/* bot answer */
.answer{ background:var(--card); border:1px solid var(--line); border-radius:4px 16px 16px 16px; padding:20px 22px; font-size:15.5px; line-height:1.62; }
.answer p{ margin:0; } .answer p + p{ margin-top:12px; }
.answer .cite-ref{ display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; padding:0 5px; margin:0 1px; border-radius:5px; background:color-mix(in srgb,var(--teal) 16%,transparent); color:var(--teal-d); font-family:var(--font-display); font-weight:800; font-size:11px; vertical-align:2px; cursor:pointer; transition:background .15s; }
.answer .cite-ref:hover{ background:var(--teal); color:#fff; }
.answer .conf{ display:flex; align-items:center; gap:10px; margin-top:18px; padding-top:16px; border-top:1px dashed var(--line); }
.conf-label{ font-family:var(--font-display); font-weight:800; font-size:10.5px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); }
.conf-band{ display:inline-flex; align-items:center; gap:7px; font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.1em; text-transform:uppercase; padding:5px 11px; border-radius:100px; }
.conf-band.high{ background:color-mix(in srgb,var(--teal) 16%,transparent); color:var(--teal-d); }
.conf-band.medium{ background:color-mix(in srgb,var(--gold) 30%,transparent); color:#8a6d05; }
.conf-band.low{ background:color-mix(in srgb,var(--coral) 26%,transparent); color:var(--coral-d); }
.conf-band .dot{ width:7px; height:7px; border-radius:50%; background:currentColor; }

.followups{ display:flex; flex-direction:column; gap:9px; margin-top:14px; }
.followup{ text-align:left; background:var(--card); border:1px solid var(--line); border-radius:11px; padding:12px 15px; font-family:var(--font-display); font-weight:600; font-size:14.5px; color:var(--ink); cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:12px; transition:border-color .15s, transform .15s, color .15s; }
.followup:hover{ border-color:var(--teal); color:var(--teal); transform:translateX(2px); }
.followup .arr{ color:var(--teal); transition:transform .2s; } .followup:hover .arr{ transform:translateX(3px); }

/* composer */
.composer{ border-top:1px solid var(--line); padding:16px 18px; background:var(--card); }
.composer .suggest{ display:flex; gap:8px; flex-wrap:wrap; margin-bottom:12px; }
.composer .chip{ font-family:var(--font-body); font-weight:600; font-size:13px; padding:7px 13px; border-radius:100px; border:1px solid var(--line); background:var(--paper); color:var(--ink-2); cursor:pointer; transition:all .15s; }
.composer .chip:hover{ border-color:var(--teal); color:var(--teal); }
.composer form{ display:flex; gap:10px; align-items:flex-end; }
.composer textarea{ flex:1; resize:none; font-family:var(--font-body); font-size:15.5px; color:var(--ink); background:var(--paper); border:1.5px solid var(--line); border-radius:13px; padding:13px 16px; min-height:50px; max-height:120px; line-height:1.45; transition:border-color .15s, box-shadow .15s; }
.composer textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 14%,transparent); }
.composer .send{ width:50px; height:50px; flex:none; border:0; border-radius:13px; background:var(--teal); color:#fff; font-size:20px; cursor:pointer; display:grid; place-items:center; transition:background .2s, transform .15s; }
.composer .send:hover{ background:var(--teal-d); transform:translateY(-1px); }
.composer .send:disabled{ background:var(--line); color:var(--ink-2); cursor:not-allowed; transform:none; }

/* sources rail */
.chat-rail{ background:var(--paper-2); border-left:1px solid var(--line); padding:22px 22px; overflow-y:auto; }
.chat-rail .rail-head{ font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-2); display:flex; align-items:center; gap:8px; }
.chat-rail .rail-head .l{ flex:1; height:1px; background:var(--line); }
.rail-empty{ margin-top:20px; font-size:14px; color:var(--ink-2); line-height:1.5; }
.rail-empty .ic{ width:42px; height:42px; border-radius:11px; background:var(--card); border:1px solid var(--line); display:grid; place-items:center; margin-bottom:14px; }
.source-card{ background:var(--card); border:1px solid var(--line); border-radius:13px; padding:15px 16px; margin-top:13px; cursor:pointer; transition:border-color .15s, transform .15s, box-shadow .2s; opacity:0; transform:translateY(8px); }
.source-card.in{ opacity:1; transform:none; }
.source-card:hover{ border-color:var(--teal); box-shadow:0 14px 30px -24px rgba(28,43,39,.4); }
.source-card .doc{ font-family:var(--font-display); font-weight:800; font-size:14.5px; letter-spacing:-0.01em; display:flex; align-items:center; gap:9px; }
.source-card .doc .tag{ width:9px; height:9px; border-radius:3px; flex:none; }
.source-card .passage{ font-size:13px; color:var(--ink-2); margin-top:9px; line-height:1.5; }
.source-card .meta{ display:flex; align-items:center; justify-content:space-between; margin-top:12px; }
.source-card .cited{ font-family:var(--font-display); font-weight:800; font-size:9.5px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); }
.score{ display:inline-flex; align-items:center; gap:7px; }
.score .bar{ width:46px; height:5px; border-radius:3px; background:var(--line); overflow:hidden; }
.score .bar i{ display:block; height:100%; background:var(--teal); border-radius:3px; }
.score b{ font-family:var(--font-display); font-weight:900; font-size:13px; color:var(--teal-d); }

@media (max-width:880px){ .chat-shell{ grid-template-columns:1fr; } .chat-rail{ border-left:0; border-top:1px solid var(--line); } .chat-main{ min-height:480px; } }

/* ---------- generic numbered feature row (how-it-works) ---------- */
.flow-block{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:56px; align-items:start; padding:60px 0; border-bottom:1px solid var(--line); }
.flow-block:last-of-type{ border-bottom:0; }
.flow-block .left .tagn{ display:flex; align-items:center; gap:14px; }
.flow-block .left .sq{ width:34px; height:34px; border-radius:7px; flex:none; }
.flow-block .left .no{ font-family:var(--font-display); font-weight:900; font-size:15px; color:var(--ink-2); letter-spacing:.08em; }
.flow-block .left h2{ font-size:clamp(28px,3.2vw,40px); font-weight:900; letter-spacing:-0.025em; margin:18px 0 0; }
.flow-block .left p{ font-size:17px; color:var(--ink-2); margin:18px 0 0; }
.flow-block .formats, .idea-grid .formats{ display:flex; gap:8px; flex-wrap:wrap; margin-top:22px; }
.flow-block .formats span, .idea-grid .formats span{ font-size:13px; padding:7px 14px; border-radius:100px; background:var(--paper-2); border:1px solid var(--line); color:var(--ink-2); }
.feat{ list-style:none; margin:0; padding:0; }
.feat li{ display:flex; gap:16px; align-items:flex-start; padding:18px 0; border-top:1px solid var(--line); }
.feat li:last-child{ border-bottom:1px solid var(--line); }
.feat li .dot{ width:10px; height:10px; border-radius:3px; margin-top:7px; flex:none; }
.feat li b{ font-family:var(--font-display); font-size:17px; display:block; }
.feat li span{ font-size:15px; color:var(--ink-2); }
@media (max-width:900px){ .flow-block{ grid-template-columns:1fr; gap:28px; } }

/* trace stepper (how it works visual) */
.stepper{ display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-top:18px; }
.stepper .st{ background:var(--paper-2); border:1px solid var(--line); border-radius:12px; padding:18px 16px; }
.stepper .st .n{ font-family:var(--font-display); font-weight:900; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--teal); }
.stepper .st b{ font-family:var(--font-display); font-size:15px; display:block; margin-top:9px; }
.stepper .st span{ font-size:12.5px; color:var(--ink-2); display:block; margin-top:5px; }
@media (max-width:680px){ .stepper{ grid-template-columns:1fr 1fr; } }

/* artifact catalogue chips */
.catalogue{ display:flex; gap:10px; flex-wrap:wrap; margin-top:8px; }
.catalogue span{ font-family:var(--font-display); font-weight:700; font-size:14px; padding:11px 18px; border-radius:11px; background:var(--card); border:1px solid var(--line); }
.catalogue span .c{ color:var(--coral-d); }

/* trainer cockpit (3 column x-ray) */
.cockpit{ display:grid; grid-template-columns:repeat(3,1fr); gap:12px; margin-top:8px; }
.cockpit .col{ background:var(--paper-2); border:1px solid var(--line); border-radius:14px; padding:18px; }
.cockpit .col h5{ font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-2); margin:0 0 12px; display:flex; align-items:center; gap:8px; }
.cockpit .col h5 .n{ width:20px; height:20px; border-radius:6px; background:var(--teal); color:#fff; display:grid; place-items:center; font-size:11px; }
.cockpit .src-row{ background:var(--card); border:1px solid var(--line); border-radius:10px; padding:11px 13px; margin-bottom:9px; font-size:13.5px; }
.cockpit .src-row .t{ font-family:var(--font-display); font-weight:700; }
.cockpit .src-row .m{ font-size:11px; color:var(--ink-2); margin-top:4px; font-family:var(--font-display); font-weight:700; letter-spacing:.04em; }
.cockpit .src-row.boost{ border-color:color-mix(in srgb,var(--mint) 60%,transparent); }
@media (max-width:780px){ .cockpit{ grid-template-columns:1fr; } }

/* ---------- FOR WHO ---------- */
.who-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:54px; }
.who-card{ background:var(--card); border:1px solid var(--line); border-radius:18px; padding:34px 32px; display:flex; flex-direction:column; transition:transform .2s, box-shadow .25s; }
.who-card:hover{ transform:translateY(-5px); box-shadow:0 28px 54px -34px rgba(28,43,39,.42); }
.who-card .bar{ height:8px; width:56px; border-radius:3px; }
.who-card h3{ font-size:24px; margin:20px 0 0; }
.who-card .role{ font-family:var(--font-display); font-weight:700; font-size:14px; color:var(--teal); margin-top:6px; }
.who-card p{ font-size:15.5px; color:var(--ink-2); margin:14px 0 0; }
.who-card ul{ list-style:none; margin:18px 0 0; padding:0; display:flex; flex-direction:column; gap:10px; }
.who-card ul li{ font-size:14.5px; color:var(--ink-2); display:flex; gap:11px; align-items:flex-start; }
.who-card ul li .tick{ color:var(--teal); font-weight:800; flex:none; }
.who-card .more{ margin-top:auto; padding-top:24px; }
@media (max-width:900px){ .who-grid{ grid-template-columns:1fr; } }

/* benefit row (who benefits) */
.bene{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:40px; background:var(--line); border:1px solid var(--line); border-radius:16px; overflow:hidden; }
.bene .b{ background:var(--paper); padding:30px 28px; }
.bene .b .ttl{ font-family:var(--font-display); font-weight:900; font-size:18px; display:flex; align-items:center; gap:10px; }
.bene .b .ttl .sq{ width:12px; height:12px; border-radius:3px; }
.bene .b p{ font-size:14.5px; color:var(--ink-2); margin-top:12px; }
@media (max-width:820px){ .bene{ grid-template-columns:1fr; } }

/* ---------- PRICING ---------- */
.price-note{ background:color-mix(in srgb,var(--gold) 22%,#fff); border:1px solid color-mix(in srgb,var(--gold) 55%,var(--line)); border-radius:14px; padding:18px 22px; font-size:15px; color:var(--ink-2); display:flex; gap:13px; align-items:flex-start; margin-top:38px; }
.price-note b{ color:var(--ink); }
.price-grid{ display:grid; grid-template-columns:1fr 1fr; gap:22px; margin-top:30px; }
.price-card{ background:var(--card); border:1px solid var(--line); border-radius:18px; padding:34px 32px; display:flex; flex-direction:column; }
.price-card.feature{ border:1.5px solid var(--teal); box-shadow:0 30px 60px -44px rgba(31,110,88,.5); position:relative; }
.price-card .tier{ font-family:var(--font-display); font-weight:800; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); display:flex; align-items:center; gap:9px; }
.price-card .flag{ font-family:var(--font-display); font-weight:800; font-size:10.5px; letter-spacing:.1em; text-transform:uppercase; background:var(--teal); color:#fff; padding:5px 11px; border-radius:100px; }
.price-card .amt{ font-family:var(--font-display); font-weight:900; font-size:46px; letter-spacing:-0.03em; margin:18px 0 0; line-height:1; }
.price-card .amt small{ font-size:17px; font-weight:700; color:var(--ink-2); letter-spacing:0; }
.price-card .sub{ font-size:14.5px; color:var(--ink-2); margin-top:8px; }
.price-card p.desc{ font-size:15px; color:var(--ink-2); margin:18px 0 0; }
.price-card ul{ list-style:none; margin:20px 0 0; padding:0; display:flex; flex-direction:column; gap:11px; }
.price-card ul li{ font-size:14.5px; display:flex; gap:11px; align-items:flex-start; color:var(--ink-2); }
.price-card ul li .tick{ color:var(--teal); font-weight:800; flex:none; }
.price-card .act{ margin-top:auto; padding-top:26px; }
/* site licence tiers */
.tiers{ display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:22px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; }
.tiers .ti{ background:var(--paper); padding:22px 20px; }
.tiers .ti .lab{ font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-2); }
.tiers .ti .v{ font-family:var(--font-display); font-weight:900; font-size:26px; letter-spacing:-0.02em; color:var(--teal); margin-top:8px; }
@media (max-width:820px){ .price-grid{ grid-template-columns:1fr; } .tiers{ grid-template-columns:1fr; } }

/* ---------- SECURITY ---------- */
.sec-cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:54px; }
.sec-card{ background:var(--card); border:1px solid var(--line); border-radius:18px; padding:32px 30px; }
.sec-card .n{ font-family:var(--font-display); font-weight:900; font-size:12px; letter-spacing:.12em; text-transform:uppercase; color:var(--teal); }
.sec-card h3{ font-size:22px; margin:14px 0 0; max-width:14ch; }
.sec-card p{ font-size:15px; color:var(--ink-2); margin:14px 0 0; }
.sec-card .bar{ height:8px; width:44px; border-radius:3px; margin-bottom:4px; }
@media (max-width:900px){ .sec-cards{ grid-template-columns:1fr; } }

/* server map table */
.servermap{ width:100%; border-collapse:collapse; margin-top:30px; background:var(--card); border:1px solid var(--line); border-radius:16px; overflow:hidden; }
.servermap th, .servermap td{ text-align:left; padding:18px 22px; border-bottom:1px solid var(--line); font-size:15px; }
.servermap th{ font-family:var(--font-display); font-weight:800; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--ink-2); background:var(--paper-2); }
.servermap tr:last-child td{ border-bottom:0; }
.servermap td:first-child{ font-weight:600; }
.servermap .where{ font-family:var(--font-display); font-weight:700; color:var(--ink); }
.servermap .eu{ display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:800; font-size:12px; color:var(--teal-d); }
.servermap .eu .d{ width:8px; height:8px; border-radius:50%; background:var(--mint); }
@media (max-width:680px){ .servermap th:nth-child(2), .servermap td:nth-child(2){ display:none; } }

/* ---------- LOGIN (split screen) ---------- */
.auth-split{ min-height:100vh; display:grid; grid-template-columns:1.05fr 1fr; }

/* left brand panel */
.auth-aside{ position:relative; background:var(--teal); color:#fff; overflow:hidden; display:flex; }
.auth-aside::after{ content:""; position:absolute; right:-160px; bottom:-160px; width:460px; height:460px; border-radius:50%; background:color-mix(in srgb,#fff 7%,transparent); }
.auth-aside .stripe{ position:absolute; top:0; left:0; right:0; display:flex; height:12px; z-index:2; }
.auth-aside .stripe i{ flex:1; }
.auth-aside-in{ position:relative; z-index:1; display:flex; flex-direction:column; padding:52px 56px; width:100%; max-width:560px; margin-left:auto; }
.auth-aside .brand-lock .prod{ background:color-mix(in srgb,#fff 16%,transparent); color:#fff; font-family:var(--font-display); font-weight:800; font-size:14px; letter-spacing:.04em; padding:5px 11px; border-radius:8px; line-height:1; }
.auth-aside .aside-body{ margin-top:auto; padding:48px 0; }
.auth-aside .eyebrow{ font-size:13px; color:var(--gold); display:inline-flex; align-items:center; gap:10px; text-transform:uppercase; letter-spacing:.14em; font-weight:700; }
.auth-aside .eyebrow::before{ content:""; width:28px; height:3px; background:var(--gold); border-radius:2px; }
.auth-aside h2{ font-size:clamp(28px,3vw,40px); font-weight:900; letter-spacing:-0.03em; line-height:1.05; margin:18px 0 0; max-width:15ch; }
.auth-aside p{ font-size:17px; line-height:1.55; color:color-mix(in srgb,#fff 86%,transparent); margin:18px 0 0; max-width:46ch; }
.auth-aside p b{ color:#fff; font-weight:700; }
.auth-aside .aside-list{ list-style:none; margin:26px 0 0; padding:0; display:flex; flex-direction:column; gap:13px; }
.auth-aside .aside-list li{ display:flex; align-items:center; gap:13px; font-size:15px; color:color-mix(in srgb,#fff 90%,transparent); }
.auth-aside .aside-list .sq{ width:13px; height:13px; border-radius:4px; flex:none; }
.auth-aside .aside-foot{ font-family:var(--font-display); font-weight:700; font-size:12px; letter-spacing:.1em; text-transform:uppercase; color:color-mix(in srgb,#fff 78%,transparent); display:flex; align-items:center; gap:9px; margin:0; }
.auth-aside .aside-foot .d{ width:8px; height:8px; border-radius:50%; background:var(--mint); }

/* right form panel */
.auth-main{ display:grid; place-items:center; background:var(--paper); padding:40px 28px; }
.auth-card{ width:100%; max-width:400px; }
.auth-card h1{ font-size:32px; font-weight:900; letter-spacing:-0.025em; }
.auth-card .sub{ font-size:15.5px; color:var(--ink-2); margin-top:8px; }
.auth-card .field{ margin-top:16px; }
.auth-card label{ display:block; font-family:var(--font-display); font-weight:700; font-size:13.5px; margin-bottom:8px; }
.auth-card input[type=email], .auth-card input[type=password]{ width:100%; font-family:var(--font-body); font-size:16px; color:var(--ink); background:var(--card); border:1.5px solid var(--line); border-radius:12px; padding:13px 16px; transition:border-color .15s, box-shadow .15s; }
.auth-card input:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 14%,transparent); }
.auth-card .field.bad input{ border-color:var(--coral-d); }
.auth-card .row{ display:flex; align-items:center; justify-content:space-between; margin-top:14px; font-size:14px; gap:14px; }
.auth-card .row a{ color:var(--teal); font-weight:600; text-decoration:none; white-space:nowrap; }
.auth-card .remember{ font-family:var(--font-body); font-weight:500; font-size:14px; color:var(--ink-2); display:inline-flex; align-items:center; gap:8px; margin:0; cursor:pointer; white-space:nowrap; }
.auth-card .remember input{ width:auto; accent-color:var(--teal); }
.auth-card .submit{ width:100%; margin-top:20px; justify-content:center; }
.auth-card .or{ display:flex; align-items:center; gap:14px; margin:22px 0; color:var(--ink-2); font-size:12px; font-family:var(--font-display); font-weight:700; letter-spacing:.08em; text-transform:uppercase; }
.auth-card .or::before, .auth-card .or::after{ content:""; flex:1; height:1px; background:var(--line); }
.sso{ display:flex; flex-direction:column; gap:11px; }
.sso.compact{ flex-direction:row; gap:11px; }
.sso button{ flex:1; display:flex; align-items:center; justify-content:center; gap:10px; font-family:var(--font-display); font-weight:700; font-size:14.5px; color:var(--ink); background:var(--card); border:1.5px solid var(--line); border-radius:12px; padding:13px 14px; cursor:pointer; transition:border-color .15s, background .15s; }
.sso button:hover{ border-color:var(--teal); background:#fff; }
.sso button .g{ width:20px; height:20px; border-radius:5px; display:grid; place-items:center; font-family:var(--font-display); font-weight:900; font-size:11px; color:#fff; flex:none; }
.auth-card .auth-foot{ text-align:center; margin-top:22px; font-size:14px; color:var(--ink-2); }
.auth-card .auth-foot a{ color:var(--teal); font-weight:600; text-decoration:none; }

@media (max-width:860px){
  .auth-split{ grid-template-columns:1fr; }
  .auth-aside{ display:none; }
  .auth-main{ min-height:100vh; }
}

/* ---------- contact (reuse from BBE) ---------- */
.contact{ padding:76px 0 104px; }
.c-grid{ display:grid; grid-template-columns:1.25fr 0.75fr; gap:60px; align-items:start; }
form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.field{ margin-top:20px; }
.field label{ display:block; font-family:var(--font-display); font-weight:700; font-size:14px; margin-bottom:8px; }
.field label .req{ color:var(--coral-d); }
.field input, .field select, .field textarea{ width:100%; font-family:var(--font-body); font-size:16px; color:var(--ink); background:var(--card); border:1.5px solid var(--line); border-radius:11px; padding:14px 16px; transition:border-color .15s, box-shadow .15s; }
.field textarea{ resize:vertical; min-height:140px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--teal); box-shadow:0 0 0 4px color-mix(in srgb,var(--teal) 16%,transparent); }
.field.bad input, .field.bad textarea{ border-color:var(--coral-d); }
.err{ color:var(--coral-d); font-size:13px; margin-top:6px; display:none; }
.field.bad .err{ display:block; }
.interest{ display:flex; flex-wrap:wrap; gap:10px; margin-top:8px; }
.interest input{ position:absolute; opacity:0; pointer-events:none; }
.interest label{ margin:0; cursor:pointer; font-family:var(--font-body); font-weight:600; font-size:14px; padding:9px 16px; border-radius:100px; border:1.5px solid var(--line); background:var(--card); transition:all .15s; }
.interest input:checked + label{ background:var(--ink); color:#fff; border-color:var(--ink); }
form .submit{ margin-top:28px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.note-small{ font-size:13px; color:var(--ink-2); }
.success{ display:none; background:color-mix(in srgb,var(--mint) 16%,#fff); border:1.5px solid var(--mint); border-radius:16px; padding:36px; }
.success.show{ display:block; }
.success .ic{ width:54px; height:54px; border-radius:50%; background:var(--teal); color:#fff; display:grid; place-items:center; font-size:26px; }
.success h3{ font-size:24px; margin:18px 0 0; }
.success p{ color:var(--ink-2); margin:10px 0 0; }
form.hide{ display:none; }
.side .box{ background:var(--card); border:1px solid var(--line); border-radius:16px; padding:28px; margin-bottom:18px; }
.side h4{ font-family:var(--font-display); font-size:14px; text-transform:uppercase; letter-spacing:.12em; color:var(--teal); margin:0 0 16px; }
.side a.mail{ font-family:var(--font-display); font-weight:800; font-size:19px; color:var(--ink); text-decoration:none; word-break:break-all; }
.side a.mail:hover{ color:var(--teal); }
.side .next{ list-style:none; margin:0; padding:0; counter-reset:n; }
.side .next li{ counter-increment:n; display:flex; gap:14px; padding:12px 0; border-top:1px solid var(--line); font-size:15px; color:var(--ink-2); }
.side .next li:first-child{ border-top:0; padding-top:0; }
.side .next li::before{ content:counter(n); font-family:var(--font-display); font-weight:900; font-size:13px; color:#fff; background:var(--coral); width:24px; height:24px; border-radius:7px; display:grid; place-items:center; flex:none; }
@media (max-width:900px){ .c-grid{ grid-template-columns:1fr; gap:40px; } form .row2{ grid-template-columns:1fr; } }
