/* ==========================================================================
   PlainPages, base.css
   Structure, layout, and components. Visual identity lives in the theme
   files (styles/themes/*.css), which set the custom properties below and
   add per-mode flourishes. Keep structural rules here, personality there.
   ========================================================================== */

/* ---------- Tokens (neutral defaults; every theme overrides these) ------- */
:root {
  --bg: #fafafa;            /* page background */
  --bg-soft: #f1f1f1;       /* alternate section background */
  --surface: #ffffff;       /* cards, panels, windows */
  --ink: #141414;           /* primary text */
  --muted: #5c5c5c;         /* secondary text */
  --accent: #d92d20;        /* primary accent */
  --accent-ink: #ffffff;    /* text on accent */
  --accent-2: #141414;      /* secondary accent */
  --line: #e4e4e4;          /* hairlines and borders */
  --border-w: 1px;
  --radius: 2px;
  --radius-lg: 4px;
  --shadow: none;
  --shadow-strong: none;

  --font-body: "Inter", "Noto Sans Thai", "Noto Sans SC", "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-display: "Inter", "Noto Sans Thai", "Noto Sans SC", "Sarabun", system-ui, -apple-system, "Segoe UI", sans-serif;
  --font-mono: "IBM Plex Mono", "Noto Sans Thai", "Noto Sans SC", ui-monospace, monospace;

  --h-weight: 700;
  --h-tracking: -0.02em;
  --h-transform: none;
  --kicker-font: var(--font-mono);

  --btn-radius: 2px;
  --dur: 0.45s;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--header-offset, 6rem);
}
html.is-theme-switching { scroll-behavior: auto; }
body {
  font-family: var(--font-body);
  font-size: 1rem;
  line-height: 1.6;
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  transition: background-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; cursor: pointer; }
input, select, textarea { font: inherit; color: inherit; }
a { color: inherit; }

/* Keep translated text in fonts designed for its script, even when a visual
   theme normally swaps in a decorative Latin display face. */
html[lang="th"] {
  --font-body: "Noto Sans Thai", "Sarabun", "Inter", system-ui, sans-serif !important;
  --font-display: "Noto Sans Thai", "Sarabun", "Inter", system-ui, sans-serif !important;
  --font-mono: "Noto Sans Thai", "Sarabun", "Inter", system-ui, sans-serif !important;
  --h-transform: none !important;
  --h-tracking: 0 !important;
}
html[lang="zh"] {
  --font-body: "Noto Sans SC", "Inter", system-ui, sans-serif !important;
  --font-display: "Noto Sans SC", "Inter", system-ui, sans-serif !important;
  --font-mono: "Noto Sans SC", "Inter", system-ui, sans-serif !important;
  --h-transform: none !important;
  --h-tracking: 0 !important;
}
/* Thai stacks vowels and tone marks above/below the line, so give it a little
   more breathing room and keep long compounds from clipping tight buttons. */
html[lang="th"] body { line-height: 1.75; }
html[lang="th"] .btn,
html[lang="th"] .lang-btn,
html[lang="th"] .nav-link { line-height: 1.5; }
html[lang="th"] .hero-title,
html[lang="th"] .section-title { line-height: 1.3; }
html[lang="zh"] body { line-height: 1.7; }
html[lang="zh"] .hero-title,
html[lang="zh"] .section-title { line-height: 1.22; }
html:is([lang="th"], [lang="zh"]) :is(
  .lang-btn, .lang-option, .nav-link, .btn, .kicker, .tk-item, .hp,
  .service-feature__kicker, .service-option__label, .demo-cat, .price-badge,
  .ci-label, .mp-label, .ms-eyebrow, .ms-status, .ms-mode, .ms-stat-label,
  .ms-meter, .adm-meta
) {
  letter-spacing: 0 !important;
  text-transform: none !important;
}
::selection { background: var(--accent); color: var(--accent-ink); }

:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; }

.skip-link {
  position: absolute; left: -999px; top: 0; z-index: 100;
  padding: 0.6rem 1rem; background: var(--ink); color: var(--bg);
  text-decoration: none; font-weight: 600;
}
.skip-link:focus { left: 0.5rem; top: 0.5rem; }

.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}

/* ---------- Layout ---------- */
.container { max-width: 1140px; margin-inline: auto; padding-inline: clamp(1.1rem, 4vw, 2rem); }
.section {
  padding-block: clamp(4rem, 9vw, 6.5rem);
  position: relative;
  scroll-margin-top: var(--header-offset, 6rem);
}
.section--alt { background: var(--bg-soft); transition: background-color var(--dur) var(--ease); }

.section-head { max-width: 46rem; margin-bottom: clamp(2.2rem, 5vw, 3.5rem); }
.kicker {
  font-family: var(--kicker-font);
  font-size: 0.78rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.9rem;
}
.section-title {
  font-family: var(--font-display);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  text-transform: var(--h-transform);
  font-size: clamp(1.7rem, 3.6vw, 2.6rem);
  line-height: 1.15;
}
.section-intro { margin-top: 1rem; color: var(--muted); max-width: 42rem; }

h3 {
  font-family: var(--font-display);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  text-transform: var(--h-transform);
  font-size: 1.08rem;
  line-height: 1.3;
}

/* ---------- Buttons ---------- */
.btn {
  display: inline-block;
  padding: 0.85rem 1.7rem;
  border: var(--border-w) solid var(--ink);
  border-radius: var(--btn-radius);
  font-weight: 600;
  font-size: 0.95rem;
  text-decoration: none;
  line-height: 1.2;
  transition: transform 0.18s var(--ease), background-color 0.18s ease,
              color 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}
.btn--primary { background: var(--ink); color: var(--bg); }
.btn--primary:hover { background: var(--accent); border-color: var(--accent); color: var(--accent-ink); }
.btn--ghost { background: transparent; color: var(--ink); }
.btn--ghost:hover { background: var(--ink); color: var(--bg); }

/* ---------- Header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 70;
  padding-block: 0.72rem;
  border-bottom: var(--border-w) solid color-mix(in srgb, var(--line) 74%, transparent);
  background: color-mix(in srgb, var(--bg) 88%, transparent);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: background-color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
}
.site-header.is-scrolled {
  border-bottom-color: color-mix(in srgb, var(--line) 92%, transparent);
  box-shadow: 0 12px 30px color-mix(in srgb, var(--ink) 10%, transparent);
}
.header-inner {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  grid-template-areas: "brand nav actions";
  align-items: center;
  gap: clamp(0.8rem, 2.2vw, 1.5rem);
}
.brand {
  --brand-page: var(--accent);
  --brand-fold: var(--accent-2);
  --brand-outline: transparent;
  --brand-outline-w: 0;
  grid-area: brand;
  display: flex;
  align-items: center;
  justify-self: start;
  gap: 0.5rem;
  text-decoration: none;
}
.brand-mark {
  width: 1.55rem;
  height: 1.55rem;
  flex: 0 0 auto;
  overflow: visible;
  transition: transform 0.22s var(--ease), filter 0.22s ease;
}
.bm-page,
.bm-fold {
  stroke: var(--brand-outline);
  stroke-width: var(--brand-outline-w);
  stroke-linejoin: miter;
  vector-effect: non-scaling-stroke;
  transition: fill 0.22s ease, stroke 0.22s ease;
}
.bm-page { fill: var(--brand-page); }
.bm-fold { fill: var(--brand-fold); }
.brand-name { font-family: var(--font-display); font-weight: 800; letter-spacing: -0.045em; font-size: 1.1rem; }
.brand-name i { font-style: normal; font-weight: 400; color: var(--muted); }

/* The page mark keeps one silhouette while adopting each mode's visual rules. */
:is(
  [data-theme="kinetic"], [data-theme="brutal"], [data-theme="constructivist"],
  [data-theme="bauhaus"], [data-theme="pixel"], [data-theme="poster"]
) .brand {
  --brand-outline: var(--ink);
  --brand-outline-w: 1.5;
}
:is(
  [data-theme="kinetic"], [data-theme="brutal"], [data-theme="bauhaus"],
  [data-theme="pixel"], [data-theme="poster"]
) .brand-mark {
  filter: drop-shadow(2px 2px 0 var(--ink));
  transform: translate(-1px, -1px);
}
[data-theme="sketch"] .brand-mark { transform: rotate(-2deg); }
[data-theme="sketch"] .brand {
  --brand-outline: var(--ink);
  --brand-outline-w: 1.15;
}
[data-theme="collage"] .brand-mark {
  filter: drop-shadow(2px 3px 0 color-mix(in srgb, var(--ink) 22%, transparent));
  transform: rotate(-3deg);
}
[data-theme="retro"] .brand-mark,
[data-theme="pixel"] .brand-mark { shape-rendering: crispEdges; }
[data-theme="y2k"] .brand-mark {
  filter: drop-shadow(0 3px 5px color-mix(in srgb, var(--accent) 32%, transparent));
  transform: rotate(2deg);
}
:is([data-theme="glass"], [data-theme="cyber"]) .brand-mark {
  filter: drop-shadow(0 0 6px color-mix(in srgb, var(--accent) 72%, transparent));
}
[data-theme="clay"] .brand-mark {
  filter:
    drop-shadow(2px 3px 3px rgba(83, 92, 135, 0.22))
    drop-shadow(-1px -1px 1px rgba(255, 255, 255, 0.9));
}
[data-theme="organic"] .brand-mark { transform: rotate(1.5deg); }
[data-theme="wellness"] .brand-mark {
  filter: drop-shadow(0 4px 7px color-mix(in srgb, var(--accent) 20%, transparent));
}
.site-nav {
  grid-area: nav;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.35rem, 1vw, 0.75rem);
}
.nav-link {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-height: 2.25rem;
  padding: 0.25rem 0.55rem;
  border-radius: var(--btn-radius);
  text-decoration: none;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--muted);
  line-height: 1.1;
  transition: color 0.18s ease, background-color 0.18s ease, transform 0.18s var(--ease);
}
.nav-link:hover,
.nav-link:focus-visible {
  color: var(--ink);
  background: color-mix(in srgb, var(--surface) 72%, transparent);
}
.nav-link[aria-current="true"] {
  color: var(--ink);
}
.nav-link[aria-current="true"]::after {
  content: "";
  position: absolute;
  left: 0.55rem;
  right: 0.55rem;
  bottom: 0.2rem;
  height: 2px;
  background: var(--accent);
  border-radius: 99px;
}
.header-actions {
  grid-area: actions;
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-self: end;
  gap: 0.65rem;
}
.lang-switcher {
  position: relative;
  flex: 0 0 auto;
}
.lang-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  min-height: 2.35rem;
  padding: 0.4rem 0.65rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: transparent;
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0;
  line-height: 1.2;
  white-space: nowrap;
  transition: border-color 0.18s ease, background-color 0.18s ease, color 0.18s ease;
}
.lang-btn:hover,
.lang-btn[aria-expanded="true"] {
  border-color: var(--ink);
  background: color-mix(in srgb, var(--surface) 82%, transparent);
}
.lang-icon { width: 1rem; height: 1rem; flex: 0 0 auto; }
.lang-current { min-width: 3.4rem; text-align: left; }
.lang-chevron {
  width: 0.65rem;
  height: 0.45rem;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.6;
  transition: transform 0.18s var(--ease);
}
.lang-btn[aria-expanded="true"] .lang-chevron { transform: rotate(180deg); }
.lang-menu {
  position: absolute;
  z-index: 30;
  top: calc(100% + 0.45rem);
  right: 0;
  width: max-content;
  min-width: 10rem;
  padding: 0.35rem;
  border: var(--border-w) solid var(--line);
  border-radius: max(var(--btn-radius), 0.45rem);
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 16px 36px color-mix(in srgb, var(--ink) 16%, transparent);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.35rem) scale(0.98);
  transform-origin: top right;
  pointer-events: none;
  transition: opacity 0.16s ease, transform 0.16s var(--ease), visibility 0s linear 0.16s;
}
.lang-switcher[data-open="true"] .lang-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  pointer-events: auto;
  transition-delay: 0s;
}
.lang-option {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  min-height: 2.5rem;
  padding: 0.5rem 0.65rem;
  border: 0;
  border-radius: max(calc(var(--btn-radius) - 1px), 0.3rem);
  background: transparent;
  color: inherit;
  text-align: left;
  font-weight: 600;
  line-height: 1.35;
}
.lang-option:hover,
.lang-option:focus-visible {
  background: color-mix(in srgb, var(--accent) 10%, var(--surface));
}
.lang-option[aria-checked="true"] {
  color: var(--accent);
  background: color-mix(in srgb, var(--accent) 8%, var(--surface));
}
.lang-check { opacity: 0; }
.lang-option[aria-checked="true"] .lang-check { opacity: 1; }
.header-cta {
  padding: 0.68rem 1rem;
  font-size: 0.86rem;
  white-space: nowrap;
}
/* Expressive themes give .btn large padding and wide tracking. Specificity lets
   those win over the compact header CTA and balloon the actions column until it
   overlaps the nav. Keep the desktop header CTA compact regardless of theme. */
