@font-face {
  font-family: 'BuildInter';
  src: url('/fonts/inter-latin.woff2') format('woff2');
  font-style: normal;
  font-weight: 100 900;
  font-display: swap;
}

@font-face {
  font-family: 'BuildMono';
  src: url('/fonts/jetbrains-mono-latin.woff2') format('woff2');
  font-style: normal;
  font-weight: 100 800;
  font-display: swap;
}

:root {
  --bg: #0d0d0d;
  --fg: #f2f2f2;
  --accent: #ffb800;
  --bg-base: #0b0b0c;
  --bg-warm: #12100a;
  --bg-cool: #11150f;
  --ink: #171412;
  --ink-muted: rgba(23, 20, 18, 0.62);
  --ink-soft: rgba(23, 20, 18, 0.42);
  --line-light: rgba(242, 242, 242, 0.12);
  --line-dark: rgba(23, 20, 18, 0.12);
  --nav-height: 2rem;
  --section-scroll-offset-mobile: 40px;
  --section-scroll-offset-desktop: 40px;
  --section-scroll-offset: var(--section-scroll-offset-mobile);
  --display-font: "Arial Black", "Franklin Gothic Heavy", "Helvetica Neue", Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scroll-padding-top: var(--section-scroll-offset);
  font-family: 'BuildInter', ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  color-scheme: dark;
}

html[data-theme='light'] {
  color-scheme: light;
}

section[id] {
  scroll-margin-top: var(--section-scroll-offset);
}

@media (min-width: 768px) {
  :root {
    --section-scroll-offset: var(--section-scroll-offset-desktop);
  }
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--fg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.site-shell,
#site-nav,
#mobile-menu,
.bg-section-base,
.bg-section-warm,
.bg-section-cool,
.bg-section-feature,
.bg-section-strip,
.contact-field,
.custom-select-list,
.custom-select-option,
.faq-item,
.faq-toggle,
.testimonial-mini,
.testimonial-indicator,
.featured-tab-button,
.theme-toggle,
.footer-outline-word {
  transition:
    background-color 0.35s ease,
    background-image 0.35s ease,
    color 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease;
}

html[data-theme='light'] body {
  background: #f4efe7;
  color: var(--ink);
}

html[data-theme='light'] .site-shell {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.58) 0%, rgba(244, 239, 231, 0) 26%),
    linear-gradient(180deg, #f7f3ec 0%, #f2ece2 100%);
}

.bg-section-base {
  background-color: var(--bg-base);
  background-image:
    radial-gradient(120% 90% at 50% -20%, rgba(242, 242, 242, 0.04) 0%, rgba(242, 242, 242, 0) 62%),
    radial-gradient(90% 80% at 8% 100%, rgba(255, 184, 0, 0.035) 0%, rgba(255, 184, 0, 0) 72%);
}

.bg-section-warm {
  background-color: var(--bg-warm);
  background-image:
    radial-gradient(120% 90% at 0% 0%, rgba(255, 184, 0, 0.09) 0%, rgba(255, 184, 0, 0) 60%),
    radial-gradient(100% 90% at 100% 100%, rgba(255, 107, 0, 0.07) 0%, rgba(255, 107, 0, 0) 72%);
}

.bg-section-cool {
  background-color: var(--bg-cool);
  background-image:
    radial-gradient(120% 90% at 100% 0%, rgba(152, 176, 110, 0.1) 0%, rgba(152, 176, 110, 0) 62%),
    radial-gradient(105% 95% at 0% 100%, rgba(96, 124, 72, 0.08) 0%, rgba(96, 124, 72, 0) 72%);
}

.bg-section-feature {
  background-color: #100d09;
  background-image:
    linear-gradient(180deg, rgba(255, 184, 0, 0.05) 0%, rgba(16, 13, 9, 0.45) 48%, rgba(16, 13, 9, 0.96) 100%),
    radial-gradient(110% 95% at 88% 8%, rgba(255, 107, 0, 0.08) 0%, rgba(255, 107, 0, 0) 68%);
}

.bg-section-strip {
  background-color: #100d08;
  background-image:
    linear-gradient(180deg, rgba(16, 13, 8, 0.08) 0%, rgba(16, 13, 8, 0.2) 44%, rgba(16, 13, 8, 0.94) 100%),
    linear-gradient(90deg, rgba(255, 184, 0, 0.07) 0%, rgba(16, 13, 8, 0.7) 45%, rgba(255, 107, 0, 0.05) 100%);
}

.divider-line {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 600px;
  max-width: 100%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 184, 0, 0.4), transparent);
  pointer-events: none;
  z-index: 2;
}

html[data-theme='light'] .bg-section-base {
  background-color: #f7f3ec;
  background-image:
    radial-gradient(120% 90% at 50% -18%, rgba(255, 184, 0, 0.09) 0%, rgba(255, 184, 0, 0) 58%),
    radial-gradient(95% 82% at 6% 100%, rgba(23, 20, 18, 0.05) 0%, rgba(23, 20, 18, 0) 72%);
}

html[data-theme='light'] .bg-section-warm {
  background-color: #f7efe2;
  background-image:
    radial-gradient(120% 90% at 0% 0%, rgba(255, 184, 0, 0.11) 0%, rgba(255, 184, 0, 0) 60%),
    radial-gradient(100% 90% at 100% 100%, rgba(255, 107, 0, 0.1) 0%, rgba(255, 107, 0, 0) 72%);
}

html[data-theme='light'] .bg-section-cool {
  background-color: #edf3ec;
  background-image:
    radial-gradient(120% 90% at 100% 0%, rgba(148, 178, 112, 0.16) 0%, rgba(148, 178, 112, 0) 62%),
    radial-gradient(105% 95% at 0% 100%, rgba(96, 124, 72, 0.09) 0%, rgba(96, 124, 72, 0) 72%);
}

