/* assets/css/src/base/variables.css */
:root {
  --color-primary: #7c3aed;
  --color-primary-soft: rgba(124, 58, 237, 0.12);
  --color-primary-dark: #5b21b6;
  --color-accent: #22d3ee;
  --color-accent-soft: rgba(34, 211, 238, 0.14);
  --color-cta: #10b981;
  --color-cta-dark: #059669;
  --color-text: #0a0a0b;
  --color-muted: #52525b;
  --color-bg: #f4f4f5;
  --color-bg-alt: #e4e4e7;
  --color-border: rgba(9, 9, 11, 0.08);
  --color-deep: #18181b;
  --color-ink: #09090b;
  --font-display:
    "Syne",
    system-ui,
    sans-serif;
  --font-sans:
    "Plus Jakarta Sans",
    system-ui,
    sans-serif;
  --radius: 14px;
  --radius-lg: 24px;
  --radius-pill: 999px;
  --shadow: 0 4px 24px rgba(9, 9, 11, 0.06);
  --shadow-hover: 0 20px 50px rgba(9, 9, 11, 0.1);
  --shadow-glow: 0 0 0 1px rgba(124, 58, 237, 0.12), 0 12px 40px rgba(124, 58, 237, 0.15);
  --container: 1180px;
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --scrollbar-size: 11px;
  --scrollbar-track: #e4e4e7;
  --scrollbar-track-glow: rgba(124, 58, 237, 0.08);
  --scrollbar-thumb-fallback: #7c3aed;
  --scrollbar-thumb-hover-fallback: #6d28d9;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  font-size: 100%;
  scroll-behavior: smooth;
  color-scheme: light;
  scrollbar-width: thin;
  scrollbar-color: var(--scrollbar-thumb-fallback) var(--scrollbar-track);
}

/* assets/css/src/base/scrollbar.css */
*::-webkit-scrollbar {
  width: var(--scrollbar-size);
  height: var(--scrollbar-size);
}
*::-webkit-scrollbar-track {
  margin: 6px;
  background:
    linear-gradient(
      180deg,
      var(--scrollbar-track-glow) 0%,
      transparent 35%,
      transparent 65%,
      rgba(34, 211, 238, 0.06) 100%),
    var(--scrollbar-track);
  border-radius: var(--radius-pill);
  box-shadow: inset 0 0 0 1px var(--color-border);
}
*::-webkit-scrollbar-thumb {
  border-radius: var(--radius-pill);
  border: 2px solid transparent;
  background-clip: padding-box;
  background-image:
    linear-gradient(
      90deg,
      rgba(34, 211, 238, 0.55) 0%,
      rgba(34, 211, 238, 0) 28%),
    linear-gradient(
      180deg,
      #e9d5ff 0%,
      var(--color-primary) 42%,
      var(--color-primary-dark) 100%);
  box-shadow: 0 0 12px rgba(124, 58, 237, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.45);
}
*::-webkit-scrollbar-thumb:hover {
  background-image:
    linear-gradient(
      90deg,
      rgba(34, 211, 238, 0.75) 0%,
      rgba(34, 211, 238, 0) 32%),
    linear-gradient(
      180deg,
      #f5f3ff 0%,
      #8b5cf6 38%,
      var(--color-primary-dark) 100%);
  box-shadow: 0 0 16px rgba(124, 58, 237, 0.35), inset 0 1px 0 rgba(255, 255, 255, 0.55);
}
*::-webkit-scrollbar-corner {
  background: var(--scrollbar-track);
}

/* assets/css/src/base/cursors.css */
@media (pointer: fine) {
  :root {
    --cursor-pointer: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32" viewBox="0 0 32 32" fill="none">%0A  <g opacity="0.4" transform="translate(2 2.5)">%0A    <path fill="%235b21b6" d="M16.5 2.5C14.2 2.5 12.5 4.3 12.5 6.5V20C12.5 26.8 16.8 31 22.5 31C28.2 31 31.5 26.5 31.5 21V15.2C31.5 13.6 29.9 12.6 28.4 13.2L27.2 17.8C27 16.2 25.4 15.6 24.3 16.8L23.6 11.8C23.4 9.7 21.3 9.2 20.2 10.8L19.6 17.2V6.2C19.6 4 18 2.5 16.5 2.5Z"/>%0A  </g>%0A  <path fill="%237c3aed" stroke="%23ffffff" stroke-width="2" stroke-linejoin="round" stroke-linecap="round" d="M16.5 2.5C14.2 2.5 12.5 4.3 12.5 6.5V20C12.5 26.8 16.8 31 22.5 31C28.2 31 31.5 26.5 31.5 21V15.2C31.5 13.6 29.9 12.6 28.4 13.2L27.2 17.8C27 16.2 25.4 15.6 24.3 16.8L23.6 11.8C23.4 9.7 21.3 9.2 20.2 10.8L19.6 17.2V6.2C19.6 4 18 2.5 16.5 2.5Z"/>%0A  <circle cx="20" cy="20.5" r="4.8" fill="%2322d3ee" fill-opacity="0.45"/>%0A</svg>%0A') 16 3, pointer;
  }
  html {
    cursor: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='32' height='32' viewBox='0 0 32 32'%3E%3Cg opacity='0.4' transform='translate(2%2C2.5)'%3E%3Cpath d='M2.5%203.5%20L2.5%2026%20L15%2013.5%20L20.5%2029%20L26.5%2025.5%20L19%209.5%20L29.5%209.5%20Z' fill='%235b21b6'/%3E%3C/g%3E%3Cpath d='M2.5%203.5%20L2.5%2026%20L15%2013.5%20L20.5%2029%20L26.5%2025.5%20L19%209.5%20L29.5%209.5%20Z' fill='%237c3aed' stroke='%23ffffff' stroke-width='2' stroke-linejoin='round' stroke-linecap='round'/%3E%3Ccircle cx='14' cy='12' r='5' fill='%2322d3ee' fill-opacity='0.45'/%3E%3C/svg%3E") 3 4, auto;
  }
  a:any-link,
  button:enabled,
  input[type=submit]:enabled,
  input[type=button]:enabled,
  input[type=reset]:enabled,
  label[for],
  summary,
  [role=button]:not([aria-disabled=true]) {
    cursor: var(--cursor-pointer, pointer);
  }
}
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: 1rem;
  line-height: 1.65;
  color: var(--color-text);
  background-color: var(--color-bg);
  background-image:
    radial-gradient(
      ellipse 120% 90% at 80% -20%,
      rgba(124, 58, 237, 0.09) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 80% 60% at 0% 100%,
      rgba(34, 211, 238, 0.07) 0%,
      transparent 45%),
    linear-gradient(
      180deg,
      #fafafa 0%,
      var(--color-bg) 35%,
      #f4f4f5 100%);
  background-attachment: fixed;
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  opacity: 0.35;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.45'/%3E%3C/svg%3E");
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}
a {
  color: var(--color-primary);
  text-decoration: none;
}
a:hover {
  text-decoration: underline;
}
.text-link {
  font-weight: 600;
}
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.hp-field {
  position: absolute !important;
  left: -9999px !important;
  top: auto !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
}
.skip-link {
  position: absolute;
  left: -9999px;
  top: 0;
  z-index: 1000;
  padding: 0.75rem 1rem;
  background: var(--color-primary);
  color: #fff;
}
.skip-link:focus {
  left: 1rem;
  top: 1rem;
}
.container {
  width: min(100% - 1.5rem, var(--container));
  margin-inline: auto;
}

/* assets/css/src/layout/top-bar.css */
.top-bar {
  position: relative;
  z-index: 60;
  background:
    linear-gradient(
      105deg,
      #09090b 0%,
      #18181b 42%,
      #27272a 100%);
  color: #a1a1aa;
  font-size: 0.8125rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.top-bar__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.65rem 1.5rem;
  padding: 0.5rem 0;
}
.top-bar__schedule {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.35rem 0.5rem;
  margin: 0;
  line-height: 1.35;
}
.top-bar__schedule-label {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #71717a;
}
.top-bar__schedule-value {
  color: #d4d4d8;
  font-weight: 600;
}
.top-bar__contacts {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 1.1rem;
  list-style: none;
  margin: 0;
  padding: 0;
}
.top-bar__contacts-item {
  display: inline-flex;
  align-items: center;
}
.top-bar__link {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  color: #fafafa;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.top-bar__link:hover {
  color: var(--color-accent);
}
.top-bar__icon {
  flex-shrink: 0;
  opacity: 0.75;
  color: var(--color-accent);
}
.top-bar__link:hover .top-bar__icon {
  opacity: 1;
}
.top-bar__icon--brand {
  opacity: 1;
}
.top-bar__link--viber .top-bar__icon--brand {
  color: #7360f2;
}
.top-bar__link--telegram .top-bar__icon--brand {
  color: #2aabee;
}
.top-bar__link--viber:hover,
.top-bar__link--telegram:hover {
  color: #fafafa;
}
.top-bar__link-text {
  max-width: 52vw;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (min-width: 480px) {
  .top-bar__link-text {
    max-width: none;
    white-space: normal;
  }
}
@media (max-width: 639px) {
  .top-bar__inner {
    display: grid;
    grid-template-columns: auto auto;
    grid-template-areas: "schedule schedule" "contacts lang";
    justify-content: center;
    align-items: center;
    text-align: center;
  }
  .top-bar__schedule {
    grid-area: schedule;
    justify-content: center;
  }
  .top-bar__contacts {
    grid-area: contacts;
    justify-self: end;
    justify-content: flex-end;
    flex-wrap: nowrap;
    gap: 0.35rem;
  }
  .top-bar__contacts > li:not(.top-bar__contacts-item--telegram) {
    display: none;
  }
  .top-bar .lang-switch {
    grid-area: lang;
    justify-self: start;
    align-self: center;
  }
}
@media (min-width: 640px) and (max-width: 1023px) {
  .top-bar__inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.65rem 1rem;
  }
  .top-bar__contacts {
    justify-self: stretch;
    width: 100%;
    flex-wrap: nowrap;
    justify-content: flex-start;
    min-width: 0;
  }
  .top-bar__contacts-item--telegram {
    margin-left: auto;
    margin-right: 8px;
  }
}
@media (min-width: 1024px) {
  .top-bar__inner {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 0.65rem 1.5rem;
  }
  .top-bar__schedule {
    justify-self: start;
  }
  .top-bar__contacts {
    justify-self: stretch;
    justify-content: flex-start;
    flex-wrap: nowrap;
    min-width: 0;
    width: 100%;
  }
  .top-bar__contacts-item--telegram {
    margin-left: auto;
    margin-right: 10px;
    padding-left: 0;
    border-left: 0;
  }
  .top-bar .lang-switch {
    justify-self: end;
  }
}

/* assets/css/src/layout/header.css */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.82);
  border-bottom: 1px solid var(--color-border);
  backdrop-filter: blur(20px) saturate(1.35);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.72) inset, 0 8px 32px rgba(9, 9, 11, 0.04);
}
.site-header__bar {
  display: grid;
  align-items: center;
  gap: 0 1rem;
  padding: 0.7rem 0;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-template-areas: "brand toggle" "nav nav";
}
@media (min-width: 1024px) {
  .site-header__bar {
    grid-template-columns: auto minmax(0, 1fr) auto;
    grid-template-areas: "brand nav actions";
    gap: 0 1.75rem;
    padding: 0.65rem 0;
  }
}
.site-header__brand {
  grid-area: brand;
  min-width: 0;
}
.site-header__toggle {
  grid-area: toggle;
  justify-self: end;
}
.site-header__nav {
  grid-area: nav;
  min-width: 0;
}
.site-header__actions {
  grid-area: actions;
  display: none;
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: nowrap;
}
@media (min-width: 1024px) {
  .site-header__actions {
    display: flex;
  }
}
.logo {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: 1.35rem;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.logo:hover {
  text-decoration: none;
}
.logo--lockup {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  line-height: 1;
  min-width: 0;
}
.logo__mark {
  display: block;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  border-radius: 12px;
  box-shadow: 0 4px 16px rgba(124, 58, 237, 0.2);
}
.logo__wordmark {
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(1.1rem, 3.5vw, 1.35rem);
  letter-spacing: -0.04em;
  background:
    linear-gradient(
      115deg,
      var(--color-text) 0%,
      var(--color-primary) 55%,
      #5b21b6 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.logo--footer-lockup .logo__wordmark--footer {
  background:
    linear-gradient(
      115deg,
      #fafafa 0%,
      #e9d5ff 50%,
      #67e8f9 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.logo__mark--footer {
  width: 40px;
  height: 40px;
  border-radius: 11px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.35);
}

/* assets/css/src/layout/nav-toggle.css */
.nav-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 46px;
  height: 46px;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.95);
  cursor: var(--cursor-pointer, pointer);
  box-shadow: var(--shadow);
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}
.nav-toggle:hover {
  border-color: rgba(124, 58, 237, 0.28);
  box-shadow: var(--shadow-glow);
}
.nav-toggle:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 3px;
}
.nav-toggle__bars {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 22px;
  height: 16px;
}
.nav-toggle__bar {
  display: block;
  height: 2px;
  width: 100%;
  background: var(--color-text);
  border-radius: 2px;
  transition: transform 0.25s var(--ease-out), opacity 0.2s ease;
  transform-origin: center;
}
@media (prefers-reduced-motion: reduce) {
  .nav-toggle__bar {
    transition: none;
  }
}
.nav-toggle[aria-expanded=true] .nav-toggle__bar:nth-child(1) {
  transform: translateY(7px) rotate(45deg);
}
.nav-toggle[aria-expanded=true] .nav-toggle__bar:nth-child(2) {
  opacity: 0;
  transform: scaleX(0);
}
.nav-toggle[aria-expanded=true] .nav-toggle__bar:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg);
}
@media (min-width: 1024px) {
  .site-header__toggle {
    display: none;
  }
}
.site-nav {
  width: 100%;
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.38s var(--ease-out);
}
.site-nav.is-open {
  max-height: min(88vh, 720px);
}
@media (max-width: 1023px) {
  .site-header__nav.site-nav.is-open {
    margin-top: 0.35rem;
    padding: 0.15rem 0.85rem 1.15rem;
    background: rgba(255, 255, 255, 0.97);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-hover);
  }
  body.nav-open {
    overflow: hidden;
  }
}
@media (min-width: 1024px) {
  .site-nav {
    width: 100%;
    min-width: 0;
    max-height: none;
    overflow: visible;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
}
.site-nav__list {
  list-style: none;
  margin: 0;
  padding: 0.65rem 0 0.75rem;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  width: 100%;
}
@media (min-width: 1024px) {
  .site-nav__list {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.15rem 0.2rem;
    padding: 0;
    width: 100%;
    max-width: none;
  }
}
.site-nav__item {
  margin: 0;
}
.site-nav__item--mobile-only {
  display: block;
}
.site-nav__item--desktop-only {
  display: none;
}
.site-nav__item--group-label {
  width: 100%;
  margin-top: 0.45rem;
}
.site-nav__group-label {
  display: block;
  padding: 0.45rem 0.85rem 0.25rem;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
}
@media (min-width: 1024px) {
  .site-nav__item--mobile-only {
    display: none;
  }
  .site-nav__item--desktop-only {
    display: block;
  }
}
.site-nav__link {
  display: block;
  padding: 0.55rem 0.85rem;
  color: var(--color-text);
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: var(--radius-pill);
  transition:
    color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.site-nav__link:hover,
.site-nav__link.is-active {
  color: var(--color-primary-dark);
  text-decoration: none;
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      var(--color-accent-soft) 100%);
  box-shadow: 0 0 0 1px rgba(124, 58, 237, 0.08);
}
.site-nav__link.is-active {
  font-weight: 700;
}
@media (min-width: 1024px) and (max-width: 1199px) {
  .site-nav__link {
    padding: 0.45rem 0.55rem;
    font-size: 0.82rem;
  }
}

/* assets/css/src/layout/nav-dropdown.css */
.site-nav__dropdown {
  position: relative;
}
.site-nav__dropdown-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  width: 100%;
  border: none;
  background: transparent;
  font: inherit;
  cursor: var(--cursor-pointer, pointer);
  text-align: left;
}
@media (min-width: 1024px) {
  .site-nav__dropdown-btn {
    width: auto;
    text-align: center;
    white-space: nowrap;
  }
}
.site-nav__chevron {
  flex-shrink: 0;
  opacity: 0.65;
  transition: transform 0.25s var(--ease-out);
}
.site-nav__dropdown.is-open .site-nav__chevron {
  transform: rotate(180deg);
}
.site-nav__dropdown-panel {
  list-style: none;
  margin: 0;
  padding: 0.35rem 0 0;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.35s var(--ease-out), opacity 0.2s ease;
}
.site-nav__dropdown.is-open .site-nav__dropdown-panel {
  max-height: min(70vh, 420px);
  opacity: 1;
}
.site-nav__dropdown.is-open .site-nav__dropdown-panel--mega {
  max-height: min(90vh, 720px);
}
@media (min-width: 1024px) {
  .site-nav__dropdown-panel {
    position: absolute;
    top: calc(100% + 0.35rem);
    left: 50%;
    transform: translateX(-50%) translateY(-6px);
    min-width: 15.5rem;
    padding: 0.4rem;
    max-height: none;
    overflow: visible;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow-hover), 0 0 0 1px rgba(124, 58, 237, 0.06);
    transition:
      opacity 0.2s var(--ease-out),
      transform 0.2s var(--ease-out),
      visibility 0.2s;
  }
  .site-nav__dropdown.is-open .site-nav__dropdown-panel {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
  }
}
.site-nav__dropdown-link {
  display: block;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--color-text);
  text-decoration: none;
  border-radius: var(--radius);
  transition: background 0.2s var(--ease-out), color 0.2s var(--ease-out);
}
.site-nav__dropdown-link:hover,
.site-nav__dropdown-link.is-active {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
  text-decoration: none;
}

/* assets/css/src/layout/mega-menu.css */
.site-nav__mega-grid {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.site-nav__mega-col {
  margin: 0;
  padding: 0;
  border-radius: var(--radius);
}
.site-nav__mega-col + .site-nav__mega-col {
  padding-top: 0.85rem;
  border-top: 1px solid rgba(124, 58, 237, 0.12);
}
.site-nav__mega-heading {
  margin: 0 0 0.45rem;
  padding: 0 0.15rem;
  font-size: 0.6875rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
  line-height: 1.3;
}
.site-nav__mega-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.12rem;
}
.site-nav__mega-link {
  font-weight: 600;
}
@media (min-width: 1024px) {
  .site-nav__dropdown-panel--mega {
    min-width: min(36rem, calc(100vw - 2rem));
    padding: 1rem 1.1rem;
    background:
      linear-gradient(
        145deg,
        rgba(255, 255, 255, 0.99) 0%,
        rgba(250, 245, 255, 0.97) 45%,
        rgba(240, 253, 250, 0.55) 100%);
    border: 1px solid rgba(124, 58, 237, 0.14);
    box-shadow:
      var(--shadow-hover),
      0 0 0 1px rgba(124, 58, 237, 0.05),
      0 24px 48px rgba(91, 33, 182, 0.08);
  }
  .site-nav__mega-grid {
    flex-direction: row;
    align-items: stretch;
    gap: 0;
  }
  .site-nav__mega-col {
    flex: 1;
    min-width: 0;
    padding: 0.35rem 1rem;
    border-radius: var(--radius);
  }
  .site-nav__mega-col:first-child {
    padding-left: 0.2rem;
    background:
      linear-gradient(
        160deg,
        rgba(124, 58, 237, 0.07) 0%,
        transparent 72%);
  }
  .site-nav__mega-col:last-child {
    padding-right: 0.2rem;
    background:
      linear-gradient(
        200deg,
        rgba(16, 185, 129, 0.08) 0%,
        transparent 70%);
  }
  .site-nav__mega-col + .site-nav__mega-col {
    padding-top: 0.35rem;
    margin-left: 0.35rem;
    padding-left: 1.15rem;
    border-top: none;
    border-left: 1px solid rgba(124, 58, 237, 0.14);
  }
  .site-nav__mega-heading {
    margin-bottom: 0.55rem;
  }
}
.site-nav__cta {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 1rem 0 0.35rem;
  margin-top: 0.35rem;
  border-top: 1px solid var(--color-border);
}
@media (min-width: 1024px) {
  .site-nav__cta {
    display: none;
  }
}

/* assets/css/src/layout/footer-cta.css */
.site-footer__cta {
  padding: 2.25rem 0 2.5rem;
  background:
    linear-gradient(
      180deg,
      #0a0a0b 0%,
      #18181b 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.footer-cta-card {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 1.25rem;
  max-width: 100%;
  padding: 1.5rem 1.35rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.22) 0%,
      rgba(9, 9, 11, 0.92) 45%,
      rgba(15, 23, 42, 0.95) 100%);
  border: 1px solid rgba(167, 139, 250, 0.2);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.04) inset;
  text-align: center;
}
.footer-cta-card__text {
  flex: 1 1 auto;
  min-width: 0;
}
.footer-cta-card__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.5vw, 1.45rem);
  font-weight: 800;
  color: #fafafa;
  letter-spacing: -0.02em;
}
.footer-cta-card__desc {
  margin: 0;
  margin-inline: auto;
  max-width: 36rem;
  font-size: 0.92rem;
  line-height: 1.55;
  color: #a1a1aa;
}
.footer-cta-card__direct {
  margin: 0.65rem 0 0;
  font-size: 0.9375rem;
  line-height: 1.5;
  color: #d4d4d8;
}
.footer-cta-card__direct-label {
  display: inline;
  margin-right: 0.35rem;
  color: #a1a1aa;
}
.footer-cta-card__tel {
  font-weight: 700;
  color: #a5f3fc;
  text-decoration: none;
  white-space: nowrap;
}
.footer-cta-card__tel:hover {
  color: #cffafe;
  text-decoration: underline;
}
.footer-cta-card__form {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 0.65rem;
  flex-shrink: 0;
  width: 100%;
  max-width: 22rem;
  margin-inline: auto;
}
.footer-cta-card__input {
  width: 100%;
  padding: 0.7rem 1rem;
  font: inherit;
  font-size: 1rem;
  line-height: 1.35;
  color: var(--color-text);
  background: #fff;
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: var(--radius);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}
.footer-cta-card__input::placeholder {
  color: #a1a1aa;
}
.footer-cta-card__input:hover {
  border-color: rgba(167, 139, 250, 0.45);
}
.footer-cta-card__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-soft), 0 1px 3px rgba(0, 0, 0, 0.15);
}
.footer-cta-card__submit {
  flex-shrink: 0;
  width: 100%;
  justify-content: center;
  min-height: 2.65rem;
  font-size: 0.9375rem;
}
@media (min-width: 520px) {
  .footer-cta-card__form {
    flex-direction: row;
    align-items: stretch;
    max-width: none;
    width: 100%;
  }
  .footer-cta-card__input {
    flex: 1 1 auto;
    min-width: 0;
  }
  .footer-cta-card__submit {
    width: auto;
    min-width: 8.5rem;
    padding-left: 1.25rem;
    padding-right: 1.25rem;
  }
}
@media (min-width: 720px) {
  .footer-cta-card {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 1.75rem;
    padding: 1.65rem 2rem;
    text-align: left;
  }
  .footer-cta-card__desc {
    margin-inline: 0;
  }
  .footer-cta-card__form {
    flex: 0 0 auto;
    width: min(100%, 26rem);
    margin-inline: 0;
  }
}

/* assets/css/src/layout/footer.css */
.site-footer {
  position: relative;
  background: #09090b;
  color: #a1a1aa;
  font-size: 0.9rem;
}
.site-footer__body {
  padding: 2rem 0 1.65rem;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
}
.site-footer__grid {
  display: grid;
  gap: 1.75rem 2rem;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .site-footer__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1024px) {
  .site-footer__grid {
    grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.76fr) minmax(0, 0.62fr) minmax(0, 0.95fr);
    gap: 1.5rem 2.25rem;
    align-items: start;
  }
}
.site-footer__col--brand {
  max-width: 20rem;
}
@media (min-width: 1024px) {
  .site-footer__col--reach {
    max-width: 22rem;
    justify-self: end;
  }
}
.site-footer__lead {
  margin: 1rem 0 0;
  font-size: 0.875rem;
  line-height: 1.55;
  color: #71717a;
}
.site-footer__heading {
  margin: 0 0 0.85rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: #71717a;
}
.site-footer__subheading {
  margin: 1rem 0 0.45rem;
  font-family: var(--font-display);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: #71717a;
}
.site-footer__subheading--section {
  margin-top: 1.25rem;
  margin-bottom: 0.65rem;
}
.site-footer__nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.site-footer__nav-link {
  color: #e4e4e7;
  font-weight: 600;
  font-size: 0.9rem;
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.site-footer__nav-link:hover {
  color: var(--color-accent);
  text-decoration: none;
}
.site-footer__contact-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.site-footer__contact-link {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.55rem;
  color: #e4e4e7;
  font-weight: 500;
  font-size: 0.88rem;
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.site-footer__contact-link:hover {
  color: var(--color-accent);
  text-decoration: none;
}
.site-footer__contact-static {
  display: inline-flex;
  align-items: flex-start;
  gap: 0.55rem;
  color: #a1a1aa;
  font-size: 0.88rem;
  line-height: 1.45;
}
.site-footer__contact-icon {
  flex-shrink: 0;
  margin-top: 0.12rem;
  color: var(--color-accent);
  opacity: 0.85;
}
.site-footer__messengers {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.site-footer__messenger {
  display: inline-flex;
  align-items: center;
  padding: 0.38rem 0.8rem;
  font-size: 0.78rem;
  font-weight: 700;
  color: #fafafa;
  text-decoration: none;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    color 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.site-footer__messenger:hover {
  background: rgba(124, 58, 237, 0.22);
  border-color: rgba(167, 139, 250, 0.32);
  color: #fff;
  text-decoration: none;
}
.site-footer__social-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}
.site-footer__social-btn {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.9rem;
  font-size: 0.8rem;
  font-weight: 700;
  color: #fafafa;
  text-decoration: none;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  transition:
    background 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    color 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.site-footer__social-btn:hover {
  background: rgba(124, 58, 237, 0.25);
  border-color: rgba(167, 139, 250, 0.35);
  color: #fff;
  text-decoration: none;
}
.site-footer__bottom {
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  padding: 1.15rem 0 1.75rem;
  background: rgba(0, 0, 0, 0.25);
}
.site-footer__bottom-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.55rem;
  text-align: center;
}
@media (min-width: 768px) {
  .site-footer__bottom-inner {
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
    gap: 1.25rem;
    text-align: left;
  }
}
.site-footer__copy {
  margin: 0;
  font-size: 0.78rem;
  color: #52525b;
  line-height: 1.5;
}

/* assets/css/src/components/buttons.css */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  padding: 0.65rem 1.35rem;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.01em;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      #8b5cf6 0%,
      var(--color-primary) 45%,
      #5b21b6 100%);
  border: none;
  border-radius: var(--radius-pill);
  cursor: var(--cursor-pointer, pointer);
  text-decoration: none;
  font-family: inherit;
  box-shadow: 0 4px 20px rgba(124, 58, 237, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
  transition: box-shadow 0.25s var(--ease-out), filter 0.25s var(--ease-out);
}
.btn:hover {
  filter: brightness(1.06);
  box-shadow: 0 8px 32px rgba(124, 58, 237, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.12) inset;
  text-decoration: none;
  color: #fff;
}
.btn:active {
  filter: brightness(0.97);
}
.btn:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 3px;
}
.btn--ghost {
  background: rgba(255, 255, 255, 0.06);
  color: var(--color-primary);
  border: 1.5px solid rgba(124, 58, 237, 0.35);
  box-shadow: none;
}
.btn--ghost:hover {
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  border-color: var(--color-primary);
  box-shadow: 0 4px 20px rgba(124, 58, 237, 0.12);
}
.btn--accent {
  background:
    linear-gradient(
      135deg,
      #34d399 0%,
      var(--color-cta) 40%,
      var(--color-cta-dark) 100%);
  box-shadow: 0 4px 22px rgba(16, 185, 129, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
}
.btn--accent:hover {
  box-shadow: 0 8px 32px rgba(16, 185, 129, 0.42), 0 0 0 1px rgba(255, 255, 255, 0.12) inset;
  color: #fff;
}
.hero .btn--ghost {
  border-color: rgba(255, 255, 255, 0.65);
  color: #fff;
}
.hero .btn--ghost:hover {
  background: rgba(255, 255, 255, 0.14);
  color: #fff;
  border-color: #fff;
}
.btn--block {
  width: 100%;
}
.btn--lg {
  padding: 0.9rem 1.6rem;
  font-size: 1rem;
}

/* assets/css/src/components/sections.css */
.main {
  position: relative;
  z-index: 1;
  min-height: 50vh;
}
.section {
  padding: 3.25rem 0;
}
.section--alt {
  background:
    linear-gradient(
      180deg,
      rgba(250, 250, 250, 0.97) 0%,
      rgba(244, 244, 245, 0.99) 100%),
    radial-gradient(
      ellipse 60% 40% at 100% 50%,
      rgba(124, 58, 237, 0.04) 0%,
      transparent 55%);
}
.section--tight {
  padding: 2rem 0;
}
.section-eyebrow {
  margin: 0 0 0.65rem;
  text-align: center;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-accent);
}
.section-title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 4vw, 2.05rem);
  text-align: center;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.section-title__accent {
  background:
    linear-gradient(
      120deg,
      var(--color-primary) 0%,
      #a78bfa 45%,
      var(--color-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.section-title--left {
  text-align: left;
}
.section-lead {
  max-width: 560px;
  margin: 0 auto 2rem;
  text-align: center;
  color: var(--color-muted);
  font-size: 1.02rem;
}

/* assets/css/src/components/hero.css */
.hero {
  position: relative;
  padding: 0;
  overflow: hidden;
  color: #fafafa;
}
.hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse 85% 65% at 12% 25%,
      rgba(124, 58, 237, 0.5) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 65% 55% at 92% 20%,
      rgba(34, 211, 238, 0.2) 0%,
      transparent 52%),
    linear-gradient(
      165deg,
      #030712 0%,
      #0f172a 30%,
      #1e1b4b 60%,
      #0c0a09 100%);
  will-change: transform;
  animation: hero-drift 32s ease-in-out infinite;
}
@keyframes hero-drift {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  33% {
    transform: translate3d(1.5%, -1%, 0) scale(1.04);
  }
  66% {
    transform: translate3d(-1%, 1.5%, 0) scale(0.98);
  }
}
.hero__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.35;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.028) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(255, 255, 255, 0.028) 1px,
      transparent 1px);
  background-size: 56px 56px;
  pointer-events: none;
  mask-image:
    radial-gradient(
      ellipse 80% 80% at 50% 50%,
      #000 45%,
      transparent 100%);
  -webkit-mask-image:
    radial-gradient(
      ellipse 80% 80% at 50% 50%,
      #000 45%,
      transparent 100%);
}
.hero__bg::after {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.28;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/%3E%3C/svg%3E");
  pointer-events: none;
  mix-blend-mode: overlay;
}
.hero__grid {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2.75rem;
  padding: 4.5rem 0 4rem;
  text-align: center;
}
@media (min-width: 900px) {
  .hero__grid {
    min-height: 68vh;
    gap: 3.5rem;
    padding: 6rem 0 5rem;
  }
}
@media (min-width: 1200px) {
  .hero__grid {
    padding: 7rem 0 6rem;
  }
}
.hero__content {
  width: 100%;
  max-width: 840px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.hero__eyebrow {
  margin: 0 0 1.35rem;
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-accent);
}
.hero h1 {
  margin: 0 0 1.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.95rem, 5vw, 3.5rem);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.035em;
  text-wrap: balance;
}
.hero__gradient {
  display: block;
  margin-top: 0.2em;
  background:
    linear-gradient(
      105deg,
      #ddd6fe 0%,
      #a78bfa 42%,
      #5eead4 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.hero__subtitle {
  margin: 0 auto 2.25rem;
  max-width: 58ch;
  font-size: clamp(1.02rem, 1.6vw, 1.2rem);
  font-weight: 500;
  line-height: 1.55;
  color: rgba(250, 250, 250, 0.78);
  text-wrap: pretty;
}
.hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}
@media (max-width: 640px) {
  .hero__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .hero__actions > .btn {
    width: 100%;
  }
}
.hero .btn:not(.btn--ghost) {
  box-shadow: 0 12px 32px rgba(16, 185, 129, 0.28), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
}
.hero__meta {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  margin: 1.35rem 0 0;
  padding: 0;
  font-size: 0.82rem;
  font-weight: 500;
  line-height: 1.4;
  color: rgba(250, 250, 250, 0.7);
}
.hero__meta-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.18rem 0.5rem;
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: #0c0a09;
  background:
    linear-gradient(
      135deg,
      #5eead4 0%,
      #22d3ee 55%,
      #a78bfa 100%);
  border-radius: var(--radius-pill);
  flex-shrink: 0;
}
.hero__meta-text {
  color: rgba(250, 250, 250, 0.78);
}
@keyframes hero-rise {
  from {
    opacity: 0;
    transform: translateY(14px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.hero__eyebrow {
  animation: hero-rise 0.7s var(--ease-out) 0.05s both;
}
.hero h1 {
  animation: hero-rise 0.8s var(--ease-out) 0.18s both;
}
.hero__subtitle {
  animation: hero-rise 0.8s var(--ease-out) 0.32s both;
}
.hero__actions {
  animation: hero-rise 0.8s var(--ease-out) 0.48s both;
}
.hero__meta {
  animation: hero-rise 0.8s var(--ease-out) 0.64s both;
}
.hero__scroll-cue {
  position: absolute;
  bottom: 1.75rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  justify-content: center;
  pointer-events: none;
  opacity: 0;
  animation: hero-rise 0.8s var(--ease-out) 0.9s both;
}
.hero__scroll-cue span {
  display: block;
  width: 1px;
  height: 44px;
  background:
    linear-gradient(
      to bottom,
      rgba(255, 255, 255, 0) 0%,
      rgba(255, 255, 255, 0.7) 100%);
  transform-origin: top center;
  animation: cue-pulse 2.4s ease-in-out infinite;
}
@keyframes cue-pulse {
  0%, 100% {
    opacity: 0.25;
    transform: scaleY(0.65);
  }
  50% {
    opacity: 1;
    transform: scaleY(1);
  }
}
@media (max-width: 899px) {
  .hero__scroll-cue {
    display: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  .hero__bg,
  .hero__eyebrow,
  .hero h1,
  .hero__subtitle,
  .hero__actions,
  .hero__meta,
  .hero__scroll-cue,
  .hero__scroll-cue span {
    animation: none;
  }
  .hero__scroll-cue {
    opacity: 0.55;
  }
}

/* assets/css/src/components/feature-grid.css */
.features-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 600px) {
  .features-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 900px) {
  .features-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.feature-card {
  padding: 1.35rem 1.25rem;
  background: rgba(255, 255, 255, 0.92);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition: box-shadow 0.28s var(--ease-out), border-color 0.28s var(--ease-out);
}
.feature-card:hover {
  box-shadow: var(--shadow-hover), var(--shadow-glow);
  border-color: rgba(124, 58, 237, 0.15);
}
.feature-card__icon {
  width: 52px;
  height: 52px;
  margin-bottom: 0.85rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-primary-soft);
  border-radius: 12px;
}
.feature-card__icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}
.feature-card h3 {
  margin: 0 0 0.45rem;
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 700;
  color: var(--color-text);
}
.feature-card p {
  margin: 0;
  font-size: 0.94rem;
  color: var(--color-muted);
}

/* assets/css/src/components/packages.css */
.packages-grid--prose-top {
  margin-top: 1.5rem;
}
.packages-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .packages-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1000px) {
  .packages-grid {
    grid-template-columns: repeat(4, 1fr);
  }
  .packages-grid--3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.package-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.6rem;
  background: rgba(255, 255, 255, 0.95);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition: box-shadow 0.28s var(--ease-out), border-color 0.28s var(--ease-out);
}
.package-card:hover {
  box-shadow: var(--shadow-hover), 0 0 0 1px rgba(124, 58, 237, 0.06);
  border-color: rgba(124, 58, 237, 0.2);
}
.package-card--featured {
  border-color: transparent;
  background:
    linear-gradient(
      180deg,
      #ffffff 0%,
      #faf5ff 100%) padding-box,
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.75),
      rgba(34, 211, 238, 0.5)) border-box;
  border: 2px solid transparent;
  box-shadow: 0 20px 50px rgba(124, 58, 237, 0.2), 0 0 0 1px rgba(255, 255, 255, 0.55) inset;
}
.package-card__badge {
  position: absolute;
  top: 14px;
  right: 14px;
  padding: 0.25rem 0.6rem;
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #fff;
  background:
    linear-gradient(
      120deg,
      #22d3ee 0%,
      var(--color-primary) 100%);
  border-radius: var(--radius-pill);
  box-shadow: 0 4px 14px rgba(124, 58, 237, 0.35);
}
.package-card h3 {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
}
.package-card__price {
  font-size: 1.45rem;
  font-weight: 800;
  font-family: var(--font-display);
  color: var(--color-primary);
}
.package-card__old {
  font-size: 0.88rem;
  color: var(--color-muted);
  text-decoration: line-through;
}
.package-card ul {
  margin: 1rem 0;
  padding-left: 1.1rem;
  flex: 1;
  font-size: 0.9rem;
  color: var(--color-muted);
}
.package-card p {
  margin: 0 0 1rem;
  font-size: 0.88rem;
  color: var(--color-muted);
}
.package-card .btn {
  box-shadow: 0 4px 18px rgba(124, 58, 237, 0.28);
}

