:root {
  --bg: #060816;
  --bg-2: #0b1020;
  --surface: rgba(12, 18, 36, 0.82);
  --surface-2: rgba(18, 26, 46, 0.9);
  --line: rgba(175, 255, 77, 0.14);
  --line-2: rgba(180, 133, 255, 0.2);
  --text: #f6f7fb;
  --muted: #a2aecf;
  --accent: #a855f7;
  --accent-2: #9eff38;
  --accent-3: #52b6ff;
  --shadow: 0 18px 60px rgba(0, 0, 0, 0.45);
  --radius: 26px;
  --container: 1200px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: var(--text);
  background:
    radial-gradient(circle at 12% 12%, rgba(168,85,247,.18), transparent 28%),
    radial-gradient(circle at 85% 12%, rgba(158,255,56,.15), transparent 28%),
    radial-gradient(circle at 50% 100%, rgba(82,182,255,.11), transparent 32%),
    linear-gradient(180deg, #060816 0%, #070a15 45%, #090d19 100%);
  overflow-x: hidden;
}
a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
body.menu-open { overflow: hidden; }

.site-shell { position: relative; min-height: 100vh; overflow: clip; }
.site-main { position: relative; z-index: 2; }
.container { width: min(var(--container), calc(100% - 32px)); margin: 0 auto; }
.narrow { max-width: 760px; }
.section { position: relative; padding: 112px 0; }
.section-alt { background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01)); }
.section-divider::after {
  content: "";
  position: absolute;
  left: 50%; transform: translateX(-50%);
  bottom: 0;
  width: min(1000px, calc(100% - 32px));
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.08), transparent);
}
.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 8px 14px; border-radius: 999px;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08);
  color: #d7e1ff; font-size: .82rem; text-transform: uppercase; letter-spacing: .12em;
}
.eyebrow::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 18px rgba(168,85,247,.85);
}
h1, h2, h3, h4 { margin: 0 0 16px; line-height: 1.05; letter-spacing: -.03em; }
h1 { font-size: clamp(3rem, 7vw, 5.9rem); }
h2 { font-size: clamp(2rem, 4vw, 3.5rem); }
h3 { font-size: clamp(1.2rem, 2vw, 1.55rem); }
p { margin: 0; color: var(--muted); line-height: 1.75; }

.button {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  min-height: 50px; padding: 0 18px; border: 1px solid transparent; border-radius: 999px;
  transition: transform .28s ease, border-color .28s ease, background .28s ease, box-shadow .28s ease;
  white-space: nowrap;
}
.button:hover { transform: translateY(-2px); }
.button-primary {
  color: #08110c;
  background: linear-gradient(135deg, var(--accent-2), #d6ff74 70%);
  box-shadow: 0 10px 30px rgba(158,255,56,.22);
}
.button-secondary {
  color: var(--text);
  border-color: rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
}

.glass {
  position: relative;
  background: linear-gradient(180deg, rgba(18, 24, 46, 0.78), rgba(10, 14, 26, 0.82));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: var(--radius);
}
.glass::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: inherit; pointer-events: none;
  background: linear-gradient(135deg, rgba(255,255,255,.08), transparent 20%, transparent 80%, rgba(158,255,56,.04));
}

.bg-grid,
.bg-noise,
.bg-glow,
.bottom-blur-mask { pointer-events: none; position: fixed; inset: 0; z-index: 0; }
.bg-grid {
  opacity: .23;
  background-image:
    linear-gradient(rgba(255,255,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.03) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at center, black 40%, transparent 100%);
}
.bg-noise { opacity: .08; background-image: radial-gradient(rgba(255,255,255,.24) 1px, transparent 1px); background-size: 10px 10px; }
.bg-glow-a { background: radial-gradient(circle at 15% 20%, rgba(168,85,247,.24), transparent 26%); }
.bg-glow-b { background: radial-gradient(circle at 86% 16%, rgba(158,255,56,.16), transparent 26%); }
.bg-glow-c { background: radial-gradient(circle at 50% 86%, rgba(82,182,255,.12), transparent 25%); }
.bottom-blur-mask {
  top: auto; height: 30vh;
  background: linear-gradient(180deg, transparent, rgba(6,8,22,.35) 18%, rgba(6,8,22,.9) 100%);
  backdrop-filter: blur(16px); -webkit-backdrop-filter: blur(16px);
}

