:root {
  --gold: #FE8F00;
  --gold-2: #FE8F00;
  --gold-3: #FE8F00;
  --line: rgba(254, 143, 0, 0.24);
}

.site-page {
  background:
    radial-gradient(circle at 76% 18%, rgba(254, 143, 0, 0.18), transparent 30%),
    linear-gradient(180deg, #241400 0%, #120900 100%);
}

.hero {
  min-height: 720px;
  padding-top: 104px;
  padding-bottom: 0;
  background:
    radial-gradient(circle at 70% 26%, rgba(254, 143, 0, 0.38), transparent 34%),
    linear-gradient(115deg, #FE8F00 0%, #B86600 36%, #4D2A00 100%);
  color: #fff;
  border-bottom-right-radius: 34px;
  border-bottom-left-radius: 34px;
}

.hero::before {
  background: linear-gradient(90deg, rgba(254, 143, 0, 0.18), rgba(0, 0, 0, 0.12));
}

.hero::after {
  height: 260px;
  background: linear-gradient(180deg, rgba(77, 42, 0, 0) 0%, rgba(77, 42, 0, 0.74) 58%, #120900 100%);
}

.site-nav {
  border-bottom-color: rgba(255, 255, 255, 0.18);
  background: linear-gradient(90deg, rgba(254, 143, 0, 0.96), rgba(184, 102, 0, 0.94));
  color: #fff;
}

.site-logo {
  width: 220px;
  height: 64px;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.site-logo img {
  object-fit: contain;
}

.site-nav-links a,
.nav-whatsapp,
.hero-copy,
.hero-copy p {
  color: #fff;
}

.hero-float-scene {
  display: none;
}

.hero-grid {
  grid-template-columns: minmax(440px, 52%) minmax(420px, 48%);
  width: min(100%, 1180px);
  min-height: 600px;
}

.hero-copy {
  grid-column: 1;
  justify-self: start;
  max-width: 780px;
  text-align: left;
  transform: translate(-52px, -10px);
}

.hero-copy h1 {
  max-width: 900px;
  margin-top: 24px;
  color: #fff;
  font-size: clamp(40px, 3.25vw, 54px);
  font-weight: 700;
  line-height: 1.16;
  letter-spacing: 0;
}

.hero-title-line {
  display: block;
  white-space: nowrap;
}

.hero-title-desktop {
  display: block;
}

.hero-title-mobile {
  display: none;
}

.hero-title-mark {
  display: inline-block;
  width: fit-content;
  margin-top: 4px;
  padding: 0 8px 8px;
  background: #FE8F00;
}

.hero-checklist {
  display: grid;
  gap: 26px;
  margin: 34px 0 38px;
  padding: 0;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  list-style: none;
}

.hero-checklist li {
  position: relative;
  padding-left: 30px;
}

.hero-checklist li::before {
  position: absolute;
  left: 0;
  background: linear-gradient(90deg, #008a18, #00b82f);
  background-clip: text;
  color: transparent;
  font-size: 20px;
  font-weight: 900;
  content: "\2713";
  -webkit-background-clip: text;
}

.hero-action-row {
  display: flex;
  align-items: center;
  gap: 18px;
}

.hero-action-row > span {
  color: #fff;
  font-size: 14px;
  font-weight: 500;
}

.primary-button,
.nav-whatsapp,
.language-option.is-active,
.niche-buttons button.is-active,
.budget-glass a,
.rights-toast {
  background: linear-gradient(90deg, #008a18, #00b82f);
  color: #fff;
}

.primary-button {
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 42px rgba(0, 120, 22, 0.26);
}

.primary-button::before,
.nav-whatsapp::before,
.niche-buttons button.is-active::before,
.budget-glass a::before {
  position: absolute;
  top: -35%;
  bottom: -35%;
  left: -45%;
  width: 34%;
  background: linear-gradient(
    90deg,
    transparent,
    rgba(255, 255, 255, 0.76),
    transparent
  );
  content: "";
  filter: blur(2px);
  transform: skewX(-20deg);
  animation: button-flash 2.4s ease-in-out infinite;
  pointer-events: none;
}

.nav-whatsapp,
.niche-buttons button.is-active,
.budget-glass a {
  position: relative;
  overflow: hidden;
}

.hero-action-row .primary-button {
  position: relative;
  min-width: 296px;
  min-height: 58px;
  padding: 0 56px;
  border-radius: 18px;
  font-family: "Anton", Impact, sans-serif;
  font-size: 23px;
  font-weight: 400;
  text-align: center;
  text-shadow: none;
  letter-spacing: 0;
}

.hero-action-row .primary-button::after {
  position: absolute;
  right: 30px;
  margin-left: 0;
  font-family: "Segoe UI", system-ui, sans-serif;
  font-size: 24px;
  font-weight: 400;
  line-height: 1;
  content: "\2192";
}

.hero-social-proof {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 26px;
}

.hero-proof-logos {
  display: flex;
  align-items: center;
}

.hero-proof-logos span {
  display: block;
  width: 42px;
  height: 42px;
  margin-left: -14px;
  border: 2px solid rgba(255, 255, 255, 0.16);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
}

.hero-proof-logos span:first-child {
  margin-left: 0;
}

.hero-proof-logos img {
  display: block;
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}

.hero-social-proof p {
  margin: 0 0 0 6px;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.34;
}

.hero-social-proof strong {
  color: #00b82f;
  font-weight: 600;
}

@keyframes button-flash {
  0%,
  38% {
    left: -45%;
  }

  68%,
  100% {
    left: 118%;
  }
}

.hero-media {
  grid-column: 2;
  display: flex;
  align-items: end;
  justify-content: center;
  min-height: 670px;
}

.hero-media img {
  position: relative;
  z-index: 5;
  display: block;
  width: min(150%, 920px);
  max-height: 820px;
  object-fit: contain;
  object-position: bottom center;
  transform: translateX(44px);
}

.gold-ribbon,
.section-line,
.agency-step-number span,
.budget-glass::before,
.comparison-card-gold,
.exclusive-dot,
.niche-buttons button:not(.is-active):hover {
  background: #FE8F00;
}

.portfolio-section h2 span,
.services-section > .services-title span,
.development-title span,
.comparison-title span,
.service-icon,
.development-icon,
.faq-arrow,
.budget-copy span,
.agency-kicker,
.exclusive-title span {
  color: #FE8F00;
}

.nav-icon-button,
.language-switcher,
.site-logo,
.portfolio-card,
.service-card,
.development-card,
.faq-item,
.image-slot,
.budget-glass {
  border-color: rgba(254, 143, 0, 0.24);
}

html[data-theme="light"] .site-nav {
  background: linear-gradient(90deg, rgba(254, 143, 0, 0.96), rgba(184, 102, 0, 0.94));
  color: #fff;
}

html[data-theme="light"] .site-logo {
  background: transparent;
}

html[data-theme="light"] .site-nav-links a,
html[data-theme="light"] .hero,
html[data-theme="light"] .hero-copy,
html[data-theme="light"] .hero-copy h1,
html[data-theme="light"] .hero-action-row > span {
  color: #fff;
}

html[data-theme="light"] .hero {
  background:
    radial-gradient(circle at 70% 26%, rgba(254, 143, 0, 0.38), transparent 34%),
    linear-gradient(115deg, #FE8F00 0%, #B86600 36%, #4D2A00 100%);
}

html[data-theme="light"] .hero::before {
  background: linear-gradient(90deg, rgba(254, 143, 0, 0.18), rgba(0, 0, 0, 0.12));
}

html[data-theme="light"] .hero::after {
  background: linear-gradient(180deg, rgba(77, 42, 0, 0) 0%, rgba(77, 42, 0, 0.74) 58%, #120900 100%);
}

@media (max-width: 900px) {
  .site-nav {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 10px;
    padding: 0 12px;
  }

  .site-logo {
    width: 142px;
    height: 48px;
  }

  .site-nav-links {
    justify-content: center;
    gap: 12px;
  }

  .site-nav-links a {
    font-size: 12px;
  }

  .nav-controls {
    display: none;
  }

  .nav-whatsapp {
    min-width: 104px;
    min-height: 38px;
    padding: 0 14px;
    font-size: 12px;
  }

  .hero {
    padding: 104px 18px 48px;
  }

  .hero-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .hero-copy {
    width: 100%;
    text-align: left;
    transform: none;
  }

  .hero-copy h1 {
    font-size: clamp(34px, 8.4vw, 52px);
    line-height: 1.06;
    white-space: normal;
  }

  .hero-title-line {
    white-space: normal;
  }

  .hero-title-mark {
    display: inline;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
  }

  .hero-checklist {
    gap: 16px;
    margin: 28px 0 30px;
  }

  .hero-media {
    grid-column: 1;
    display: flex;
    min-height: 320px;
  }

  .hero-media img {
    width: min(100%, 420px);
    max-height: 390px;
    transform: translateX(0);
  }

  .hero-action-row {
    align-items: stretch;
    flex-direction: column;
    gap: 12px;
  }

  .hero-action-row .primary-button {
    width: min(100%, 320px);
  }

  .hero-social-proof {
    flex-wrap: wrap;
    margin-top: 22px;
  }
}

@media (max-width: 520px) {
  .site-nav {
    grid-template-columns: auto minmax(0, 1fr) auto;
    min-height: 76px;
    align-items: center;
    gap: 10px;
    padding: 8px 10px;
  }

  .site-logo {
    width: 148px;
    height: 46px;
  }

  .site-nav-links {
    display: none;
  }

  .nav-controls {
    display: flex;
    justify-self: center;
  }

  .nav-whatsapp {
    min-width: 112px;
    min-height: 40px;
    padding: 0 16px;
    font-size: 12px;
  }

  .hero {
    min-height: 100svh;
    padding: 128px 14px 0;
  }

  .hero-grid {
    grid-template-rows: auto 1fr;
    min-height: calc(100svh - 128px);
    gap: 12px;
  }

  .hero-copy {
    max-width: 100%;
  }

  .hero-title-desktop {
    display: none;
  }

  .hero-title-mobile {
    display: block;
  }

  .hero-title-mobile .hero-title-line {
    margin-bottom: 4px;
  }

  .hero-title-mobile .hero-title-line:last-child {
    margin-bottom: 0;
  }

  .hero-title-mobile .hero-title-mark {
    padding: 0 7px 4px;
    line-height: 1.04;
  }

  .hero-copy h1 {
    font-size: clamp(25px, 7.8vw, 34px);
    line-height: 1.03;
  }

  .hero-checklist {
    gap: 12px;
    margin: 18px 0 22px;
    font-size: 13px;
  }

  .hero-action-row {
    gap: 10px;
  }

  .hero-action-row .primary-button {
    width: min(100%, 300px);
    min-height: 52px;
    padding: 0 20px;
    font-size: 19px;
  }

  .hero-social-proof {
    align-items: flex-start;
    gap: 8px;
    margin-top: 14px;
  }

  .hero-proof-logos span {
    width: 36px;
    height: 36px;
    margin-left: -12px;
  }

  .hero-social-proof p {
    font-size: 13px;
    line-height: 1.2;
  }

  .hero-media {
    align-self: end;
    min-height: 0;
  }

  .hero-media img {
    width: min(90vw, 330px);
    max-height: 42svh;
  }
}