/* assets/css/src/components/stats.css */
.stats-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 768px) {
  .stats-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.stat-item {
  padding: 1.35rem 1rem;
  background: rgba(255, 255, 255, 0.94);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  text-align: center;
  box-shadow: var(--shadow);
}
.stat-item__value {
  font-size: 2rem;
  font-weight: 800;
  font-family: var(--font-display);
  color: var(--color-primary);
  line-height: 1.1;
}
.stat-item__label {
  margin-top: 0.35rem;
  font-size: 0.86rem;
  color: var(--color-muted);
  font-weight: 500;
}

/* assets/css/src/components/stats-bg.css */
.section--stats-band {
  position: relative;
  padding-top: clamp(3rem, 6vw, 4.5rem);
  padding-bottom: clamp(3.5rem, 7vw, 5rem);
  background:
    radial-gradient(
      ellipse 70% 50% at 15% 0%,
      rgba(124, 58, 237, 0.38) 0%,
      transparent 60%),
    radial-gradient(
      ellipse 70% 50% at 85% 100%,
      rgba(34, 211, 238, 0.22) 0%,
      transparent 60%),
    linear-gradient(
      160deg,
      #0b0a1a 0%,
      #1c1a3f 45%,
      #0c0d26 100%);
  color: #e4e4e7;
  overflow: hidden;
  isolation: isolate;
}
.home-stats-section__grid {
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255, 255, 255, 0.08) 1px, transparent 1px);
  background-size: 26px 26px;
  opacity: 0.55;
  mask-image:
    radial-gradient(
      ellipse at center,
      #000 35%,
      transparent 85%);
  -webkit-mask-image:
    radial-gradient(
      ellipse at center,
      #000 35%,
      transparent 85%);
  pointer-events: none;
  z-index: 0;
}
.home-stats-section__inner {
  position: relative;
  z-index: 1;
}
.home-stats-section__head {
  text-align: center;
  margin-bottom: clamp(1.75rem, 3vw, 2.5rem);
}
.home-stats-section__eyebrow {
  color: #67e8f9;
}
.section--stats-band .section-title {
  color: #f5f3ff;
}
.section--stats-band .section-title .section-title__accent {
  background:
    linear-gradient(
      120deg,
      #a78bfa 0%,
      #c4b5fd 50%,
      #67e8f9 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.home-stats-section__lead {
  max-width: 640px;
  color: rgba(226, 232, 240, 0.78);
}
.home-stats-grid {
  display: grid;
  gap: clamp(0.85rem, 1.8vw, 1.25rem);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (min-width: 900px) {
  .home-stats-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}
.home-stat {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.5rem 1.35rem 1.45rem;
  border-radius: clamp(var(--radius-lg), 1.8vw, 22px);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.06) 0%,
      rgba(255, 255, 255, 0.02) 100%);
  border: 1px solid rgba(255, 255, 255, 0.10);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  overflow: hidden;
  transition:
    transform 0.35s var(--ease-out),
    border-color 0.35s var(--ease-out),
    box-shadow 0.35s var(--ease-out);
}
.home-stat::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(167, 139, 250, 0.55),
      rgba(34, 211, 238, 0.5));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  opacity: 0;
  transition: opacity 0.35s var(--ease-out);
  pointer-events: none;
}
.home-stat:hover {
  transform: translateY(-3px);
  border-color: rgba(167, 139, 250, 0.3);
  box-shadow: 0 22px 48px -28px rgba(124, 58, 237, 0.65);
}
.home-stat:hover::before {
  opacity: 1;
}
.home-stat__figure {
  display: inline-flex;
  align-items: baseline;
  gap: 0.1rem;
  font-family: var(--font-display);
  font-variant-numeric: tabular-nums;
  line-height: 1;
}
.home-stat__value {
  font-size: clamp(2.25rem, 5vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  background:
    linear-gradient(
      180deg,
      #fafafa 0%,
      #c4b5fd 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 0 40px rgba(167, 139, 250, 0.18);
}
.home-stat__suffix {
  font-size: clamp(1.25rem, 2.4vw, 1.55rem);
  font-weight: 700;
  color: #67e8f9;
  margin-left: 0.1rem;
}
.home-stat__label {
  margin: 0.85rem 0 0.35rem;
  font-family: var(--font-display);
  font-size: 0.98rem;
  font-weight: 700;
  letter-spacing: -0.005em;
  color: #f8fafc;
}
.home-stat__caption {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.5;
  color: rgba(226, 232, 240, 0.72);
}
@media (prefers-reduced-motion: reduce) {
  .home-stat,
  .home-stat::before {
    transition: none;
  }
  .home-stat:hover {
    transform: none;
  }
}

/* assets/css/src/components/directions.css */
.directions-grid {
  display: grid;
  gap: 1.1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .directions-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
.direction-card {
  display: flex;
  gap: 1rem;
  align-items: flex-start;
  padding: 1.35rem 1.25rem;
  background: rgba(255, 255, 255, 0.94);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition: box-shadow 0.28s var(--ease-out), border-color 0.28s var(--ease-out);
}
.direction-card:hover {
  box-shadow: var(--shadow-hover);
  border-color: rgba(34, 211, 238, 0.2);
}
.direction-card__icon {
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(
      145deg,
      var(--color-accent-soft) 0%,
      var(--color-primary-soft) 100%);
  border-radius: 14px;
  border: 1px solid rgba(124, 58, 237, 0.08);
}
.direction-card__icon svg {
  color: var(--color-primary-dark);
}
.direction-card__icon img {
  width: 30px;
  height: 30px;
  object-fit: contain;
}
.direction-card__body h3 {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
}
.direction-card__body p {
  margin: 0;
  font-size: 0.92rem;
  color: var(--color-muted);
}
a.direction-card--link {
  text-decoration: none;
  color: inherit;
  height: 100%;
  box-sizing: border-box;
}
a.direction-card--link:hover {
  border-color: rgba(124, 58, 237, 0.22);
}
.direction-card__cta {
  display: inline-block;
  margin-top: 0.75rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-primary);
}
@media (min-width: 900px) {
  .directions-grid--dense {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

/* assets/css/src/components/cta-inline.css */
.section--cta-inline {
  padding: 2.5rem 0;
}
.cta-inline {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.25rem;
  padding: 2rem 1.5rem;
  text-align: center;
  background:
    linear-gradient(
      125deg,
      #5b21b6 0%,
      #7c3aed 38%,
      #4c1d95 100%);
  background-size: cover;
  background-position: center;
  border-radius: var(--radius-lg);
  color: #fff;
  box-shadow: 0 20px 50px rgba(91, 33, 182, 0.35), 0 0 0 1px rgba(255, 255, 255, 0.08) inset;
}
.cta-inline--consult-bg {
  position: relative;
  overflow: hidden;
  background-image:
    linear-gradient(
      115deg,
      rgba(9, 9, 11, 0.88) 0%,
      rgba(91, 33, 182, 0.82) 55%,
      rgba(34, 211, 238, 0.15) 100%),
    var(--cta-bg);
  background-size: cover;
  background-position: center;
}
.cta-inline--mesh {
  position: relative;
  overflow: hidden;
  background-image:
    radial-gradient(
      ellipse 90% 80% at 90% 20%,
      rgba(34, 211, 238, 0.18) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 70% 60% at 10% 80%,
      rgba(124, 58, 237, 0.35) 0%,
      transparent 45%),
    linear-gradient(
      125deg,
      #4c1d95 0%,
      #7c3aed 40%,
      #312e81 100%);
}
@media (min-width: 720px) {
  .cta-inline {
    flex-direction: row;
    justify-content: space-between;
    text-align: left;
    padding: 2rem 2.5rem;
  }
}
.cta-inline__title {
  margin: 0 0 0.35rem;
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 3vw, 1.6rem);
  font-weight: 700;
}
.cta-inline__lead {
  margin: 0;
  opacity: 0.92;
  font-size: 1rem;
}
.cta-inline .btn {
  background: #fff;
  color: var(--color-primary-dark);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  flex-shrink: 0;
}
.cta-inline .btn:hover {
  background: var(--color-accent);
  color: var(--color-ink);
  filter: none;
}

/* assets/css/src/components/cta-section.css */
.section__actions {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 1.25rem;
}
@media (max-width: 640px) {
  .section__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .section__actions > .btn {
    width: 100%;
  }
}
.btn--compact {
  padding: 0.5rem 1rem;
  font-size: 0.85rem;
}

/* assets/css/src/components/cta-pages.css */
.cta-block {
  text-align: center;
  max-width: 560px;
  margin: 0 auto;
}
.cta-block--inline {
  margin-top: 2.5rem;
  padding: 1.75rem 1.25rem;
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.cta-block__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
}
.cta-block__text {
  margin: 0 0 1rem;
  color: var(--color-muted);
}

/* assets/css/src/components/two-columns.css */
.content-columns {
  display: grid;
  gap: 2rem;
  align-items: start;
}
@media (min-width: 900px) {
  .content-columns {
    grid-template-columns: 1fr 1fr;
  }
}
.prose {
  max-width: 720px;
}
.prose--narrow {
  max-width: 640px;
  margin-inline: auto;
}
.prose--card {
  padding: 1.5rem 1.75rem;
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.prose h2 {
  margin-top: 0;
  margin-bottom: 0.75rem;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 700;
}
.prose h3 {
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
  font-size: 1.1rem;
  font-weight: 700;
}
.prose p,
.prose li {
  color: var(--color-muted);
}
.prose ul {
  padding-left: 1.2rem;
}

/* assets/css/src/components/page-hero.css */
.page-hero {
  position: relative;
  padding: 3rem 0 2.75rem;
  text-align: center;
  border-bottom: 1px solid var(--color-border);
  background:
    radial-gradient(
      ellipse 100% 120% at 80% -40%,
      rgba(124, 58, 237, 0.1) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 80% 100% at 0% 100%,
      rgba(34, 211, 238, 0.06) 0%,
      transparent 50%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--compact {
  padding: 2.25rem 0 2rem;
}
.page-hero--quiz {
  padding: 2.75rem 0 2.5rem;
  background:
    radial-gradient(
      ellipse 90% 80% at 50% -30%,
      rgba(124, 58, 237, 0.14) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 70% 50% at 100% 80%,
      rgba(34, 211, 238, 0.1) 0%,
      transparent 45%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero__gradient {
  background:
    linear-gradient(
      105deg,
      var(--color-primary) 0%,
      #8b5cf6 45%,
      var(--color-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.quiz-hero-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
  margin-bottom: 1rem;
}
.quiz-hero-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.35rem 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow);
}
.quiz-hero-badge--accent {
  color: var(--color-primary-dark);
  border-color: rgba(124, 58, 237, 0.25);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.08) 100%);
}
.page-hero--portfolio {
  padding: 2.85rem 0 2.5rem;
  background:
    radial-gradient(
      ellipse 85% 70% at 20% -25%,
      rgba(34, 211, 238, 0.11) 0%,
      transparent 52%),
    radial-gradient(
      ellipse 70% 55% at 100% 0%,
      rgba(124, 58, 237, 0.12) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--about {
  padding: 2.85rem 0 2.5rem;
  background:
    radial-gradient(
      ellipse 75% 65% at 85% -20%,
      rgba(124, 58, 237, 0.13) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 65% 55% at 0% 100%,
      rgba(34, 211, 238, 0.09) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--contact {
  padding: 2.85rem 0 2.5rem;
  background:
    radial-gradient(
      ellipse 80% 70% at 50% -30%,
      rgba(34, 211, 238, 0.12) 0%,
      transparent 52%),
    radial-gradient(
      ellipse 60% 50% at 0% 90%,
      rgba(124, 58, 237, 0.1) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service {
  padding: 2.85rem 0 2.5rem;
}
.page-hero--service-landing {
  background:
    radial-gradient(
      ellipse 75% 65% at 100% -15%,
      rgba(124, 58, 237, 0.13) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 60% 55% at 0% 100%,
      rgba(34, 211, 238, 0.09) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-quiz {
  background:
    radial-gradient(
      ellipse 70% 60% at 15% -20%,
      rgba(34, 211, 238, 0.14) 0%,
      transparent 52%),
    radial-gradient(
      ellipse 65% 55% at 95% 80%,
      rgba(124, 58, 237, 0.11) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-shop {
  background:
    radial-gradient(
      ellipse 80% 70% at 50% -25%,
      rgba(16, 185, 129, 0.08) 0%,
      transparent 48%),
    radial-gradient(
      ellipse 55% 50% at 100% 50%,
      rgba(124, 58, 237, 0.12) 0%,
      transparent 50%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-promo {
  background:
    radial-gradient(
      ellipse 70% 60% at 20% -15%,
      rgba(124, 58, 237, 0.14) 0%,
      transparent 52%),
    radial-gradient(
      ellipse 55% 50% at 100% 100%,
      rgba(34, 211, 238, 0.1) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-seo {
  background:
    radial-gradient(
      ellipse 75% 65% at 85% -20%,
      rgba(16, 185, 129, 0.12) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 50% 55% at 0% 90%,
      rgba(124, 58, 237, 0.09) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-ads {
  background:
    radial-gradient(
      ellipse 65% 55% at 50% -25%,
      rgba(34, 211, 238, 0.14) 0%,
      transparent 52%),
    radial-gradient(
      ellipse 60% 50% at 0% 50%,
      rgba(124, 58, 237, 0.11) 0%,
      transparent 50%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-crm {
  background:
    radial-gradient(
      ellipse 70% 60% at 100% 0%,
      rgba(49, 46, 129, 0.14) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 55% 50% at 15% 100%,
      rgba(34, 211, 238, 0.08) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero--service-telegram-bots {
  background:
    radial-gradient(
      ellipse 70% 60% at 100% -15%,
      rgba(14, 165, 233, 0.14) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 55% 50% at 0% 100%,
      rgba(99, 102, 241, 0.12) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.page-hero__kicker {
  margin: 0 0 0.65rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.2em;
  color: var(--color-primary);
  opacity: 0.95;
}
.page-hero h1 {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.55rem, 4vw, 2.2rem);
  font-weight: 700;
  letter-spacing: -0.03em;
  color: var(--color-text);
  line-height: 1.15;
}
.page-hero__lead {
  margin: 0.85rem auto 0;
  max-width: 38rem;
  font-size: 1.02rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.page-hero .section-lead {
  margin-top: 0.85rem;
  margin-bottom: 0;
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
  color: var(--color-muted);
}
.page-hero__actions {
  margin-top: 1.35rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  justify-content: center;
}
@media (max-width: 640px) {
  .page-hero__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .page-hero__actions > .btn {
    width: 100%;
  }
}
.page-hero--error h1 {
  font-size: clamp(1.45rem, 3.5vw, 1.95rem);
}

/* assets/css/src/components/faq.css */
.faq-list {
  max-width: 800px;
  margin: 0 auto;
}
.faq-item {
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  margin-bottom: 0.5rem;
  overflow: hidden;
  background: #fff;
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.faq-item summary {
  padding: 1rem 1.25rem;
  cursor: var(--cursor-pointer, pointer);
  font-weight: 600;
  list-style: none;
  font-family: var(--font-display);
}
.faq-item summary:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.faq-item summary::-webkit-details-marker {
  display: none;
}
.faq-item[open] {
  border-color: rgba(124, 58, 237, 0.22);
  box-shadow: 0 8px 26px rgba(124, 58, 237, 0.07);
}
.faq-item[open] summary {
  border-bottom: 1px solid var(--color-border);
  color: var(--color-primary);
}
.faq-item p {
  margin: 0;
  padding: 1rem 1.25rem;
  font-size: 0.95rem;
  color: var(--color-muted);
}
.faq-section__lead {
  margin-bottom: 1.75rem;
}
.faq-shell {
  max-width: 56rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
}
.faq-shell .faq-list {
  max-width: none;
  margin: 0;
}

/* assets/css/src/components/prose.css */
.service-prose-shell--wide .prose {
  max-width: none;
}
.service-prose.prose h2:first-child {
  margin-top: 0;
}
.service-showcase-section {
  position: relative;
  padding-top: 0.25rem;
  padding-bottom: 2.5rem;
}
.service-showcase-section::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 45% 60% at 80% 0%,
      rgba(124, 58, 237, 0.05) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 40% 50% at 10% 100%,
      rgba(34, 211, 238, 0.05) 0%,
      transparent 45%);
  z-index: 0;
}
.service-showcase-section .container {
  position: relative;
  z-index: 1;
}
.service-showcase-section .section-title {
  text-align: center;
}
.service-showcase-section .section-lead {
  text-align: center;
  max-width: 40rem;
  margin-left: auto;
  margin-right: auto;
}
.service-showcase__note {
  margin: 1rem auto 0;
  max-width: 36rem;
  text-align: center;
  font-size: 0.78rem;
  color: var(--color-muted);
  opacity: 0.9;
}
.service-showcase__note code {
  font-size: 0.85em;
}
.service-packages-section {
  position: relative;
}
.service-packages-section .section-title {
  text-align: center;
}
.service-packages-section .section-lead {
  text-align: center;
  max-width: 36rem;
  margin-left: auto;
  margin-right: auto;
}
.service-packages-shell {
  margin-top: 0.5rem;
  padding: clamp(1.25rem, 2.5vw, 1.75rem);
  border-radius: clamp(var(--radius-lg), 2vw, 26px);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.5) 0%,
      rgba(244, 244, 245, 0.35) 100%);
  border: 1px solid rgba(124, 58, 237, 0.08);
}
.service-feature-section .section-title {
  text-align: center;
}
.service-feature-section .section-lead {
  text-align: center;
  max-width: 38rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.75rem;
}
.service-feature-grid {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
}
@media (min-width: 560px) {
  .service-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 900px) {
  .service-feature-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.service-feature-card {
  padding: 1.15rem 1.2rem 1.25rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      155deg,
      rgba(255, 255, 255, 0.96) 0%,
      #fafafa 100%);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition:
    border-color 0.3s var(--ease-out),
    box-shadow 0.3s var(--ease-out),
    transform 0.3s var(--ease-out);
}
.service-feature-card:hover {
  border-color: rgba(124, 58, 237, 0.2);
  box-shadow: var(--shadow-hover);
  transform: translateY(-2px);
}
@media (prefers-reduced-motion: reduce) {
  .service-feature-card:hover {
    transform: none;
  }
}
.service-feature-card__tag {
  display: inline-block;
  margin-bottom: 0.45rem;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.service-feature-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.02rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-text);
}
.service-cta-band {
  position: relative;
  margin-top: 0.5rem;
  padding: clamp(1.75rem, 3.8vw, 2.65rem) clamp(1.25rem, 3.2vw, 2.25rem);
  text-align: center;
  border-radius: clamp(var(--radius-lg), 2vw, 28px);
  overflow: hidden;
  isolation: isolate;
  background:
    radial-gradient(
      ellipse 60% 80% at 12% 0%,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 60% 80% at 92% 100%,
      rgba(34, 211, 238, 0.16) 0%,
      transparent 55%),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.95) 0%,
      rgba(248, 248, 252, 0.98) 100%);
  border: 1px solid rgba(124, 58, 237, 0.14);
  box-shadow:
    0 20px 56px -28px rgba(124, 58, 237, 0.32),
    0 10px 28px -18px rgba(9, 9, 11, 0.15),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
.service-cta-band::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background:
    linear-gradient(
      90deg,
      #7c3aed 0%,
      #22d3ee 100%);
  opacity: 0.85;
  pointer-events: none;
  z-index: 1;
}
.service-cta-band::after {
  content: "";
  position: absolute;
  z-index: 0;
  pointer-events: none;
  top: -35%;
  right: -18%;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 65%);
  filter: blur(28px);
}
.service-cta-band > * {
  position: relative;
  z-index: 1;
}
.service-cta-band__mark {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.32rem 0.85rem;
  margin-bottom: 1rem;
  border-radius: 999px;
  background:
    linear-gradient(
      120deg,
      rgba(124, 58, 237, 0.12),
      rgba(34, 211, 238, 0.1));
  border: 1px solid rgba(124, 58, 237, 0.2);
  color: var(--color-text);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.service-cta-band__mark::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      #7c3aed,
      #22d3ee);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.18);
}
.service-cta-band .section-title {
  margin-bottom: 0.7rem;
  font-size: clamp(1.35rem, 2.8vw, 1.8rem);
  line-height: 1.18;
  letter-spacing: -0.02em;
}
.service-cta-band .section-lead {
  margin: 0 auto 1.25rem;
  max-width: 34rem;
  color: var(--color-muted);
  font-size: clamp(0.96rem, 1.3vw, 1.05rem);
  line-height: 1.55;
}
.service-cta-band .section__actions {
  margin-top: 0;
  justify-content: center;
  gap: 0.85rem;
  flex-wrap: wrap;
}

/* assets/css/src/components/legacy-cards.css */
.contact-cards {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .contact-cards {
    grid-template-columns: repeat(2, 1fr);
  }
}
.contact-card {
  padding: 1.5rem;
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition: box-shadow 0.25s ease, border-color 0.25s ease;
}
.contact-card:hover {
  border-color: rgba(124, 58, 237, 0.25);
  box-shadow: var(--shadow-hover);
}
.contact-card h3 {
  margin: 0 0 0.75rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  font-weight: 700;
}
.contact-card p,
.contact-card a {
  margin: 0;
  font-size: 1rem;
}
.contact-card__note {
  margin-top: 0.5rem;
  font-size: 0.9rem;
  color: var(--color-muted);
}

/* assets/css/src/components/quiz-wizard.css */
.quiz-page {
  position: relative;
  padding-top: 0.5rem;
  padding-bottom: 4rem;
  overflow: hidden;
}
.quiz-page::before {
  content: "";
  position: absolute;
  inset: -20% -10% auto;
  height: min(70vh, 520px);
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 60% 70% at 15% 20%,
      rgba(124, 58, 237, 0.11) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 50% 60% at 90% 30%,
      rgba(34, 211, 238, 0.09) 0%,
      transparent 50%);
  z-index: 0;
}
.quiz-page__inner {
  position: relative;
  z-index: 1;
}
.quiz-wizard {
  max-width: 920px;
  margin: 0 auto;
  padding: clamp(1.25rem, 3vw, 2rem);
  border-radius: clamp(var(--radius-lg), 2vw, 28px);
  background:
    linear-gradient(
      155deg,
      rgba(255, 255, 255, 0.92) 0%,
      rgba(250, 250, 250, 0.98) 50%,
      rgba(255, 255, 255, 0.9) 100%);
  border: 1px solid rgba(255, 255, 255, 0.65);
  box-shadow:
    var(--shadow-glow),
    0 24px 64px rgba(9, 9, 11, 0.08),
    0 0 0 1px rgba(124, 58, 237, 0.06) inset;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
.quiz-wizard__head {
  margin-bottom: 1.5rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--color-border);
}
.quiz-wizard__head-row {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 1rem;
  margin-bottom: 0.75rem;
}
.quiz-wizard__estimate {
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
  opacity: 0.85;
}
.quiz-progress-bar {
  height: 6px;
  border-radius: var(--radius-pill);
  background: var(--color-bg-alt);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(9, 9, 11, 0.06);
}
.quiz-progress-bar__fill {
  height: 100%;
  border-radius: inherit;
  background:
    linear-gradient(
      90deg,
      var(--color-primary) 0%,
      #a78bfa 42%,
      var(--color-accent) 100%);
  box-shadow: 0 0 20px rgba(124, 58, 237, 0.35);
  transition: width 0.45s var(--ease-out);
}
@media (prefers-reduced-motion: reduce) {
  .quiz-progress-bar__fill {
    transition: none;
  }
}
.quiz-progress {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.quiz-tracker {
  display: none;
  list-style: none;
  margin: 1.15rem 0 0;
  padding: 0;
  gap: 0.35rem;
  grid-template-columns: repeat(6, minmax(0, 1fr));
}
@media (min-width: 720px) {
  .quiz-tracker {
    display: grid;
  }
}
.quiz-tracker__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 0.4rem;
  padding: 0.5rem 0.25rem;
  border-radius: var(--radius);
  transition: background 0.2s var(--ease-out), opacity 0.2s var(--ease-out);
  opacity: 0.45;
}
.quiz-tracker__item.is-active {
  opacity: 1;
  background: var(--color-primary-soft);
}
.quiz-tracker__item.is-done {
  opacity: 1;
}
.quiz-tracker.is-complete .quiz-tracker__item {
  opacity: 1;
}
.quiz-tracker__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--color-bg-alt);
  border: 2px solid var(--color-border);
  transition:
    border-color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out);
}
.quiz-tracker__item.is-active .quiz-tracker__dot {
  border-color: var(--color-primary);
  background: #fff;
  box-shadow: 0 0 0 4px var(--color-primary-soft);
}
.quiz-tracker__item.is-done .quiz-tracker__dot {
  border-color: var(--color-cta);
  background: var(--color-cta);
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.25);
}
.quiz-tracker.is-complete .quiz-tracker__dot {
  border-color: var(--color-cta);
  background: var(--color-cta);
}
.quiz-tracker__text {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}
.quiz-tracker__label {
  font-size: 0.65rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text);
  line-height: 1.2;
}
.quiz-tracker__hint {
  font-size: 0.62rem;
  color: var(--color-muted);
  line-height: 1.2;
  display: none;
}
@media (min-width: 900px) {
  .quiz-tracker__hint {
    display: block;
  }
}
.quiz-wizard__body {
  min-height: 12rem;
}
.quiz-step {
  display: none;
  animation: quiz-step-in 0.4s var(--ease-out) both;
}
.quiz-step.is-active {
  display: block;
}
@keyframes quiz-step-in {
  from {
    opacity: 0;
    transform: translateY(8px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
@media (prefers-reduced-motion: reduce) {
  .quiz-step {
    animation: none;
  }
}
.quiz-step__eyebrow {
  margin: 0 0 0.35rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.quiz-step__title {
  margin: 0 0 0.5rem;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.8vw, 1.55rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  color: var(--color-text);
}
.quiz-step__title--success {
  margin-bottom: 0.65rem;
}
.quiz-step__lead {
  margin: 0 0 1.25rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
  max-width: 42rem;
}
.quiz-step__hint {
  margin: 0 0 1.25rem;
  font-size: 0.95rem;
  line-height: 1.6;
  color: var(--color-muted);
  text-align: left;
}
.quiz-step__hint strong {
  color: var(--color-primary-dark);
  font-weight: 700;
}
.quiz-options {
  display: grid;
  gap: 0.65rem;
  margin: 0;
  grid-template-columns: 1fr;
}
@media (min-width: 560px) {
  .quiz-options:not(.quiz-options--vertical) {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .quiz-options--vertical {
    display: block;
    column-count: 2;
    column-gap: 0.65rem;
  }
  .quiz-options--vertical > .quiz-option {
    break-inside: avoid;
    margin-bottom: 0.65rem;
  }
  .quiz-options--vertical > .quiz-option:last-child {
    margin-bottom: 0;
  }
}
.quiz-option {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0.85rem;
  margin: 0;
  padding: 1rem 1.1rem;
  min-height: 3.25rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  cursor: var(--cursor-pointer, pointer);
  background: rgba(255, 255, 255, 0.65);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8) inset;
  transition:
    border-color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}
.quiz-option:hover {
  border-color: rgba(124, 58, 237, 0.35);
  background: #fff;
  box-shadow: var(--shadow);
}
.quiz-option:has(input:focus-visible) {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.quiz-option:has(input:checked) {
  border-color: var(--color-primary);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.06) 100%);
  box-shadow: var(--shadow-glow);
  transform: translateY(-1px);
}
.quiz-option input {
  position: absolute;
  opacity: 0;
  width: 1px;
  height: 1px;
  margin: 0;
  clip: rect(0, 0, 0, 0);
}
.quiz-option__box {
  flex-shrink: 0;
  width: 1.15rem;
  height: 1.15rem;
  margin-top: 0.12rem;
  border-radius: 50%;
  border: 2px solid var(--color-border);
  background: #fff;
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
  box-shadow: inset 0 1px 2px rgba(9, 9, 11, 0.04);
}
.quiz-option:hover .quiz-option__box {
  border-color: rgba(124, 58, 237, 0.45);
}
.quiz-option:has(input:checked) .quiz-option__box {
  border-color: var(--color-primary);
  background:
    radial-gradient(
      circle at 30% 30%,
      var(--color-accent) 0%,
      var(--color-primary) 65%);
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.quiz-option__text {
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-text);
}
.quiz-final-card {
  padding: 1.35rem 1.25rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      160deg,
      rgba(255, 255, 255, 0.95) 0%,
      var(--color-primary-soft) 120%);
  border: 1px solid rgba(124, 58, 237, 0.12);
  box-shadow: var(--shadow);
}
.quiz-discount {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.95rem;
  margin: 0 0 1rem;
  padding: 0.85rem 1.05rem 0.85rem 0.85rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.08) 0%,
      rgba(168, 85, 247, 0.04) 100%),
    #fff;
  border: 1px solid rgba(124, 58, 237, 0.18);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.6) inset, 0 6px 18px -10px rgba(124, 58, 237, 0.35);
  overflow: hidden;
}
.quiz-discount::before {
  content: "";
  position: absolute;
  inset: -40% -20% auto auto;
  width: 180px;
  height: 180px;
  background:
    radial-gradient(
      closest-side,
      rgba(168, 85, 247, 0.22),
      transparent 70%);
  pointer-events: none;
  filter: blur(2px);
}
.quiz-discount__badge {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  border-radius: 50%;
  background:
    linear-gradient(
      140deg,
      var(--color-primary) 0%,
      #a855f7 60%,
      #ec4899 100%);
  color: #fff;
  box-shadow: 0 8px 22px -8px rgba(124, 58, 237, 0.55), 0 0 0 4px rgba(124, 58, 237, 0.08);
}
.quiz-discount__badge::after {
  content: "";
  position: absolute;
  inset: 4px;
  border-radius: 50%;
  border: 1px dashed rgba(255, 255, 255, 0.45);
  pointer-events: none;
}
.quiz-discount__badge-value {
  position: relative;
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: 0.01em;
  line-height: 1;
}
.quiz-discount__body {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.quiz-discount__title {
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.3;
  color: var(--color-primary-dark);
}
.quiz-discount__note {
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--color-muted);
}
@media (prefers-reduced-motion: no-preference) {
  .quiz-discount__badge {
    animation: quizDiscountPulse 2.8s ease-in-out infinite;
  }
}
@keyframes quizDiscountPulse {
  0%, 100% {
    box-shadow: 0 8px 22px -8px rgba(124, 58, 237, 0.55), 0 0 0 4px rgba(124, 58, 237, 0.08);
  }
  50% {
    box-shadow: 0 10px 26px -6px rgba(124, 58, 237, 0.65), 0 0 0 8px rgba(124, 58, 237, 0.12);
  }
}
.quiz-final-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
  align-items: start;
}
.quiz-final-grid:has(> .quiz-summary[hidden]) {
  grid-template-columns: 1fr;
}
@media (min-width: 760px) {
  .quiz-final-grid {
    grid-template-columns: minmax(0, 0.7fr) minmax(0, 1.3fr);
    gap: 1rem;
  }
  .quiz-final-grid:has(> .quiz-summary[hidden]) {
    grid-template-columns: minmax(0, 1fr);
  }
}
.quiz-summary {
  margin: 0;
  padding: 0.7rem 0.8rem;
  border-radius: var(--radius);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.85) 0%,
      rgba(255, 255, 255, 0.6) 100%);
  border: 1px solid rgba(124, 58, 237, 0.16);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset;
}
@media (min-width: 760px) {
  .quiz-summary {
    position: sticky;
    top: 1rem;
  }
}
.quiz-summary__label {
  margin: 0 0 0.5rem;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
}
.quiz-summary__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.quiz-summary__item {
  display: grid;
  grid-template-columns: 16px minmax(0, 1fr);
  gap: 0.45rem;
  align-items: center;
  padding: 0.32rem 0.45rem;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(124, 58, 237, 0.1);
  transition: border-color 0.2s var(--ease-out), background 0.2s var(--ease-out);
}
.quiz-summary__item:hover {
  border-color: rgba(124, 58, 237, 0.22);
  background: #fff;
}
.quiz-summary__check {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background:
    linear-gradient(
      140deg,
      var(--color-primary) 0%,
      #a855f7 100%);
  color: #fff;
  box-shadow: 0 2px 6px -2px rgba(124, 58, 237, 0.5);
}
.quiz-summary__check svg {
  width: 9px;
  height: 9px;
  display: block;
}
.quiz-summary__text {
  display: flex;
  flex-direction: column;
  gap: 0;
  min-width: 0;
  line-height: 1.2;
}
.quiz-summary__step {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.quiz-summary__value {
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.25;
  color: var(--color-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.quiz-final-form {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  margin-top: 0.25rem;
}
.quiz-field {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.quiz-field__label {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-text);
}
.quiz-field__req {
  color: #ef4444;
  font-weight: 700;
}
.quiz-field__control {
  position: relative;
  display: block;
}
.quiz-field__icon {
  position: absolute;
  left: 0.85rem;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  color: var(--color-muted);
  pointer-events: none;
  transition: color 0.2s var(--ease-out);
  z-index: 1;
}
.quiz-field__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.quiz-field__input {
  width: 100%;
  padding: 0.78rem 0.85rem 0.78rem 2.55rem;
  font: inherit;
  font-size: 0.95rem;
  color: var(--color-text);
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  transition:
    border-color 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out),
    background 0.2s var(--ease-out);
}
.quiz-field__input::placeholder {
  color: var(--color-muted);
  opacity: 0.7;
}
.quiz-field__input:hover {
  border-color: rgba(124, 58, 237, 0.32);
}
.quiz-field__input:focus {
  outline: none;
  border-color: var(--color-primary);
  background: #fff;
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.iti .quiz-field__input {
  padding-left: 52px;
}
.quiz-field__control:has(.quiz-field__input:focus) .quiz-field__icon {
  color: var(--color-primary);
}
.quiz-field__control .iti {
  display: block;
  width: 100%;
}
.quiz-final-form__submit {
  margin-top: 0.35rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
}
.quiz-final-form__submit-arrow {
  width: 16px;
  height: 16px;
  transition: transform 0.2s var(--ease-out);
}
.quiz-final-form__submit:hover .quiz-final-form__submit-arrow {
  transform: translateX(3px);
}
@media (prefers-reduced-motion: reduce) {
  .quiz-final-form__submit:hover .quiz-final-form__submit-arrow {
    transform: none;
  }
}
.quiz-final-trust {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  margin: 0.25rem 0 0;
  padding: 0.25rem 0;
  font-size: 0.78rem;
  line-height: 1.45;
  color: var(--color-muted);
}
.quiz-final-trust svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: #10b981;
}
.quiz-step__error {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
  margin-top: 1rem;
  padding: 0.7rem 0.9rem;
  border-radius: var(--radius);
  background:
    linear-gradient(
      180deg,
      rgba(254, 242, 242, 0.95) 0%,
      rgba(255, 255, 255, 0.95) 100%);
  border: 1px solid rgba(239, 68, 68, 0.32);
  color: #b91c1c;
  font-size: 0.88rem;
  line-height: 1.4;
  font-weight: 500;
  box-shadow: 0 6px 16px -10px rgba(239, 68, 68, 0.45);
}
.quiz-step__error[hidden] {
  display: none;
}
.quiz-step__error-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  color: #ef4444;
  margin-top: 1px;
}
.quiz-step__error-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.quiz-step__error-text {
  min-width: 0;
}
.quiz-step__error.is-shaking {
  animation: quizErrorShake 0.45s cubic-bezier(0.36, 0.07, 0.19, 0.97) both;
}
@keyframes quizErrorShake {
  10%, 90% {
    transform: translateX(-1px);
  }
  20%, 80% {
    transform: translateX(2px);
  }
  30%, 50%, 70% {
    transform: translateX(-4px);
  }
  40%, 60% {
    transform: translateX(4px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .quiz-step__error.is-shaking {
    animation: none;
  }
}
.quiz-field__input.is-invalid {
  border-color: #ef4444;
  background: #fff5f5;
}
.quiz-field__input.is-invalid:focus {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239, 68, 68, 0.18);
}
.quiz-options.is-invalid > .quiz-option {
  border-color: rgba(239, 68, 68, 0.45);
}
.quiz-step--success .quiz-step__title {
  text-align: center;
}
.quiz-success {
  text-align: center;
  padding: 1rem 0 0.5rem;
  max-width: 26rem;
  margin: 0 auto;
}
.quiz-success__icon {
  display: flex;
  justify-content: center;
  margin-bottom: 0.75rem;
  color: var(--color-cta);
}
.quiz-success__text {
  margin: 0 0 1.5rem;
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-muted);
}
.quiz-success__actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  align-items: stretch;
  width: 100%;
  max-width: 22rem;
  margin-inline: auto;
}
.quiz-success__actions > .btn {
  width: 100%;
}
@media (min-width: 641px) {
  .quiz-success__actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    width: auto;
    max-width: none;
    margin-inline: 0;
  }
  .quiz-success__actions > .btn {
    width: auto;
  }
}
.quiz-nav {
  display: flex;
  gap: 0.65rem;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  margin-top: 1.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--color-border);
}
.quiz-nav__back {
  margin-right: auto;
}
.quiz-nav__next {
  min-width: 8.5rem;
}

/* assets/css/src/components/modal.css */
.modal[hidden] {
  display: none !important;
}
.modal {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.modal__backdrop {
  position: absolute;
  inset: 0;
  cursor: var(--cursor-pointer, pointer);
  background: rgba(9, 9, 11, 0.65);
  backdrop-filter: blur(10px) saturate(1.1);
  transition: opacity 0.25s var(--ease-out);
}
.modal--consult .modal__dialog {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  width: min(100%, 920px);
  max-height: min(92vh, 900px);
  overflow: hidden;
  padding: 0;
  border-radius: var(--radius-lg);
  background: #fff;
  border: 1px solid rgba(9, 9, 11, 0.08);
  box-shadow:
    0 32px 100px rgba(9, 9, 11, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.04) inset,
    0 0 60px rgba(124, 58, 237, 0.08);
}
.modal--consult .modal__body {
  flex: 1 1 auto;
  min-height: 0;
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}
.modal__accent {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
  height: 4px;
  border-radius: var(--radius-lg) var(--radius-lg) 0 0;
  background:
    linear-gradient(
      90deg,
      #7c3aed 0%,
      #a78bfa 45%,
      #22d3ee 100%);
  pointer-events: none;
}
.modal__layout {
  display: grid;
  grid-template-columns: 1fr;
  min-height: min-content;
}
@media (min-width: 768px) {
  .modal__layout {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.1fr);
    align-items: stretch;
  }
}
.modal__aside {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 2rem 1.75rem;
  background:
    linear-gradient(
      160deg,
      #1e1b4b 0%,
      #312e81 42%,
      #0f172a 100%);
  color: #e4e4e7;
  overflow: hidden;
  isolation: isolate;
}
.modal__aside::before {
  content: "";
  position: absolute;
  top: -40%;
  right: -30%;
  width: 80%;
  aspect-ratio: 1;
  background:
    radial-gradient(
      circle,
      rgba(167, 139, 250, 0.28) 0%,
      rgba(167, 139, 250, 0) 65%);
  filter: blur(8px);
  pointer-events: none;
  z-index: -1;
}
.modal__aside::after {
  content: "";
  position: absolute;
  bottom: -35%;
  left: -25%;
  width: 70%;
  aspect-ratio: 1;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.18) 0%,
      rgba(34, 211, 238, 0) 65%);
  filter: blur(8px);
  pointer-events: none;
  z-index: -1;
}
@media (min-width: 768px) {
  .modal__aside {
    padding: 2.25rem 2rem;
  }
}
.modal__aside .modal__kicker {
  color: #c4b5fd;
}
.modal__aside .modal__title {
  position: relative;
  margin: 0 0 0.85rem;
  padding-bottom: 0.85rem;
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 2.8vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  color: #fafafa;
  line-height: 1.12;
}
.modal__aside .modal__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 56px;
  height: 2px;
  border-radius: 2px;
  background:
    linear-gradient(
      90deg,
      #a78bfa 0%,
      #22d3ee 100%);
}
.modal__aside .modal__lead {
  margin: 0 0 1.25rem;
  font-size: 0.9375rem;
  line-height: 1.6;
  color: #c4c4cc;
}
.modal__bullets {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 0.9375rem;
  line-height: 1.45;
  color: #e4e4e7;
}
.modal__bullets li {
  position: relative;
  padding-left: 1.75rem;
  margin-bottom: 0.6rem;
}
.modal__bullets li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.15em;
  width: 1.1rem;
  height: 1.1rem;
  border-radius: 999px;
  background:
    linear-gradient(
      135deg,
      rgba(167, 139, 250, 0.22),
      rgba(34, 211, 238, 0.22)),
    rgba(255, 255, 255, 0.04);
  box-shadow: inset 0 0 0 1px rgba(167, 139, 250, 0.35);
}
.modal__bullets li::after {
  content: "";
  position: absolute;
  left: 0.32rem;
  top: 0.42em;
  width: 0.45rem;
  height: 0.25rem;
  border-left: 1.5px solid #c4b5fd;
  border-bottom: 1.5px solid #c4b5fd;
  transform: rotate(-45deg);
}
.modal__aside-foot {
  margin: 1.5rem 0 0;
  padding-top: 1.1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  font-size: 0.9375rem;
}
.modal__aside .modal__brief-link {
  color: #67e8f9;
}
.modal__aside .modal__brief-link:hover {
  color: #a5f3fc;
}
.modal__aside .modal__hint-meta {
  color: #71717a;
}
.modal__main {
  padding: 2rem 1.75rem;
  background: #fff;
}
@media (min-width: 768px) {
  .modal__main {
    padding: 2.25rem 2rem;
  }
}
.modal__row {
  display: grid;
  gap: 0.85rem;
  margin-bottom: 0.85rem;
}
@media (min-width: 520px) {
  .modal__row {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
}
.modal--consult .modal__close,
.modal--exit-intent .modal__close {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  padding: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.9);
  color: var(--color-muted);
  cursor: var(--cursor-pointer, pointer);
  transition:
    color 0.2s var(--ease-out),
    border-color 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out);
}
.modal--consult .modal__close:hover,
.modal--exit-intent .modal__close:hover {
  color: var(--color-primary-dark);
  border-color: rgba(124, 58, 237, 0.25);
  box-shadow: var(--shadow-glow);
}
.modal--consult .modal__close:focus-visible,
.modal--exit-intent .modal__close:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.modal__close-icon {
  display: block;
}
.modal__kicker {
  margin: 0 0 0.45rem;
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.modal__lead {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.modal--consult .modal__form {
  padding: 0;
}
.modal__main .modal__label {
  margin-bottom: 0.75rem;
}
.modal__main .modal__label:last-of-type {
  margin-bottom: 1rem;
}
.modal__label {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  margin: 0;
  cursor: var(--cursor-pointer, pointer);
}
.modal__label-text {
  font-size: 0.875rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: 0.01em;
}
.modal__input {
  width: 100%;
  padding: 0.75rem 1rem;
  font: inherit;
  font-size: 1rem;
  line-height: 1.45;
  color: var(--color-text);
  background: #fff;
  border: 1px solid rgba(9, 9, 11, 0.12);
  border-radius: var(--radius);
  box-shadow: 0 1px 2px rgba(9, 9, 11, 0.04);
  transition: border-color 0.2s var(--ease-out), box-shadow 0.2s var(--ease-out);
}
.modal__input::placeholder {
  color: #a1a1aa;
}
.modal__input:hover {
  border-color: rgba(124, 58, 237, 0.2);
}
.modal__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-soft), 0 1px 2px rgba(9, 9, 11, 0.06);
}
.modal__textarea {
  resize: vertical;
  min-height: 104px;
  line-height: 1.55;
}
.modal__input.modal__textarea {
  display: block;
}
.modal--consult .modal__submit {
  margin-top: 0.35rem;
  min-height: 2.75rem;
  font-size: 1rem;
  font-weight: 700;
}
.modal__main .modal__hint--muted {
  margin: 0.85rem 0 0;
  font-size: 0.8125rem;
  line-height: 1.5;
}
.modal__main .modal__hint--muted code {
  font-size: 0.85em;
  padding: 0.1rem 0.35rem;
  border-radius: 4px;
  background: rgba(124, 58, 237, 0.08);
  color: var(--color-primary-dark);
}
.modal__brief-link {
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
}
.modal__brief-link:hover {
  color: var(--color-primary-dark);
  text-decoration: underline;
}
.modal__hint-meta {
  margin-left: 0.4rem;
  font-size: 0.6875rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: #a1a1aa;
}

/* assets/css/src/components/exit-intent.css */
.modal--exit-intent {
  z-index: 210;
}
.modal--exit-intent .exit-intent__dialog {
  position: relative;
  z-index: 1;
  width: min(100%, 440px);
  max-height: min(90vh, 560px);
  overflow: hidden;
  padding: 0;
  border-radius: var(--radius-lg);
  background: #fff;
  border: 1px solid rgba(124, 58, 237, 0.15);
  box-shadow:
    0 28px 90px rgba(9, 9, 11, 0.45),
    0 0 0 1px rgba(255, 255, 255, 0.06) inset,
    0 0 64px rgba(124, 58, 237, 0.1);
}
.exit-intent__body {
  padding: 1.75rem 1.5rem 1.5rem;
}
@media (min-width: 480px) {
  .exit-intent__body {
    padding: 2rem 1.85rem 1.65rem;
  }
}
.exit-intent__kicker {
  margin: 0 0 0.5rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.exit-intent__title {
  margin: 0 0 0.85rem;
  font-family: var(--font-display, "Syne", system-ui, sans-serif);
  font-size: clamp(1.2rem, 4vw, 1.45rem);
  font-weight: 800;
  line-height: 1.25;
  color: var(--color-text);
  letter-spacing: -0.02em;
}
.exit-intent__lead {
  margin: 0 0 1.35rem;
  font-size: 0.92rem;
  line-height: 1.6;
  color: var(--color-muted);
}
.exit-intent__actions {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
@media (min-width: 400px) {
  .exit-intent__actions {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
  }
  .exit-intent__btn-primary {
    flex: 1 1 auto;
    min-width: 10rem;
  }
  .exit-intent__btn-secondary {
    flex: 0 0 auto;
  }
}
@media (prefers-reduced-motion: reduce) {
  .modal__backdrop {
    transition: none;
  }
}
.form__label {
  display: block;
  margin-bottom: 0.75rem;
  font-size: 0.9rem;
  font-weight: 600;
}
.form__input {
  display: block;
  width: 100%;
  margin-top: 0.35rem;
  padding: 0.6rem 0.75rem;
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  font: inherit;
  transition: border-color 0.15s;
}
.form__input:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.form__textarea {
  resize: vertical;
  min-height: 80px;
}
.req {
  color: #dc2626;
}

/* assets/css/src/components/pricing-table.css */
.price-table {
  width: 100%;
  border-collapse: collapse;
  margin: 1rem 0;
  font-size: 0.95rem;
  border-radius: var(--radius);
  overflow: hidden;
}
.price-table th,
.price-table td {
  border: 1px solid var(--color-border);
  padding: 0.65rem 0.85rem;
  text-align: left;
}
.price-table th {
  background: var(--color-bg-alt);
  font-family: var(--font-display);
  font-weight: 700;
}

/* assets/css/src/components/lang-switch.css */
.lang-switch {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-pill);
  overflow: hidden;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  flex-shrink: 0;
}
.lang-switch__item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.3rem 0.5rem;
  color: #a1a1aa;
  text-decoration: none;
  transition: color 0.2s var(--ease-out), background 0.2s var(--ease-out);
  cursor: var(--cursor-pointer, pointer);
}
.lang-switch__item:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.1);
  text-decoration: none;
}
.lang-switch__item.is-active {
  color: #fff;
  background: var(--color-primary);
  cursor: default;
}
.lang-switch__item + .lang-switch__item {
  border-left: 1px solid rgba(255, 255, 255, 0.12);
}
.lang-switch--mobile {
  border-color: var(--color-border);
  align-self: center;
}
.lang-switch--mobile .lang-switch__item {
  color: var(--color-muted);
}
.lang-switch--mobile .lang-switch__item:hover {
  color: var(--color-primary);
  background: var(--color-primary-soft);
}
.lang-switch--mobile .lang-switch__item + .lang-switch__item {
  border-left-color: var(--color-border);
}
@media (min-width: 1024px) {
  .lang-switch--mobile {
    display: none;
  }
}

/* assets/css/src/components/cookie-consent.css */
.cookie-consent {
  position: fixed;
  inset: auto 0.65rem 0.65rem 0.65rem;
  z-index: 180;
  margin: 0 auto;
  max-width: 620px;
  padding: 0.75rem 0.95rem;
  border-radius: var(--radius);
  background:
    linear-gradient(
      160deg,
      rgba(255, 255, 255, 0.98) 0%,
      #f8f8fc 100%);
  border: 1px solid rgba(124, 58, 237, 0.18);
  box-shadow:
    0 24px 60px -28px rgba(9, 9, 11, 0.4),
    0 12px 32px -16px rgba(124, 58, 237, 0.25),
    inset 0 1px 0 rgba(255, 255, 255, 0.7);
  transform: translateY(140%);
  opacity: 0;
  transition: transform 0.4s var(--ease-out), opacity 0.4s var(--ease-out);
  will-change: transform, opacity;
}
.cookie-consent[hidden] {
  display: none !important;
}
.cookie-consent.is-visible {
  transform: translateY(0);
  opacity: 1;
}
.cookie-consent::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0.95rem;
  right: 0.95rem;
  height: 2px;
  border-radius: 2px;
  background:
    linear-gradient(
      90deg,
      var(--color-primary) 0%,
      #a78bfa 50%,
      var(--color-accent) 100%);
  opacity: 0.85;
}
.cookie-consent__inner {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
@media (min-width: 720px) {
  .cookie-consent__inner {
    flex-direction: row;
    align-items: center;
    gap: 0.85rem;
  }
}
.cookie-consent__icon {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      var(--color-accent-soft) 100%);
  color: var(--color-primary-dark);
}
.cookie-consent__text {
  flex: 1 1 auto;
  min-width: 0;
}
.cookie-consent__title {
  margin: 0 0 0.15rem;
  font-family: var(--font-display);
  font-size: 0.925rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--color-text);
}
.cookie-consent__desc {
  margin: 0;
  font-size: 0.8125rem;
  line-height: 1.45;
  color: var(--color-muted);
}
.cookie-consent__link {
  color: var(--color-primary-dark);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  margin-left: 0.25rem;
}
@media (min-width: 480px) {
  .cookie-consent__link {
    white-space: nowrap;
  }
}
.cookie-consent__link:hover,
.cookie-consent__link:focus-visible {
  color: var(--color-primary);
  outline: none;
}
.cookie-consent__actions {
  flex-shrink: 0;
  display: flex;
  gap: 0.45rem;
}
@media (max-width: 719.98px) {
  .cookie-consent__actions .btn {
    flex: 1 1 0;
  }
}
.cookie-consent .btn {
  min-height: 2.15rem;
  padding-inline: 0.85rem;
  padding-block: 0.35rem;
  font-size: 0.8125rem;
}
@media (min-width: 720px) {
  .cookie-consent {
    inset: auto 1rem 0.85rem 1rem;
    padding: 0.85rem 1.05rem;
    max-width: 640px;
    border-radius: var(--radius-lg);
  }
  .cookie-consent::before {
    left: 1.05rem;
    right: 1.05rem;
  }
  .cookie-consent__inner {
    gap: 1rem;
  }
  .cookie-consent .btn {
    min-height: 2.25rem;
    font-size: 0.875rem;
  }
}
@media (prefers-reduced-motion: reduce) {
  .cookie-consent {
    transition: opacity 0.2s linear;
    transform: none;
  }
}
.site-footer__legal {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 1.1rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.site-footer__legal-link,
.site-footer__legal-btn {
  appearance: none;
  border: 0;
  background: transparent;
  padding: 0;
  margin: 0;
  color: inherit;
  font: inherit;
  cursor: var(--cursor-pointer, pointer);
  color: rgba(228, 228, 231, 0.75);
  font-size: 0.82rem;
  text-decoration: none;
  transition: color 0.2s var(--ease-out);
}
.site-footer__legal-link:hover,
.site-footer__legal-link:focus-visible,
.site-footer__legal-btn:hover,
.site-footer__legal-btn:focus-visible {
  color: #fafafa;
  outline: none;
}
.site-footer__legal-divider {
  color: rgba(228, 228, 231, 0.35);
  user-select: none;
}

/* assets/css/src/pages/home-services.css */
.home-services-section {
  position: relative;
  overflow: hidden;
}
.home-services-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse 50% 30% at 12% 12%,
      rgba(124, 58, 237, 0.08) 0%,
      transparent 60%),
    radial-gradient(
      ellipse 40% 25% at 88% 90%,
      rgba(34, 211, 238, 0.06) 0%,
      transparent 60%);
  pointer-events: none;
}
.home-services-section > .container {
  position: relative;
  z-index: 1;
}
.home-services-board {
  display: grid;
  gap: 1.4rem;
  margin-top: 2.25rem;
}
.home-services-group {
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(9, 9, 11, 0.06);
  border-radius: var(--radius-lg);
  padding: 1.5rem 1.4rem 1.6rem;
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}
.home-services-group::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.18),
      rgba(34, 211, 238, 0.12) 50%,
      transparent 80%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  opacity: 0.85;
}
.home-services-group--apps::before {
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.22),
      rgba(124, 58, 237, 0.12) 50%,
      transparent 80%);
}
.home-services-group--marketing::before {
  background:
    linear-gradient(
      135deg,
      rgba(16, 185, 129, 0.22),
      rgba(124, 58, 237, 0.12) 50%,
      transparent 80%);
}
.home-services-group__head {
  display: grid;
  gap: 0.4rem;
  padding-bottom: 1rem;
  border-bottom: 1px dashed rgba(9, 9, 11, 0.08);
  margin-bottom: 1.1rem;
}
.home-services-group__eyebrow {
  font-family:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    monospace;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: var(--color-primary);
  text-transform: uppercase;
}
.home-services-group--apps .home-services-group__eyebrow {
  color: var(--color-accent);
}
.home-services-group--marketing .home-services-group__eyebrow {
  color: var(--color-cta);
}
.home-services-group__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.home-services-group__lead {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-muted);
  line-height: 1.4;
}
.home-services-group__list {
  display: grid;
  gap: 0.75rem;
}
.home-service-card {
  display: grid;
  grid-template-columns: 44px 1fr;
  grid-template-areas: "icon body" "icon foot";
  gap: 0.45rem 0.85rem;
  padding: 0.95rem 1rem;
  background: rgba(250, 250, 251, 0.6);
  border: 1px solid rgba(9, 9, 11, 0.06);
  border-radius: 16px;
  text-decoration: none;
  color: inherit;
  transition:
    transform 200ms var(--ease-out),
    border-color 200ms var(--ease-out),
    box-shadow 200ms var(--ease-out),
    background 200ms var(--ease-out);
}
.home-service-card:hover,
.home-service-card:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(124, 58, 237, 0.25);
  background: #fff;
  box-shadow: 0 14px 36px rgba(124, 58, 237, 0.12);
  outline: none;
}
.home-services-group--apps .home-service-card:hover,
.home-services-group--apps .home-service-card:focus-visible {
  border-color: rgba(34, 211, 238, 0.4);
  box-shadow: 0 14px 36px rgba(34, 211, 238, 0.12);
}
.home-services-group--marketing .home-service-card:hover,
.home-services-group--marketing .home-service-card:focus-visible {
  border-color: rgba(16, 185, 129, 0.35);
  box-shadow: 0 14px 36px rgba(16, 185, 129, 0.12);
}
.home-service-card__icon {
  grid-area: icon;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.12),
      rgba(34, 211, 238, 0.08));
  color: var(--color-primary);
  align-self: start;
}
.home-services-group--apps .home-service-card__icon {
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.14),
      rgba(124, 58, 237, 0.08));
  color: #0e7490;
}
.home-services-group--marketing .home-service-card__icon {
  background:
    linear-gradient(
      135deg,
      rgba(16, 185, 129, 0.14),
      rgba(34, 211, 238, 0.08));
  color: var(--color-cta-dark);
}
.home-service-card__icon svg {
  width: 22px;
  height: 22px;
}
.home-service-card__icon img {
  width: 28px;
  height: 28px;
  object-fit: contain;
}
.home-service-card__body {
  grid-area: body;
  display: grid;
  gap: 0.2rem;
}
.home-service-card__title {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.25;
}
.home-service-card__lead {
  margin: 0;
  font-size: 0.85rem;
  color: var(--color-muted);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.home-service-card__foot {
  grid-area: foot;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem 0.85rem;
  margin-top: 0.35rem;
  padding-top: 0.55rem;
  border-top: 1px solid rgba(9, 9, 11, 0.06);
}
.home-service-card__range {
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.25;
}
.home-service-card__range-note {
  display: block;
  margin-top: 0.1rem;
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--color-muted);
  letter-spacing: 0.02em;
}
.home-service-card__cta {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: 0.02em;
  transition: transform 200ms var(--ease-out);
}
.home-service-card:hover .home-service-card__cta {
  transform: translateX(2px);
}
.home-services-group--apps .home-service-card__cta {
  color: #0e7490;
}
.home-services-group--marketing .home-service-card__cta {
  color: var(--color-cta-dark);
}
.home-services-foot {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: center;
  justify-content: center;
  padding: 1.1rem 1.3rem;
  background: rgba(255, 255, 255, 0.7);
  border: 1px dashed rgba(124, 58, 237, 0.25);
  border-radius: var(--radius);
  text-align: center;
}
.home-services-foot__lead {
  margin: 0;
  color: var(--color-muted);
  font-size: 0.95rem;
}
.home-services-foot__link {
  font-weight: 700;
  color: var(--color-primary);
  text-decoration: none;
  transition: color 180ms var(--ease-out);
}
.home-services-foot__link:hover {
  color: var(--color-primary-dark);
}
@media (min-width: 720px) {
  .home-services-board {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1024px) {
  .home-services-board {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (prefers-reduced-motion: reduce) {
  .home-service-card,
  .home-service-card__cta {
    transition: none;
  }
}

/* assets/css/src/pages/home-values.css */
.home-values-section {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.home-values-grid {
  display: grid;
  gap: 1.1rem;
  margin-top: 2rem;
}
@media (min-width: 720px) {
  .home-values-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.home-value-card {
  position: relative;
  padding: 1.6rem 1.5rem 1.4rem;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.96) 0%,
      rgba(255, 255, 255, 0.85) 100%);
  border: 1px solid rgba(9, 9, 11, 0.06);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: transform 220ms var(--ease-out), box-shadow 220ms var(--ease-out);
}
.home-value-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.35),
      transparent 60%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.home-value-card--2::before {
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.4),
      transparent 60%);
}
.home-value-card--3::before {
  background:
    linear-gradient(
      135deg,
      rgba(16, 185, 129, 0.36),
      transparent 60%);
}
.home-value-card::after {
  content: "";
  position: absolute;
  top: -45px;
  right: -45px;
  width: 180px;
  height: 180px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 70%);
  pointer-events: none;
  transition: transform 400ms var(--ease-out);
}
.home-value-card--2::after {
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.18) 0%,
      transparent 70%);
}
.home-value-card--3::after {
  background:
    radial-gradient(
      circle,
      rgba(16, 185, 129, 0.16) 0%,
      transparent 70%);
}
.home-value-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 22px 48px rgba(124, 58, 237, 0.12);
}
.home-value-card:hover::after {
  transform: scale(1.15);
}
.home-value-card__tag {
  display: inline-block;
  font-family:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  text-transform: uppercase;
  margin-bottom: 0.75rem;
  padding: 0.25rem 0.65rem;
  background: var(--color-primary-soft);
  border-radius: var(--radius-pill);
  position: relative;
  z-index: 1;
}
.home-value-card--2 .home-value-card__tag {
  color: #0e7490;
  background: var(--color-accent-soft);
}
.home-value-card--3 .home-value-card__tag {
  color: var(--color-cta-dark);
  background: rgba(16, 185, 129, 0.12);
}
.home-value-card__title {
  margin: 0 0 0.6rem;
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--color-text);
  letter-spacing: -0.02em;
  line-height: 1.25;
  position: relative;
  z-index: 1;
}
.home-value-card__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
  position: relative;
  z-index: 1;
}
@media (prefers-reduced-motion: reduce) {
  .home-value-card,
  .home-value-card::after {
    transition: none;
  }
  .home-value-card:hover {
    transform: none;
  }
  .home-value-card:hover::after {
    transform: none;
  }
}