.site-header {
  position: sticky; top: 18px; z-index: 30;
  width: 100%; padding: 0 16px;
}
.dynamic-island {
  display: flex; justify-content: center;
  transition: transform .35s ease;
}
.dynamic-island__pill {
  position: relative;
  display: flex; align-items: center; justify-content: space-between; gap: 18px;
  width: min(100%, 520px); min-height: 64px;
  padding: 10px 14px 10px 18px;
  border-radius: 999px;
  background: rgba(8, 11, 22, 0.72);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow: 0 22px 55px rgba(0,0,0,.38), inset 0 1px 0 rgba(255,255,255,.08);
  backdrop-filter: blur(22px); -webkit-backdrop-filter: blur(22px);
  transition: width .52s cubic-bezier(.2,.9,.2,1.1), border-radius .52s cubic-bezier(.2,.9,.2,1.1), transform .52s ease, background .52s ease;
}
.dynamic-island.is-expanded .dynamic-island__pill { width: min(100%, 1060px); }
.dynamic-island.is-scrolled .dynamic-island__pill { background: rgba(9, 12, 23, .84); }
.brand { display: inline-flex; align-items: center; min-width: 0; font-weight: 800; letter-spacing: -.03em; }
.brand img, .brand .custom-logo { max-height: 40px; width: auto; }
.brand span { font-size: 1.08rem; white-space: nowrap; }
.main-nav { min-width: 0; }
.menu-inline, .menu-inline ul {
  list-style: none; display: flex; align-items: center; gap: 8px; padding: 0; margin: 0;
}
.menu-inline a {
  display: inline-flex; align-items: center; justify-content: center; height: 42px;
  padding: 0 14px; border-radius: 999px; color: #dbe4ff; font-size: .93rem; white-space: nowrap;
}
.menu-inline a:hover, .menu-inline .current-menu-item > a { background: rgba(255,255,255,.06); }
.nav-actions { display: inline-flex; align-items: center; gap: 10px; flex-shrink: 0; }
.lang-switcher { display: inline-flex; padding: 4px; border-radius: 999px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); }
.lang-switcher a {
  display: inline-flex; min-width: 42px; height: 34px; align-items: center; justify-content: center; border-radius: 999px;
  color: var(--muted); font-weight: 700; font-size: .82rem;
}
.lang-switcher a.active { color: #08110c; background: linear-gradient(135deg, var(--accent-2), #d3ff6e); }
.lang-switcher--mobile { display: none; }
.menu-toggle {
  width: 44px; height: 44px; border: 0; border-radius: 999px; background: rgba(255,255,255,.06);
  display: none; align-items: center; justify-content: center; position: relative; padding: 0;
}
.menu-toggle span {
  position: absolute; width: 18px; height: 2px; background: #fff; border-radius: 999px;
  transition: transform .28s ease, opacity .28s ease;
}
.menu-toggle span:first-child { transform: translateY(-4px); }
.menu-toggle span:last-child { transform: translateY(4px); }
.dynamic-island.is-menu-open .menu-toggle span:first-child { transform: rotate(45deg); }
.dynamic-island.is-menu-open .menu-toggle span:last-child { transform: rotate(-45deg); }

.hero { padding-top: 78px; }
.hero-grid { display: grid; grid-template-columns: minmax(0, 1.08fr) minmax(340px, .92fr); gap: 34px; align-items: center; }
.hero-copy, .hero-visual { position: relative; z-index: 2; }
.hero-text { max-width: 700px; font-size: clamp(1rem, 1.5vw, 1.15rem); margin-top: 10px; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; margin: 28px 0 24px; }
.hero-proof { display: flex; flex-wrap: wrap; gap: 10px; margin-bottom: 26px; }
.hero-proof span, .brand-chip {
  display: inline-flex; align-items: center; min-height: 36px; padding: 0 14px; border-radius: 999px;
  background: rgba(255,255,255,.045); border: 1px solid rgba(255,255,255,.08); color: #d7e1ff; font-size: .88rem;
}
.stats-grid, .cards-grid, .project-grid, .service-grid-enhanced { display: grid; gap: 18px; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.stat-card, .info-card, .process-card, .project-card, .contact-form, .content-card, .about-panel, .testimonials-wrap, .sticky-card, .immersive-panel, .faq-item, .price-calc, .footer-col--brand { padding: 24px; }
.stat-card strong { display: block; font-size: 1.6rem; margin-bottom: 6px; }
.hero-visual { min-height: 560px; }
.dashboard-card { padding: 22px; min-height: 100%; }
.hero-dashboard__screen { display: grid; gap: 18px; }
.dash-top { display: flex; gap: 8px; margin-bottom: 22px; }
.dash-top span { width: 11px; height: 11px; border-radius: 50%; background: rgba(255,255,255,.34); }
.mini-panel { padding: 22px; border-radius: 22px; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); }
.mini-panel--primary { background: linear-gradient(180deg, rgba(168,85,247,.12), rgba(255,255,255,.03)); }
.mini-panel h3 { margin: 8px 0 12px; font-size: clamp(1.25rem, 2vw, 1.8rem); }
.hero-metrics { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
.hero-metric { padding: 18px; border-radius: 18px; background: rgba(255,255,255,.035); border: 1px solid rgba(255,255,255,.06); }
.hero-metric strong { display: block; font-size: 1.5rem; color: #fff; margin-bottom: 6px; }
.mini-bars { display: grid; gap: 12px; }
.mini-bars span {
  display: block; height: 12px; border-radius: 999px;
  background: linear-gradient(90deg, rgba(158,255,56,.82), rgba(168,85,247,.82));
  box-shadow: 0 0 30px rgba(168,85,247,.22);
}
.mini-bars span:nth-child(2) { width: 82%; }
.mini-bars span:nth-child(3) { width: 70%; }
.mini-bars span:nth-child(4) { width: 92%; }
.service-pills, .tag-list { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 10px; }
.service-pills span, .tag-list span, .project-meta {
  display: inline-flex; align-items: center; min-height: 32px; padding: 0 12px; border-radius: 999px; font-size: .82rem;
  background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); color: #d6defa;
}
.float-card { animation: hoverFloat 7s ease-in-out infinite; }
.floating-note {
  position: absolute; padding: 13px 17px; border-radius: 999px; font-weight: 700; font-size: .82rem;
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); background: rgba(8,11,22,.58);
  border: 1px solid rgba(255,255,255,.08);
}
.note-a { top: 6%; right: -1%; }
.note-b { bottom: 7%; left: -1%; }
.hero-orbit {
  position: absolute; border-radius: 50%; filter: blur(24px); opacity: .8; z-index: 1;
}
.hero-orbit-a { width: 320px; height: 320px; right: 12%; top: 10%; background: radial-gradient(circle, rgba(168,85,247,.4), transparent 70%); }
.hero-orbit-b { width: 240px; height: 240px; left: 5%; bottom: 10%; background: radial-gradient(circle, rgba(158,255,56,.22), transparent 70%); }
.brand-strip__label { color: var(--muted); text-align: center; margin-bottom: 18px; }
.brand-strip__row { display: flex; justify-content: center; gap: 12px; flex-wrap: wrap; }
.section-head { display: grid; gap: 16px; margin-bottom: 28px; }
.center { text-align: center; }
.split-head { grid-template-columns: 1.05fr .95fr; align-items: end; }
.service-card-enhanced, .project-card, .immersive-panel, .sticky-card, .faq-item { transition: transform .32s ease, border-color .32s ease, background .32s ease; }
.service-card-enhanced:hover, .project-card:hover, .immersive-panel:hover, .sticky-card:hover, .faq-item:hover { transform: translateY(-6px); border-color: rgba(168,85,247,.26); }
.service-card-featured {
  background: linear-gradient(180deg, rgba(168,85,247,.16), rgba(12,18,36,.92));
  border-color: rgba(168,85,247,.28);
}
.service-card__index {
  width: 44px; height: 44px; display: grid; place-items: center; margin-bottom: 18px; border-radius: 999px;
  background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.08); color: var(--accent-2); font-weight: 700;
}
.split-grid { display: grid; gap: 24px; }
.split-grid-wide { grid-template-columns: .96fr 1.04fr; }
.sticky-copy { position: sticky; top: 112px; align-self: start; }
.sticky-stack { display: grid; gap: 18px; }
.feature-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 12px; }
.feature-list li { position: relative; padding-left: 20px; }
.feature-list li::before {
  content: ""; position: absolute; left: 0; top: 10px; width: 8px; height: 8px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent-2), var(--accent)); box-shadow: 0 0 22px rgba(158,255,56,.7);
}
.process-ribbon { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); padding: 0; overflow: hidden; }
.process-ribbon__item { padding: 28px; position: relative; }
.process-ribbon__item + .process-ribbon__item::before {
  content: ""; position: absolute; top: 18%; bottom: 18%; left: 0; width: 1px; background: rgba(255,255,255,.08);
}
.process-step { display: inline-flex; margin-bottom: 16px; font-weight: 800; color: var(--accent-2); }
.immersive-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.project-thumb {
  height: 230px; border-radius: 20px; margin-bottom: 18px;
  background:
    radial-gradient(circle at 25% 30%, rgba(158,255,56,.22), transparent 30%),
    radial-gradient(circle at 75% 20%, rgba(168,85,247,.3), transparent 32%),
    linear-gradient(135deg, #0d1326, #121b34 55%, #09101d);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07);
}
.testimonials-wrap { padding: 30px; }
.testimonial-track { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; }
.testimonial-card { margin: 0; padding: 22px; border-radius: 20px; background: rgba(255,255,255,.03); border: 1px solid rgba(255,255,255,.06); }
.testimonial-card footer { margin-top: 14px; color: #dce4ff; font-size: .9rem; }
.faq-grid { display: grid; grid-template-columns: .86fr 1.14fr; gap: 28px; align-items: start; }
.faq-item summary { list-style: none; cursor: pointer; font-weight: 700; color: #fff; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item p { margin-top: 14px; }
.page-hero { padding-top: 136px; }
.page-hero__title { margin-top: 18px; }
.page-hero__text { margin-top: 12px; font-size: 1.06rem; }
.pricing-value { font-size: 2.25rem; line-height: 1; color: #fff; margin-bottom: 18px; }

.price-calc { display: grid; grid-template-columns: .9fr 1.1fr .88fr; gap: 20px; align-items: stretch; }
.price-calc--compact { grid-template-columns: .85fr 1.05fr .9fr; }
.price-calc__intro h3 { margin-top: 16px; }
.price-calc__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.price-calc label { display: grid; gap: 8px; }
.price-calc label span { font-size: .86rem; color: #dce4ff; }
.price-calc select,
.contact-form input,
.contact-form textarea {
  width: 100%; min-height: 52px; padding: 14px 16px;
  border-radius: 16px; border: 1px solid rgba(255,255,255,.1); outline: none;
  background: rgba(255,255,255,.04); color: #fff;
}
.contact-form textarea { min-height: 160px; resize: vertical; }
.price-calc__result {
  display: grid; gap: 14px; align-content: start;
  padding: 24px; border-radius: 22px;
  background: linear-gradient(180deg, rgba(168,85,247,.14), rgba(18,24,46,.82));
  border: 1px solid rgba(168,85,247,.24);
}
.price-calc__result small { color: #dce4ff; text-transform: uppercase; letter-spacing: .12em; }
.price-calc__result strong { font-size: clamp(2rem, 4vw, 3rem); line-height: 1; }
.field-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.contact-grid { display: grid; gap: 18px; grid-template-columns: .86fr 1.14fr; }
.contact-list { display: grid; gap: 12px; margin-top: 14px; }
.form-status { margin-top: 14px; color: #fff4b5; }

.footer-cta {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 24px; align-items: center;
  padding: 34px; margin-bottom: 24px;
}
.footer-cta__actions { display: flex; flex-wrap: wrap; gap: 12px; justify-content: flex-end; }
.site-footer { padding: 0 0 42px; position: relative; z-index: 2; }
.footer-grid { display: grid; gap: 18px; grid-template-columns: 1.35fr repeat(4, minmax(0, .7fr)); align-items: start; }
.footer-grid--large { margin-top: 24px; }
.footer-col--brand { min-height: 100%; }
.footer-brand-wrap { display: flex; gap: 14px; align-items: center; margin-bottom: 14px; }
.footer-brand-mark {
  width: 48px; height: 48px; border-radius: 16px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 16px 34px rgba(168,85,247,.22);
}
.footer-brand { font-size: 1.35rem; font-weight: 800; }
.footer-brand-copy { margin: 14px 0 18px; }
.footer-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.footer-list a, .footer-list li { color: var(--muted); }
.footer-list a:hover { color: #fff; }
.footer-bottom {
  display: flex; justify-content: space-between; gap: 18px; padding-top: 22px; margin-top: 22px;
  border-top: 1px solid rgba(255,255,255,.08); color: var(--muted); font-size: .92rem;
}

.reveal { opacity: 0; transform: translateY(26px); transition: opacity .7s ease, transform .7s ease; }
.reveal.is-visible { opacity: 1; transform: none; }
.tilt-card { transform-style: preserve-3d; }

.site-loader {
  position: fixed; inset: 0; z-index: 100;
  display: grid; place-items: center;
  background: radial-gradient(circle at center, rgba(15,20,35,.8), rgba(5,7,16,.98));
  transition: opacity .8s ease, visibility .8s ease;
}
.site-loader.is-hidden { opacity: 0; visibility: hidden; }
.site-loader__inner { position: relative; width: min(88vw, 420px); text-align: center; }
.site-loader__pulse,
.site-loader__ring {
  position: absolute; inset: 50% auto auto 50%; transform: translate(-50%, -50%);
  border-radius: 50%; pointer-events: none;
}
.site-loader__pulse { width: 168px; height: 168px; background: radial-gradient(circle, rgba(168,85,247,.36), transparent 68%); filter: blur(14px); animation: pulseGlow 2.2s ease-in-out infinite; }
.site-loader__ring { width: 132px; height: 132px; border: 1px solid rgba(255,255,255,.14); box-shadow: inset 0 0 30px rgba(255,255,255,.05); animation: spin 4.8s linear infinite; }
.site-loader__wordmark { position: relative; font-size: clamp(2.2rem, 6vw, 3.5rem); font-weight: 800; letter-spacing: -.05em; }
.site-loader__caption { position: relative; margin-top: 12px; color: var(--muted); }
.site-loader__line { position: relative; height: 4px; width: min(100%, 320px); margin: 22px auto 0; border-radius: 999px; overflow: hidden; background: rgba(255,255,255,.06); }
.site-loader__line span { display: block; width: 38%; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--accent), var(--accent-2)); animation: loaderLine 1.55s ease-in-out infinite; }

@keyframes hoverFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
@keyframes pulseGlow {
  0%, 100% { transform: translate(-50%, -50%) scale(.92); opacity: .72; }
  50% { transform: translate(-50%, -50%) scale(1.08); opacity: 1; }
}
@keyframes spin { from { transform: translate(-50%, -50%) rotate(0deg); } to { transform: translate(-50%, -50%) rotate(360deg); } }
@keyframes loaderLine {
  0% { transform: translateX(-120%); }
  50% { transform: translateX(120%); }
  100% { transform: translateX(260%); }
}

@media (max-width: 1180px) {
  .hero-grid, .split-head, .split-grid-wide, .footer-cta, .footer-grid, .faq-grid, .contact-grid, .price-calc { grid-template-columns: 1fr; }
  .footer-cta__actions { justify-content: flex-start; }
  .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .stats-grid, .testimonial-track, .immersive-grid, .project-grid, .service-grid-enhanced { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .process-ribbon { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sticky-copy { position: static; }
}

@media (max-width: 860px) {
  .section { padding: 86px 0; }
  .site-header { top: 12px; padding: 0 10px; }
  .dynamic-island { align-items: flex-start; }
  .dynamic-island__pill {
    width: min(100%, 440px); min-height: 60px; padding: 8px 10px 8px 16px;
    flex-wrap: wrap; align-items: center; justify-content: space-between;
    overflow: hidden;
  }
  .dynamic-island.is-expanded .dynamic-island__pill,
  .dynamic-island.is-menu-open .dynamic-island__pill {
    width: min(100%, 440px);
    border-radius: 28px;
  }
  .desktop-cta, .lang-switcher--desktop, .main-nav { display: none; }
  .menu-toggle, .lang-switcher--mobile { display: inline-flex; }
  .main-nav {
    width: 100%; order: 3; margin-top: 6px; padding-top: 6px;
    max-height: 0; overflow: hidden; transition: max-height .42s ease, opacity .32s ease;
    opacity: 0;
  }
  .dynamic-island.is-menu-open .main-nav { display: block; max-height: 72vh; opacity: 1; overflow-y: auto; }
  .dynamic-island.is-menu-open .dynamic-island__pill { background: rgba(8,11,22,.94); }
  .menu-inline, .menu-inline ul { flex-direction: column; align-items: stretch; width: 100%; }
  .menu-inline a { justify-content: flex-start; width: 100%; min-height: 46px; }
  .main-nav__mobile-meta { display: grid; gap: 12px; padding-top: 10px; }
  .hero { padding-top: 52px; }
  .hero-visual { min-height: 420px; }
  .stats-grid, .cards-grid, .project-grid, .service-grid-enhanced, .testimonial-track, .immersive-grid, .hero-metrics, .price-calc__grid, .field-grid { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; }
  .note-a, .note-b { display: none; }
}

@media (max-width: 560px) {
  .container { width: min(var(--container), calc(100% - 20px)); }
  .dynamic-island__pill { padding-inline: 14px 10px; }
  .brand span { font-size: .98rem; }
  .button { width: 100%; }
  .hero-actions .button, .footer-cta__actions .button { width: 100%; }
  .hero-proof { gap: 8px; }
  .hero-proof span, .brand-chip { width: 100%; justify-content: center; text-align: center; }
  .stat-card, .info-card, .project-card, .contact-form, .price-calc, .footer-col--brand, .testimonials-wrap, .sticky-card, .immersive-panel, .faq-item { padding: 20px; }
  .process-ribbon { grid-template-columns: 1fr; }
  .process-ribbon__item + .process-ribbon__item::before { display: none; }
  .pricing-value { font-size: 1.9rem; }
}


/* ===== v6 final polish ===== */
:root {
  --bg: #030303;
  --bg-2: #09090c;
  --surface: rgba(15, 16, 21, 0.82);
  --surface-2: rgba(16, 18, 24, 0.94);
  --line: rgba(174, 255, 0, 0.16);
  --line-2: rgba(169, 95, 255, 0.2);
  --accent: #8f4dff;
  --accent-2: #b7ff39;
  --accent-3: #2da8ff;
  --muted: #acb3c7;
  --shadow: 0 24px 80px rgba(0,0,0,.48);
  --container: 1240px;
}
body {
  background:
    radial-gradient(circle at 18% 14%, rgba(143,77,255,.18), transparent 24%),
    radial-gradient(circle at 84% 14%, rgba(183,255,57,.12), transparent 22%),
    radial-gradient(circle at 50% 100%, rgba(45,168,255,.12), transparent 26%),
    linear-gradient(180deg, #020202 0%, #06070a 50%, #08090d 100%);
}
.bg-grid { opacity: .14; }
.glass { background: linear-gradient(180deg, rgba(14,14,19,.86), rgba(9,10,15,.92)); border-color: rgba(255,255,255,.075); }
.brand img, .brand .custom-logo, .brand-logo { display:block; max-height:42px; width:auto; }
.footer-logo { display:block; max-width:220px; width:100%; height:auto; }
.loader-logo { max-width: 260px; width: 72vw; height: auto; filter: drop-shadow(0 0 32px rgba(255,255,255,.15)); }
.site-loader__inner { width:min(92vw, 520px); }
.site-loader__halo { position:absolute; inset: 50% auto auto 50%; transform: translate(-50%,-50%); width:260px; height:260px; border-radius:50%; background: radial-gradient(circle, rgba(143,77,255,.25), rgba(183,255,57,.08) 35%, transparent 68%); filter: blur(20px); animation:pulseGlow 2.4s ease-in-out infinite; }
.site-loader__logo { position:relative; z-index:2; display:flex; justify-content:center; }
.site-loader__caption { font-size:.96rem; letter-spacing:.08em; text-transform:uppercase; }
.site-loader__ring { width: 180px; height: 180px; border-color: rgba(255,255,255,.08); }
.site-loader__line span { background: linear-gradient(90deg, var(--accent), var(--accent-3), var(--accent-2)); }
.dynamic-island__pill {
  width:min(100%, 360px); min-height:68px; padding: 10px 12px 10px 16px;
  background: linear-gradient(180deg, rgba(10,11,16,.86), rgba(8,9,13,.92));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 60px rgba(0,0,0,.48), inset 0 1px 0 rgba(255,255,255,.06), 0 0 0 1px rgba(143,77,255,.04);
}
.dynamic-island.is-expanded .dynamic-island__pill { width:min(100%, 1140px); }
.menu-inline a { color:#d8deef; font-weight:500; }
.menu-inline a:hover, .menu-inline .current-menu-item>a { background: rgba(255,255,255,.05); }
.desktop-cta { background: linear-gradient(135deg, var(--accent-2), #d9ff7d 70%); }
.button-primary { color:#101207; }
.hero-v6 { overflow:hidden; padding-top: 92px; }
.hero-grid-v6 { grid-template-columns: 1.05fr .95fr; align-items:center; }
.hero-visual-v6 { min-height: 620px; }
.lightspeed-bg { position:absolute; inset:0; overflow:hidden; pointer-events:none; opacity:.9; }
.lightspeed-bg span {
  position:absolute; left:50%; top:50%; width: 3px; height: 42vh; transform-origin: top center; border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0), rgba(45,168,255,.5), rgba(143,77,255,.7), rgba(183,255,57,.35), rgba(255,255,255,0));
  filter: blur(0.8px); opacity:.9; animation: streakZoom 10s linear infinite;
}
.lightspeed-bg span:nth-child(1){ transform: translate(-50%,-50%) rotate(10deg); animation-delay:-1s; }
.lightspeed-bg span:nth-child(2){ transform: translate(-50%,-50%) rotate(70deg); animation-delay:-5s; }
.lightspeed-bg span:nth-child(3){ transform: translate(-50%,-50%) rotate(138deg); animation-delay:-3s; }
.lightspeed-bg span:nth-child(4){ transform: translate(-50%,-50%) rotate(205deg); animation-delay:-7s; }
.lightspeed-bg span:nth-child(5){ transform: translate(-50%,-50%) rotate(275deg); animation-delay:-2s; }
.lightspeed-bg span:nth-child(6){ transform: translate(-50%,-50%) rotate(328deg); animation-delay:-6s; }
.hero-showpiece { padding: 24px; min-height: 100%; position:relative; overflow:hidden; }
.hero-showpiece::after { content:""; position:absolute; inset:-15%; background: radial-gradient(circle at 50% 40%, rgba(143,77,255,.18), transparent 36%), radial-gradient(circle at 56% 60%, rgba(183,255,57,.08), transparent 28%); filter: blur(10px); }
.hero-showpiece__head { display:flex; align-items:center; gap:8px; margin-bottom:20px; position:relative; z-index:2; }
.hero-showpiece__head span { width:10px; height:10px; border-radius:50%; background: rgba(255,255,255,.25); }
.hero-showpiece__label { margin-left:auto; font-size:.8rem; color:#dbe0ee; text-transform:uppercase; letter-spacing:.12em; }
.hero-showpiece__body { position:relative; z-index:2; display:grid; gap:18px; }
.logo-float { display:flex; justify-content:center; padding: 26px 0 18px; }
.hero-logo { max-width: 320px; width:100%; height:auto; opacity:.96; filter: drop-shadow(0 12px 40px rgba(0,0,0,.42)); }
.hero-insight-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:14px; }
.hero-insight { padding:18px; border-radius: 20px; }
.hero-insight small { display:block; color: var(--muted); margin-bottom:8px; text-transform:uppercase; letter-spacing:.1em; }
.hero-insight strong { display:block; font-size:1rem; }
.hero-spectrum { height: 170px; border-radius: 24px; background: radial-gradient(circle at 50% 45%, rgba(255,255,255,.14), transparent 18%), radial-gradient(circle at 30% 50%, rgba(143,77,255,.55), transparent 26%), radial-gradient(circle at 70% 50%, rgba(183,255,57,.35), transparent 22%), radial-gradient(circle at 50% 70%, rgba(45,168,255,.25), transparent 24%), linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)); box-shadow: inset 0 1px 0 rgba(255,255,255,.07); }
.stats-grid-hero { grid-template-columns: repeat(3, minmax(0,1fr)); }
.tilt-grid { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 24px; perspective:1200px; }
.tilt-card-card { background:#ececec; color:#202020; border-radius:28px; overflow:hidden; box-shadow: 0 20px 60px rgba(0,0,0,.32); transform-style: preserve-3d; transition: transform .24s ease; }
.tilt-card-card__media { height: 300px; background-size:cover; background-position:center; }
.tilt-card-card__body { padding: 28px; background:#f0f1f3; }
.tilt-card-card__body h3 { margin-bottom: 12px; }
.tilt-card-card__body p { color:#5e6169; }
.media-1 { background: linear-gradient(135deg, #0e6f95, #132533 70%); }
.media-2 { background: linear-gradient(135deg, #fd8a4d, #4a2548 70%); }
.media-3 { background: linear-gradient(135deg, #79d0ff, #17324d 75%); }
.engine-grid { position:relative; display:grid; grid-template-columns: 1fr 420px 1fr; grid-template-rows: repeat(2, minmax(120px, auto)); gap: 24px 32px; align-items:center; min-height: 420px; }
.engine-core { grid-column:2; grid-row:1 / span 2; min-height: 230px; display:grid; place-content:center; text-align:center; padding:30px; position:relative; z-index:2; }
.engine-core__icon { width:72px; height:72px; border-radius:22px; display:grid; place-items:center; margin:0 auto 16px; background: rgba(255,255,255,.05); box-shadow: 0 0 50px rgba(255,255,255,.12), 0 0 60px rgba(183,255,57,.1); font-size: 2rem; }
.engine-node { position:relative; z-index:2; padding:24px; border-radius:22px; background: rgba(255,255,255,.03); border:1px solid rgba(255,255,255,.08); }
.engine-node strong { display:block; margin-bottom:6px; }
.engine-node span { color:var(--muted); }
.engine-node--left.top { grid-column:1; grid-row:1; }
.engine-node--left.mid { grid-column:1; grid-row:2; }
.engine-node--right.top { grid-column:3; grid-row:1; }
.engine-node--right.mid { grid-column:3; grid-row:2; }
.engine-lines { position:absolute; inset:0; width:100%; height:100%; z-index:1; }
.engine-lines path { fill:none; stroke: rgba(255,255,255,.12); stroke-width:2; }
.h-scroll { display:grid; grid-auto-flow: column; grid-auto-columns: minmax(320px, 420px); gap: 18px; overflow-x:auto; padding-bottom: 8px; scroll-snap-type: x mandatory; }
.h-scroll__item { scroll-snap-align:start; min-height: 500px; display:grid; align-content:start; gap:16px; }
.h-scroll__badge { display:inline-flex; align-items:center; height:34px; padding:0 14px; border-radius:999px; background: rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.08); width:max-content; }
.h-scroll__visual { margin-top:auto; height: 220px; border-radius:24px; background: linear-gradient(135deg, rgba(143,77,255,.32), rgba(45,168,255,.14) 55%, rgba(183,255,57,.2)); }
.visual-2 { background: linear-gradient(135deg, rgba(183,255,57,.24), rgba(143,77,255,.2) 55%, rgba(255,255,255,.08)); }
.visual-3 { background: linear-gradient(135deg, rgba(45,168,255,.28), rgba(143,77,255,.18) 55%, rgba(255,255,255,.06)); }
.visual-4 { background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(143,77,255,.2) 45%, rgba(183,255,57,.22)); }
.project-meta-row { display:flex; flex-wrap:wrap; gap:8px; }
.compare-slider { position:relative; min-height: 620px; overflow:hidden; }
.compare-pane { position:absolute; inset:0; }
.compare-pane--after { clip-path: inset(0 0 0 50%); }
.compare-surface { position:absolute; inset:0; padding:34px; display:grid; gap:24px; }
.compare-surface--before { background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.015)); }
.compare-surface--after { background: radial-gradient(circle at 75% 25%, rgba(143,77,255,.18), transparent 24%), linear-gradient(180deg, rgba(12,15,24,.8), rgba(8,9,13,.96)); }
.compare-label { display:inline-flex; width:max-content; min-height:38px; align-items:center; padding:0 16px; border-radius:999px; background: rgba(143,77,255,.9); color:#fff; }
.compare-pane--after .compare-label { background: rgba(17,18,21,.9); border: 1px solid rgba(255,255,255,.12); }
.wireframe-card, .final-card { border-radius:24px; }
.wireframe-card--one { height: 180px; background: linear-gradient(135deg, rgba(255,255,255,.08), rgba(255,255,255,.02)); border:1px solid rgba(255,255,255,.08); }
.wireframe-card--two { height: 260px; width: 58%; background: linear-gradient(135deg, rgba(255,255,255,.06), rgba(255,255,255,.02)); border:1px dashed rgba(255,255,255,.18); }
.final-card--hero { height: 230px; background: radial-gradient(circle at 30% 35%, rgba(255,255,255,.14), transparent 12%), linear-gradient(135deg, rgba(143,77,255,.35), rgba(45,168,255,.16) 52%, rgba(183,255,57,.18)); box-shadow: inset 0 1px 0 rgba(255,255,255,.1); }
.final-card--metrics { margin-left:auto; width: 72%; height: 220px; background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.03)); border:1px solid rgba(255,255,255,.08); }
.compare-handle { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:72px; height:72px; border-radius:999px; display:grid; place-items:center; background: rgba(11,12,16,.88); border:1px solid rgba(255,255,255,.1); box-shadow: 0 18px 40px rgba(0,0,0,.32); z-index:4; cursor: ew-resize; }
.compare-handle span { position:absolute; width: 2px; height: 22px; background:#fff; border-radius:99px; }
.compare-handle span:first-child { transform: translateX(-6px); }
.compare-handle span:last-child { transform: translateX(6px); }
.text-mask-word {
  font-size: clamp(5rem, 18vw, 15rem); line-height:.9; font-weight: 900; letter-spacing: -.08em; color: transparent;
  background-image: radial-gradient(circle at 30% 35%, rgba(255,255,255,.9), rgba(255,255,255,.45) 20%, transparent 21%), linear-gradient(135deg, rgba(255,255,255,.95) 0%, rgba(255,255,255,.9) 12%, rgba(143,77,255,.7) 45%, rgba(45,168,255,.75) 68%, rgba(183,255,57,.58) 100%);
  -webkit-background-clip: text; background-clip:text; filter: drop-shadow(0 18px 40px rgba(0,0,0,.32));
}
.text-mask-copy { margin-top:18px; max-width: 760px; }
.feature-flip-grid { display:grid; grid-template-columns: 1.12fr .88fr; gap:22px; }
.feature-panel { min-height: 520px; position:relative; overflow:hidden; padding:26px; display:flex; flex-direction:column; justify-content:space-between; }
.feature-panel::before { content:""; position:absolute; inset:0; background: radial-gradient(circle at 24% 22%, rgba(255,255,255,.14), transparent 18%), radial-gradient(circle at 80% 80%, rgba(143,77,255,.18), transparent 26%), linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)); }
.feature-panel--wide::after { content:""; position:absolute; inset:auto 7% 8% 42%; height: 220px; border-radius: 28px; background: linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,.06)); transform: rotate(-8deg); opacity:.7; }
.feature-panel--tall::after { content:""; position:absolute; inset:0; background: radial-gradient(circle at 50% 35%, rgba(183,255,57,.15), transparent 25%), linear-gradient(180deg, rgba(255,255,255,.02), rgba(143,77,255,.12)); }
.feature-chip { position:relative; z-index:2; display:inline-flex; width:max-content; min-height:40px; align-items:center; padding:0 16px; border-radius:999px; background: rgba(255,255,255,.72); color:#111; font-weight:700; }
.feature-panel__body { position:relative; z-index:2; max-width: 72%; }
.feature-panel__body h3 { font-size: clamp(2rem, 4vw, 4rem); margin: 0 0 12px; }
.price-calc { grid-template-columns: .82fr 1.18fr .95fr; gap: 22px; border-radius: 32px; }
.price-calc__grid--advanced { grid-template-columns: repeat(2, minmax(0,1fr)); }
.price-calc input[type="range"] { width:100%; }
.price-calc input[type="text"] { width:100%; min-height:52px; padding:14px 16px; border-radius:16px; border:1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04); color:#fff; }
.price-calc .range-value { display:inline-flex; min-height: 34px; align-items:center; width:max-content; padding:0 12px; border-radius:999px; background: rgba(255,255,255,.05); border: 1px solid rgba(255,255,255,.08); }
.checkbox-stack { grid-column: span 2; }
.checkbox-stack > span:first-child { margin-bottom: 8px; }
.checkbox-stack > span:not(:first-child) { display:flex; align-items:center; gap:10px; min-height:42px; padding: 10px 12px; border-radius: 14px; background: rgba(255,255,255,.03); margin-top:8px; }
.checkbox-stack input { accent-color: var(--accent-2); }
.calc-breakdown { display:grid; gap:10px; }
.calc-breakdown span { display:flex; justify-content:space-between; gap:12px; padding:10px 12px; border-radius: 14px; background: rgba(255,255,255,.04); color: #dbe1ee; }
.footer-grid--final { grid-template-columns: 1.3fr repeat(4, minmax(0,.78fr)); }
.footer-col--brand { padding: 28px; }
.footer-brand-logo { display:flex; align-items:center; }
.footer-brand-wrap { margin-bottom: 18px; }
.footer-bottom { margin-top: 28px; }
.h-scroll::-webkit-scrollbar { height: 10px; }
.h-scroll::-webkit-scrollbar-thumb { background: rgba(255,255,255,.12); border-radius:999px; }
@keyframes streakZoom { 0% { opacity:0; transform-origin:center top; } 20% { opacity:.85; } 100% { opacity:0; transform: translate(-50%,-50%) scale(1.26) rotate(var(--r,0deg)); } }
@media (max-width: 1180px) {
  .hero-grid-v6, .feature-flip-grid, .engine-grid, .price-calc { grid-template-columns: 1fr; }
  .engine-core { grid-column:auto; grid-row:auto; }
  .engine-node--left.top, .engine-node--left.mid, .engine-node--right.top, .engine-node--right.mid { grid-column:auto; grid-row:auto; }
  .engine-lines { display:none; }
  .tilt-grid, .hero-insight-grid { grid-template-columns: 1fr 1fr; }
  .footer-grid--final { grid-template-columns: repeat(2, minmax(0,1fr)); }
}
@media (max-width: 860px) {
  .dynamic-island__pill { width:min(100%, 92vw); padding: 10px 12px; }
  .dynamic-island.is-expanded .dynamic-island__pill,
  .dynamic-island.is-menu-open .dynamic-island__pill { width:min(100%, 92vw); }
  .brand { flex:1; min-width:0; }
  .brand-logo { max-width: 160px; }
  .main-nav { order:4; width:100%; }
  .dynamic-island.is-menu-open .main-nav { max-height: 68vh; padding-top:8px; }
  .menu-inline a { min-height: 48px; }
  .nav-actions { gap:8px; }
  .menu-toggle { display:inline-flex; flex-shrink:0; }
  .desktop-cta, .lang-switcher--desktop { display:none; }
  .lang-switcher--mobile { display:inline-flex; }
  .hero-grid-v6, .tilt-grid, .hero-insight-grid, .feature-flip-grid, .price-calc__grid--advanced, .stats-grid-hero { grid-template-columns: 1fr; }
  .hero-visual-v6 { min-height: auto; }
  .compare-slider { min-height: 480px; }
  .feature-panel, .feature-panel--wide, .feature-panel--tall { min-height: 340px; }
  .feature-panel__body { max-width: 100%; }
  .footer-grid--final { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  h1 { font-size: clamp(2.5rem, 10vw, 4rem); }
  .dynamic-island__pill { border-radius: 28px; min-height: 62px; }
  .brand-logo { max-width: 132px; }
  .menu-toggle { width:42px; height:42px; }
  .site-loader__halo { width:180px; height:180px; }
  .compare-slider { min-height: 380px; }
  .compare-surface { padding: 18px; }
  .wireframe-card--two, .final-card--metrics { width: 100%; }
  .text-mask-word { font-size: clamp(4rem, 24vw, 7rem); }
}


/* --- v7 homepage polish overrides --- */
.site-header { padding-inline: 14px; }
.dynamic-island { --pill-compact: 880px; --pill-wide: 1120px; }
.dynamic-island__pill {
  width: min(100%, var(--pill-compact));
  gap: 14px;
  padding: 10px 14px 10px 16px;
  overflow: hidden;
}
.dynamic-island.is-expanded .dynamic-island__pill { width: min(100%, var(--pill-wide)); }
.dynamic-island.play-intro .dynamic-island__pill { animation: islandIntroDesktop 1.25s cubic-bezier(.2,.9,.2,1) both; }
.brand { flex: 0 0 auto; }
.brand img, .brand .custom-logo, .brand-logo { max-height: 28px; width: auto; display:block; }
.main-nav { flex: 1 1 auto; min-width: 0; }
.menu-inline, .menu-inline ul { gap: 2px; justify-content: center; }
.menu-inline a {
  height: 40px;
  padding-inline: 12px;
  font-size: .88rem;
  font-weight: 600;
}
.nav-actions { gap: 8px; }
.desktop-cta { min-height: 42px; padding-inline: 16px; font-size: .92rem; }
.lang-switcher { flex-shrink: 0; }
.lang-switcher a { min-width: 40px; }

.hero-home { padding-top: 68px; overflow: clip; }
.hero-home__grid {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.06fr) minmax(360px, .94fr);
  gap: 32px;
  align-items: start;
}
.hero-home__copy { padding-top: 18px; }
.hero-home__copy h1 { max-width: 10.5ch; }
.hero-home__stage { display: grid; gap: 18px; }
.hero-orb {
  position: absolute; inset: auto; pointer-events: none; z-index: 0; filter: blur(70px); opacity: .55;
  width: 320px; height: 320px; border-radius: 50%;
}
.hero-orb--violet { left: -70px; top: 50px; background: radial-gradient(circle, rgba(168,85,247,.34), transparent 68%); }
.hero-orb--green { right: -40px; bottom: 30px; background: radial-gradient(circle, rgba(158,255,56,.26), transparent 68%); }
.hero-stage { padding: 22px; min-height: 440px; }
.hero-stage__chrome { display:flex; gap:8px; margin-bottom: 18px; }
.hero-stage__chrome span { width: 10px; height: 10px; border-radius:50%; background: rgba(255,255,255,.26); }
.hero-stage__screen {
  min-height: 360px;
  border-radius: 24px;
  padding: 24px;
  background: linear-gradient(180deg, rgba(7,10,20,.96), rgba(11,16,32,.92));
  border: 1px solid rgba(255,255,255,.06);
  display: grid;
  align-content: start;
  gap: 18px;
  overflow: hidden;
}
.hero-stage__headline { font-size: .84rem; letter-spacing: .18em; text-transform: uppercase; color: #ccd7f5; }
.hero-stage__grid { display:grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 10px; }
.hero-stage__panel {
  min-height: 130px; border-radius: 22px; padding: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.02));
  border: 1px solid rgba(255,255,255,.08);
  display:grid; align-content:start; gap:10px;
}
.hero-stage__panel--primary {
  grid-column: span 2;
  min-height: 170px;
  background:
    radial-gradient(circle at 78% 30%, rgba(158,255,56,.16), transparent 18%),
    radial-gradient(circle at 28% 68%, rgba(168,85,247,.18), transparent 22%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
}
.hero-stage__panel small { color: #cad5f3; text-transform: uppercase; letter-spacing: .16em; font-size: .72rem; }
.hero-stage__panel strong { font-size: 1.14rem; line-height: 1.28; }
.hero-stage__panel--wide { grid-column: span 2; min-height: 120px; }
.hero-stage__bars { display:flex; gap:10px; align-items:flex-end; height: 70px; }
.hero-stage__bars span {
  display:block; flex:1; border-radius: 999px;
  background: linear-gradient(180deg, rgba(168,85,247,.9), rgba(82,182,255,.75));
  box-shadow: 0 0 28px rgba(168,85,247,.18);
}
.hero-stage__bars span:nth-child(1) { height: 48%; }
.hero-stage__bars span:nth-child(2) { height: 82%; background: linear-gradient(180deg, rgba(158,255,56,.9), rgba(82,182,255,.65)); }
.hero-stage__bars span:nth-child(3) { height: 63%; }
.hero-side-card { padding: 24px; }
.hero-side-card h3 { max-width: 18ch; margin-top: 12px; }
.eyebrow--small { font-size: .72rem; }
.hero-stats-compact { grid-template-columns: repeat(2, minmax(0,1fr)); max-width: 560px; }
.hero-stats-compact .stat-card:last-child { grid-column: span 2; }

.engine-section .section-head { margin-bottom: 30px; }
.engine-system {
  position: relative; min-height: 700px; border-radius: 34px; padding: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.01));
  border: 1px solid rgba(255,255,255,.07);
  overflow: hidden;
}
.engine-system__orbit {
  position:absolute; inset:50% auto auto 50%; transform: translate(-50%, -50%);
  border-radius: 50%; border: 1px solid rgba(255,255,255,.06);
}
.engine-system__orbit--one { width: 420px; height: 420px; animation: spin 16s linear infinite; }
.engine-system__orbit--two { width: 620px; height: 620px; animation: spin 24s linear infinite reverse; }
.engine-system__core {
  position:absolute; inset:50% auto auto 50%; transform: translate(-50%, -50%);
  width: 280px; min-height: 280px; border-radius: 36px; padding: 26px; text-align:center;
  display:grid; align-content:center; gap: 10px; z-index:3;
}
.engine-system__core::after {
  content: ""; position:absolute; inset: 18px; border-radius: inherit;
  border: 1px solid rgba(255,255,255,.06); pointer-events:none;
}
.engine-system__core-icon {
  width: 72px; height: 72px; border-radius: 24px; margin: 0 auto 8px;
  display:grid; place-items:center; font-size: 2rem;
  background: radial-gradient(circle at 50% 50%, rgba(255,255,255,.3), rgba(255,255,255,.05));
  box-shadow: 0 0 60px rgba(168,85,247,.18), 0 0 40px rgba(158,255,56,.09);
}
.engine-system__node {
  position:absolute; width: 220px; min-height: 120px; padding: 18px 18px 16px;
  display:grid; gap:8px; z-index: 2;
}
.engine-system__node strong { font-size: 1.02rem; }
.engine-system__node span { color: var(--muted); line-height: 1.55; }
.engine-system__node::before {
  content:""; position:absolute; width: 10px; height:10px; border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 0 18px rgba(168,85,247,.34);
}
.node-1 { top: 6%; left: 8%; }
.node-1::before { right: -22px; top: 50%; transform: translateY(-50%); }
.node-2 { top: 32%; left: 3%; }
.node-2::before { right: -22px; top: 50%; transform: translateY(-50%); }
.node-3 { bottom: 7%; left: 9%; }
.node-3::before { right: -22px; top: 50%; transform: translateY(-50%); }
.node-4 { top: 6%; right: 8%; }
.node-4::before { left: -22px; top: 50%; transform: translateY(-50%); }
.node-5 { top: 32%; right: 3%; }
.node-5::before { left: -22px; top: 50%; transform: translateY(-50%); }
.node-6 { bottom: 7%; right: 9%; }
.node-6::before { left: -22px; top: 50%; transform: translateY(-50%); }
.engine-system::before,
.engine-system::after {
  content: ""; position: absolute; inset: 0; pointer-events:none;
  background:
    linear-gradient(90deg, transparent 0 12%, rgba(255,255,255,.08) 12% calc(12% + 1px), transparent calc(12% + 1px) 50%, rgba(255,255,255,.08) 50% calc(50% + 1px), transparent calc(50% + 1px) 88%, rgba(255,255,255,.08) 88% calc(88% + 1px), transparent calc(88% + 1px));
  mask: radial-gradient(circle at center, transparent 0 118px, black 119px);
  opacity: .22;
}
.engine-system::after {
  background:
    linear-gradient(180deg, transparent 0 12%, rgba(255,255,255,.08) 12% calc(12% + 1px), transparent calc(12% + 1px) 50%, rgba(255,255,255,.08) 50% calc(50% + 1px), transparent calc(50% + 1px) 88%, rgba(255,255,255,.08) 88% calc(88% + 1px), transparent calc(88% + 1px));
}
.showcase-bento {
  display:grid; grid-template-columns: 1.15fr .85fr .85fr; gap: 18px; align-items: stretch;
}
.showcase-card { padding: 22px; min-height: 470px; display:grid; align-content:start; gap:14px; }
.showcase-card--featured { min-height: 540px; }
.showcase-card__meta { display:flex; justify-content:space-between; gap:10px; color:#d6e1ff; font-size: .8rem; text-transform: uppercase; letter-spacing: .12em; }
.showcase-card__visual {
  margin-top: auto; min-height: 220px; border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.08);
}
.showcase-card--featured .showcase-card__visual { min-height: 300px; }
.perception-grid { display:grid; grid-template-columns: .9fr 1.1fr; gap: 36px; align-items: end; }
.perception-copy { max-width: 650px; }
.perception-copy h2 { margin-bottom: 14px; }
.perception-copy .feature-list { margin-top: 18px; }
.text-mask-word { margin-top: 14px; }

.price-calc {
  align-items: start;
  grid-template-columns: .82fr 1.18fr .88fr;
  gap: 18px;
  padding: 26px;
  border-radius: 34px;
}
.price-calc__intro,
.price-calc__grid,
.price-calc__result {
  padding: 18px;
  border-radius: 24px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.06);
}
.price-calc__grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: 14px 16px; }
.price-calc__grid label { display:grid; gap: 8px; }
.price-calc__grid label > span,
.checkbox-stack > span:first-child { color:#dbe4ff; font-size:.86rem; font-weight: 600; }
.price-calc select,
.price-calc input[type="text"] {
  width:100%; min-height: 52px; padding: 0 16px; border-radius: 16px;
  border: 1px solid rgba(255,255,255,.1); color: #fff; background: rgba(9,12,24,.96);
  appearance: none; -webkit-appearance:none;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.04);
}
.price-calc select { background-image: linear-gradient(45deg, transparent 50%, #dfe6f7 50%), linear-gradient(135deg, #dfe6f7 50%, transparent 50%); background-position: calc(100% - 22px) calc(50% - 4px), calc(100% - 16px) calc(50% - 4px); background-size: 6px 6px, 6px 6px; background-repeat:no-repeat; padding-right: 42px; }
.price-calc select option { background: #101526; color: #eef3ff; }
.price-calc input[type="range"] { accent-color: var(--accent-2); }
.range-value { font-size: .84rem; color:#ebf2ff; }
.checkbox-stack { grid-column: span 2; }
.checkbox-stack > span:not(:first-child) {
  min-height: 48px; border-radius: 16px; background: rgba(255,255,255,.025);
  border:1px solid rgba(255,255,255,.05);
}
.price-calc__result small { display:block; color:#d3dcf5; text-transform: uppercase; letter-spacing:.14em; margin-bottom: 8px; }
.price-calc__result strong[data-price-output] { display:block; font-size: clamp(2rem, 4vw, 3rem); line-height:1; margin-bottom: 12px; }
.price-calc__result p { margin-bottom: 18px; }
.calc-breakdown span { background: rgba(255,255,255,.025); }
.calc-breakdown em { font-style: normal; color: #cdd8f2; }
.calc-breakdown strong { color: #f4f7ff; font-size: 1rem; }

@keyframes islandIntroDesktop {
  0% { width: min(100%, 340px); transform: translateY(4px) scale(.97); }
  55% { width: min(100%, var(--pill-wide)); transform: translateY(0) scale(1); }
  100% { width: min(100%, var(--pill-compact)); }
}
@keyframes islandIntroMobile {
  0% { width: 62px; border-radius: 999px; }
  55% { width: min(100%, 92vw); border-radius: 28px; }
  100% { width: min(100%, 92vw); border-radius: 28px; }
}

@media (max-width: 1180px) {
  .dynamic-island { --pill-compact: 1000px; --pill-wide: 1000px; }
  .hero-home__grid, .perception-grid, .showcase-bento, .price-calc { grid-template-columns: 1fr; }
  .showcase-card, .showcase-card--featured { min-height: 420px; }
  .engine-system { min-height: auto; padding: 24px; display:grid; grid-template-columns: 1fr 1fr; gap: 16px; }
  .engine-system__core, .engine-system__node { position: relative; inset: auto; transform:none; width:auto; min-height: 0; }
  .engine-system__core { order: -1; grid-column: 1 / -1; }
  .engine-system__orbit, .engine-system::before, .engine-system::after { display:none; }
  .engine-system__node::before { display:none; }
}
@media (max-width: 1040px) {
  .site-header { top: 12px; }
  .dynamic-island__pill { width: min(100%, 94vw); }
  .desktop-cta { display:none; }
  .menu-inline a { padding-inline: 10px; font-size: .82rem; }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 24px; }
}
@media (max-width: 980px) {
  .section { padding: 84px 0; }
  .site-header { padding-inline: 10px; }
  .dynamic-island { --pill-compact: 92vw; --pill-wide: 92vw; align-items: flex-start; }
  .dynamic-island.play-intro .dynamic-island__pill { animation: islandIntroMobile 1.15s cubic-bezier(.2,.9,.2,1) both; }
  .dynamic-island__pill {
    width: min(100%, 92vw); min-height: 62px; padding: 8px 10px 8px 12px;
    grid-template-columns: auto 1fr auto; display:grid; align-items:center;
  }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 16px; }
  .desktop-cta, .lang-switcher--desktop, .main-nav { display:none; }
  .menu-toggle { display:inline-flex; }
  .main-nav {
    width:100%; grid-column: 1 / -1; order: 4; margin-top: 8px; padding-top: 8px;
    max-height: 0; opacity: 0; overflow: hidden; transition: max-height .4s ease, opacity .3s ease;
  }
  .dynamic-island.is-menu-open .main-nav { display:block; max-height: 72vh; opacity: 1; overflow-y: auto; }
  .dynamic-island.is-menu-open .dynamic-island__pill { background: rgba(8,11,22,.95); border-radius: 28px; }
  .menu-inline, .menu-inline ul { flex-direction: column; align-items: stretch; width:100%; gap: 2px; }
  .menu-inline a { width: 100%; justify-content:flex-start; min-height: 44px; font-size: 1rem; padding-inline: 10px; }
  .main-nav__mobile-meta { display:grid; gap: 10px; padding-top: 10px; }
  .lang-switcher--mobile { display:inline-flex; width: fit-content; max-width: 124px; padding: 3px; }
  .lang-switcher--mobile a { min-width: 52px; height: 34px; }
  .main-nav__mobile-meta .button { width: 100%; }
  .hero-home { padding-top: 52px; }
  .hero-home__copy h1 { max-width: none; }
  .hero-stats-compact { grid-template-columns: 1fr; max-width:none; }
  .hero-stats-compact .stat-card:last-child { grid-column: auto; }
  .hero-stage { min-height: auto; }
  .hero-stage__screen { min-height: auto; }
  .hero-stage__grid { grid-template-columns: 1fr; }
  .hero-stage__panel--primary, .hero-stage__panel--wide { grid-column: auto; }
  .showcase-bento, .perception-grid, .price-calc__grid { grid-template-columns: 1fr; }
  .checkbox-stack { grid-column: auto; }
}
@media (max-width: 560px) {
  .dynamic-island__pill { min-height: 58px; }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 13px; }
  .hero-actions .button { width: 100%; }
  .showcase-card, .showcase-card--featured { min-height: 360px; }
  .text-mask-word { font-size: clamp(3.8rem, 24vw, 6rem); }
  .price-calc { padding: 18px; }
}


/* --- v8 nav + compare refinement --- */
.dynamic-island { --pill-compact: 760px; --pill-wide: 920px; }
.dynamic-island__pill { padding: 10px 14px; gap: 12px; }
.brand img, .brand .custom-logo, .brand-logo { max-height: 30px; }
.main-nav { flex: 1 1 auto; }
.menu-inline, .menu-inline ul { gap: 4px; }
.menu-inline li:nth-child(n+5) { display:none; }
.menu-inline a { padding-inline: 12px; font-size: .9rem; }
.desktop-cta { min-width: 104px; padding-inline: 14px; }
.lang-switcher { min-width: 84px; }
@media (max-width: 1100px) {
  .dynamic-island { --pill-compact: 92vw; --pill-wide: 92vw; }
  .menu-inline a { padding-inline: 10px; font-size: .84rem; }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 26px; }
}
@media (max-width: 980px) {
  .brand img, .brand .custom-logo, .brand-logo { max-height: 22px; }
  .menu-inline li:nth-child(n+1) { display:block; }
  .lang-switcher--mobile { max-width: 96px; }
  .lang-switcher--mobile a { min-width: 42px; padding-inline: 10px; }
  .main-nav__mobile-meta { grid-template-columns: auto 1fr; align-items:center; }
  .main-nav__mobile-meta .button { width: auto; justify-self: end; min-width: 124px; }
}
@media (max-width: 560px) {
  .dynamic-island__pill { width:min(100%, 94vw); }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 20px; }
  .main-nav__mobile-meta { grid-template-columns: 1fr; }
  .main-nav__mobile-meta .button { width:100%; justify-self: stretch; }
}
.compare-slider { min-height: 620px; }
.compare-surface--image { padding: 0; overflow: hidden; }
.compare-surface--image img { width: 100%; height: 100%; object-fit: cover; display:block; }
.compare-surface--image::after {
  content:''; position:absolute; inset:auto 0 0 0; height: 32%;
  background: linear-gradient(180deg, transparent, rgba(5,8,18,.34) 45%, rgba(5,8,18,.65) 100%);
  pointer-events:none;
}
.compare-label { position:absolute; z-index:2; top: 20px; left: 20px; }
.compare-pane--after .compare-label { left: auto; right: 20px; }
@media (max-width: 980px) {
  .compare-slider { min-height: 420px; }
}


/* --- v9 navigation, hero, carousel, calculator, footer --- */
.dynamic-island { --pill-compact: 540px; --pill-wide: 860px; }
.dynamic-island__pill { width:min(100%, var(--pill-compact)); justify-content:space-between; }
.dynamic-island .desktop-cta, .main-nav__mobile-meta .button { display:none !important; }
.main-nav { flex: 0 1 auto; }
.menu-inline, .menu-inline ul { gap: 6px; }
.menu-inline a { white-space: nowrap; }
.brand { min-width: 0; display:flex; align-items:center; }
.brand img, .brand .custom-logo, .brand-logo { max-height: 42px; width:auto; }
.dynamic-island.is-expanded .dynamic-island__pill { width:min(100%, var(--pill-wide)); }
@media (max-width: 1100px){ .dynamic-island { --pill-compact: 92vw; --pill-wide: 92vw; } }
@media (max-width:980px){
  .dynamic-island { --pill-compact: 88vw; --pill-wide: 92vw; }
  .dynamic-island__pill { grid-template-columns: auto 1fr auto; padding: 8px 12px; }
  .brand img, .brand .custom-logo, .brand-logo { max-height: 28px; }
  .lang-switcher--mobile { max-width: 104px; }
  .lang-switcher--mobile a { min-width: 46px; }
}
@media (max-width:560px){ .brand img, .brand .custom-logo, .brand-logo { max-height: 24px; } }

.site-loader__logo { overflow:hidden; }
.site-loader__logo .custom-logo-link, .site-loader__logo img { display:block; }
.site-loader__logo { clip-path: inset(0 100% 0 0); animation: revealLogo 1.45s ease forwards .18s; }
@keyframes revealLogo { to { clip-path: inset(0 0 0 0); } }

.hero-home__grid { grid-template-columns: minmax(0, 1.08fr) minmax(340px, .92fr); gap: 42px; align-items:center; }
.hero-home__copy { max-width: 700px; }
.hero-home__copy h1 { max-width: 10.6ch; }
.hero-proof { margin-top: 18px; }
.hero-metrics-strip {
  display:grid; grid-template-columns: repeat(4,minmax(0,1fr)); gap: 18px; margin-top: 26px;
  padding-top: 16px; border-top: 1px solid rgba(255,255,255,.08);
}
.metric-item strong { display:block; font-size: clamp(2rem, 4vw, 3.6rem); line-height: .95; font-weight: 500; color: #f3f6ff; }
.metric-item span { display:block; margin-top: 8px; color:#bfc9e2; }
.hero-stage { min-height: 0; }
.hero-stage__screen { min-height: 420px; }
.hero-side-card { min-height: 0; }
@media (max-width: 980px){ .hero-metrics-strip { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 560px){ .hero-metrics-strip { grid-template-columns: 1fr; } }

.engine-system { min-height: 760px; }
.engine-system__orbit--one, .engine-system__orbit--two { border-style: dashed; }
.engine-system__orbit::after {
  content:''; position:absolute; top:50%; left:50%; width:10px; height:10px; border-radius:50%;
  background: radial-gradient(circle, #dff2ff 0, var(--accent) 55%, transparent 60%);
  box-shadow: 0 0 24px rgba(143,77,255,.45), 0 0 18px rgba(173,255,47,.24);
  transform: translate(-50%, -50%) translateX(calc(50% - 6px));
}
.engine-system__orbit--one::after { animation: orbitDot 8.4s linear infinite; }
.engine-system__orbit--two::after { animation: orbitDot 13s linear infinite reverse; }
@keyframes orbitDot { from { transform: translate(-50%,-50%) rotate(0deg) translateX(calc(210px - 6px)) rotate(0deg);} to { transform: translate(-50%,-50%) rotate(360deg) translateX(calc(210px - 6px)) rotate(-360deg);} }
.engine-system__orbit--two::after { animation-name: orbitDotLarge; }
@keyframes orbitDotLarge { from { transform: translate(-50%,-50%) rotate(0deg) translateX(calc(310px - 6px)) rotate(0deg);} to { transform: translate(-50%,-50%) rotate(360deg) translateX(calc(310px - 6px)) rotate(-360deg);} }

.curve-carousel { position:relative; overflow:hidden; padding: 20px 0 6px; mask-image: linear-gradient(90deg, transparent, #000 8%, #000 92%, transparent); }
.curve-carousel__track { display:flex; gap:18px; align-items:flex-end; will-change: transform; }
.curve-card { flex: 0 0 290px; min-height: 320px; padding: 22px; border-radius: 28px; position:relative; overflow:hidden; }
.curve-card:nth-child(odd) { transform: perspective(900px) rotateY(12deg) translateY(16px); }
.curve-card:nth-child(even) { transform: perspective(900px) rotateY(-10deg) translateY(-6px); }
.curve-card__tag { display:inline-flex; padding:7px 12px; border-radius:999px; background: rgba(255,255,255,.06); color:#dbe5fd; font-size:.76rem; margin-bottom: 16px; }
.curve-card h3 { margin-bottom: 10px; }
.curve-card::after { content:''; position:absolute; inset:auto -10% -18% auto; width:220px; height:220px; border-radius:50%; background: radial-gradient(circle, rgba(143,77,255,.22), transparent 60%); pointer-events:none; }

.compare-slider, .compare-slider * { user-select:none; -webkit-user-select:none; }
.compare-slider img { -webkit-user-drag:none; user-drag:none; pointer-events:none; }

.page-hero { padding-top: 144px; }
.page-hero__inner { max-width: 1120px; }
.page-hero__title { max-width: 14ch; text-align:left; }
.page-hero__text { max-width: 760px; text-align:left; }
.page-hero .container { margin-inline:auto; }

.service-icon { width:48px; height:48px; border-radius:16px; display:grid; place-items:center; background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); color:#f1f5ff; margin-bottom: 18px; }
.service-icon svg { width:22px; height:22px; }

.price-calc { grid-template-columns: .84fr 1.16fr .92fr; gap: 22px; }
.price-calc__grid { gap: 18px 18px; }
.price-calc__result { position: sticky; top: 110px; }
.calc-breakdown { display:grid; gap: 10px; }
.calc-breakdown span { display:flex; justify-content:space-between; gap: 14px; padding: 12px 14px; border-radius: 16px; }
.price-calc select:focus, .price-calc input[type="text"]:focus { outline:none; border-color: rgba(173,255,47,.45); box-shadow: 0 0 0 4px rgba(173,255,47,.08); }
@media (max-width: 1180px){ .price-calc__result { position: static; } }

.footer-grid { grid-template-columns: 1.2fr .8fr .8fr .9fr .8fr; align-items:start; }
.footer-brand-logo .brand-logo { max-height: 38px; }
.footer-socials { display:flex; flex-wrap:wrap; gap: 10px; margin-top: 18px; }
.social-icon { width:42px; height:42px; border-radius: 14px; display:grid; place-items:center; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); color:#eef4ff; }
.social-icon svg { width:18px; height:18px; }
@media (max-width: 980px){ .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px){ .footer-grid { grid-template-columns: 1fr; } }

.cookie-consent { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 90; }
.cookie-consent__inner { display:flex; gap: 18px; align-items:center; justify-content:space-between; padding: 18px 20px; }
.cookie-consent__inner p { margin: 6px 0 0; max-width: 680px; }
.cookie-consent__actions { display:flex; gap: 10px; flex-wrap:wrap; }
@media (max-width: 760px){ .cookie-consent__inner { display:grid; } }


/* v10 polish */
.site-loader__halo,
.site-loader__ring { display: none; }
.site-loader__inner { gap: 18px; }
.site-loader__logo img,
.site-loader__logo .custom-logo { max-height: 74px; width: auto; filter: drop-shadow(0 0 22px rgba(255,255,255,.12)); }
.site-loader__caption { opacity: .9; letter-spacing: .06em; }
.site-loader__line {
  width: min(420px, 72vw);
  height: 10px;
  padding: 1px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  overflow: hidden;
}
.site-loader__line span {
  display: block; width: 0; height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(255,255,255,.1), rgba(255,255,255,.92));
}

.dynamic-island { --island-collapsed: 560px; --island-expanded: 1120px; }
.dynamic-island__pill {
  width: min(100%, var(--island-collapsed));
  padding: 10px 16px;
  gap: 14px;
}
.dynamic-island.is-expanded .dynamic-island__pill,
.dynamic-island:hover .dynamic-island__pill { width: min(100%, var(--island-expanded)); }
.brand { flex: 0 0 auto; min-width: 142px; }
.brand img, .brand .custom-logo { max-height: 50px; width: auto; object-fit: contain; }
.main-nav { flex: 1 1 auto; overflow: hidden; }
.menu-inline { justify-content: center; flex-wrap: nowrap; gap: 2px; }
.menu-inline a {
  font-size: .84rem;
  padding: 0 10px;
  height: 38px;
  opacity: .92;
}
.nav-actions { gap: 8px; }
.lang-switcher { flex: 0 0 auto; }
.menu-toggle { display: none; }

.hero-home { padding-top: 76px; }
.hero-home__grid { align-items: start; gap: 26px; }
.hero-proof { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 20px; }
.hero-proof span {
  display: inline-flex; align-items: center;
  min-height: 34px; padding: 0 12px; border-radius: 999px;
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.08);
  color: #d9e2ff; font-size: .82rem;
}
.hero-metrics-strip {
  display: grid; grid-template-columns: repeat(4, minmax(0,1fr));
  gap: 14px; margin-top: 18px;
}
.metric-item {
  display: grid; gap: 6px; justify-items: center;
  text-align: center; padding: 18px 12px;
  border-radius: 20px; background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}
.metric-item strong { font-size: clamp(2rem, 3vw, 3rem); line-height: 1; }
.metric-item span { font-size: .88rem; color: var(--muted); }
.hero-stage__screen { min-height: 380px; }
.hero-stage__panel strong { font-size: 1rem; }
.hero-side-card { margin-top: 14px; }

.page-hero { padding: 82px 0 42px; }
.page-hero__inner { max-width: 980px; }
.page-hero .eyebrow { margin-bottom: 18px; }
.page-hero__title {
  max-width: 760px;
  font-size: clamp(2rem, 4vw, 3.3rem);
  line-height: 1.05;
  text-align: left;
}
.page-hero__text {
  max-width: 680px;
  margin-top: 6px;
  font-size: 1rem;
}

.compare-slider, .compare-slider * { user-select: none; -webkit-user-select: none; -webkit-touch-callout: none; }
.compare-slider img { pointer-events: none; user-drag: none; -webkit-user-drag: none; }

.price-calc { padding: 28px; }
.price-calc__intro { max-width: 340px; }
.price-calc__grid--advanced { align-items: start; }
.price-calc__grid label { gap: 8px; }
.price-calc select,
.price-calc input[type="text"],
.price-calc textarea {
  width: 100%; min-height: 48px;
  border-radius: 16px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.1);
  color: var(--text); padding: 0 14px;
}
.price-calc select option { color: #111; }
.checkbox-stack span {
  display: flex; align-items: center; gap: 10px;
  min-height: 44px; padding: 0 14px;
  border-radius: 14px; background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
}
.price-calc__result {
  align-self: stretch;
  position: sticky; top: 100px;
}
.calc-breakdown { display: grid; gap: 10px; margin: 18px 0 22px; }
.calc-breakdown div {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 12px 14px; border-radius: 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  color: #dce5ff;
}

.footer-brand-logo img, .footer-brand-logo .custom-logo { max-height: 58px; width: auto; object-fit: contain; }
.footer-grid--large { gap: 24px; }
.footer-list a { opacity: .88; }

@media (max-width: 1180px) {
  .dynamic-island { --island-collapsed: 500px; --island-expanded: 980px; }
  .brand { min-width: 128px; }
  .menu-inline a { padding: 0 8px; font-size: .8rem; }
}

@media (max-width: 980px) {
  .site-header { top: 12px; padding: 0 10px; }
  .dynamic-island,
  .dynamic-island.is-expanded { --island-collapsed: 100%; --island-expanded: 100%; }
  .dynamic-island__pill {
    min-height: 62px;
    gap: 12px;
    padding: 10px 12px 10px 14px;
  }
  .brand { min-width: 120px; }
  .brand img, .brand .custom-logo { max-height: 42px; }
  .menu-inline a { font-size: .74rem; padding: 0 7px; }
  .lang-switcher a { min-width: 38px; height: 32px; font-size: .78rem; }
  .hero-home__grid { grid-template-columns: 1fr; }
  .hero-home__stage { order: 2; }
  .hero-home__copy { order: 1; }
  .hero-metrics-strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .split-head, .perception-grid, .showcase-bento, .split-grid, .price-calc { grid-template-columns: 1fr; }
  .price-calc__intro { max-width: none; }
  .price-calc__result { position: static; }
  .engine-system {
    min-height: 760px;
    padding: 120px 12px 24px;
  }
  .engine-system__core { position: relative; inset: auto; transform: none; margin: 0 auto 18px; width: min(100%, 320px); }
  .engine-system__node { position: relative !important; inset: auto !important; width: 100%; max-width: none; margin-bottom: 12px; }
}

@media (max-width: 760px) {
  .section { padding: 76px 0; }
  h1 { font-size: clamp(2.4rem, 12vw, 4rem); }
  h2 { font-size: clamp(1.7rem, 8vw, 2.5rem); }
  .dynamic-island__pill { border-radius: 28px; }
  .brand { min-width: 132px; }
  .brand img, .brand .custom-logo { max-height: 36px; }
  .main-nav {
    position: fixed; inset: 82px 12px auto 12px;
    max-height: calc(100vh - 108px);
    overflow: auto;
    padding: 14px;
    border-radius: 24px;
    background: rgba(8,11,22,.95);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 22px 50px rgba(0,0,0,.45);
    opacity: 0; visibility: hidden; transform: translateY(-10px);
    transition: opacity .28s ease, transform .28s ease, visibility .28s ease;
  }
  body.menu-open .main-nav { opacity: 1; visibility: visible; transform: none; }
  .main-nav .menu-inline { display: grid; gap: 6px; justify-content: stretch; }
  .main-nav .menu-inline a {
    justify-content: flex-start;
    width: 100%;
    height: 46px;
    padding: 0 14px;
    font-size: .95rem;
    border-radius: 14px;
  }
  .main-nav__mobile-meta { display: block; margin-top: 12px; }
  .lang-switcher--mobile { width: fit-content; }
  .lang-switcher--desktop { display: none; }
  .menu-toggle {
    display: inline-flex; width: 42px; height: 42px; border-radius: 50%;
    align-items: center; justify-content: center; border: 1px solid rgba(255,255,255,.08);
    background: rgba(255,255,255,.04); position: relative;
  }
  .menu-toggle span {
    position: absolute; width: 16px; height: 2px; background: #fff; border-radius: 999px;
    transition: transform .25s ease, opacity .25s ease;
  }
  .menu-toggle span:first-child { transform: translateY(-4px); }
  .menu-toggle span:last-child { transform: translateY(4px); }
  body.menu-open .menu-toggle span:first-child { transform: rotate(45deg); }
  body.menu-open .menu-toggle span:last-child { transform: rotate(-45deg); }
  .hero-home { padding-top: 42px; }
  .hero-actions { flex-wrap: wrap; }
  .hero-proof { display: none; }
  .hero-stage__screen { min-height: 0; }
  .hero-stage__grid { grid-template-columns: 1fr; }
  .hero-stage__panel--wide { grid-column: auto; }
  .hero-metrics-strip { gap: 10px; }
  .metric-item { padding: 14px 10px; }
  .tilt-grid { grid-template-columns: 1fr; }
  .price-calc { padding: 18px; }
  .price-calc__grid--advanced { display: grid; grid-template-columns: 1fr; gap: 14px; }
  .price-calc__result { margin-top: 8px; }
  .showcase-bento { gap: 14px; }
  .compare-wrap .section-head { margin-bottom: 18px; }
  .text-mask-word { font-size: clamp(3rem, 16vw, 5.5rem); }
  .footer-cta { grid-template-columns: 1fr; gap: 18px; }
  .footer-grid--large { grid-template-columns: 1fr 1fr; }
}

@media (max-width: 540px) {
  .container { width: min(var(--container), calc(100% - 20px)); }
  .site-header { padding: 0 6px; }
  .dynamic-island__pill { padding: 10px 10px 10px 12px; gap: 8px; }
  .brand { min-width: 118px; }
  .brand img, .brand .custom-logo { max-height: 32px; }
  .metric-item strong { font-size: 1.75rem; }
  .hero-metrics-strip { grid-template-columns: 1fr 1fr; }
  .footer-grid--large { grid-template-columns: 1fr; }
  .page-hero { padding: 72px 0 30px; }
  .page-hero__title { font-size: clamp(1.7rem, 9vw, 2.3rem); }
  .page-hero__text { font-size: .96rem; }
}


/* --- final stability pass / mobile polish --- */
:root { --app-vh: 1vh; }
html, body { max-width: 100%; }
body.menu-open { touch-action: none; }
.brand { position: relative; z-index: 3; }
.brand img,
.brand .custom-logo,
.brand-logo {
  display: block;
  width: auto;
  max-width: min(100%, 210px);
  height: auto;
  object-fit: contain;
  filter: drop-shadow(0 6px 16px rgba(0,0,0,.42));
}
.custom-logo-link { display: inline-flex; align-items: center; }
.dynamic-island { width: 100%; }
.dynamic-island__pill {
  overflow: visible;
  align-items: center;
  isolation: isolate;
}
.main-nav { min-width: 0; }
.menu-inline { min-width: 0; }
.menu-inline li { min-width: 0; }
.menu-inline a {
  text-align: center;
  overflow: hidden;
  text-overflow: ellipsis;
}
.hero-home__copy,
.hero-home__stage,
.section-head,
.price-calc__intro,
.price-calc__grid,
.price-calc__result,
.contact-form,
.footer-cta,
.footer-col--brand { min-width: 0; }
.hero-stage,
.hero-side-card,
.price-calc,
.compare-slider,
.showcase-card,
.tilt-card-card,
.contact-form { overflow: hidden; }
.showcase-card__visual,
.tilt-card-card__media {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.media-1 { background-image: linear-gradient(135deg, rgba(14,111,149,.28), rgba(19,37,51,.78)), url('../images/showcase-homepage.png'); }
.media-2 { background-image: linear-gradient(135deg, rgba(253,138,77,.20), rgba(74,37,72,.72)), url('../images/showcase-system.png'); }
.media-3 { background-image: linear-gradient(135deg, rgba(121,208,255,.18), rgba(23,50,77,.72)), url('../images/showcase-pricing.png'); }
.visual-1 { background: linear-gradient(135deg, rgba(183,255,57,.18), rgba(143,77,255,.18) 55%, rgba(255,255,255,.06)), url('../images/showcase-services-mobile.png') center/cover no-repeat; }
.visual-2 { background: linear-gradient(135deg, rgba(183,255,57,.18), rgba(143,77,255,.18) 55%, rgba(255,255,255,.06)), url('../images/showcase-portfolio-mobile.png') center/cover no-repeat; }
.visual-3 { background: linear-gradient(135deg, rgba(45,168,255,.18), rgba(143,77,255,.18) 55%, rgba(255,255,255,.05)), url('../images/showcase-process-mobile.png') center/cover no-repeat; }
.compare-surface--image img { object-position: center top; }
.contact-form input,
.contact-form textarea,
.price-calc select,
.price-calc input[type="text"],
.price-calc textarea { min-width: 0; }
.field-grid > *,
.price-calc__grid > *,
.footer-grid > * { min-width: 0; }
.calc-breakdown span,
.calc-breakdown div { flex-wrap: wrap; }

@media (max-width: 1180px) {
  .dynamic-island__pill { gap: 12px; }
  .brand img, .brand .custom-logo, .brand-logo { max-width: 188px; }
  .menu-inline a { padding-inline: 10px; font-size: .82rem; }
}

@media (max-width: 980px) {
  .site-header { top: 10px; padding-inline: 10px; }
  .dynamic-island__pill {
    width: 100%;
    min-height: 60px;
    padding: 9px 10px 9px 12px;
    gap: 10px;
    border-radius: 24px;
  }
  .brand { min-width: 0; flex: 1 1 auto; }
  .brand img, .brand .custom-logo, .brand-logo { max-width: 170px; max-height: 34px; }
  .nav-actions { margin-left: auto; gap: 6px; }
  .lang-switcher--desktop { display: inline-flex; }
  .lang-switcher--desktop a { min-width: 34px; height: 30px; font-size: .76rem; }
  .main-nav {
    position: fixed;
    left: 10px;
    right: 10px;
    top: calc(env(safe-area-inset-top, 0px) + 76px);
    max-height: calc((var(--app-vh) * 100) - 92px);
    padding: 12px;
    border-radius: 22px;
    background: rgba(7,10,20,.97);
    border: 1px solid rgba(255,255,255,.08);
    box-shadow: 0 28px 60px rgba(0,0,0,.45);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(-10px) scale(.985);
    transition: opacity .24s ease, transform .24s ease, visibility .24s ease;
    overflow-y: auto;
    overscroll-behavior: contain;
    z-index: 40;
    display: block;
  }
  .dynamic-island.is-menu-open .main-nav,
  body.menu-open .main-nav {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0) scale(1);
  }
  .main-nav .menu-inline,
  .main-nav .menu-inline ul {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }
  .main-nav .menu-inline a {
    justify-content: flex-start;
    width: 100%;
    min-height: 46px;
    height: auto;
    padding: 12px 14px;
    border-radius: 14px;
    font-size: .95rem;
    white-space: normal;
    line-height: 1.35;
  }
  .main-nav__mobile-meta { display: grid; gap: 12px; padding-top: 10px; }
  .lang-switcher--mobile { display: inline-flex; }
  .menu-toggle {
    display: inline-flex;
    width: 42px;
    height: 42px;
    flex: 0 0 42px;
    border-radius: 999px;
    align-items: center;
    justify-content: center;
  }
  .hero-home { padding-top: 40px; }
  .hero-home__grid { grid-template-columns: 1fr; gap: 18px; }
  .hero-home__copy h1 { max-width: 11.2ch; }
  .hero-stage { min-height: auto; }
  .hero-stage__screen { min-height: 0; padding: 18px; }
  .hero-stage__grid,
  .showcase-bento,
  .perception-grid,
  .price-calc,
  .footer-cta,
  .footer-grid--final,
  .footer-grid,
  .field-grid { grid-template-columns: 1fr; }
  .hero-metrics-strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .compare-slider { min-height: 460px; }
  .compare-handle { width: 62px; height: 62px; }
  .price-calc__result { position: static; top: auto; }
}

@media (max-width: 640px) {
  .site-header { padding-inline: 8px; }
  .dynamic-island__pill { padding-inline: 10px; gap: 8px; }
  .brand img, .brand .custom-logo, .brand-logo { max-width: 150px; max-height: 30px; }
  .lang-switcher--desktop a { min-width: 32px; }
  .hero-home__copy h1 { max-width: 9.8ch; }
  .hero-actions, .footer-cta__actions { display: grid; grid-template-columns: 1fr; }
  .hero-actions .button, .footer-cta__actions .button { width: 100%; }
  .hero-proof { display: none; }
  .metric-item { padding: 14px 10px; }
  .metric-item strong { font-size: 1.7rem; }
  .tilt-card-card__media { height: 220px; }
  .showcase-card__visual { min-height: 180px; }
  .showcase-card--featured .showcase-card__visual { min-height: 220px; }
  .compare-slider { min-height: 360px; }
  .compare-label { min-height: 34px; padding-inline: 12px; font-size: .76rem; }
  .text-mask-word { font-size: clamp(3.3rem, 20vw, 5.4rem); }
  .price-calc { padding: 16px; border-radius: 24px; }
  .price-calc__intro, .price-calc__grid, .price-calc__result, .contact-form { padding: 16px; border-radius: 18px; }
}

@media (max-width: 420px) {
  .dynamic-island__pill { min-height: 58px; }
  .brand img, .brand .custom-logo, .brand-logo { max-width: 138px; max-height: 28px; }
  .lang-switcher--desktop a { min-width: 30px; height: 28px; font-size: .72rem; }
  .menu-toggle { width: 40px; height: 40px; flex-basis: 40px; }
  .hero-metrics-strip { grid-template-columns: 1fr; }
  .hero-home__copy h1 { max-width: none; }
}

/* --- Final home page and navigation polish --- */
.hero-home__grid--formal { align-items: center; }
.hero-proof--formal { gap: 10px; }
.hero-proof--formal span {
  border-color: rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
  color: #dbe4ff;
}
.formal-pricing-block { padding: 30px; }
.formal-pricing-block p:last-of-type { max-width: 1080px; }

@media (min-width: 981px) {
  .dynamic-island {
    --island-collapsed: 520px;
    --island-expanded: 1120px;
  }
  .dynamic-island__pill {
    overflow: hidden;
    gap: 16px;
  }
  .brand-logo,
  .brand img,
  .brand .custom-logo {
    max-width: 230px;
    max-height: 34px;
  }
  .main-nav {
    flex: 1 1 auto;
    max-width: 0;
    opacity: 0;
    pointer-events: none;
    transform: translateX(10px);
    transition: max-width .34s ease, opacity .22s ease, transform .34s ease;
  }
  .dynamic-island.is-expanded .main-nav,
  .dynamic-island:hover .main-nav,
  .dynamic-island.is-menu-open .main-nav {
    max-width: 680px;
    opacity: 1;
    pointer-events: auto;
    transform: translateX(0);
  }
  .main-nav .menu-inline,
  .main-nav .menu-inline ul {
    justify-content: center;
    flex-wrap: nowrap;
    gap: 22px;
  }
  .main-nav .menu-inline a {
    white-space: nowrap;
    font-size: .95rem;
  }
}

@media (max-width: 980px) {
  .hero-home__grid--formal { gap: 22px; }
  .hero-proof--formal { grid-template-columns: 1fr; }
  .formal-pricing-block { padding: 22px; }
}

/* --- Hero redesign: compact left copy + animated AI workspace --- */
.hero-home {
  padding-top: clamp(34px, 5vw, 62px);
  min-height: calc(var(--app-vh, 1vh) * 100 - 92px);
  display: flex;
  align-items: center;
}
.hero-home__grid--chat {
  grid-template-columns: minmax(0, .82fr) minmax(420px, 1.08fr);
  gap: clamp(20px, 2.5vw, 36px);
  align-items: center;
}
.hero-home__copy {
  padding-top: 0;
  max-width: 540px;
}
.hero-home__copy h1 {
  max-width: 9.8ch;
  font-size: clamp(2.65rem, 4.75vw, 4.95rem);
  line-height: .95;
  letter-spacing: -0.05em;
}
.hero-actions { margin: 24px 0 16px; }
.hero-mini-line {
  font-size: .92rem;
  line-height: 1.55;
  color: #b7c4e7;
  letter-spacing: .02em;
}
.hero-home__stage { display: block; }
.hero-chat-scene {
  position: relative;
  min-height: 520px;
  padding: 24px;
  overflow: hidden;
  border-radius: 34px;
  background:
    radial-gradient(circle at 10% 14%, rgba(168,85,247,.18), transparent 26%),
    radial-gradient(circle at 100% 0%, rgba(82,182,255,.18), transparent 28%),
    radial-gradient(circle at 72% 100%, rgba(158,255,56,.08), transparent 22%),
    linear-gradient(180deg, rgba(6,8,17,.98), rgba(4,7,16,.97));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 30px 80px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.04);
}
.hero-chat-scene::before {
  content: "";
  position: absolute;
  inset: 14px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.045);
  pointer-events: none;
}
.hero-chat-scene__workspace {
  position: absolute;
  inset: 96px 26px 26px 26px;
  border-radius: 28px;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(4,5,11,.98), rgba(1,3,8,.98));
  border: 1px solid rgba(255,255,255,.06);
}
.hero-chat-scene__workspace::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 0% 50%, rgba(168,85,247,.14), transparent 34%),
    radial-gradient(circle at 100% 18%, rgba(82,182,255,.16), transparent 34%),
    radial-gradient(circle at 70% 100%, rgba(158,255,56,.06), transparent 28%);
  opacity: .95;
}
.hero-chat-scene__sidebar {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 235px;
  z-index: 2;
  padding: 22px 18px;
  background: linear-gradient(180deg, rgba(10,13,25,.92), rgba(8,11,20,.84));
  border-right: 1px solid rgba(255,255,255,.07);
}
.hero-app-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1.05rem;
  color: #eef2ff;
}
.hero-app-brand__mark {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: conic-gradient(from 180deg, rgba(168,85,247,.95), rgba(82,182,255,.95), rgba(158,255,56,.9), rgba(168,85,247,.95));
  box-shadow: 0 0 24px rgba(126,98,255,.28);
}
.hero-app-button {
  margin-top: 22px;
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: #edf1ff;
  background: rgba(255,255,255,.025);
  border: 1px solid rgba(255,255,255,.09);
  font-size: .92rem;
}
.hero-app-list {
  display: grid;
  gap: 18px;
  margin-top: 26px;
}
.hero-app-list span {
  position: relative;
  padding-left: 22px;
  color: rgba(221,230,255,.54);
  font-size: .88rem;
}
.hero-app-list span::before {
  content: "";
  position: absolute;
  left: 0;
  top: .38rem;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  border: 1px solid rgba(255,255,255,.34);
}
.hero-chat-scene__canvas {
  position: absolute;
  inset: 0 0 0 235px;
  background:
    radial-gradient(circle at 24% 50%, rgba(168,85,247,.12), transparent 34%),
    radial-gradient(circle at 88% 28%, rgba(82,182,255,.18), transparent 34%),
    radial-gradient(circle at 50% 100%, rgba(158,255,56,.05), transparent 24%),
    linear-gradient(180deg, rgba(1,3,8,.2), rgba(1,3,8,.02));
}
.hero-floating-composer {
  position: absolute;
  z-index: 4;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: min(760px, calc(100% - 90px));
  padding: 22px 22px 16px;
  border-radius: 24px;
  background: rgba(2,4,10,.96);
  border: 1px solid rgba(255,255,255,.1);
  box-shadow:
    0 26px 64px rgba(0,0,0,.44),
    0 0 0 1px rgba(168,85,247,.18),
    0 0 42px rgba(82,182,255,.12);
}
.hero-floating-composer::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background: linear-gradient(90deg, rgba(168,85,247,.5), rgba(82,182,255,.45), rgba(158,255,56,.22));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: .8;
}
.hero-floating-composer__top,
.hero-floating-composer__bottom {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.hero-model-pill,
.hero-globe-pill,
.hero-action-pills span,
.hero-send-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 14px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.02);
  color: #eef2ff;
}
.hero-globe-pill { min-width: 38px; padding: 0; }
.hero-prompt-line {
  position: relative;
  z-index: 1;
  min-height: 88px;
  display: flex;
  align-items: center;
  padding: 12px 0 10px;
  font-size: clamp(1.05rem, 1.7vw, 1.55rem);
  color: #f6f8ff;
  line-height: 1.35;
  font-weight: 500;
}
.hero-prompt-text { display: inline; }
.hero-caret {
  display: inline-block;
  width: 10px;
  height: 1.35em;
  margin-left: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(168,85,247,.95), rgba(82,182,255,.95));
  animation: heroCaretBlink 1s step-end infinite;
  vertical-align: -0.18em;
}
@keyframes heroCaretBlink { 50% { opacity: .18; } }
.hero-floating-composer__bottom { align-items: flex-end; }
.hero-action-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.hero-action-pills span {
  min-height: 36px;
  font-size: .92rem;
  padding-inline: 12px;
}
.hero-send-button {
  min-width: 92px;
  background: linear-gradient(180deg, rgba(168,85,247,.16), rgba(82,182,255,.16));
  box-shadow: 0 0 0 1px rgba(82,182,255,.18), inset 0 1px 0 rgba(255,255,255,.05);
}
.hero-chat-feed {
  position: absolute;
  right: 26px;
  bottom: 28px;
  z-index: 3;
  width: min(390px, calc(100% - 300px));
  display: grid;
  gap: 12px;
}
.hero-chat-bubble {
  max-width: 100%;
  padding: 14px 16px;
  border-radius: 18px;
  font-size: .95rem;
  line-height: 1.55;
  box-shadow: 0 14px 34px rgba(0,0,0,.28);
}
.hero-chat-bubble--user {
  justify-self: end;
  color: #f5f7ff;
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.045));
  border: 1px solid rgba(255,255,255,.09);
}
.hero-chat-bubble--assistant {
  justify-self: start;
  color: #b8d0ff;
  background: linear-gradient(180deg, rgba(168,85,247,.18), rgba(82,182,255,.1));
  border: 1px solid rgba(126,137,255,.24);
}
.hero-metrics-section { padding-top: 0; }
.hero-home + .hero-metrics-section { margin-top: -10px; }
.hero-metrics-strip {
  margin-top: 0;
  grid-template-columns: repeat(4, minmax(0,1fr));
}

@media (max-width: 1199px) {
  .hero-home {
    min-height: auto;
    align-items: stretch;
  }
  .hero-home__grid--chat {
    grid-template-columns: 1fr;
  }
  .hero-home__copy { max-width: 700px; }
  .hero-home__copy h1 { max-width: 12.2ch; }
  .hero-chat-scene { min-height: 500px; }
}

@media (max-width: 980px) {
  .hero-home { padding-top: 38px; }
  .hero-chat-scene {
    min-height: 500px;
    padding: 18px;
  }
  .hero-chat-scene__workspace {
    inset: 88px 18px 18px 18px;
  }
  .hero-chat-scene__sidebar { width: 178px; padding: 18px 14px; }
  .hero-chat-scene__canvas { inset: 0 0 0 178px; }
  .hero-floating-composer {
    width: calc(100% - 36px);
    top: 14px;
    padding: 16px 16px 14px;
  }
  .hero-prompt-line { min-height: 72px; font-size: 1.05rem; }
  .hero-chat-feed {
    right: 18px;
    bottom: 18px;
    width: calc(100% - 220px);
  }
}

@media (max-width: 680px) {
  .hero-home__copy h1 {
    max-width: none;
    font-size: clamp(2.35rem, 10vw, 3.2rem);
  }
  .hero-mini-line { font-size: .84rem; }
  .hero-chat-scene {
    min-height: 420px;
    border-radius: 24px;
  }
  .hero-chat-scene__workspace {
    inset: 104px 14px 14px 14px;
    border-radius: 20px;
  }
  .hero-chat-scene__sidebar {
    width: 132px;
    padding: 14px 10px;
  }
  .hero-app-brand { font-size: .9rem; }
  .hero-app-button {
    margin-top: 14px;
    min-height: 34px;
    font-size: .8rem;
  }
  .hero-app-list { gap: 12px; margin-top: 16px; }
  .hero-app-list span {
    padding-left: 16px;
    font-size: .74rem;
  }
  .hero-app-list span::before { width: 8px; height: 8px; top: .34rem; }
  .hero-chat-scene__canvas { inset: 0 0 0 132px; }
  .hero-floating-composer {
    top: 12px;
    width: calc(100% - 28px);
    border-radius: 18px;
  }
  .hero-floating-composer__top,
  .hero-floating-composer__bottom { gap: 8px; }
  .hero-model-pill,
  .hero-globe-pill,
  .hero-action-pills span,
  .hero-send-button {
    min-height: 32px;
    padding-inline: 10px;
    font-size: .78rem;
    border-radius: 10px;
  }
  .hero-globe-pill { min-width: 32px; }
  .hero-prompt-line {
    min-height: 58px;
    padding: 8px 0;
    font-size: .92rem;
  }
  .hero-chat-feed {
    position: static;
    width: auto;
    margin: 180px 10px 0 152px;
    gap: 10px;
  }
  .hero-chat-bubble {
    padding: 12px 13px;
    font-size: .82rem;
    border-radius: 14px;
  }
  .hero-metrics-strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
}

@media (max-width: 480px) {
  .hero-actions { display: grid; grid-template-columns: 1fr; }
  .hero-chat-scene__sidebar { display: none; }
  .hero-chat-scene__canvas { inset: 0; }
  .hero-chat-feed { margin: 156px 8px 0; }
  .hero-metrics-strip { grid-template-columns: 1fr; }
}

/* --- v15 hero finale + back to top --- */
.hero-home__grid--chat { grid-template-columns: minmax(0, .86fr) minmax(440px, 1.04fr); gap: clamp(22px, 2.4vw, 38px); }
.hero-home__copy { max-width: 590px; }
.hero-home__copy h1 {
  max-width: 11.4ch;
  font-size: clamp(2.8rem, 5vw, 5.15rem);
  line-height: .96;
  letter-spacing: -.055em;
  text-wrap: balance;
}
.hero-actions { margin: 22px 0 14px; }
.hero-mini-line {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 36px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.07);
  color: #c2d0ee;
}
.hero-chat-scene {
  min-height: 560px;
  padding: 22px;
  border-radius: 36px;
  background:
    radial-gradient(circle at 10% 10%, rgba(127,86,217,.22), transparent 28%),
    radial-gradient(circle at 100% 0%, rgba(43,118,255,.18), transparent 26%),
    radial-gradient(circle at 84% 100%, rgba(74,222,128,.08), transparent 20%),
    linear-gradient(180deg, rgba(6,8,18,.98), rgba(5,8,16,.98));
  box-shadow: 0 34px 90px rgba(0,0,0,.44), inset 0 1px 0 rgba(255,255,255,.05), 0 0 0 1px rgba(124,92,255,.08);
}
.hero-chat-scene::after {
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:inherit;
  padding:1px;
  background: linear-gradient(135deg, rgba(136,95,255,.28), rgba(68,143,255,.18) 45%, rgba(61,213,156,.12) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events:none;
}
.hero-scene-glow,
.hero-scene-grid,
.hero-scene-badge,
.hero-scene-inline-cta { position:absolute; z-index:1; }
.hero-scene-glow {
  width: 240px; height: 240px; border-radius: 999px; filter: blur(34px); opacity:.5; pointer-events:none;
}
.hero-scene-glow--violet { top:-40px; right:10%; background: radial-gradient(circle, rgba(133,90,255,.45), transparent 68%); animation: heroFloatA 8.4s ease-in-out infinite; }
.hero-scene-glow--cyan { bottom:-26px; left:38%; background: radial-gradient(circle, rgba(79,169,255,.28), transparent 68%); animation: heroFloatB 10.5s ease-in-out infinite; }
.hero-scene-grid {
  inset: 20px;
  border-radius: 28px;
  background-image: linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 36px 36px;
  opacity: .18;
  mask-image: radial-gradient(circle at 50% 50%, #000 42%, transparent 100%);
  pointer-events:none;
}
.hero-scene-badge {
  top: 22px; right: 24px;
  min-height: 34px; padding: 0 12px; border-radius: 999px;
  display:inline-flex; align-items:center;
  color:#d7e4ff; font-size:.8rem; letter-spacing:.04em;
  background: rgba(8,10,18,.68); border:1px solid rgba(255,255,255,.09);
  backdrop-filter: blur(12px);
}
.hero-chat-scene__workspace { inset: 92px 24px 24px 24px; }
.hero-chat-scene__workspace::before {
  background:
    radial-gradient(circle at 8% 50%, rgba(124,92,255,.18), transparent 36%),
    radial-gradient(circle at 100% 10%, rgba(82,182,255,.22), transparent 34%),
    radial-gradient(circle at 72% 100%, rgba(61,213,156,.08), transparent 28%);
}
.hero-chat-scene__sidebar {
  width: 220px;
  background: linear-gradient(180deg, rgba(10,13,24,.9), rgba(7,10,18,.82));
  backdrop-filter: blur(12px);
}
.hero-app-button {
  background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 10px 24px rgba(0,0,0,.18);
}
.hero-app-list span { color: rgba(225,234,255,.64); }
.hero-chat-scene__canvas::after {
  content:"";
  position:absolute; inset: 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.05);
  pointer-events:none;
}
.hero-floating-composer {
  top: 18px;
  width: min(760px, calc(100% - 74px));
  padding: 20px 20px 15px;
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(4,7,14,.98), rgba(6,10,18,.95));
  box-shadow: 0 24px 70px rgba(0,0,0,.42), 0 0 0 1px rgba(124,92,255,.12), 0 0 52px rgba(76,120,255,.1);
}
.hero-model-pill,
.hero-globe-pill,
.hero-action-pills span,
.hero-send-button {
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.12);
}
.hero-model-pill {
  background: linear-gradient(180deg, rgba(126,95,255,.16), rgba(62,128,255,.12));
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 0 0 1px rgba(118,112,255,.12);
}
.hero-prompt-line {
  min-height: 96px;
  color:#f7f9ff;
  text-wrap: balance;
}
.hero-send-button {
  background: linear-gradient(180deg, rgba(126,95,255,.2), rgba(62,128,255,.15));
  color:#fff;
}
.hero-chat-feed {
  right: 22px;
  bottom: 20px;
  width: min(372px, calc(100% - 272px));
  gap: 10px;
  z-index:4;
}
.hero-chat-bubble {
  backdrop-filter: blur(16px);
  border-radius: 20px;
}
.hero-chat-bubble--user {
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.045));
}
.hero-chat-bubble--assistant {
  color:#d7e6ff;
  background: linear-gradient(180deg, rgba(123,94,255,.2), rgba(62,128,255,.12));
}
.hero-scene-inline-cta {
  left: 246px;
  right: 26px;
  bottom: 20px;
  z-index: 4;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  min-height: 48px;
  padding: 0 14px;
  border-radius: 16px;
  background: rgba(8,11,19,.72);
  border:1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 32px rgba(0,0,0,.22);
}
.hero-scene-inline-cta span { color:#c6d4f1; font-size:.84rem; }
.hero-scene-inline-cta a {
  display:inline-flex; align-items:center; justify-content:center;
  min-height: 34px; padding: 0 12px; border-radius: 10px;
  color:#fff; background: linear-gradient(135deg, rgba(127,95,255,.9), rgba(66,136,255,.88));
  box-shadow: 0 10px 24px rgba(74,94,255,.24);
}
.hero-scene-inline-cta a:hover { transform: translateY(-1px); }
@keyframes heroFloatA { 0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(10px,12px,0); } }
@keyframes heroFloatB { 0%,100% { transform: translate3d(0,0,0); } 50% { transform: translate3d(-12px,-6px,0); } }

.back-to-top {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 90;
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(15,18,30,.94), rgba(9,12,22,.94));
  color: #eef2ff;
  box-shadow: 0 18px 40px rgba(0,0,0,.28), 0 0 0 1px rgba(125,96,255,.14);
  opacity: 0;
  visibility: hidden;
  transform: translateY(10px);
  transition: opacity .25s ease, transform .25s ease, visibility .25s ease, box-shadow .25s ease;
}
.back-to-top::before {
  content:"";
  position:absolute; inset:-1px; border-radius:inherit; padding:1px;
  background: linear-gradient(135deg, rgba(132,96,255,.34), rgba(73,135,255,.26), rgba(62,213,159,.18));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
}
.back-to-top.is-visible { opacity: 1; visibility: visible; transform: translateY(0); }
.back-to-top:hover { transform: translateY(-2px); box-shadow: 0 22px 48px rgba(0,0,0,.34), 0 0 0 1px rgba(125,96,255,.18); }
.back-to-top span { position:relative; z-index:1; font-size: 1.1rem; }

