/* Cubevo — Marketing site kit layout
   Layout/composition only; all values come from the token system. */

.site { background: var(--bg-page); color: var(--text-primary); font-family: var(--font-body); overflow-x: hidden; }
.wrap { max-width: var(--container-xl); margin: 0 auto; padding-inline: var(--space-6); }
.eyebrow { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase; color: var(--brand-text); display: inline-flex; align-items: center; gap: 8px; }
.section { padding-block: var(--space-24); }
.section__head { max-width: 680px; margin-bottom: var(--space-12); }
.section__head h2 { font-size: var(--text-4xl); margin: var(--space-3) 0 var(--space-4); letter-spacing: var(--tracking-tight); }
.section__head p { font-size: var(--text-lg); color: var(--text-secondary); }

/* ---------- Header ---------- */
.hdr { position: sticky; top: 0; z-index: 50; backdrop-filter: blur(var(--blur-md));
  background: var(--surface-overlay); border-bottom: 1px solid var(--border-subtle); }
.hdr__row { display: flex; align-items: center; gap: var(--space-6); height: 72px; }
.hdr__logo { display: inline-flex; align-items: center; height: 26px; }
.hdr__logo img { height: 26px; width: auto; }
.logo-dark { display: none; }
[data-theme="dark"] .logo-light { display: none; }
[data-theme="dark"] .logo-dark { display: inline-flex; }
.hdr__nav { display: flex; align-items: center; gap: var(--space-6); margin-left: var(--space-4); }
.hdr__nav a { font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--text-secondary);
  transition: color var(--dur-fast) var(--ease-out); }
.hdr__nav a:hover { color: var(--text-primary); }
.hdr__spacer { flex: 1; }
.hdr__actions { display: flex; align-items: center; gap: var(--space-3); }
.langtoggle { display: inline-flex; background: var(--bg-muted); border-radius: var(--radius-full); padding: 3px; }
.langtoggle button { border: none; background: transparent; cursor: pointer; font-family: var(--font-mono);
  font-size: var(--text-xs); font-weight: var(--weight-medium); color: var(--text-tertiary);
  padding: 5px 10px; border-radius: var(--radius-full); transition: all var(--dur-fast) var(--ease-out); }
.langtoggle button[aria-pressed="true"] { background: var(--surface-card); color: var(--text-primary); box-shadow: var(--shadow-sm); }
.hdr__menu-btn { display: none; }

/* mobile nav panel */
.hdr__mobile { display: none; }
.hdr__mobile-inner { display: flex; flex-direction: column; gap: var(--space-1);
  padding: var(--space-2) var(--space-6) var(--space-6); }
.hdr__mobile a { font-size: var(--text-lg); font-weight: var(--weight-medium); color: var(--text-secondary);
  padding: var(--space-3) 0; border-bottom: 1px solid var(--border-subtle); }
.hdr__mobile a:hover { color: var(--text-primary); }
.hdr__mobile .m-foot { display: flex; align-items: center; gap: var(--space-3); margin-top: var(--space-5); }
@keyframes hdrDrop { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: none; } }
@media (max-width: 980px) {
  .hdr .langtoggle, .hdr__cta { display: none; }
  .hdr__menu-btn { display: inline-flex; }
  .hdr__mobile.open { display: block; border-top: 1px solid var(--border-subtle);
    background: var(--surface-card); box-shadow: var(--shadow-lg); }
}

/* ---------- Hero ---------- */
.hero { position: relative; padding-top: var(--space-24); padding-bottom: var(--space-16); overflow: hidden; }
.hero__grid-bg { position: absolute; inset: 0; background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-line) 1px, transparent 1px);
  background-size: 38px 38px; mask-image: radial-gradient(120% 90% at 70% 0%, #000 35%, transparent 75%); }
.hero__glow { position: absolute; width: 720px; height: 720px; right: -180px; top: -320px; border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand) 26%, transparent), transparent 62%);
  filter: blur(20px); pointer-events: none; }
.hero__inner { position: relative; display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--space-16); align-items: center; }
.hero h1 { font-size: var(--text-6xl); line-height: 1.02; letter-spacing: var(--tracking-tighter); margin: var(--space-5) 0 var(--space-6); }
.hero h1 .accent { color: var(--brand); }
.hero__lead { font-size: var(--text-xl); color: var(--text-secondary); max-width: 30ch; line-height: var(--leading-snug); }
.hero__cta { display: flex; gap: var(--space-3); margin-top: var(--space-8); flex-wrap: wrap; }
.hero__trust { display: flex; gap: var(--space-8); margin-top: var(--space-12); }
.hero__trust .num { font-family: var(--font-display); font-weight: var(--weight-bold); font-size: var(--text-2xl); color: var(--text-primary); }
.hero__trust .cap { font-size: var(--text-sm); color: var(--text-tertiary); }