.header-inner .header-actions .header-cta {
  padding-inline: 1rem;
  letter-spacing: 0.05em;
}
.header-cta--mobile { display: none; }
.nav-toggle {
  grid-area: toggle;
  position: relative;
  z-index: 2;
  display: none;
  width: 2.35rem;
  height: 2.35rem;
  padding: 0;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: var(--surface);
  align-items: center;
  justify-content: center;
  gap: 0.28rem;
  flex-direction: column;
}
.nav-toggle span {
  display: block;
  width: 1rem;
  height: 2px;
  background: var(--ink);
  transition: transform 0.18s var(--ease), opacity 0.18s ease;
}
.nav-toggle[aria-expanded="true"] span:first-child { transform: translateY(3px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:last-child { transform: translateY(-3px) rotate(-45deg); }

/* ---------- Hero ---------- */
.hero { padding-block: clamp(4rem, 10vw, 7.5rem); overflow: hidden; scroll-margin-top: var(--header-offset, 6rem); }
.hero-inner {
  display: grid;
  grid-template-columns: minmax(0, 7fr) minmax(0, 5fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: center;
}
.hero .kicker { margin-bottom: 1.2rem; }
.hero-title {
  font-family: var(--font-display);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  text-transform: var(--h-transform);
  font-size: clamp(2.1rem, 5.4vw, 3.7rem);
  line-height: 1.06;
}
.hero-title span { display: block; }
.hero-title em { font-style: normal; color: var(--accent); }
.hero-sub { margin-top: 1.4rem; color: var(--muted); max-width: 34rem; font-size: 1.05rem; }
.hero-points { list-style: none; padding: 0; margin-top: 1.5rem; display: flex; flex-wrap: wrap; gap: 0.55rem 0.6rem; }
.hp {
  font-size: 0.82rem; font-weight: 600;
  padding: 0.38rem 0.8rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: var(--surface);
}
.hero-ctas { margin-top: 2.1rem; display: flex; gap: 0.8rem; flex-wrap: wrap; }

/* Hero art, generic shapes + a browser window every theme restyles */
.hero-art { position: relative; min-height: 320px; }
.ha { position: absolute; display: block; }
.ha-1, .ha-2, .ha-3, .ha-4 { opacity: 0; } /* themes opt shapes in */

.win {
  position: relative;
  background: var(--surface);
  border: var(--border-w) solid var(--ink);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-strong);
  transition: border-radius var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.win--hero { position: absolute; inset: 12% 4% auto 8%; z-index: 2; }
.win-bar {
  display: flex; align-items: center; gap: 0.6rem;
  padding: 0.55rem 0.8rem;
  border-bottom: var(--border-w) solid var(--line);
  font-family: var(--font-mono); font-size: 0.72rem; color: var(--muted);
}
.win-dots { display: inline-flex; gap: 0.3rem; }
.win-dots i { width: 0.55rem; height: 0.55rem; border-radius: 50%; background: var(--line); }
.win-title { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.win-body { padding: 1.1rem 1.2rem 1.3rem; display: grid; grid-template-columns: minmax(0, 1fr); gap: 0.7rem; }
.ha-line { height: 0.55rem; border-radius: 99px; background: var(--line); }
.ha-line.w55 { width: 55%; }
.ha-line.w90 { width: 90%; }
.ha-line.w70 { width: 70%; }
.ha-chips { display: flex; gap: 0.5rem; margin-top: 0.2rem; }
.ha-chip { width: 4.2rem; height: 1.5rem; border-radius: var(--btn-radius); background: var(--ink); }
.ha-chip--alt { background: transparent; border: var(--border-w) solid var(--ink); }
.ha-bar { height: 0.75rem; border: var(--border-w) solid var(--line); border-radius: 99px; overflow: hidden; display: none; }
.ha-bar i { display: block; height: 100%; width: 62%; background: var(--accent); }

.doodle { position: absolute; display: none; color: var(--accent); }

/* Extra decoration slots, hidden by default, artistic themes opt in */
.td { position: absolute; display: none; pointer-events: none; }

/* ---------- Marquee ticker ----------
   Two identical .tk-group halves scroll by -50% for a seamless loop.
   Reduced-motion users get a static strip (global rule kills the animation). */
.ticker {
  --tk-dur: 38s;
  overflow: hidden;
  padding-block: 0.7rem;
  background: var(--surface);
  border-top: var(--border-w) solid var(--line);
  border-bottom: var(--border-w) solid var(--line);
  user-select: none;
  transition: background-color var(--dur) var(--ease);
}
.ticker-track {
  display: flex; width: max-content;
  animation: tk-scroll var(--tk-dur) linear infinite;
}
.ticker:hover .ticker-track { animation-play-state: paused; }
.tk-group { display: flex; align-items: center; flex: 0 0 auto; }
.tk-item {
  flex: 0 0 auto; white-space: nowrap;
  font-family: var(--kicker-font);
  font-size: 0.76rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--muted);
}
.tk-sep { flex: 0 0 auto; margin-inline: 1.5rem; color: var(--accent); line-height: 1; }
.tk-sep::before { content: "•"; }
@keyframes tk-scroll { to { transform: translateX(-50%); } }

/* ---------- Design-mode carousel ---------- */
.carousel { display: flex; align-items: stretch; gap: 0.7rem; }
.car-btn {
  flex: 0 0 auto; align-self: center;
  width: 2.6rem; height: 2.6rem;
  display: grid; place-items: center;
  border: var(--border-w) solid var(--ink);
  border-radius: var(--btn-radius);
  background: var(--surface);
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s var(--ease);
}
.car-btn svg { width: 1.1rem; height: 1.1rem; }
.car-btn:hover { background: var(--ink); color: var(--bg); }
.car-track {
  display: flex; gap: 0.9rem;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  padding: 0.8rem 0.3rem 1.1rem;
  scrollbar-width: none;
}
.car-track.is-auto-scrolling { scroll-snap-type: none; }
.car-track::-webkit-scrollbar { display: none; }
.mode-card[data-carousel-clone] {
  cursor: pointer;
}

/* Each mode card is permanently rendered in its OWN visual language
   (see the theme files), the carousel is its own little gallery. */
.mode-card {
  flex: 0 0 11.5rem;
  scroll-snap-align: center;
  display: flex; flex-direction: column; gap: 0.25rem;
  padding: 0.8rem 0.8rem 0.95rem;
  text-align: left;
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  transition: transform 0.22s var(--ease), box-shadow 0.22s var(--ease);
}
.mode-card:hover { transform: translateY(-3px); }
.mode-card.is-selected { position: relative; }
.mode-card.is-selected::after {
  content: ""; position: absolute; inset: -5px;
  border: 2px solid var(--accent);
  border-radius: inherit;
  pointer-events: none;
}
.mc-prev {
  position: relative; height: 5.6rem; margin-bottom: 0.55rem;
  border-radius: 4px; overflow: hidden; display: block;
}
.mp { position: absolute; display: block; }
.mc-aa { position: absolute; font-size: 1.5rem; line-height: 1; }
.mc-name { font-weight: 700; font-size: 0.95rem; font-family: var(--font-body); }
.mc-desc { font-size: 0.78rem; color: var(--muted); }

/* ---------- Design philosophy panel ---------- */
.mode-panel {
  margin-top: 1.5rem;
  max-width: 56rem;
  padding: clamp(1.3rem, 3vw, 1.9rem);
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  transition: background-color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.mp-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; margin-bottom: 1.1rem;
}
.mp-dots { position: relative; display: flex; align-items: center; gap: 0.5rem; }
.mp-dot {
  width: 1.1rem; height: 1.1rem; padding: 0;
  border-radius: 50%;
  border: 1px solid color-mix(in srgb, var(--ink) 25%, transparent);
  transition: transform 0.16s var(--ease);
}
.mp-dot--a { background: var(--accent); }
.mp-dot--b { background: var(--accent-2); }
.mp-dot--c { background: var(--ink); }
.mp-dot:hover, .mp-dot[aria-expanded="true"] { transform: scale(1.2); }
.mp-index {
  font-family: var(--font-mono);
  font-size: 0.74rem; letter-spacing: 0.12em;
  color: var(--muted);
  text-transform: uppercase;
}
.mp-title {
  font-family: var(--font-display);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  text-transform: var(--h-transform);
  font-size: 1.3rem;
  margin-bottom: 0.55rem;
}
.mp-philosophy { color: var(--muted); max-width: 44rem; }
.mp-cols {
  display: grid;
  grid-template-columns: minmax(0, 2fr) minmax(0, 3fr);
  gap: 1.5rem;
  margin-top: 1.2rem; padding-top: 1.2rem;
  border-top: var(--border-w) solid var(--line);
}
.mp-label {
  font-family: var(--kicker-font);
  font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.45rem;
}
.mp-bestfor, .mp-visual { color: var(--muted); font-size: 0.92rem; }

/* ---------- Palette popover ---------- */
.palette-pop {
  position: absolute; top: calc(100% + 0.7rem); left: 0; z-index: 40;
  min-width: 16rem;
  padding: 0.9rem;
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: 0 14px 36px rgba(0, 0, 0, 0.2);
}
.pp-title {
  font-family: var(--kicker-font);
  font-size: 0.66rem; letter-spacing: 0.13em; text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 0.65rem;
}
.pp-list { display: grid; gap: 0.35rem; }
.pp-option {
  display: flex; align-items: center; gap: 0.65rem;
  width: 100%; padding: 0.5rem 0.6rem;
  border: 1px solid transparent;
  border-radius: var(--btn-radius);
  background: transparent;
  font-size: 0.86rem; font-weight: 600;
  text-align: left;
}
.pp-option:hover { border-color: var(--line); background: var(--bg-soft); }
.pp-option[aria-checked="true"] { border-color: var(--accent); }
.pp-swatches { display: inline-flex; gap: 0.28rem; }
.pp-swatches i {
  width: 0.85rem; height: 0.85rem; border-radius: 50%;
  border: 1px solid rgba(0, 0, 0, 0.15);
}

/* ---------- Services ---------- */
.svc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15.5rem, 1fr));
  gap: 1.1rem;
}
.svc-card {
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem 1.4rem 1.6rem;
  transition: transform 0.22s var(--ease), box-shadow 0.22s var(--ease),
              border-color 0.22s ease, background-color var(--dur) var(--ease);
}
.svc-card h3 { margin-bottom: 0.5rem; }
.svc-card p { color: var(--muted); font-size: 0.93rem; }
.svc-icon { width: 2.4rem; height: 2.4rem; margin-bottom: 1rem; color: var(--accent); }
.ic { display: none; width: 100%; height: 100%; }
.cut { fill: var(--surface); }
.cut-stroke { stroke: var(--surface); }

/* Icon sets per theme: line (default), bold/blocky, hand-drawn */
[data-theme="mono"] .ic--line,
[data-theme="swiss"] .ic--line,
[data-theme="bento"] .ic--line,
[data-theme="editorial"] .ic--line,
[data-theme="glass"] .ic--line,
[data-theme="organic"] .ic--line,
[data-theme="luxe"] .ic--line,
[data-theme="cyber"] .ic--line,
[data-theme="clay"] .ic--line { display: block; }
[data-theme="kinetic"] .ic--bold,
[data-theme="brutal"] .ic--bold,
[data-theme="constructivist"] .ic--bold,
[data-theme="retro"] .ic--bold,
[data-theme="y2k"] .ic--bold,
[data-theme="collage"] .ic--bold,
[data-theme="bauhaus"] .ic--bold { display: block; }
[data-theme="sketch"] .ic--sketch { display: block; }

/* ---------- Interactive service showcase ---------- */
.services {
  overflow: clip;
}
.services::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 11% 22%, rgba(255, 119, 184, 0.12), transparent 27rem),
    radial-gradient(circle at 88% 18%, rgba(112, 135, 255, 0.13), transparent 28rem),
    radial-gradient(circle at 72% 84%, rgba(91, 211, 255, 0.1), transparent 24rem);
}
.services .container { position: relative; z-index: 1; }
.services .section-head { max-width: 50rem; }
.services-showcase {
  --service-color: #7181ff;
  --service-color-2: #68d5ff;
  position: relative;
}
.service-feature {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: minmax(0, 1.05fr) minmax(22rem, 0.95fr);
  height: 35rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--service-color) 24%, var(--line));
  border-radius: clamp(1.5rem, 3vw, 2.3rem);
  background:
    linear-gradient(135deg,
      color-mix(in srgb, var(--surface) 91%, #fff 9%),
      color-mix(in srgb, var(--surface) 86%, var(--service-color) 14%));
  box-shadow:
    0 32px 90px color-mix(in srgb, var(--ink) 13%, transparent),
    0 0 70px color-mix(in srgb, var(--service-color) 13%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  transition: border-color 0.28s ease, box-shadow 0.28s ease,
              background 0.28s ease;
}
.service-feature::before,
.service-feature::after {
  content: "";
  position: absolute;
  z-index: -1;
  border-radius: 50%;
  pointer-events: none;
  filter: blur(2px);
}
.service-feature::before {
  width: 18rem;
  height: 18rem;
  top: -9rem;
  right: 20%;
  background: color-mix(in srgb, var(--service-color) 21%, transparent);
}
.service-feature::after {
  width: 15rem;
  height: 15rem;
  left: 35%;
  bottom: -10rem;
  background: color-mix(in srgb, var(--service-color-2) 18%, transparent);
}
.service-feature__copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  padding: clamp(2rem, 5vw, 4.25rem);
  transition: opacity 0.18s ease, transform 0.28s var(--ease);
}
.service-feature__kicker {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  margin-bottom: 1.15rem;
  color: var(--service-color);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  line-height: 1.3;
  text-transform: uppercase;
}
.service-feature__kicker span {
  display: inline-grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  flex: 0 0 auto;
  border: 1px solid color-mix(in srgb, var(--service-color) 52%, transparent);
  border-radius: 50%;
  background: color-mix(in srgb, var(--surface) 70%, transparent);
}
.service-feature h3 {
  max-width: 12ch;
  font-size: clamp(2rem, 4.4vw, 3.65rem);
  line-height: 0.98;
  margin-bottom: 1.3rem;
}
.service-feature__text {
  max-width: 38rem;
  color: var(--muted);
  font-size: clamp(1rem, 1.35vw, 1.1rem);
  line-height: 1.72;
}
.service-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  padding: 0;
  margin-top: 1.55rem;
  list-style: none;
}
.service-tags li {
  padding: 0.48rem 0.72rem;
  border: 1px solid color-mix(in srgb, var(--service-color) 28%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--surface) 76%, transparent);
  color: color-mix(in srgb, var(--ink) 84%, var(--service-color));
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 500;
  letter-spacing: 0.02em;
}
.service-feature__visual {
  display: grid;
  place-items: center;
  min-width: 0;
  padding: clamp(1rem, 3vw, 2.25rem);
  transition: opacity 0.18s ease, transform 0.28s var(--ease);
}
.service-feature.is-changing .service-feature__copy {
  opacity: 0.35;
  transform: translateY(5px);
}
.service-feature.is-changing .service-feature__visual {
  opacity: 0.2;
  transform: scale(0.985);
}
.services-showcase:focus-within .service-feature {
  border-color: color-mix(in srgb, var(--service-color) 66%, var(--line));
  box-shadow:
    0 32px 90px color-mix(in srgb, var(--ink) 13%, transparent),
    0 0 0 3px color-mix(in srgb, var(--service-color) 22%, transparent),
    0 0 70px color-mix(in srgb, var(--service-color) 16%, transparent);
}

.service-options {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-auto-flow: row;
  gap: 0.9rem;
  margin-top: 1rem;
}
.service-option {
  --service-color: #7181ff;
  position: relative;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.8rem;
  min-height: 9rem;
  padding: 1.15rem;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--service-color) 18%, var(--line));
  border-radius: 1.25rem;
  background:
    linear-gradient(145deg,
      color-mix(in srgb, var(--surface) 86%, transparent),
      color-mix(in srgb, var(--surface) 74%, var(--service-color) 7%));
  box-shadow:
    0 13px 32px color-mix(in srgb, var(--ink) 7%, transparent),
    inset 0 1px 0 rgba(255, 255, 255, 0.68);
  text-align: left;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform 0.22s var(--ease), border-color 0.22s ease,
              box-shadow 0.22s ease, background 0.22s ease;
}
.service-option::before {
  content: "";
  position: absolute;
  inset: auto 15% -70% auto;
  width: 7rem;
  height: 7rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--service-color) 18%, transparent);
  filter: blur(8px);
  transition: transform 0.3s var(--ease);
}
.service-option:hover,
.service-option:focus-visible {
  z-index: 1;
  transform: translateY(-4px);
  border-color: color-mix(in srgb, var(--service-color) 58%, var(--line));
  box-shadow:
    0 20px 42px color-mix(in srgb, var(--ink) 11%, transparent),
    0 0 32px color-mix(in srgb, var(--service-color) 11%, transparent);
}
.service-option:hover::before,
.service-option:focus-visible::before { transform: translateY(-12%); }
.service-option:focus-visible { outline: 2px solid var(--service-color); outline-offset: 3px; }
.service-option.is-active {
  position: fixed;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: 0;
  overflow: hidden;
  border: 0;
  opacity: 0;
  clip-path: inset(50%);
  white-space: nowrap;
  pointer-events: none;
}
.service-option__index {
  color: var(--service-color);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 600;
  line-height: 1.4;
}
.service-option__copy { min-width: 0; }
.service-option__label {
  display: block;
  margin-bottom: 0.5rem;
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  line-height: 1.35;
  text-transform: uppercase;
}
.service-option strong {
  display: block;
  font-family: var(--font-display);
  font-size: clamp(0.94rem, 1.35vw, 1.08rem);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  line-height: 1.25;
}
.service-option__arrow {
  width: 1.1rem;
  height: 1.1rem;
  color: var(--service-color);
  transition: transform 0.22s var(--ease);
}
.service-option:hover .service-option__arrow,
.service-option:focus-visible .service-option__arrow { transform: translate(2px, -2px); }
.service-noscript {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid var(--line);
  border-radius: 1rem;
  background: var(--surface);
  color: var(--muted);
}