html[data-theme='light'] .bg-section-feature {
  background-color: #fbf6ee;
  background-image:
    linear-gradient(180deg, rgba(255, 184, 0, 0.08) 0%, rgba(251, 246, 238, 0.86) 48%, rgba(251, 246, 238, 0.98) 100%),
    radial-gradient(110% 95% at 88% 8%, rgba(255, 107, 0, 0.12) 0%, rgba(255, 107, 0, 0) 68%);
}

html[data-theme='light'] .bg-section-strip {
  background-color: #f2ebdf;
  background-image:
    linear-gradient(180deg, rgba(255, 255, 255, 0.16) 0%, rgba(242, 235, 223, 0.7) 40%, rgba(242, 235, 223, 0.96) 100%),
    linear-gradient(90deg, rgba(255, 184, 0, 0.09) 0%, rgba(255, 255, 255, 0.36) 45%, rgba(255, 107, 0, 0.08) 100%);
}

.font-mono {
  font-family: 'BuildMono', 'JetBrains Mono', 'SF Mono', 'Fira Code', monospace;
}

.hero-title {
  font-family: var(--display-font);
  line-height: 1.1 !important;
}

.hero-stroke-word {
  display: inline-block;
  color: transparent;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 2px #ffb800;
  paint-order: stroke fill;
  font-kerning: none;
  font-variant-ligatures: none;
  font-feature-settings: "kern" 0, "liga" 0;
  text-shadow: none;
}

.hero-content-layer {
  transition: opacity 0.2s ease;
}

.hero-grid-overlay,
.hero-bg-gradient,
.hero-bg-image {
  transition: opacity 0.2s ease;
}

#hero-section.is-divider-dragging,
#hero-section.is-divider-dragging * {
  -webkit-user-select: none;
  user-select: none;
}

#hero-section.is-divider-dragging .hero-content-layer {
  opacity: 0.28;
  pointer-events: none;
}

#hero-section.is-divider-dragging .hero-grid-overlay,
#hero-section.is-divider-dragging .hero-bg-gradient {
  opacity: 0;
}

#hero-section.is-divider-dragging .hero-bg-image {
  opacity: 1;
}

.footer-outline-word {
  font-family: var(--display-font);
  color: transparent;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1px rgba(242, 242, 242, 0.08);
  paint-order: stroke fill;
  font-kerning: none;
  font-variant-ligatures: none;
  font-feature-settings: "kern" 0, "liga" 0;
  text-shadow: none;
}

.footer-outline-title {
  display: inline-block;
  font-size: clamp(3.2rem, 11.5vw, 10rem);
  line-height: 0.86;
  letter-spacing: -0.03em;
  max-width: 100%;
  white-space: nowrap;
}

::selection {
  background-color: #ffb800;
  color: #0d0d0d;
}

*:focus-visible {
  outline: 2px solid #ffb800;
  outline-offset: 2px;
}

.scrollbar-hide::-webkit-scrollbar {
  display: none;
}

.scrollbar-hide {
  -ms-overflow-style: none;
  scrollbar-width: none;
}

#projects-track {
  cursor: grab;
  will-change: scroll-position;
  -webkit-overflow-scrolling: auto;
  overscroll-behavior-x: contain;
}

#projects-track.is-dragging {
  cursor: grabbing;
}

#projects-track.is-dragging,
#projects-track.is-dragging * {
  -webkit-user-select: none;
  user-select: none;
}

#site-nav {
  border-bottom: 1px solid transparent;
}

#site-nav.is-scrolled {
  background: rgba(13, 13, 13, 0.9);
  backdrop-filter: blur(12px);
  border-bottom-color: rgba(242, 242, 242, 0.06);
}

html[data-theme='light'] #site-nav.is-scrolled {
  background: rgba(247, 243, 236, 0.88);
  border-bottom-color: rgba(23, 20, 18, 0.08);
  box-shadow: 0 14px 34px rgba(88, 67, 34, 0.08);
}

#mobile-menu {
  transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
  transition: transform 0.5s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.35s ease;
}

#mobile-menu.is-open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: auto;
}

.site-logo-word,
.site-quote-button,
.site-mobile-cta,
.site-menu-toggle,
.site-menu-toggle-line {
  transition: color 0.35s ease, border-color 0.35s ease, background-color 0.35s ease, box-shadow 0.35s ease;
}

.site-menu-toggle-icon {
  position: relative;
  display: inline-flex;
  width: 1.125rem;
  height: 0.875rem;
}

.site-menu-toggle-line {
  position: absolute;
  left: 0;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transform-origin: center;
  transition:
    transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    opacity 0.22s ease,
    top 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    bottom 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    background-color 0.35s ease;
}

.site-menu-toggle-line--top {
  top: 0;
}

.site-menu-toggle-line--middle {
  top: 50%;
  transform: translateY(-50%);
}

.site-menu-toggle-line--bottom {
  bottom: 0;
}

.site-menu-toggle.is-open .site-menu-toggle-line--top {
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}

.site-menu-toggle.is-open .site-menu-toggle-line--middle {
  opacity: 0;
  transform: translateY(-50%) scaleX(0.35);
}

.site-menu-toggle.is-open .site-menu-toggle-line--bottom {
  top: 50%;
  bottom: auto;
  transform: translateY(-50%) rotate(-45deg);
}

.theme-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 1px solid rgba(242, 242, 242, 0.18);
  border-radius: 999px;
  color: #f2f2f2;
  background: rgba(13, 13, 13, 0.38);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.18);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  cursor: pointer;
  overflow: hidden;
  transform-origin: center;
  transition:
    transform 0.35s ease,
    background-color 0.35s ease,
    border-color 0.35s ease,
    box-shadow 0.35s ease,
    color 0.35s ease;
}