@media (max-width: 1199px) {
  .hero-home__copy h1 { max-width: 12ch; font-size: clamp(2.7rem, 6vw, 4.4rem); }
  .hero-chat-scene { min-height: 540px; }
}
@media (max-width: 980px) {
  .hero-home__grid--chat { gap: 18px; }
  .hero-home__copy { max-width: 100%; }
  .hero-home__copy h1 { max-width: 13ch; }
  .hero-chat-scene { min-height: 520px; }
  .hero-chat-scene__sidebar { width: 168px; }
  .hero-chat-scene__canvas { inset: 0 0 0 168px; }
  .hero-floating-composer { width: calc(100% - 34px); }
  .hero-scene-inline-cta { left: 182px; right: 18px; bottom: 18px; }
  .hero-chat-feed { width: calc(100% - 200px); }
}
@media (max-width: 680px) {
  .hero-home { min-height: auto; }
  .hero-home__copy h1 { max-width: none; font-size: clamp(2.35rem, 10.6vw, 3.45rem); }
  .hero-mini-line { min-height: 34px; font-size: .78rem; }
  .hero-chat-scene {
    min-height: 530px;
    padding: 14px;
    border-radius: 26px;
  }
  .hero-scene-badge { top: 14px; right: 14px; }
  .hero-chat-scene__workspace {
    inset: 94px 14px 14px 14px;
    border-radius: 20px;
  }
  .hero-chat-scene__sidebar {
    width: auto;
    right: 0;
    left: 0;
    bottom: auto;
    height: 76px;
    display:flex;
    align-items:center;
    gap: 12px;
    padding: 14px;
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.07);
  }
  .hero-app-button,
  .hero-app-list { display:none; }
  .hero-chat-scene__canvas { inset: 76px 0 0 0; }
  .hero-floating-composer {
    top: 10px;
    width: calc(100% - 20px);
    padding: 14px 14px 12px;
    border-radius: 18px;
  }
  .hero-floating-composer__bottom { align-items:flex-start; flex-direction: column; }
  .hero-prompt-line { min-height: 52px; padding: 6px 0 4px; font-size: .9rem; }
  .hero-chat-feed {
    right: 14px;
    left: 14px;
    bottom: 74px;
    width: auto;
  }
  .hero-chat-bubble { font-size: .8rem; line-height: 1.45; }
  .hero-scene-inline-cta {
    left: 14px; right: 14px; bottom: 14px;
    min-height: 44px; padding: 0 12px;
  }
  .hero-scene-inline-cta span { font-size: .76rem; }
  .hero-scene-inline-cta a { min-height: 30px; font-size: .76rem; }
  .back-to-top { right: 16px; bottom: 16px; width: 48px; height: 48px; border-radius: 14px; }
}
@media (max-width: 480px) {
  .hero-home__copy h1 { font-size: clamp(2.2rem, 11vw, 3rem); }
  .hero-actions { grid-template-columns: 1fr; }
  .hero-action-pills { gap: 6px; }
  .hero-action-pills span:nth-child(3) { display:none; }
  .hero-globe-pill { display:none; }
  .hero-chat-feed { bottom: 68px; }
  .hero-scene-inline-cta span { display:none; }
}