/* hero preview card */
.preview { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl); overflow: hidden; }
.preview__bar { display: flex; align-items: center; gap: 8px; padding: 12px 16px; border-bottom: 1px solid var(--border-subtle); background: var(--bg-subtle); }
.preview__dot { width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong); }
.preview__tab { margin-left: auto; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); }
.preview__body { padding: 18px; display: grid; gap: 14px; }
.codeblock { font-family: var(--font-mono); font-size: 12.5px; line-height: 1.7; color: var(--text-secondary);
  background: var(--surface-sunken); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: 14px 16px; }
.codeblock .k { color: var(--brand-text); } .codeblock .s { color: var(--accent-text); } .codeblock .c { color: var(--text-muted); }
.preview__row { display: flex; gap: 12px; }
.mini { flex: 1; background: var(--bg-subtle); border: 1px solid var(--border-subtle); border-radius: var(--radius-md); padding: 12px 14px; }
.mini .lbl { font-size: var(--text-xs); color: var(--text-tertiary); }
.mini .val { font-family: var(--font-display); font-weight: var(--weight-bold); font-size: var(--text-xl); margin-top: 4px; }
.bars { display: flex; align-items: flex-end; gap: 6px; height: 46px; margin-top: 8px; }
.bars i { flex: 1; background: var(--brand); border-radius: 3px 3px 0 0; opacity: .35; }
.bars i:nth-child(4){ opacity: 1; } .bars i:nth-child(5){ opacity:.7; }

/* ---------- Service / feature grid ---------- */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.feature { display: flex; flex-direction: column; gap: var(--space-3); height: 100%; }
.feature__ico { width: 46px; height: 46px; border-radius: var(--radius-md); display: grid; place-items: center;
  background: var(--brand-subtle); color: var(--brand-text); }
.feature h3 { font-size: var(--text-xl); }
.feature p { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-snug); flex: 1; }
.feature__link { display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-sm); font-weight: var(--weight-semibold);
  color: var(--brand-text); margin-top: var(--space-2); }
.feature__link svg { transition: transform var(--dur-fast) var(--ease-out); }
.cv-card--interactive:hover .feature__link svg { transform: translateX(3px); }

/* ---------- AI band ---------- */
.band { background: var(--bg-subtle); border-block: 1px solid var(--border-subtle); }
[data-theme="dark"] .band { background: var(--surface-sunken); }
.ai-ico { background: var(--accent-subtle); color: var(--accent-text); }

/* ---------- Work ---------- */
.work__head { display: flex; align-items: flex-end; justify-content: space-between; gap: var(--space-6); margin-bottom: var(--space-10); flex-wrap: wrap; }
.work__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5); }
.project { display: flex; flex-direction: column; gap: var(--space-3); }
.project__top { display: flex; align-items: center; justify-content: space-between; }
.project__ico { width: 40px; height: 40px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--bg-muted); color: var(--text-secondary); }
.project h3 { font-size: var(--text-lg); }
.project p { font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-snug); }

/* ---------- Contact ---------- */
.contact { position: relative; overflow: hidden; }
.contact__card { position: relative; background: var(--brand); color: #fff; border-radius: var(--radius-2xl);
  padding: var(--space-20) var(--space-16); text-align: center; box-shadow: var(--shadow-brand); overflow: hidden; }