/* assets/css/src/pages/home-engagement.css */
.home-engagement-section {
  position: relative;
  overflow: hidden;
}
.home-engagement-section::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse 50% 35% at 90% 20%,
      rgba(124, 58, 237, 0.07) 0%,
      transparent 60%),
    radial-gradient(
      ellipse 45% 30% at 10% 90%,
      rgba(34, 211, 238, 0.05) 0%,
      transparent 60%);
  pointer-events: none;
}
.home-engagement-section > .container {
  position: relative;
  z-index: 1;
}
.engagement-grid {
  display: grid;
  gap: 1.15rem;
  margin-top: 2rem;
  align-items: stretch;
}
@media (min-width: 720px) {
  .engagement-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1rem;
  }
}
.engagement-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 1.6rem 1.45rem 1.5rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(9, 9, 11, 0.06);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  transition: transform 220ms var(--ease-out), box-shadow 220ms var(--ease-out);
  overflow: hidden;
}
.engagement-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.18),
      transparent 70%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
}
.engagement-card--2::before {
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.32),
      rgba(124, 58, 237, 0.22) 50%,
      transparent 80%);
}
.engagement-card--3::before {
  background:
    linear-gradient(
      135deg,
      rgba(16, 185, 129, 0.3),
      transparent 70%);
}
.engagement-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 50px rgba(124, 58, 237, 0.12);
}
.engagement-card--featured {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(244, 245, 255, 0.95) 100%),
    radial-gradient(
      circle at 100% 0%,
      rgba(34, 211, 238, 0.12) 0%,
      transparent 55%);
  border-color: transparent;
  box-shadow: 0 18px 44px rgba(124, 58, 237, 0.16), 0 0 0 1px rgba(255, 255, 255, 0.7) inset;
  transform: translateY(-2px);
}
@media (min-width: 720px) {
  .engagement-card--featured {
    transform: translateY(-12px);
  }
}
.engagement-card--featured:hover {
  transform: translateY(-16px);
}
.engagement-card__badge {
  position: absolute;
  top: 0.85rem;
  right: 0.85rem;
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.7rem;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      #a78bfa 100%);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: var(--radius-pill);
  box-shadow: 0 6px 18px rgba(124, 58, 237, 0.4);
  z-index: 2;
}
.engagement-card__head {
  display: grid;
  gap: 0.35rem;
  padding-bottom: 0.95rem;
  border-bottom: 1px dashed rgba(9, 9, 11, 0.08);
  position: relative;
  z-index: 1;
}
.engagement-card__tag {
  font-family:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--color-primary);
  text-transform: uppercase;
}
.engagement-card--2 .engagement-card__tag {
  color: #0e7490;
}
.engagement-card--3 .engagement-card__tag {
  color: var(--color-cta-dark);
}
.engagement-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
  line-height: 1.2;
}
.engagement-card__subtitle {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 500;
  color: var(--color-muted);
  line-height: 1.35;
}
.engagement-card__lead {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-deep);
  position: relative;
  z-index: 1;
}
.engagement-card__meta {
  margin: 0;
  padding: 0.85rem 0.95rem;
  display: grid;
  gap: 0.45rem;
  background: rgba(124, 58, 237, 0.045);
  border-radius: var(--radius);
  border: 1px solid rgba(124, 58, 237, 0.08);
  position: relative;
  z-index: 1;
}
.engagement-card--2 .engagement-card__meta {
  background: rgba(34, 211, 238, 0.06);
  border-color: rgba(34, 211, 238, 0.14);
}
.engagement-card--3 .engagement-card__meta {
  background: rgba(16, 185, 129, 0.05);
  border-color: rgba(16, 185, 129, 0.12);
}
.engagement-card__meta-row {
  display: grid;
  grid-template-columns: minmax(0, auto) minmax(0, 1fr);
  gap: 0.6rem;
  align-items: baseline;
  font-size: 0.85rem;
  line-height: 1.35;
}
.engagement-card__meta-label {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
  min-width: 4.5rem;
}
.engagement-card__meta-value {
  margin: 0;
  font-weight: 600;
  color: var(--color-text);
  text-align: right;
}
.engagement-card__bullets {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 0.4rem;
  position: relative;
  z-index: 1;
}
.engagement-card__bullets li {
  position: relative;
  padding-left: 1.45rem;
  font-size: 0.9rem;
  line-height: 1.45;
  color: var(--color-deep);
}
.engagement-card__bullets li::before {
  content: "";
  position: absolute;
  top: 0.45rem;
  left: 0;
  width: 0.95rem;
  height: 0.95rem;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      var(--color-accent) 100%);
  box-shadow: 0 4px 10px rgba(124, 58, 237, 0.25);
}
.engagement-card__bullets li::after {
  content: "";
  position: absolute;
  top: 0.6rem;
  left: 0.22rem;
  width: 0.32rem;
  height: 0.18rem;
  border-left: 1.5px solid #fff;
  border-bottom: 1.5px solid #fff;
  transform: rotate(-45deg);
}
.engagement-card--3 .engagement-card__bullets li::before {
  background:
    linear-gradient(
      135deg,
      var(--color-cta) 0%,
      var(--color-accent) 100%);
}
.engagement-card__cta {
  margin-top: auto;
  position: relative;
  z-index: 1;
}
@media (prefers-reduced-motion: reduce) {
  .engagement-card,
  .engagement-card--featured {
    transition: none;
  }
  .engagement-card:hover,
  .engagement-card--featured:hover {
    transform: none;
  }
}
.home-engagement-foot {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.85rem 1.25rem;
  padding: 1.1rem 1.4rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.06),
      rgba(34, 211, 238, 0.04));
  border: 1px solid rgba(124, 58, 237, 0.14);
  text-align: center;
}
.home-engagement-foot__lead {
  margin: 0;
  font-size: 0.95rem;
  color: var(--color-deep);
  font-weight: 500;
}