/* --- v16 hero refinement + loader + legal routes polish --- */
.site-loader {
  background:
    radial-gradient(circle at 50% 42%, rgba(122, 92, 255, .18), transparent 22%),
    radial-gradient(circle at 82% 28%, rgba(64, 139, 255, .10), transparent 22%),
    linear-gradient(180deg, rgba(3,5,12,.98), rgba(5,7,15,.995));
  backdrop-filter: blur(14px);
}
.site-loader__inner {
  width: min(90vw, 560px);
  min-height: 220px;
  display: grid;
  place-items: center;
}
.site-loader__halo { width: 300px; height: 300px; opacity: .92; }
.site-loader__ring {
  width: 210px;
  height: 210px;
  border-color: rgba(255,255,255,.07);
  box-shadow: inset 0 0 42px rgba(255,255,255,.03), 0 0 44px rgba(76,120,255,.06);
}
.site-loader__logo {
  position: relative;
  z-index: 2;
  clip-path: none;
  animation: none;
  filter: drop-shadow(0 0 28px rgba(112, 103, 255, .18));
}
.site-loader__logo img,
.site-loader__logo .custom-logo {
  width: min(72vw, 330px);
  max-height: none;
  height: auto;
}
.site-loader__shine {
  position: absolute;
  inset: auto 50% 20px;
  transform: translateX(-50%);
  width: min(68vw, 320px);
  height: 1px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent 0%, rgba(140,106,255,.08) 18%, rgba(180,255,57,.18) 50%, rgba(82,138,255,.08) 82%, transparent 100%);
  box-shadow: 0 0 24px rgba(111, 115, 255, .18);
  animation: loaderSweep 2.2s ease-in-out infinite;
}
@keyframes loaderSweep {
  0%,100% { opacity: .45; transform: translateX(-50%) scaleX(.84); }
  50% { opacity: 1; transform: translateX(-50%) scaleX(1); }
}