.theme-toggle::before {
  content: '';
  position: absolute;
  inset: 0.38rem;
  border-radius: 999px;
  background: radial-gradient(circle, rgba(255, 184, 0, 0.22), transparent 68%);
  opacity: 0;
  transform: scale(0.7);
  transition: opacity 0.35s ease, transform 0.35s ease;
}

.theme-toggle:hover {
  transform: translateY(-1px) scale(1.02);
  border-color: rgba(255, 184, 0, 0.42);
}

.theme-toggle:hover::before {
  opacity: 1;
  transform: scale(1);
}

.theme-toggle:active {
  transform: scale(0.98);
}

.theme-toggle:focus-visible {
  outline: 2px solid rgba(255, 184, 0, 0.78);
  outline-offset: 3px;
}

.theme-toggle-icon-stack {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.2rem;
  height: 1.2rem;
  z-index: 1;
}

.theme-toggle-icon {
  position: absolute;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transform-origin: center center;
  transition: opacity 0.3s ease, transform 0.4s ease, filter 0.35s ease;
}

.theme-toggle-icon svg {
  display: block;
  width: 1.2rem;
  height: 1.2rem;
}

.theme-toggle-icon--sun {
  opacity: 1;
  transform: rotate(0deg) scale(1);
  filter: drop-shadow(0 0 10px rgba(255, 184, 0, 0.18));
}

.theme-toggle-icon--moon {
  opacity: 0;
  transform: rotate(-90deg) scale(0.6);
}

html[data-theme='light'] .theme-toggle {
  color: var(--ink);
  border-color: rgba(23, 20, 18, 0.12);
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 14px 28px rgba(170, 136, 68, 0.14);
}

html[data-theme='light'] .theme-toggle-icon--moon {
  opacity: 1;
  transform: rotate(0deg) scale(1);
}

html[data-theme='light'] .theme-toggle-icon--sun {
  opacity: 0;
  transform: rotate(90deg) scale(0.6);
  filter: none;
}

html[data-theme='light'] #site-nav.is-scrolled .site-logo-word {
  color: var(--ink);
}

html[data-theme='light'] #site-nav:not(.is-scrolled) .site-logo-word,
html[data-theme='light'] #site-nav:not(.is-scrolled) .site-nav-link,
html[data-theme='light'] #site-nav:not(.is-scrolled) .site-menu-toggle {
  color: #f2f2f2 !important;
}

html[data-theme='light'] #site-nav:not(.is-scrolled) .theme-toggle {
  color: #f2f2f2;
  border-color: rgba(242, 242, 242, 0.18);
  background: rgba(13, 13, 13, 0.42);
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.2);
}

.demo-banner {
  position: fixed;
  left: 50%;
  bottom: 1rem;
  transform: translateX(-50%) translateY(12px);
  z-index: 130;
  width: calc(100% - 2rem);
  max-width: 674px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.9rem 1rem;
  border-radius: 14px;
  font-family: 'BuildInter', ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", Segoe UI Symbol, "Noto Color Emoji";
  border: 1px solid rgba(255, 184, 0, 0.22);
  background:
    linear-gradient(140deg, rgba(255, 184, 0, 0.14), rgba(255, 107, 0, 0.05) 42%, rgba(255, 107, 0, 0) 80%),
    rgba(11, 11, 12, 0.92);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.3);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.35s ease, transform 0.35s ease, visibility 0.35s ease, border-color 0.35s ease, background-color 0.35s ease, box-shadow 0.35s ease;
}

.demo-banner.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}

.demo-banner.is-hidden {
  display: none;
}

.demo-banner p {
  margin: 0;
  color: rgba(242, 242, 242, 0.84);
  font-size: 0.9rem;
  line-height: 1.5;
}

.demo-banner a {
  color: #ffb800;
  font-weight: 700;
  text-decoration: none;
  transition: color 0.25s ease, opacity 0.25s ease;
}

.demo-banner a:hover,
.demo-banner a:focus-visible {
  color: #ffcf5a;
}

.demo-banner__close {
  flex-shrink: 0;
  border: 1px solid rgba(242, 242, 242, 0.12);
  background: rgba(255, 184, 0, 0.12);
  color: #f2f2f2;
  padding: 0.6rem 0.85rem;
  border-radius: 999px;
  font-family: inherit;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background-color 0.25s ease, border-color 0.25s ease, color 0.25s ease, transform 0.25s ease;
}

.demo-banner__close:hover,
.demo-banner__close:focus-visible {
  background: rgba(255, 184, 0, 0.18);
  border-color: rgba(255, 184, 0, 0.32);
  color: #ffffff;
}

.demo-banner__close:active {
  transform: scale(0.98);
}

html[data-theme='light'] .demo-banner {
  border-color: rgba(201, 141, 40, 0.22);
  background:
    linear-gradient(140deg, rgba(255, 184, 0, 0.12), rgba(255, 107, 0, 0.05) 42%, rgba(255, 107, 0, 0) 80%),
    rgba(250, 246, 238, 0.92);
  box-shadow: 0 18px 45px rgba(109, 82, 39, 0.16);
}

html[data-theme='light'] .demo-banner p {
  color: rgba(23, 20, 18, 0.84);
}

html[data-theme='light'] .demo-banner a {
  color: #cf7a14;
}

html[data-theme='light'] .demo-banner a:hover,
html[data-theme='light'] .demo-banner a:focus-visible {
  color: #a95c00;
}

html[data-theme='light'] .demo-banner__close {
  border-color: rgba(23, 20, 18, 0.1);
  background: rgba(255, 184, 0, 0.12);
  color: var(--ink);
}

html[data-theme='light'] .demo-banner__close:hover,
html[data-theme='light'] .demo-banner__close:focus-visible {
  background: rgba(255, 184, 0, 0.18);
  border-color: rgba(207, 122, 20, 0.28);
}