.contact__card .grid-bg { position: absolute; inset: 0; background-image:
    linear-gradient(rgba(255,255,255,.07) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px);
  background-size: 34px 34px; mask-image: radial-gradient(80% 80% at 50% 0%, #000, transparent 75%); }
.contact__card h2 { color: #fff; font-size: var(--text-5xl); letter-spacing: var(--tracking-tight); position: relative; }
.contact__card p { color: rgba(255,255,255,.82); font-size: var(--text-lg); max-width: 46ch; margin: var(--space-4) auto var(--space-8); position: relative; }
.contact__email { position: relative; display: inline-flex; align-items: center; gap: 10px; font-family: var(--font-mono);
  font-size: var(--text-xl); color: #fff; background: rgba(255,255,255,.14); border: 1px solid rgba(255,255,255,.28);
  padding: 14px 22px; border-radius: var(--radius-full); transition: background var(--dur-fast) var(--ease-out); }
.contact__email:hover { background: rgba(255,255,255,.24); }

/* ---------- Footer ---------- */
.ftr { background: var(--bg-subtle); border-top: 1px solid var(--border-subtle); padding-block: var(--space-16) var(--space-8); }
.ftr__top { display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr; gap: var(--space-8); }
.ftr__brand img { height: 24px; margin-bottom: var(--space-4); }
.ftr__brand p { font-size: var(--text-sm); color: var(--text-tertiary); max-width: 34ch; line-height: var(--leading-normal); }
.ftr__col h4 { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-4); font-weight: var(--weight-medium); }
.ftr__col ul { margin: 0; padding: 0; }
.ftr__col a, .ftr__col li { display: block; font-size: var(--text-sm); color: var(--text-secondary); margin-bottom: var(--space-2); list-style: none; }
.ftr__col a:hover { color: var(--brand-text); }
.ftr__bottom { display: flex; justify-content: space-between; align-items: center; margin-top: var(--space-12);
  padding-top: var(--space-6); border-top: 1px solid var(--border-subtle); font-size: var(--text-xs); color: var(--text-muted); flex-wrap: wrap; gap: var(--space-3); }

/* ================================================================
   PRODUCT PAGES (Microservers + Digital Signage)
   ================================================================ */

/* spec chips under a hero */
.spec-strip { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-10); }
.chip { display: inline-flex; align-items: center; gap: 8px; font-size: var(--text-sm); font-weight: var(--weight-medium);
  color: var(--text-secondary); background: var(--surface-card); border: 1px solid var(--border-default);
  border-radius: var(--radius-full); padding: 8px 14px; }
.chip svg { color: var(--brand); }

/* ---------- Microserver device visual ---------- */
.device-stage { position: relative; display: grid; place-items: center; min-height: 380px; }
.device { position: relative; width: 230px; height: 300px; border-radius: var(--radius-xl);
  background: linear-gradient(160deg, var(--gray-800), var(--gray-950));
  border: 1px solid var(--border-strong); box-shadow: var(--shadow-xl); padding: 22px; overflow: hidden; }
[data-theme="dark"] .device { border-color: #2f3a4d; }
.device::before { content: ""; position: absolute; inset: 0; background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px);
  background-size: 22px 22px; mask-image: radial-gradient(120% 80% at 50% 0%, #000, transparent 80%); }
.device__leds { position: relative; display: flex; gap: 7px; margin-bottom: 20px; }
.device__leds i { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.22); }
.device__leds i.on { background: #34c46a; box-shadow: 0 0 10px #34c46a; animation: cv-blink 2.4s var(--ease-in-out) infinite; }
.device__leds i.brand { background: var(--signal-400); box-shadow: 0 0 10px var(--signal-400); }
@keyframes cv-blink { 0%,100%{opacity:1} 50%{opacity:.35} }
.device__bays { position: relative; display: flex; flex-direction: column; gap: 10px; margin-bottom: 22px; }
.device__bays span { height: 26px; border-radius: var(--radius-sm); background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); }
.device__mark { position: absolute; bottom: 20px; left: 22px; }
.device__mark img { height: 26px; opacity: .9; }
.device__glow { position: absolute; inset: 0; pointer-events: none; }
.device__glow::after { content: ""; position: absolute; width: 360px; height: 360px; left: 50%; top: 50%;
  transform: translate(-50%,-50%); border-radius: 50%;
  background: radial-gradient(circle, color-mix(in srgb, var(--brand) 30%, transparent), transparent 60%); filter: blur(10px); z-index: -1; }

/* ---------- capabilities grid (2-col, deep cards) ---------- */
.cap-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }
.cap { display: flex; gap: var(--space-4); }
.cap__ico { flex: none; width: 44px; height: 44px; border-radius: var(--radius-md); display: grid; place-items: center;
  background: var(--brand-subtle); color: var(--brand-text); }
.cap h3 { font-size: var(--text-lg); margin-bottom: 4px; }
.cap p { font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-snug); margin-bottom: var(--space-3); }
.cap__adv { display: flex; flex-wrap: wrap; gap: 6px; }
.cap__adv span { display: inline-flex; align-items: center; gap: 5px; font-size: var(--text-xs); color: var(--text-tertiary); }
.cap__adv svg { color: var(--success); }

/* ---------- why band ---------- */
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }
.why { display: flex; flex-direction: column; gap: var(--space-3); }
.why__ico { width: 48px; height: 48px; border-radius: var(--radius-lg); display: grid; place-items: center;
  background: var(--surface-card); border: 1px solid var(--border-default); color: var(--brand-text); box-shadow: var(--shadow-sm); }
