
:root {
  --bg: #08111f;
  --bg-gradient:
    radial-gradient(circle at top left, rgba(110, 231, 216, 0.12), transparent 28%),
    radial-gradient(circle at top right, rgba(143, 184, 255, 0.12), transparent 24%),
    linear-gradient(180deg, #07101c 0%, #0a1528 55%, #08111f 100%);
  --panel: rgba(14, 26, 46, 0.92);
  --panel-soft: rgba(20, 34, 58, 0.88);
  --line: rgba(158, 177, 209, 0.22);
  --line-strong: rgba(255, 255, 255, 0.08);
  --text: #e8f0ff;
  --muted: #a7bbdd;
  --accent: #6ee7d8;
  --accent-2: #8fb8ff;
  --dark: #07101c;
  --surface-1: rgba(255,255,255,0.02);
  --surface-2: rgba(255,255,255,0.04);
  --surface-3: rgba(255,255,255,0.05);
  --header-bg: rgba(8, 17, 31, 0.84);
  --dropdown-bg: rgba(10, 20, 38, 0.98);
  --eyebrow-bg: rgba(110,231,216,.08);
  --eyebrow-border: rgba(110,231,216,.24);
  --hero-frame: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.01));
  --radius: 20px;
  --shadow: 0 18px 45px rgba(0, 0, 0, 0.28);
  --max: 1180px;
}
html[data-theme="light"] {
  --bg: #f4f8ff;
  --bg-gradient:
    radial-gradient(circle at top left, rgba(110, 231, 216, 0.18), transparent 24%),
    radial-gradient(circle at top right, rgba(47, 111, 255, 0.14), transparent 22%),
    linear-gradient(180deg, #f9fbff 0%, #eef4ff 55%, #e8f0ff 100%);
  --panel: rgba(255, 255, 255, 0.86);
  --panel-soft: rgba(255, 255, 255, 0.78);
  --line: rgba(31, 61, 104, 0.16);
  --line-strong: rgba(31, 61, 104, 0.18);
  --text: #0f1d33;
  --muted: #536785;
  --accent: #0b766d;
  --accent-2: #2f6fff;
  --dark: #f4f8ff;
  --surface-1: rgba(15,29,51,0.03);
  --surface-2: rgba(15,29,51,0.05);
  --surface-3: rgba(15,29,51,0.08);
  --header-bg: rgba(244, 248, 255, 0.86);
  --dropdown-bg: rgba(255, 255, 255, 0.98);
  --eyebrow-bg: rgba(47,111,255,.08);
  --eyebrow-border: rgba(47,111,255,.18);
  --hero-frame: linear-gradient(180deg, rgba(47,111,255,.08), rgba(47,111,255,.02));
  --shadow: 0 18px 45px rgba(18, 32, 53, 0.12);
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; color-scheme: dark; }
html[data-theme="light"] { color-scheme: light; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  line-height: 1.65;
  background: var(--bg-gradient);
  background-color: var(--bg);
}
html[lang="zh-Hans"] body {
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", "Source Han Sans SC", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
html[lang="ja"] body {
  font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
.language-switcher,
.language-switcher a,
.language-switcher span,
.language-switcher .language-note {
  font-family: "PingFang SC", "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", "Source Han Sans SC", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Yu Gothic", "Meiryo", Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
button { font: inherit; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }
.container { width: min(calc(100% - 32px), var(--max)); margin: 0 auto; }
.utility-inner, .header-inner, .footer-grid, .card-grid, .contact-layout, .split-section, .route-grid, .glossary-grid {
  display: grid;
  gap: 20px;
}
.utility-bar {
  border-bottom: 1px solid var(--line);
  background: var(--surface-1);
}
.utility-inner { grid-template-columns: 1fr auto; align-items: center; padding: 10px 0; color: var(--muted); font-size: .94rem; }
.utility-links { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
html.nav-open { overflow: hidden; }
body.nav-open { overscroll-behavior: none; }
.site-header {
  position: sticky; top: 0; z-index: 30;
  backdrop-filter: blur(16px);
  background: var(--header-bg);
  border-bottom: 1px solid var(--line);
  min-height: 66px;
}
.header-inner { grid-template-columns: auto 1fr; align-items: center; gap: 18px; padding: 12px 0; min-height: 64px; }
.brand { display: inline-flex; align-items: center; gap: 12px; font-weight: 800; letter-spacing: .01em; }
.brand img { width: 40px; height: 40px; border-radius: 12px; box-shadow: 0 10px 22px rgba(61,213,196,.24); }
.nav-toggle {
  display: none; align-items: center; justify-content: center; gap: 8px;
  min-height: 42px; padding: 0 14px; border-radius: 999px; border: 1px solid var(--line);
  background: var(--surface-2); color: var(--text); font: inherit; font-weight: 700; cursor: pointer;
}
.nav-toggle-icon { font-size: 1.1rem; line-height: 1; }
.nav-shell { display: grid; grid-template-columns: minmax(0, 1fr) auto; align-items: center; gap: 18px; min-width: 0; }
.nav-links { display: flex; justify-content: center; gap: 18px; flex-wrap: wrap; align-items: center; }
.nav-links > a, .nav-dropdown > a { color: var(--muted); font-size: .96rem; }
.nav-links > a.active, .nav-dropdown > a.active, .nav-links a:hover { color: var(--text); }
.nav-dropdown { position: relative; }
.nav-dropdown::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  height: 14px;
}
.dropdown-menu {
  position: absolute; left: 0; top: calc(100% + 6px); min-width: 280px; z-index: 35;
  display: none; flex-direction: column; padding: 14px; border-radius: 18px;
  max-height: min(72vh, calc(100dvh - 120px)); overflow-y: auto; scrollbar-gutter: stable;
  background: var(--dropdown-bg); border: 1px solid var(--line); box-shadow: var(--shadow);
}
.dropdown-menu a { padding: 8px 10px; border-radius: 10px; color: var(--muted); }
.dropdown-menu a:hover { background: var(--surface-3); color: var(--text); }
.nav-dropdown:hover .dropdown-menu, .nav-dropdown:focus-within .dropdown-menu { display: flex; }
.header-actions, .cta-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.mobile-utility-links { display: none; }
.button, .button-secondary, .button-ghost {
  display: inline-flex; align-items: center; justify-content: center; min-height: 42px;
  padding: 0 16px; border-radius: 999px; border: 1px solid transparent; font-weight: 700;
  transition: transform .16s ease, background .16s ease, border-color .16s ease;
  cursor: pointer;
}
.button:hover, .button-secondary:hover, .button-ghost:hover { transform: translateY(-1px); }
.button { background: linear-gradient(135deg, var(--accent), #bafce4); color: #04111f; box-shadow: 0 14px 34px rgba(61,213,196,.22); }
.button-secondary { background: var(--surface-2); color: var(--text); border-color: var(--line); }
.button-ghost { background: transparent; color: var(--muted); border-color: var(--line); }
.consent-banner {
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 60;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px 18px;
  align-items: center;
  width: min(720px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(8, 17, 31, 0.94);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.28);
  backdrop-filter: blur(16px);
}
html[data-theme="light"] .consent-banner {
  background: rgba(255, 255, 255, 0.94);
}
.consent-banner__copy {
  display: grid;
  gap: 4px;
  min-width: 0;
}
.consent-banner__copy strong {
  font-size: .96rem;
}
.consent-banner__copy p {
  margin: 0;
  color: var(--muted);
  font-size: .92rem;
  line-height: 1.45;
}
.consent-banner__copy a {
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 2px;
}
.consent-banner__actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}
.consent-banner__actions .button,
.consent-banner__actions .button-ghost {
  min-height: 38px;
}
.utility-button { min-height: 34px; padding: 0 12px; font-size: .92rem; }
.theme-toggle { gap: 8px; }
.theme-toggle-icon { font-size: 1rem; line-height: 1; }
main { padding-bottom: 72px; }
.page-header { padding: 48px 0 18px; }
.page-header-grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(320px, .72fr); gap: 32px; align-items: start; }
.page-header-grid-landscape { grid-template-columns: minmax(0, .98fr) minmax(420px, 1.02fr); gap: 28px; align-items: start; }
.page-header-copy { min-width: 0; }
.page-header.hero-layout { padding-bottom: 28px; }
.eyebrow, .kicker, .intent-tag {
  display: inline-flex; align-items: center; gap: 10px; padding: 7px 12px; border-radius: 999px;
  border: 1px solid var(--eyebrow-border); background: var(--eyebrow-bg); color: var(--accent);
  font-size: .9rem; margin-bottom: 18px;
}
.kicker { margin-bottom: 12px; }
.intent-tag { margin: 6px 8px 0 0; }
.page-header h1, .cta-band h2, .section h2 { line-height: 1.06; margin: 0 0 10px; letter-spacing: -.03em; }
.page-header h1 { font-size: clamp(2.1rem, 4.8vw, 3.8rem); max-width: 14ch; }
.page-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin: 0 0 8px;
  color: var(--muted);
  font-size: .94rem;
}
.page-meta span { display: inline-flex; align-items: center; gap: 6px; }
.page-meta a { color: var(--text); }
.page-meta-role { color: var(--accent-2); }
.card-meta {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  align-self: flex-start;
  margin-bottom: 2px;
  color: var(--accent-2);
  font-size: .83rem;
  line-height: 1.35;
}
.card-synopsis { color: var(--muted); line-height: 1.68; }
.copy-flow { display: grid; align-content: start; gap: 10px; }
.copy-flow > * { margin: 0; }
.copy-flow > ul, .copy-flow > .feature-visual-list { margin-top: 6px; }
.copy-flow + .card-grid { margin-top: 18px; }
.lead, .section p { color: var(--muted); max-width: 76ch; font-size: 1.03rem; text-align: justify; text-wrap: pretty; }
.section li { color: var(--muted); text-align: justify; text-wrap: pretty; }
.hero-actions { margin-top: 12px; }
.hero-media { margin: 0; padding: 18px; background: var(--hero-frame); justify-self: end; width: min(100%, 420px); }
.hero-media img { display: block; border-radius: 24px; width: 100%; aspect-ratio: 9 / 16; object-fit: cover; background: var(--dark); }
.hero-media.hero-media-home { width: min(100%, 340px); align-self: center; justify-self: center; }
.hero-media.hero-media-home img { display: block; width: 100%; height: auto; aspect-ratio: unset; object-fit: contain; background: transparent; }
.hero-media-fit-contain { width: min(100%, 440px); padding: 6px; }
.hero-media-fit-contain img { aspect-ratio: auto; object-fit: contain; background: transparent; }
.hero-media-landscape { width: min(100%, 720px); padding: 10px; align-self: center; }
.hero-media-landscape img { aspect-ratio: auto; object-fit: contain; background: transparent; }
.breadcrumb ol {
  list-style: none; display: flex; gap: 10px; flex-wrap: wrap; padding: 0; margin: 0 0 18px; color: var(--muted); font-size: .92rem;
}
.breadcrumb li+li::before { content: '/'; margin-right: 10px; color: var(--line); }
.section { padding: 18px 0; }
.section-heading { margin-bottom: 12px; }
ul { padding-left: 18px; }
.card-grid { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.card, .form-panel, .image-card, .comparison-table, .faq-item, .search-results article {
  background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); box-shadow: var(--shadow);
}
.card, .form-panel, .image-card, .faq-item, .search-results article { padding: 22px; }
.card h3, .form-panel h3 { margin-top: 0; }
.card-linked { padding: 0; overflow: hidden; }
.card-copy, .card-copy-stack {
  display: grid;
  gap: 12px;
}
.card-body { margin: 0; }
.card-link-block {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 100%;
  padding: 22px;
}
.card-link-block:hover { background: var(--surface-1); }
.card-cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: var(--surface-2);
  color: var(--text);
  font-weight: 700;
}
.card-cta::after { content: '→'; color: var(--accent-2); }
.related-card { display: flex; }
.related-card-copy { display: flex; flex-direction: column; gap: 12px; min-height: 100%; }
.related-kicker { font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--accent-2); }
.card-link { color: var(--text); text-decoration: none; }
.card-link:hover { color: var(--accent-2); }
.related-button { margin-top: auto; align-self: flex-start; }
.split-section { grid-template-columns: minmax(0, 1.02fr) minmax(320px, .98fr); gap: 12px 22px; align-items: start; }
.split-section > .copy-flow { min-width: 0; max-width: 70ch; }
.split-section-feature { align-items: center; }
.image-card, .section-aside { margin: 0; }
.split-section > .image-card,
.split-feature-flow > .image-card,
.video-feature-row > .image-card,
.section-aside-layout > .image-card { justify-self: end; }
.section-aside-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(280px, .72fr);
  gap: 16px 24px;
  align-items: start;
}
.section-aside-layout > div { min-width: 0; }
.section-aside { align-self: start; }
.store-promo { display: grid; gap: 16px; }
.store-promo-copy { display: grid; gap: 10px; }
.store-promo-eyebrow {
  margin: 0;
  color: var(--accent-2);
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.store-promo-text { margin: 0; color: var(--muted); }
.store-badges { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; justify-content: flex-start; }
.store-badge { display: inline-flex; }
.store-badge img { display: block; width: min(100%, 180px); height: auto; }
.feature-visual-list { margin: 10px 0 0; padding-left: 20px; display: grid; gap: 7px; }
.feature-visual-list li { color: var(--text); }
.image-card img { border-radius: 16px; width: 100%; }
.image-card.hero-media-home { padding: 10px; }
.image-card.hero-media-home img { border-radius: 24px; }
.page-header .hero-media.hero-media-home { min-height: 0; }
.video-card { padding: 0; overflow: hidden; }
.video-embed { position: relative; width: 100%; padding-top: 56.25%; }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.video-showcase-block {
  display: grid;
  gap: 18px;
  justify-items: center;
  margin: 30px auto 42px;
}
.video-showcase-copy {
  display: grid;
  gap: 10px;
  justify-items: center;
  text-align: center;
  width: min(100%, 760px);
}
.video-showcase-copy .lead {
  max-width: 62ch;
  margin: 0 auto;
}
.video-showcase-card {
  width: min(100%, 690px);
  margin: 0 auto;
  padding: 12px;
}
.video-showcase-player {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  border: 0;
  border-radius: 18px;
  background: #000;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.video-showcase-player:focus-visible {
  outline: 2px solid var(--accent-2);
  outline-offset: 4px;
}
.page-header-copy-home { gap: 14px; }
.page-header-grid-home { grid-template-columns: minmax(0, .84fr) minmax(420px, 1.16fr); gap: 40px; align-items: center; }
.page-header-copy-home .lead { max-width: 62ch; }
.hero-media.hero-media-home.hero-media-landscape {
  width: min(100%, 760px);
  padding: 12px;
  justify-self: end;
}
.hero-media.hero-media-home.hero-media-landscape img {
  border-radius: 20px;
}
.home-section-heading {
  display: grid;
  gap: 12px;
  width: min(100%, 760px);
  margin-bottom: 22px;
}
.home-proof-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.home-proof-card {
  display: grid;
  align-content: start;
  gap: 8px;
  min-height: 100%;
}
.home-proof-value {
  margin: 0;
  color: var(--text);
  font-size: clamp(1.9rem, 4vw, 3rem);
  font-weight: 800;
  letter-spacing: -.04em;
}
.home-proof-card h3 {
  margin: 0;
  font-size: 1.02rem;
}
.home-story-grid {
  gap: 24px 32px;
  align-items: center;
}
.home-story-visual {
  padding: 14px;
}
.home-inline-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 10px;
}
.home-inline-link {
  min-height: 38px;
}
.cta-band {
  display: grid; grid-template-columns: 1.1fr auto; gap: 20px; align-items: center;
  padding: 24px; border-radius: 24px; background: linear-gradient(135deg, rgba(110,231,216,.12), rgba(143,184,255,.12)); border: 1px solid var(--line-strong);
}
.contact-layout { grid-template-columns: 1fr 1fr; align-items: start; }
.route-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); }
.route-card {
  background: var(--panel-soft); border: 1px solid var(--line); border-radius: 18px; padding: 18px; cursor: pointer;
}
.route-card.active { border-color: rgba(110,231,216,.55); box-shadow: 0 0 0 1px rgba(110,231,216,.25) inset; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.phone-input-group {
  display: grid;
  grid-template-columns: minmax(96px, 120px) 1fr;
  gap: 10px;
  align-items: center;
}
label { display: flex; flex-direction: column; gap: 8px; margin-bottom: 14px; color: var(--text); font-weight: 600; }
input, select, textarea {
  width: 100%; background: var(--surface-1); color: var(--text); border: 1px solid var(--line);
  border-radius: 14px; padding: 12px 14px; font: inherit;
}
select {
  background-color: #ffffff;
  color: var(--text);
}
select option {
  background-color: #ffffff;
  color: var(--text);
}
textarea { min-height: 140px; resize: vertical; }
.form-consent, .footer-meta, .footer-bottom, .form-panel p, .card p { color: var(--muted); }
.form-status { margin: 0 0 16px; padding: 14px 16px; border-radius: 16px; border: 1px solid transparent; font-size: 0.95rem; }
.form-status[hidden] { display: none; }
.form-status-error { background: rgba(248, 113, 113, 0.08); border-color: rgba(248, 113, 113, 0.24); color: #fecaca; }
.form-status a { color: inherit; text-decoration: underline; }
.footer-meta { display: grid; gap: 8px; }
.footer-contact-line { display: grid; gap: 4px; }
.footer-contact-label { font-size: .78rem; letter-spacing: .08em; text-transform: uppercase; color: var(--accent-2); }
.footer-meta a, .footer-meta div { display: block; }
.footer-platform-links {
  margin-top: 14px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 10px;
}
.footer-platform-links a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-height: 38px;
  padding: 0 18px;
  text-align: center;
  font-size: .92rem;
  letter-spacing: .01em;
}
.footer-cta {
  border-width: 1px;
  box-shadow: 0 10px 24px rgba(4, 17, 31, .18);
}
.footer-cta-primary {
  background: linear-gradient(135deg, rgba(61,213,196,.26), rgba(124,156,255,.30));
  color: #eefcff;
  border-color: rgba(132, 218, 255, .34);
}
.footer-cta-primary:hover {
  background: linear-gradient(135deg, rgba(61,213,196,.34), rgba(124,156,255,.38));
  border-color: rgba(160, 230, 255, .5);
}
.footer-cta-secondary {
  background: rgba(106, 132, 196, .14);
  color: #dce8ff;
  border-color: rgba(137, 169, 255, .26);
}
.footer-cta-secondary:hover {
  background: rgba(106, 132, 196, .22);
  border-color: rgba(137, 169, 255, .42);
}
.faq-list { display: grid; gap: 14px; }
.faq-item summary { cursor: pointer; font-weight: 700; }
.faq-answer { padding-top: 12px; }
.comparison-table { overflow-x: auto; padding: 0; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 14px 16px; border-bottom: 1px solid var(--line); text-align: left; vertical-align: top; }
.search-form { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 18px; }
.search-form input { min-width: min(100%, 380px); flex: 1; }
.search-results { display: grid; gap: 16px; }
.search-results article h3 { margin-top: 0; }
.glossary-grid { grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); }
.site-footer { border-top: 1px solid var(--line); margin-top: 32px; padding: 28px 0 14px; background: var(--surface-1); }
.footer-grid { grid-template-columns: minmax(260px, 1.35fr) repeat(3, minmax(180px, 1fr)); align-items: start; gap: 22px 20px; }
.footer-column { display: grid; gap: 8px; align-content: start; }
.footer-primary { gap: 12px; }
.footer-stack { gap: 18px; }
.footer-group { display: grid; gap: 8px; }
.footer-column h3 { margin: 0 0 4px; font-size: 1rem; }
.footer-column a { color: var(--muted); }
.footer-column a:hover { color: var(--text); }
.footer-store-links {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}
.footer-store-links p {
  margin: 0;
  color: var(--muted);
  font-size: .94rem;
  font-weight: 700;
}
.language-switcher {
  display: flex;
  align-items: baseline;
  gap: 10px 14px;
  flex-wrap: wrap;
}
.language-switcher-label {
  color: var(--accent-2);
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.language-switcher-links {
  display: flex;
  align-items: center;
  gap: 8px 14px;
  flex-wrap: wrap;
}
.language-switcher a {
  color: var(--muted);
}
.language-switcher a:hover,
.language-switcher a.active {
  color: var(--text);
}
.language-switcher a.active {
  font-weight: 700;
}
.language-note {
  color: var(--accent-2);
  font-size: .84em;
}
.store-badges-footer {
  gap: 10px;
}
.footer-bottom { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap; padding-top: 20px; font-size: .93rem; }
.footer-bottom-legal { justify-content: center; padding-top: 10px; }
.footer-legal-strip { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: 6px; font-size: .75rem; line-height: 1.45; text-align: center; }
.footer-legal-item a { color: var(--muted); }
.footer-legal-item a:hover { color: var(--text); }
.footer-legal-separator { color: var(--line-strong); }
@media (max-width: 1100px) {
  .utility-inner, .cta-band, .contact-layout, .split-section, .section-aside-layout, .page-header-grid { grid-template-columns: 1fr; }
  .hero-media { justify-self: start; width: min(100%, 420px); }
  .hero-media.hero-media-home { width: min(100%, 260px); justify-self: center; }
  .hero-media-landscape { width: min(100%, 720px); }
  .page-header-grid-home { gap: 26px; }
  .hero-media.hero-media-home.hero-media-landscape { width: min(100%, 720px); justify-self: start; }
  .home-proof-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 20px 18px; }
  .footer-primary { grid-column: 1 / -1; }
}
@media (max-width: 820px) {
  .utility-bar { display: none; }
  .site-header { overflow: visible; min-height: 56px; }
  .site-header.nav-open {
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .header-inner { grid-template-columns: auto auto; justify-content: space-between; gap: 12px; padding: 10px 0; min-height: 54px; }
  .brand span { font-size: .98rem; }
  .brand img { width: 34px; height: 34px; border-radius: 10px; }
  .nav-toggle { display: inline-flex; }
  .nav-shell {
    display: none; opacity: 0; visibility: hidden; pointer-events: none;
  }
  .nav-shell.nav-shell-open {
    display: grid; position: absolute; left: 0; right: 0; top: calc(100% + 1px); width: 100%; z-index: 40;
    height: calc(100svh - var(--mobile-nav-offset, 56px) - 1px); max-height: calc(100dvh - var(--mobile-nav-offset, 56px) - 1px); min-height: calc(100vh - var(--mobile-nav-offset, 56px) - 1px);
    opacity: 1; visibility: visible; pointer-events: auto;
    grid-template-columns: 1fr; align-content: start; gap: 14px; overflow-y: auto; overscroll-behavior: contain;
    -webkit-overflow-scrolling: touch; padding: 16px 20px 28px; margin: 0;
    background: var(--dropdown-bg); border-top: 1px solid var(--line); box-shadow: 0 22px 60px rgba(4, 10, 20, 0.36);
    backdrop-filter: blur(18px) saturate(130%); -webkit-backdrop-filter: blur(18px) saturate(130%);
  }
  .nav-links, .header-actions, .mobile-utility-links { display: grid; justify-content: stretch; }
  .nav-links { gap: 4px; }
  .nav-links > a, .nav-dropdown > a {
    display: block; padding: 10px 0; font-size: 1rem; border-bottom: 1px solid rgba(255,255,255,0.04);
  }
  .nav-dropdown { display: grid; gap: 4px; }
  .nav-dropdown::after { display: none; }
  .dropdown-menu {
    position: static; display: grid; min-width: 0; padding: 2px 0 8px 14px; gap: 2px;
    background: transparent; border: 0; box-shadow: none;
  }
  .dropdown-menu a { padding: 7px 0; }
  .nav-dropdown:hover .dropdown-menu, .nav-dropdown:focus-within .dropdown-menu { display: grid; }
  .header-actions { gap: 10px; }
  .header-actions > * { width: 100%; }
  .theme-toggle { justify-content: center; }
  .mobile-utility-links {
    display: grid; gap: 10px; padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.04);
  }
  .mobile-utility-links a { color: var(--muted); }
  .mobile-utility-links .button-secondary { width: 100%; }
  .site-footer { padding: 24px 0 14px; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px 14px; }
  .footer-primary { grid-column: 1 / -1; }
  .footer-column h3 { font-size: .96rem; }
  .footer-column a, .footer-meta, .footer-bottom { font-size: .92rem; }
  .footer-legal-strip { font-size: .69rem; gap: 5px; }
}
@media (max-width: 720px) {
  .field-row { grid-template-columns: 1fr; }
  .phone-input-group { grid-template-columns: 1fr; }
  .page-header { padding-top: 36px; }
  .page-header h1 { max-width: 100%; }
  .home-inline-actions { display: grid; }
  .home-inline-link { width: 100%; justify-content: center; }
  .lead, .section p, .section li { text-align: left; }
  .nav-toggle span:last-child { display: none; }
  .nav-toggle { padding: 0 12px; }
  .consent-banner {
    grid-template-columns: 1fr;
    gap: 12px;
    width: auto;
  }
  .consent-banner__actions {
    justify-content: stretch;
  }
  .consent-banner__actions .button,
  .consent-banner__actions .button-ghost {
    flex: 1 1 150px;
  }
}
  .video-showcase-block { margin: 26px auto 34px; }
  .video-showcase-card { width: min(100%, 100%); padding: 10px; }
@media (max-width: 520px) {
  .footer-grid { grid-template-columns: 1fr; gap: 16px 12px; }
  .footer-column { gap: 6px; }
  .footer-stack { gap: 14px; }
  .footer-column h3 { margin-bottom: 2px; font-size: .92rem; }
  .footer-column a, .footer-meta, .footer-bottom { font-size: .88rem; }
  .footer-bottom { padding-top: 16px; }
  .footer-legal-strip { font-size: .65rem; gap: 4px; }
}