html[data-theme='light'] #site-nav:not(.is-scrolled) .site-menu-toggle {
  border-color: rgba(242, 242, 242, 0.2) !important;
}

html[data-theme='light'] #site-nav.is-scrolled .site-nav-link {
  color: rgba(23, 20, 18, 0.62) !important;
}

html[data-theme='light'] #site-nav.is-scrolled .site-nav-link:hover,
html[data-theme='light'] #site-nav.is-scrolled .site-nav-link.is-active {
  color: #ffb800 !important;
}

html[data-theme='light'] #site-nav.is-scrolled .site-menu-toggle {
  color: var(--ink) !important;
  border-color: rgba(23, 20, 18, 0.12) !important;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 10px 20px rgba(146, 120, 61, 0.12);
}

html[data-theme='light'] .site-quote-button,
html[data-theme='light'] .site-mobile-cta {
  box-shadow: 0 12px 24px rgba(207, 146, 31, 0.18);
}

html[data-theme='light'] .site-mobile-menu {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.84) 0%, rgba(246, 239, 228, 0.96) 100%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

html[data-theme='light'] .site-mobile-menu-link {
  border-bottom-color: rgba(23, 20, 18, 0.08) !important;
}

html[data-theme='light'] .site-mobile-menu-link span:last-child {
  color: var(--ink) !important;
}

.section-grid-lines {
  transition: background-image 0.35s ease, opacity 0.35s ease;
}

html[data-theme='light'] .section-grid-lines--vertical {
  background-image: linear-gradient(to right, rgba(31, 24, 16, 0.045) 1px, transparent 1px) !important;
  opacity: 0.72;
}

html[data-theme='light'] .section-grid-lines--horizontal {
  background-image: linear-gradient(to bottom, rgba(31, 24, 16, 0.038) 1px, transparent 1px) !important;
  opacity: 0.68;
}

html[data-theme='light'] .stats-section-wash {
  background: linear-gradient(180deg, rgba(255, 184, 0, 0.04) 0%, transparent 22%, transparent 68%, rgba(243, 236, 224, 0.84) 100%) !important;
}

html[data-theme='light'] .services-top-fade {
  background: linear-gradient(180deg, rgba(252, 248, 241, 0.94) 0%, rgba(252, 248, 241, 0) 100%) !important;
}

html[data-theme='light'] .featured-project-section {
  background:
    linear-gradient(180deg, #f3ecdf 0%, #f8f4eb 24%, #fbf8f1 100%);
}

html[data-theme='light'] .featured-project-hero {
  background: #e5d8c7;
}

html[data-theme='light'] .featured-project-overlay--vertical {
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.02) 0%, rgba(22, 18, 12, 0.04) 32%, rgba(57, 41, 19, 0.56) 78%, rgba(73, 53, 24, 0.82) 100%) !important;
}

html[data-theme='light'] .featured-project-overlay--horizontal {
  background: linear-gradient(to right, rgba(33, 24, 12, 0.62) 0%, rgba(33, 24, 12, 0.22) 36%, transparent 60%) !important;
}

.nav-link::after {
  content: '';
  position: absolute;
  left: 0;
  right: 0;
  bottom: -0.55rem;
  height: 1px;
  background: #ffb800;
  opacity: 0;
  transform: scaleX(0.35);
  transform-origin: center;
  transition: opacity 0.2s ease, transform 0.2s ease;
}

.nav-link.is-active {
  color: #ffb800 !important;
}

.nav-link.is-active::after {
  opacity: 1;
  transform: scaleX(1);
}

html[data-theme='light'] .site-shell [class*='text-[#FFB800]'] {
  color: #c77900 !important;
}

html[data-theme='light'] .site-shell [class*='text-[#FFB800]/70'] {
  color: rgba(199, 121, 0, 0.72) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#FFB800]/65'] {
  color: rgba(199, 121, 0, 0.68) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#FFB800]/60'] {
  color: rgba(199, 121, 0, 0.64) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#FFB800]/50'] {
  color: rgba(199, 121, 0, 0.56) !important;
}

html[data-theme='light'] .site-shell [class*='hover:text-[#FFB800]']:hover,
html[data-theme='light'] .site-shell .group:hover [class*='group-hover:text-[#FFB800]'] {
  color: #c77900 !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#FFB800]'] {
  color: #ffb800 !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#FFB800]/70'] {
  color: rgba(255, 184, 0, 0.72) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#FFB800]/65'] {
  color: rgba(255, 184, 0, 0.68) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#FFB800]/60'] {
  color: rgba(255, 184, 0, 0.64) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#FFB800]/50'] {
  color: rgba(255, 184, 0, 0.56) !important;
}

html[data-theme='light'] .theme-contrast [class*='hover:text-[#FFB800]']:hover,
html[data-theme='light'] .theme-contrast .group:hover [class*='group-hover:text-[#FFB800]'] {
  color: #ffb800 !important;
}

html[data-theme='light'] .site-shell [class*='text-[#A8FF78]'] {
  color: #7caf59 !important;
}

html[data-theme='light'] .site-shell [class*='text-[#00C6FF]'] {
  color: #1f8fb8 !important;
}

html[data-theme='light'] .site-shell [class*='text-[#f857a6]'] {
  color: #bf4c82 !important;
}

html[data-theme='light'] .site-shell [style*='color: #A8FF78'] {
  color: #7caf59 !important;
}

html[data-theme='light'] .site-shell [style*='background: #A8FF78'] {
  background: #7caf59 !important;
}

html[data-theme='light'] .site-shell [style*='color: #00C6FF'] {
  color: #1f8fb8 !important;
}

html[data-theme='light'] .site-shell [style*='background: #00C6FF'] {
  background: #1f8fb8 !important;
}

html[data-theme='light'] .site-shell [style*='color: #f857a6'] {
  color: #bf4c82 !important;
}