.bottom-blur-mask {
  background:
    linear-gradient(180deg, rgba(4,7,15,0) 0%, rgba(4,7,15,.04) 58%, rgba(4,7,15,.22) 78%, rgba(4,7,15,.62) 100%),
    radial-gradient(circle at 50% 100%, rgba(124,92,255,.10), transparent 40%);
  backdrop-filter: blur(8px);
  mask-image: linear-gradient(180deg, transparent 0%, transparent 62%, rgba(0,0,0,.8) 84%, #000 100%);
}
.hero-home {
  position: relative;
  min-height: calc(var(--app-vh, 1vh) * 100 - 86px);
  padding-top: clamp(22px, 4.4vw, 48px);
}
.hero-home::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 140px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(4,7,15,0) 0%, rgba(4,7,15,.42) 74%, rgba(4,7,15,.86) 100%);
  filter: blur(18px);
  opacity: .92;
}
.hero-home__grid--chat {
  grid-template-columns: minmax(0, .97fr) minmax(420px, 1.03fr);
  gap: clamp(22px, 2.2vw, 34px);
}
.hero-home__copy {
  max-width: 700px;
  padding-left: clamp(2px, .4vw, 8px);
}
.hero-home__copy h1 {
  max-width: 13.1ch;
  font-size: clamp(2.9rem, 4.8vw, 5rem);
  line-height: .94;
  letter-spacing: -.058em;
}
.hero-actions {
  margin: 20px 0 12px;
}
.hero-chat-scene {
  min-height: 510px;
  border-radius: 34px;
}
.hero-chat-scene__workspace {
  inset: 88px 22px 22px 22px;
}
.hero-floating-composer {
  width: min(720px, calc(100% - 56px));
  padding: 18px 18px 14px;
}
.hero-prompt-line {
  min-height: 82px;
  font-size: clamp(1.2rem, 2vw, 1.45rem);
}
.hero-chat-feed {
  right: 20px;
  bottom: 18px;
  width: min(350px, calc(100% - 268px));
}
.hero-scene-inline-cta {
  left: 242px;
  right: 22px;
  bottom: 18px;
}
.hero-chat-bubble {
  max-width: 100%;
  line-height: 1.42;
}
.hero-scene-grid { opacity: .12; }
.hero-chat-scene__canvas::after { inset: 14px; }