/* assets/css/src/pages/home-portfolio-preview.css */
.home-portfolio-teaser__grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .home-portfolio-teaser__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1000px) {
  .home-portfolio-teaser__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.home-portfolio-teaser__card {
  display: flex;
  flex-direction: column;
  background: rgba(255, 255, 255, 0.95);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition: box-shadow 0.28s var(--ease-out), border-color 0.28s var(--ease-out);
}
.home-portfolio-teaser__card:hover {
  box-shadow: var(--shadow-hover), 0 0 0 1px rgba(124, 58, 237, 0.06);
  border-color: rgba(124, 58, 237, 0.18);
}
.home-portfolio-teaser__media {
  aspect-ratio: 1024 / 570;
  overflow: hidden;
  background: var(--color-bg-alt, #f4f4f5);
}
.home-portfolio-teaser__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  display: block;
}
.home-portfolio-teaser__body {
  padding: 1.1rem 1.2rem 1.25rem;
}
.home-portfolio-teaser__kind {
  display: inline-block;
  margin-bottom: 0.35rem;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.home-portfolio-teaser__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: -0.02em;
}
.home-portfolio-teaser__summary {
  margin: 0;
  font-size: 0.9rem;
  color: var(--color-muted);
  line-height: 1.5;
}
.home-portfolio-teaser__more {
  margin: 1.75rem 0 0;
  text-align: center;
}

/* assets/css/src/pages/home-about.css */
.section--home-about {
  padding-top: clamp(2.5rem, 5vw, 3.5rem);
  padding-bottom: clamp(2.75rem, 5vw, 3.5rem);
}
.home-about-split {
  display: grid;
  gap: 1.5rem;
  padding: clamp(1.35rem, 2.8vw, 1.85rem);
  border-radius: clamp(var(--radius-lg), 2.5vw, 28px);
  background:
    linear-gradient(
      148deg,
      rgba(255, 255, 255, 0.99) 0%,
      rgba(250, 245, 255, 0.96) 38%,
      rgba(236, 253, 245, 0.45) 100%);
  border: 1px solid rgba(124, 58, 237, 0.12);
  box-shadow: var(--shadow-hover), 0 0 0 1px rgba(255, 255, 255, 0.78) inset;
}
.home-about-split .prose {
  max-width: none;
  margin: 0;
}
.home-about-split__story {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.home-about-split__story.prose h2 {
  font-size: clamp(1.45rem, 2.8vw, 1.8rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1.2;
  margin: 0;
}
.home-about-split__story.prose p {
  margin: 0;
}
.home-about-split__more {
  margin-top: auto;
  padding-top: 0.4rem;
}
.home-about-bullets {
  list-style: none;
  margin: 0.25rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.6rem;
}
@media (min-width: 560px) {
  .home-about-bullets {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.55rem 0.75rem;
  }
}
.home-about-bullets__item {
  display: flex;
  align-items: flex-start;
  gap: 0.65rem;
  padding: 0.7rem 0.85rem;
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(124, 58, 237, 0.09);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
  transition:
    background 0.22s var(--ease-out),
    border-color 0.22s var(--ease-out),
    box-shadow 0.22s var(--ease-out);
}
@media (prefers-reduced-motion: no-preference) {
  .home-about-bullets__item:hover {
    background: rgba(255, 255, 255, 0.95);
    border-color: rgba(124, 58, 237, 0.2);
    box-shadow: 0 6px 20px rgba(124, 58, 237, 0.08);
  }
}
.home-about-bullets__mark {
  position: relative;
  flex-shrink: 0;
  width: 1.35rem;
  height: 1.35rem;
  margin-top: 0.1rem;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #8b5cf6 50%,
      #22d3ee 130%);
  box-shadow: 0 4px 12px rgba(124, 58, 237, 0.28);
}
.home-about-bullets__mark::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 45%;
  width: 0.28rem;
  height: 0.48rem;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: translate(-50%, -50%) rotate(45deg);
}
.home-about-bullets__text {
  flex: 1;
  min-width: 0;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.4;
  color: var(--color-deep);
}
.home-about-split__aside {
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
  min-width: 0;
}
.home-about-split .about-card--home {
  margin: 0;
  width: 100%;
}
.home-about-cta {
  padding: 1.35rem 1.3rem 1.4rem;
  border-radius: clamp(var(--radius-lg), 2vw, 22px);
  background:
    linear-gradient(
      140deg,
      rgba(124, 58, 237, 0.06) 0%,
      rgba(34, 211, 238, 0.06) 100%),
    rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(124, 58, 237, 0.14);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.9) inset;
}
.home-about-cta__lead {
  margin: 0 0 0.9rem;
  font-size: 0.95rem;
  font-weight: 600;
  line-height: 1.5;
  color: var(--color-deep);
}
.home-about-cta__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
  align-items: center;
}
.home-about-cta__actions .btn--ghost {
  border-color: rgba(124, 58, 237, 0.28);
  background: rgba(255, 255, 255, 0.7);
}
@media (max-width: 640px) {
  .home-about-cta__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .home-about-cta__actions > .btn {
    width: 100%;
  }
}
@media (min-width: 900px) {
  .home-about-split {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0 2.5rem;
    align-items: stretch;
    padding: clamp(1.85rem, 3.2vw, 2.5rem) clamp(1.75rem, 3vw, 2.65rem);
  }
  .home-about-split__story {
    padding-right: 2.5rem;
    border-right: 1px solid rgba(124, 58, 237, 0.14);
  }
  .home-about-split__aside {
    align-self: stretch;
  }
  .home-about-cta {
    margin-top: auto;
  }
}
@media (max-width: 899px) {
  .home-about-split__story {
    padding-bottom: 1.35rem;
    border-bottom: 1px solid rgba(124, 58, 237, 0.1);
  }
}

/* assets/css/src/pages/portfolio.css */
.portfolio-placeholder {
  text-align: center;
  padding: 2rem;
  background: #fff;
  border-radius: var(--radius-lg);
  border: 1px dashed var(--color-border);
  color: var(--color-muted);
}
.portfolio-section {
  position: relative;
  padding-bottom: 3.5rem;
}
.portfolio-section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: min(55vh, 420px);
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 55% 80% at 10% 0%,
      rgba(124, 58, 237, 0.07) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 45% 70% at 95% 20%,
      rgba(34, 211, 238, 0.06) 0%,
      transparent 50%);
  z-index: 0;
}
.portfolio-section .container {
  position: relative;
  z-index: 1;
}
.portfolio-manifesto {
  max-width: 48rem;
  margin: 0 auto 2.5rem;
  text-align: center;
}
.about-manifesto {
  max-width: 48rem;
  margin: 2.75rem auto 0;
  text-align: center;
}
.contact-manifesto {
  max-width: 48rem;
  margin: 0 auto 2.25rem;
  text-align: center;
}
.service-manifesto {
  max-width: 48rem;
  margin: 0 auto 2rem;
  text-align: center;
}
.portfolio-manifesto__lead,
.about-manifesto__lead,
.contact-manifesto__lead,
.service-manifesto__lead {
  margin: 0 0 1.1rem;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--color-muted);
}
.portfolio-manifesto__chips,
.about-manifesto__chips,
.contact-manifesto__chips,
.service-manifesto__chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  justify-content: center;
}
.portfolio-manifesto__chip,
.about-manifesto__chip,
.contact-manifesto__chip,
.service-manifesto__chip {
  padding: 0.4rem 0.9rem;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.08) 100%);
  border: 1px solid rgba(124, 58, 237, 0.15);
  border-radius: var(--radius-pill);
}
.portfolio-showcase {
  display: grid;
  gap: clamp(1.35rem, 2.5vw, 2rem);
  grid-template-columns: 1fr;
}
@media (min-width: 700px) {
  .portfolio-showcase {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media (min-width: 1080px) {
  .portfolio-showcase {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
.portfolio-piece {
  display: flex;
  flex-direction: column;
  border-radius: clamp(var(--radius-lg), 2vw, 26px);
  overflow: hidden;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition:
    box-shadow 0.35s var(--ease-out),
    border-color 0.35s var(--ease-out),
    transform 0.35s var(--ease-out);
}
.portfolio-piece:hover {
  border-color: rgba(124, 58, 237, 0.22);
  box-shadow: var(--shadow-glow);
  transform: translateY(-3px);
}
@media (prefers-reduced-motion: reduce) {
  .portfolio-piece:hover {
    transform: none;
  }
}
.portfolio-piece__media {
  position: relative;
  overflow: hidden;
  background:
    linear-gradient(
      145deg,
      #1e1b4b 0%,
      #0f172a 100%);
  aspect-ratio: 1024 / 570;
}
.portfolio-piece__glow {
  position: absolute;
  inset: auto -20% -40% -20%;
  height: 70%;
  background:
    radial-gradient(
      ellipse at 50% 0%,
      rgba(124, 58, 237, 0.35) 0%,
      transparent 65%);
  pointer-events: none;
  z-index: 1;
  opacity: 0.85;
}
.portfolio-piece__img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
  position: relative;
  z-index: 0;
  transition: transform 0.5s var(--ease-out);
}
.portfolio-piece:hover .portfolio-piece__img {
  transform: scale(1.02);
}
@media (prefers-reduced-motion: reduce) {
  .portfolio-piece:hover .portfolio-piece__img {
    transform: none;
  }
}
.portfolio-piece__ribbon {
  position: absolute;
  top: 0.85rem;
  left: 0.85rem;
  z-index: 2;
  padding: 0.35rem 0.75rem;
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #fafafa;
  background: rgba(9, 9, 11, 0.55);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-pill);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  max-width: calc(100% - 1.7rem);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.portfolio-piece__panel {
  flex: 1 1 auto;
  padding: 1.25rem 1.35rem 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      #fafafa 100%);
}
.portfolio-piece__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 2vw, 1.2rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-text);
}
.portfolio-piece__summary {
  margin: 0;
  font-size: 0.9rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--color-text);
}
.portfolio-piece__description {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--color-muted);
}
.portfolio-foot {
  margin-top: 2.75rem;
  padding: 1.35rem 1.25rem;
  text-align: center;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.06) 100%);
  border: 1px solid rgba(124, 58, 237, 0.12);
}
.portfolio-foot__text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.portfolio-foot__text a {
  font-weight: 700;
  color: var(--color-primary);
}

/* assets/css/src/pages/about.css */
.about-section {
  position: relative;
  padding-bottom: 1rem;
}
.about-section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: min(50vh, 380px);
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 50% 75% at 5% 15%,
      rgba(124, 58, 237, 0.08) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 55% 70% at 100% 0%,
      rgba(34, 211, 238, 0.07) 0%,
      transparent 52%);
  z-index: 0;
}
.about-section .container {
  position: relative;
  z-index: 1;
}
.about-split {
  display: grid;
  gap: 2rem;
  align-items: start;
}
@media (min-width: 960px) {
  .about-split {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 2.5rem;
    align-items: center;
  }
}
.about-story {
  padding: 1.5rem 1.4rem;
  border-radius: clamp(var(--radius-lg), 2vw, 26px);
  background:
    linear-gradient(
      155deg,
      rgba(255, 255, 255, 0.94) 0%,
      rgba(250, 250, 250, 0.98) 100%);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-glow), 0 16px 48px rgba(9, 9, 11, 0.06);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.about-story__p {
  margin: 0 0 1rem;
  font-size: 1rem;
  line-height: 1.65;
  color: var(--color-muted);
}
.about-story__p:last-of-type {
  margin-bottom: 0;
}
.about-focus-list {
  list-style: none;
  margin: 1.35rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.about-focus-list__item {
  position: relative;
  margin: 0;
  padding: 0.85rem 1rem 0.85rem 2.65rem;
  font-size: 0.92rem;
  line-height: 1.5;
  font-weight: 600;
  color: var(--color-text);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.05) 100%);
  border: 1px solid rgba(124, 58, 237, 0.12);
  border-radius: var(--radius);
}
.about-focus-list__item::before {
  content: "";
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  width: 0.55rem;
  height: 0.55rem;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      var(--color-accent) 0%,
      var(--color-primary) 100%);
  box-shadow: 0 0 0 3px var(--color-primary-soft);
}
.about-visual {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
}
@media (min-width: 960px) {
  .about-visual {
    position: sticky;
    top: 1.25rem;
  }
}
.about-visual__glow {
  position: absolute;
  inset: -12% -8% auto;
  height: 55%;
  background:
    radial-gradient(
      ellipse at 50% 0%,
      rgba(124, 58, 237, 0.2) 0%,
      transparent 68%);
  pointer-events: none;
  z-index: 0;
}
.about-card {
  position: relative;
  z-index: 1;
  isolation: isolate;
  overflow: hidden;
  width: 100%;
  max-width: 440px;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  padding: clamp(1.5rem, 2.6vw, 1.85rem);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(
      ellipse 80% 70% at 100% 0%,
      rgba(34, 211, 238, 0.18) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 70% 60% at 0% 100%,
      rgba(124, 58, 237, 0.32) 0%,
      transparent 50%),
    linear-gradient(
      160deg,
      #1e1b4b 0%,
      #312e81 42%,
      #0f172a 100%);
  color: #e4e4e7;
  box-shadow:
    0 28px 72px rgba(15, 23, 42, 0.38),
    0 0 0 1px rgba(167, 139, 250, 0.18) inset,
    0 0 64px rgba(124, 58, 237, 0.14);
}
.about-card::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.55),
      rgba(124, 58, 237, 0.45) 45%,
      transparent 70%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
.about-card > * {
  position: relative;
  z-index: 2;
}
.about-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.about-card__tag {
  font-family:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #6ee7b7;
  opacity: 0.95;
}
.about-card__status {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.7rem 0.35rem 0.55rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.35);
  border-radius: var(--radius-pill);
}
.about-card__status-dot {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 0 4px rgba(52, 211, 153, 0.2);
}
.about-card__status-dot::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: rgba(52, 211, 153, 0.4);
  animation: aboutCardPulse 2.4s ease-out infinite;
}
@keyframes aboutCardPulse {
  0% {
    transform: scale(0.6);
    opacity: 0.7;
  }
  80% {
    transform: scale(1.8);
    opacity: 0;
  }
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .about-card__status-dot::after {
    animation: none;
  }
}
.about-card__brand {
  display: flex;
  align-items: center;
  gap: 0.95rem;
}
.about-card__mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #22d3ee 100%);
  border-radius: 18px;
  box-shadow: 0 8px 22px rgba(124, 58, 237, 0.45), 0 0 0 1px rgba(255, 255, 255, 0.1) inset;
}
.about-card__brand-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
  min-width: 0;
}
.about-card__brand-name {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 2.4vw, 1.45rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  color: #fafafa;
}
.about-card__brand-sub {
  margin-top: 0.2rem;
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(226, 232, 240, 0.7);
}
.about-card__section {
  padding-top: 1.1rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.about-card__label {
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(196, 181, 253, 0.85);
}
.about-card__chips {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.about-card__chip {
  padding: 0.38rem 0.75rem;
  font-size: 0.78rem;
  font-weight: 700;
  color: #f1f5f9;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: var(--radius-pill);
}
.about-card__team {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
}
.about-card__avatar {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: rgba(241, 245, 249, 0.78);
  background:
    linear-gradient(
      160deg,
      rgba(255, 255, 255, 0.1) 0%,
      rgba(255, 255, 255, 0.04) 100%);
  border-radius: 50%;
  border: 2px solid #1e1b4b;
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.3), 0 0 0 1px rgba(255, 255, 255, 0.06) inset;
  transition: transform 0.2s var(--ease-out), color 0.2s var(--ease-out);
}
.about-card__avatar svg {
  width: 18px;
  height: 18px;
}
.about-card__avatar + .about-card__avatar {
  margin-left: -8px;
}
.about-card__avatar:hover {
  color: #fff;
  transform: translateY(-1px);
  z-index: 1;
}
.about-card__avatar--1 {
  background:
    linear-gradient(
      160deg,
      rgba(124, 58, 237, 0.55) 0%,
      rgba(124, 58, 237, 0.18) 100%);
}
.about-card__avatar--2 {
  background:
    linear-gradient(
      160deg,
      rgba(34, 211, 238, 0.5) 0%,
      rgba(34, 211, 238, 0.16) 100%);
}
.about-card__avatar--3 {
  background:
    linear-gradient(
      160deg,
      rgba(236, 72, 153, 0.5) 0%,
      rgba(236, 72, 153, 0.16) 100%);
}
.about-card__avatar--4 {
  background:
    linear-gradient(
      160deg,
      rgba(16, 185, 129, 0.5) 0%,
      rgba(16, 185, 129, 0.16) 100%);
}
.about-card__avatar--5 {
  background:
    linear-gradient(
      160deg,
      rgba(245, 158, 11, 0.5) 0%,
      rgba(245, 158, 11, 0.16) 100%);
}
@media (prefers-reduced-motion: reduce) {
  .about-card__avatar:hover {
    transform: none;
  }
}
.about-card__team-roles {
  margin: 0;
  font-size: 0.82rem;
  line-height: 1.5;
  color: rgba(226, 232, 240, 0.65);
}
.about-visual__caption {
  position: relative;
  z-index: 1;
  margin: 0;
  max-width: 22rem;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
  line-height: 1.45;
}
.about-stats-section {
  position: relative;
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}
.about-stats-section__lead {
  margin-bottom: 1.75rem;
}
.stats-grid--about {
  gap: 1.15rem;
}
.stat-item--about {
  padding: 1.5rem 1.1rem;
  background:
    linear-gradient(
      180deg,
      #ffffff 0%,
      #fafafa 100%);
  border: 1px solid rgba(124, 58, 237, 0.1);
  box-shadow: 0 8px 32px rgba(124, 58, 237, 0.06);
  transition: border-color 0.25s var(--ease-out), box-shadow 0.25s var(--ease-out);
}
.stat-item--about:hover {
  border-color: rgba(124, 58, 237, 0.22);
  box-shadow: var(--shadow-glow);
}
.stat-item--about .stat-item__value {
  font-size: clamp(1.85rem, 4vw, 2.35rem);
}
.stat-item--about .stat-item__value .js-counter {
  background:
    linear-gradient(
      105deg,
      var(--color-primary) 0%,
      #8b5cf6 50%,
      var(--color-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.about-values-section .section-lead {
  margin-bottom: 1.75rem;
}
.about-values-grid {
  display: grid;
  gap: 1.15rem;
  grid-template-columns: 1fr;
}
@media (min-width: 640px) {
  .about-values-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.about-value-card {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 1.35rem 1.3rem 1.45rem;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition:
    transform 0.3s var(--ease-out),
    border-color 0.3s var(--ease-out),
    box-shadow 0.3s var(--ease-out);
}
.about-value-card:hover {
  transform: translateY(-2px);
  border-color: rgba(124, 58, 237, 0.2);
  box-shadow: var(--shadow-hover);
}
@media (prefers-reduced-motion: reduce) {
  .about-value-card:hover {
    transform: none;
  }
}
.about-value-card__tag {
  align-self: flex-start;
  padding: 0.3rem 0.65rem;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
  border-radius: var(--radius-pill);
  border: 1px solid rgba(124, 58, 237, 0.12);
}
.about-value-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.12rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.about-value-card__lead {
  margin: 0;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.45;
  color: var(--color-text);
}
.about-value-card__text {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.6;
  color: var(--color-muted);
}

/* assets/css/src/pages/contacts.css */
.contact-page-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding-top: clamp(2rem, 4vw, 3rem);
  padding-bottom: clamp(2.25rem, 4.5vw, 3.25rem);
}
.contact-page-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.contact-page-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.55;
}
.contact-page-section__orb--1 {
  top: -12%;
  left: -8%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.42),
      transparent 70%);
}
.contact-page-section__orb--2 {
  bottom: -22%;
  right: -10%;
  width: 460px;
  height: 460px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.36),
      transparent 70%);
}
.contact-bento {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.1rem;
}
@media (min-width: 768px) {
  .contact-bento {
    grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
    grid-template-rows: 1fr 1fr;
    gap: 1.25rem;
  }
  .contact-bento__primary {
    grid-row: 1 / -1;
  }
}
@media (min-width: 1180px) {
  .contact-bento {
    grid-template-columns: minmax(0, 1.32fr) minmax(0, 0.68fr);
  }
}
.contact-bento__primary {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
  padding: clamp(1.65rem, 3vw, 2.25rem);
  border-radius: var(--radius-lg);
  background:
    radial-gradient(
      ellipse 80% 70% at 100% 0%,
      rgba(34, 211, 238, 0.18) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 70% 60% at 0% 100%,
      rgba(124, 58, 237, 0.32) 0%,
      transparent 50%),
    linear-gradient(
      160deg,
      #1e1b4b 0%,
      #312e81 42%,
      #0f172a 100%);
  color: #e4e4e7;
  box-shadow:
    0 28px 72px rgba(15, 23, 42, 0.38),
    0 0 0 1px rgba(167, 139, 250, 0.18) inset,
    0 0 64px rgba(124, 58, 237, 0.14);
}
@media (min-width: 1024px) {
  .contact-bento__primary {
    grid-template-columns: minmax(0, 1fr) 280px;
    align-items: stretch;
    gap: 2rem;
  }
}
.contact-bento__primary::before {
  content: "";
  position: absolute;
  inset: -1px;
  border-radius: inherit;
  padding: 1px;
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.55),
      rgba(124, 58, 237, 0.45) 45%,
      transparent 70%);
  -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
  -webkit-mask-composite: xor;
  mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
}
.contact-bento__primary > * {
  position: relative;
  z-index: 2;
}
.contact-bento__info {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  min-width: 0;
}
.contact-bento__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
.contact-bento__tag {
  font-family:
    ui-monospace,
    "Cascadia Code",
    "Source Code Pro",
    Menlo,
    monospace;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  color: #6ee7b7;
  opacity: 0.95;
}
.contact-bento__status {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.35rem 0.7rem 0.35rem 0.55rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #d1fae5;
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.35);
  border-radius: var(--radius-pill);
}
.contact-bento__status-dot {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 0 4px rgba(52, 211, 153, 0.2);
}
.contact-bento__status-dot::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: 50%;
  background: rgba(52, 211, 153, 0.4);
  animation: contactPulse 2.4s ease-out infinite;
}
@keyframes contactPulse {
  0% {
    transform: scale(0.6);
    opacity: 0.7;
  }
  80% {
    transform: scale(1.8);
    opacity: 0;
  }
  100% {
    transform: scale(1.8);
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .contact-bento__status-dot::after {
    animation: none;
  }
}
.contact-bento__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 3vw, 1.85rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  line-height: 1.15;
  color: #fafafa;
}
.contact-bento__lead {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: rgba(226, 232, 240, 0.78);
  max-width: 36rem;
}
.contact-bento__channel {
  margin-top: 0.35rem;
  padding-top: 1.15rem;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
.contact-bento__label {
  display: block;
  margin: 0 0 0.4rem;
  font-size: 0.66rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(196, 181, 253, 0.85);
}
.contact-bento__email {
  display: inline-block;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.6vw, 1.5rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: #fafafa;
  text-decoration: none;
  word-break: break-word;
  transition: color 0.2s var(--ease-out);
}
.contact-bento__email:hover {
  text-decoration: none;
  color: #67e8f9;
}
.contact-bento__email-kicker {
  display: block;
  margin-top: 0.25rem;
  font-size: 0.82rem;
  font-weight: 500;
  color: rgba(226, 232, 240, 0.55);
}
.contact-bento__messengers {
  display: flex;
  flex-wrap: wrap;
  gap: 0.55rem;
}
.contact-bento__messenger {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.6rem 1rem;
  font-size: 0.88rem;
  font-weight: 700;
  text-decoration: none;
  color: #f1f5f9;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: var(--radius-pill);
  transition:
    border-color 0.2s var(--ease-out),
    background 0.2s var(--ease-out),
    color 0.2s var(--ease-out),
    transform 0.2s var(--ease-out);
}
.contact-bento__messenger svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
.contact-bento__messenger:hover {
  text-decoration: none;
  transform: translateY(-1px);
}
.contact-bento__messenger--tg:hover {
  color: #fff;
  border-color: rgba(56, 189, 248, 0.6);
  background: rgba(14, 165, 233, 0.18);
}
.contact-bento__messenger--viber:hover {
  color: #fff;
  border-color: rgba(167, 139, 250, 0.6);
  background: rgba(124, 58, 237, 0.22);
}
@media (prefers-reduced-motion: reduce) {
  .contact-bento__messenger:hover {
    transform: none;
  }
}
.contact-bento__chat {
  display: none;
}
@media (min-width: 1024px) {
  .contact-bento__chat {
    position: relative;
    display: flex;
    flex-direction: column;
    align-self: stretch;
    max-height: 360px;
    border-radius: 18px;
    background:
      linear-gradient(
        170deg,
        rgba(15, 23, 42, 0.85) 0%,
        rgba(30, 27, 75, 0.7) 100%);
    border: 1px solid rgba(255, 255, 255, 0.08);
    box-shadow: 0 18px 40px rgba(0, 0, 0, 0.32), 0 0 0 1px rgba(167, 139, 250, 0.1) inset;
    overflow: hidden;
  }
}
.contact-bento__chat-head {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  padding: 0.7rem 0.85rem;
  background: rgba(15, 23, 42, 0.55);
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  backdrop-filter: blur(8px);
}
.contact-bento__chat-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #22d3ee 100%);
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(124, 58, 237, 0.4);
}
.contact-bento__chat-meta {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}
.contact-bento__chat-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: #f1f5f9;
}
.contact-bento__chat-presence {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.68rem;
  font-weight: 600;
  color: rgba(110, 231, 183, 0.85);
}
.contact-bento__chat-presence::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 0 2px rgba(52, 211, 153, 0.25);
}
.contact-bento__chat-body {
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.85rem 0.85rem 0.65rem;
  overflow: hidden;
}
.contact-bento__chat-day {
  align-self: center;
  padding: 0.18rem 0.55rem;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(226, 232, 240, 0.5);
  background: rgba(255, 255, 255, 0.04);
  border-radius: var(--radius-pill);
}
.contact-bento__chat-msg {
  max-width: 82%;
  padding: 0.55rem 0.75rem;
  font-size: 0.78rem;
  line-height: 1.45;
  border-radius: 14px;
  word-wrap: break-word;
}
.contact-bento__chat-msg--in {
  align-self: flex-start;
  color: #f1f5f9;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-bottom-left-radius: 4px;
}
.contact-bento__chat-msg--out {
  align-self: flex-end;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      #5b21b6 0%,
      #7c3aed 100%);
  border-bottom-right-radius: 4px;
  box-shadow: 0 6px 16px rgba(124, 58, 237, 0.35);
}
.contact-bento__chat-input {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 0.7rem;
  background: rgba(15, 23, 42, 0.6);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.contact-bento__chat-input-field {
  flex: 1 1 auto;
  padding: 0.45rem 0.7rem;
  font-size: 0.74rem;
  color: rgba(226, 232, 240, 0.55);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: var(--radius-pill);
}
.contact-bento__chat-send {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      #22d3ee 0%,
      #7c3aed 100%);
  border-radius: 50%;
  box-shadow: 0 4px 12px rgba(34, 211, 238, 0.35);
}
.contact-bento__chat-send svg {
  width: 12px;
  height: 12px;
}
.contact-bento__card {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  padding: 1.5rem 1.4rem 1.4rem;
  background: #fff;
  border: 1px solid rgba(9, 9, 11, 0.08);
  border-radius: var(--radius-lg);
  box-shadow: 0 4px 20px rgba(9, 9, 11, 0.04);
  transition:
    border-color 0.25s var(--ease-out),
    box-shadow 0.25s var(--ease-out),
    transform 0.25s var(--ease-out);
}
.contact-bento__card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  opacity: 0.5;
  z-index: 0;
}
.contact-bento__card--office::before {
  background-image:
    linear-gradient(
      0deg,
      transparent 95%,
      rgba(124, 58, 237, 0.08) 95%,
      rgba(124, 58, 237, 0.08) 100%),
    linear-gradient(
      90deg,
      transparent 95%,
      rgba(124, 58, 237, 0.08) 95%,
      rgba(124, 58, 237, 0.08) 100%);
  background-size: 24px 24px;
  -webkit-mask-image:
    radial-gradient(
      ellipse 80% 70% at 80% 0%,
      #000 0%,
      transparent 70%);
  mask-image:
    radial-gradient(
      ellipse 80% 70% at 80% 0%,
      #000 0%,
      transparent 70%);
}
.contact-bento__card--hours::before {
  background:
    radial-gradient(
      circle 200px at 100% 0%,
      rgba(34, 211, 238, 0.1) 0%,
      transparent 65%),
    radial-gradient(
      circle 160px at 100% 0%,
      transparent 58%,
      rgba(124, 58, 237, 0.12) 60%,
      transparent 62%);
}
.contact-bento__card > * {
  position: relative;
  z-index: 1;
}
.contact-bento__card:hover {
  border-color: rgba(124, 58, 237, 0.22);
  box-shadow: 0 12px 32px rgba(9, 9, 11, 0.08), 0 0 0 1px rgba(124, 58, 237, 0.06);
  transform: translateY(-2px);
}
@media (prefers-reduced-motion: reduce) {
  .contact-bento__card:hover {
    transform: none;
  }
}
.contact-bento__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  margin-bottom: 0.95rem;
  border-radius: 12px;
  color: var(--color-primary);
  background:
    linear-gradient(
      135deg,
      var(--color-primary-soft) 0%,
      rgba(34, 211, 238, 0.1) 100%);
  border: 1px solid rgba(124, 58, 237, 0.16);
}
.contact-bento__icon svg {
  width: 20px;
  height: 20px;
}
.contact-bento__card-title {
  margin: 0 0 0.45rem;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 2vw, 1.18rem);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.25;
  color: var(--color-text);
}
.contact-bento__card-text {
  margin: 0;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.contact-bento__card-action {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: auto;
  padding-top: 1rem;
  font-size: 0.9rem;
  font-weight: 700;
  color: var(--color-primary-dark);
  text-decoration: none;
  transition: color 0.2s var(--ease-out), gap 0.2s var(--ease-out);
}
.contact-bento__card-action:hover {
  text-decoration: none;
  color: var(--color-primary);
  gap: 0.6rem;
}
.contact-bento__card-action svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
}
.contact-bento__card-body {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
}