html[data-theme='light'] .site-shell [style*='background: #f857a6'] {
  background: #bf4c82 !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#A8FF78]'] {
  color: #a8ff78 !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#00C6FF]'] {
  color: #00c6ff !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#f857a6]'] {
  color: #f857a6 !important;
}

html[data-theme='light'] .theme-contrast [style*='color: #A8FF78'] {
  color: #a8ff78 !important;
}

html[data-theme='light'] .theme-contrast [style*='background: #A8FF78'] {
  background: #a8ff78 !important;
}

html[data-theme='light'] .theme-contrast [style*='color: #00C6FF'] {
  color: #00c6ff !important;
}

html[data-theme='light'] .theme-contrast [style*='background: #00C6FF'] {
  background: #00c6ff !important;
}

html[data-theme='light'] .theme-contrast [style*='color: #f857a6'] {
  color: #f857a6 !important;
}

html[data-theme='light'] .theme-contrast [style*='background: #f857a6'] {
  background: #f857a6 !important;
}

.mobile-nav-link.is-active {
  border-bottom-color: rgba(255, 184, 0, 0.26);
}

.mobile-nav-link.is-active > :first-child {
  color: rgba(255, 184, 0, 0.95);
}

.mobile-nav-link.is-active > :last-child {
  color: #ffb800;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]'] {
  color: rgba(23, 20, 18, 0.94) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/75'] {
  color: rgba(23, 20, 18, 0.78) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/70'] {
  color: rgba(23, 20, 18, 0.74) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/65'] {
  color: rgba(23, 20, 18, 0.7) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/60'] {
  color: rgba(23, 20, 18, 0.66) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/55'] {
  color: rgba(23, 20, 18, 0.62) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/50'] {
  color: rgba(23, 20, 18, 0.56) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/40'] {
  color: rgba(23, 20, 18, 0.48) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/35'] {
  color: rgba(23, 20, 18, 0.44) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/30'] {
  color: rgba(23, 20, 18, 0.39) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/25'] {
  color: rgba(23, 20, 18, 0.34) !important;
}

html[data-theme='light'] .site-shell [class*='text-[#F2F2F2]/20'] {
  color: rgba(23, 20, 18, 0.28) !important;
}

html[data-theme='light'] .site-shell .group:hover [class*='group-hover:text-[#F2F2F2]'] {
  color: rgba(23, 20, 18, 0.94) !important;
}

html[data-theme='light'] .site-shell [class*='border-[#F2F2F2]'] {
  border-color: rgba(23, 20, 18, 0.14) !important;
}

html[data-theme='light'] .site-shell [class*='border-[#F2F2F2]/20'] {
  border-color: rgba(23, 20, 18, 0.2) !important;
}

html[data-theme='light'] .site-shell [class*='border-[#F2F2F2]/15'],
html[data-theme='light'] .site-shell [class*='border-[#F2F2F2]/10'] {
  border-color: rgba(23, 20, 18, 0.15) !important;
}

html[data-theme='light'] .site-shell [class*='bg-[#0D0D0D]'] {
  background-color: rgba(255, 255, 255, 0.78) !important;
}

html[data-theme='light'] .site-shell [class*='bg-[#0D0D0D]/80'] {
  background-color: rgba(255, 255, 255, 0.84) !important;
}

html[data-theme='light'] .site-shell [class*='bg-[#0D0D0D]/70'] {
  background-color: rgba(255, 255, 255, 0.8) !important;
}

html[data-theme='light'] .site-shell [class*='bg-[#1a1a1a]'],
html[data-theme='light'] .site-shell [class*='bg-[#121212]'] {
  background-color: rgba(255, 255, 255, 0.72) !important;
}

html[data-theme='light'] .site-shell [class*='divide-[#F2F2F2]'] > :not([hidden]) ~ :not([hidden]) {
  border-color: rgba(23, 20, 18, 0.08) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]'] {
  color: rgba(242, 242, 242, 0.94) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/75'] {
  color: rgba(242, 242, 242, 0.76) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/70'] {
  color: rgba(242, 242, 242, 0.72) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/65'] {
  color: rgba(242, 242, 242, 0.67) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/60'] {
  color: rgba(242, 242, 242, 0.62) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/55'] {
  color: rgba(242, 242, 242, 0.62) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/50'] {
  color: rgba(242, 242, 242, 0.56) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/40'] {
  color: rgba(242, 242, 242, 0.48) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/30'] {
  color: rgba(242, 242, 242, 0.4) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/25'] {
  color: rgba(242, 242, 242, 0.34) !important;
}

html[data-theme='light'] .theme-contrast [class*='text-[#F2F2F2]/20'] {
  color: rgba(242, 242, 242, 0.28) !important;
}

html[data-theme='light'] .theme-contrast .group:hover [class*='group-hover:text-[#F2F2F2]'] {
  color: rgba(242, 242, 242, 0.94) !important;
}

html[data-theme='light'] .theme-contrast [class*='border-[#F2F2F2]'] {
  border-color: rgba(242, 242, 242, 0.14) !important;
}

html[data-theme='light'] .theme-contrast [class*='border-[#F2F2F2]/20'],
html[data-theme='light'] .theme-contrast [class*='border-[#F2F2F2]/15'],
html[data-theme='light'] .theme-contrast [class*='border-[#F2F2F2]/10'] {
  border-color: rgba(242, 242, 242, 0.16) !important;
}

html[data-theme='light'] .theme-contrast [class*='bg-[#0D0D0D]'] {
  background-color: rgba(13, 13, 13, 0.78) !important;
}

html[data-theme='light'] .theme-contrast [class*='bg-[#0D0D0D]/80'] {
  background-color: rgba(13, 13, 13, 0.82) !important;
}

html[data-theme='light'] .theme-contrast [class*='bg-[#0D0D0D]/70'] {
  background-color: rgba(13, 13, 13, 0.7) !important;
}