/* CSS-only service illustrations */
.svc-visual {
  position: relative;
  width: min(100%, 29rem);
  aspect-ratio: 1.08;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--service-color) 24%, rgba(255, 255, 255, 0.7));
  border-radius: clamp(1.4rem, 3vw, 2rem);
  background:
    linear-gradient(rgba(255,255,255,0.17) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.17) 1px, transparent 1px),
    radial-gradient(circle at 18% 14%, color-mix(in srgb, var(--service-color-2) 34%, transparent), transparent 35%),
    linear-gradient(145deg,
      color-mix(in srgb, var(--service-color) 24%, #f8f5ff),
      color-mix(in srgb, var(--service-color-2) 20%, #effaff));
  background-size: 24px 24px, 24px 24px, auto, auto;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.8),
    0 24px 54px color-mix(in srgb, var(--service-color) 18%, transparent);
}
.svc-visual::before {
  content: "";
  position: absolute;
  width: 12rem;
  height: 12rem;
  right: -5rem;
  bottom: -5rem;
  border-radius: 50%;
  background: color-mix(in srgb, var(--service-color) 24%, transparent);
  filter: blur(12px);
}
.svc-ui {
  position: absolute;
  border: 1px solid rgba(255, 255, 255, 0.82);
  background: color-mix(in srgb, var(--surface) 78%, rgba(255,255,255,0.48));
  box-shadow: 0 18px 38px color-mix(in srgb, #27315f 20%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.svc-ui-lines {
  background:
    linear-gradient(var(--service-color), var(--service-color)) 0 0 / 52% 6px no-repeat,
    linear-gradient(color-mix(in srgb, var(--service-color) 24%, #d8dcef),
                    color-mix(in srgb, var(--service-color) 24%, #d8dcef)) 0 18px / 78% 5px no-repeat,
    linear-gradient(#e8eaf4, #e8eaf4) 0 34px / 64% 5px no-repeat;
}

/* Responsive devices */
.device {
  position: absolute;
  padding: 1.15rem 0.85rem 0.7rem;
  border: 2px solid color-mix(in srgb, var(--ink) 70%, #4a5272);
  border-radius: 0.75rem;
  background: #f8f9ff;
  box-shadow: 0 20px 36px rgba(44, 50, 91, 0.2);
}
.device::before {
  content: "";
  position: absolute;
  top: 0.48rem;
  left: 0.65rem;
  width: 0.34rem;
  height: 0.34rem;
  border-radius: 50%;
  background: var(--service-color);
  box-shadow: 0.52rem 0 0 #ff91bf, 1.04rem 0 0 #7be0cf;
}
.device__screen { height: 100%; border-radius: 0.35rem; }
.device--laptop {
  width: 65%;
  height: 54%;
  top: 19%;
  left: 13%;
  transform: rotate(-3deg);
  animation: svc-float 5.5s ease-in-out infinite;
}
.device--laptop::after {
  content: "";
  position: absolute;
  left: -8%;
  right: -8%;
  bottom: -0.65rem;
  height: 0.5rem;
  border-radius: 0 0 1rem 1rem;
  background: color-mix(in srgb, var(--ink) 72%, #68708e);
}
.device--tablet {
  width: 34%;
  height: 48%;
  right: 11%;
  top: 29%;
  transform: rotate(4deg);
  animation: svc-float 5s 0.4s ease-in-out infinite;
}
.device--phone {
  width: 20%;
  height: 37%;
  right: 31%;
  bottom: 8%;
  padding-inline: 0.45rem;
  transform: rotate(-2deg);
  animation: svc-float 4.7s 0.8s ease-in-out infinite;
}

/* Booking and payment flow */
.pay-calendar {
  width: 45%;
  height: 53%;
  left: 9%;
  top: 20%;
  padding: 3.2rem 1rem 1rem;
  border-radius: 1.1rem;
}
.pay-calendar::before {
  content: "BOOKING";
  position: absolute;
  inset: 0 0 auto;
  padding: 0.9rem 1rem;
  border-radius: 1.1rem 1.1rem 0 0;
  background: var(--service-color);
  color: white;
  font: 600 0.62rem/1 var(--font-mono);
  letter-spacing: 0.1em;
}
.pay-calendar__days {
  height: 100%;
  background:
    radial-gradient(circle, #d6d9e8 0 3px, transparent 4px) 0 0 / 25% 33%,
    radial-gradient(circle, var(--service-color-2) 0 5px, transparent 6px) 25% 33% / 100% 100%;
}
.pay-card {
  width: 48%;
  height: 34%;
  right: 7%;
  top: 38%;
  padding: 1.2rem;
  border-radius: 1.1rem;
  background:
    radial-gradient(circle at 82% 24%, rgba(255,255,255,0.45) 0 1rem, transparent 1.05rem),
    linear-gradient(135deg, var(--service-color), var(--service-color-2));
  color: white;
}
.pay-card::before,
.pay-card::after {
  content: "";
  position: absolute;
  left: 1.2rem;
  height: 0.38rem;
  border-radius: 1rem;
  background: rgba(255,255,255,0.78);
}
.pay-card::before { width: 2.2rem; top: 1.25rem; }
.pay-card::after { width: 5rem; bottom: 1.25rem; }
.pay-route {
  position: absolute;
  width: 32%;
  height: 2px;
  left: 43%;
  top: 52%;
  background: linear-gradient(90deg, var(--service-color), var(--service-color-2));
  transform: rotate(-8deg);
}
.pay-route i {
  position: absolute;
  width: 0.48rem;
  height: 0.48rem;
  top: -0.2rem;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 12px var(--service-color);
  animation: svc-route 2.4s linear infinite;
}
.pay-route i:nth-child(2) { animation-delay: -0.8s; }
.pay-route i:nth-child(3) { animation-delay: -1.6s; }

/* Email routing */
.mail-source {
  width: 38%;
  height: 30%;
  left: 8%;
  top: 34%;
  border-radius: 1rem;
}
.mail-source::before {
  content: "";
  position: absolute;
  inset: 20% 15%;
  border: 2px solid var(--service-color);
  border-radius: 0.35rem;
  background:
    linear-gradient(32deg, transparent 48%, var(--service-color) 49% 52%, transparent 53%),
    linear-gradient(-32deg, transparent 48%, var(--service-color) 49% 52%, transparent 53%);
}
.mail-branches {
  position: absolute;
  left: 43%;
  top: 31%;
  width: 25%;
  height: 38%;
  border-left: 2px solid color-mix(in srgb, var(--service-color) 70%, transparent);
}
.mail-branches::before,
.mail-branches::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, var(--service-color), var(--service-color-2));
}
.mail-branches::before { top: 2%; transform: rotate(-18deg); transform-origin: left; }
.mail-branches::after { bottom: 2%; transform: rotate(18deg); transform-origin: left; }
.inbox {
  width: 27%;
  height: 22%;
  right: 7%;
  padding: 0.9rem;
  border-radius: 0.85rem;
}
.inbox::before {
  content: "";
  display: block;
  width: 35%;
  height: 0.38rem;
  margin-bottom: 0.55rem;
  border-radius: 1rem;
  background: var(--service-color);
}
.inbox::after {
  content: "";
  display: block;
  width: 76%;
  height: 0.3rem;
  border-radius: 1rem;
  background: #d8dceb;
  box-shadow: 0 0.65rem 0 #e6e8f2;
}
.inbox--one { top: 14%; transform: rotate(3deg); }
.inbox--two { top: 40%; right: 4%; }
.inbox--three { bottom: 12%; transform: rotate(-3deg); }

/* Form automation */
.auto-form {
  width: 42%;
  height: 61%;
  left: 8%;
  top: 19%;
  padding: 1.2rem;
  border-radius: 1rem;
}
.auto-form__field {
  height: 0.7rem;
  margin-bottom: 0.85rem;
  border-radius: 0.3rem;
  background: #e0e3ef;
}
.auto-form__field:nth-child(2) { width: 78%; }
.auto-form__field:nth-child(3) { height: 2.5rem; }
.auto-form__submit {
  width: 46%;
  height: 1.45rem;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--service-color), var(--service-color-2));
}
.auto-line {
  position: absolute;
  left: 46%;
  top: 49%;
  width: 23%;
  height: 2px;
  background: var(--service-color);
}
.auto-node {
  position: absolute;
  right: 10%;
  width: 3.4rem;
  height: 3.4rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(255,255,255,0.8);
  border-radius: 1rem;
  background: color-mix(in srgb, var(--surface) 80%, var(--service-color) 20%);
  box-shadow: 0 12px 24px rgba(42, 48, 86, 0.16);
  color: var(--service-color);
  font: 700 0.68rem/1 var(--font-mono);
}
.auto-node--one { top: 16%; }
.auto-node--two { top: 42%; right: 5%; }
.auto-node--three { bottom: 14%; }

/* Editable content dashboard */
.cms-dashboard {
  width: 82%;
  height: 68%;
  left: 9%;
  top: 16%;
  display: grid;
  grid-template-columns: 25% 1fr;
  overflow: hidden;
  border-radius: 1.1rem;
}
.cms-sidebar {
  padding: 1.2rem 0.8rem;
  background: color-mix(in srgb, var(--service-color) 18%, #e9ebf8);
}
.cms-sidebar i {
  display: block;
  width: 78%;
  height: 0.45rem;
  margin-bottom: 0.85rem;
  border-radius: 1rem;
  background: color-mix(in srgb, var(--service-color) 36%, #c7cbe0);
}
.cms-main {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  padding: 1rem;
}
.cms-block {
  border: 1px solid #e0e3ef;
  border-radius: 0.65rem;
  background:
    linear-gradient(var(--service-color), var(--service-color)) 0.7rem 0.7rem / 38% 5px no-repeat,
    linear-gradient(#dfe2ed, #dfe2ed) 0.7rem 1.5rem / 70% 4px no-repeat,
    #fbfbff;
}
.cms-block--preview {
  grid-row: span 2;
  background:
    linear-gradient(145deg, color-mix(in srgb, var(--service-color) 35%, #fff), #fff);
}
.cms-toggle {
  position: absolute;
  right: 13%;
  bottom: 12%;
  width: 3.2rem;
  height: 1.55rem;
  border-radius: 999px;
  background: var(--service-color);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--service-color) 35%, transparent);
}
.cms-toggle::after {
  content: "";
  position: absolute;
  width: 1.05rem;
  height: 1.05rem;
  right: 0.25rem;
  top: 0.25rem;
  border-radius: 50%;
  background: white;
}

/* Local search */
.local-result {
  width: 69%;
  height: 43%;
  left: 8%;
  top: 18%;
  padding: 1.2rem;
  border-radius: 1rem;
}
.local-result::before {
  content: "PLAINPAGES";
  display: block;
  margin-bottom: 0.9rem;
  color: var(--service-color);
  font: 600 0.68rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.local-result::after {
  content: "";
  display: block;
  width: 88%;
  height: 0.42rem;
  border-radius: 1rem;
  background: #d9ddeb;
  box-shadow: 0 0.8rem 0 #e7e9f2, 0 1.6rem 0 #e7e9f2;
}
.map-surface {
  position: absolute;
  width: 54%;
  height: 43%;
  right: 7%;
  bottom: 10%;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,0.8);
  border-radius: 1rem;
  background:
    linear-gradient(32deg, transparent 46%, rgba(255,255,255,0.72) 47% 52%, transparent 53%),
    linear-gradient(-24deg, transparent 46%, rgba(255,255,255,0.72) 47% 52%, transparent 53%),
    color-mix(in srgb, var(--service-color-2) 28%, #dff2eb);
  box-shadow: 0 18px 34px rgba(42, 48, 86, 0.16);
}
.map-pin {
  position: absolute;
  width: 2.35rem;
  height: 2.35rem;
  left: 51%;
  top: 48%;
  border: 0.55rem solid var(--service-color);
  border-radius: 50% 50% 50% 0;
  background: white;
  transform: translate(-50%, -65%) rotate(-45deg);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--service-color) 45%, transparent);
}
.map-ring {
  position: absolute;
  width: 5rem;
  height: 2rem;
  left: 51%;
  top: 61%;
  border: 2px solid color-mix(in srgb, var(--service-color) 44%, transparent);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  animation: svc-pulse 2.8s ease-out infinite;
}

/* Analytics */
.analytics-panel {
  width: 82%;
  height: 66%;
  left: 9%;
  top: 17%;
  padding: 1.2rem;
  border-radius: 1.1rem;
}
.analytics-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
}
.analytics-stat {
  height: 3.5rem;
  padding: 0.75rem;
  border-radius: 0.7rem;
  background: color-mix(in srgb, var(--service-color) 10%, #f6f7ff);
}
.analytics-stat::before {
  content: "";
  display: block;
  width: 35%;
  height: 0.3rem;
  margin-bottom: 0.65rem;
  border-radius: 1rem;
  background: #ced2e3;
}
.analytics-stat::after {
  content: "";
  display: block;
  width: 62%;
  height: 0.55rem;
  border-radius: 1rem;
  background: var(--service-color);
}
.analytics-chart {
  position: absolute;
  left: 1.2rem;
  right: 1.2rem;
  bottom: 1.1rem;
  height: 43%;
  overflow: visible;
}
.analytics-chart path {
  fill: none;
  stroke: var(--service-color);
  stroke-width: 4;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-dasharray: 260;
  animation: svc-chart 4s ease-in-out infinite;
}
.analytics-chart circle { fill: var(--service-color-2); stroke: white; stroke-width: 3; }

/* Hosting and security */
.server-stack {
  position: absolute;
  width: 50%;
  left: 11%;
  top: 19%;
}
.server {
  position: relative;
  height: 3.3rem;
  margin-bottom: 0.7rem;
  border: 1px solid rgba(255,255,255,0.85);
  border-radius: 0.75rem;
  background: color-mix(in srgb, var(--surface) 82%, var(--service-color) 18%);
  box-shadow: 0 12px 22px rgba(42, 48, 86, 0.13);
}
.server::before {
  content: "";
  position: absolute;
  width: 0.55rem;
  height: 0.55rem;
  left: 0.9rem;
  top: 1.3rem;
  border-radius: 50%;
  background: #62d8b5;
  box-shadow: 1rem 0 0 var(--service-color);
}
.server::after {
  content: "";
  position: absolute;
  width: 42%;
  height: 0.45rem;
  right: 0.9rem;
  top: 1.32rem;
  border-radius: 1rem;
  background: #d4d8e7;
}
.security-shield {
  position: absolute;
  width: 34%;
  aspect-ratio: 0.88;
  right: 10%;
  top: 25%;
  display: grid;
  place-items: center;
  clip-path: polygon(50% 0, 92% 16%, 84% 72%, 50% 100%, 16% 72%, 8% 16%);
  background: linear-gradient(145deg, var(--service-color), var(--service-color-2));
  color: white;
  filter: drop-shadow(0 18px 18px color-mix(in srgb, var(--service-color) 30%, transparent));
}
.security-shield::before {
  content: "";
  width: 20%;
  height: 31%;
  border: solid white;
  border-width: 0 0.28rem 0.28rem 0;
  transform: translateY(-8%) rotate(45deg);
}
.speed-line {
  position: absolute;
  height: 2px;
  border-radius: 1rem;
  background: linear-gradient(90deg, transparent, var(--service-color-2));
  animation: svc-speed 2.3s ease-in-out infinite;
}
.speed-line--one { width: 30%; right: 4%; top: 18%; }
.speed-line--two { width: 22%; right: 0; top: 72%; animation-delay: -0.8s; }
.speed-line--three { width: 18%; left: 4%; bottom: 12%; animation-delay: -1.4s; }

/* Brand system */
.brand-frame {
  width: 45%;
  height: 48%;
  left: 12%;
  top: 18%;
  overflow: hidden;
  border-radius: 1rem;
  transform: rotate(-5deg);
  background:
    radial-gradient(circle at 65% 35%, var(--service-color-2) 0 15%, transparent 16%),
    linear-gradient(145deg, color-mix(in srgb, var(--service-color) 60%, #fff), #fff);
  animation: svc-float 5s ease-in-out infinite;
}
.brand-frame::before {
  content: "Aa";
  position: absolute;
  left: 1rem;
  bottom: 0.75rem;
  color: color-mix(in srgb, var(--ink) 84%, var(--service-color));
  font: 700 2.3rem/1 var(--font-display);
}
.brand-card {
  width: 43%;
  height: 31%;
  right: 8%;
  top: 39%;
  padding: 1rem;
  border-radius: 1rem;
  transform: rotate(5deg);
  background: linear-gradient(135deg, var(--service-color), var(--service-color-2));
  animation: svc-float 4.7s 0.5s ease-in-out infinite;
}
.brand-card::before {
  content: "";
  display: block;
  width: 2rem;
  height: 2rem;
  border: 0.4rem solid rgba(255,255,255,0.88);
  border-radius: 50%;
}
.brand-card::after {
  content: "";
  position: absolute;
  left: 1rem;
  right: 1rem;
  bottom: 1rem;
  height: 0.4rem;
  border-radius: 1rem;
  background: rgba(255,255,255,0.78);
}
.brand-sticker {
  position: absolute;
  display: grid;
  place-items: center;
  border: 3px solid white;
  background: #fff0a8;
  color: #5b4a19;
  box-shadow: 0 10px 20px rgba(42,48,86,0.14);
  font: 700 0.62rem/1 var(--font-mono);
}
.brand-sticker--one {
  width: 4.4rem;
  height: 4.4rem;
  right: 13%;
  top: 13%;
  border-radius: 50%;
  transform: rotate(12deg);
}
.brand-sticker--two {
  width: 4.8rem;
  height: 2.2rem;
  left: 28%;
  bottom: 12%;
  border-radius: 999px;
  background: #ffd0e6;
  transform: rotate(-8deg);
}
.brand-spark {
  position: absolute;
  width: 1.5rem;
  height: 1.5rem;
  background: white;
  clip-path: polygon(50% 0, 61% 39%, 100% 50%, 61% 61%, 50% 100%, 39% 61%, 0 50%, 39% 39%);
  filter: drop-shadow(0 0 8px var(--service-color));
}
.brand-spark--one { left: 8%; bottom: 18%; }
.brand-spark--two { right: 6%; bottom: 12%; transform: scale(0.65); }

/* Enhanced commerce, communication, automation, and brand scenes */
.pay-calendar {
  z-index: 2;
  width: 51%;
  height: 65%;
  left: 6%;
  top: 10%;
  padding: 1rem;
}
.pay-calendar::before,
.pay-card::before,
.pay-card::after { content: none; }
.pay-calendar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 0.7rem;
  border-bottom: 1px solid #e1e3ef;
}
.pay-calendar__head span,
.pay-calendar__head strong { font-family: var(--font-mono); line-height: 1; }
.pay-calendar__head span {
  color: var(--service-color);
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.12em;
}
.pay-calendar__head strong { color: #555a72; font-size: 0.5rem; }
.pay-calendar__week,
.pay-calendar__days {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0.28rem;
  text-align: center;
}
.pay-calendar__week {
  padding-block: 0.65rem 0.35rem;
  color: #9a9eb3;
  font: 600 0.5rem/1 var(--font-mono);
}
.pay-calendar__days {
  height: auto;
  color: #6c7089;
  font: 600 0.55rem/1 var(--font-mono);
  background: none;
}
.pay-calendar__days i {
  display: grid;
  place-items: center;
  aspect-ratio: 1;
  border-radius: 0.4rem;
  background: #f2f3f9;
  font-style: normal;
}
.pay-calendar__days .is-selected {
  background: linear-gradient(145deg, var(--service-color), var(--service-color-2));
  color: white;
  box-shadow: 0 6px 14px color-mix(in srgb, var(--service-color) 35%, transparent);
}
.pay-slot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.7rem;
  padding: 0.55rem 0.6rem;
  border: 1px solid color-mix(in srgb, var(--service-color) 20%, #e2e4ef);
  border-radius: 0.55rem;
  background: color-mix(in srgb, var(--service-color) 7%, #fff);
  font: 600 0.5rem/1 var(--font-mono);
}
.pay-slot b {
  color: var(--service-color);
  font-size: 0.43rem;
  text-transform: uppercase;
}
.pay-card {
  z-index: 4;
  display: flex;
  flex-direction: column;
  width: 45%;
  height: 37%;
  right: 5%;
  top: 29%;
  padding: 1rem;
  transform: rotate(4deg);
}
.pay-card__chip {
  width: 1.65rem;
  height: 1.15rem;
  border-radius: 0.3rem;
  background:
    linear-gradient(90deg, transparent 45%, rgba(90,64,132,0.25) 46% 54%, transparent 55%),
    linear-gradient(rgba(90,64,132,0.25) 45%, transparent 46% 54%, rgba(90,64,132,0.25) 55%),
    #ffe6a7;
}
.pay-card__brand {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font: 600 0.43rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.pay-card strong {
  margin-top: auto;
  font: 700 clamp(1.05rem, 2.6vw, 1.5rem)/1 var(--font-display);
}
.pay-card small {
  margin-top: 0.35rem;
  color: rgba(255,255,255,0.8);
  font: 500 0.48rem/1 var(--font-mono);
}
.pay-route {
  z-index: 3;
  width: 46%;
  height: 28%;
  left: 40%;
  top: 29%;
  overflow: visible;
  background: none;
  transform: none;
}
.pay-route path,
.mail-flow path,
.auto-flow path {
  fill: none;
  stroke: color-mix(in srgb, var(--service-color) 64%, var(--service-color-2));
  stroke-width: 2.5;
  stroke-linecap: round;
  stroke-dasharray: 6 7;
  animation: svc-dash 4s linear infinite;
}
.pay-route circle {
  fill: #fff;
  stroke: var(--service-color);
  stroke-width: 2;
  filter: drop-shadow(0 0 5px var(--service-color));
}
.pay-confirm {
  position: absolute;
  z-index: 5;
  right: 8%;
  bottom: 10%;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  width: 47%;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(255,255,255,0.88);
  border-radius: 0.85rem;
  background: rgba(255,255,255,0.82);
  box-shadow: 0 14px 28px rgba(42,48,86,0.14);
  backdrop-filter: blur(10px);
}
.pay-confirm > span {
  display: grid;
  place-items: center;
  width: 1.6rem;
  height: 1.6rem;
  flex: 0 0 auto;
  border-radius: 50%;
  background: #55d1aa;
  color: white;
  font-weight: 800;
}
.pay-confirm b,
.pay-confirm small { display: block; }
.pay-confirm b { color: #3e435f; font-size: 0.62rem; }
.pay-confirm small { margin-top: 0.15rem; color: #898da4; font: 500 0.43rem/1 var(--font-mono); }

.mail-source {
  z-index: 3;
  width: 42%;
  height: 43%;
  left: 5%;
  top: 28%;
  padding: 0.9rem;
}
.mail-source::before { content: none; }
.mail-address {
  display: block;
  overflow: hidden;
  color: var(--service-color);
  font: 600 0.49rem/1 var(--font-mono);
  text-overflow: ellipsis;
  white-space: nowrap;
}
.mail-envelope {
  position: relative;
  width: 68%;
  height: 42%;
  margin: 0.85rem auto 0.75rem;
  border: 2px solid var(--service-color);
  border-radius: 0.55rem;
  background:
    linear-gradient(32deg, transparent 48%, var(--service-color) 49% 52%, transparent 53%),
    linear-gradient(-32deg, transparent 48%, var(--service-color) 49% 52%, transparent 53%);
}
.mail-envelope i {
  position: absolute;
  width: 0.7rem;
  height: 0.7rem;
  right: -0.35rem;
  top: -0.35rem;
  border: 2px solid white;
  border-radius: 50%;
  background: #59d3ad;
  box-shadow: 0 4px 10px rgba(40,130,105,0.25);
}
.mail-auth {
  display: flex;
  justify-content: center;
  gap: 0.3rem;
}
.mail-auth span {
  padding: 0.28rem 0.34rem;
  border-radius: 999px;
  background: color-mix(in srgb, #59d3ad 12%, #f6f7fb);
  color: #24866d;
  font: 700 0.35rem/1 var(--font-mono);
}
.mail-flow {
  position: absolute;
  z-index: 1;
  width: 57%;
  height: 68%;
  left: 37%;
  top: 16%;
  overflow: visible;
}
.mail-flow path { animation-duration: 4.5s; }
.mail-router {
  position: absolute;
  z-index: 4;
  left: 43%;
  top: 39%;
  display: grid;
  place-items: center;
  width: 4rem;
  height: 4rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 1.2rem;
  background: linear-gradient(145deg, var(--service-color), var(--service-color-2));
  box-shadow: 0 14px 28px color-mix(in srgb, var(--service-color) 26%, transparent);
  color: white;
  transform: rotate(-5deg);
}
.mail-router span { font-size: 1.3rem; line-height: 1; }
.mail-router small { font: 600 0.35rem/1.15 var(--font-mono); letter-spacing: 0.06em; text-align: center; }
.inbox {
  z-index: 3;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.5rem;
  width: 32%;
  height: 19%;
  right: 4%;
  padding: 0.65rem;
}
.inbox::before,
.inbox::after { content: none; }
.inbox > i {
  width: 1.15rem;
  height: 1.15rem;
  border: 0.27rem solid color-mix(in srgb, var(--service-color) 70%, #fff);
  border-radius: 50%;
  background: color-mix(in srgb, var(--service-color) 13%, #fff);
}
.inbox b,
.inbox small { display: block; }
.inbox b { color: #464b69; font: 700 0.48rem/1 var(--font-mono); }
.inbox small { margin-top: 0.2rem; color: #969aaf; font: 500 0.38rem/1 var(--font-mono); }
.inbox > span {
  display: grid;
  place-items: center;
  width: 1.2rem;
  height: 1.2rem;
  border-radius: 50%;
  background: var(--service-color);
  color: white;
  font: 700 0.44rem/1 var(--font-mono);
}
.inbox--one { top: 8%; transform: rotate(2deg); }
.inbox--two { top: 40%; right: 2%; }
.inbox--three { bottom: 8%; transform: rotate(-2deg); }

.auto-form {
  z-index: 3;
  width: 43%;
  height: 68%;
  left: 5%;
  top: 11%;
  padding: 0.9rem;
}
.auto-form__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.65rem;
  color: var(--service-color);
  font: 700 0.45rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.auto-form__head i { color: #a4a7ba; font-style: normal; }
.auto-form label {
  display: block;
  margin-top: 0.45rem;
  color: #777b94;
  font: 600 0.39rem/1 var(--font-mono);
}
.auto-form__field {
  position: relative;
  width: 100%;
  height: 1.15rem;
  margin: 0.26rem 0 0;
  border: 1px solid #e0e3ed;
  border-radius: 0.4rem;
  background:
    linear-gradient(#d5d8e5, #d5d8e5) 0.42rem 50% / 48% 0.22rem no-repeat,
    #f8f8fc;
}
.auto-form__field--select::after {
  content: "⌄";
  position: absolute;
  right: 0.4rem;
  top: 0.1rem;
  color: #9da1b4;
}
.auto-form__field--message {
  height: 2.05rem;
  background:
    linear-gradient(#d5d8e5, #d5d8e5) 0.42rem 0.52rem / 68% 0.2rem no-repeat,
    linear-gradient(#e2e4ed, #e2e4ed) 0.42rem 1.08rem / 48% 0.2rem no-repeat,
    #f8f8fc;
}
.auto-form__submit {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  height: auto;
  margin-top: 0.6rem;
  padding: 0.5rem 0.6rem;
  color: white;
  font: 700 0.4rem/1 var(--font-mono);
  letter-spacing: 0.05em;
}
.auto-flow {
  position: absolute;
  z-index: 1;
  width: 55%;
  height: 72%;
  left: 39%;
  top: 13%;
  overflow: visible;
}
.auto-flow path { animation-direction: reverse; }
.auto-trigger {
  position: absolute;
  z-index: 4;
  left: 43%;
  top: 40%;
  display: grid;
  place-items: center;
  width: 3.75rem;
  height: 3.75rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 50%;
  background: linear-gradient(145deg, var(--service-color), var(--service-color-2));
  box-shadow: 0 13px 28px color-mix(in srgb, var(--service-color) 28%, transparent);
  color: white;
}
.auto-trigger span { font-size: 1.1rem; line-height: 1; }
.auto-trigger small { font: 700 0.34rem/1 var(--font-mono); letter-spacing: 0.06em; }
.auto-node {
  z-index: 3;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.42rem;
  width: 34%;
  height: 18%;
  right: 4%;
  padding: 0.62rem;
  border-radius: 0.85rem;
}
.auto-node > span {
  padding: 0.34rem;
  border-radius: 0.4rem;
  background: color-mix(in srgb, var(--service-color) 13%, #fff);
  color: var(--service-color);
  font: 700 0.39rem/1 var(--font-mono);
}
.auto-node b { color: #545971; font: 600 0.43rem/1.15 var(--font-mono); }
.auto-node > i {
  display: grid;
  place-items: center;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  background: #57d2a9;
  color: white;
  font: 700 0.42rem/1 var(--font-mono);
  font-style: normal;
}
.auto-node--one { top: 8%; transform: rotate(1.5deg); }
.auto-node--two { top: 39%; right: 2%; }
.auto-node--three { bottom: 10%; transform: rotate(-1.5deg); }
.auto-success {
  position: absolute;
  z-index: 5;
  left: 21%;
  bottom: 6%;
  display: flex;
  align-items: center;
  gap: 0.42rem;
  padding: 0.52rem 0.68rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 999px;
  background: rgba(255,255,255,0.86);
  box-shadow: 0 10px 24px rgba(42,48,86,0.15);
  color: #555a72;
  font: 600 0.4rem/1 var(--font-mono);
  backdrop-filter: blur(10px);
}
.auto-success i {
  display: grid;
  place-items: center;
  width: 1.05rem;
  height: 1.05rem;
  border-radius: 50%;
  background: #57d2a9;
  color: white;
  font-style: normal;
}

.brand-frame {
  z-index: 3;
  width: 55%;
  height: 67%;
  left: 7%;
  top: 12%;
  padding: 0.85rem;
  transform: rotate(-4deg);
  background:
    radial-gradient(circle at 76% 37%, var(--service-color-2) 0 13%, transparent 13.5%),
    linear-gradient(145deg, color-mix(in srgb, var(--service-color) 52%, #fff), #fff);
}
.brand-frame::before { content: none; }
.brand-frame__top {
  display: flex;
  align-items: center;
  color: #62677f;
  font: 700 0.37rem/1 var(--font-mono);
  letter-spacing: 0.06em;
}
.brand-frame__top span { margin-right: auto; }
.brand-frame__top i {
  width: 0.35rem;
  height: 0.35rem;
  margin-left: 0.25rem;
  border-radius: 50%;
  background: var(--service-color);
}
.brand-frame__top i:last-child { background: var(--service-color-2); }
.brand-frame > strong {
  position: absolute;
  left: 0.9rem;
  bottom: 2.8rem;
  color: color-mix(in srgb, var(--ink) 83%, var(--service-color));
  font: 700 clamp(2rem, 6vw, 3.2rem)/1 var(--font-display);
}
.brand-frame > b {
  position: absolute;
  right: 0.9rem;
  bottom: 2.95rem;
  color: #383d59;
  font: 800 clamp(0.65rem, 1.8vw, 0.95rem)/0.95 var(--font-display);
  text-align: right;
}
.brand-shape { position: absolute; }
.brand-shape--disc {
  width: 4.3rem;
  height: 4.3rem;
  left: 15%;
  top: 25%;
  border-radius: 50%;
  background: linear-gradient(145deg, #ff92bf, var(--service-color));
  box-shadow: 0 12px 24px color-mix(in srgb, var(--service-color) 25%, transparent);
}
.brand-shape--pill {
  width: 5rem;
  height: 1.7rem;
  right: 10%;
  top: 52%;
  border-radius: 999px;
  background: #fff3a6;
  transform: rotate(-13deg);
}
.brand-palette {
  position: absolute;
  left: 0.9rem;
  right: 0.9rem;
  bottom: 0.85rem;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.32rem;
}
.brand-palette i { height: 0.6rem; border-radius: 999px; background: var(--service-color); }
.brand-palette i:nth-child(2) { background: var(--service-color-2); }
.brand-palette i:nth-child(3) { background: #ffdc75; }
.brand-palette i:nth-child(4) { background: #333850; }
.motion-card {
  z-index: 4;
  width: 40%;
  height: 43%;
  right: 5%;
  top: 37%;
  padding: 0.75rem;
  border-radius: 1rem;
  transform: rotate(4deg);
}
.motion-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--service-color);
  font: 700 0.43rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.motion-card__head b {
  display: grid;
  place-items: center;
  width: 1.3rem;
  height: 1.3rem;
  border-radius: 50%;
  background: var(--service-color);
  color: white;
  font-size: 0.42rem;
}
.motion-stage {
  position: relative;
  height: 48%;
  margin-top: 0.55rem;
  overflow: hidden;
  border-radius: 0.6rem;
  background:
    radial-gradient(circle at 28% 35%, #ff92bf 0 0.75rem, transparent 0.8rem),
    linear-gradient(145deg, color-mix(in srgb, var(--service-color-2) 24%, #f8f7ff), #fff);
}
.motion-stage i {
  position: absolute;
  width: 2.6rem;
  height: 0.85rem;
  right: 13%;
  bottom: 18%;
  border-radius: 999px;
  background: var(--service-color-2);
  transform: rotate(-16deg);
  animation: svc-motion-shape 3.4s ease-in-out infinite;
}
.motion-stage span {
  position: absolute;
  right: 12%;
  top: 11%;
  color: var(--service-color);
  font: 500 1.2rem/1 var(--font-body);
}
.motion-timeline {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.25rem;
  margin-top: 0.65rem;
}
.motion-timeline i {
  height: 0.48rem;
  border-radius: 999px;
  background: #e1e3ed;
}
.motion-timeline i:nth-child(1),
.motion-timeline i:nth-child(2) { background: var(--service-color); }
.brand-cursor {
  position: absolute;
  z-index: 6;
  left: 54%;
  top: 23%;
  color: var(--service-color);
  transform: rotate(-8deg);
  filter: drop-shadow(0 5px 8px rgba(42,48,86,0.18));
}
.brand-cursor span { display: block; font-size: 1.8rem; line-height: 1; }
.brand-cursor b {
  display: block;
  margin-left: 1.1rem;
  padding: 0.25rem 0.4rem;
  border-radius: 999px;
  background: var(--service-color);
  color: white;
  font: 700 0.36rem/1 var(--font-mono);
}
.brand-orbit {
  position: absolute;
  border: 1px dashed color-mix(in srgb, var(--service-color) 42%, transparent);
  border-radius: 50%;
  animation: svc-orbit 12s linear infinite;
}
.brand-orbit--one { width: 9rem; height: 9rem; right: -2rem; top: -2rem; }
.brand-orbit--two { width: 5rem; height: 5rem; left: -1rem; bottom: -1rem; animation-direction: reverse; }
.brand-card { display: none; }
.brand-sticker { z-index: 5; }
.brand-sticker--one {
  width: 4.2rem;
  height: 2.1rem;
  right: 7%;
  top: 12%;
  border-radius: 999px;
  transform: rotate(9deg);
}
.brand-sticker--two {
  width: 4.4rem;
  height: 2rem;
  left: 29%;
  bottom: 7%;
  transform: rotate(-7deg);
}

/* Enhanced responsive, CMS, local, analytics, and security scenes */
.responsive-ruler {
  position: absolute;
  left: 8%;
  right: 8%;
  bottom: 6%;
  display: flex;
  justify-content: space-between;
  padding-top: 0.55rem;
  border-top: 1px solid color-mix(in srgb, var(--service-color) 48%, transparent);
  color: color-mix(in srgb, var(--ink) 68%, var(--service-color));
  font: 600 0.45rem/1 var(--font-mono);
}
.responsive-ruler::before,
.responsive-ruler::after {
  content: "";
  position: absolute;
  top: -0.28rem;
  width: 1px;
  height: 0.55rem;
  background: var(--service-color);
}
.responsive-ruler::before { left: 0; }
.responsive-ruler::after { right: 0; }
.responsive-component {
  position: absolute;
  z-index: 6;
  left: 5%;
  top: 8%;
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(255,255,255,0.88);
  border-radius: 0.75rem;
  background: rgba(255,255,255,0.84);
  box-shadow: 0 10px 22px rgba(42,48,86,0.14);
  backdrop-filter: blur(10px);
}
.responsive-component > i {
  width: 1.35rem;
  height: 1.35rem;
  border-radius: 0.38rem;
  background:
    linear-gradient(var(--service-color), var(--service-color)) 50% 30% / 58% 0.18rem no-repeat,
    linear-gradient(var(--service-color-2), var(--service-color-2)) 50% 65% / 40% 0.18rem no-repeat,
    color-mix(in srgb, var(--service-color) 12%, #fff);
}
.responsive-component b,
.responsive-component small { display: block; }
.responsive-component b { color: #464b66; font: 700 0.42rem/1 var(--font-mono); }
.responsive-component small { margin-top: 0.2rem; color: #969aaf; font: 500 0.36rem/1 var(--font-mono); }
.responsive-sync {
  position: absolute;
  z-index: 5;
  right: 6%;
  top: 9%;
  display: flex;
  gap: 0.3rem;
}
.responsive-sync i {
  width: 0.48rem;
  height: 0.48rem;
  border: 2px solid white;
  border-radius: 50%;
  background: var(--service-color);
  box-shadow: 0 3px 9px color-mix(in srgb, var(--service-color) 38%, transparent);
}
.responsive-sync i:nth-child(2) { background: var(--service-color-2); }
.responsive-sync i:nth-child(3) { background: #58d3ac; }

.cms-dashboard {
  width: 86%;
  height: 72%;
  left: 7%;
  top: 12%;
  grid-template-columns: 23% 1fr;
  grid-template-rows: 2.2rem 1fr;
}
.cms-topbar {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  padding: 0 0.75rem;
  border-bottom: 1px solid #e2e4ee;
  color: var(--service-color);
  font: 700 0.43rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.cms-topbar > div { display: flex; gap: 0.25rem; margin-left: auto; }
.cms-topbar i { width: 0.38rem; height: 0.38rem; border-radius: 50%; background: #d7d9e5; }
.cms-topbar i:first-child { background: var(--service-color); }
.cms-sidebar {
  padding: 0.75rem 0.6rem;
  background: color-mix(in srgb, var(--service-color) 10%, #f1f2f8);
}
.cms-sidebar b {
  display: block;
  margin: 0.35rem 0 0.55rem;
  color: #777b91;
  font: 700 0.36rem/1 var(--font-mono);
  text-transform: uppercase;
}
.cms-sidebar i {
  width: 82%;
  height: 0.34rem;
  margin-bottom: 0.58rem;
}
.cms-main {
  grid-template-columns: 1.05fr 0.95fr;
  gap: 0.55rem;
  padding: 0.65rem;
  background: #f5f6fa;
}
.cms-editor,
.cms-preview {
  position: relative;
  min-width: 0;
  padding: 0.7rem;
  border: 1px solid #e1e3ec;
  border-radius: 0.65rem;
  background: #fff;
}
.cms-editor > span,
.cms-preview > span {
  display: block;
  color: var(--service-color);
  font: 700 0.34rem/1 var(--font-mono);
  letter-spacing: 0.06em;
}
.cms-editor > strong,
.cms-preview > strong {
  display: block;
  margin-top: 0.55rem;
  color: #484d68;
  font: 700 0.58rem/1.05 var(--font-display);
}
.cms-field {
  height: 2.6rem;
  margin-top: 0.6rem;
  padding: 0.55rem;
  border: 1px solid color-mix(in srgb, var(--service-color) 35%, #e0e2eb);
  border-radius: 0.45rem;
}
.cms-field i {
  display: block;
  width: 86%;
  height: 0.24rem;
  border-radius: 1rem;
  background: #d9dce8;
}
.cms-field i + i { width: 62%; margin-top: 0.5rem; }
.cms-price {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.55rem;
  color: #777b91;
  font: 600 0.4rem/1 var(--font-mono);
}
.cms-price span {
  padding: 0.35rem 0.45rem;
  border-radius: 0.35rem;
  background: color-mix(in srgb, var(--service-color) 10%, #f5f6fa);
  color: var(--service-color);
}
.cms-controls { display: flex; gap: 0.3rem; margin-top: 0.65rem; }
.cms-controls i { width: 1.1rem; height: 1.1rem; border-radius: 0.35rem; background: #eceef4; }
.cms-controls i:first-child { background: var(--service-color); }
.cms-preview__image {
  height: 42%;
  margin-top: 0.55rem;
  border-radius: 0.5rem;
  background:
    radial-gradient(circle at 70% 35%, var(--service-color-2) 0 0.75rem, transparent 0.8rem),
    linear-gradient(145deg, color-mix(in srgb, var(--service-color) 30%, #fff), #fff3df);
}
.cms-preview > i {
  display: block;
  width: 82%;
  height: 0.22rem;
  margin-top: 0.45rem;
  border-radius: 1rem;
  background: #dfe1ea;
}
.cms-preview > i:last-child { width: 54%; }
.cms-toggle { display: none; }
.cms-cursor {
  position: absolute;
  z-index: 5;
  left: 45%;
  top: 51%;
  color: var(--service-color);
  filter: drop-shadow(0 4px 7px rgba(42,48,86,0.18));
}
.cms-cursor span { font-size: 1.4rem; }
.cms-cursor b {
  display: block;
  margin: -0.25rem 0 0 0.9rem;
  padding: 0.25rem 0.4rem;
  border-radius: 999px;
  background: var(--service-color);
  color: white;
  font: 700 0.33rem/1 var(--font-mono);
  white-space: nowrap;
}
.cms-publish {
  position: absolute;
  z-index: 5;
  right: 7%;
  bottom: 7%;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.7rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 10px 24px rgba(42,48,86,0.14);
}
.cms-publish > i {
  display: grid;
  place-items: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: #58d2aa;
  color: white;
  font-style: normal;
  font-size: 0.55rem;
}
.cms-publish b,
.cms-publish small { display: block; }
.cms-publish b { color: #4b506b; font-size: 0.5rem; }
.cms-publish small { margin-top: 0.15rem; color: #969aaf; font: 500 0.36rem/1 var(--font-mono); }

.local-query {
  position: absolute;
  z-index: 5;
  left: 7%;
  top: 8%;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.5rem;
  width: 68%;
  padding: 0.65rem 0.75rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 12px 24px rgba(42,48,86,0.13);
  color: #666b84;
  font: 500 0.48rem/1 var(--font-mono);
}
.local-query > i { width: 0.65rem; height: 0.65rem; border: 2px solid var(--service-color); border-radius: 50%; }
.local-query > b { color: var(--service-color); font-size: 0.8rem; }
.local-result {
  z-index: 3;
  width: 68%;
  height: 51%;
  left: 6%;
  top: 24%;
  padding: 0.9rem;
}
.local-result::before,
.local-result::after { content: none; }
.local-result__url {
  color: #42966f;
  font: 600 0.38rem/1 var(--font-mono);
}
.local-result > strong {
  display: block;
  margin-top: 0.45rem;
  color: var(--service-color);
  font: 700 0.76rem/1.05 var(--font-display);
}
.local-rating {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  margin-top: 0.5rem;
  font-size: 0.45rem;
}
.local-rating b { color: #5a5f77; }
.local-rating span { color: #f4ac3c; letter-spacing: 0.05em; }
.local-rating small { color: #9296aa; font-family: var(--font-mono); }
.local-result > p {
  margin-top: 0.45rem;
  color: #767b92;
  font-size: 0.48rem;
  line-height: 1.4;
}
.local-links { display: flex; gap: 0.35rem; margin-top: 0.55rem; }
.local-links i {
  padding: 0.32rem 0.4rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--service-color) 9%, #f3f4f8);
  color: var(--service-color);
  font: 600 0.35rem/1 var(--font-mono);
  font-style: normal;
}
.map-surface {
  z-index: 4;
  width: 49%;
  height: 47%;
  right: 5%;
  bottom: 9%;
}
.map-road {
  position: absolute;
  width: 130%;
  height: 0.65rem;
  left: -15%;
  background: rgba(255,255,255,0.72);
  box-shadow: inset 0 0.16rem 0 rgba(106,128,148,0.12), inset 0 -0.16rem 0 rgba(106,128,148,0.12);
}
.map-road--one { top: 38%; transform: rotate(25deg); }
.map-road--two { top: 58%; transform: rotate(-18deg); }
.map-label {
  position: absolute;
  left: 51%;
  top: 71%;
  transform: translateX(-50%);
  padding: 0.25rem 0.35rem;
  border-radius: 999px;
  background: white;
  color: var(--service-color);
  font: 700 0.3rem/1 var(--font-mono);
  white-space: nowrap;
}
.local-rank {
  position: absolute;
  z-index: 6;
  right: 7%;
  top: 10%;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 0.75rem;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 10px 22px rgba(42,48,86,0.14);
}
.local-rank > span { color: var(--service-color); font: 800 1.05rem/1 var(--font-display); }
.local-rank b,
.local-rank small { display: block; }
.local-rank b { color: #51566e; font: 700 0.38rem/1 var(--font-mono); }
.local-rank small { margin-top: 0.18rem; color: #969aaf; font: 500 0.34rem/1 var(--font-mono); }
.local-schema {
  position: absolute;
  z-index: 6;
  left: 8%;
  bottom: 7%;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.65rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 999px;
  background: rgba(255,255,255,0.9);
  box-shadow: 0 10px 22px rgba(42,48,86,0.13);
  color: #5f647c;
  font: 600 0.36rem/1 var(--font-mono);
}
.local-schema > i { color: var(--service-color); font-style: normal; font-weight: 800; }
.local-schema > b { color: #42ae87; }

.analytics-panel {
  width: 80%;
  height: 67%;
  left: 6%;
  top: 11%;
  padding: 0.85rem;
}
.analytics-stats { gap: 0.45rem; }
.analytics-stat {
  height: 3.25rem;
  padding: 0.6rem;
}
.analytics-stat::before,
.analytics-stat::after { content: none; }
.analytics-stat > span {
  display: block;
  color: #85899e;
  font: 600 0.32rem/1 var(--font-mono);
}
.analytics-stat > b {
  display: inline-block;
  margin-top: 0.45rem;
  color: #444963;
  font: 700 0.85rem/1 var(--font-display);
}
.analytics-stat > i {
  float: right;
  margin-top: 0.48rem;
  color: #39a982;
  font: 700 0.32rem/1 var(--font-mono);
  font-style: normal;
}
.analytics-legend {
  display: flex;
  gap: 0.75rem;
  margin-top: 0.7rem;
  color: #7e8298;
  font: 500 0.34rem/1 var(--font-mono);
}
.analytics-legend span { display: flex; align-items: center; gap: 0.25rem; }
.analytics-legend i { width: 0.4rem; height: 0.4rem; border-radius: 50%; background: var(--service-color); }
.analytics-legend span:last-child i { background: var(--service-color-2); }
.analytics-chart { bottom: 0.75rem; height: 40%; }
.analytics-chart .analytics-gridline {
  stroke: #e3e5ed;
  stroke-width: 1;
  stroke-dasharray: none;
  animation: none;
}
.analytics-events {
  position: absolute;
  z-index: 5;
  right: 5%;
  bottom: 8%;
  width: 39%;
  padding: 0.7rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 0.85rem;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 12px 25px rgba(42,48,86,0.15);
  backdrop-filter: blur(10px);
}
.analytics-events > span {
  color: var(--service-color);
  font: 700 0.34rem/1 var(--font-mono);
  letter-spacing: 0.08em;
}
.analytics-events > div {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.55rem;
}
.analytics-events i { width: 0.48rem; height: 0.48rem; border-radius: 50%; background: #50d1a6; box-shadow: 0 0 0 0.25rem rgba(80,209,166,0.13); }
.analytics-events b { color: #555a72; font: 600 0.4rem/1 var(--font-mono); }
.analytics-events small { color: #9da1b3; font: 500 0.34rem/1 var(--font-mono); }
.analytics-goal {
  position: absolute;
  z-index: 6;
  right: 7%;
  top: 8%;
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.55rem 0.65rem;
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 0.75rem;
  background: rgba(255,255,255,0.9);
  box-shadow: 0 10px 22px rgba(42,48,86,0.13);
}
.analytics-goal > i {
  display: grid;
  place-items: center;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 50%;
  background: var(--service-color);
  color: white;
  font-style: normal;
}
.analytics-goal b,
.analytics-goal small { display: block; }
.analytics-goal b { color: #4c516b; font-size: 0.48rem; }
.analytics-goal small { margin-top: 0.15rem; color: #969aaf; font: 500 0.34rem/1 var(--font-mono); }

.server-stack {
  z-index: 2;
  width: 48%;
  left: 6%;
  top: 14%;
}
.server {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 3rem;
  padding: 0 0.8rem 0 3rem;
}
.server::before { left: 0.8rem; top: 1.2rem; }
.server::after { content: none; }
.server span { color: #62677f; font: 600 0.4rem/1 var(--font-mono); }
.server b { color: #42aa83; font: 700 0.38rem/1 var(--font-mono); }
.security-shield {
  z-index: 4;
  width: 30%;
  right: 8%;
  top: 18%;
  color: white;
}
.security-shield::before { content: none; }
.security-shield span { font-size: 2rem; line-height: 1; }
.security-shield small {
  position: absolute;
  bottom: 20%;
  font: 700 0.4rem/1 var(--font-mono);
  letter-spacing: 0.09em;
}
.turnstile-card,
.bot-blocked,
.security-meter {
  position: absolute;
  z-index: 5;
  border: 1px solid rgba(255,255,255,0.9);
  background: rgba(255,255,255,0.9);
  box-shadow: 0 11px 24px rgba(42,48,86,0.14);
  backdrop-filter: blur(10px);
}
.turnstile-card {
  left: 8%;
  bottom: 8%;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.5rem;
  width: 57%;
  padding: 0.65rem;
  border-radius: 0.75rem;
}
.turnstile-box {
  display: grid;
  place-items: center;
  width: 1.35rem;
  height: 1.35rem;
  border: 2px solid #53cda5;
  border-radius: 0.28rem;
  color: #39a982;
}
.turnstile-box i { font-style: normal; font-size: 0.65rem; }
.turnstile-card b,
.turnstile-card small { display: block; }
.turnstile-card b { color: #50556d; font-size: 0.48rem; }
.turnstile-card small { margin-top: 0.18rem; color: #969aaf; font: 500 0.33rem/1 var(--font-mono); }
.turnstile-card > span { color: #f48120; font: 700 0.3rem/1 var(--font-mono); }
.bot-blocked {
  right: 5%;
  bottom: 9%;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.45rem;
  width: 39%;
  padding: 0.62rem;
  border-radius: 0.75rem;
}
.bot-blocked > span {
  display: grid;
  place-items: center;
  width: 1.45rem;
  height: 1.45rem;
  border-radius: 0.4rem;
  background: #ffe8ed;
  color: #d95670;
  font: 800 0.38rem/1 var(--font-mono);
}
.bot-blocked b,
.bot-blocked small { display: block; }
.bot-blocked b { color: #555a72; font-size: 0.42rem; }
.bot-blocked small { margin-top: 0.15rem; color: #969aaf; font: 500 0.31rem/1 var(--font-mono); }
.bot-blocked > i { color: #d95670; font-style: normal; font-weight: 800; }
.security-meter {
  right: 6%;
  top: 8%;
  width: 43%;
  padding: 0.55rem 0.65rem;
  border-radius: 0.7rem;
}
.security-meter span { color: #777b91; font: 600 0.32rem/1 var(--font-mono); }
.security-meter > div { height: 0.3rem; margin-top: 0.42rem; overflow: hidden; border-radius: 999px; background: #e5e7ee; }
.security-meter > div i { display: block; width: 98.7%; height: 100%; background: linear-gradient(90deg, var(--service-color), #54d1a8); }
.security-meter b { position: absolute; top: 0.55rem; right: 0.65rem; color: var(--service-color); font: 700 0.44rem/1 var(--font-mono); }

/* Service showcase follows the selected design mode */
[data-theme] .service-feature,
[data-theme] .service-option {
  --service-color: var(--accent) !important;
  --service-color-2: var(--accent-2) !important;
  color: var(--ink);
}
[data-theme] .service-feature {
  border-color: var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
  backdrop-filter: none;
}
[data-theme] .service-option {
  border-color: var(--line);
  background: var(--surface);
  box-shadow: var(--shadow);
  backdrop-filter: none;
}
[data-theme] .svc-visual {
  --service-color: var(--accent) !important;
  --service-color-2: var(--accent-2) !important;
  border-color: var(--line);
  background:
    linear-gradient(color-mix(in srgb, var(--line) 42%, transparent) 1px, transparent 1px),
    linear-gradient(90deg, color-mix(in srgb, var(--line) 42%, transparent) 1px, transparent 1px),
    var(--bg-soft);
  background-size: 24px 24px;
  box-shadow: none;
}
[data-theme] .service-tags li {
  border-color: var(--line);
  background: var(--bg-soft);
  color: var(--ink);
}

[data-theme="mono"] .service-feature,
[data-theme="mono"] .service-option {
  border: 1px solid var(--line);
  border-top: 2px solid var(--ink);
  border-radius: 0;
  box-shadow: none;
}
[data-theme="mono"] .svc-visual { border-radius: 0; }

[data-theme="swiss"] .service-feature,
[data-theme="swiss"] .service-option {
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: none;
}
[data-theme="swiss"] .service-feature { border-top: 5px solid var(--accent); }
[data-theme="swiss"] .svc-visual { border-radius: 0; background-size: 32px 32px; }

[data-theme="kinetic"] .service-feature,
[data-theme="kinetic"] .service-option {
  border: 3px solid var(--ink);
  border-radius: 0;
  box-shadow: 7px 7px 0 var(--ink);
}
[data-theme="kinetic"] .service-option:hover,
[data-theme="kinetic"] .service-option:focus-visible { transform: translate(-3px, -3px); box-shadow: 10px 10px 0 var(--ink); }
[data-theme="kinetic"] .svc-visual { border: 3px solid var(--ink); border-radius: 0; }

[data-theme="brutal"] .service-feature,
[data-theme="brutal"] .service-option {
  border: 3px solid #000;
  border-radius: 8px;
  box-shadow: 8px 8px 0 #000;
}
[data-theme="brutal"] .service-option:nth-child(odd) { transform: rotate(-0.35deg); }
[data-theme="brutal"] .service-option:nth-child(even) { transform: rotate(0.35deg); }
[data-theme="brutal"] .svc-visual { border: 3px solid #000; border-radius: 8px; }

[data-theme="constructivist"] .service-feature,
[data-theme="constructivist"] .service-option {
  border: 2px solid var(--ink);
  border-top: 6px solid var(--accent);
  border-radius: 0;
  box-shadow: -6px 6px 0 var(--ink);
}
[data-theme="constructivist"] .svc-visual { border: 2px solid var(--ink); border-radius: 0; }

[data-theme="poster"] .service-feature,
[data-theme="poster"] .service-option {
  border: 3px solid var(--ink);
  border-radius: 0;
  box-shadow: 7px 7px 0 var(--ink);
}
[data-theme="poster"] .service-feature__kicker span { border-radius: 0; background: var(--accent); color: var(--ink); }
[data-theme="poster"] .svc-visual { border: 3px solid var(--ink); border-radius: 0; }

[data-theme="bauhaus"] .service-feature,
[data-theme="bauhaus"] .service-option {
  border: 2px solid var(--ink);
  border-radius: 0;
  box-shadow: 6px 6px 0 var(--accent-2);
}
[data-theme="bauhaus"] .service-option::before { width: 4rem; height: 4rem; right: -1rem; bottom: -1rem; filter: none; background: #f0b41c; }
[data-theme="bauhaus"] .svc-visual { border: 2px solid var(--ink); border-radius: 0; }

[data-theme="pixel"] .service-feature,
[data-theme="pixel"] .service-option {
  border: 2px solid var(--ink);
  border-radius: 0;
  box-shadow: 6px 6px 0 #080612;
}
[data-theme="pixel"] .service-option:hover,
[data-theme="pixel"] .service-option:focus-visible { transform: translate(2px, 2px); box-shadow: 2px 2px 0 #080612; }
[data-theme="pixel"] .svc-visual { border: 2px solid var(--line); border-radius: 0; image-rendering: pixelated; }

[data-theme="bento"] .service-feature,
[data-theme="bento"] .service-option {
  border-color: transparent;
  border-radius: 22px;
  box-shadow: var(--shadow);
}
[data-theme="bento"] .svc-visual { border: 0; border-radius: 18px; }

[data-theme="clay"] .service-feature,
[data-theme="clay"] .service-option {
  border: 0;
  border-radius: 30px;
  box-shadow: var(--shadow);
}
[data-theme="clay"] .service-option:active { transform: translateY(3px); box-shadow: inset 3px 3px 8px rgba(83,92,135,0.18); }
[data-theme="clay"] .svc-visual { border: 0; border-radius: 26px; box-shadow: inset 4px 4px 10px rgba(83,92,135,0.12); }

[data-theme="wellness"] .service-feature,
[data-theme="wellness"] .service-option {
  border: 1px solid rgba(255,255,255,0.9);
  border-radius: 30px 30px 70px 30px;
  background: rgba(255,255,255,0.76);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
}
[data-theme="wellness"] .svc-visual { border: 0; border-radius: 22px 22px 70px 22px; }

[data-theme="organic"] .service-feature { border-radius: 30px 45px 34px 52px; }
[data-theme="organic"] .service-option:nth-child(odd) { border-radius: 22px 28px 20px 30px; }
[data-theme="organic"] .service-option:nth-child(even) { border-radius: 30px 20px 28px 22px; }
[data-theme="organic"] .svc-visual { border-radius: 35% 28% 32% 25% / 25% 35% 28% 32%; }

[data-theme="saas"] .service-feature,
[data-theme="saas"] .service-option {
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: var(--shadow);
}
[data-theme="saas"] .service-feature { border-top: 4px solid var(--accent); }
[data-theme="saas"] .svc-visual { border: 1px solid #dfe5f2; border-radius: 12px; }

[data-theme="editorial"] .service-feature,
[data-theme="editorial"] .service-option {
  border: 1px solid var(--line);
  border-radius: 0;
  box-shadow: none;
}
[data-theme="editorial"] .service-feature { outline: 1px solid var(--line); outline-offset: 5px; }
[data-theme="editorial"] .service-feature h3 { font-weight: 400; }
[data-theme="editorial"] .svc-visual { border-radius: 0; }

[data-theme="luxe"] .service-feature,
[data-theme="luxe"] .service-option {
  border: 1px solid var(--line);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}
[data-theme="luxe"] .service-feature { border-block-color: var(--accent-2); }
[data-theme="luxe"] .svc-visual { border-radius: 0; background-color: var(--bg-soft); }
[data-theme="luxe"] .service-tags li { border-radius: 0; letter-spacing: 0.12em; text-transform: uppercase; }

[data-theme="sketch"] .service-feature,
[data-theme="sketch"] .service-option {
  border: 2px solid var(--ink);
  border-radius: 15px 225px 15px 255px / 255px 15px 225px 15px;
  box-shadow: 3px 4px 0 color-mix(in srgb, var(--ink) 18%, transparent);
}
[data-theme="sketch"] .service-option:nth-child(even) { transform: rotate(0.3deg); }
[data-theme="sketch"] .svc-visual { border: 2px solid var(--ink); border-radius: 18px 225px 20px 255px / 255px 20px 225px 18px; }

[data-theme="retro"] .service-feature,
[data-theme="retro"] .service-option {
  border: 2px solid;
  border-color: #fbf9f1 #777166 #777166 #fbf9f1;
  border-radius: 0;
  background: var(--surface);
  box-shadow: none;
}
[data-theme="retro"] .service-feature__kicker span,
[data-theme="retro"] .service-tags li { border-radius: 0; }
[data-theme="retro"] .svc-visual { border: 2px solid; border-color: #777166 #fbf9f1 #fbf9f1 #777166; border-radius: 0; }

[data-theme="y2k"] .service-feature,
[data-theme="y2k"] .service-option {
  border: 1.5px solid #fff;
  border-radius: 18px;
  background: linear-gradient(145deg, rgba(255,255,255,0.88), rgba(250,222,255,0.68));
  box-shadow: var(--shadow);
  backdrop-filter: blur(12px);
}
[data-theme="y2k"] .service-feature { border-radius: 30px; }
[data-theme="y2k"] .svc-visual { border: 1.5px solid #fff; border-radius: 20px; box-shadow: 0 0 28px rgba(230,46,174,0.16); }

[data-theme="glass"] .service-feature,
[data-theme="glass"] .service-option {
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 18px;
  background: rgba(18,28,52,0.58);
  box-shadow: var(--shadow), inset 0 1px 0 rgba(255,255,255,0.1);
  backdrop-filter: blur(18px);
}
[data-theme="glass"] .service-feature { border-radius: 28px; }
[data-theme="glass"] .svc-visual { border-color: rgba(110,168,255,0.34); border-radius: 20px; box-shadow: 0 0 30px rgba(110,168,255,0.16); }

[data-theme="cyber"] .service-feature,
[data-theme="cyber"] .service-option {
  border: 1px solid var(--line);
  border-radius: 0;
  background: var(--surface);
  box-shadow: 0 0 20px color-mix(in srgb, var(--accent) 14%, transparent);
}
[data-theme="cyber"] .service-feature { border-left: 4px solid var(--accent); }
[data-theme="cyber"] .service-option:focus-visible { box-shadow: 0 0 26px color-mix(in srgb, var(--accent) 28%, transparent); }
[data-theme="cyber"] .svc-visual { border-radius: 0; box-shadow: inset 0 0 24px color-mix(in srgb, var(--accent) 10%, transparent); }

[data-theme="collage"] .service-feature,
[data-theme="collage"] .service-option {
  overflow: visible;
  border: 1.5px solid var(--ink);
  border-radius: 0;
  background: color-mix(in srgb, var(--surface) 88%, #efdfbe);
  box-shadow: var(--shadow);
}
[data-theme="collage"] .service-option:nth-child(odd) { transform: rotate(-0.45deg); }
[data-theme="collage"] .service-option:nth-child(even) { transform: rotate(0.4deg); }
[data-theme="collage"] .service-option::before {
  inset: -0.55rem auto auto 50%;
  width: 3.6rem;
  height: 1rem;
  border-radius: 0;
  background: rgba(232,213,160,0.82);
  filter: none;
  transform: translateX(-50%) rotate(-2deg);
}
[data-theme="collage"] .svc-visual { border: 1.5px solid var(--ink); border-radius: 0; background-color: #efdfbe; }

@keyframes svc-float {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -6px; }
}
@keyframes svc-route {
  from { left: 0; opacity: 0; }
  15%, 85% { opacity: 1; }
  to { left: 100%; opacity: 0; }
}
@keyframes svc-pulse {
  0% { opacity: 0.7; transform: translate(-50%, -50%) scale(0.72); }
  80%, 100% { opacity: 0; transform: translate(-50%, -50%) scale(1.35); }
}
@keyframes svc-chart {
  0%, 18% { stroke-dashoffset: 260; }
  48%, 100% { stroke-dashoffset: 0; }
}
@keyframes svc-speed {
  0%, 100% { opacity: 0.25; transform: translateX(-8px); }
  50% { opacity: 1; transform: translateX(8px); }
}
@keyframes svc-dash { to { stroke-dashoffset: -26; } }
@keyframes svc-motion-shape {
  0%, 100% { transform: translateX(0) rotate(-16deg); }
  50% { transform: translateX(-0.8rem) rotate(6deg); }
}
@keyframes svc-orbit { to { transform: rotate(360deg); } }

/* ---------- Why ---------- */
.why .section-head { max-width: 52rem; }
.why .section-title em { font-style: normal; color: var(--accent); }
.why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.1rem; }
.why-card {
  padding: 1.6rem 1.5rem;
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  transition: background-color var(--dur) var(--ease);
}
.why-num {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.8rem;
  color: var(--accent);
  margin-bottom: 0.9rem;
}
.why-card h3 { margin-bottom: 0.5rem; }
.why-card p { color: var(--muted); font-size: 0.93rem; }

/* ---------- Systems ---------- */
.sys-grid {
  display: grid;
  grid-template-columns: minmax(0, 6fr) minmax(0, 6fr);
  gap: clamp(2rem, 5vw, 3.5rem);
  align-items: center;
}
.sys-list { list-style: none; padding: 0; display: grid; gap: 0; }
.sys-item { padding: 1.05rem 0; border-bottom: var(--border-w) solid var(--line); }
.sys-item:first-child { border-top: var(--border-w) solid var(--line); }
.sys-item h3 { font-size: 1rem; margin-bottom: 0.2rem; }
.sys-item p { color: var(--muted); font-size: 0.9rem; }

.win--admin .win-body { gap: 0; padding: 0.4rem 0; }
.adm-row {
  display: flex; align-items: center; gap: 0.7rem;
  padding: 0.78rem 1.1rem;
  font-size: 0.84rem;
}
.adm-row + .adm-row { border-top: var(--border-w) solid var(--line); }
.adm-dot { flex: 0 0 auto; width: 0.6rem; height: 0.6rem; border-radius: 50%; }
.adm-dot--new { background: var(--accent); }
.adm-dot--pay { background: var(--accent-2); }
.adm-dot--mail { background: var(--ink); opacity: 0.55; }
.adm-dot--ok { background: var(--ink); opacity: 0.25; }
.adm-text { flex: 1 1 auto; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.adm-text b { font-weight: 600; color: var(--accent); }
.adm-meta { flex: 0 0 auto; font-family: var(--font-mono); font-size: 0.68rem; color: var(--muted); }

/* ---------- Demo sites ---------- */
.demo-library {
  display: grid;
  gap: clamp(2.2rem, 5vw, 3.7rem);
}
.catalog-block { min-width: 0; }
.catalog-block__head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: clamp(1rem, 3vw, 2rem);
  margin-bottom: clamp(1rem, 3vw, 1.6rem);
}
.catalog-block__head > div:first-child {
  min-width: 0;
  max-width: 44rem;
}
.catalog-block__head h3 {
  font-size: clamp(1.25rem, 2.6vw, 1.85rem);
  margin-bottom: 0.45rem;
}
.catalog-block__head p:not(.catalog-eyebrow) {
  color: var(--muted);
  font-size: 0.95rem;
}
.catalog-eyebrow {
  margin-bottom: 0.55rem;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  line-height: 1.2;
  text-transform: uppercase;
}
.catalog-arrows {
  display: flex;
  flex: 0 0 auto;
  gap: 0.55rem;
}
.catalog-arrow {
  width: 2.7rem;
  height: 2.7rem;
  display: grid;
  place-items: center;
  border: var(--border-w) solid var(--ink);
  border-radius: var(--btn-radius);
  background: var(--surface);
  color: var(--ink);
  box-shadow: var(--shadow);
  transition: background-color 0.18s ease, color 0.18s ease, transform 0.18s var(--ease), border-color 0.18s ease;
}
.catalog-arrow svg {
  width: 1.12rem;
  height: 1.12rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.15;
  stroke-linecap: round;
  stroke-linejoin: round;
}
.catalog-arrow:hover {
  background: var(--ink);
  color: var(--bg);
  transform: translateY(-2px);
}
.catalog-viewport {
  min-width: 0;
  overflow-x: auto;
  overflow-y: visible;
  scroll-snap-type: x mandatory;
  scrollbar-width: none;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
  cursor: grab;
}
.catalog-viewport::-webkit-scrollbar { display: none; }
.catalog-viewport:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 0.35rem;
}
.catalog-viewport.is-dragging {
  cursor: grabbing;
  scroll-snap-type: none;
  user-select: none;
}
.catalog-track {
  display: flex;
  align-items: stretch;
  gap: clamp(0.9rem, 2vw, 1.2rem);
  width: max-content;
  min-width: 100%;
}
.feature-track { width: 100%; }
.feature-slide {
  position: relative;
  flex: 0 0 100%;
  min-width: 0;
  min-height: 29rem;
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  align-items: stretch;
  gap: clamp(1.2rem, 4vw, 2.5rem);
  scroll-snap-align: start;
  overflow: hidden;
  padding: clamp(1.35rem, 3.2vw, 2rem);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius-lg);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--accent) 7%, transparent), transparent 48%),
    var(--surface);
  box-shadow: var(--shadow);
  opacity: 0.68;
  transform: scale(0.985);
  transform-origin: center;
  transition:
    opacity 0.28s var(--ease),
    transform 0.28s var(--ease),
    border-color 0.24s var(--ease),
    box-shadow 0.24s var(--ease),
    background-color var(--dur) var(--ease);
}
.feature-slide.is-current {
  opacity: 1;
  transform: scale(1);
  border-color: color-mix(in srgb, var(--accent) 42%, var(--line));
  box-shadow: var(--shadow-strong);
}
.feature-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
  max-width: 32rem;
  line-height: 1.5;
}
.feature-kicker {
  margin-bottom: 0.75rem;
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.13em;
  line-height: 1.2;
  text-transform: uppercase;
}
.feature-title {
  font-size: clamp(1.45rem, 3.6vw, 2.35rem);
  line-height: 1.15;
  margin-bottom: 0.8rem;
}
.feature-text {
  color: var(--muted);
  font-size: clamp(0.96rem, 1.4vw, 1.05rem);
  line-height: 1.55;
}
.feature-points {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  padding: 0;
  margin-top: 1.25rem;
  list-style: none;
}
.feature-points li {
  max-width: 100%;
  padding: 0.38rem 0.65rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: color-mix(in srgb, var(--surface) 78%, var(--accent) 7%);
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  line-height: 1.25;
  text-transform: uppercase;
}
.feature-preview {
  min-width: 0;
  min-height: 22rem;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(circle at 12% 16%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 34%),
    linear-gradient(145deg, color-mix(in srgb, var(--bg-soft) 82%, var(--accent) 8%), var(--surface));
  transition: transform 0.32s var(--ease), border-color 0.24s var(--ease);
}
.feature-slide.is-current .feature-preview {
  transform: translateY(-2px);
  border-color: color-mix(in srgb, var(--accent) 38%, var(--line));
}
.preview-window {
  width: min(94%, 29rem);
  min-height: 18.5rem;
  padding: 1rem;
  border: var(--border-w) solid color-mix(in srgb, var(--ink) 22%, var(--line));
  border-radius: max(var(--radius-lg), 0.75rem);
  background: color-mix(in srgb, var(--surface) 92%, var(--bg) 8%);
  box-shadow: 0 1.2rem 2.4rem color-mix(in srgb, var(--ink) 14%, transparent);
  line-height: 1.35;
}
.preview-window.preview-window--image {
  width: min(96%, 36rem);
  min-height: 0;
  padding: 0.45rem;
  aspect-ratio: 1672 / 941;
  overflow: hidden;
}
.preview-window.preview-window--image img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: calc(max(var(--radius-lg), 0.75rem) - 0.35rem);
  object-fit: cover;
  object-position: center;
}
.preview-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding-bottom: 0.8rem;
  margin-bottom: 0.9rem;
  border-bottom: var(--border-w) solid var(--line);
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.preview-topline i {
  display: block;
  width: 4.2rem;
  height: 0.46rem;
  border-radius: 99px;
  background: color-mix(in srgb, var(--accent) 74%, var(--line));
}
.menu-hero,
.payment-total,
.routing-success {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
  padding: 0.85rem;
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-soft));
}
.menu-hero b,
.payment-total b,
.routing-success b { font-size: 1rem; }
.menu-hero em,
.payment-total em,
.routing-success em {
  color: var(--accent);
  font-style: normal;
  font-family: var(--font-mono);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.menu-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.65rem;
  margin-top: 0.8rem;
}
.menu-card,
.pay-option,
.inbox-card {
  min-width: 0;
  padding: 0.78rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  background: var(--surface);
}
.menu-card span,
.pay-option span,
.inbox-card span {
  display: block;
  color: var(--muted);
  font-size: 0.72rem;
}
.menu-card b,
.pay-option b,
.inbox-card b {
  display: block;
  margin-top: 0.18rem;
  font-size: 0.92rem;
}
.menu-card i {
  display: block;
  height: 0.36rem;
  margin-top: 0.65rem;
  border-radius: 99px;
  background: color-mix(in srgb, var(--accent) 64%, var(--line));
}
.schedule-board { display: grid; gap: 0.5rem; }
.schedule-row {
  display: grid;
  grid-template-columns: 4.2rem minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.55rem;
  padding: 0.68rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 82%, var(--bg-soft));
}
.schedule-row time {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.7rem;
  font-weight: 700;
}
.schedule-row span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-weight: 700;
}
.schedule-row b {
  padding: 0.2rem 0.45rem;
  border-radius: 99px;
  background: color-mix(in srgb, var(--accent) 12%, var(--surface));
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.schedule-strip {
  display: grid;
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 0.35rem;
  margin-top: 0.85rem;
}
.schedule-strip i {
  height: 3.2rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  background:
    linear-gradient(var(--accent), var(--accent)) 50% 72% / 54% 0.34rem no-repeat,
    color-mix(in srgb, var(--bg-soft) 82%, var(--surface));
}
.schedule-strip i:nth-child(even) { background-position: 50% 42%; }
.payment-card { display: grid; gap: 0.7rem; }
.pay-options {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.6rem;
}
.qr-mock {
  display: grid;
  grid-template-columns: 5rem minmax(0, 1fr);
  align-items: center;
  gap: 0.8rem;
  padding: 0.75rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 78%, var(--bg-soft));
}
.qr-mock img {
  display: block;
  width: 5rem;
  height: 5rem;
  padding: 0.28rem;
  border: var(--border-w) solid var(--ink);
  border-radius: var(--radius);
  background: #fff;
  object-fit: contain;
  image-rendering: pixelated;
}
.qr-mock b {
  display: block;
  font-size: 0.95rem;
}
.qr-mock span {
  display: block;
  color: var(--muted);
  font-size: 0.76rem;
}
  .routing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 9.2rem;
  gap: 0.75rem;
}
.route-form { display: grid; gap: 0.55rem; }
.route-field {
  height: 2.25rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--surface) 72%, var(--bg-soft));
}
.route-field--message { height: 4.5rem; }
.route-choice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  padding: 0.55rem 0.65rem;
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 42%, var(--line));
  border-radius: var(--radius);
  background: color-mix(in srgb, var(--accent) 9%, var(--surface));
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 700;
}
.route-choice b {
  color: var(--accent);
  font-family: var(--font-mono);
  font-size: 0.62rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.routing-inboxes { display: grid; gap: 0.55rem; }
.inbox-card.is-active {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent) 18%, transparent);
}
.routing-success { margin-top: 0.75rem; }
.catalog-meta {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 0.85rem;
  margin-top: 0.9rem;
}
.catalog-progress {
  height: 0.42rem;
  overflow: hidden;
  border: var(--border-w) solid var(--line);
  border-radius: 999px;
  background: var(--bg-soft);
}
.catalog-progress span {
  display: block;
  width: var(--catalog-progress, 25%);
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
  transition: width 0.28s var(--ease);
}
.catalog-count {
  color: var(--muted);
  font-family: var(--font-mono);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
}
.catalog-dots {
  display: flex;
  flex-wrap: wrap;
  justify-content: end;
  gap: 0.45rem;
}
.catalog-dot {
  width: 0.58rem;
  height: 0.58rem;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: var(--surface);
  transition: background-color 0.18s ease, border-color 0.18s ease, transform 0.18s var(--ease);
}
.catalog-dot.is-current {
  background: var(--accent);
  border-color: var(--accent);
  transform: scale(1.28);
}
.demo-viewport { padding-block: 0.35rem 0.85rem; }
.demo-track { padding-inline: 0; }
.demo-track .demo-card {
  flex: 0 0 clamp(14rem, 22vw, 17rem);
  min-height: 24.5rem;
  scroll-snap-align: start;
}
.demo-track .demo-thumb { height: 8.2rem; }
.demo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1.1rem;
}
.demo-card {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  text-decoration: none;
  color: inherit;
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 0.9rem 0.9rem 1.1rem;
  transition: transform 0.22s var(--ease), box-shadow 0.22s var(--ease),
              background-color var(--dur) var(--ease);
}
.demo-card:hover { transform: translateY(-3px); }
.demo-thumb {
  position: relative; height: 7.2rem; margin-bottom: 0.9rem;
  width: 100%;
  border-radius: var(--radius); overflow: hidden;
  background: var(--bg-soft);
  border: var(--border-w) solid var(--line);
}
.demo-thumb > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.35s var(--ease), filter 0.35s var(--ease);
}
.demo-card:hover .demo-thumb > img { transform: scale(1.035); }
.demo-thumb--books {
  background: color-mix(in srgb, var(--ink) 88%, var(--accent) 12%);
}
.demo-thumb--books::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--ink) 84%, transparent),
    color-mix(in srgb, var(--ink) 24%, transparent) 58%,
    color-mix(in srgb, var(--ink) 78%, transparent));
  pointer-events: none;
}
.demo-thumb--books > img {
  object-position: center 34%;
  filter: saturate(0.88) contrast(1.08) brightness(0.82);
}
.demo-book-stack {
  position: absolute;
  z-index: 2;
  right: 0.55rem;
  top: 0.55rem;
  width: 43%;
  height: calc(100% - 1.1rem);
  display: grid;
  align-items: center;
  justify-items: end;
  pointer-events: none;
}
.demo-book-stack i {
  display: grid;
  place-items: center;
  width: 56%;
  min-width: 2.6rem;
  height: 76%;
  padding: 0.28rem;
  border: 1px solid color-mix(in srgb, var(--bg) 34%, transparent);
  border-radius: 3px;
  color: var(--bg);
  background: linear-gradient(145deg, color-mix(in srgb, var(--ink) 82%, var(--accent)), var(--accent));
  box-shadow: 0 0.5rem 1rem color-mix(in srgb, var(--ink) 34%, transparent);
  font-family: var(--font-body);
  font-size: 0.42rem;
  line-height: 1.05;
  text-align: center;
  font-style: normal;
}
.demo-book-stack i:nth-child(1) { transform: translate(-34%, 7%) rotate(-7deg); background: linear-gradient(145deg, color-mix(in srgb, var(--accent-2) 42%, var(--ink)), color-mix(in srgb, var(--accent) 58%, var(--surface))); }
.demo-book-stack i:nth-child(2) { transform: translate(3%, -4%) rotate(4deg); background: linear-gradient(145deg, color-mix(in srgb, var(--ink) 86%, var(--accent)), color-mix(in srgb, var(--accent-2) 62%, var(--surface))); }
.demo-book-stack i:nth-child(3) { transform: translate(-15%, -14%) rotate(-2deg); background: linear-gradient(145deg, color-mix(in srgb, var(--surface) 72%, var(--accent)), var(--accent)); color: var(--ink); }
.demo-thumb--artist {
  background: color-mix(in srgb, var(--bg-soft) 84%, var(--accent) 8%);
}
.demo-thumb--artist .demo-thumb-primary {
  position: absolute;
  inset: 0 34% 0 0;
  width: 66%;
  height: 100%;
  object-position: center 28%;
}
.demo-thumb--artist .demo-thumb-art {
  position: absolute;
  z-index: 2;
  right: 0.55rem;
  top: 0.65rem;
  width: 40%;
  height: calc(100% - 1.35rem);
  border: 0.22rem solid var(--surface);
  box-shadow: 0 0.6rem 1.2rem color-mix(in srgb, var(--ink) 18%, transparent);
  object-position: center 46%;
  transform: rotate(-3deg);
}
.demo-card:hover .demo-thumb--artist .demo-thumb-art { transform: rotate(-3deg) scale(1.035); }
.demo-preview-ui {
  position: absolute;
  z-index: 3;
  inset: auto 0.55rem 0.55rem;
  width: fit-content;
  max-width: calc(100% - 1.1rem);
  padding: 0.38rem 0.5rem;
  background: rgba(16, 16, 15, 0.82);
  color: #fff;
  font-family: var(--font-body);
  font-size: 0.64rem;
  line-height: 1.05;
  letter-spacing: 0.03em;
  backdrop-filter: blur(5px);
}
.demo-preview-ui b { font-size: 0.82rem; }
[data-demo="tutor"] .demo-thumb img { object-position: center 35%; }
[data-demo="peaceculture"] .demo-thumb img { object-position: center 48%; filter: saturate(0.88) contrast(1.02); }
[data-demo="artist"] .demo-thumb img { object-position: center 38%; }
[data-demo="coolcare"] .demo-thumb img { object-position: center 48%; }
[data-demo="framehouse"] .demo-thumb img { object-position: center 45%; filter: saturate(0.85) contrast(1.08); }
[data-demo="bakery"] .demo-thumb img { object-position: center 58%; }
[data-demo="muaythai"] .demo-thumb img { object-position: center 38%; filter: contrast(1.08); }
[data-demo="glow"] .demo-thumb img { object-position: center 58%; }
[data-demo="tutor"] .demo-thumb--books img { object-position: center 34%; }
[data-demo="artist"] .demo-thumb--artist .demo-thumb-primary { object-position: center 28%; }
[data-demo="artist"] .demo-thumb--artist .demo-thumb-art { object-position: center 46%; }
.demo-thumb--portal {
  display: grid;
  place-items: center;
  padding: 0.65rem;
  background: color-mix(in srgb, var(--accent) 10%, var(--bg-soft));
}
.portal-mini {
  display: grid; gap: 0.28rem; width: 88%; padding: 0.65rem;
  border: var(--border-w) solid color-mix(in srgb, var(--accent) 30%, var(--line));
  border-radius: 0.35rem;
  background: var(--surface);
  color: var(--ink);
  box-shadow: 0 0.5rem 1rem color-mix(in srgb, var(--ink) 12%, transparent);
  font-family: var(--font-body);
  font-style: normal;
}
.portal-mini i { font-size: 0.45rem; letter-spacing: 0.16em; font-style: normal; color: var(--muted); }
.portal-mini b { font-size: 0.72rem; }
.portal-mini em { padding: 0.28rem; background: var(--bg-soft); font-size: 0.52rem; font-style: normal; }
.portal-mini strong { padding: 0.3rem; border-radius: 0.2rem; background: var(--accent); color: var(--accent-ink); font-size: 0.5rem; text-align: center; }
.dt { position: absolute; display: block; }
.dt-a { background: var(--ink); opacity: 0.85; }
.dt-b { background: var(--accent); border-radius: 50%; }
.dt-c { background: var(--ink); opacity: 0.25; }

/* Abstract layout sketches, one per demo site */
[data-demo="tutor"]      .dt-a { inset: 18% 50% 32% 12%; }
[data-demo="tutor"]      .dt-b { width: 1.2rem; height: 1.2rem; left: 14%; bottom: 18%; }
[data-demo="tutor"]      .dt-c { inset: 18% 12% 18% 56%; }
[data-demo="stillness"]  .dt-a { inset: 62% 30% 34% 30%; }
[data-demo="stillness"]  .dt-b { width: 2.2rem; height: 2.2rem; left: 42%; top: 16%; }
[data-demo="stillness"]  .dt-c { inset: 76% 22% 18% 22%; }
[data-demo="coolcare"]   .dt-a { inset: 16% 18% 60% 18%; border-radius: 6px; }
[data-demo="coolcare"]   .dt-b { width: 1.1rem; height: 1.1rem; right: 24%; top: 22%; }
[data-demo="coolcare"]   .dt-c { inset: 52% 14% 18% 14%; }
[data-demo="framehouse"] .dt-a { inset: 14% 55% 20% 12%; }
[data-demo="framehouse"] .dt-b { width: 1.6rem; height: 1.6rem; right: 22%; bottom: 22%; }
[data-demo="framehouse"] .dt-c { inset: 14% 12% 52% 52%; }
[data-demo="bakery"]     .dt-a { inset: 30% 36% 42% 36%; border-radius: 99px 99px 0 0; }
[data-demo="bakery"]     .dt-b { width: 0.9rem; height: 0.9rem; left: 46%; top: 16%; }
[data-demo="bakery"]     .dt-c { inset: 60% 16% 20% 16%; }
[data-demo="muaythai"]   .dt-a { inset: 30% 14% 44% 14%; transform: rotate(-4deg); }
[data-demo="muaythai"]   .dt-b { width: 1.4rem; height: 1.4rem; right: 18%; top: 14%; }
[data-demo="muaythai"]   .dt-c { inset: auto 24% 16% 24%; height: 0.5rem; }
[data-demo="glow"]       .dt-a { inset: 20% 48% 34% 14%; border-radius: 99px; }
[data-demo="glow"]       .dt-b { width: 1.7rem; height: 1.7rem; right: 20%; top: 22%; }
[data-demo="glow"]       .dt-c { inset: 58% 14% 20% 14%; }
[data-demo="portal"]     .dt-a { inset: 16% 24% 54% 24%; }
[data-demo="portal"]     .dt-b { width: 1.1rem; height: 1.1rem; left: 27%; bottom: 21%; }
[data-demo="portal"]     .dt-c { inset: 54% 28% 22% 28%; }

.demo-cat {
  font-family: var(--font-mono);
  font-size: 0.64rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 0.3rem;
}
.demo-name { font-size: 1rem; margin-bottom: 0.25rem; }
.demo-tag { color: var(--muted); font-size: 0.82rem; margin-bottom: 0.9rem; }
.demo-status { margin-top: auto; }
.demo-status {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.66rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  padding: 0.28rem 0.6rem;
  border: var(--border-w) solid var(--line);
  border-radius: 99px;
  color: var(--muted);
}
.demo-status--prod { border-color: var(--accent); color: var(--accent); }
/* ---------- Process ---------- */
.steps {
  list-style: none; padding: 0;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.1rem;
  counter-reset: step;
}
.step {
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 1.5rem 1.4rem;
  transition: background-color var(--dur) var(--ease);
}
.step-num {
  display: inline-grid; place-items: center;
  width: 2rem; height: 2rem;
  margin-bottom: 0.9rem;
  border: var(--border-w) solid var(--ink);
  border-radius: 50%;
  font-family: var(--font-mono);
  font-size: 0.85rem; font-weight: 600;
}
.step h3 { margin-bottom: 0.4rem; }
.step p { color: var(--muted); font-size: 0.9rem; }

/* ---------- Pricing ---------- */
.price-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.3rem;
  max-width: 76rem;
}
.price-card {
  position: relative;
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 2rem 1.8rem;
  display: flex; flex-direction: column;
  transition: background-color var(--dur) var(--ease);
}
.price-card--featured { border-color: var(--ink); box-shadow: var(--shadow-strong); }
.price-badge {
  position: absolute; top: -0.8rem; left: 1.6rem;
  background: var(--accent); color: var(--accent-ink);
  font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.3rem 0.7rem;
  border-radius: var(--btn-radius);
}
.price-name { font-size: 1.15rem; margin-bottom: 0.8rem; }
.price-pricing {
  display: grid;
  justify-items: start;
  gap: 0.38rem;
  margin-bottom: 1rem;
}
.price-amount {
  font-family: var(--font-display);
  font-weight: var(--h-weight);
  letter-spacing: var(--h-tracking);
  font-size: clamp(2.2rem, 4vw, 2.9rem);
  line-height: 1;
  white-space: nowrap;
}
.price-usd {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 600;
  line-height: 1.35;
}
.price-care {
  max-width: 100%;
  margin-top: 0.25rem;
  padding: 0.48rem 0.72rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: var(--bg-soft);
  color: var(--ink);
  font-size: 0.88rem;
  font-weight: 700;
  line-height: 1.35;
}
.price-desc { color: var(--muted); font-size: 0.93rem; margin-bottom: 1.3rem; }
.price-list { list-style: none; padding: 0; margin-bottom: 1.8rem; display: grid; gap: 0.55rem; }
.price-list li { position: relative; padding-left: 1.5rem; font-size: 0.93rem; }
.price-list li::before {
  content: "✓";
  position: absolute; left: 0; top: 0;
  color: var(--accent); font-weight: 700;
}
.price-cta { margin-top: auto; text-align: center; }
.price-note {
  max-width: 56rem;
  margin-top: 1.4rem;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.6;
}

/* ---------- Contact ---------- */
.contact-grid {
  display: grid;
  grid-template-columns: minmax(0, 5fr) minmax(0, 7fr);
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.ci-list { list-style: none; padding: 0; margin-top: 1.8rem; display: grid; gap: 0.7rem; }
.ci-item { display: flex; gap: 1rem; font-size: 0.95rem; align-items: baseline; }
.ci-label {
  flex: 0 0 4.5rem;
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--muted);
}
.ci-item a { color: var(--ink); text-decoration-color: var(--accent); }

.form {
  background: var(--surface);
  border: var(--border-w) solid var(--line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  padding: clamp(1.4rem, 3vw, 2rem);
  display: grid; gap: 1.1rem;
  transition: background-color var(--dur) var(--ease);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.field { display: grid; gap: 0.35rem; }
.field--full { grid-column: 1 / -1; }
.field label {
  font-size: 0.78rem; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--muted);
}
.field input, .field select, .field textarea {
  width: 100%;
  padding: 0.7rem 0.85rem;
  border: var(--border-w) solid var(--line);
  border-radius: var(--btn-radius);
  background: var(--bg);
  transition: border-color 0.15s ease;
}
.field textarea { resize: vertical; min-height: 7rem; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--accent);
}
.field-error {
  min-height: 1.15em;
  color: #b42318;
  font-size: 0.78rem;
  line-height: 1.35;
}
.field :is(input, select, textarea)[aria-invalid="true"] {
  border-color: #b42318;
  box-shadow: 0 0 0 1px #b42318;
}
.form-submit { justify-self: start; border: var(--border-w) solid var(--ink); }
.form-submit:disabled { cursor: wait; opacity: 0.65; }
.turnstile-widget { min-height: 65px; }
.form-note {
  min-height: 1.4em;
  margin-top: -0.4rem;
  padding: 0.75rem 0.85rem;
  border: var(--border-w) solid transparent;
  border-radius: var(--btn-radius);
  color: var(--muted);
  font-size: 0.88rem;
}
.form-note:empty {
  min-height: 1.4em;
  padding: 0;
  border: 0;
}
.form-note.is-success {
  border-color: color-mix(in srgb, #208a4c 48%, var(--line));
  background: color-mix(in srgb, #208a4c 10%, var(--surface));
  color: color-mix(in srgb, #145c33 78%, var(--ink));
}
.form-note.is-error {
  border-color: color-mix(in srgb, #b42318 48%, var(--line));
  background: color-mix(in srgb, #b42318 9%, var(--surface));
  color: color-mix(in srgb, #8a1c13 78%, var(--ink));
}
.contact-privacy { color: var(--muted); font-size: 0.82rem; line-height: 1.5; }
.contact-privacy a { color: var(--ink); text-decoration-color: var(--accent); text-underline-offset: 0.18em; }

/* ---------- Footer ---------- */
.site-footer {
  border-top: var(--border-w) solid var(--line);
  padding-block: 2.6rem;
  font-size: 0.9rem;
}
.footer-inner { display: grid; gap: 1.4rem; }
.footer-brand p { color: var(--muted); margin-top: 0.4rem; max-width: 28rem; }
.business-identity {
  display: grid;
  gap: 0.28rem;
  margin-top: 1rem;
  color: var(--muted);
  font-size: 0.82rem;
  line-height: 1.45;
}
.business-identity strong {
  color: var(--ink);
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.business-identity a {
  color: var(--ink);
  text-decoration-color: var(--accent);
  text-underline-offset: 0.18em;
}
.footer-nav { display: flex; flex-wrap: wrap; gap: 1.2rem; }
.footer-nav a { color: var(--muted); text-decoration: none; }
.footer-nav a:hover { color: var(--ink); }
.footer-meta { color: var(--muted); font-size: 0.82rem; }
.footer-meta a { color: var(--ink); }
.footer-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) repeat(2, minmax(9rem, 0.65fr));
  gap: clamp(1.5rem, 5vw, 4rem);
}
.footer-email { display: inline-block; margin-top: 0.75rem; color: var(--ink); text-decoration-color: var(--accent); }
.footer-group strong {
  display: block;
  margin-bottom: 0.7rem;
  font-family: var(--font-mono);
  color: var(--ink);
  font-size: 0.7rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.footer-group nav { display: grid; gap: 0.48rem; }
.footer-group a { color: var(--muted); text-decoration: none; }
.footer-group a:hover { color: var(--ink); }
.footer-bottom {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.75rem 1.5rem;
  padding-top: 1.25rem;
  border-top: var(--border-w) solid var(--line);
}
.terminal-label { display: none; }
[data-theme="terminal"] .standard-label { display: none; }
[data-theme="terminal"] .terminal-label { display: inline; }
[data-theme="terminal"] .footer-legal a::before { content: "[ "; }
[data-theme="terminal"] .footer-legal a::after { content: " ]"; }
:is([data-theme="kinetic"], [data-theme="saas"], [data-theme="poster"]) .site-footer .footer-group strong {
  color: inherit;
}
[data-theme="kinetic"] .site-footer :is(.footer-group a, .footer-email) {
  color: #d6d6cd;
}
[data-theme="kinetic"] .site-footer :is(.footer-group a, .footer-email):hover {
  color: var(--accent);
}

/* ---------- Scroll-reveal (class added by JS; no-JS users see everything) -- */
.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.6s var(--ease), transform 0.6s var(--ease);
  transition-delay: var(--reveal-delay, 0s);
}
.reveal.in-view { opacity: 1; transform: none; }

/* ---------- Responsive ---------- */

/* Collapse the inline nav to a mobile menu early, before the links can crowd
   the language selector and CTA. The longest UI language (Thai) needs the most
   room, so we switch over at a generous width rather than squeezing everything
   into one row. Keep this max-width in sync with the matchMedia() in js/main.js. */
@media (max-width: 1080px) {
  html { scroll-padding-top: var(--header-offset, 5.25rem); }
  .site-header { padding-block: 0.55rem; }
  .header-inner {
    grid-template-columns: minmax(0, 1fr) auto;
    grid-template-areas:
      "brand controls"
      "nav nav";
    gap: 0.55rem 0.8rem;
  }
  .brand-name { font-size: 1rem; }
  .nav-toggle {
    display: flex;
    grid-area: controls;
    justify-self: end;
  }
  .header-actions {
    grid-area: controls;
    justify-self: end;
    padding-right: 2.9rem;
  }
  .header-cta--desktop { display: none; }
  .site-nav {
    display: none;
    width: 100%;
    justify-content: stretch;
    gap: 0.25rem;
    padding: 0.7rem;
    background: color-mix(in srgb, var(--surface) 90%, transparent);
    border: var(--border-w) solid var(--line);
    border-radius: var(--radius-lg);
    box-shadow: 0 16px 34px color-mix(in srgb, var(--ink) 12%, transparent);
  }
  .site-header.nav-open .site-nav {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
  }
  .nav-link {
    min-height: 2.45rem;
    justify-content: space-between;
    padding: 0.65rem 0.75rem;
  }
  .nav-link[aria-current="true"]::after {
    left: auto;
    right: 0.75rem;
    top: 50%;
    bottom: auto;
    width: 0.38rem;
    height: 0.38rem;
    transform: translateY(-50%);
    border-radius: 50%;
  }
  .header-cta--mobile {
    display: inline-flex;
    justify-content: center;
    margin-top: 0.35rem;
    width: 100%;
    text-align: center;
  }
}
@media (max-width: 900px) {
  .hero-inner { grid-template-columns: minmax(0, 1fr); }
  .hero-art { min-height: 260px; }
  .service-options { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .why-grid { grid-template-columns: 1fr; }
  .sys-grid { grid-template-columns: minmax(0, 1fr); }
  .feature-slide {
    grid-template-columns: minmax(0, 1fr);
    min-height: 0;
  }
  .feature-copy {
    justify-content: start;
    max-width: none;
  }
  .price-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .steps { grid-template-columns: repeat(2, 1fr); }
  .contact-grid { grid-template-columns: minmax(0, 1fr); }
  .demo-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-grid { grid-template-columns: minmax(0, 1fr) minmax(9rem, 1fr) minmax(9rem, 1fr); }
}
@media (max-width: 820px) {
  .service-feature {
    grid-template-columns: minmax(0, 1fr);
    height: 52rem;
  }
  .service-feature h3 { max-width: 15ch; }
  .service-feature__copy { padding-bottom: 1.25rem; }
  .service-feature__visual {
    min-height: 25rem;
    padding-top: 0;
  }
  .svc-visual { width: min(100%, 34rem); }
}
@media (max-width: 700px) {
  .mp-cols { grid-template-columns: minmax(0, 1fr); gap: 1.1rem; }
}
@media (max-width: 600px) {
  .catalog-block__head {
    display: grid;
    gap: 0.9rem;
  }
  .catalog-arrows {
    justify-self: start;
  }
  .feature-slide {
    padding: 1rem;
  }
  .feature-copy {
    line-height: 1.38;
  }
  .feature-kicker {
    margin-bottom: 0.5rem;
  }
  .feature-title {
    font-size: clamp(1.35rem, 8vw, 1.9rem);
    margin-bottom: 0.55rem;
  }
  .feature-text {
    font-size: 0.92rem;
    line-height: 1.45;
  }
  .feature-points {
    gap: 0.36rem;
    margin-top: 0.85rem;
  }
  .feature-points li {
    padding: 0.32rem 0.5rem;
    font-size: 0.58rem;
  }
  .feature-preview {
    min-height: 18rem;
  }
  .preview-window {
    width: 100%;
    min-height: 16.5rem;
    padding: 0.75rem;
  }
.routing-layout {
    grid-template-columns: minmax(0, 1fr);
  }
  .menu-grid,
  .pay-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .pay-option:nth-child(3) {
    grid-column: 1 / -1;
  }
  .schedule-row {
    grid-template-columns: 3.6rem minmax(0, 1fr);
  }
  .schedule-row b {
    grid-column: 2;
    justify-self: start;
  }
  .catalog-meta {
    grid-template-columns: minmax(0, 1fr) auto;
  }
  .catalog-dots {
    grid-column: 1 / -1;
    justify-content: start;
  }
  .demo-track .demo-card {
    flex-basis: min(82vw, 20rem);
    min-height: 24rem;
  }
  .service-feature { height: 48rem; }
  .service-feature__copy { padding: 1.6rem 1.35rem 1rem; }
  .service-feature__visual {
    min-height: 19rem;
    padding: 0.75rem 1rem 1.2rem;
  }
  .service-option {
    min-height: 7.8rem;
    padding: 1rem;
  }
  .service-tags { gap: 0.42rem; }
  .service-tags li { font-size: 0.62rem; }
  .price-grid { grid-template-columns: 1fr; }
  .price-card { padding-inline: 1.35rem; }
  .price-care { width: 100%; }
  .steps { grid-template-columns: 1fr; }
  .demo-grid { grid-template-columns: minmax(0, 1fr); }
  .form-row { grid-template-columns: 1fr; }
  .car-btn { display: none; } /* swipe on touch screens */
  .mode-card { flex-basis: 10.5rem; }
  .palette-pop { min-width: 13rem; max-width: calc(100vw - 3.5rem); }
  .tk-item { font-size: 0.7rem; }
  .footer-grid { grid-template-columns: minmax(0, 1fr); }
  .footer-bottom { display: grid; }
}
@media (max-width: 480px) {
  .service-options { grid-template-columns: minmax(0, 1fr); }
  .service-feature { height: 46rem; }
  .service-feature__visual { min-height: 17rem; }
  .service-feature h3 { font-size: clamp(1.8rem, 10vw, 2.45rem); }
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
  .reveal { opacity: 1; transform: none; }
}