.hero-home + .hero-metrics-section {
  margin-top: 0;
}

@media (max-width: 1280px) {
  .hero-home__grid--chat { grid-template-columns: minmax(0, .95fr) minmax(410px, 1fr); }
  .hero-home__copy h1 { max-width: 12.8ch; font-size: clamp(2.8rem, 4.7vw, 4.75rem); }
  .hero-chat-scene { min-height: 500px; }
}

@media (max-width: 980px) {
  .hero-home {
    min-height: auto;
    padding-top: 34px;
  }
  .hero-home::after { height: 100px; }
  .hero-home__grid--chat { gap: 16px; }
  .hero-home__copy { max-width: 100%; padding-left: 0; }
  .hero-home__copy h1 { max-width: 15ch; }
  .hero-chat-scene { min-height: 500px; }
}

@media (max-width: 680px) {
  .hero-home::after,
  .bottom-blur-mask { display: none; }
  .hero-home__copy h1 {
    max-width: none;
    font-size: clamp(2.25rem, 10.8vw, 3.1rem);
    line-height: .97;
  }
  .hero-chat-scene {
    min-height: 506px;
    padding: 14px;
  }
  .hero-chat-scene__workspace { inset: 88px 14px 14px 14px; }
  .hero-prompt-line { min-height: 48px; font-size: .94rem; }
  .hero-chat-feed {
    right: 12px;
    left: 12px;
    bottom: 66px;
    width: auto;
  }
  .hero-scene-inline-cta {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }
}


/* --- v17 final refinements --- */
.hero-home__grid--chat {
  grid-template-columns: minmax(0, .94fr) minmax(470px, 1.02fr);
  gap: clamp(26px, 2.8vw, 44px);
}
.hero-home__copy { max-width: 650px; }
.hero-home__copy h1 {
  max-width: 13.2ch;
  font-size: clamp(2.8rem, 4.85vw, 5.15rem);
  line-height: .93;
}
.hero-chat-scene {
  min-height: 548px;
  padding: 20px;
}
.hero-chat-scene__workspace { inset: 90px 22px 22px 22px; }
.hero-floating-composer {
  width: min(735px, calc(100% - 70px));
  padding: 18px 18px 14px;
}
.hero-prompt-line {
  min-height: 82px;
  font-size: clamp(1rem, 1.45vw, 1.42rem);
}
.hero-chat-feed {
  right: 22px;
  bottom: 92px;
  width: min(332px, calc(100% - 292px));
  gap: 10px;
}
.hero-chat-bubble {
  padding: 13px 15px;
  font-size: .9rem;
  line-height: 1.48;
}
.hero-scene-inline-cta {
  left: 242px;
  right: 22px;
  bottom: 20px;
  min-height: 56px;
  padding: 10px 14px 10px 16px;
  border-radius: 18px;
}
.hero-scene-inline-cta span {
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.35;
}
.hero-scene-inline-cta a {
  min-width: 136px;
  min-height: 40px;
  font-size: .92rem;
}
.hero-chat-bubble--user { max-width: 100%; }
.hero-chat-bubble--assistant { max-width: 96%; }

.perception-section {
  position: relative;
  overflow: hidden;
}
.perception-section::before,
.perception-section::after {
  content: "";
  position: absolute;
  border-radius: 999px;
  pointer-events: none;
  filter: blur(54px);
  opacity: .28;
}
.perception-section::before {
  width: 280px;
  height: 280px;
  left: -40px;
  top: 8%;
  background: radial-gradient(circle, rgba(137,92,255,.44), transparent 70%);
  animation: heroFloatA 10s ease-in-out infinite;
}
.perception-section::after {
  width: 320px;
  height: 320px;
  right: -70px;
  bottom: 0;
  background: radial-gradient(circle, rgba(73,184,255,.3), transparent 72%);
  animation: heroFloatB 11s ease-in-out infinite;
}
.perception-grid {
  position: relative;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, .92fr);
  gap: clamp(30px, 4vw, 56px);
  align-items: end;
}
.perception-word-wrap { position: relative; }
.text-mask-word {
  max-width: 8.4ch;
  line-height: .88;
  letter-spacing: -.065em;
  background: linear-gradient(90deg, #f2f3ff 0%, #d8c8ff 22%, #7b68ff 48%, #44a4ff 70%, #84ff7a 100%);
  background-size: 180% 180%;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  animation: gradientShift 8s ease infinite;
}
.lang-sr .perception-section .text-mask-word {
  font-size: clamp(3.6rem, 9vw, 6.4rem);
  max-width: 6.8ch;
}
.lang-en .perception-section .text-mask-word {
  font-size: clamp(4.8rem, 12vw, 8.4rem);
}
.perception-copy {
  max-width: 530px;
  margin-left: auto;
}
@keyframes gradientShift {
  0%,100% { background-position: 0% 50%; }
  50% { background-position: 100% 50%; }
}

.footer-banner {
  padding: clamp(36px, 6vw, 68px) 0 14px;
}
.footer-banner__inner {
  position: relative;
  display: grid;
  grid-template-columns: 1.08fr .92fr;
  align-items: center;
  gap: 28px;
  padding: clamp(28px, 4vw, 42px);
  border-radius: 34px;
  background:
    radial-gradient(circle at 10% 20%, rgba(137,92,255,.16), transparent 28%),
    radial-gradient(circle at 90% 15%, rgba(73,184,255,.14), transparent 26%),
    radial-gradient(circle at 84% 100%, rgba(132,255,122,.08), transparent 20%),
    linear-gradient(180deg, rgba(8,10,18,.98), rgba(5,8,15,.98));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 80px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.05);
}
.footer-banner__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  pointer-events: none;
}
.site-footer { padding: 0 0 48px; }
.footer-grid--large { margin-top: 44px; }
.footer-bottom { margin-top: 28px; }

@media (max-width: 1180px) {
  .perception-grid,
  .footer-banner__inner { grid-template-columns: 1fr; }
  .perception-copy {
    max-width: none;
    margin-left: 0;
  }
  .text-mask-word,
  .lang-sr .perception-section .text-mask-word,
  .lang-en .perception-section .text-mask-word {
    max-width: none;
    font-size: clamp(3.6rem, 16vw, 6rem);
  }
}

@media (max-width: 980px) {
  .hero-home__grid--chat { grid-template-columns: 1fr; gap: 24px; }
  .hero-home__copy { max-width: 720px; }
  .hero-home__copy h1 {
    max-width: 14ch;
    font-size: clamp(2.5rem, 7vw, 4rem);
  }
  .hero-chat-scene {
    min-height: 520px;
    padding: 16px;
    border-radius: 28px;
  }
  .hero-chat-scene__workspace {
    inset: 88px 16px 16px 16px;
    border-radius: 22px;
  }
  .hero-chat-scene__sidebar { width: 160px; }
  .hero-chat-scene__canvas { inset: 0 0 0 160px; }
  .hero-floating-composer {
    width: calc(100% - 32px);
    padding: 14px 14px 12px;
    border-radius: 20px;
  }
  .hero-prompt-line { min-height: 60px; font-size: .98rem; }
  .hero-chat-feed {
    right: 16px;
    bottom: 84px;
    width: calc(100% - 210px);
  }
  .hero-scene-inline-cta {
    left: 176px;
    right: 16px;
    bottom: 16px;
    min-height: 52px;
  }
}