html[data-theme='light'] .theme-contrast [class*='bg-[#1a1a1a]'],
html[data-theme='light'] .theme-contrast [class*='bg-[#121212]'] {
  background-color: rgba(26, 26, 26, 1) !important;
}

html[data-theme='light'] .hero-grid-overlay {
  opacity: 0.9;
}

html[data-theme='light'] .footer-outline-word {
  -webkit-text-stroke-color: rgba(23, 20, 18, 0.12);
}

html[data-theme='light'] .featured-tab-button {
  color: rgba(23, 20, 18, 0.34);
}

html[data-theme='light'] .featured-tab-button:hover {
  color: rgba(23, 20, 18, 0.58);
}

html[data-theme='light'] .featured-tab-button.is-active {
  color: #c77900;
  border-color: rgba(199, 121, 0, 0.42) !important;
}

html[data-theme='light'] .contact-field {
  background: rgba(255, 255, 255, 0.76);
  border-color: rgba(23, 20, 18, 0.14);
  box-shadow: 0 16px 30px rgba(176, 136, 54, 0.06);
}

html[data-theme='light'] .contact-field:hover {
  border-color: rgba(23, 20, 18, 0.22);
}

html[data-theme='light'] .contact-field:focus {
  background: rgba(255, 255, 255, 0.94);
}

html[data-theme='light'] .contact-field::placeholder {
  color: rgba(23, 20, 18, 0.28) !important;
}

html[data-theme='light'] .custom-select-list {
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 36px rgba(108, 81, 27, 0.14);
}

html[data-theme='light'] .custom-select-option {
  color: rgba(23, 20, 18, 0.68);
  border-bottom-color: rgba(23, 20, 18, 0.08);
}

html[data-theme='light'] .custom-select-option:hover,
html[data-theme='light'] .custom-select-option:focus-visible {
  color: var(--ink);
  background: rgba(23, 20, 18, 0.05);
}

html[data-theme='light'] .custom-select-option.is-selected {
  background: rgba(255, 184, 0, 0.12);
}

html[data-theme='light'] .testimonial-indicator {
  background: rgba(23, 20, 18, 0.14);
}

html[data-theme='light'] .testimonial-indicator:hover {
  background: rgba(23, 20, 18, 0.22);
}

html[data-theme='light'] .testimonial-indicator.is-active {
  background: #c77900;
  box-shadow: 0 0 0 1px rgba(199, 121, 0, 0.18);
}

html[data-theme='light'] .testimonial-mini {
  border-color: rgba(23, 20, 18, 0.08);
  background: rgba(255, 255, 255, 0.42);
}

html[data-theme='light'] .testimonial-mini:hover {
  border-color: rgba(23, 20, 18, 0.14);
}

html[data-theme='light'] .testimonial-mini.is-active {
  background: linear-gradient(to right, rgba(255, 184, 0, 0.09), rgba(255, 255, 255, 0.68));
}

html[data-theme='light'] .faq-item {
  border-color: rgba(23, 20, 18, 0.08);
  background:
    linear-gradient(135deg, rgba(255, 184, 0, 0.05), transparent 38%),
    rgba(255, 255, 255, 0.5);
}

html[data-theme='light'] .faq-item:hover {
  border-color: rgba(23, 20, 18, 0.14);
}

html[data-theme='light'] .faq-item[open] {
  background:
    linear-gradient(135deg, rgba(255, 184, 0, 0.08), transparent 42%),
    rgba(255, 255, 255, 0.62);
}

html[data-theme='light'] .faq-toggle {
  border-color: rgba(23, 20, 18, 0.12);
  background: rgba(255, 255, 255, 0.72);
}

html[data-theme='light'] .faq-toggle::before,
html[data-theme='light'] .faq-toggle::after {
  background: rgba(23, 20, 18, 0.72);
}

.reveal-block {
  opacity: 0;
  transform: translate3d(0, var(--reveal-distance, 18px), 0);
  transition:
    opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.28s cubic-bezier(0.4, 0, 0.2, 1);
  transition-delay: var(--reveal-delay, 0ms);
  will-change: opacity, transform;
}

.reveal-block[data-reveal-direction='left'] {
  transform: translate3d(calc(var(--reveal-distance, 18px) * -1), 0, 0);
}

.reveal-block[data-reveal-direction='right'] {
  transform: translate3d(var(--reveal-distance, 18px), 0, 0);
}

.reveal-block[data-reveal-direction='scale'] {
  transform: translate3d(0, var(--reveal-distance, 18px), 0) scale(0.985);
  transform-origin: center bottom;
}

.reveal-block.is-revealed {
  opacity: 1;
  transform: translate3d(0, 0, 0) scale(1);
}

.scroll-indicator {
  animation: floatDownCentered 2s ease-in-out infinite;
  will-change: transform;
}

.service-content {
  max-height: 0;
  opacity: 0;
  transition: max-height 0.45s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.25s ease;
}

.service-card.open .service-content {
  opacity: 1;
}

.service-toggle-icon {
  transition: transform 0.3s ease, border-color 0.3s ease, background 0.3s ease;
}

.service-card.open .service-toggle-icon {
  transform: rotate(45deg);
}

.service-phase-icon,
.service-phase-number,
.service-phase-duration,
.service-phase-dot,
.step-icon-wrap,
.step-icon,
.step-number,
.step-title {
  transition: color 0.35s ease, border-color 0.35s ease, background-color 0.35s ease, opacity 0.35s ease;
}

html[data-theme='light'] .service-phase-meta--muted {
  color: rgba(23, 20, 18, 0.56) !important;
}

html[data-theme='light'] .service-phase-count {
  color: rgba(23, 20, 18, 0.36) !important;
}

html[data-theme='light'] .service-summary {
  color: rgba(23, 20, 18, 0.62) !important;
}