.why h3 { font-size: var(--text-xl); }
.why p { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-snug); }

/* ---------- Digital Signage dashboard mockup ---------- */
.dash { background: var(--surface-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl); overflow: hidden; }
.dash__bar { display: flex; align-items: center; gap: 10px; padding: 12px 16px; border-bottom: 1px solid var(--border-subtle); background: var(--bg-subtle); }
.dash__bar .d { width: 10px; height: 10px; border-radius: 50%; background: var(--border-strong); }
.dash__bar .name { margin-left: 8px; font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); }
.dash__bar .live { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-size: var(--text-xs); color: var(--success); font-weight: var(--weight-semibold); }
.dash__bar .live i { width: 7px; height: 7px; border-radius: 50%; background: var(--success); box-shadow: 0 0 8px var(--success); }
.dash__body { display: grid; grid-template-columns: 150px 1fr; min-height: 300px; }
.dash__side { border-right: 1px solid var(--border-subtle); padding: 16px 12px; background: var(--bg-subtle); display: flex; flex-direction: column; gap: 4px; }
.dash__side a { display: flex; align-items: center; gap: 9px; font-size: var(--text-sm); color: var(--text-secondary); padding: 8px 10px; border-radius: var(--radius-sm); }
.dash__side a.active { background: var(--brand-subtle); color: var(--brand-text); font-weight: var(--weight-semibold); }
.dash__side a svg { width: 16px; height: 16px; }
.dash__main { padding: 18px; }
.dash__main h4 { font-size: var(--text-sm); color: var(--text-tertiary); font-family: var(--font-mono); letter-spacing: var(--tracking-wide); text-transform: uppercase; margin-bottom: 14px; }
.dash__devices { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.dvc { border: 1px solid var(--border-subtle); border-radius: var(--radius-md); overflow: hidden; background: var(--bg-page); }
.dvc__scr { height: 56px; background: linear-gradient(135deg, var(--blue-500), var(--signal-500)); position: relative; }
.dvc__scr.alt { background: linear-gradient(135deg, var(--gray-700), var(--gray-900)); }
.dvc__scr.alt2 { background: linear-gradient(135deg, var(--signal-500), var(--blue-600)); }
.dvc__meta { display: flex; align-items: center; gap: 7px; padding: 8px 10px; }
.dvc__meta .dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.dvc__meta .dot.on { background: var(--success); } .dvc__meta .dot.off { background: var(--text-muted); }
.dvc__meta .lbl { font-size: var(--text-xs); color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---------- benefits (two big blocks) ---------- */
.benefit-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.benefit { padding: var(--space-8); }
.benefit__ico { width: 52px; height: 52px; border-radius: var(--radius-lg); display: grid; place-items: center;
  background: var(--brand-subtle); color: var(--brand-text); margin-bottom: var(--space-5); }
.benefit h3 { font-size: var(--text-2xl); margin-bottom: var(--space-3); }
.benefit p { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-normal); margin-bottom: var(--space-4); }
.benefit ul { display: flex; flex-direction: column; gap: 8px; list-style: none; }
.benefit li { display: flex; align-items: center; gap: 10px; font-size: var(--text-sm); color: var(--text-primary); }
.benefit li svg { color: var(--success); flex: none; }

/* ================================================================
   CONTENT PAGES (Contact · Case study · Legal)
   ================================================================ */

/* shared compact page hero */
.page-hero { position: relative; overflow: hidden; padding-block: var(--space-20) var(--space-12); border-bottom: 1px solid var(--border-subtle); }
.page-hero .wrap { position: relative; }
.page-hero h1 { font-size: var(--text-5xl); letter-spacing: var(--tracking-tight); margin: var(--space-4) 0 var(--space-4); }
.page-hero p { font-size: var(--text-lg); color: var(--text-secondary); max-width: 60ch; }

/* ---------- Contact ---------- */
.contact-grid { display: grid; grid-template-columns: 1.3fr 0.9fr; gap: var(--space-12); align-items: start; }
.field-stack { display: flex; flex-direction: column; gap: var(--space-5); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
.info-list { display: flex; flex-direction: column; gap: var(--space-6); }
.info-item { display: flex; gap: var(--space-4); }
.info-item .ico { flex: none; width: 42px; height: 42px; border-radius: var(--radius-md); display: grid; place-items: center; background: var(--brand-subtle); color: var(--brand-text); }
.info-item h4 { font-size: var(--text-base); margin-bottom: 2px; }
.info-item p, .info-item a { font-size: var(--text-sm); color: var(--text-secondary); line-height: var(--leading-snug); }
.info-item a:hover { color: var(--brand-text); }
.form-success { display: flex; flex-direction: column; gap: var(--space-5); align-items: flex-start; }

/* ---------- Case study ---------- */
.cs-meta { display: flex; flex-wrap: wrap; gap: var(--space-8) var(--space-10); margin-top: var(--space-8); }
.cs-meta .k { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--text-tertiary); }
.cs-meta .v { font-family: var(--font-display); font-weight: var(--weight-semibold); font-size: var(--text-lg); margin-top: 4px; }
.cs-tags { display: flex; gap: 8px; flex-wrap: wrap; margin-top: var(--space-6); }
.cs-shot { aspect-ratio: 16 / 9; border-radius: var(--radius-xl); border: 1px solid var(--border-default); overflow: hidden; position: relative; background: var(--bg-subtle); display: grid; place-items: center; box-shadow: var(--shadow-lg); }
.cs-shot .gridtex { position: absolute; inset: 0; background-image:
    linear-gradient(var(--grid-line) 1px, transparent 1px), linear-gradient(90deg, var(--grid-line) 1px, transparent 1px); background-size: 28px 28px; }
.cs-shot .ph { position: relative; display: flex; flex-direction: column; align-items: center; gap: 8px; color: var(--text-muted); font-size: var(--text-sm); }
.cs-prose { max-width: 760px; }
.cs-twocol { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-6); }
.cs-results { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-8); }
.cs-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); }