@media (max-width: 680px) {
  .hero-home__copy h1 {
    max-width: 12.8ch;
    font-size: clamp(2.35rem, 10vw, 3.35rem);
  }
  .hero-chat-scene {
    min-height: 505px;
    padding: 14px;
    border-radius: 24px;
  }
  .hero-chat-scene__workspace {
    inset: 90px 14px 14px 14px;
    border-radius: 18px;
  }
  .hero-chat-scene__sidebar { display: none; }
  .hero-chat-scene__canvas {
    inset: 0;
    overflow: hidden;
  }
  .hero-chat-scene__canvas::before {
    content: "";
    position: absolute;
    left: 50%;
    top: 52%;
    width: 172px;
    height: 172px;
    transform: translate(-50%, -50%);
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,.09);
    box-shadow: 0 0 0 18px rgba(123,94,255,.04), 0 0 0 38px rgba(73,184,255,.03), inset 0 0 30px rgba(255,255,255,.03);
    animation: spin 14s linear infinite;
  }
  .hero-chat-scene__canvas::after {
    content: "✦";
    position: absolute;
    left: 50%;
    top: 52%;
    width: 104px;
    height: 104px;
    transform: translate(-50%, -50%);
    display: grid;
    place-items: center;
    border-radius: 28px;
    font-size: 2rem;
    color: #f5f8ff;
    background: linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.03));
    box-shadow: 0 0 52px rgba(123,94,255,.18), inset 0 1px 0 rgba(255,255,255,.08);
    backdrop-filter: blur(18px);
    animation: pulseGlow 3s ease-in-out infinite;
  }
  .hero-scene-badge {
    top: 14px;
    right: 14px;
    font-size: .72rem;
    min-height: 30px;
  }
  .hero-floating-composer {
    top: 14px;
    width: calc(100% - 28px);
    padding: 13px 13px 11px;
  }
  .hero-floating-composer__top,
  .hero-floating-composer__bottom { gap: 8px; }
  .hero-action-pills { display: none; }
  .hero-send-button {
    min-width: 82px;
    min-height: 34px;
    font-size: .8rem;
  }
  .hero-prompt-line {
    min-height: 52px;
    padding: 6px 0;
    font-size: .88rem;
  }
  .hero-chat-feed {
    left: 16px;
    right: 16px;
    bottom: 78px;
    width: auto;
    gap: 10px;
  }
  .hero-chat-bubble {
    max-width: 88%;
    padding: 11px 12px;
    font-size: .8rem;
    border-radius: 16px;
  }
  .hero-scene-inline-cta {
    left: 14px;
    right: 14px;
    bottom: 14px;
    min-height: 48px;
    padding: 8px 10px;
    gap: 10px;
  }
  .hero-scene-inline-cta span {
    font-size: .76rem;
    line-height: 1.25;
  }
  .hero-scene-inline-cta a {
    min-width: 118px;
    min-height: 36px;
    font-size: .84rem;
    padding: 0 10px;
  }
  .footer-banner { padding-top: 28px; }
  .footer-banner__inner { border-radius: 24px; }
}

@media (max-width: 420px) {
  .hero-home__copy h1 {
    max-width: none;
    font-size: clamp(2.15rem, 11vw, 3rem);
  }
  .hero-mini-line {
    width: 100%;
    justify-content: center;
    text-align: center;
    padding-inline: 10px;
    font-size: .8rem;
  }
  .hero-chat-scene { min-height: 492px; }
  .hero-chat-feed { bottom: 74px; }
  .hero-scene-inline-cta a {
    min-width: 108px;
    font-size: .8rem;
  }
}


/* v19 final refinement overrides */
.main-nav .menu-item-contact a { color: #f3f7ff; }
.hero-home__copy { max-width: 760px; }
.hero-home__copy h1 { max-width: 13.5ch; text-wrap: balance; }
.hero-chat-scene { min-height: 530px; }
.hero-chat-feed { width: calc(100% - 230px); right: 22px; bottom: 86px; gap: 12px; }
.hero-chat-bubble { max-width: min(82%, 360px); font-size: .98rem; }
.hero-chat-bubble--assistant { max-width: min(88%, 420px); }
.hero-scene-inline-cta { left: auto; right: 22px; bottom: 20px; min-width: 320px; justify-content: space-between; }
.hero-scene-inline-cta a { min-width: 152px; justify-content: center; }
.hero-floating-composer__bottom { gap: 10px; flex-wrap: nowrap; }
.hero-action-pills { flex-wrap: wrap; }

.perception-section { overflow: hidden; }
.perception-panel { display:grid; grid-template-columns: .95fr 1.05fr; gap: 28px; padding: 34px; position: relative; overflow: hidden; }
.perception-panel::before { content:''; position:absolute; inset:-20% auto auto -10%; width: 320px; height: 320px; border-radius:50%; background: radial-gradient(circle, rgba(118,92,255,.22), transparent 65%); filter: blur(18px); animation: driftGlow 12s ease-in-out infinite; }
.perception-panel::after { content:''; position:absolute; inset:auto -8% -30% auto; width: 360px; height: 360px; border-radius:50%; background: radial-gradient(circle, rgba(173,255,47,.15), transparent 62%); filter: blur(22px); animation: driftGlow 15s ease-in-out infinite reverse; }
.perception-panel > * { position: relative; z-index: 1; }
.perception-title { font-size: clamp(2.4rem, 5vw, 4.2rem); line-height: .98; margin: 12px 0 16px; max-width: 9ch; }
.perception-panel__copy > p { margin-bottom: 18px; }
.perception-points { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 14px; }
.perception-point { padding: 16px 18px; border-radius: 20px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); }
.perception-point strong { display:block; margin-bottom:8px; }
.perception-point span { color: var(--muted); line-height:1.55; }

.engine-system { overflow:hidden; }
@media (max-width: 768px) {
  .engine-system { display:block; min-height:auto; padding: 26px 16px 18px; }
  .engine-system__orbit { display:block !important; position:absolute; left:50%; top:124px; transform:translate(-50%, -50%); opacity:.52; }
  .engine-system__orbit--one { width: 220px; height:220px; }
  .engine-system__orbit--two { width: 300px; height:300px; }
  .engine-system__core { width: min(100%, 320px); margin: 0 auto 18px; padding-top: 38px; }
  .engine-system__core::before { content:''; position:absolute; left:50%; top:12px; width: 14px; height: 14px; border-radius:50%; background: linear-gradient(135deg, #7c63ff, #7fff73); transform: translateX(-50%); box-shadow: 0 0 0 10px rgba(124,99,255,.08), 0 0 35px rgba(124,99,255,.35); animation: pulseDot 2.4s ease-in-out infinite; }
  .engine-system__node { margin-bottom: 12px; }
}

.price-calc { grid-template-columns: .86fr 1.28fr .86fr; align-items:start; }
.price-calc__menu { display:grid; gap: 10px; margin-top: 20px; }
.price-menu-row { display:flex; justify-content:space-between; gap:14px; padding: 12px 14px; border-radius:16px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08); }
.price-menu-row strong { color:#e9ff74; font-weight:700; white-space:nowrap; }
.checkbox-stack--wide span { display:flex; align-items:center; justify-content:space-between; gap:12px; }
.checkbox-stack--wide em { color:#c8d5f0; font-style:normal; font-size:.84rem; }
.price-calc textarea { width:100%; min-height: 118px; padding:14px 16px; border-radius:16px; border:1px solid rgba(255,255,255,.1); background: rgba(255,255,255,.04); color:#fff; resize: vertical; }
.price-calc__microcopy { margin: 0 0 16px; color:#c8d5f0; line-height:1.55; font-size:.95rem; }
.calc-breakdown { display:grid; gap:10px; margin: 18px 0; }
.calc-breakdown span { display:flex; justify-content:space-between; gap:12px; padding: 10px 12px; border-radius:14px; background: rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.06); }
.calc-breakdown em { font-style:normal; color:#dce5fb; }
.calc-breakdown strong { white-space:nowrap; }
@media (max-width: 1100px) {
  .price-calc { grid-template-columns: 1fr; }
}

.footer-banner { padding: 72px 0 76px; }
.footer-banner__shell { width:100%; padding: 0 32px; }
.footer-banner__inner { width: 100%; max-width:none; min-height: 340px; padding: 44px 46px; border-radius: 34px; align-items:end; }
.site-footer { padding-top: 20px; }
.footer-grid--final { margin-top: 26px; }
@media (max-width: 768px) {
  .hero-home__copy h1 { max-width: 15ch; font-size: clamp(2.35rem, 10.4vw, 3.45rem); }
  .hero-chat-scene { min-height: 520px; }
  .hero-chat-feed { width: calc(100% - 28px); left: 14px; right: 14px; bottom: 82px; }
  .hero-chat-bubble { max-width: 100%; font-size: .84rem; }
  .hero-scene-inline-cta { left: 14px; right: 14px; min-width: 0; bottom: 14px; gap: 10px; }
  .hero-scene-inline-cta a { min-width: 0; flex: 1; }
  .perception-panel { grid-template-columns: 1fr; padding: 22px 18px; }
  .perception-title { max-width:none; font-size: clamp(2rem, 9vw, 3rem); }
  .perception-points { grid-template-columns: 1fr; }
  .footer-banner__shell { padding: 0 16px; }
  .footer-banner__inner { padding: 24px 20px; min-height: auto; border-radius: 24px; }
}

@keyframes driftGlow {
  0%,100% { transform: translate3d(0,0,0) scale(1); }
  50% { transform: translate3d(10px,-14px,0) scale(1.06); }
}
@keyframes pulseDot {
  0%,100% { transform: translateX(-50%) scale(1); opacity:1; }
  50% { transform: translateX(-50%) scale(1.18); opacity:.8; }
}

/* --- Iteration 1: service + work system polish --- */
.page-hero--story__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(340px, .96fr);
  gap: 28px;
  align-items: start;
}
.page-hero--story .page-hero__title { max-width: 11.2ch; }
.page-hero--story .page-hero__text { max-width: 66ch; }
.story-preview,
.story-preview__meta,
.service-card__media,
.story-zigzag__visual,
.story-zigzag__surface,
.demo-spotlight,
.demo-spotlight__card,
.demo-spotlight__thumb,
.story-stat,
.service-check-item { min-width: 0; }
.story-preview {
  display: grid;
  gap: 18px;
  padding: 18px;
  border-radius: 28px;
}
.story-preview__frame,
.story-zigzag__surface,
.demo-spotlight__thumb,
.service-card__media,
.project-thumb {
  min-height: 240px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
  background-size: cover;
  background-position: center;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.06);
}
.story-preview__meta h3,
.demo-spotlight__meta strong,
.service-check-item strong { color: var(--text); }
.story-preview__meta p,
.demo-spotlight__meta p,
.service-check-item p { margin: 8px 0 0; }
.story-preview__actions,
.service-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 18px;
  align-items: center;
}
.story-stat-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0,1fr));
  gap: 14px;
  margin-top: 24px;
}
.story-stat {
  padding: 18px;
  border-radius: 20px;
}
.story-stat strong {
  display: block;
  font-size: 1.3rem;
  color: var(--text);
  margin-bottom: 6px;
}
.story-stat span { color: var(--muted); font-size: .92rem; line-height: 1.45; }
.story-zigzag {
  display: grid;
  grid-template-columns: minmax(0, .94fr) minmax(0, 1.06fr);
  gap: 28px;
  align-items: center;
}
.story-zigzag--reverse { grid-template-columns: minmax(0, 1.06fr) minmax(0, .94fr); }
.story-zigzag--reverse .story-zigzag__copy { order: 2; }
.story-zigzag--reverse .story-zigzag__visual { order: 1; }
.story-zigzag__copy h2 { max-width: 13ch; }
.story-zigzag__visual {
  padding: 18px;
  border-radius: 28px;
}
.story-zigzag__caption { margin-top: 12px; color: var(--muted); }
.service-check-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0,1fr));
  gap: 14px;
}
.service-check-item {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
}
.step-index {
  display: inline-flex;
  width: 34px;
  height: 34px;
  border-radius: 999px;
  align-items: center;
  justify-content: center;
  background: rgba(183,255,57,.14);
  color: var(--accent);
  font-size: .82rem;
  font-weight: 700;
  margin-bottom: 16px;
}
.demo-spotlight {
  display: grid;
  grid-template-columns: minmax(0, 1.04fr) minmax(320px, .96fr);
  gap: 24px;
  align-items: center;
  padding: 28px;
  border-radius: 30px;
}
.demo-spotlight__card {
  display: grid;
  gap: 16px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}
.service-card__media,
.project-thumb { min-height: 170px; margin-bottom: 18px; }
.service-card__index {
  margin: 10px 0 14px;
  font-size: .84rem;
  color: var(--accent);
  letter-spacing: .08em;
}
.service-card__actions {
  margin-top: 18px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.08);
}
.service-card__actions a {
  color: var(--text);
  font-size: .92rem;
  text-decoration: none;
}
.service-card__actions a:hover { color: var(--accent); }
.service-value-grid { grid-template-columns: repeat(3, minmax(0,1fr)); }
.project-grid-advanced .project-card { display: flex; flex-direction: column; }
.project-grid-advanced .project-card p:last-of-type { margin-bottom: 0; }

@media (max-width: 1100px) {
  .page-hero--story__grid,
  .story-zigzag,
  .story-zigzag--reverse,
  .demo-spotlight { grid-template-columns: 1fr; }
  .story-zigzag--reverse .story-zigzag__copy,
  .story-zigzag--reverse .story-zigzag__visual { order: initial; }
}

@media (max-width: 860px) {
  .story-stat-strip,
  .service-check-grid,
  .service-value-grid { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .story-preview,
  .story-zigzag__visual,
  .demo-spotlight,
  .demo-spotlight__card { padding: 16px; }
  .story-preview__frame,
  .story-zigzag__surface,
  .demo-spotlight__thumb,
  .service-card__media,
  .project-thumb { min-height: 190px; }
  .story-preview__actions,
  .service-card__actions { display: grid; grid-template-columns: 1fr; }
}

/* --- v11 agency cleanup --- */
.dynamic-island {
  --island-collapsed: 940px;
  --island-expanded: 1140px;
}

.dynamic-island__pill {
  width: min(100%, var(--island-collapsed));
  padding: 10px 16px;
  gap: 14px;
}

.dynamic-island.is-expanded .dynamic-island__pill,
.dynamic-island:hover .dynamic-island__pill {
  width: min(100%, var(--island-expanded));
}

.desktop-cta {
  min-height: 42px;
  padding-inline: 16px;
  font-size: .88rem;
  box-shadow: 0 10px 26px rgba(158,255,56,.18);
}

.main-nav__mobile-meta .button {
  width: 100%;
}

.page-hero {
  padding-top: 88px;
}

.home-hero-clean {
  padding-top: 104px;
}

.home-hero-clean__grid {
  align-items: start;
  gap: 28px;
}

.hero-home__copy h1 {
  max-width: 12.4ch;
  text-wrap: balance;
}

.hero-text {
  max-width: 62ch;
}

.hero-summary-card {
  display: grid;
  gap: 20px;
  padding: 28px;
  min-height: 100%;
}

.hero-summary-card h3 {
  margin-bottom: 0;
}

.hero-summary-card__list {
  display: grid;
  gap: 14px;
}

.hero-summary-stat {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 20px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
}

.hero-summary-stat strong {
  color: var(--text);
  font-size: 1.15rem;
}

.hero-summary-card__footer {
  display: grid;
  gap: 14px;
}

.home-trust-grid,
.home-pricing-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.home-inline-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  justify-content: center;
  margin-top: 28px;
}

.showcase-card,
.project-card,
.service-card-enhanced,
.demo-card,
.contact-method,
.hero-summary-stat,
.immersive-panel {
  min-width: 0;
}

.showcase-card {
  min-height: auto;
}

.service-card-enhanced,
.project-card,
.demo-card,
.faq-item,
.contact-method {
  transition: transform .28s ease, border-color .28s ease, background .28s ease;
}

.service-card-enhanced:hover,
.project-card:hover,
.demo-card:hover,
.faq-item:hover,
.contact-method:hover {
  transform: translateY(-4px);
  border-color: rgba(168,85,247,.22);
}

.demo-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.demo-card {
  display: grid;
  gap: 18px;
  padding: 24px;
}

.demo-card h2 {
  font-size: clamp(1.4rem, 2.5vw, 2rem);
}

.demo-card__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.project-grid-advanced {
  display: grid;
  gap: 18px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.project-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.project-card .service-card__actions,
.showcase-card .service-card__actions {
  margin-top: auto;
}

.contact-grid-extended {
  align-items: start;
}

.contact-sidebar-card,
.contact-form {
  min-height: 100%;
}

.contact-methods {
  display: grid;
  gap: 12px;
  margin-top: 22px;
}

.contact-method {
  display: grid;
  gap: 4px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.03);
}

.contact-method strong {
  color: var(--text);
  font-size: .85rem;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.contact-method span {
  color: var(--muted);
  line-height: 1.55;
}

.contact-method--static:hover {
  transform: none;
}

.field-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.contact-form {
  padding: 24px;
}

.contact-form label {
  display: grid;
  gap: 8px;
}

.contact-form input,
.contact-form textarea,
.price-calc select,
.price-calc textarea {
  width: 100%;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  color: var(--text);
  padding: 14px 16px;
}

.contact-form input::placeholder,
.contact-form textarea::placeholder,
.price-calc textarea::placeholder {
  color: #8f98a4;
}

.price-calc {
  gap: 24px;
}

.price-calc__result {
  border-radius: 24px;
}

.footer-grid--final {
  align-items: start;
}

.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 18px;
}

.social-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: #eef4ff;
}

.social-icon svg {
  width: 18px;
  height: 18px;
}

@media (max-width: 1180px) {
  .home-trust-grid,
  .home-pricing-grid,
  .project-grid-advanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .dynamic-island {
    --island-collapsed: 92vw;
    --island-expanded: 92vw;
  }

  .desktop-cta {
    display: none !important;
  }

  .home-hero-clean {
    padding-top: 74px;
  }

  .home-hero-clean__grid,
  .contact-grid,
  .faq-grid,
  .footer-grid,
  .footer-grid--final,
  .demo-grid,
  .project-grid-advanced {
    grid-template-columns: 1fr;
  }

  .home-trust-grid,
  .home-pricing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .home-trust-grid,
  .home-pricing-grid,
  .field-grid {
    grid-template-columns: 1fr;
  }

  .hero-summary-card,
  .demo-card,
  .contact-form,
  .contact-sidebar-card {
    padding: 20px;
  }

  .home-inline-cta,
  .demo-card__actions {
    display: grid;
    grid-template-columns: 1fr;
  }
}

/* --- v12 premium refinement --- */
:root {
  --bg: #0b0d11;
  --bg-2: #14181e;
  --surface: #171b22;
  --surface-2: #1c2129;
  --line: rgba(255,255,255,.08);
  --line-2: rgba(203,181,138,.18);
  --text: #f4efe7;
  --muted: #a4adb8;
  --accent: #cbb58a;
  --accent-2: #f0dfbb;
  --accent-3: #6f7a88;
  --shadow: 0 24px 70px rgba(0,0,0,.34);
  --radius: 28px;
  --container: 1200px;
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Manrope", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: linear-gradient(180deg, #090b0f 0%, #11151b 50%, #151a21 100%);
  color: var(--text);
}

body.is-loading {
  overflow: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(circle at 16% 0%, rgba(203,181,138,.11), transparent 32%),
    radial-gradient(circle at 100% 8%, rgba(255,255,255,.05), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 24%);
}

h1,
h2,
h3,
h4 {
  font-family: "Fraunces", Georgia, serif;
  font-weight: 600;
  letter-spacing: -.035em;
  color: var(--text);
}

p {
  color: var(--muted);
  line-height: 1.72;
}

.container {
  width: min(var(--container), calc(100% - 40px));
}

.section {
  padding: 108px 0;
}

.section-alt {
  background: linear-gradient(180deg, rgba(255,255,255,.018), rgba(255,255,255,.006));
}