html[data-theme='light'] .service-phase-number.service-phase-meta--muted {
  color: rgba(23, 20, 18, 0.42) !important;
}

html[data-theme='light'] .service-phase-icon.service-phase-meta--muted,
html[data-theme='light'] .service-phase-duration.service-phase-meta--muted {
  color: rgba(23, 20, 18, 0.56) !important;
}

html[data-theme='light'] .service-phase-title {
  color: rgba(23, 20, 18, 0.9) !important;
}

html[data-theme='light'] .service-phase-dot--muted {
  background: rgba(23, 20, 18, 0.42) !important;
}

html[data-theme='light'] .service-stat-label {
  color: rgba(23, 20, 18, 0.4) !important;
}

html[data-theme='light'] .service-capability-tag {
  color: rgba(23, 20, 18, 0.5) !important;
  border-color: rgba(23, 20, 18, 0.1) !important;
}

.featured-tab-button {
  border-color: transparent;
  color: rgba(242, 242, 242, 0.3);
}

.featured-tab-button:hover {
  color: rgba(242, 242, 242, 0.6);
}

.featured-tab-button.is-active {
  border-color: #ffb800;
  color: #ffb800;
}

.featured-tab-panel {
  animation: panelFadeUp 0.3s ease;
}

.timeline-fill {
  transition: width 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.process-step-button.is-active {
  border-color: rgba(255, 184, 0, 0.3);
}

.process-step-button .step-icon-wrap {
  transition: opacity 0.3s ease, background 0.3s ease, border-color 0.3s ease;
}

.process-step-button:not(.is-active) .step-icon-wrap {
  opacity: 0.3;
}

.process-step-button:not(.is-active):hover .step-icon-wrap {
  opacity: 0.5;
}

html[data-theme='light'] .process-step-button {
  background: rgba(255, 255, 255, 0.12);
  border-color: rgba(23, 20, 18, 0.12) !important;
}

html[data-theme='light'] .process-step-button.is-active {
  box-shadow: 0 18px 34px rgba(81, 122, 160, 0.08);
}

html[data-theme='light'] .process-step-button.is-active .step-title {
  color: rgba(23, 20, 18, 0.94) !important;
}

html[data-theme='light'] .process-step-button:not(.is-active):hover {
  border-color: rgba(23, 20, 18, 0.18) !important;
  background: rgba(255, 255, 255, 0.2);
}

html[data-theme='light'] .process-step-button:not(.is-active):hover .step-icon-wrap--muted {
  border-color: rgba(23, 20, 18, 0.18) !important;
  background: rgba(255, 255, 255, 0.7);
  opacity: 0.82 !important;
}

html[data-theme='light'] .process-step-button:not(.is-active):hover .step-icon--muted {
  color: rgba(23, 20, 18, 0.76) !important;
}

html[data-theme='light'] .process-step-button:not(.is-active):hover .step-number--muted {
  color: rgba(23, 20, 18, 0.42) !important;
}

html[data-theme='light'] .process-step-button:not(.is-active):hover .step-title {
  color: rgba(23, 20, 18, 0.7) !important;
}

html[data-theme='light'] .step-icon-wrap--muted {
  border-color: rgba(23, 20, 18, 0.14) !important;
  background: rgba(23, 20, 18, 0.03);
  opacity: 0.62 !important;
}

html[data-theme='light'] .step-icon--muted {
  color: rgba(23, 20, 18, 0.64) !important;
}

html[data-theme='light'] .step-number--muted {
  color: rgba(23, 20, 18, 0.34) !important;
}

.process-panel {
  animation: panelFadeIn 0.35s ease;
}

.contact-field {
  background: rgba(13, 13, 13, 0.42);
  border: 1px solid rgba(242, 242, 242, 0.14);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: border-color 0.2s ease, background-color 0.2s ease;
}

.contact-field:hover {
  border-color: rgba(242, 242, 242, 0.24);
}

.contact-field:focus {
  border-color: #ffb800;
  background: rgba(13, 13, 13, 0.56);
}

.custom-select-trigger {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.custom-select-label {
  font-size: inherit;
  line-height: 1.2;
}

.custom-select-icon {
  transition: transform 0.25s ease, color 0.25s ease;
}

.custom-select-list {
  max-height: min(16rem, 45vh);
  overflow-y: auto;
  background: rgba(12, 12, 12, 0.76);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  -ms-overflow-style: none;
  scrollbar-width: none;
  box-shadow: 0 14px 30px rgba(0, 0, 0, 0.45);
}

.custom-select-list::-webkit-scrollbar {
  display: none;
  width: 0;
  height: 0;
}

.custom-select-option {
  width: 100%;
  text-align: left;
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(242, 242, 242, 0.08);
  color: rgba(242, 242, 242, 0.72);
  padding: 0.65rem 0.75rem;
  font-size: 0.82rem;
  transition: color 0.2s ease, background 0.2s ease;
}

.custom-select-option:last-child {
  border-bottom: 0;
}

.custom-select-option:hover,
.custom-select-option:focus-visible {
  color: #f2f2f2;
  background: rgba(242, 242, 242, 0.06);
  outline: none;
}

.custom-select-option.is-selected {
  color: #ffb800;
  background: rgba(255, 184, 0, 0.08);
}

.custom-select.is-open .custom-select-trigger {
  border-color: #ffb800;
}

.custom-select.is-open .custom-select-icon {
  transform: rotate(180deg);
  color: #ffb800;
}

@media (max-width: 767px) {
  .reveal-block {
    --reveal-distance: 14px;
  }

  html[data-theme='light'] .featured-tab-button.is-active {
    background:
      linear-gradient(135deg, rgba(255, 184, 0, 0.1), rgba(255, 255, 255, 0.78));
    box-shadow: 0 10px 18px rgba(173, 127, 44, 0.08);
  }

  .contact-field {
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
    font-size: 16px;
  }

  .custom-select-option {
    font-size: 0.79rem;
  }

  .faq-item {
    backdrop-filter: blur(7px);
    -webkit-backdrop-filter: blur(7px);
  }

  .faq-summary {
    padding: 1rem 1rem 0.95rem;
    align-items: flex-start;
  }

  .faq-toggle {
    width: 2.15rem;
    height: 2.15rem;
  }

  .faq-answer-inner {
    padding: 0 1rem 1rem;
  }
}

.testimonial-stage {
  min-height: 20rem;
}

.testimonial-panel {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(18px);
  transition: opacity 0.45s ease, transform 0.55s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}

.testimonial-panel.is-active {
  position: relative;
  z-index: 1;
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}

.testimonial-indicator {
  width: 1.75rem;
  background: rgba(242, 242, 242, 0.15);
}

.testimonial-indicator:hover {
  background: rgba(242, 242, 242, 0.3);
}

.testimonial-indicator.is-active {
  width: 3.5rem;
  background: #ffb800;
}

.testimonial-mini {
  border-color: rgba(242, 242, 242, 0.06);
  background: rgba(242, 242, 242, 0.02);
}

.testimonial-mini:hover {
  border-color: rgba(242, 242, 242, 0.12);
}

.testimonial-mini.is-active {
  border-color: rgba(255, 184, 0, 0.4);
  background: linear-gradient(to right, rgba(255, 184, 0, 0.07), transparent);
}

.faq-item {
  border: 1px solid rgba(242, 242, 242, 0.08);
  background:
    linear-gradient(135deg, rgba(255, 184, 0, 0.035), transparent 38%),
    rgba(242, 242, 242, 0.02);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition:
    opacity 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    transform 0.28s cubic-bezier(0.4, 0, 0.2, 1),
    border-color 0.25s ease,
    background-color 0.25s ease;
}

.faq-item:hover {
  border-color: rgba(242, 242, 242, 0.14);
}

.faq-item[open] {
  border-color: rgba(255, 184, 0, 0.32);
  background:
    linear-gradient(135deg, rgba(255, 184, 0, 0.055), transparent 42%),
    rgba(242, 242, 242, 0.028);
}

.faq-summary {
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  width: 100%;
  cursor: pointer;
  padding: 1.25rem 1.25rem 1.2rem;
}

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

.faq-summary:focus-visible {
  outline: 2px solid rgba(255, 184, 0, 0.7);
  outline-offset: -2px;
}

.faq-toggle {
  position: relative;
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border: 1px solid rgba(242, 242, 242, 0.12);
  background: rgba(13, 13, 13, 0.36);
  transition: border-color 0.25s ease, background-color 0.25s ease;
}

.faq-toggle::before,
.faq-toggle::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 0.8rem;
  height: 1px;
  background: rgba(242, 242, 242, 0.72);
  transform: translate(-50%, -50%);
  transition: transform 0.25s ease, opacity 0.25s ease, background-color 0.25s ease;
}

.faq-toggle::after {
  transform: translate(-50%, -50%) rotate(90deg);
}

.faq-item[open] .faq-toggle {
  border-color: rgba(255, 184, 0, 0.3);
  background: rgba(255, 184, 0, 0.08);
}

.faq-item[open] .faq-toggle::before,
.faq-item[open] .faq-toggle::after {
  background: #ffb800;
}

.faq-item[open] .faq-toggle::after {
  opacity: 0;
  transform: translate(-50%, -50%) rotate(90deg) scaleX(0);
}

.faq-answer {
  height: 0;
  overflow: hidden;
  opacity: 0;
  transition: height 0.38s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.22s ease;
  will-change: height, opacity;
}

.faq-item[open] .faq-answer {
  opacity: 1;
}

.faq-answer-inner {
  padding: 0 1.25rem 1.25rem;
}

.line-clamp-2 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

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

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

@keyframes floatDownCentered {
  0%,
  100% {
    transform: translate(-50%, 0);
  }
  50% {
    transform: translate(-50%, 8px);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

@media (max-width: 1359px) {
  #hero-divider {
    display: none !important;
  }

  #hero-compare {
    clip-path: inset(0 100% 0 0) !important;
  }

  #hero-section::before {
    content: '';
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    background: rgba(13, 13, 13, 0.5);
  }
}