/* assets/css/src/pages/services.css */
.service-page {
  position: relative;
  padding-bottom: 0.5rem;
}
.service-page::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: min(52vh, 400px);
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 50% 75% at 8% 5%,
      rgba(124, 58, 237, 0.07) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 48% 70% at 94% 15%,
      rgba(34, 211, 238, 0.06) 0%,
      transparent 50%);
  z-index: 0;
}
.service-page .container {
  position: relative;
  z-index: 1;
}
.service-prose-shell {
  max-width: 46rem;
  margin: 0 auto;
  padding: clamp(1.35rem, 3vw, 2rem) clamp(1.2rem, 2.5vw, 1.85rem);
  border-radius: clamp(var(--radius-lg), 2vw, 26px);
  background:
    linear-gradient(
      165deg,
      rgba(255, 255, 255, 0.94) 0%,
      rgba(250, 250, 250, 0.98) 100%);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-glow), 0 16px 48px rgba(9, 9, 11, 0.05);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.service-prose-shell--wide {
  max-width: 100%;
}
.service-page--details {
  padding-top: clamp(2rem, 4vw, 3rem);
  padding-bottom: clamp(2rem, 4vw, 3rem);
}
.service-page--details::before {
  height: min(40vh, 320px);
  background:
    radial-gradient(
      ellipse 50% 75% at 8% 5%,
      rgba(124, 58, 237, 0.05) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 48% 70% at 94% 15%,
      rgba(34, 211, 238, 0.04) 0%,
      transparent 50%);
}
.service-prose-shell--details {
  position: relative;
  max-width: 56rem;
  overflow: hidden;
}
.service-prose-shell--details::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
  background:
    linear-gradient(
      90deg,
      #7c3aed 0%,
      #22d3ee 100%);
  opacity: 0.85;
  pointer-events: none;
}
.service-prose-shell--details + .service-prose-shell--details {
  margin-top: clamp(1.25rem, 2.5vw, 1.75rem);
}
.service-intro-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  padding-top: clamp(2rem, 4vw, 3.25rem);
  padding-bottom: clamp(2.25rem, 5vw, 3.75rem);
}
.service-intro-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.service-intro-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.55;
}
.service-intro-section__orb--1 {
  top: -10%;
  left: -10%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.5),
      transparent 70%);
}
.service-intro-section__orb--2 {
  bottom: -20%;
  right: -10%;
  width: 480px;
  height: 480px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.4),
      transparent 70%);
}
.service-intro {
  display: grid;
  gap: 2rem;
  align-items: center;
  grid-template-columns: 1fr;
  min-height: clamp(260px, 36vh, 380px);
}
@media (min-width: 900px) {
  .service-intro {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.95fr);
    gap: 3.5rem;
  }
}
.service-intro__content {
  position: relative;
  z-index: 1;
}
.service-intro__content .service-manifesto {
  max-width: none;
  margin: 0;
  padding: 0;
  background: none;
  border: 0;
  box-shadow: none;
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  overflow: visible;
  text-align: left;
}
.service-intro__content .service-manifesto::before,
.service-intro__content .service-manifesto::after {
  content: none;
}
.service-intro__content .service-manifesto__lead {
  font-size: clamp(1.02rem, 1.3vw, 1.15rem);
  line-height: 1.55;
}
.service-intro__content .service-manifesto__chips {
  justify-content: flex-start;
}
.service-intro__visual {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 260px;
  z-index: 1;
}
.service-intro-mock {
  position: relative;
  width: 100%;
  max-width: 380px;
  border-radius: clamp(14px, 1.6vw, 20px);
  overflow: hidden;
  background:
    linear-gradient(
      165deg,
      rgba(255, 255, 255, 0.96) 0%,
      rgba(244, 244, 245, 0.92) 100%);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow:
    0 30px 60px -28px rgba(15, 23, 42, 0.45),
    0 12px 24px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(124, 58, 237, 0.08);
  transform: rotate(-2deg) translateY(-4px);
  transition: transform 0.5s var(--ease-out);
  z-index: 1;
}
.service-intro__visual:hover .service-intro-mock:not(.service-intro-mock--ghost) {
  transform: rotate(-1deg) translateY(-8px);
}
@media (prefers-reduced-motion: reduce) {
  .service-intro-mock {
    transition: none;
  }
  .service-intro__visual:hover .service-intro-mock:not(.service-intro-mock--ghost) {
    transform: rotate(-2deg) translateY(-4px);
  }
}
.service-intro-mock--ghost {
  position: absolute;
  top: 6%;
  right: 4%;
  width: 78%;
  max-width: 300px;
  height: 240px;
  transform: rotate(5deg);
  z-index: 0;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.22) 0%,
      rgba(34, 211, 238, 0.18) 100%),
    rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow: 0 22px 48px -28px rgba(15, 23, 42, 0.4), 0 0 0 1px rgba(124, 58, 237, 0.1);
}
.service-intro-mock__chrome {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.95rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid rgba(15, 15, 20, 0.06);
}
.service-intro-mock__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.service-intro-mock__dot--r {
  background: #ff5f57;
}
.service-intro-mock__dot--y {
  background: #febc2e;
}
.service-intro-mock__dot--g {
  background: #28c840;
}
.service-intro-mock__url {
  margin-left: auto;
  width: 60%;
  height: 18px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
}
.service-intro-mock__view {
  padding: 1.1rem 1.1rem 1.25rem;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.service-intro-mock__hero {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  padding: 1.1rem 1rem;
  border-radius: 12px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.12) 0%,
      rgba(34, 211, 238, 0.12) 100%);
  border: 1px solid rgba(124, 58, 237, 0.08);
}
.service-intro-mock__title {
  display: block;
  height: 14px;
  border-radius: 99px;
  background:
    linear-gradient(
      90deg,
      rgba(124, 58, 237, 0.7),
      rgba(34, 211, 238, 0.5));
  width: 80%;
}
.service-intro-mock__title--short {
  width: 55%;
  opacity: 0.7;
}
.service-intro-mock__cta {
  margin-top: 0.4rem;
  display: block;
  width: 110px;
  height: 28px;
  border-radius: 999px;
  background:
    linear-gradient(
      90deg,
      #7c3aed,
      #22d3ee);
  box-shadow: 0 6px 14px -6px rgba(124, 58, 237, 0.5);
}
.service-intro-mock__tiles {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
}
.service-intro-mock__tile {
  aspect-ratio: 1;
  border-radius: 9px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.08) 0%,
      rgba(34, 211, 238, 0.08) 100%);
  border: 1px solid rgba(15, 15, 20, 0.05);
}
.service-intro-mock__tile:nth-child(2) {
  background:
    linear-gradient(
      135deg,
      rgba(34, 211, 238, 0.18) 0%,
      rgba(124, 58, 237, 0.1) 100%);
}
.service-intro-mock__rows {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.service-intro-mock__bar {
  display: block;
  height: 8px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.08);
}
.service-intro-mock__bar--short {
  width: 60%;
}
@media (max-width: 899px) {
  .service-intro {
    min-height: 0;
  }
  .service-intro__visual {
    min-height: 260px;
  }
  .service-intro-mock {
    max-width: 320px;
  }
  .service-intro-mock--ghost {
    display: none;
  }
}

/* assets/css/src/pages/service-intro-visuals.css */
.iv {
  --iv-grad:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #22d3ee 100%);
  --iv-grad-90:
    linear-gradient(
      90deg,
      #7c3aed 0%,
      #22d3ee 100%);
  --iv-surface: rgba(255, 255, 255, 0.96);
  --iv-surface-dim: rgba(244, 244, 245, 0.92);
  --iv-line: rgba(15, 15, 20, 0.07);
  --iv-text: #1c1c1f;
  --iv-muted: rgba(28, 28, 31, 0.55);
  --iv-shadow:
    0 30px 60px -28px rgba(15, 23, 42, 0.45),
    0 12px 24px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(124, 58, 237, 0.08);
  --iv-shadow-soft: 0 18px 40px -22px rgba(15, 23, 42, 0.4), 0 0 0 1px rgba(124, 58, 237, 0.08);
  --iv-radius: clamp(14px, 1.6vw, 20px);
  position: relative;
  width: 100%;
  max-width: 380px;
  color: var(--iv-text);
  font-family: var(--font-display);
}
.iv-card {
  position: relative;
  background: var(--iv-surface);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: var(--iv-radius);
  box-shadow: var(--iv-shadow);
  overflow: hidden;
}
@keyframes iv-float {
  0%, 100% {
    transform: translate3d(0, 0, 0);
  }
  50% {
    transform: translate3d(0, -6px, 0);
  }
}
@keyframes iv-pulse {
  0%, 100% {
    opacity: 0.55;
    transform: scale(1);
  }
  50% {
    opacity: 1;
    transform: scale(1.08);
  }
}
@keyframes iv-typing {
  0%, 60%, 100% {
    opacity: 0.25;
    transform: translateY(0);
  }
  30% {
    opacity: 1;
    transform: translateY(-2px);
  }
}
@media (prefers-reduced-motion: reduce) {
  .iv *,
  .iv *::before,
  .iv *::after {
    animation: none !important;
    transition: none !important;
  }
}
.iv-shop {
  transition: transform 0.5s var(--ease-out);
}
.service-intro__visual:hover .iv-shop {
  transform: translateY(-6px);
}
.iv-shop__card {
  position: relative;
  z-index: 2;
  display: flex;
  flex-direction: column;
}
.iv-shop__chrome {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 0.85rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--iv-line);
}
.iv-shop__chrome-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.iv-shop__chrome-dot--r {
  background: #ff5f57;
}
.iv-shop__chrome-dot--y {
  background: #febc2e;
}
.iv-shop__chrome-dot--g {
  background: #28c840;
}
.iv-shop__chrome-url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.18rem 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--iv-muted);
  letter-spacing: 0.01em;
}
.iv-shop__topbar {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.65rem 0.9rem;
  border-bottom: 1px solid var(--iv-line);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.6),
      rgba(255, 255, 255, 0.95));
}
.iv-shop__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
}
.iv-shop__brand-mark {
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: var(--iv-grad);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.45);
}
.iv-shop__brand-name {
  font-size: 0.75rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: var(--iv-text);
}
.iv-shop__nav {
  margin-left: 0.4rem;
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  flex: 1;
}
.iv-shop__nav-link {
  height: 6px;
  width: 26px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.1);
}
.iv-shop__nav-link:nth-child(2) {
  width: 32px;
}
.iv-shop__nav-link:nth-child(3) {
  width: 22px;
}
.iv-shop__cart {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 10px;
  background: rgba(124, 58, 237, 0.08);
  color: #5b21b6;
  flex-shrink: 0;
}
.iv-shop__cart-icon svg {
  width: 16px;
  height: 16px;
  display: block;
}
.iv-shop__cart-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 800;
  line-height: 16px;
  text-align: center;
  box-shadow: 0 0 0 2px #fff;
}
.iv-shop__featured {
  display: grid;
  grid-template-columns: 100px 1fr;
  gap: 0.85rem;
  padding: 0.9rem;
  border-bottom: 1px solid var(--iv-line);
}
.iv-shop__feat-thumb {
  position: relative;
  aspect-ratio: 1;
  border-radius: 10px;
  overflow: hidden;
  background:
    radial-gradient(
      circle at 30% 25%,
      rgba(255, 255, 255, 0.55),
      transparent 55%),
    linear-gradient(
      135deg,
      #efe9dc 0%,
      #c9b89a 60%,
      #6a5a3f 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4), inset 0 -16px 32px rgba(0, 0, 0, 0.15);
}
.iv-shop__feat-thumb::before {
  content: "";
  position: absolute;
  top: -25%;
  right: -15%;
  width: 70%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(
      circle,
      rgba(255, 255, 255, 0.55),
      transparent 65%);
  filter: blur(4px);
}
.iv-shop__feat-sale {
  position: absolute;
  top: 6px;
  left: 6px;
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.58rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  box-shadow: 0 6px 14px -6px rgba(124, 58, 237, 0.55);
}
.iv-shop__feat-info {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  min-width: 0;
}
.iv-shop__feat-cat {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--iv-muted);
}
.iv-shop__feat-name {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--iv-text);
  letter-spacing: -0.01em;
  line-height: 1.2;
}
.iv-shop__feat-price {
  display: flex;
  align-items: baseline;
  gap: 0.4rem;
  margin-top: 0.1rem;
}
.iv-shop__feat-now {
  font-size: 1rem;
  font-weight: 800;
  background: var(--iv-grad-90);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.02em;
}
.iv-shop__feat-old {
  font-size: 0.7rem;
  color: var(--iv-muted);
  text-decoration: line-through;
}
.iv-shop__feat-buy {
  align-self: flex-start;
  margin-top: 0.3rem;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  box-shadow: 0 8px 16px -8px rgba(124, 58, 237, 0.55);
}
.iv-shop__catalog {
  padding: 0.75rem 0.9rem 0.95rem;
}
.iv-shop__cat-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: 0.5rem;
}
.iv-shop__cat-title {
  font-size: 0.6rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--iv-muted);
}
.iv-shop__cat-link {
  font-size: 0.62rem;
  font-weight: 700;
  color: #5b21b6;
}
.iv-shop__cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
}
.iv-shop__cat-item {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.iv-shop__cat-thumb {
  aspect-ratio: 1;
  border-radius: 9px;
  border: 1px solid var(--iv-line);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
.iv-shop__cat-item--a .iv-shop__cat-thumb {
  background:
    radial-gradient(
      circle at 30% 25%,
      rgba(255, 255, 255, 0.5),
      transparent 55%),
    linear-gradient(
      135deg,
      #fde7d2 0%,
      #f3a36a 60%,
      #b46127 100%);
}
.iv-shop__cat-item--b .iv-shop__cat-thumb {
  background:
    radial-gradient(
      circle at 30% 25%,
      rgba(255, 255, 255, 0.55),
      transparent 55%),
    linear-gradient(
      135deg,
      #dfe7ff 0%,
      #8094f0 60%,
      #3f4ea8 100%);
}
.iv-shop__cat-item--c .iv-shop__cat-thumb {
  background:
    radial-gradient(
      circle at 30% 25%,
      rgba(255, 255, 255, 0.55),
      transparent 55%),
    linear-gradient(
      135deg,
      #d8f2e9 0%,
      #62c9a6 60%,
      #1f7a5d 100%);
}
.iv-shop__cat-price {
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--iv-text);
  letter-spacing: -0.01em;
}
.iv-landing__chrome {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 0.85rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--iv-line);
}
.iv-landing__chrome span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(15, 15, 20, 0.18);
}
.iv-landing__chrome span:nth-child(1) {
  background: #ff5f57;
}
.iv-landing__chrome span:nth-child(2) {
  background: #febc2e;
}
.iv-landing__chrome span:nth-child(3) {
  background: #28c840;
}
.iv-landing__url {
  margin-left: 0.5rem;
  flex: 1;
  height: 14px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--iv-line);
}
.iv-landing__hero {
  padding: 1.05rem 1.1rem 0.9rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
  background:
    radial-gradient(
      ellipse 80% 60% at 80% 0%,
      rgba(34, 211, 238, 0.22),
      transparent 60%),
    radial-gradient(
      ellipse 80% 60% at 0% 100%,
      rgba(124, 58, 237, 0.18),
      transparent 60%);
}
.iv-landing__kicker {
  display: inline-block;
  width: fit-content;
  padding: 0.2rem 0.55rem;
  border-radius: 999px;
  background: rgba(124, 58, 237, 0.12);
  color: #5b21b6;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.iv-landing__title {
  margin: 0;
  font-size: 1.4rem;
  line-height: 1.1;
  font-weight: 800;
  letter-spacing: -0.025em;
}
.iv-landing__title b {
  background: var(--iv-grad-90);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  font-weight: 800;
}
.iv-landing__lead {
  height: 8px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.1);
  width: 90%;
}
.iv-landing__lead--short {
  width: 65%;
}
.iv-landing__actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.35rem;
}
.iv-landing__cta {
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  box-shadow: 0 8px 18px -8px rgba(124, 58, 237, 0.5);
}
.iv-landing__cta-ghost {
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid var(--iv-line);
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--iv-text);
}
.iv-landing__panel {
  padding: 0.7rem 0.95rem 0.85rem;
  border-top: 1px solid var(--iv-line);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.6),
      rgba(255, 255, 255, 0.95));
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.iv-landing__stats {
  display: flex;
  align-items: stretch;
  gap: 0.75rem;
}
.iv-landing__stat {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  min-width: 0;
}
.iv-landing__stat-divider {
  width: 1px;
  background: var(--iv-line);
  margin: 0.15rem 0;
}
.iv-landing__stat-label {
  font-size: 0.58rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.iv-landing__stat-value {
  font-size: 1.05rem;
  font-weight: 800;
  background: var(--iv-grad-90);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.02em;
  line-height: 1.1;
}
.iv-landing__stat-trend {
  font-size: 0.62rem;
  font-weight: 700;
  color: #16a34a;
  letter-spacing: 0.02em;
}
.iv-landing__sparkline {
  width: 100%;
  height: 26px;
  display: block;
  overflow: visible;
}
.iv-crm {
  transform: rotate(-1.5deg);
  transition: transform 0.5s var(--ease-out);
}
.service-intro__visual:hover .iv-crm {
  transform: rotate(-0.5deg) translateY(-6px);
}
.iv-crm__topbar {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.7rem 0.9rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--iv-line);
}
.iv-crm__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.iv-crm__brand::before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 6px;
  background: var(--iv-grad);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
}
.iv-crm__avatar {
  margin-left: auto;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--iv-grad-90);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}
