/* ============================================================
   BonusGroup — group marketing site
   Self-contained, no dependencies. Bonus-family design system.
   To change where every "Book a call" goes: edit BOOK_URL in the
   <script> at the bottom of this file (one line).
   ============================================================ */

:root{
  --ink:#14132a;
  --ink-2:#2b2945;
  --muted:#6b6980;
  --line:#e9e8f0;
  --canvas:#f4f3f8;
  --paper:#ffffff;
  --indigo:#5b54c9;
  --indigo-dark:#4d46b8;
  --violet:#6d5efc;
  --soft:#ece9fb;
  --teal:#0f9e75;
  --amber:#ba7517;
  --radius:18px;
  --radius-sm:12px;
  --maxw:1140px;
  --shadow-sm:0 1px 2px rgba(20,19,42,.04), 0 4px 16px rgba(20,19,42,.05);
  --shadow-md:0 12px 40px rgba(43,41,69,.10);
  --shadow-lg:0 28px 70px rgba(43,41,69,.16);
  --grad:linear-gradient(120deg,#5b54c9 0%,#6d5efc 100%);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink);
  background:var(--paper);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

h1,h2,h3{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:500;line-height:1.08;letter-spacing:-.01em;margin:0}
h1{font-size:clamp(2.5rem,5.4vw,4.2rem)}
h2{font-size:clamp(1.9rem,3.6vw,2.9rem)}
h3{font-size:1.18rem;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:600;letter-spacing:-.01em;line-height:1.3}
p{margin:0}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
.eyebrow{
  font-size:.72rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--indigo);margin:0 0 14px;
}
.lede{font-size:1.13rem;color:var(--muted);max-width:60ch}
.section{padding:96px 0}
.section--tight{padding:72px 0}

/* buttons */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;justify-content:center;
  font-weight:600;font-size:.97rem;border-radius:999px;padding:.85rem 1.5rem;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,border-color .2s;
  white-space:nowrap;
}
.btn--primary{background:var(--ink);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:#0d0c1f}
.btn--accent{background:var(--grad);color:#fff;box-shadow:0 8px 24px rgba(91,84,201,.32)}
.btn--accent:hover{transform:translateY(-2px);box-shadow:0 14px 34px rgba(91,84,201,.42)}
.btn--ghost{background:#fff;color:var(--ink);border-color:var(--line)}
.btn--ghost:hover{border-color:#cfcae6;transform:translateY(-2px)}
.btn--light{background:#fff;color:var(--ink)}
.btn--light:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--lg{padding:1rem 1.8rem;font-size:1.02rem}
.arrowlink{display:inline-flex;align-items:center;gap:.4rem;font-weight:600;color:var(--indigo)}
.arrowlink .ar{transition:transform .18s ease}
.arrowlink:hover .ar{transform:translateX(4px)}

/* skip link */
.skip{position:absolute;left:-9999px;top:0;background:var(--ink);color:#fff;padding:10px 16px;border-radius:0 0 8px 0;z-index:200}
.skip:focus{left:0}
:focus-visible{outline:3px solid var(--violet);outline-offset:2px;border-radius:6px}

/* ---------- logo mark ---------- */
.mark{
  width:32px;height:32px;border-radius:9px;background:var(--grad);
  display:grid;place-items:center;color:#fff;font-weight:700;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:1.05rem;flex:none;
  box-shadow:0 4px 12px rgba(91,84,201,.35);
}
.mark--sm{width:26px;height:26px;border-radius:7px;font-size:.85rem}
.brand{display:flex;align-items:center;gap:.6rem;font-weight:700;font-size:1.12rem;letter-spacing:-.02em}
.brand .b-rest{color:var(--ink)}

/* ---------- header ---------- */
header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.82);backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:68px}
.nav-links{display:flex;align-items:center;gap:30px}
.nav-links a{font-size:.94rem;font-weight:500;color:var(--ink-2);transition:color .15s}
.nav-links a:hover{color:var(--indigo)}
.nav-cta{display:flex;align-items:center;gap:14px}
.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:10px;width:42px;height:40px;cursor:pointer;align-items:center;justify-content:center}
.menu-btn span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
.menu-btn span::before{top:-6px}.menu-btn span::after{top:6px}

/* ---------- hero ---------- */
.hero{position:relative;overflow:hidden;padding:64px 0 56px;background:
  radial-gradient(1100px 520px at 78% -8%, #efeafe 0%, rgba(239,234,254,0) 60%),
  radial-gradient(760px 420px at -5% 12%, #f1f7ff 0%, rgba(241,247,255,0) 55%);}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{margin-bottom:22px}
.hero h1 em{font-style:italic;color:var(--indigo)}
.hero .lede{font-size:1.18rem;margin-bottom:30px;max-width:42ch}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.hero-note{font-size:.9rem;color:var(--muted);display:flex;align-items:center;gap:.5rem}
.hero-note .dot{width:7px;height:7px;border-radius:50%;background:var(--teal);flex:none;box-shadow:0 0 0 4px rgba(15,158,117,.14)}

/* constellation signature */
.constellation{position:relative;height:420px}
.constellation .field{position:absolute;inset:0;background:var(--paper);border:1px solid var(--line);border-radius:24px;box-shadow:var(--shadow-md);overflow:hidden}
.constellation .field::before{content:"";position:absolute;inset:0;background-image:radial-gradient(rgba(91,84,201,.07) 1px,transparent 1px);background-size:22px 22px;opacity:.6}
.cline{position:absolute;inset:0;width:100%;height:100%}
.cline line{stroke:#cfc9ee;stroke-width:1.4;stroke-dasharray:3 5;opacity:.9}
.node{position:absolute;transform:translate(-50%,-50%);background:#fff;border:1px solid var(--line);border-radius:12px;padding:.5rem .7rem;font-size:.8rem;font-weight:600;color:var(--ink-2);box-shadow:var(--shadow-sm);display:flex;align-items:center;gap:.45rem;white-space:nowrap;transition:transform .2s ease,box-shadow .2s ease;animation:floaty 7s ease-in-out infinite}
.node:hover{transform:translate(-50%,-50%) scale(1.05);box-shadow:var(--shadow-md);z-index:5}
.node .pip{width:8px;height:8px;border-radius:3px;background:var(--indigo)}
.node--flow .pip{background:var(--violet)}
.node--books .pip{background:var(--indigo)}
.node--data .pip{background:var(--teal)}
.node--host .pip{background:#3b82f6}
.node--web .pip{background:var(--amber)}
.node--shop .pip{background:#d4537e}
.node-core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:96px;height:96px;border-radius:24px;background:var(--grad);display:grid;place-items:center;color:#fff;text-align:center;box-shadow:0 18px 40px rgba(91,84,201,.4);z-index:6}
.node-core b{display:block;font-size:1.7rem;font-weight:700;line-height:1}
.node-core small{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;opacity:.9;margin-top:3px;display:block}
@keyframes floaty{0%,100%{translate:0 0}50%{translate:0 -6px}}
.node--n2{animation-delay:-1s}.node--n3{animation-delay:-2s}.node--n4{animation-delay:-3s}.node--n5{animation-delay:-4s}.node--n6{animation-delay:-5s}

/* trust strip */
.trust{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--canvas)}
.trust-row{display:flex;flex-wrap:wrap;gap:14px 34px;justify-content:center;padding:20px 0;font-size:.88rem;color:var(--ink-2);font-weight:500}
.trust-row span{display:flex;align-items:center;gap:.5rem}
.trust-row span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--indigo);opacity:.7}

/* section heads */
.shead{max-width:62ch;margin-bottom:48px}
.shead h2{margin-bottom:16px}

/* what we do */
.do{background:var(--paper)}
.do-statement{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:400;font-size:clamp(1.5rem,2.7vw,2.05rem);line-height:1.34;letter-spacing:-.01em;max-width:24ch}
.do-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:54px;align-items:start}
.do-grid p{color:var(--muted);margin-bottom:16px;font-size:1.05rem}
.do-grid p:last-child{margin-bottom:0}

/* products */
.products{background:var(--canvas)}
.flagship{display:grid;grid-template-columns:1.05fr .95fr;gap:0;background:var(--paper);border:1px solid var(--line);border-radius:24px;overflow:hidden;box-shadow:var(--shadow-md);margin-bottom:26px}
.flagship-body{padding:44px}
.tagpill{display:inline-flex;align-items:center;gap:.45rem;font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--indigo);background:var(--soft);padding:.4rem .75rem;border-radius:999px;margin-bottom:20px}
.flagship h3{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:500;font-size:1.9rem;line-height:1.12;margin:6px 0 14px;display:flex;align-items:center;gap:.55rem}
.flagship .tagline{font-size:1.05rem;color:var(--ink-2);margin-bottom:18px;font-weight:500}
.flagship p{color:var(--muted);margin-bottom:22px}
.pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:26px}
.pill{font-size:.8rem;font-weight:500;color:var(--ink-2);background:var(--canvas);border:1px solid var(--line);border-radius:8px;padding:.34rem .6rem}
.flagship-actions{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.priceline{font-size:.85rem;color:var(--muted);margin-top:18px}
.priceline b{color:var(--ink)}

/* flagship visual: mini "calm screen" */
.flagship-visual{background:linear-gradient(160deg,#f6f4ff,#eef0ff);padding:38px;display:flex;align-items:center;justify-content:center;border-left:1px solid var(--line)}
.miniapp{width:100%;max-width:340px;background:#fff;border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow-lg);overflow:hidden}
.miniapp-top{display:flex;align-items:center;gap:.5rem;padding:12px 14px;border-bottom:1px solid var(--line);background:#fbfaff}
.miniapp-top .dots{display:flex;gap:5px}
.miniapp-top .dots i{width:9px;height:9px;border-radius:50%;background:#e0ddf0;display:block}
.miniapp-top .ttl{font-size:.72rem;color:var(--muted);font-weight:600;margin-left:auto}
.miniapp-body{padding:16px}
.greet{font-size:.92rem;font-weight:700;margin-bottom:2px}
.greet-sub{font-size:.74rem;color:var(--muted);margin-bottom:14px}
.task{display:flex;align-items:center;gap:10px;padding:10px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:#fff}
.task .ic{width:26px;height:26px;border-radius:7px;display:grid;place-items:center;font-size:.8rem;flex:none}
.task .ic.red{background:#fdeceb;color:#d85a30}
.task .ic.blue{background:#e8eefe;color:#3b6ef0}
.task .ic.green{background:#e1f5ee;color:#0f9e75}
.task .tx{font-size:.78rem;line-height:1.3}
.task .tx b{font-weight:600}
.task .tx small{color:var(--muted);display:block;font-size:.7rem}
.task .badge{margin-left:auto;font-size:.62rem;font-weight:600;padding:.18rem .45rem;border-radius:6px;background:var(--soft);color:var(--indigo)}

/* secondary product cards */
.prod-cards{display:grid;grid-template-columns:1fr 1fr;gap:26px}
.pcard{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:32px;box-shadow:var(--shadow-sm);transition:transform .2s ease,box-shadow .2s ease;display:flex;flex-direction:column}
.pcard:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.pcard h3{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-weight:500;font-size:1.4rem;display:flex;align-items:center;gap:.5rem;margin-bottom:10px}
.pcard .tagline{font-weight:600;color:var(--ink-2);margin-bottom:10px}
.pcard p{color:var(--muted);font-size:.97rem;margin-bottom:22px;flex:1}

/* services */
.services{background:var(--paper)}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:var(--paper);border:1px solid var(--line);border-radius:18px;padding:30px;transition:transform .2s ease,box-shadow .2s ease,border-color .2s}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);border-color:#dcd7f1}
.svc-ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;margin-bottom:18px;background:var(--soft)}
.svc-ic svg{width:22px;height:22px;stroke:var(--indigo);fill:none;stroke-width:1.7}
.svc h3{margin-bottom:9px}
.svc p{color:var(--muted);font-size:.95rem}

/* why us */
.why{background:var(--canvas)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:start}
.why h2{margin-bottom:18px}
.why .lede{margin-bottom:0}
.why-points{display:grid;gap:18px}
.wpoint{background:#fff;border:1px solid var(--line);border-radius:16px;padding:24px 26px;box-shadow:var(--shadow-sm)}
.wpoint h3{margin-bottom:7px;display:flex;align-items:center;gap:.6rem}
.wpoint h3 .tick{width:24px;height:24px;border-radius:7px;background:var(--soft);color:var(--indigo);display:grid;place-items:center;font-size:.85rem;flex:none}
.wpoint p{color:var(--muted);font-size:.97rem}

/* process */
.process{background:var(--paper)}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border:1px solid var(--line);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm)}
.step{padding:34px 28px;border-right:1px solid var(--line);position:relative}
.step:last-child{border-right:none}
.step .num{font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;font-size:2.4rem;color:var(--indigo);line-height:1;margin-bottom:16px;opacity:.85}
.step h3{margin-bottom:8px}
.step p{color:var(--muted);font-size:.93rem}

/* reliability band */
.reliab{background:var(--canvas)}
.reliab-inner{display:grid;grid-template-columns:1.1fr .9fr;gap:54px;align-items:center}
.reliab h2{margin-bottom:16px}
.reliab p{color:var(--muted);font-size:1.05rem}
.chips{display:flex;flex-wrap:wrap;gap:12px}
.chip{display:flex;align-items:center;gap:.5rem;background:#fff;border:1px solid var(--line);border-radius:999px;padding:.6rem 1rem;font-size:.88rem;font-weight:600;color:var(--ink-2);box-shadow:var(--shadow-sm)}
.chip .ck{color:var(--teal);font-weight:700}

/* final CTA */
.cta{background:
  radial-gradient(900px 500px at 85% -20%, rgba(109,94,252,.45), transparent 60%),
  linear-gradient(140deg,#1b1838 0%,#2a2456 60%,#3a2f7a 100%);
  color:#fff;}
.cta-inner{text-align:center;max-width:680px;margin:0 auto}
.cta .eyebrow{color:#c9c2ff}
.cta h2{color:#fff;margin-bottom:18px;font-size:clamp(2.1rem,4vw,3.1rem)}
.cta p{color:rgba(255,255,255,.82);font-size:1.12rem;margin-bottom:32px}
.cta-note{font-size:.9rem;color:rgba(255,255,255,.62);margin-top:18px}

/* footer */
footer{background:var(--ink);color:#cdcbe0;padding:64px 0 30px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr 1fr;gap:40px;margin-bottom:46px}
.foot-brand .brand{color:#fff;margin-bottom:14px}
.foot-brand .brand .b-rest{color:#fff}
.foot-brand p{font-size:.92rem;color:#9c9ab6;max-width:34ch;line-height:1.6}
footer h4{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:#7e7c9b;font-weight:600;margin:0 0 16px}
.foot-col a{display:block;font-size:.92rem;color:#cdcbe0;margin-bottom:11px;transition:color .15s}
.foot-col a:hover{color:#fff}
.foot-col a .ext{font-size:.7rem;color:#6f6d8d;margin-left:3px}
.foot-bottom{border-top:1px solid #2a2849;padding-top:24px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;font-size:.84rem;color:#8b89a6}
.foot-bottom a{color:#8b89a6}.foot-bottom a:hover{color:#fff}

/* reveal */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ---------- responsive ---------- */
@media (max-width:980px){
  .hero-grid,.do-grid,.why-grid,.reliab-inner{grid-template-columns:1fr;gap:38px}
  .flagship{grid-template-columns:1fr}
  .flagship-visual{border-left:none;border-top:1px solid var(--line)}
  .svc-grid{grid-template-columns:1fr 1fr}
  .steps{grid-template-columns:1fr 1fr}
  .step{border-bottom:1px solid var(--line)}
  .step:nth-child(odd){border-right:1px solid var(--line)}
  .step:nth-child(even){border-right:none}
  .foot-grid{grid-template-columns:1fr 1fr 1fr}
  .foot-brand{grid-column:1 / -1}
  .constellation{height:360px}
}
@media (max-width:680px){
  .nav-links{display:none}
  .nav-links.open{display:flex;position:absolute;top:68px;left:0;right:0;flex-direction:column;align-items:flex-start;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px 24px 16px;box-shadow:var(--shadow-md)}
  .nav-links.open a{padding:12px 0;width:100%;border-bottom:1px solid var(--line)}
  .menu-btn{display:flex}
  .nav-cta .btn--ghost{display:none}
  .section{padding:64px 0}
  .prod-cards,.svc-grid,.steps{grid-template-columns:1fr}
  .step{border-right:none}
  .flagship-body{padding:30px}
  .foot-grid{grid-template-columns:1fr 1fr}
  /* constellation collapses to a tidy stack on small screens */
  .constellation{height:auto;background:none}
  .constellation .field,.cline,.node-core{display:none}
  .node{position:static;transform:none;animation:none;justify-content:flex-start}
  .node-stack{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:8px}
}
@media (min-width:681px){.node-stack{display:contents}}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none;transition:none}
}

/* ===== multi-page components ===== */
.crumbs{padding:24px 0 0}
.crumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:.5rem;margin:0;padding:0;font-size:.85rem;color:var(--muted)}
.crumbs li{display:flex;align-items:center;gap:.5rem}
.crumbs li+li::before{content:"/";color:#c8c5da}
.crumbs a{color:var(--indigo);font-weight:500}
.crumbs a:hover{text-decoration:underline}
.crumbs [aria-current]{color:var(--ink-2)}

.subhero{padding:30px 0 60px;background:radial-gradient(900px 460px at 82% -10%, #efeafe 0, rgba(239,234,254,0) 60%)}
.subhero h1{font-size:clamp(2.1rem,4.6vw,3.4rem);margin:14px 0 18px;max-width:19ch}
.subhero h1 em{font-style:italic;color:var(--indigo)}
.subhero .lede{font-size:1.16rem;max-width:56ch;margin-bottom:26px}
.subhero .hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.prose{max-width:70ch}
.prose>p{color:var(--muted);font-size:1.06rem;margin:0 0 16px}
.prose>p:last-child{margin-bottom:0}
.prose ul{margin:6px 0 18px;padding:0;list-style:none;display:grid;gap:11px}
.prose ul li{position:relative;padding-left:30px;color:var(--ink-2);font-size:1.01rem;line-height:1.55}
.prose ul li::before{content:"✓";position:absolute;left:0;top:0;color:var(--indigo);font-weight:700}
.prose strong{color:var(--ink)}
.prose a{color:var(--indigo);font-weight:600;text-decoration:underline;text-underline-offset:2px}
.prose h3{margin:26px 0 10px}

.section--alt{background:var(--canvas)}

.faq-list{display:grid;border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm)}
.faq-list details{border-bottom:1px solid var(--line)}
.faq-list details:last-child{border-bottom:none}
.faq-list summary{cursor:pointer;list-style:none;padding:22px 26px;font-weight:600;font-size:1.04rem;display:flex;justify-content:space-between;align-items:center;gap:16px;color:var(--ink)}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";font-size:1.5rem;line-height:1;color:var(--indigo);font-weight:400;flex:none;transition:transform .2s}
.faq-list details[open] summary::after{transform:rotate(45deg)}
.faq-list .faq-a{padding:0 26px 22px;color:var(--muted);font-size:1rem;max-width:72ch}
.faq-list .faq-a a{color:var(--indigo);font-weight:600}

a.svc{display:flex;flex-direction:column;text-decoration:none;color:inherit}
a.svc h3{color:var(--ink)}
a.svc .more{margin-top:auto;padding-top:14px;font-weight:600;color:var(--indigo);font-size:.92rem}
a.svc:hover .more{text-decoration:underline}

.intro-2col{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
@media(max-width:860px){.intro-2col{grid-template-columns:1fr;gap:30px}}

.cform{display:grid;gap:14px;max-width:540px}
.cform .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.cform label{font-size:.84rem;font-weight:600;color:var(--ink-2);display:block;margin-bottom:5px}
.cform input,.cform textarea{width:100%;padding:.8rem 1rem;border:1px solid var(--line);border-radius:12px;font:inherit;font-size:.95rem;background:#fff;color:var(--ink)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(109,94,252,.16)}
.contact-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:start}
.contact-aside{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;box-shadow:var(--shadow-sm)}
.contact-aside h3{margin-bottom:14px}
.contact-aside p{color:var(--muted);font-size:.97rem;margin-bottom:10px}
.contact-aside a{color:var(--indigo);font-weight:600}
@media(max-width:860px){.contact-grid,.row2{grid-template-columns:1fr;gap:30px}}
.note{font-size:.8rem;color:var(--muted)}
.hub-lead{max-width:60ch;margin-bottom:46px}

/* ===== generic type weights + BG monogram ===== */
h1,h2,h3{font-weight:700;letter-spacing:-.02em}
.do-statement{font-weight:600}
.flagship h3{font-weight:700}
.step .num{font-weight:700;opacity:.9}
.mark{font-size:.8rem;font-weight:800;letter-spacing:-.04em;border-radius:8px}
.mark--sm{font-size:.64rem;border-radius:6px}
.node-core b{font-size:1.5rem;letter-spacing:-.03em}
.node-core small{margin-top:2px}