@media (min-width: 1360px) {
  #hero-section.is-divider-dragging,
  #hero-section.is-divider-dragging * {
    cursor: grabbing;
  }
}

@media (max-width: 767px) {
  #hero-section {
    height: 100svh !important;
    min-height: 100svh;
  }

  .demo-banner {
    width: calc(100% - 1rem);
    bottom: 0.5rem;
    padding: 0.8rem 0.9rem;
    flex-direction: column;
    align-items: flex-start;
  }

  .demo-banner__close {
    width: 100%;
    text-align: center;
  }

  .hero-content-layer {
    height: calc(100svh - var(--nav-height));
    min-height: calc(100svh - var(--nav-height));
    margin-top: var(--nav-height);
    padding-bottom: calc(2rem + env(safe-area-inset-bottom));
  }

  .hero-title {
    font-size: clamp(1.95rem, 8.2vw, 2.6rem) !important;
    letter-spacing: -0.015em !important;
    line-height: 1.2 !important;
  }

  .hero-stroke-word {
    -webkit-text-stroke-width: 1px;
    letter-spacing: 0.01em;
  }
}

@supports (-webkit-touch-callout: none) {
  @media (max-width: 1024px) {
    .hero-stroke-word {
      -webkit-text-stroke-width: 1px;
      letter-spacing: 0.012em;
    }

    .footer-outline-word {
      -webkit-text-stroke-width: 1px;
      letter-spacing: -0.015em;
    }
  }
}