.iv-crm__kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  padding: 0.85rem 0.95rem;
  border-bottom: 1px solid var(--iv-line);
}
.iv-crm__kpi {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  padding: 0.55rem 0.5rem;
  background: rgba(124, 58, 237, 0.06);
  border-radius: 10px;
  border: 1px solid rgba(124, 58, 237, 0.08);
}
.iv-crm__kpi-value {
  font-size: 0.95rem;
  font-weight: 800;
  color: #5b21b6;
  letter-spacing: -0.02em;
}
.iv-crm__kpi-label {
  font-size: 0.55rem;
  font-weight: 600;
  color: var(--iv-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.iv-crm__board {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.5rem;
  padding: 0.85rem 0.95rem 1rem;
}
.iv-crm__col {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.iv-crm__col-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.55rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--iv-muted);
}
.iv-crm__col-head::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
  margin-right: 4px;
  opacity: 0.5;
}
.iv-crm__col--lead .iv-crm__col-head {
  color: #6366f1;
}
.iv-crm__col--neg .iv-crm__col-head {
  color: #f59e0b;
}
.iv-crm__col--won .iv-crm__col-head {
  color: #16a34a;
}
.iv-crm__deal {
  padding: 0.5rem 0.55rem;
  background: #fff;
  border-radius: 8px;
  border: 1px solid var(--iv-line);
  box-shadow: 0 2px 6px -2px rgba(15, 23, 42, 0.08);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.iv-crm__deal--active {
  border-color: rgba(124, 58, 237, 0.3);
  box-shadow: 0 4px 12px -4px rgba(124, 58, 237, 0.25), 0 0 0 2px rgba(124, 58, 237, 0.12);
  transform: translateY(-1px);
}
.iv-crm__deal-name {
  height: 6px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.15);
  width: 80%;
}
.iv-crm__deal-amount {
  font-size: 0.65rem;
  font-weight: 800;
  color: var(--iv-text);
}
.iv-crm__col--won .iv-crm__deal-amount {
  color: #16a34a;
}
.iv-crm__deal--active .iv-crm__deal-amount {
  background: var(--iv-grad-90);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.iv-quiz {
  --iv-quiz-accent: #5b21b6;
  --iv-quiz-accent-soft: rgba(124, 58, 237, 0.1);
  transition: transform 0.5s var(--ease-out);
  filter: drop-shadow(0 24px 36px rgba(124, 58, 237, 0.18));
}
.service-intro__visual:hover .iv-quiz {
  transform: translateY(-6px);
}
.iv-quiz__card {
  display: flex;
  flex-direction: column;
}
.iv-quiz__chrome {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.55rem 0.85rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--iv-line);
}
.iv-quiz__chrome-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
}
.iv-quiz__chrome-dot--r {
  background: #ff5f57;
}
.iv-quiz__chrome-dot--y {
  background: #febc2e;
}
.iv-quiz__chrome-dot--g {
  background: #28c840;
}
.iv-quiz__chrome-url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.18rem 0.7rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.68rem;
  font-weight: 500;
  color: var(--iv-muted);
  letter-spacing: 0.01em;
}
.iv-quiz__view {
  padding: 0.95rem 1rem 1.05rem;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
  background:
    radial-gradient(
      ellipse 70% 50% at 100% 0%,
      rgba(34, 211, 238, 0.12),
      transparent 60%),
    var(--iv-surface);
}
.iv-quiz__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}
.iv-quiz__brand {
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.16em;
  color: var(--iv-text);
}
.iv-quiz__step {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.04em;
}
.iv-quiz__progress {
  height: 4px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.06);
  overflow: hidden;
}
.iv-quiz__progress-bar {
  display: block;
  height: 100%;
  width: 60%;
  border-radius: 99px;
  background: var(--iv-grad-90);
  box-shadow: 0 0 8px rgba(124, 58, 237, 0.4);
}
.iv-quiz__kicker {
  margin-top: 0.1rem;
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--iv-quiz-accent);
}
.iv-quiz__question {
  margin: 0;
  font-family: var(--font-display, inherit);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1.25;
  letter-spacing: -0.01em;
  color: var(--iv-text);
}
.iv-quiz__options {
  list-style: none;
  margin: 0.15rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.iv-quiz__opt {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.5rem 0.7rem;
  border-radius: 10px;
  border: 1px solid var(--iv-line);
  background: rgba(255, 255, 255, 0.85);
}
.iv-quiz__opt-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 8px;
  background: var(--iv-quiz-accent-soft);
  color: var(--iv-quiz-accent);
  font-size: 0.78rem;
  font-weight: 800;
  line-height: 1;
}
.iv-quiz__opt-body {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  min-width: 0;
}
.iv-quiz__opt-label {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--iv-text);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.iv-quiz__opt-meta {
  font-size: 0.6rem;
  color: var(--iv-muted);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.iv-quiz__opt-radio {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid rgba(15, 15, 20, 0.2);
  flex-shrink: 0;
}
.iv-quiz__opt--active {
  background:
    linear-gradient(
      120deg,
      rgba(124, 58, 237, 0.08),
      rgba(34, 211, 238, 0.06));
  border-color: rgba(124, 58, 237, 0.3);
  box-shadow: 0 4px 12px -4px rgba(124, 58, 237, 0.2);
}
.iv-quiz__opt--active .iv-quiz__opt-icon {
  background: var(--iv-grad);
  color: #fff;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.5);
}
.iv-quiz__opt--active .iv-quiz__opt-radio {
  background: var(--iv-grad-90);
  border-color: transparent;
  position: relative;
}
.iv-quiz__opt--active .iv-quiz__opt-radio::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: #fff;
}
.iv-quiz__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 0.2rem;
  padding-top: 0.55rem;
  border-top: 1px solid var(--iv-line);
}
.iv-quiz__back {
  padding: 0.35rem 0.7rem;
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--iv-muted);
  border-radius: 999px;
}
.iv-quiz__next {
  padding: 0.4rem 0.95rem;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  box-shadow: 0 8px 16px -8px rgba(124, 58, 237, 0.5);
}
.iv-quiz__badge {
  position: absolute;
  z-index: 3;
  top: -10px;
  right: 12px;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.4rem 0.7rem 0.4rem 0.6rem;
  border-radius: 999px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  box-shadow: 0 12px 24px -10px rgba(124, 58, 237, 0.55), 0 0 0 4px rgba(255, 255, 255, 0.85);
  animation: iv-float 5s ease-in-out infinite;
}
.iv-quiz__badge-icon {
  font-size: 0.85rem;
  line-height: 1;
  text-shadow: 0 0 10px rgba(255, 255, 255, 0.7);
}
.iv-tg {
  --iv-tg-bg: #e6ecf2;
  background:
    linear-gradient(
      160deg,
      #f0f4f8 0%,
      #d8e2ec 100%);
  border-radius: 28px;
  padding: 14px;
  box-shadow:
    0 30px 60px -28px rgba(15, 23, 42, 0.45),
    0 0 0 1px rgba(124, 58, 237, 0.08),
    inset 0 0 0 1px rgba(255, 255, 255, 0.5);
}
.iv-tg__screen {
  border-radius: 18px;
  overflow: hidden;
  background: var(--iv-tg-bg);
  box-shadow: inset 0 0 0 1px rgba(15, 15, 20, 0.05);
}
.iv-tg__header {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.75rem 0.85rem;
  background:
    linear-gradient(
      180deg,
      #fff 0%,
      rgba(255, 255, 255, 0.85) 100%);
  border-bottom: 1px solid rgba(15, 15, 20, 0.06);
}
.iv-tg__avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--iv-grad);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.4);
  color: #fff;
  font-size: 0.75rem;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.iv-tg__name {
  display: flex;
  flex-direction: column;
}
.iv-tg__name-main {
  font-size: 0.78rem;
  font-weight: 700;
}
.iv-tg__name-status {
  font-size: 0.6rem;
  color: #16a34a;
  font-weight: 600;
}
.iv-tg__feed {
  padding: 0.7rem 0.7rem 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  min-height: 200px;
}
.iv-tg__msg {
  display: flex;
  max-width: 80%;
}
.iv-tg__msg--bot {
  align-self: flex-start;
}
.iv-tg__msg--me {
  align-self: flex-end;
}
.iv-tg__bubble {
  padding: 0.5rem 0.7rem;
  border-radius: 14px;
  font-size: 0.74rem;
  line-height: 1.35;
  font-weight: 500;
  box-shadow: 0 2px 4px -2px rgba(15, 23, 42, 0.1);
}
.iv-tg__msg--bot .iv-tg__bubble {
  background: #fff;
  border-bottom-left-radius: 4px;
  color: var(--iv-text);
}
.iv-tg__msg--me .iv-tg__bubble {
  background: var(--iv-grad);
  border-bottom-right-radius: 4px;
  color: #fff;
}
.iv-tg__keyboard {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
  margin-top: 6px;
}
.iv-tg__kbtn {
  padding: 0.4rem 0.5rem;
  border-radius: 8px;
  background: rgba(124, 58, 237, 0.1);
  color: #5b21b6;
  font-size: 0.68rem;
  font-weight: 700;
  text-align: center;
}
.iv-tg__kbtn--full {
  grid-column: span 2;
}
.iv-tg__typing {
  align-self: flex-start;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0.55rem 0.75rem;
  border-radius: 14px;
  border-bottom-left-radius: 4px;
  background: #fff;
  box-shadow: 0 2px 4px -2px rgba(15, 23, 42, 0.1);
}
.iv-tg__typing i {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(124, 58, 237, 0.55);
  animation: iv-typing 1.4s infinite;
}
.iv-tg__typing i:nth-child(2) {
  animation-delay: 0.2s;
}
.iv-tg__typing i:nth-child(3) {
  animation-delay: 0.4s;
}
.iv-ads {
  padding: 0.95rem 0.95rem 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.iv-ads__search {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 0.75rem;
  border-radius: 999px;
  background: #fff;
  border: 1px solid var(--iv-line);
  box-shadow: 0 4px 10px -4px rgba(15, 23, 42, 0.08);
}
.iv-ads__search::before {
  content: "";
  width: 12px;
  height: 12px;
  border: 1.5px solid var(--iv-muted);
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
}
.iv-ads__search-text {
  flex: 1;
  height: 8px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.1);
  width: 60%;
}
.iv-ads__result {
  padding: 0.85rem 0.85rem 0.95rem;
  border-radius: 12px;
  background:
    linear-gradient(
      165deg,
      #fff 0%,
      rgba(244, 244, 245, 0.95) 100%);
  border: 1px solid var(--iv-line);
  box-shadow: 0 6px 16px -8px rgba(15, 23, 42, 0.12);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  position: relative;
}
.iv-ads__badge {
  display: inline-block;
  width: fit-content;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  background: var(--iv-grad-90);
  color: #fff;
  font-size: 0.6rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.iv-ads__url {
  font-size: 0.65rem;
  color: var(--iv-muted);
  font-weight: 500;
}
.iv-ads__title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 700;
  color: #1a0dab;
  line-height: 1.25;
  letter-spacing: -0.01em;
}
.iv-ads__desc {
  height: 6px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.1);
  width: 95%;
}
.iv-ads__desc--short {
  width: 70%;
}
.iv-ads__sitelinks {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.2rem;
}
.iv-ads__sitelink {
  flex: 1;
  height: 6px;
  border-radius: 99px;
  background: rgba(124, 58, 237, 0.18);
}
.iv-ads__chart {
  display: flex;
  align-items: flex-end;
  gap: 5px;
  height: 56px;
  padding: 0.7rem 0.85rem 0;
  border-top: 1px solid var(--iv-line);
}
.iv-ads__chart i {
  flex: 1;
  border-radius: 3px 3px 0 0;
  background:
    linear-gradient(
      180deg,
      #22d3ee 0%,
      rgba(124, 58, 237, 0.6) 100%);
  opacity: 0.85;
}
.iv-ads__chart i:nth-child(1) {
  height: 40%;
}
.iv-ads__chart i:nth-child(2) {
  height: 55%;
}
.iv-ads__chart i:nth-child(3) {
  height: 70%;
}
.iv-ads__chart i:nth-child(4) {
  height: 60%;
}
.iv-ads__chart i:nth-child(5) {
  height: 85%;
}
.iv-ads__chart i:nth-child(6) {
  height: 75%;
}
.iv-ads__chart i:nth-child(7) {
  height: 100%;
  background:
    linear-gradient(
      180deg,
      #fff 0%,
      #22d3ee 100%);
  box-shadow: 0 0 12px rgba(34, 211, 238, 0.5);
  opacity: 1;
}
.iv-ads__chart-label {
  position: absolute;
  bottom: 12px;
  right: 12px;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.12);
  color: #15803d;
  font-size: 0.65rem;
  font-weight: 800;
}
.iv-seo {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.iv-seo__top {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.8rem;
  border-radius: 14px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.1) 0%,
      rgba(34, 211, 238, 0.08) 100%);
  border: 1px solid rgba(124, 58, 237, 0.15);
  position: relative;
  overflow: hidden;
}
.iv-seo__top::after {
  content: "";
  position: absolute;
  top: -40%;
  right: -10%;
  width: 60%;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.3),
      transparent 65%);
  filter: blur(10px);
}
.iv-seo__rank {
  position: relative;
  flex-shrink: 0;
  width: 42px;
  height: 42px;
  border-radius: 12px;
  background: var(--iv-grad);
  color: #fff;
  font-size: 1.1rem;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  letter-spacing: -0.02em;
  box-shadow: 0 6px 14px -4px rgba(124, 58, 237, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.4);
}
.iv-seo__rank::before {
  content: "#";
  font-size: 0.7rem;
  margin-right: 1px;
  opacity: 0.85;
}
.iv-seo__top-meta {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.iv-seo__top-label {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.iv-seo__top-query {
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: -0.01em;
}
.iv-seo__trend {
  margin-left: auto;
  position: relative;
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.15);
  color: #15803d;
  font-size: 0.7rem;
  font-weight: 800;
  display: inline-flex;
  align-items: center;
  gap: 3px;
}
.iv-seo__trend::before {
  content: "\2191";
  font-weight: 900;
}
.iv-seo__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
}
.iv-seo__chip {
  padding: 0.3rem 0.65rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--iv-line);
  font-size: 0.66rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.02em;
}
.iv-seo__chip--accent {
  background: rgba(124, 58, 237, 0.1);
  color: #5b21b6;
  border-color: rgba(124, 58, 237, 0.18);
}
.iv-seo__ladder {
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  padding: 0.8rem;
  border-radius: 12px;
  background: rgba(15, 15, 20, 0.03);
}
.iv-seo__rung {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.68rem;
  font-weight: 600;
}
.iv-seo__rung-pos {
  width: 22px;
  text-align: center;
  font-weight: 800;
  color: var(--iv-muted);
}
.iv-seo__rung-bar {
  flex: 1;
  height: 6px;
  border-radius: 99px;
  background: rgba(15, 15, 20, 0.08);
  position: relative;
  overflow: hidden;
}
.iv-seo__rung-bar::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 99px;
  background: var(--iv-grad-90);
  width: var(--p, 50%);
}
.iv-seo__rung-delta {
  width: 36px;
  text-align: right;
  font-size: 0.62rem;
  font-weight: 800;
  color: #15803d;
}
.iv-promo {
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}
.iv-promo__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}
.iv-promo__head-meta {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
}
.iv-promo__label {
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
}
.iv-promo__value {
  font-size: 1.5rem;
  font-weight: 800;
  background: var(--iv-grad-90);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: -0.02em;
  line-height: 1;
}
.iv-promo__delta {
  padding: 0.3rem 0.55rem;
  border-radius: 999px;
  background: rgba(22, 163, 74, 0.14);
  color: #15803d;
  font-size: 0.7rem;
  font-weight: 800;
  height: fit-content;
}
.iv-promo__delta::before {
  content: "\2191  ";
}
.iv-promo__chart {
  position: relative;
  height: 96px;
  border-radius: 10px;
  background: rgba(124, 58, 237, 0.04);
  overflow: hidden;
}
.iv-promo__chart svg {
  display: block;
  width: 100%;
  height: 100%;
}
.iv-promo__sources {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.4rem;
}
.iv-promo__source {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0.55rem 0.6rem;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--iv-line);
}
.iv-promo__source-label {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 0.6rem;
  font-weight: 700;
  color: var(--iv-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.iv-promo__source-label::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--iv-src-color, #7c3aed);
}
.iv-promo__source--organic {
  --iv-src-color: #7c3aed;
}
.iv-promo__source--ads {
  --iv-src-color: #22d3ee;
}
.iv-promo__source--social {
  --iv-src-color: #f59e0b;
}
.iv-promo__source-value {
  font-size: 0.85rem;
  font-weight: 800;
  color: var(--iv-text);
  letter-spacing: -0.01em;
}
@media (max-width: 899px) {
  .iv {
    max-width: 320px;
  }
  .iv-quiz__badge {
    top: -8px;
    right: 8px;
    font-size: 0.6rem;
    padding: 0.32rem 0.6rem 0.32rem 0.5rem;
  }
}

/* assets/css/src/pages/mobile-app.css */
.mobile-intro-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.mobile-intro-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.mobile-intro-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(90px);
  opacity: 0.55;
}
.mobile-intro-section__orb--1 {
  top: -10%;
  left: -10%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.5),
      transparent 70%);
}
.mobile-intro-section__orb--2 {
  bottom: -20%;
  right: -10%;
  width: 480px;
  height: 480px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.4),
      transparent 70%);
}
.mobile-intro {
  display: grid;
  gap: 2.5rem;
  align-items: center;
  grid-template-columns: 1fr;
}
@media (min-width: 900px) {
  .mobile-intro {
    grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
    gap: 3.5rem;
  }
}
.mobile-intro__content .service-manifesto {
  margin-bottom: 1.75rem;
}
.mobile-intro__prose {
  margin: 0;
  max-width: none;
}
.mobile-intro__prose h2 {
  margin: 0 0 0.85rem;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 2.2vw, 1.8rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.mobile-intro__prose p {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.65;
  color: var(--color-muted);
}
.mobile-intro__visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 460px;
}
.mobile-intro__visual::before,
.mobile-intro__visual::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.mobile-intro__visual::before {
  width: 320px;
  height: 320px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.18),
      transparent 70%);
  filter: blur(40px);
  z-index: 0;
}
.mobile-intro__visual::after {
  width: 240px;
  height: 240px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.16),
      transparent 70%);
  filter: blur(40px);
  transform: translate(60%, 30%);
  z-index: 0;
}
.phone {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 260px;
  aspect-ratio: 9 / 19;
  padding: 12px;
  background:
    linear-gradient(
      150deg,
      #1c1c1f 0%,
      #0a0a0c 100%);
  border-radius: 2.6rem;
  box-shadow:
    0 30px 60px -25px rgba(15, 23, 42, 0.45),
    0 12px 24px -12px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(255, 255, 255, 0.04),
    inset 0 0 0 2px rgba(255, 255, 255, 0.06);
  transition: transform 0.6s var(--ease-out);
}
.phone--solo {
  transform: rotate(-3deg);
}
.mobile-intro__visual:hover .phone--solo {
  transform: rotate(-1deg) translateY(-4px);
}
.phone__notch {
  position: absolute;
  top: 18px;
  left: 50%;
  transform: translateX(-50%);
  width: 88px;
  height: 24px;
  background: #000;
  border-radius: 14px;
  z-index: 3;
}
.phone__notch::before {
  content: "";
  position: absolute;
  top: 50%;
  right: 14px;
  transform: translateY(-50%);
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 35% 35%,
      #1e293b,
      #0f172a 70%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.1);
}
.phone__screen {
  position: relative;
  height: 100%;
  border-radius: 2rem;
  overflow: hidden;
  background:
    radial-gradient(
      ellipse at 30% 0%,
      rgba(124, 58, 237, 0.55) 0%,
      transparent 55%),
    radial-gradient(
      ellipse at 80% 100%,
      rgba(34, 211, 238, 0.35) 0%,
      transparent 55%),
    linear-gradient(
      160deg,
      #1e1b4b 0%,
      #0b1220 100%);
  color: #fff;
  padding: 2.5rem 0.7rem 0.7rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.phone__status {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  opacity: 0.9;
  padding: 0 0.4rem;
}
.phone__icons {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.phone__icons i {
  display: inline-block;
  background: currentColor;
  border-radius: 1px;
  opacity: 0.85;
}
.phone__signal {
  width: 12px;
  height: 8px;
  clip-path: polygon(0 100%, 25% 60%, 25% 100%, 50% 35%, 50% 100%, 75% 15%, 75% 100%, 100% 0, 100% 100%);
}
.phone__wifi {
  width: 10px;
  height: 8px;
  clip-path: polygon(50% 0, 100% 40%, 85% 55%, 50% 25%, 15% 55%, 0 40%);
}
.phone__battery {
  width: 16px;
  height: 8px;
  border-radius: 2px;
  background: transparent !important;
  border: 1px solid currentColor;
  position: relative;
}
.phone__battery::before {
  content: "";
  position: absolute;
  inset: 1px;
  width: 10px;
  background: currentColor;
  border-radius: 1px;
}
.phone__battery::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -3px;
  transform: translateY(-50%);
  width: 2px;
  height: 4px;
  background: currentColor;
  border-radius: 0 1px 1px 0;
  opacity: 0.85;
}
.phone-app__header {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.15rem 0.25rem;
}
.phone-app__avatar {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 10px;
  background:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #22d3ee 100%);
  font-family: var(--font-display);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  color: #fff;
  box-shadow: 0 4px 10px -4px rgba(124, 58, 237, 0.6), inset 0 1px 0 rgba(255, 255, 255, 0.25);
}
.phone-app__greeting {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  min-width: 0;
}
.phone-app__hello {
  font-size: 0.62rem;
  opacity: 0.7;
  font-weight: 500;
}
.phone-app__studio {
  font-family: var(--font-display);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.01em;
}
.phone-app__bell {
  position: relative;
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.phone-app__bell::before {
  content: "";
  position: absolute;
  inset: 0;
  margin: auto;
  width: 12px;
  height: 12px;
  background: #fff;
  opacity: 0.85;
  clip-path: polygon(50% 5%, 75% 25%, 75% 60%, 85% 75%, 15% 75%, 25% 60%, 25% 25%);
}
.phone-app__bell-dot {
  position: absolute;
  top: 5px;
  right: 5px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #ef4444;
  box-shadow: 0 0 6px rgba(239, 68, 68, 0.6);
}
.phone-app__hero {
  position: relative;
  padding: 0.85rem 0.85rem 0.7rem;
  border-radius: 1rem;
  background:
    linear-gradient(
      140deg,
      rgba(255, 255, 255, 0.18) 0%,
      rgba(255, 255, 255, 0.06) 100%);
  border: 1px solid rgba(255, 255, 255, 0.14);
  backdrop-filter: blur(8px);
  box-shadow: 0 6px 18px -10px rgba(0, 0, 0, 0.45);
  overflow: hidden;
}
.phone-app__hero::after {
  content: "";
  position: absolute;
  top: -30%;
  right: -10%;
  width: 80%;
  height: 80%;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.35),
      transparent 70%);
  pointer-events: none;
}
.phone-app__hero-top {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}
.phone-app__hero-label {
  font-size: 0.66rem;
  font-weight: 500;
  opacity: 0.78;
}
.phone-app__hero-delta {
  font-size: 0.6rem;
  font-weight: 600;
  color: #4ade80;
  padding: 0.1rem 0.4rem;
  border-radius: 99px;
  background: rgba(74, 222, 128, 0.18);
}
.phone-app__hero-value {
  position: relative;
  display: block;
  margin-top: 0.2rem;
  font-family: var(--font-display);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.25);
}
.phone-app__chart {
  position: relative;
  display: flex;
  align-items: flex-end;
  gap: 4px;
  height: 32px;
  margin-top: 0.55rem;
}
.phone-app__chart i {
  flex: 1;
  display: block;
  height: var(--h, 50%);
  border-radius: 3px 3px 0 0;
  background:
    linear-gradient(
      180deg,
      #22d3ee 0%,
      rgba(124, 58, 237, 0.4) 100%);
  opacity: 0.85;
}
.phone-app__chart i:last-child {
  background:
    linear-gradient(
      180deg,
      #fff 0%,
      #22d3ee 100%);
  opacity: 1;
  box-shadow: 0 0 10px rgba(34, 211, 238, 0.5);
}
.phone-app__stats {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0.4rem;
}
.phone-app__stat {
  padding: 0.6rem 0.7rem;
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}
.phone-app__stat-label {
  font-size: 0.6rem;
  opacity: 0.7;
  font-weight: 500;
}
.phone-app__stat-value {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.phone-app__section-title {
  margin-top: 0.15rem;
  padding: 0 0.25rem;
  font-size: 0.62rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  opacity: 0.65;
}
.phone-app__projects {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
  flex: 1;
}
.phone-app__project {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  padding: 0.55rem;
  border-radius: 0.85rem;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.1);
}
.phone-app__project-thumb {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  border-radius: 8px;
  box-shadow: 0 4px 8px -4px rgba(0, 0, 0, 0.5), inset 0 1px 0 rgba(255, 255, 255, 0.25);
}
.phone-app__project-thumb--1 {
  background:
    linear-gradient(
      135deg,
      #f97316,
      #ec4899);
}
.phone-app__project-thumb--2 {
  background:
    linear-gradient(
      135deg,
      #6366f1,
      #22d3ee);
}
.phone-app__project-body {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
  min-width: 0;
}
.phone-app__project-name {
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1.2;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.phone-app__project-meta {
  font-size: 0.58rem;
  opacity: 0.7;
  font-weight: 500;
}
.phone-app__project-bar {
  display: block;
  height: 3px;
  border-radius: 99px;
  background: rgba(255, 255, 255, 0.14);
  overflow: hidden;
}
.phone-app__project-bar i {
  display: block;
  height: 100%;
  width: var(--p, 50%);
  border-radius: 99px;
  background:
    linear-gradient(
      90deg,
      #7c3aed,
      #22d3ee);
  box-shadow: 0 0 6px rgba(34, 211, 238, 0.4);
}
@media (prefers-reduced-motion: reduce) {
  .phone {
    transition: none;
  }
  .mobile-intro__visual:hover .phone--solo {
    transform: rotate(-3deg);
  }
}
.mobile-deliverables-section {
  position: relative;
}
.mobile-deliverables-section__header {
  text-align: center;
  max-width: 42rem;
  margin: 0 auto;
}
.mobile-deliverables-section__header .section-title,
.mobile-deliverables-section__header .section-lead {
  text-align: center;
}
.mobile-deliverables-grid {
  margin-top: 2.75rem;
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .mobile-deliverables-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1080px) {
  .mobile-deliverables-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.mobile-deliverables-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding: 1.6rem 1.5rem;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  transition:
    box-shadow 0.28s var(--ease-out),
    border-color 0.28s var(--ease-out),
    transform 0.28s var(--ease-out);
  overflow: hidden;
}
.mobile-deliverables-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background:
    linear-gradient(
      90deg,
      #7c3aed,
      #22d3ee);
  opacity: 0;
  transition: opacity 0.28s var(--ease-out);
}
.mobile-deliverables-card:hover {
  box-shadow: var(--shadow-hover), var(--shadow-glow);
  border-color: rgba(124, 58, 237, 0.18);
  transform: translateY(-3px);
}
.mobile-deliverables-card:hover::before {
  opacity: 1;
}
.mobile-deliverables-card__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 14px;
  background:
    linear-gradient(
      135deg,
      rgba(124, 58, 237, 0.12),
      rgba(34, 211, 238, 0.12));
  font-size: 1.5rem;
  line-height: 1;
}
.mobile-deliverables-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.3;
}
.mobile-deliverables-card__text {
  margin: 0;
  font-size: 0.92rem;
  color: var(--color-muted);
  line-height: 1.6;
}
.mobile-process-section {
  position: relative;
  overflow: hidden;
}
.mobile-process-section::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: min(60vh, 480px);
  pointer-events: none;
  background:
    radial-gradient(
      ellipse 55% 80% at 5% 10%,
      rgba(124, 58, 237, 0.06) 0%,
      transparent 60%),
    radial-gradient(
      ellipse 50% 70% at 95% 20%,
      rgba(34, 211, 238, 0.05) 0%,
      transparent 55%);
  z-index: 0;
}
.mobile-process-list {
  list-style: none;
  margin: 2.5rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.25rem;
  counter-reset: none;
  position: relative;
  z-index: 1;
}
@media (min-width: 720px) {
  .mobile-process-list {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .mobile-process-list {
    grid-template-columns: repeat(3, 1fr);
  }
}
.mobile-process-step {
  display: flex;
  gap: 1.1rem;
  padding: 1.5rem 1.35rem;
  background: rgba(255, 255, 255, 0.92);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition:
    box-shadow 0.28s var(--ease-out),
    border-color 0.28s var(--ease-out),
    transform 0.28s var(--ease-out);
}
.mobile-process-step:hover {
  box-shadow: var(--shadow-hover), var(--shadow-glow);
  border-color: rgba(124, 58, 237, 0.18);
  transform: translateY(-3px);
}
.mobile-process-step__num {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 2.6rem;
  height: 2.6rem;
  border-radius: 50%;
  background: var(--color-primary-soft);
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 700;
  color: var(--color-primary);
  letter-spacing: 0.01em;
}
.mobile-process-step__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.25;
}
.mobile-process-step__text {
  margin: 0;
  font-size: 0.92rem;
  color: var(--color-muted);
  line-height: 1.6;
}
.mobile-cases-section {
  position: relative;
}
.mobile-cases-grid {
  margin-top: 2.5rem;
  display: grid;
  gap: 1.5rem;
}
@media (min-width: 720px) {
  .mobile-cases-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .mobile-cases-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.mobile-case-card {
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
  padding: 1.75rem 1.5rem;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  transition:
    box-shadow 0.28s var(--ease-out),
    border-color 0.28s var(--ease-out),
    transform 0.28s var(--ease-out);
}
.mobile-case-card:hover {
  box-shadow: var(--shadow-hover), var(--shadow-glow);
  border-color: rgba(124, 58, 237, 0.18);
  transform: translateY(-4px);
}
.mobile-case-card__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}
.mobile-case-card__category {
  display: inline-block;
  padding: 0.25rem 0.75rem;
  border-radius: 99px;
  background: var(--color-primary-soft);
  font-size: 0.76rem;
  font-weight: 600;
  color: var(--color-primary);
  letter-spacing: 0.02em;
  text-transform: uppercase;
  white-space: nowrap;
}
.mobile-case-card__metric {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.1rem;
}
.mobile-case-card__metric-value {
  font-family: var(--font-display);
  font-size: 1.55rem;
  font-weight: 700;
  color: var(--color-primary);
  line-height: 1;
}
.mobile-case-card__metric-label {
  font-size: 0.72rem;
  color: var(--color-muted);
  white-space: nowrap;
}
.mobile-case-card__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--color-text);
  line-height: 1.3;
}
.mobile-case-card__desc {
  margin: 0;
  font-size: 0.91rem;
  color: var(--color-muted);
  line-height: 1.65;
  flex: 1;
}
.mobile-case-card__tags {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.mobile-case-card__tag {
  padding: 0.2rem 0.6rem;
  border-radius: 6px;
  background: rgba(9, 9, 11, 0.04);
  border: 1px solid var(--color-border);
  font-size: 0.75rem;
  color: var(--color-muted);
  font-weight: 500;
}
.mobile-tech-section {
  position: relative;
}
.mobile-tech-grid {
  margin-top: 2.5rem;
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 600px) {
  .mobile-tech-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1000px) {
  .mobile-tech-grid {
    grid-template-columns: repeat(4, 1fr);
  }
}
.mobile-tech-group {
  padding: 1.4rem 1.25rem;
  border-radius: var(--radius-lg);
  background: rgba(255, 255, 255, 0.88);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.mobile-tech-group__heading {
  margin: 0 0 0.85rem;
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--color-primary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.mobile-tech-group__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.mobile-tech-group__item {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.91rem;
  color: var(--color-text);
  font-weight: 500;
}
.mobile-tech-group__item::before {
  content: "";
  display: inline-block;
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--color-primary);
  opacity: 0.5;
}

/* assets/css/src/pages/services-gallery.css */
.showcase-grid {
  display: grid;
  gap: 1.25rem;
  grid-template-columns: 1fr;
  margin-top: 1.5rem;
}
.showcase-grid--studio {
  gap: clamp(1.15rem, 2vw, 1.65rem);
  margin-top: 1.75rem;
}
@media (min-width: 640px) {
  .showcase-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1000px) {
  .showcase-grid:not(.showcase-grid--tight) {
    grid-template-columns: repeat(3, 1fr);
  }
}
.showcase-grid--tight {
  margin-top: 1rem;
}
@media (min-width: 720px) {
  .showcase-grid--tight {
    grid-template-columns: repeat(2, 1fr);
  }
}
.showcase-card {
  margin: 0;
  background: rgba(255, 255, 255, 0.96);
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
  overflow: hidden;
  transition:
    box-shadow 0.35s var(--ease-out),
    border-color 0.35s var(--ease-out),
    transform 0.35s var(--ease-out);
}
.showcase-card:hover {
  box-shadow: var(--shadow-hover), 0 0 0 1px rgba(124, 58, 237, 0.06);
  border-color: rgba(124, 58, 237, 0.12);
}
.showcase-card--studio {
  border-radius: clamp(16px, 2vw, 22px);
  border: 1px solid rgba(124, 58, 237, 0.1);
  box-shadow: var(--shadow), 0 0 0 1px rgba(255, 255, 255, 0.6) inset;
  background:
    linear-gradient(
      180deg,
      #ffffff 0%,
      #fafafa 100%);
}
.showcase-card--studio:hover {
  border-color: rgba(124, 58, 237, 0.22);
  box-shadow: var(--shadow-glow);
  transform: translateY(-3px);
}
@media (prefers-reduced-motion: reduce) {
  .showcase-card--studio:hover {
    transform: none;
  }
}
.showcase-card img {
  display: block;
  width: 100%;
  height: auto;
  vertical-align: middle;
  transition: transform 0.45s var(--ease-out);
}
.showcase-card--studio:hover img {
  transform: scale(1.02);
}
@media (prefers-reduced-motion: reduce) {
  .showcase-card--studio:hover img {
    transform: none;
  }
}
.showcase-card figcaption {
  padding: 0.55rem 0.85rem;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-muted);
  border-top: 1px solid var(--color-border);
}
.showcase-card--studio figcaption {
  padding: 0.85rem 1rem;
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-text);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.98) 0%,
      rgba(244, 244, 245, 0.95) 100%);
  border-top: 1px solid rgba(124, 58, 237, 0.08);
}
@media (prefers-reduced-motion: no-preference) {
  .reveal-section {
    opacity: 0;
    transform: translateY(18px);
    transition: opacity 0.55s ease, transform 0.55s ease;
  }
  .reveal-section.is-visible {
    opacity: 1;
    transform: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
}

/* assets/css/src/pages/shop-showcase.css */
.shop-showcase-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.shop-showcase-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.shop-showcase-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(110px);
  opacity: 0.5;
}
.shop-showcase-section__orb--1 {
  top: -15%;
  left: -8%;
  width: 460px;
  height: 460px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.45),
      transparent 70%);
}
.shop-showcase-section__orb--2 {
  bottom: -20%;
  right: -10%;
  width: 520px;
  height: 520px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.38),
      transparent 70%);
}
.shop-mockup-grid {
  margin-top: 2.25rem;
  display: grid;
  gap: clamp(1.25rem, 2.5vw, 2rem);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .shop-mockup-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .shop-mockup-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.shop-mockup {
  --mock-bg: #faf7f1;
  --mock-fg: #1c1c1f;
  --mock-muted: rgba(28, 28, 31, 0.55);
  --mock-accent: #1f4d3a;
  --mock-accent-soft: rgba(31, 77, 58, 0.1);
  --mock-line: rgba(28, 28, 31, 0.08);
  --mock-thumb-1:
    linear-gradient(
      135deg,
      #e8dfd0 0%,
      #c9b89a 100%);
  --mock-thumb-2:
    linear-gradient(
      135deg,
      #d8d2c3 0%,
      #a89878 100%);
  --mock-thumb-3:
    linear-gradient(
      135deg,
      #f1e9d8 0%,
      #d2bc94 100%);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.4s var(--ease-out);
}
.shop-mockup:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  .shop-mockup,
  .shop-mockup:hover {
    transform: none;
    transition: none;
  }
}
.shop-mockup__frame {
  border-radius: clamp(14px, 1.6vw, 20px);
  overflow: hidden;
  background: var(--mock-bg);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow:
    0 24px 60px -28px rgba(15, 23, 42, 0.45),
    0 10px 24px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(124, 58, 237, 0.06);
  transition: box-shadow 0.4s var(--ease-out);
}
.shop-mockup:hover .shop-mockup__frame {
  box-shadow:
    0 32px 70px -28px rgba(15, 23, 42, 0.55),
    0 14px 28px -16px rgba(15, 23, 42, 0.3),
    0 0 0 1px rgba(124, 58, 237, 0.18);
}
.shop-mockup__chrome {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.95rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--mock-line);
}
.shop-mockup__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.shop-mockup__dot--red {
  background: #ff5f57;
}
.shop-mockup__dot--yellow {
  background: #febc2e;
}
.shop-mockup__dot--green {
  background: #28c840;
}
.shop-mockup__url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.2rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.01em;
  max-width: 65%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.shop-mockup__view {
  padding: 1.1rem 1.1rem 1.25rem;
  color: var(--mock-fg);
  background: var(--mock-bg);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.shop-mockup__nav {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding-bottom: 0.7rem;
  border-bottom: 1px solid var(--mock-line);
}
.shop-mockup__brand {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  color: var(--mock-fg);
}
.shop-mockup__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: none;
  gap: 0.95rem;
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.02em;
}
@media (min-width: 380px) {
  .shop-mockup__menu {
    display: inline-flex;
  }
}
.shop-mockup__bag {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.25rem 0.55rem;
  border-radius: 999px;
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  font-size: 0.7rem;
  font-weight: 700;
}
.shop-mockup__bag-icon {
  position: relative;
  display: inline-block;
  width: 10px;
  height: 11px;
  border: 1.5px solid currentColor;
  border-radius: 0 0 2px 2px;
  border-top: none;
}
.shop-mockup__bag-icon::before {
  content: "";
  position: absolute;
  top: -4px;
  left: 50%;
  width: 7px;
  height: 5px;
  transform: translateX(-50%);
  border: 1.5px solid currentColor;
  border-bottom: none;
  border-radius: 4px 4px 0 0;
}
.shop-mockup__bag-count {
  line-height: 1;
}
.shop-mockup__hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 0.85rem;
  padding: 1.1rem 1rem;
  border-radius: 12px;
  overflow: hidden;
  background: var(--mock-hero-bg, linear-gradient(135deg, #efe9dc 0%, #ddd1b8 100%));
  color: var(--mock-hero-fg, var(--mock-fg));
  min-height: 132px;
}
.shop-mockup__hero-text {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  z-index: 1;
}
.shop-mockup__kicker {
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.7;
}
.shop-mockup__hero-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.05rem, 1.6vw, 1.3rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.shop-mockup__cta {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  align-self: flex-start;
  gap: 0.35rem;
  padding: 0.4rem 0.85rem;
  border-radius: 999px;
  background: var(--mock-cta-bg, var(--mock-accent));
  color: var(--mock-cta-fg, #fff);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}
.shop-mockup__cta::after {
  content: "\2192";
  font-weight: 700;
}
.shop-mockup__hero-art {
  position: relative;
  border-radius: 10px;
  background: var(--mock-art, linear-gradient(135deg, #c9b89a 0%, #8a7a5c 100%));
  overflow: hidden;
  min-height: 100px;
}
.shop-mockup__hero-art::before,
.shop-mockup__hero-art::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.shop-mockup__hero-art::before {
  inset: -25% -10% auto auto;
  width: 80%;
  aspect-ratio: 1;
  background: var(--mock-art-shape-1, radial-gradient(circle, rgba(255, 255, 255, 0.45), transparent 65%));
  filter: blur(2px);
}
.shop-mockup__hero-art::after {
  inset: auto auto -30% -15%;
  width: 70%;
  aspect-ratio: 1;
  background: var(--mock-art-shape-2, radial-gradient(circle, rgba(0, 0, 0, 0.18), transparent 65%));
  filter: blur(3px);
}
.shop-mockup__products {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
}
.shop-mockup__product {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  padding: 0.5rem 0.55rem 0.6rem;
  background: rgba(255, 255, 255, 0.6);
  border-radius: 9px;
  border: 1px solid var(--mock-line);
}
.shop-mockup__product-thumb {
  aspect-ratio: 1;
  border-radius: 6px;
  background: var(--mock-thumb-1);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.35);
}
.shop-mockup__product--2 .shop-mockup__product-thumb {
  background: var(--mock-thumb-2);
}
.shop-mockup__product--3 .shop-mockup__product-thumb {
  background: var(--mock-thumb-3);
}
.shop-mockup__product-name {
  font-size: 0.66rem;
  font-weight: 600;
  color: var(--mock-fg);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.shop-mockup__product-price {
  font-family: var(--font-display);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--mock-accent);
  letter-spacing: -0.01em;
}
.shop-mockup__caption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 0.25rem;
}
.shop-mockup__caption-title {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.shop-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.shop-mockup__caption-sep {
  color: var(--color-muted);
  font-weight: 400;
}
.shop-mockup__caption-niche {
  color: var(--color-text);
  font-weight: 700;
}
.shop-mockup__caption-stack {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.shop-mockup--objecta {
  --mock-bg: #faf7f1;
  --mock-fg: #1c1f1c;
  --mock-muted: rgba(28, 31, 28, 0.55);
  --mock-accent: #1f4d3a;
  --mock-accent-soft: rgba(31, 77, 58, 0.1);
  --mock-line: rgba(28, 31, 28, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #efe9dc 0%,
      #d9cdb1 100%);
  --mock-art:
    linear-gradient(
      135deg,
      #c9b89a 0%,
      #6a5a3f 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(255, 255, 255, 0.45),
      transparent 65%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(0, 0, 0, 0.22),
      transparent 65%);
  --mock-thumb-1:
    linear-gradient(
      135deg,
      #e8dfd0 0%,
      #b8a482 100%);
  --mock-thumb-2:
    linear-gradient(
      135deg,
      #d8d2c3 0%,
      #8a7a5c 100%);
  --mock-thumb-3:
    linear-gradient(
      135deg,
      #f1e9d8 0%,
      #c2a878 100%);
}
.shop-mockup--aurelia {
  --mock-bg: #fdf6f3;
  --mock-fg: #2a1f1c;
  --mock-muted: rgba(42, 31, 28, 0.55);
  --mock-accent: #b85c75;
  --mock-accent-soft: rgba(184, 92, 117, 0.12);
  --mock-line: rgba(42, 31, 28, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #f7dde0 0%,
      #e8b8b0 100%);
  --mock-hero-fg: #3d1a1a;
  --mock-art:
    linear-gradient(
      135deg,
      #e8a8a0 0%,
      #b85c75 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(255, 235, 220, 0.6),
      transparent 65%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(120, 30, 50, 0.25),
      transparent 65%);
  --mock-thumb-1:
    linear-gradient(
      135deg,
      #f5d8d0 0%,
      #d89890 100%);
  --mock-thumb-2:
    linear-gradient(
      135deg,
      #f0c8c8 0%,
      #c47878 100%);
  --mock-thumb-3:
    linear-gradient(
      135deg,
      #fae0e0 0%,
      #e0a0a0 100%);
}
.shop-mockup--noir {
  --mock-bg: #0e0e12;
  --mock-fg: #f4f4f6;
  --mock-muted: rgba(244, 244, 246, 0.55);
  --mock-accent: #c4b5fd;
  --mock-accent-soft: rgba(196, 181, 253, 0.16);
  --mock-line: rgba(244, 244, 246, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #1a1a24 0%,
      #2a1a3a 100%);
  --mock-hero-fg: #f4f4f6;
  --mock-cta-bg:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  --mock-cta-fg: #ffffff;
  --mock-art:
    linear-gradient(
      135deg,
      #4c1d95 0%,
      #0e7490 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(196, 181, 253, 0.55),
      transparent 60%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.4),
      transparent 60%);
  --mock-thumb-1:
    linear-gradient(
      135deg,
      #2a2a36 0%,
      #4c1d95 100%);
  --mock-thumb-2:
    linear-gradient(
      135deg,
      #1f1f2a 0%,
      #0e7490 100%);
  --mock-thumb-3:
    linear-gradient(
      135deg,
      #2a1a3a 0%,
      #7c3aed 100%);
}
.shop-mockup--noir .shop-mockup__product {
  background: rgba(255, 255, 255, 0.04);
}
.shop-mockup--noir .shop-mockup__chrome {
  background: rgba(255, 255, 255, 0.04);
}
.shop-mockup--noir .shop-mockup__url {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--mock-muted);
}
.shop-mockup--noir .shop-mockup__cta::after {
  color: #fff;
}

/* assets/css/src/pages/landing-showcase.css */
.landing-showcase-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.landing-showcase-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.landing-showcase-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(110px);
  opacity: 0.5;
}
.landing-showcase-section__orb--1 {
  top: -12%;
  left: -8%;
  width: 460px;
  height: 460px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.45),
      transparent 70%);
}
.landing-showcase-section__orb--2 {
  bottom: -18%;
  right: -10%;
  width: 520px;
  height: 520px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.38),
      transparent 70%);
}
.landing-mockup-grid {
  margin-top: 2.25rem;
  display: grid;
  gap: clamp(1.25rem, 2.5vw, 2rem);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .landing-mockup-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .landing-mockup-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.landing-mockup {
  --mock-bg: #ffffff;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-accent: #4338ca;
  --mock-accent-soft: rgba(67, 56, 202, 0.1);
  --mock-line: rgba(14, 19, 32, 0.08);
  --mock-cta-bg: var(--mock-accent);
  --mock-cta-fg: #ffffff;
  --mock-ghost-bg: transparent;
  --mock-ghost-fg: var(--mock-fg);
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.4s var(--ease-out);
}
.landing-mockup:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  .landing-mockup,
  .landing-mockup:hover {
    transform: none;
    transition: none;
  }
}
.landing-mockup__frame {
  border-radius: clamp(14px, 1.6vw, 20px);
  overflow: hidden;
  background: var(--mock-bg);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow:
    0 24px 60px -28px rgba(15, 23, 42, 0.45),
    0 10px 24px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(124, 58, 237, 0.06);
  transition: box-shadow 0.4s var(--ease-out);
}
.landing-mockup:hover .landing-mockup__frame {
  box-shadow:
    0 32px 70px -28px rgba(15, 23, 42, 0.55),
    0 14px 28px -16px rgba(15, 23, 42, 0.3),
    0 0 0 1px rgba(124, 58, 237, 0.18);
}
.landing-mockup__chrome {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.95rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--mock-line);
}
.landing-mockup__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.landing-mockup__dot--red {
  background: #ff5f57;
}
.landing-mockup__dot--yellow {
  background: #febc2e;
}
.landing-mockup__dot--green {
  background: #28c840;
}
.landing-mockup__url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.2rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.01em;
  max-width: 65%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.landing-mockup__view {
  padding: 1.1rem 1.1rem 1.25rem;
  color: var(--mock-fg);
  background: var(--mock-bg);
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.landing-mockup__nav {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding-bottom: 0.7rem;
  border-bottom: 1px solid var(--mock-line);
}
.landing-mockup__brand {
  font-family: var(--font-display);
  font-size: 0.85rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  color: var(--mock-fg);
  white-space: nowrap;
}
.landing-mockup__menu {
  list-style: none;
  margin: 0;
  padding: 0;
  display: none;
  gap: 0.95rem;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.02em;
}
@media (min-width: 420px) {
  .landing-mockup__menu {
    display: inline-flex;
  }
}
.landing-mockup__nav-cta {
  margin-left: auto;
  padding: 0.32rem 0.75rem;
  border-radius: 999px;
  background: var(--mock-accent);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.landing-mockup__hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  gap: 0.85rem;
  padding: 1.1rem 1rem;
  border-radius: 12px;
  overflow: hidden;
  background: var(--mock-hero-bg, linear-gradient(135deg, #f5f3ff 0%, #ede9fe 100%));
  color: var(--mock-hero-fg, var(--mock-fg));
  min-height: 158px;
}
.landing-mockup__hero-text {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
  z-index: 1;
}
.landing-mockup__kicker {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.7;
}
.landing-mockup__hero-title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
}
.landing-mockup__hero-lead {
  margin: 0;
  font-size: 0.74rem;
  line-height: 1.4;
  opacity: 0.78;
}
.landing-mockup__hero-actions {
  margin-top: auto;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.landing-mockup__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.landing-mockup__cta--primary {
  background: var(--mock-cta-bg);
  color: var(--mock-cta-fg);
}
.landing-mockup__cta--primary::after {
  content: "\2192";
  font-weight: 700;
}
.landing-mockup__cta--ghost {
  background: var(--mock-ghost-bg);
  color: var(--mock-ghost-fg);
  border: 1px solid currentColor;
  opacity: 0.7;
}
.landing-mockup__hero-art {
  position: relative;
  border-radius: 10px;
  background: var(--mock-art, linear-gradient(135deg, #c4b5fd 0%, #7c3aed 100%));
  overflow: hidden;
  min-height: 108px;
}
.landing-mockup__hero-art::before,
.landing-mockup__hero-art::after {
  content: "";
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
}
.landing-mockup__hero-art::before {
  inset: -20% -10% auto auto;
  width: 80%;
  aspect-ratio: 1;
  background: var(--mock-art-shape-1, radial-gradient(circle, rgba(255, 255, 255, 0.45), transparent 65%));
  filter: blur(2px);
}
.landing-mockup__hero-art::after {
  inset: auto auto -25% -15%;
  width: 70%;
  aspect-ratio: 1;
  background: var(--mock-art-shape-2, radial-gradient(circle, rgba(0, 0, 0, 0.18), transparent 65%));
  filter: blur(3px);
}
.landing-mockup__metrics {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.55rem;
}
.landing-mockup__metric {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  padding: 0.6rem 0.55rem;
  border-radius: 9px;
  background: var(--mock-accent-soft);
  border: 1px solid var(--mock-line);
  text-align: center;
}
.landing-mockup__metric-value {
  font-family: var(--font-display);
  font-size: 0.92rem;
  font-weight: 800;
  color: var(--mock-accent);
  letter-spacing: -0.02em;
  line-height: 1.05;
}
.landing-mockup__metric-label {
  font-size: 0.62rem;
  color: var(--mock-muted);
  line-height: 1.2;
}
.landing-mockup__caption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 0.25rem;
}
.landing-mockup__caption-title {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.landing-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.landing-mockup__caption-sep {
  color: var(--color-muted);
  font-weight: 400;
}
.landing-mockup__caption-niche {
  color: var(--color-text);
  font-weight: 700;
}
.landing-mockup__caption-stack {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.landing-mockup--nexa {
  --mock-bg: #0b0e1a;
  --mock-fg: #f4f4f8;
  --mock-muted: rgba(244, 244, 248, 0.55);
  --mock-accent: #c4b5fd;
  --mock-accent-soft: rgba(124, 58, 237, 0.18);
  --mock-line: rgba(244, 244, 248, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #1a1740 0%,
      #0c2638 100%);
  --mock-hero-fg: #f4f4f8;
  --mock-cta-bg:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  --mock-cta-fg: #ffffff;
  --mock-ghost-fg: rgba(244, 244, 248, 0.85);
  --mock-art:
    linear-gradient(
      135deg,
      #4c1d95 0%,
      #0e7490 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(196, 181, 253, 0.55),
      transparent 60%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.4),
      transparent 60%);
}
.landing-mockup--nexa .landing-mockup__chrome {
  background: rgba(255, 255, 255, 0.04);
}
.landing-mockup--nexa .landing-mockup__url {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--mock-muted);
}
.landing-mockup--nexa .landing-mockup__nav-cta {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
}
.landing-mockup--nexa .landing-mockup__metric-value {
  background:
    linear-gradient(
      120deg,
      #c4b5fd 0%,
      #67e8f9 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.landing-mockup--opale {
  --mock-bg: #fbfaf6;
  --mock-fg: #1d2820;
  --mock-muted: rgba(29, 40, 32, 0.58);
  --mock-accent: #4a6b56;
  --mock-accent-soft: rgba(74, 107, 86, 0.12);
  --mock-line: rgba(29, 40, 32, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #ecebe1 0%,
      #d4d8c7 100%);
  --mock-hero-fg: #1d2820;
  --mock-cta-bg: #4a6b56;
  --mock-cta-fg: #ffffff;
  --mock-art:
    linear-gradient(
      135deg,
      #c2c9b0 0%,
      #6b8473 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(255, 252, 240, 0.6),
      transparent 65%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(40, 60, 50, 0.22),
      transparent 65%);
}
.landing-mockup--volta {
  --mock-bg: #0a0a0c;
  --mock-fg: #f4f4f6;
  --mock-muted: rgba(244, 244, 246, 0.55);
  --mock-accent: #facc15;
  --mock-accent-soft: rgba(250, 204, 21, 0.14);
  --mock-line: rgba(244, 244, 246, 0.08);
  --mock-hero-bg:
    linear-gradient(
      135deg,
      #1a1a1d 0%,
      #0a0a0c 60%);
  --mock-hero-fg: #f4f4f6;
  --mock-cta-bg: #facc15;
  --mock-cta-fg: #0a0a0c;
  --mock-ghost-fg: rgba(244, 244, 246, 0.85);
  --mock-art:
    linear-gradient(
      135deg,
      #facc15 0%,
      #b45309 100%);
  --mock-art-shape-1:
    radial-gradient(
      circle,
      rgba(255, 240, 180, 0.55),
      transparent 60%);
  --mock-art-shape-2:
    radial-gradient(
      circle,
      rgba(0, 0, 0, 0.35),
      transparent 60%);
}
.landing-mockup--volta .landing-mockup__chrome {
  background: rgba(255, 255, 255, 0.04);
}
.landing-mockup--volta .landing-mockup__url {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--mock-muted);
}
.landing-mockup--volta .landing-mockup__metric {
  background: rgba(250, 204, 21, 0.08);
}

/* assets/css/src/pages/quiz-showcase.css */
.quiz-showcase-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.quiz-showcase-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.quiz-showcase-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(110px);
  opacity: 0.5;
}
.quiz-showcase-section__orb--1 {
  top: -12%;
  left: -8%;
  width: 460px;
  height: 460px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.42),
      transparent 70%);
}
.quiz-showcase-section__orb--2 {
  bottom: -18%;
  right: -10%;
  width: 520px;
  height: 520px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.36),
      transparent 70%);
}
.quiz-mockup-grid {
  margin-top: 2.25rem;
  display: grid;
  gap: clamp(1.25rem, 2.5vw, 2rem);
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .quiz-mockup-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .quiz-mockup-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.quiz-mockup {
  --mock-bg: #ffffff;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-accent: #4338ca;
  --mock-accent-soft: rgba(67, 56, 202, 0.1);
  --mock-line: rgba(14, 19, 32, 0.08);
  --mock-option-bg: rgba(255, 255, 255, 0.85);
  --mock-cta-bg: var(--mock-accent);
  --mock-cta-fg: #ffffff;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.4s var(--ease-out);
}
.quiz-mockup:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  .quiz-mockup,
  .quiz-mockup:hover {
    transform: none;
    transition: none;
  }
}
.quiz-mockup__frame {
  border-radius: clamp(14px, 1.6vw, 20px);
  overflow: hidden;
  background: var(--mock-bg);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow:
    0 24px 60px -28px rgba(15, 23, 42, 0.45),
    0 10px 24px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(124, 58, 237, 0.06);
  transition: box-shadow 0.4s var(--ease-out);
}
.quiz-mockup:hover .quiz-mockup__frame {
  box-shadow:
    0 32px 70px -28px rgba(15, 23, 42, 0.55),
    0 14px 28px -16px rgba(15, 23, 42, 0.3),
    0 0 0 1px rgba(124, 58, 237, 0.18);
}
.quiz-mockup__chrome {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.95rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--mock-line);
}
.quiz-mockup__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.quiz-mockup__dot--red {
  background: #ff5f57;
}
.quiz-mockup__dot--yellow {
  background: #febc2e;
}
.quiz-mockup__dot--green {
  background: #28c840;
}
.quiz-mockup__url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.2rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.01em;
  max-width: 65%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.quiz-mockup__view {
  padding: 1.1rem 1.1rem 1.25rem;
  color: var(--mock-fg);
  background: var(--mock-bg);
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.quiz-mockup__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.8rem;
}
.quiz-mockup__brand {
  font-family: var(--font-display);
  font-size: 0.8rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  color: var(--mock-fg);
  white-space: nowrap;
}
.quiz-mockup__step {
  font-size: 0.68rem;
  font-weight: 600;
  color: var(--mock-muted);
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.quiz-mockup__progress {
  height: 4px;
  border-radius: 999px;
  background: var(--mock-line);
  overflow: hidden;
}
.quiz-mockup__progress-bar {
  display: block;
  width: var(--p, 0%);
  height: 100%;
  background: var(--mock-progress, var(--mock-accent));
  border-radius: inherit;
  transition: width 0.6s var(--ease-out);
}
.quiz-mockup__kicker {
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--mock-accent);
  margin-top: 0.35rem;
}
.quiz-mockup__question {
  margin: 0 0 0.25rem;
  font-family: var(--font-display);
  font-size: clamp(0.95rem, 1.5vw, 1.15rem);
  font-weight: 700;
  line-height: 1.2;
  color: var(--mock-fg);
  letter-spacing: -0.01em;
}
.quiz-mockup__options {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.quiz-mockup__option {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 0.65rem;
  padding: 0.55rem 0.7rem;
  border-radius: 10px;
  background: var(--mock-option-bg);
  border: 1px solid var(--mock-line);
  transition:
    border-color 0.25s var(--ease-out),
    background 0.25s var(--ease-out),
    transform 0.25s var(--ease-out);
}
.quiz-mockup__option:hover {
  border-color: var(--mock-accent);
}
.quiz-mockup__option.is-selected {
  border-color: var(--mock-accent);
  background: var(--mock-accent-soft);
}
.quiz-mockup__option-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.85rem;
  height: 1.85rem;
  border-radius: 8px;
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  font-size: 0.95rem;
  line-height: 1;
  font-weight: 700;
}
.quiz-mockup__option-body {
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
  min-width: 0;
}
.quiz-mockup__option-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--mock-fg);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.quiz-mockup__option-meta {
  font-size: 0.66rem;
  color: var(--mock-muted);
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.quiz-mockup__option-radio {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  border: 1.5px solid currentColor;
  color: var(--mock-muted);
  position: relative;
  flex-shrink: 0;
}
.quiz-mockup__option.is-selected .quiz-mockup__option-radio {
  color: var(--mock-accent);
  border-color: currentColor;
}
.quiz-mockup__option.is-selected .quiz-mockup__option-radio::after {
  content: "";
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: currentColor;
}
.quiz-mockup__actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  margin-top: 0.35rem;
  padding-top: 0.6rem;
  border-top: 1px solid var(--mock-line);
}
.quiz-mockup__btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.42rem 0.95rem;
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.quiz-mockup__btn--ghost {
  background: transparent;
  color: var(--mock-muted);
  border: 1px solid var(--mock-line);
}
.quiz-mockup__btn--primary {
  background: var(--mock-cta-bg);
  color: var(--mock-cta-fg);
}
.quiz-mockup__btn--primary::after {
  content: "\2192";
  font-weight: 700;
}
.quiz-mockup__caption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 0.25rem;
}
.quiz-mockup__caption-title {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.quiz-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.quiz-mockup__caption-sep {
  color: var(--color-muted);
  font-weight: 400;
}
.quiz-mockup__caption-niche {
  color: var(--color-text);
  font-weight: 700;
}
.quiz-mockup__caption-stack {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.quiz-mockup--maison {
  --mock-bg: #fbf6f1;
  --mock-fg: #2a1f1c;
  --mock-muted: rgba(42, 31, 28, 0.55);
  --mock-accent: #c2755b;
  --mock-accent-soft: rgba(194, 117, 91, 0.12);
  --mock-line: rgba(42, 31, 28, 0.08);
  --mock-option-bg: rgba(255, 255, 255, 0.7);
  --mock-cta-bg: #c2755b;
  --mock-cta-fg: #ffffff;
  --mock-progress:
    linear-gradient(
      90deg,
      #d8a07a 0%,
      #c2755b 100%);
}
.quiz-mockup--drive {
  --mock-bg: #0d1426;
  --mock-fg: #f4f6fb;
  --mock-muted: rgba(244, 246, 251, 0.55);
  --mock-accent: #f59e0b;
  --mock-accent-soft: rgba(245, 158, 11, 0.14);
  --mock-line: rgba(244, 246, 251, 0.08);
  --mock-option-bg: rgba(255, 255, 255, 0.04);
  --mock-cta-bg: #f59e0b;
  --mock-cta-fg: #0d1426;
  --mock-progress:
    linear-gradient(
      90deg,
      #fbbf24 0%,
      #f59e0b 100%);
}
.quiz-mockup--drive .quiz-mockup__chrome {
  background: rgba(255, 255, 255, 0.04);
}
.quiz-mockup--drive .quiz-mockup__url {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--mock-muted);
}
.quiz-mockup--drive .quiz-mockup__btn--ghost {
  color: rgba(244, 246, 251, 0.7);
}
.quiz-mockup--raw {
  --mock-bg: #fff8ed;
  --mock-fg: #2c1c0a;
  --mock-muted: rgba(44, 28, 10, 0.55);
  --mock-accent: #d97706;
  --mock-accent-soft: rgba(217, 119, 6, 0.14);
  --mock-line: rgba(44, 28, 10, 0.08);
  --mock-option-bg: rgba(255, 255, 255, 0.75);
  --mock-cta-bg: #d97706;
  --mock-cta-fg: #ffffff;
  --mock-progress:
    linear-gradient(
      90deg,
      #fbbf24 0%,
      #d97706 100%);
}
.quiz-try-cta {
  position: relative;
  margin-top: 3rem;
  padding: 2.25rem 1.75rem;
  border-radius: var(--radius-lg);
  text-align: center;
  background:
    radial-gradient(
      120% 120% at 0% 0%,
      rgba(124, 58, 237, 0.12) 0%,
      transparent 55%),
    radial-gradient(
      120% 120% at 100% 100%,
      rgba(236, 72, 153, 0.1) 0%,
      transparent 55%),
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.95) 0%,
      rgba(255, 255, 255, 0.88) 100%);
  border: 1px solid rgba(124, 58, 237, 0.18);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.7) inset, 0 18px 40px -28px rgba(124, 58, 237, 0.45);
  overflow: hidden;
  isolation: isolate;
}
.quiz-try-cta::before,
.quiz-try-cta::after {
  content: "";
  position: absolute;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  pointer-events: none;
  z-index: -1;
  filter: blur(8px);
}
.quiz-try-cta::before {
  top: -90px;
  left: -60px;
  background:
    radial-gradient(
      closest-side,
      rgba(124, 58, 237, 0.32),
      transparent 70%);
}
.quiz-try-cta::after {
  bottom: -100px;
  right: -50px;
  background:
    radial-gradient(
      closest-side,
      rgba(236, 72, 153, 0.28),
      transparent 70%);
}
.quiz-try-cta__pill {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.8rem;
  margin-bottom: 0.9rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  background: rgba(124, 58, 237, 0.1);
  border: 1px solid rgba(124, 58, 237, 0.22);
  border-radius: var(--radius-pill);
}
.quiz-try-cta__title {
  margin: 0 0 0.65rem;
  font-size: clamp(1.35rem, 2.2vw, 1.85rem);
  font-weight: 800;
  line-height: 1.2;
  color: var(--color-text);
  max-width: 36ch;
  margin-inline: auto;
}
.quiz-try-cta__lead {
  margin: 0 auto 1.5rem;
  max-width: 56ch;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.quiz-try-cta__actions {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.85rem;
}
.quiz-try-cta__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.55rem;
  padding-inline: 1.6rem;
}
.quiz-try-cta__btn-arrow {
  width: 18px;
  height: 18px;
  transition: transform 0.2s var(--ease-out);
}
.quiz-try-cta__btn:hover .quiz-try-cta__btn-arrow {
  transform: translateX(4px);
}
@media (prefers-reduced-motion: reduce) {
  .quiz-try-cta__btn:hover .quiz-try-cta__btn-arrow {
    transform: none;
  }
}
.quiz-try-cta__meta {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.4rem 1.1rem;
  margin: 0;
  font-size: 0.82rem;
  color: var(--color-muted);
}
.quiz-try-cta__meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  line-height: 1.2;
}
.quiz-try-cta__meta-item svg {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--color-primary);
}
@media (max-width: 540px) {
  .quiz-try-cta {
    padding: 1.75rem 1.1rem;
    margin-top: 2rem;
  }
}

/* assets/css/src/pages/telegram-showcase.css */
.telegram-showcase-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.telegram-showcase-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.telegram-showcase-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.45;
}
.telegram-showcase-section__orb--1 {
  top: -10%;
  left: -6%;
  width: 480px;
  height: 480px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.45),
      transparent 70%);
}
.telegram-showcase-section__orb--2 {
  bottom: -16%;
  right: -8%;
  width: 540px;
  height: 540px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.38),
      transparent 70%);
}
.tg-mockup-grid {
  margin-top: 2.25rem;
  display: grid;
  gap: clamp(1.5rem, 2.6vw, 2.25rem);
  grid-template-columns: 1fr;
  justify-items: center;
}
@media (min-width: 720px) {
  .tg-mockup-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (min-width: 1100px) {
  .tg-mockup-grid {
    grid-template-columns: repeat(3, 1fr);
  }
}
.tg-mockup {
  --mock-screen: #ffffff;
  --mock-bg: #e9eef5;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-bot-bg: #ffffff;
  --mock-bot-fg: #0e1320;
  --mock-user-bg:
    linear-gradient(
      135deg,
      #4f46e5 0%,
      #22d3ee 100%);
  --mock-user-fg: #ffffff;
  --mock-header-bg: #ffffff;
  --mock-header-fg: #0e1320;
  --mock-accent: #2aabee;
  --mock-accent-soft: rgba(42, 171, 238, 0.12);
  --mock-line: rgba(14, 19, 32, 0.08);
  --mock-shadow: rgba(15, 23, 42, 0.45);
  width: 100%;
  max-width: 320px;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.4s var(--ease-out);
}
.tg-mockup:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  .tg-mockup,
  .tg-mockup:hover {
    transform: none;
    transition: none;
  }
}
.tg-mockup__device {
  position: relative;
  border-radius: 36px;
  background: var(--mock-bg);
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.7);
  box-shadow:
    0 30px 70px -28px var(--mock-shadow),
    0 12px 28px -16px rgba(15, 23, 42, 0.3),
    0 0 0 1px rgba(34, 211, 238, 0.08);
  display: flex;
  flex-direction: column;
  min-height: 480px;
  transition: box-shadow 0.4s var(--ease-out);
}
.tg-mockup:hover .tg-mockup__device {
  box-shadow:
    0 38px 80px -28px var(--mock-shadow),
    0 16px 32px -16px rgba(15, 23, 42, 0.32),
    0 0 0 1px rgba(34, 211, 238, 0.2);
}
.tg-mockup__notch {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 88px;
  height: 18px;
  border-radius: 999px;
  background: #0a0d14;
  z-index: 2;
}
.tg-mockup__header {
  display: grid;
  grid-template-columns: auto auto 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 2.1rem 1rem 0.75rem;
  background: var(--mock-header-bg);
  color: var(--mock-header-fg);
  border-bottom: 1px solid var(--mock-line);
}
.tg-mockup__back {
  color: var(--mock-accent);
  font-size: 1.4rem;
  line-height: 1;
  font-weight: 500;
}
.tg-mockup__avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 800;
  font-size: 0.78rem;
  letter-spacing: 0.02em;
}
.tg-mockup__identity {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  min-width: 0;
}
.tg-mockup__name {
  font-family: var(--font-display);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--mock-header-fg);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.tg-mockup__status {
  font-size: 0.66rem;
  color: var(--mock-accent);
  font-weight: 600;
  letter-spacing: 0.01em;
}
.tg-mockup__menu {
  color: var(--mock-muted);
  font-size: 1rem;
  font-weight: 700;
  line-height: 1;
}
.tg-mockup__view {
  flex: 1;
  padding: 0.85rem 0.75rem;
  background: var(--mock-bg);
  overflow: hidden;
}
.tg-mockup__feed {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.tg-mockup__msg {
  display: flex;
  max-width: 85%;
}
.tg-mockup__msg--bot {
  align-self: flex-start;
}
.tg-mockup__msg--user {
  align-self: flex-end;
}
.tg-mockup__bubble {
  display: inline-flex;
  flex-direction: column;
  gap: 0.45rem;
  padding: 0.55rem 0.75rem;
  border-radius: 16px;
  font-size: 0.78rem;
  line-height: 1.35;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}
.tg-mockup__msg--bot .tg-mockup__bubble {
  background: var(--mock-bot-bg);
  color: var(--mock-bot-fg);
  border-top-left-radius: 6px;
}
.tg-mockup__msg--user .tg-mockup__bubble {
  background: var(--mock-user-bg);
  color: var(--mock-user-fg);
  border-top-right-radius: 6px;
}
.tg-mockup__text {
  display: block;
}
.tg-mockup__keyboard {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  margin-top: 0.15rem;
}
.tg-mockup__kbtn {
  display: inline-flex;
  align-items: center;
  padding: 0.32rem 0.6rem;
  border-radius: 8px;
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  font-size: 0.7rem;
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.01em;
  border: 1px solid transparent;
  transition: border-color 0.25s var(--ease-out), background 0.25s var(--ease-out);
}
.tg-mockup__kbtn:hover {
  border-color: var(--mock-accent);
}
.tg-mockup__input {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 0.85rem 1rem;
  background: var(--mock-header-bg);
  border-top: 1px solid var(--mock-line);
}
.tg-mockup__attach,
.tg-mockup__send {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  color: var(--mock-accent);
  font-size: 0.95rem;
  font-weight: 700;
  line-height: 1;
}
.tg-mockup__send {
  background: var(--mock-accent);
  color: #ffffff;
  font-size: 0.78rem;
}
.tg-mockup__field {
  padding: 0.45rem 0.85rem;
  border-radius: 999px;
  background: var(--mock-bg);
  color: var(--mock-muted);
  font-size: 0.72rem;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  border: 1px solid var(--mock-line);
}
.tg-mockup__caption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 0.25rem;
  text-align: center;
}
.tg-mockup__caption-title {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  justify-content: center;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.tg-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #2aabee 0%,
      #4f46e5 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.tg-mockup__caption-sep {
  color: var(--color-muted);
  font-weight: 400;
}
.tg-mockup__caption-niche {
  color: var(--color-text);
  font-weight: 700;
}
.tg-mockup__caption-stack {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.tg-mockup--sales {
  --mock-screen: #ffffff;
  --mock-bg: #eef0fb;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-bot-bg: #ffffff;
  --mock-bot-fg: #0e1320;
  --mock-user-bg:
    linear-gradient(
      135deg,
      #7c3aed 0%,
      #22d3ee 100%);
  --mock-user-fg: #ffffff;
  --mock-header-bg: #ffffff;
  --mock-header-fg: #0e1320;
  --mock-accent: #6d4dff;
  --mock-accent-soft: rgba(109, 77, 255, 0.12);
  --mock-line: rgba(14, 19, 32, 0.08);
}
.tg-mockup--sales .tg-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.tg-mockup--booking {
  --mock-screen: #ffffff;
  --mock-bg: #f6ebe0;
  --mock-fg: #2a1f1c;
  --mock-muted: rgba(42, 31, 28, 0.55);
  --mock-bot-bg: #ffffff;
  --mock-bot-fg: #2a1f1c;
  --mock-user-bg:
    linear-gradient(
      135deg,
      #d8896f 0%,
      #c2755b 100%);
  --mock-user-fg: #ffffff;
  --mock-header-bg: #fbf6f1;
  --mock-header-fg: #2a1f1c;
  --mock-accent: #c2755b;
  --mock-accent-soft: rgba(194, 117, 91, 0.14);
  --mock-line: rgba(42, 31, 28, 0.08);
}
.tg-mockup--booking .tg-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #c2755b 0%,
      #d8a07a 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.tg-mockup--crypto {
  --mock-screen: #0a0e1a;
  --mock-bg: #0e1426;
  --mock-fg: #f4f6fb;
  --mock-muted: rgba(244, 246, 251, 0.55);
  --mock-bot-bg: #182037;
  --mock-bot-fg: #f4f6fb;
  --mock-user-bg:
    linear-gradient(
      135deg,
      #22c55e 0%,
      #16a34a 100%);
  --mock-user-fg: #0e1426;
  --mock-header-bg: #182037;
  --mock-header-fg: #f4f6fb;
  --mock-accent: #22c55e;
  --mock-accent-soft: rgba(34, 197, 94, 0.16);
  --mock-line: rgba(244, 246, 251, 0.08);
  --mock-shadow: rgba(0, 0, 0, 0.6);
}
.tg-mockup--crypto .tg-mockup__notch {
  background: #050811;
}
.tg-mockup--crypto .tg-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #22c55e 0%,
      #4ade80 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* assets/css/src/pages/crm-showcase.css */
.crm-showcase-section {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.crm-showcase-section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.crm-showcase-section__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.45;
}
.crm-showcase-section__orb--1 {
  top: -12%;
  left: -8%;
  width: 480px;
  height: 480px;
  background:
    radial-gradient(
      circle,
      rgba(99, 102, 241, 0.4),
      transparent 70%);
}
.crm-showcase-section__orb--2 {
  bottom: -16%;
  right: -10%;
  width: 540px;
  height: 540px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.34),
      transparent 70%);
}
.crm-mockup-grid {
  margin-top: 2.25rem;
  display: grid;
  gap: clamp(1.5rem, 2.6vw, 2.25rem);
  grid-template-columns: 1fr;
}
@media (min-width: 980px) {
  .crm-mockup-grid {
    grid-template-columns: 1fr;
  }
}
.crm-mockup {
  --mock-bg: #ffffff;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-accent: #4338ca;
  --mock-accent-soft: rgba(67, 56, 202, 0.1);
  --mock-line: rgba(14, 19, 32, 0.08);
  --mock-surface: #ffffff;
  --mock-surface-alt: #f5f6fb;
  --mock-deal-bg: #ffffff;
  --mock-tag-soft-bg: rgba(67, 56, 202, 0.1);
  --mock-tag-soft-fg: #4338ca;
  --mock-tag-hot-bg: rgba(239, 68, 68, 0.12);
  --mock-tag-hot-fg: #dc2626;
  --mock-tag-accent-bg: rgba(99, 102, 241, 0.14);
  --mock-tag-accent-fg: #4338ca;
  --mock-tag-success-bg: rgba(16, 185, 129, 0.14);
  --mock-tag-success-fg: #059669;
  --mock-col-cool: #6366f1;
  --mock-col-accent: #f59e0b;
  --mock-col-success: #10b981;
  display: flex;
  flex-direction: column;
  gap: 1rem;
  transition: transform 0.4s var(--ease-out);
}
.crm-mockup:hover {
  transform: translateY(-4px);
}
@media (prefers-reduced-motion: reduce) {
  .crm-mockup,
  .crm-mockup:hover {
    transform: none;
    transition: none;
  }
}
.crm-mockup__frame {
  border-radius: clamp(14px, 1.6vw, 20px);
  overflow: hidden;
  background: var(--mock-bg);
  border: 1px solid rgba(255, 255, 255, 0.6);
  box-shadow:
    0 30px 70px -28px rgba(15, 23, 42, 0.45),
    0 12px 28px -16px rgba(15, 23, 42, 0.25),
    0 0 0 1px rgba(99, 102, 241, 0.06);
  transition: box-shadow 0.4s var(--ease-out);
}
.crm-mockup:hover .crm-mockup__frame {
  box-shadow:
    0 38px 80px -28px rgba(15, 23, 42, 0.55),
    0 16px 32px -16px rgba(15, 23, 42, 0.3),
    0 0 0 1px rgba(99, 102, 241, 0.18);
}
.crm-mockup__chrome {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.7rem 0.95rem;
  background: rgba(15, 15, 20, 0.04);
  border-bottom: 1px solid var(--mock-line);
}
.crm-mockup__dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}
.crm-mockup__dot--red {
  background: #ff5f57;
}
.crm-mockup__dot--yellow {
  background: #febc2e;
}
.crm-mockup__dot--green {
  background: #28c840;
}
.crm-mockup__url {
  margin-left: auto;
  margin-right: auto;
  padding: 0.2rem 0.85rem;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid rgba(15, 15, 20, 0.06);
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-size: 0.72rem;
  font-weight: 500;
  color: var(--mock-muted);
  letter-spacing: 0.01em;
  max-width: 65%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.crm-mockup__view {
  color: var(--mock-fg);
  background: var(--mock-bg);
  display: flex;
  flex-direction: column;
}
.crm-mockup__topbar {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 1rem;
  padding: 0.85rem 1.1rem;
  background: var(--mock-surface);
  border-bottom: 1px solid var(--mock-line);
}
.crm-mockup__brand {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-family: var(--font-display);
}
.crm-mockup__brand-mark {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  background:
    linear-gradient(
      135deg,
      var(--mock-accent) 0%,
      var(--mock-col-cool) 100%);
  box-shadow: 0 4px 10px -4px var(--mock-accent);
}
.crm-mockup__brand-name {
  font-size: 0.92rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--mock-fg);
}
.crm-mockup__tabs {
  display: flex;
  align-items: center;
  gap: 0.35rem;
  overflow: hidden;
}
.crm-mockup__tab {
  padding: 0.32rem 0.7rem;
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 600;
  color: var(--mock-muted);
  white-space: nowrap;
}
.crm-mockup__tab.is-active {
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  font-weight: 700;
}
.crm-mockup__user {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--mock-accent-soft);
  color: var(--mock-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.02em;
}
.crm-mockup__workspace {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.85rem 1.1rem 0.5rem;
  background: var(--mock-bg);
}
.crm-mockup__workspace-label {
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--mock-fg);
}
.crm-mockup__workspace-action {
  display: inline-flex;
  align-items: center;
  padding: 0.38rem 0.85rem;
  border-radius: 999px;
  background: var(--mock-accent);
  color: #ffffff;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.01em;
  box-shadow: 0 6px 14px -8px var(--mock-accent);
  white-space: nowrap;
}
.crm-mockup__kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.6rem;
  padding: 0.4rem 1.1rem 0.85rem;
}
.crm-mockup__kpi {
  padding: 0.65rem 0.8rem;
  border-radius: 12px;
  background: var(--mock-surface-alt);
  border: 1px solid var(--mock-line);
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.crm-mockup__kpi-value {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 800;
  color: var(--mock-fg);
  letter-spacing: -0.01em;
  line-height: 1.1;
}
.crm-mockup__kpi-label {
  font-size: 0.66rem;
  color: var(--mock-muted);
  font-weight: 600;
  letter-spacing: 0.01em;
}
.crm-mockup__board {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.65rem;
  padding: 0.4rem 1.1rem 1.1rem;
}
@media (min-width: 720px) {
  .crm-mockup__board {
    grid-template-columns: repeat(3, 1fr);
  }
}
.crm-mockup__col {
  --col-tone: var(--mock-col-cool);
  background: var(--mock-surface-alt);
  border: 1px solid var(--mock-line);
  border-radius: 14px;
  padding: 0.7rem 0.7rem 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  border-top: 3px solid var(--col-tone);
}
.crm-mockup__col--cool {
  --col-tone: var(--mock-col-cool);
}
.crm-mockup__col--accent {
  --col-tone: var(--mock-col-accent);
}
.crm-mockup__col--success {
  --col-tone: var(--mock-col-success);
}
.crm-mockup__col-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}
.crm-mockup__col-title {
  font-family: var(--font-display);
  font-size: 0.78rem;
  font-weight: 800;
  color: var(--mock-fg);
  letter-spacing: -0.01em;
}
.crm-mockup__col-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 20px;
  height: 20px;
  padding: 0 0.4rem;
  border-radius: 999px;
  background: rgba(15, 19, 32, 0.06);
  color: var(--mock-muted);
  font-size: 0.65rem;
  font-weight: 700;
}
.crm-mockup__deals {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.crm-mockup__deal {
  background: var(--mock-deal-bg);
  border: 1px solid var(--mock-line);
  border-radius: 10px;
  padding: 0.55rem 0.65rem;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.crm-mockup__deal-name {
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--mock-fg);
  letter-spacing: -0.01em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.crm-mockup__deal-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.4rem;
}
.crm-mockup__deal-amount {
  font-size: 0.72rem;
  font-weight: 700;
  color: var(--mock-muted);
  letter-spacing: 0.01em;
}
.crm-mockup__deal-tag {
  display: inline-flex;
  align-items: center;
  padding: 0.18rem 0.5rem;
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  line-height: 1;
}
.crm-mockup__deal-tag--soft {
  background: var(--mock-tag-soft-bg);
  color: var(--mock-tag-soft-fg);
}
.crm-mockup__deal-tag--hot {
  background: var(--mock-tag-hot-bg);
  color: var(--mock-tag-hot-fg);
}
.crm-mockup__deal-tag--accent {
  background: var(--mock-tag-accent-bg);
  color: var(--mock-tag-accent-fg);
}
.crm-mockup__deal-tag--success {
  background: var(--mock-tag-success-bg);
  color: var(--mock-tag-success-fg);
}
.crm-mockup__caption {
  display: flex;
  flex-direction: column;
  gap: 0.2rem;
  padding: 0 0.25rem;
}
.crm-mockup__caption-title {
  margin: 0;
  display: inline-flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.4rem;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 800;
  color: var(--color-text);
  letter-spacing: -0.01em;
}
.crm-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #4338ca 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.crm-mockup__caption-sep {
  color: var(--color-muted);
  font-weight: 400;
}
.crm-mockup__caption-niche {
  color: var(--color-text);
  font-weight: 700;
}
.crm-mockup__caption-stack {
  margin: 0;
  font-size: 0.78rem;
  color: var(--color-muted);
  font-weight: 500;
  letter-spacing: 0.01em;
}
.crm-mockup--hubcrm {
  --mock-bg: #ffffff;
  --mock-fg: #0e1320;
  --mock-muted: rgba(14, 19, 32, 0.55);
  --mock-accent: #6d4dff;
  --mock-accent-soft: rgba(109, 77, 255, 0.12);
  --mock-line: rgba(14, 19, 32, 0.08);
  --mock-surface: #ffffff;
  --mock-surface-alt: #f5f6fb;
  --mock-deal-bg: #ffffff;
  --mock-col-cool: #6d4dff;
  --mock-col-accent: #22d3ee;
  --mock-col-success: #10b981;
}
.crm-mockup--hubcrm .crm-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #7c3aed 0%,
      #22d3ee 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.crm-mockup--estate {
  --mock-bg: #0d1426;
  --mock-fg: #f4f6fb;
  --mock-muted: rgba(244, 246, 251, 0.55);
  --mock-accent: #f5c163;
  --mock-accent-soft: rgba(245, 193, 99, 0.16);
  --mock-line: rgba(244, 246, 251, 0.08);
  --mock-surface: #131d36;
  --mock-surface-alt: #182343;
  --mock-deal-bg: #1d2950;
  --mock-tag-soft-bg: rgba(245, 193, 99, 0.14);
  --mock-tag-soft-fg: #f5c163;
  --mock-tag-hot-bg: rgba(248, 113, 113, 0.16);
  --mock-tag-hot-fg: #f87171;
  --mock-tag-accent-bg: rgba(56, 189, 248, 0.16);
  --mock-tag-accent-fg: #38bdf8;
  --mock-tag-success-bg: rgba(34, 197, 94, 0.16);
  --mock-tag-success-fg: #4ade80;
  --mock-col-cool: #38bdf8;
  --mock-col-accent: #f5c163;
  --mock-col-success: #22c55e;
}
.crm-mockup--estate .crm-mockup__chrome {
  background: rgba(255, 255, 255, 0.04);
  border-bottom-color: rgba(255, 255, 255, 0.06);
}
.crm-mockup--estate .crm-mockup__url {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.08);
  color: var(--mock-muted);
}
.crm-mockup--estate .crm-mockup__brand-mark {
  background:
    linear-gradient(
      135deg,
      #f5c163 0%,
      #fbbf24 100%);
  box-shadow: 0 4px 10px -4px rgba(245, 193, 99, 0.6);
}
.crm-mockup--estate .crm-mockup__col-count {
  background: rgba(255, 255, 255, 0.06);
  color: var(--mock-muted);
}
.crm-mockup--estate .crm-mockup__workspace-action {
  color: #0d1426;
}
.crm-mockup--estate .crm-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #f5c163 0%,
      #fbbf24 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.crm-mockup--atelier {
  --mock-bg: #fbf6f1;
  --mock-fg: #2a1f1c;
  --mock-muted: rgba(42, 31, 28, 0.55);
  --mock-accent: #c2755b;
  --mock-accent-soft: rgba(194, 117, 91, 0.12);
  --mock-line: rgba(42, 31, 28, 0.08);
  --mock-surface: #ffffff;
  --mock-surface-alt: #f3ebe1;
  --mock-deal-bg: #ffffff;
  --mock-tag-soft-bg: rgba(194, 117, 91, 0.14);
  --mock-tag-soft-fg: #b06548;
  --mock-tag-hot-bg: rgba(220, 38, 38, 0.12);
  --mock-tag-hot-fg: #b91c1c;
  --mock-tag-accent-bg: rgba(125, 89, 56, 0.16);
  --mock-tag-accent-fg: #7d5938;
  --mock-tag-success-bg: rgba(20, 130, 87, 0.14);
  --mock-tag-success-fg: #15803d;
  --mock-col-cool: #7d5938;
  --mock-col-accent: #c2755b;
  --mock-col-success: #15803d;
}
.crm-mockup--atelier .crm-mockup__brand-mark {
  background:
    linear-gradient(
      135deg,
      #c2755b 0%,
      #d8a07a 100%);
  box-shadow: 0 4px 10px -4px rgba(194, 117, 91, 0.5);
}
.crm-mockup--atelier .crm-mockup__caption-brand {
  background:
    linear-gradient(
      120deg,
      #c2755b 0%,
      #d8a07a 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

/* assets/css/src/pages/thanks.css */
.thanks-hero {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(3.5rem, 6vw, 5.5rem) 0 clamp(3rem, 5vw, 4.5rem);
  text-align: center;
  border-bottom: 1px solid var(--color-border);
  background:
    radial-gradient(
      ellipse 90% 80% at 50% -30%,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 70% 60% at 100% 100%,
      rgba(34, 211, 238, 0.12) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 60% 60% at 0% 100%,
      rgba(16, 185, 129, 0.08) 0%,
      transparent 55%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.thanks-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.thanks-hero__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  opacity: 0.55;
  will-change: transform;
}
.thanks-hero__blob--a {
  top: -10%;
  left: 12%;
  width: 380px;
  height: 380px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.55) 0%,
      transparent 70%);
  animation: thanks-float 14s ease-in-out infinite;
}
.thanks-hero__blob--b {
  bottom: -20%;
  right: 8%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.45) 0%,
      transparent 70%);
  animation: thanks-float 18s ease-in-out -4s infinite reverse;
}
.thanks-hero__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(9, 9, 11, 0.04) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(9, 9, 11, 0.04) 1px,
      transparent 1px);
  background-size: 56px 56px;
  mask-image:
    radial-gradient(
      ellipse 60% 60% at 50% 40%,
      #000 0%,
      transparent 75%);
  -webkit-mask-image:
    radial-gradient(
      ellipse 60% 60% at 50% 40%,
      #000 0%,
      transparent 75%);
  opacity: 0.7;
}
.thanks-hero__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.thanks-mark {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 92px;
  height: 92px;
  margin-bottom: 1.5rem;
  color: #fff;
  border-radius: 50%;
  background:
    radial-gradient(
      circle at 30% 25%,
      rgba(255, 255, 255, 0.45) 0%,
      transparent 55%),
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      #8b5cf6 45%,
      var(--color-accent) 100%);
  box-shadow:
    0 18px 40px rgba(124, 58, 237, 0.35),
    0 0 0 8px rgba(124, 58, 237, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.45);
  animation: thanks-mark-in 0.7s var(--ease-out) both;
}
.thanks-mark__pulse {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1.5px solid rgba(124, 58, 237, 0.45);
  opacity: 0;
  animation: thanks-pulse 2.6s ease-out infinite;
}
.thanks-mark__pulse--b {
  animation-delay: 1.2s;
  border-color: rgba(34, 211, 238, 0.5);
}
.thanks-mark__svg {
  position: relative;
  width: 56px;
  height: 56px;
}
.thanks-mark__ring {
  fill: none;
  stroke: rgba(255, 255, 255, 0.35);
  stroke-width: 2;
  stroke-dasharray: 176;
  stroke-dashoffset: 176;
  transform: rotate(-90deg);
  transform-origin: 32px 32px;
  animation: thanks-ring-draw 0.9s var(--ease-out) 0.15s both;
}
.thanks-mark__check {
  stroke-dasharray: 50;
  stroke-dashoffset: 50;
  animation: thanks-check-draw 0.5s var(--ease-out) 0.55s both;
}
.thanks-hero__kicker {
  margin: 0 0 0.75rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-primary);
}
.thanks-hero__title {
  margin: 0;
  max-width: 24ch;
  font-family: var(--font-display);
  font-size: clamp(1.85rem, 4.5vw, 3rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.03em;
  color: var(--color-text);
}
.thanks-hero__lead {
  margin: 1rem auto 0;
  max-width: 42rem;
  font-size: clamp(1rem, 1.5vw, 1.1rem);
  line-height: 1.6;
  color: var(--color-muted);
}
.thanks-meta {
  margin: 1.75rem 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem 0.75rem;
}
.thanks-meta__item {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.45rem 0.85rem;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-muted);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 2px 10px rgba(9, 9, 11, 0.03);
}
.thanks-meta__icon {
  color: var(--color-primary);
  flex-shrink: 0;
}
.thanks-hero__actions {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
}
@media (max-width: 640px) {
  .thanks-hero__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .thanks-hero__actions > .btn {
    width: 100%;
  }
}
.thanks-hero__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.thanks-hero__cta svg {
  flex-shrink: 0;
}
.thanks-section-header {
  max-width: 48rem;
  margin: 0 auto clamp(2rem, 4vw, 3rem);
  text-align: center;
}
.thanks-eyebrow {
  margin: 0 0 0.65rem;
  font-size: 0.7rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-primary);
}
.thanks-section-header__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.8vw, 1.85rem);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.thanks-section-header__lead {
  margin: 0.85rem auto 0;
  max-width: 38rem;
  font-size: 1rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.thanks-steps {
  counter-reset: thanks-step;
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: 56rem;
  display: flex;
  flex-direction: column;
  gap: 0.875rem;
}
.thanks-step {
  position: relative;
  display: grid;
  grid-template-columns: 64px 1fr;
  gap: 1.25rem;
  padding: 1.5rem 1.5rem 1.5rem 1.25rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  transition:
    transform 0.35s var(--ease-out),
    box-shadow 0.35s var(--ease-out),
    border-color 0.35s var(--ease-out);
}
.thanks-step:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(124, 58, 237, 0.18);
}
.thanks-step__rail {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}
.thanks-step__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  font-family: var(--font-display);
  font-size: 0.95rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #fff;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      #6d28d9 60%,
      var(--color-accent) 130%);
  border-radius: 50%;
  box-shadow: 0 10px 24px rgba(124, 58, 237, 0.3), inset 0 1px 0 rgba(255, 255, 255, 0.35);
}
.thanks-step__rail::after {
  content: "";
  position: absolute;
  top: 56px;
  bottom: -22px;
  left: 50%;
  width: 2px;
  background:
    linear-gradient(
      180deg,
      rgba(124, 58, 237, 0.35) 0%,
      rgba(124, 58, 237, 0) 100%);
  transform: translateX(-50%);
}
.thanks-step:last-child .thanks-step__rail::after {
  display: none;
}
.thanks-step__body {
  min-width: 0;
}
.thanks-step__title {
  margin: 0 0 0.4rem;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-text);
}
.thanks-step__text {
  margin: 0;
  font-size: 0.97rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.thanks-step__eta {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  margin-top: 0.85rem;
  padding: 0.3rem 0.65rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
  border-radius: var(--radius-pill);
}
.thanks-step__eta svg {
  flex-shrink: 0;
}
.thanks-explore {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1rem;
}
.thanks-explore-card {
  position: relative;
  display: flex;
  flex-direction: column;
  padding: 1.75rem;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow);
  text-decoration: none;
  color: var(--color-text);
  overflow: hidden;
  transition:
    transform 0.35s var(--ease-out),
    box-shadow 0.35s var(--ease-out),
    border-color 0.35s var(--ease-out);
}
.thanks-explore-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(
      ellipse 60% 50% at 100% 0%,
      rgba(124, 58, 237, 0.08) 0%,
      transparent 60%);
  opacity: 0;
  transition: opacity 0.4s var(--ease-out);
  pointer-events: none;
}
.thanks-explore-card:hover,
.thanks-explore-card:focus-visible {
  transform: translateY(-4px);
  box-shadow: var(--shadow-hover);
  border-color: rgba(124, 58, 237, 0.2);
  outline: none;
}
.thanks-explore-card:hover::before,
.thanks-explore-card:focus-visible::before {
  opacity: 1;
}
.thanks-explore-card__icon {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  margin-bottom: 1rem;
  color: var(--color-primary);
  background: var(--color-primary-soft);
  border-radius: 12px;
}
.thanks-explore-card__eyebrow {
  margin: 0 0 0.4rem;
  position: relative;
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.thanks-explore-card__title {
  margin: 0 0 0.5rem;
  position: relative;
  font-family: var(--font-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-text);
}
.thanks-explore-card__text {
  margin: 0 0 1.25rem;
  position: relative;
  font-size: 0.93rem;
  line-height: 1.55;
  color: var(--color-muted);
  flex-grow: 1;
}
.thanks-explore-card__action {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--color-primary-dark);
}
.thanks-explore-card__action svg {
  transition: transform 0.3s var(--ease-out);
}
.thanks-explore-card:hover .thanks-explore-card__action svg,
.thanks-explore-card:focus-visible .thanks-explore-card__action svg {
  transform: translate(2px, -2px);
}
.thanks-note-section {
  padding-top: 0;
}
.thanks-note {
  margin: 0;
  text-align: center;
  font-size: 0.95rem;
  color: var(--color-muted);
}
.thanks-note__prefix {
  margin-right: 0.35rem;
}
.thanks-note__link {
  font-weight: 600;
  color: var(--color-primary-dark);
  text-decoration: none;
  border-bottom: 1px solid rgba(124, 58, 237, 0.25);
  transition: border-color 0.2s ease, color 0.2s ease;
}
.thanks-note__link:hover {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}
@media (max-width: 540px) {
  .thanks-step {
    grid-template-columns: 48px 1fr;
    gap: 1rem;
    padding: 1.25rem;
  }
  .thanks-step__num {
    width: 40px;
    height: 40px;
    font-size: 0.85rem;
  }
  .thanks-step__rail::after {
    top: 48px;
    bottom: -18px;
  }
  .thanks-meta__item {
    font-size: 0.74rem;
    padding: 0.4rem 0.75rem;
  }
}
@keyframes thanks-mark-in {
  0% {
    transform: scale(0.6);
    opacity: 0;
  }
  60% {
    transform: scale(1.05);
    opacity: 1;
  }
  100% {
    transform: scale(1);
    opacity: 1;
  }
}
@keyframes thanks-pulse {
  0% {
    transform: scale(0.85);
    opacity: 0.6;
  }
  100% {
    transform: scale(1.6);
    opacity: 0;
  }
}
@keyframes thanks-ring-draw {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes thanks-check-draw {
  to {
    stroke-dashoffset: 0;
  }
}
@keyframes thanks-float {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(0, -20px, 0) scale(1.06);
  }
}
@media (prefers-reduced-motion: reduce) {
  .thanks-mark,
  .thanks-mark__pulse,
  .thanks-mark__ring,
  .thanks-mark__check,
  .thanks-hero__blob {
    animation: none;
  }
  .thanks-mark__ring,
  .thanks-mark__check {
    stroke-dashoffset: 0;
  }
}