/* ---------- Legal / doc ---------- */
.doc { display: grid; grid-template-columns: 230px 1fr; gap: var(--space-12); align-items: start; }
.doc-toc { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 2px; }
.doc-toc .t { font-family: var(--font-mono); font-size: var(--text-xs); letter-spacing: var(--tracking-eyebrow); text-transform: uppercase; color: var(--text-tertiary); margin-bottom: var(--space-3); }
.doc-toc a { font-size: var(--text-sm); color: var(--text-tertiary); padding: 7px 12px; border-left: 2px solid var(--border-default); transition: color var(--dur-fast) var(--ease-out), border-color var(--dur-fast) var(--ease-out); }
.doc-toc a:hover { color: var(--text-primary); border-color: var(--border-strong); }
.doc-toc a.active { color: var(--brand-text); border-color: var(--brand); font-weight: var(--weight-medium); }
.doc-body { max-width: 740px; }
.doc-updated { font-family: var(--font-mono); font-size: var(--text-xs); color: var(--text-tertiary); margin-bottom: var(--space-8); }
.prose h2 { font-size: var(--text-2xl); margin-top: var(--space-12); scroll-margin-top: 96px; }
.prose h2:first-child { margin-top: 0; }
.prose p { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-relaxed); margin-top: var(--space-4); }
.prose ul { margin-top: var(--space-4); padding-left: 1.25em; display: flex; flex-direction: column; gap: var(--space-2); }
.prose li { font-size: var(--text-base); color: var(--text-secondary); line-height: var(--leading-snug); }

/* ---------- Responsive ---------- */
@media (max-width: 980px) {
  .hero__inner { grid-template-columns: 1fr; }
  .preview { display: none; }
  .grid-3, .work__grid, .ftr__top { grid-template-columns: 1fr 1fr; }
  .hero h1 { font-size: var(--text-5xl); }
  .hdr__nav { display: none; }
  .cap-grid, .why-grid, .benefit-grid { grid-template-columns: 1fr; }
  .device-stage { min-height: 0; margin-top: var(--space-8); }
  .contact-grid, .cs-twocol, .cs-gallery { grid-template-columns: 1fr; }
  .doc { grid-template-columns: 1fr; }
  .doc-toc { position: static; flex-direction: row; flex-wrap: wrap; }
}
@media (max-width: 620px) {
  .grid-3, .work__grid, .ftr__top, .dash__devices, .cs-results { grid-template-columns: 1fr; }
  .hero h1 { font-size: var(--text-4xl); }
  .page-hero h1 { font-size: var(--text-4xl); }
  .section { padding-block: var(--space-16); }
  .contact__card { padding: var(--space-12) var(--space-6); }
  .contact__card h2 { font-size: var(--text-4xl); overflow-wrap: break-word; }
  .dash__body { grid-template-columns: 1fr; }
  .dash__side { flex-direction: row; flex-wrap: wrap; border-right: none; border-bottom: 1px solid var(--border-subtle); }
  .form-row { grid-template-columns: 1fr; }
}