.section-divider::after {
  width: min(1180px, calc(100% - 40px));
  background: linear-gradient(90deg, transparent, rgba(203,181,138,.18), transparent);
}

.eyebrow {
  padding: 8px 14px;
  border: 1px solid rgba(203,181,138,.18);
  background: rgba(255,255,255,.03);
  color: #d8cdb9;
  font-size: .74rem;
  letter-spacing: .16em;
}

.eyebrow::before {
  width: 7px;
  height: 7px;
  background: var(--accent);
  box-shadow: none;
}

.button {
  min-height: 50px;
  padding: 0 20px;
  font-weight: 600;
  letter-spacing: .01em;
}

.button-primary {
  color: #16110b;
  background: linear-gradient(135deg, var(--accent-2), var(--accent));
  box-shadow: 0 16px 34px rgba(203,181,138,.16);
}

.button-primary:hover {
  box-shadow: 0 20px 40px rgba(203,181,138,.22);
}

.button-secondary {
  color: var(--text);
  border-color: rgba(255,255,255,.1);
  background: rgba(255,255,255,.03);
}

.button-secondary:hover {
  border-color: rgba(203,181,138,.2);
  background: rgba(255,255,255,.05);
}

.glass {
  background: linear-gradient(180deg, rgba(25,29,36,.92), rgba(18,22,28,.96));
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.glass::before {
  display: none;
}

.site-shell,
.site-main,
.site-header,
.site-footer {
  position: relative;
  z-index: 1;
}

.site-loader {
  position: fixed;
  inset: 0;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #090b0f 0%, #11151b 100%);
  z-index: 100;
  transition: opacity .65s ease, visibility .65s ease;
}

.site-loader.is-hidden {
  opacity: 0;
  visibility: hidden;
}

.site-loader__inner {
  display: grid;
  gap: 22px;
  justify-items: center;
  text-align: center;
  padding: 32px;
  animation: loaderInner .95s cubic-bezier(.2,.9,.2,1) both;
}

.site-loader__logo {
  animation: loaderLogo 1.45s cubic-bezier(.2,.9,.2,1) both;
}

.site-loader__logo img,
.site-loader__logo .custom-logo {
  width: min(230px, 42vw);
  max-height: none;
  height: auto;
}

.site-loader__line {
  width: 112px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(203,181,138,.9), transparent);
  animation: loaderLine 1.7s ease-in-out infinite;
}

.site-loader__label {
  font-size: .78rem;
  color: #b8b0a2;
  text-transform: uppercase;
  letter-spacing: .14em;
  animation: loaderText 1.05s ease .18s both;
}

@keyframes loaderInner {
  from {
    opacity: 0;
    transform: translateY(16px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes loaderLogo {
  0% {
    opacity: 0;
    transform: scale(.92);
  }
  45% {
    opacity: 1;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes loaderText {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes loaderLine {
  0%, 100% {
    transform: scaleX(.55);
    opacity: .45;
  }
  50% {
    transform: scaleX(1);
    opacity: 1;
  }
}

.site-header {
  position: sticky;
  top: 18px;
  z-index: 40;
  padding: 0 20px;
}

.dynamic-island {
  display: flex;
  justify-content: center;
}

.dynamic-island__pill {
  width: min(1160px, 100%);
  min-height: 74px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 24px;
  align-items: center;
  padding: 12px 16px 12px 20px;
  border-radius: 22px;
  background: rgba(10,12,16,.84);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 18px 50px rgba(0,0,0,.28);
  transition: transform .28s ease, background .28s ease, border-color .28s ease;
}

.dynamic-island.is-menu-open .dynamic-island__pill {
  border-color: rgba(203,181,138,.2);
}

.dynamic-island.is-scrolled .dynamic-island__pill {
  background: rgba(9,11,15,.96);
  border-color: rgba(203,181,138,.18);
}

.brand img,
.brand .custom-logo {
  max-height: 36px;
  width: auto;
}

.main-nav {
  min-width: 0;
}

.menu-inline,
.menu-inline ul {
  justify-content: center;
  gap: 8px;
}

.menu-inline a {
  height: 42px;
  padding: 0 14px;
  color: #cfd5de;
  font-size: .9rem;
}

.menu-inline a:hover,
.menu-inline .current-menu-item > a {
  background: rgba(255,255,255,.05);
  color: var(--text);
}

.menu-inline .current-menu-item > a {
  border: 1px solid rgba(203,181,138,.16);
}

.menu-inline .menu-item-contact {
  display: none;
}

.nav-actions {
  gap: 12px;
}

.desktop-cta {
  min-height: 44px;
}

.lang-switcher {
  padding: 4px;
  background: rgba(255,255,255,.03);
  border-color: rgba(255,255,255,.08);
}

.lang-switcher a {
  min-width: 40px;
  height: 34px;
  color: #98a1ab;
  font-size: .77rem;
}

.lang-switcher a.active {
  background: rgba(203,181,138,.18);
  color: #fff2d1;
}

.main-nav__mobile-meta {
  display: none;
}

.menu-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid rgba(255,255,255,.1);
  background: rgba(255,255,255,.03);
}

.menu-toggle span {
  width: 18px;
  background: #f3ede3;
}

.dynamic-island.is-menu-open .menu-toggle span:first-child {
  transform: rotate(45deg);
}

.dynamic-island.is-menu-open .menu-toggle span:last-child {
  transform: rotate(-45deg);
}

.hero,
.page-hero {
  padding-top: 108px;
}

.sales-hero__grid,
.page-hero--story__grid {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(340px, .92fr);
  gap: 28px;
  align-items: stretch;
}

.hero-home__copy h1 {
  max-width: 12.8ch;
}

.hero-text,
.page-hero__text {
  max-width: 62ch;
  font-size: 1.04rem;
}

.hero-actions {
  margin: 30px 0 22px;
  gap: 14px;
}

.hero-proof {
  gap: 10px;
}

.hero-proof span {
  min-height: 38px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  color: #d5dbe3;
  font-size: .87rem;
}

.hero-stage,
.story-preview {
  padding: 0;
  overflow: hidden;
}

.hero-stage__frame,
.story-preview {
  display: grid;
  gap: 22px;
  min-height: 100%;
  padding: 26px;
}

.hero-stage__chrome {
  display: flex;
  gap: 8px;
}

.hero-stage__chrome span {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
}

.hero-stage__intro h3 {
  margin-bottom: 0;
  font-size: clamp(1.4rem, 2.2vw, 2rem);
}

.hero-stage__stack,
.contact-methods,
.service-check-grid,
.price-calc__menu,
.price-calc__grid {
  display: grid;
  gap: 12px;
}

.hero-stage__row,
.hero-stage__metric,
.service-check-item,
.contact-method,
.price-menu-row {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}

.hero-stage__row strong,
.service-check-item strong,
.contact-method strong {
  display: block;
  color: var(--text);
}

.hero-stage__row span,
.hero-stage__metric span,
.story-stat span,
.contact-method span {
  color: var(--muted);
  font-size: .9rem;
  line-height: 1.56;
}

.hero-stage__metrics,
.cards-grid,
.sales-point-grid,
.project-grid,
.project-grid-advanced,
.process-grid,
.service-value-grid,
.immersive-grid,
.step-grid,
.demo-grid {
  display: grid;
  gap: 18px;
}

.hero-stage__metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.hero-stage__metric strong,
.story-stat strong {
  display: block;
  margin-bottom: 6px;
  color: #fff0d0;
  font-family: "Fraunces", Georgia, serif;
  font-size: 1.08rem;
}

.sales-point-grid,
.cards-grid,
.service-value-grid,
.immersive-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.project-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.project-grid-advanced,
.process-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.project-grid-advanced {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.step-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.home-pricing-grid--four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.info-card,
.process-card,
.project-card,
.content-card,
.sticky-card,
.about-panel,
.contact-form,
.footer-col--brand,
.immersive-panel,
.demo-card {
  padding: 26px;
}

.info-card,
.process-card,
.project-card,
.contact-method,
.faq-item,
.demo-card,
.immersive-panel {
  transition: transform .28s ease, border-color .28s ease, box-shadow .28s ease;
}

.info-card:hover,
.process-card:hover,
.project-card:hover,
.contact-method:hover,
.faq-item:hover,
.demo-card:hover,
.immersive-panel:hover {
  transform: translateY(-4px);
  border-color: rgba(203,181,138,.24);
  box-shadow: 0 26px 56px rgba(0,0,0,.28);
}

.service-icon {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  margin-bottom: 16px;
  border-radius: 14px;
  background: rgba(203,181,138,.12);
  color: #eadab7;
}

.service-icon svg,
.social-icon svg {
  width: 18px;
  height: 18px;
}

.service-card__index,
.process-step,
.step-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  height: 44px;
  padding: 0 12px;
  margin-bottom: 16px;
  border-radius: 999px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  color: #eadab7;
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.tag-list,
.project-meta-row,
.hero-proof,
.home-inline-cta,
.demo-card__actions,
.footer-cta__actions,
.story-preview__actions,
.hero-actions,
.footer-direct-links,
.footer-socials {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}

.tag-list span,
.project-meta {
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  color: #cfd4db;
  font-size: .78rem;
}

.service-card__actions,
.project-card .service-card__actions {
  margin-top: auto;
  padding-top: 16px;
  border-top: 1px solid rgba(255,255,255,.08);
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
}

.service-card__actions a,
.footer-direct-links a {
  color: #efe4cd;
}

.service-card__actions a:hover,
.footer-direct-links a:hover {
  color: #fff;
}

.service-card-featured {
  border-color: rgba(203,181,138,.26);
  background: linear-gradient(180deg, rgba(203,181,138,.12), rgba(19,23,29,.96));
}

.pricing-value {
  margin: 8px 0 12px;
  color: #fff0d0;
  font-family: "Fraunces", Georgia, serif;
  font-size: clamp(1.55rem, 3vw, 2.2rem);
}

.project-card,
.demo-card {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.project-thumb,
.story-preview__frame,
.demo-spotlight__thumb {
  min-height: 210px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.08);
}

.media-1,
.visual-1 {
  background:
    linear-gradient(135deg, rgba(203,181,138,.16), rgba(255,255,255,.02)),
    radial-gradient(circle at 24% 22%, rgba(255,255,255,.12), transparent 24%),
    linear-gradient(180deg, #1c2129, #13171d);
}

.media-2,
.visual-2 {
  background:
    linear-gradient(135deg, rgba(255,255,255,.05), rgba(203,181,138,.08)),
    radial-gradient(circle at 72% 18%, rgba(203,181,138,.14), transparent 22%),
    linear-gradient(180deg, #1a1f27, #11151b);
}

.media-3,
.visual-3 {
  background:
    linear-gradient(135deg, rgba(203,181,138,.12), rgba(255,255,255,.02)),
    radial-gradient(circle at 30% 70%, rgba(255,255,255,.08), transparent 24%),
    linear-gradient(180deg, #171b22, #0f1319);
}

.split-grid,
.demo-spotlight,
.contact-grid,
.faq-grid,
.page-hero--story__grid {
  display: grid;
  gap: 24px;
}

.split-grid-wide {
  grid-template-columns: minmax(0, .96fr) minmax(0, 1.04fr);
}

.demo-spotlight,
.contact-grid,
.faq-grid {
  grid-template-columns: minmax(0, 1.04fr) minmax(0, .96fr);
}

.demo-spotlight {
  align-items: center;
  padding: 30px;
  border-radius: 32px;
}

.demo-spotlight__card {
  display: grid;
  gap: 16px;
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}

.demo-spotlight__meta,
.story-preview__meta {
  display: grid;
  gap: 12px;
}

.page-hero__inner {
  max-width: 820px;
  display: grid;
  gap: 16px;
}

.page-hero__title {
  max-width: 15ch;
}

.story-stat-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}

.story-stat {
  padding: 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.02);
}

.price-calc {
  padding: 28px;
  display: grid;
  grid-template-columns: minmax(280px, .72fr) minmax(0, 1fr) minmax(260px, .7fr);
  gap: 22px;
  align-items: start;
}

.price-menu-row {
  display: flex;
  justify-content: space-between;
  gap: 14px;
}

.price-menu-row span {
  color: var(--muted);
}

.price-menu-row strong {
  color: #fff0d0;
  font-size: .88rem;
}

.contact-form label,
.price-calc label {
  display: grid;
  gap: 8px;
  font-size: .92rem;
  color: #d9dfe6;
}

.contact-form input,
.contact-form textarea,
.price-calc select,
.price-calc textarea {
  width: 100%;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.09);
  background: rgba(255,255,255,.03);
  color: var(--text);
  outline: none;
  transition: border-color .2s ease, background .2s ease, box-shadow .2s ease;
}

.contact-form input:focus,
.contact-form textarea:focus,
.price-calc select:focus,
.price-calc textarea:focus {
  border-color: rgba(203,181,138,.35);
  box-shadow: 0 0 0 4px rgba(203,181,138,.08);
  background: rgba(255,255,255,.045);
}

.contact-form__trap {
  position: absolute;
  left: -9999px;
  opacity: 0;
  pointer-events: none;
}

.field-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.price-calc__result {
  padding: 22px;
  border-radius: 24px;
  background: rgba(255,255,255,.02);
  border: 1px solid rgba(255,255,255,.08);
}

.price-calc__result small {
  display: block;
  margin-bottom: 8px;
  color: #aeb6c1;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.price-calc__result strong {
  display: block;
  color: #fff0d0;
  font-family: "Fraunces", Georgia, serif;
  font-size: clamp(1.6rem, 2.4vw, 2.3rem);
}

.calc-breakdown {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.calc-breakdown span {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  font-size: .88rem;
  color: var(--muted);
}

.calc-breakdown strong {
  color: #fff0d0;
}

.calc-breakdown em {
  font-style: normal;
}

.price-calc__microcopy {
  margin-bottom: 18px;
  color: var(--muted);
  font-size: .9rem;
}

.form-status {
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 16px;
  background: rgba(177,77,77,.12);
  border: 1px solid rgba(177,77,77,.3);
  color: #f3cbc9;
}

.feature-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 12px;
}

.feature-list li {
  position: relative;
  padding-left: 18px;
}

.feature-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 10px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: none;
}

.faq-item {
  padding: 0;
  overflow: hidden;
}

.faq-item summary {
  list-style: none;
  cursor: pointer;
  padding: 20px 22px;
  position: relative;
  font-weight: 600;
  color: var(--text);
}

.faq-item summary::-webkit-details-marker {
  display: none;
}

.faq-item summary::after {
  content: "+";
  position: absolute;
  right: 22px;
  top: 20px;
  color: #eadab7;
  font-size: 1.2rem;
}

.faq-item[open] summary::after {
  content: "-";
}

.faq-item p {
  padding: 0 22px 20px;
}

.footer-banner__shell {
  padding: 0 20px;
}

.footer-banner__inner,
.footer-cta {
  padding: 28px 30px;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) auto;
  gap: 24px;
  align-items: center;
}

.site-footer {
  padding: 0 0 24px;
}

.footer-grid--final {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1.2fr) repeat(3, minmax(0, .8fr));
  align-items: start;
}

.footer-brand-logo img,
.footer-brand-logo .custom-logo {
  max-height: 42px;
  width: auto;
}

.footer-brand-copy {
  margin-bottom: 18px;
}

.footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 10px;
}

.footer-list a {
  color: var(--muted);
}

.footer-list a:hover {
  color: var(--text);
}

.footer-grid--final h4 {
  margin-bottom: 14px;
  font-size: 1rem;
}

.footer-subtitle {
  margin-top: 24px;
}

.social-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.08);
  color: #f1e6d0;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(255,255,255,.08);
  color: #919aa6;
  font-size: .9rem;
}

.cookie-consent {
  position: fixed;
  left: 20px;
  right: 20px;
  bottom: 20px;
  z-index: 60;
}

.cookie-consent__inner {
  padding: 18px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.back-to-top {
  position: fixed;
  right: 20px;
  bottom: 20px;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(10,12,16,.88);
  color: #fff0d0;
  display: grid;
  place-items: center;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity .25s ease, transform .25s ease;
  z-index: 55;
}

.back-to-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: none;
}

.thank-you-card {
  display: grid;
  gap: 18px;
}

.thank-you-card__tags,
.thank-you-card__actions {
  justify-content: center;
}

.reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .7s ease, transform .7s cubic-bezier(.2,.9,.2,1);
}

.reveal.is-visible {
  opacity: 1;
  transform: none;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .reveal,
  .site-loader__inner,
  .site-loader__logo,
  .site-loader__label,
  .site-loader__line,
  .info-card,
  .process-card,
  .project-card,
  .contact-method,
  .faq-item,
  .demo-card,
  .immersive-panel {
    animation: none !important;
    transition: none !important;
    transform: none !important;
  }
}

@media (max-width: 1180px) {
  .home-pricing-grid--four,
  .project-grid,
  .project-grid-advanced {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .footer-grid--final,
  .step-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .price-calc {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 980px) {
  .site-header {
    top: 12px;
    padding: 0 14px;
  }

  .dynamic-island__pill {
    grid-template-columns: auto auto;
    gap: 12px;
    padding: 12px 14px;
  }

  .main-nav {
    grid-column: 1 / -1;
    display: none;
  }

  .main-nav.is-open {
    display: block;
    padding-top: 10px;
  }

  .menu-toggle {
    display: inline-flex;
  }

  .lang-switcher--desktop,
  .desktop-cta {
    display: none !important;
  }

  .lang-switcher--mobile {
    display: inline-flex;
  }

  .menu-inline,
  .menu-inline ul {
    flex-direction: column;
    align-items: stretch;
  }

  .menu-inline a {
    height: auto;
    justify-content: flex-start;
    padding: 12px 14px;
    border-radius: 16px;
  }

  .main-nav__mobile-meta {
    display: grid;
    gap: 12px;
    padding-top: 14px;
    margin-top: 14px;
    border-top: 1px solid rgba(255,255,255,.08);
  }

  .sales-hero__grid,
  .page-hero--story__grid,
  .split-grid-wide,
  .demo-spotlight,
  .contact-grid,
  .faq-grid,
  .footer-banner__inner,
  .footer-grid--final {
    grid-template-columns: 1fr;
  }

  .sales-point-grid,
  .cards-grid,
  .project-grid-advanced,
  .service-value-grid,
  .process-grid,
  .immersive-grid,
  .demo-grid,
  .step-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 680px) {
  .container {
    width: min(var(--container), calc(100% - 26px));
  }

  .section {
    padding: 84px 0;
  }

  .sales-point-grid,
  .cards-grid,
  .project-grid,
  .project-grid-advanced,
  .service-value-grid,
  .process-grid,
  .immersive-grid,
  .demo-grid,
  .step-grid,
  .home-pricing-grid--four,
  .field-grid,
  .hero-stage__metrics,
  .story-stat-strip {
    grid-template-columns: 1fr;
  }

  .hero-stage__frame,
  .story-preview,
  .contact-form,
  .content-card,
  .info-card,
  .project-card,
  .demo-card,
  .footer-col--brand,
  .footer-banner__inner,
  .footer-cta,
  .demo-spotlight,
  .contact-sidebar-card {
    padding: 20px;
  }

  .hero-actions,
  .home-inline-cta,
  .demo-card__actions,
  .footer-cta__actions,
  .story-preview__actions,
  .thank-you-card__actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .footer-bottom,
  .cookie-consent__inner {
    flex-direction: column;
    align-items: flex-start;
  }

  .cookie-consent {
    left: 12px;
    right: 12px;
    bottom: 12px;
  }
}