/* assets/css/src/pages/404.css */
.notfound {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  min-height: clamp(560px, 78vh, 820px);
  padding: clamp(2.5rem, 5vw, 4.5rem) 0;
  display: flex;
  align-items: center;
  text-align: center;
  background:
    radial-gradient(
      ellipse 90% 80% at 50% -20%,
      rgba(124, 58, 237, 0.18) 0%,
      transparent 55%),
    radial-gradient(
      ellipse 70% 60% at 100% 100%,
      rgba(34, 211, 238, 0.12) 0%,
      transparent 50%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.notfound__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
}
.notfound__blob {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: 0.5;
  will-change: transform;
}
.notfound__blob--a {
  top: -8%;
  left: 8%;
  width: 420px;
  height: 420px;
  background:
    radial-gradient(
      circle,
      rgba(124, 58, 237, 0.6) 0%,
      transparent 70%);
  animation: notfound-float 16s ease-in-out infinite;
}
.notfound__blob--b {
  bottom: -15%;
  right: 5%;
  width: 460px;
  height: 460px;
  background:
    radial-gradient(
      circle,
      rgba(34, 211, 238, 0.5) 0%,
      transparent 70%);
  animation: notfound-float 22s ease-in-out -6s infinite reverse;
}
.notfound__grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(9, 9, 11, 0.04) 1px, transparent 1px),
    linear-gradient(
      90deg,
      rgba(9, 9, 11, 0.04) 1px,
      transparent 1px);
  background-size: 56px 56px;
  mask-image:
    radial-gradient(
      ellipse 55% 55% at 50% 45%,
      #000 0%,
      transparent 75%);
  -webkit-mask-image:
    radial-gradient(
      ellipse 55% 55% at 50% 45%,
      #000 0%,
      transparent 75%);
  opacity: 0.6;
}
.notfound__inner {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.notfound__display {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: clamp(0.25rem, 1vw, 0.6rem);
  margin-bottom: clamp(1.25rem, 2.5vw, 1.75rem);
  font-family: var(--font-display);
  font-weight: 800;
  font-size: clamp(6.5rem, 18vw, 12rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
  user-select: none;
}
.notfound__digit {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      #8b5cf6 45%,
      var(--color-accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  text-shadow: 0 12px 60px rgba(124, 58, 237, 0.18);
  animation: notfound-digit-in 0.7s var(--ease-out) both;
}
.notfound__digit--four:first-child {
  animation-delay: 0.05s;
}
.notfound__digit--zero {
  animation-delay: 0.18s;
}
.notfound__digit--four:last-child {
  animation-delay: 0.3s;
}
.notfound__zero-glyph {
  position: relative;
  z-index: 2;
}
.notfound__digit--zero {
  width: 1em;
  aspect-ratio: 1 / 1;
}
.notfound__orbit {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.78em;
  height: 0.78em;
  border-radius: 50%;
  border: 1.5px dashed rgba(124, 58, 237, 0.28);
  transform: translate(-50%, -50%);
  animation: notfound-spin 18s linear infinite;
  z-index: 1;
}
.notfound__orb {
  position: absolute;
  top: calc(50% - 0.39em);
  left: 50%;
  width: 0.12em;
  height: 0.12em;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      var(--color-accent) 100%);
  box-shadow: 0 0 24px rgba(124, 58, 237, 0.55);
  transform: translate(-50%, 0);
  transform-origin: 50% 0.39em;
  animation: notfound-orb-spin 6s linear infinite;
  z-index: 3;
}
.notfound__kicker {
  margin: 0 0 0.75rem;
  font-size: 0.72rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--color-primary);
}
.notfound__title {
  margin: 0;
  max-width: 26ch;
  font-family: var(--font-display);
  font-size: clamp(1.45rem, 3.4vw, 2.2rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.02em;
  color: var(--color-text);
}
.notfound__lead {
  margin: 1rem auto 0;
  max-width: 38rem;
  font-size: clamp(0.97rem, 1.4vw, 1.05rem);
  line-height: 1.6;
  color: var(--color-muted);
}
.notfound__actions {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.65rem;
  justify-content: center;
}
@media (max-width: 640px) {
  .notfound__actions {
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: stretch;
    width: 100%;
    max-width: 22rem;
    margin-inline: auto;
  }
  .notfound__actions > .btn {
    width: 100%;
  }
}
.notfound__cta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.notfound__cta svg {
  flex-shrink: 0;
}
.notfound__quick {
  margin-top: 2.5rem;
  padding-top: 1.5rem;
  width: 100%;
  max-width: 44rem;
  border-top: 1px dashed var(--color-border);
}
.notfound__quick-label {
  margin: 0 0 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.notfound__quick-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}
.notfound__quick-link {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.5rem 0.95rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-text);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  text-decoration: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 2px 10px rgba(9, 9, 11, 0.03);
  transition:
    transform 0.25s var(--ease-out),
    border-color 0.25s var(--ease-out),
    color 0.25s var(--ease-out),
    box-shadow 0.25s var(--ease-out);
}
.notfound__quick-link svg {
  flex-shrink: 0;
  color: var(--color-muted);
  transition: transform 0.25s var(--ease-out), color 0.25s var(--ease-out);
}
.notfound__quick-link:hover,
.notfound__quick-link:focus-visible {
  transform: translateY(-2px);
  color: var(--color-primary-dark);
  border-color: rgba(124, 58, 237, 0.25);
  box-shadow: 0 8px 24px rgba(124, 58, 237, 0.12);
  outline: none;
}
.notfound__quick-link:hover svg,
.notfound__quick-link:focus-visible svg {
  color: var(--color-primary);
  transform: translate(2px, -2px);
}
@media (max-width: 540px) {
  .notfound {
    min-height: clamp(520px, 70vh, 720px);
  }
  .notfound__quick-link {
    font-size: 0.8rem;
    padding: 0.45rem 0.8rem;
  }
}
@keyframes notfound-digit-in {
  0% {
    opacity: 0;
    transform: translateY(20px) scale(0.94);
  }
  60% {
    opacity: 1;
    transform: translateY(-3px) scale(1.02);
  }
  100% {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}
@keyframes notfound-float {
  0%, 100% {
    transform: translate3d(0, 0, 0) scale(1);
  }
  50% {
    transform: translate3d(0, -22px, 0) scale(1.06);
  }
}
@keyframes notfound-spin {
  to {
    transform: translate(-50%, -50%) rotate(360deg);
  }
}
@keyframes notfound-orb-spin {
  from {
    transform: translate(-50%, 0) rotate(0deg);
  }
  to {
    transform: translate(-50%, 0) rotate(360deg);
  }
}
@media (prefers-reduced-motion: reduce) {
  .notfound__digit,
  .notfound__blob,
  .notfound__orbit,
  .notfound__orb {
    animation: none;
  }
}

/* assets/css/src/pages/legal.css */
.page-hero--legal {
  padding: 2.85rem 0 2.5rem;
  background:
    radial-gradient(
      ellipse 70% 60% at 80% -25%,
      rgba(124, 58, 237, 0.12) 0%,
      transparent 50%),
    radial-gradient(
      ellipse 60% 55% at 0% 100%,
      rgba(34, 211, 238, 0.08) 0%,
      transparent 48%),
    linear-gradient(
      180deg,
      #ffffff 0%,
      #f4f4f5 100%);
}
.legal-meta {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin: 1.1rem auto 0;
  padding: 0.4rem 0.9rem;
  border-radius: var(--radius-pill);
  background: rgba(255, 255, 255, 0.85);
  border: 1px solid var(--color-border);
  font-size: 0.78rem;
}
.legal-meta__label {
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.legal-meta__value {
  font-weight: 600;
  color: var(--color-text);
}
.legal-section {
  padding-top: 2.5rem;
  padding-bottom: 3.5rem;
}
.legal-shell {
  display: grid;
  gap: 2.25rem;
  grid-template-columns: 1fr;
  align-items: start;
}
@media (min-width: 900px) {
  .legal-shell {
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 3rem;
  }
}
@media (min-width: 1100px) {
  .legal-shell {
    grid-template-columns: 260px minmax(0, 1fr);
  }
}
.legal-toc {
  position: relative;
  padding: 1.1rem 1.2rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.95) 0%,
      rgba(244, 244, 245, 0.65) 100%);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
@media (min-width: 900px) {
  .legal-toc {
    position: sticky;
    top: 1.25rem;
  }
}
.legal-toc__label {
  margin: 0 0 0.65rem;
  font-size: 0.7rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.legal-toc__list {
  list-style: none;
  counter-reset: legal-toc;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}
.legal-toc__item {
  counter-increment: legal-toc;
}
.legal-toc__link {
  display: flex;
  gap: 0.55rem;
  padding: 0.4rem 0.5rem;
  border-radius: 10px;
  color: var(--color-text);
  text-decoration: none;
  font-size: 0.92rem;
  line-height: 1.35;
  transition: background-color 0.2s var(--ease-out), color 0.2s var(--ease-out);
}
.legal-toc__link::before {
  content: counter(legal-toc, decimal-leading-zero);
  flex-shrink: 0;
  width: 1.85rem;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: var(--color-muted);
  letter-spacing: 0.04em;
}
.legal-toc__link:hover,
.legal-toc__link:focus-visible {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
  outline: none;
}
.legal-doc {
  max-width: 780px;
  margin: 0;
}
.legal-doc__section {
  padding-top: 0.5rem;
  margin-bottom: 2.4rem;
  scroll-margin-top: 1.5rem;
}
.legal-doc__section:last-child {
  margin-bottom: 0;
}
.legal-doc__title {
  margin: 0 0 0.85rem;
  font-family: var(--font-display);
  font-size: clamp(1.2rem, 2.2vw, 1.45rem);
  font-weight: 700;
  letter-spacing: -0.015em;
  color: var(--color-text);
  line-height: 1.25;
}
.legal-doc__lead {
  margin: 0 0 0.85rem;
  color: var(--color-text);
  font-weight: 500;
  line-height: 1.6;
}
.legal-doc__p {
  margin: 0 0 0.85rem;
  color: var(--color-muted);
  line-height: 1.65;
}
.legal-doc__p:last-child {
  margin-bottom: 0;
}
.legal-doc__inline-link {
  color: var(--color-primary-dark);
  font-weight: 600;
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
  transition: color 0.2s var(--ease-out);
}
.legal-doc__inline-link:hover,
.legal-doc__inline-link:focus-visible {
  color: var(--color-primary);
  outline: none;
}
.legal-doc__list {
  margin: 0 0 0.85rem;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.legal-doc__list-item {
  position: relative;
  padding-left: 1.6rem;
  color: var(--color-muted);
  line-height: 1.55;
}
.legal-doc__list-item::before {
  content: "";
  position: absolute;
  top: 0.55em;
  left: 0.4rem;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 50%;
  background:
    linear-gradient(
      135deg,
      var(--color-primary) 0%,
      var(--color-accent) 100%);
  box-shadow: 0 0 0 3px rgba(124, 58, 237, 0.1);
}
.legal-cards {
  display: grid;
  gap: 1rem;
  margin: 0.5rem 0 0.25rem;
  grid-template-columns: 1fr;
}
@media (min-width: 720px) {
  .legal-cards {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
.legal-card {
  padding: 1.1rem 1.2rem 1.2rem;
  border-radius: var(--radius-lg);
  background:
    linear-gradient(
      155deg,
      rgba(255, 255, 255, 0.96) 0%,
      #fafafa 100%);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow);
}
.legal-card__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.65rem;
}
.legal-card__tag {
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-primary);
}
.legal-card__state {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-pill);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  line-height: 1;
}
.legal-card__state::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
}
.legal-card__state--on {
  color: var(--color-cta-dark);
  background: rgba(16, 185, 129, 0.12);
  border: 1px solid rgba(16, 185, 129, 0.25);
}
.legal-card__state--on::before {
  background: var(--color-cta);
}
.legal-card__state--optional {
  color: var(--color-primary-dark);
  background: var(--color-primary-soft);
  border: 1px solid rgba(124, 58, 237, 0.25);
}
.legal-card__state--optional::before {
  background: var(--color-primary);
}
.legal-card__title {
  margin: 0 0 0.45rem;
  font-family: var(--font-display);
  font-size: 1rem;
  font-weight: 800;
  letter-spacing: -0.01em;
  color: var(--color-text);
}
.legal-card__desc {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.legal-card__table {
  width: 100%;
  margin-top: 0.85rem;
  border-collapse: collapse;
  font-size: 0.85rem;
}
.legal-card__table th,
.legal-card__table td {
  padding: 0.5rem 0.6rem;
  text-align: left;
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}
.legal-card__table th {
  font-size: 0.68rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--color-muted);
}
.legal-card__table tbody tr:last-child td {
  border-bottom: none;
}
.legal-card__table code {
  font-size: 0.85em;
  padding: 0.1rem 0.4rem;
  border-radius: 6px;
  background: var(--color-primary-soft);
  color: var(--color-primary-dark);
  font-weight: 600;
}
.legal-browsers {
  margin: 0.65rem 0 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.legal-browsers__link {
  display: inline-flex;
  align-items: center;
  padding: 0.45rem 0.85rem;
  border-radius: var(--radius-pill);
  background: #fff;
  border: 1px solid var(--color-border);
  color: var(--color-text);
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  transition:
    border-color 0.2s var(--ease-out),
    color 0.2s var(--ease-out),
    box-shadow 0.2s var(--ease-out);
}
.legal-browsers__link:hover,
.legal-browsers__link:focus-visible {
  color: var(--color-primary-dark);
  border-color: rgba(124, 58, 237, 0.3);
  box-shadow: var(--shadow-glow);
  outline: none;
}

/* assets/css/src/vendor/intl-tel-input.css */
.iti {
  width: 100%;
}
.footer-cta-card__form .iti {
  flex: 1 1 auto;
  min-width: 0;
}
.modal--consult .modal__row > .modal__label {
  min-width: 0;
}
@media (min-width: 520px) {
  .modal--consult .modal__row {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1.22fr);
  }
}
.modal--consult .iti {
  display: block;
  min-width: 0;
}
.modal--consult .iti input.iti__tel-input {
  width: 100%;
  min-width: 0;
  font-size: 0.9375rem;
}
.quiz-step .form .iti {
  width: 100%;
}

/* assets/css/src/entry.css */
