:root {
  color-scheme: light dark;
  --coral: #ff8766;
  --coral-rgb: 255, 135, 102;
  --peach: #ffc490;
  --champagne: #f3d7a8;
  --paper: #fff8f3;
  --paper-soft: #f5eee8;
  --ink: #080706;
  --graphite: #0a0a0b;
  --graphite-soft: #111114;
  --smoke: #76716d;
  --silver: #c9c6c2;
  --white: #ffffff;
  --glass: rgba(255, 255, 255, 0.08);
  --dark-glass: rgba(8, 8, 9, 0.66);
  --dark-line: rgba(255, 255, 255, 0.12);
  --light-line: rgba(8, 7, 6, 0.12);
  --shadow: 0 28px 80px rgba(0, 0, 0, 0.24);
  --glow: 0 0 34px rgba(var(--coral-rgb), 0.28);
  --radius: 8px;
  --header-height: 86px;
  --container: min(1180px, calc(100% - 32px));
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
  scrollbar-color: var(--coral) var(--ink);
}

body {
  margin: 0;
  min-width: 320px;
  overflow-x: hidden;
  background: var(--paper);
  color: var(--ink);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.6;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}

body.menu-open {
  overflow: hidden;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

a {
  color: inherit;
  text-decoration: none;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

button,
input,
select,
textarea {
  font: inherit;
}

button {
  border: 0;
}

.skip-link {
  position: fixed;
  top: 12px;
  left: 12px;
  z-index: 999;
  transform: translateY(-140%);
  padding: 12px 16px;
  border-radius: var(--radius);
  background: var(--ink);
  color: var(--paper);
  font-weight: 800;
  transition: transform 200ms ease;
}

.skip-link:focus {
  transform: translateY(0);
}

.container {
  width: var(--container);
  margin-inline: auto;
}

.section {
  position: relative;
  padding: clamp(76px, 11vw, 148px) 0;
}

.dark-section {
  overflow: hidden;
  background:
    radial-gradient(circle at 12% 8%, rgba(var(--coral-rgb), 0.18), transparent 30rem),
    linear-gradient(180deg, #070707 0%, #101012 48%, #050505 100%);
  color: var(--paper);
}

.light-section,
.projects-section {
  background:
    radial-gradient(circle at 86% 8%, rgba(var(--coral-rgb), 0.12), transparent 26rem),
    linear-gradient(180deg, var(--paper) 0%, #fff 100%);
  color: var(--ink);
}

.section-heading {
  max-width: 780px;
  margin-bottom: clamp(34px, 6vw, 70px);
}

.center-heading {
  max-width: 860px;
  margin-inline: auto;
  text-align: center;
}

.eyebrow {
  margin: 0 0 14px;
  color: var(--peach);
  font-size: clamp(0.72rem, 1vw, 0.84rem);
  font-weight: 900;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.eyebrow-dark {
  color: #a94a32;
}

.section-title,
.hero-title {
  margin: 0;
  font-family: "Times New Roman", Georgia, serif;
  font-weight: 500;
  letter-spacing: 0;
}

.section-title {
  max-width: 980px;
  color: var(--paper);
  font-size: clamp(2.2rem, 6vw, 5.4rem);
  line-height: 0.98;
}

.dark-title {
  color: var(--ink);
}

.section-copy {
  max-width: 660px;
  margin: 22px 0 0;
  color: rgba(255, 248, 243, 0.72);
  font-size: clamp(1rem, 1.6vw, 1.16rem);
}

.dark-copy {
  color: var(--smoke);
}

.button,
.nav-cta,
.package-card a {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 48px;
  padding: 0 21px;
  border-radius: 999px;
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  overflow: hidden;
  isolation: isolate;
  transition: transform 280ms var(--ease), box-shadow 280ms ease, border-color 280ms ease, background 280ms ease, color 280ms ease;
}

.button::after,
.nav-cta::after,
.package-card a::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: 0;
  background: linear-gradient(115deg, transparent, rgba(255,255,255,0.36), transparent);
  transform: translateX(-120%);
  transition: transform 650ms var(--ease), opacity 250ms ease;
}

.button:hover::after,
.nav-cta:hover::after,
.package-card a:hover::after {
  opacity: 1;
  transform: translateX(120%);
}

.button:hover,
.nav-cta:hover,
.package-card a:hover {
  transform: translateY(-2px);
}

.button-primary,
.nav-cta {
  border: 1px solid rgba(var(--coral-rgb), 0.85);
  background: linear-gradient(135deg, var(--coral), var(--peach));
  color: #170704;
  box-shadow: 0 16px 40px rgba(var(--coral-rgb), 0.3);
}

.button-ghost {
  border: 1px solid rgba(255,255,255,0.22);
  background: rgba(255,255,255,0.06);
  color: var(--paper);
  backdrop-filter: blur(18px);
}

.button-ghost:hover {
  border-color: rgba(var(--coral-rgb), 0.58);
  box-shadow: var(--glow);
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  min-height: var(--header-height);
  border-bottom: 1px solid rgba(8, 7, 6, 0.08);
  background: rgba(255, 248, 243, 0.94);
  color: var(--ink);
  backdrop-filter: blur(18px) saturate(140%);
  box-shadow: 0 8px 30px rgba(0,0,0,0.06);
  transition: background 260ms ease, box-shadow 260ms ease;
}

.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(255, 255, 255, 0.98);
  box-shadow: 0 18px 50px rgba(0,0,0,0.12);
}

.navbar {
  width: var(--container);
  min-height: var(--header-height);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.brand,
.footer-brand {
  display: inline-flex;
  align-items: center;
  flex: 0 0 auto;
}

.brand img,
.footer-brand img {
  width: clamp(142px, 17vw, 205px);
  height: auto;
  max-height: 68px;
  object-fit: contain;
  filter: drop-shadow(0 8px 18px rgba(0,0,0,0.15));
}

.menu-toggle {
  position: relative;
  z-index: 102;
  width: 48px;
  height: 48px;
  display: inline-grid;
  place-items: center;
  border: 1px solid rgba(8,7,6,0.14);
  border-radius: 50%;
  background: rgba(255,255,255,0.72);
  color: var(--ink);
  cursor: pointer;
}

.menu-toggle span {
  position: absolute;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: currentColor;
  transition: transform 240ms var(--ease);
}

.menu-toggle span:first-child {
  transform: translateY(-5px);
}

.menu-toggle span:last-child {
  transform: translateY(5px);
}

.menu-toggle[aria-expanded="true"] span:first-child {
  transform: rotate(45deg);
}

.menu-toggle[aria-expanded="true"] span:last-child {
  transform: rotate(-45deg);
}

.nav-panel {
  position: fixed;
  inset: var(--header-height) 14px auto;
  display: grid;
  gap: 24px;
  padding: 24px;
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background: rgba(255, 248, 243, 0.98);
  box-shadow: var(--shadow);
  opacity: 0;
  visibility: hidden;
  transform: translateY(-14px);
  transition: opacity 240ms ease, visibility 240ms ease, transform 240ms var(--ease);
}

.nav-panel.is-open {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}

.nav-links {
  display: grid;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.nav-links a {
  display: block;
  padding: 12px 0;
  color: rgba(8,7,6,0.72);
  font-size: 0.84rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: color 200ms ease;
}

.nav-links a:hover,
.nav-links a:focus-visible {
  color: #b34e34;
}

.nav-cta {
  width: 100%;
}

.social-links {
  display: flex;
  align-items: center;
  gap: 8px;
}

.social-links a {
  position: relative;
  width: 40px;
  height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(8,7,6,0.12);
  border-radius: 50%;
  background: rgba(255,255,255,0.64);
  color: rgba(8,7,6,0.72);
  transition: transform 240ms var(--ease), color 240ms ease, border-color 240ms ease, background 240ms ease, box-shadow 240ms ease;
}

.social-links svg {
  display: none;
}

.social-links a::before {
  content: "";
  width: 18px;
  height: 18px;
  background: currentColor;
  -webkit-mask: var(--social-icon) center / contain no-repeat;
  mask: var(--social-icon) center / contain no-repeat;
}

.social-links a[aria-label*="Instagram"] {
  --social-icon: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M7.5%202h9A5.51%205.51%200%200%201%2022%207.5v9a5.51%205.51%200%200%201-5.5%205.5h-9A5.51%205.51%200%200%201%202%2016.5v-9A5.51%205.51%200%200%201%207.5%202Zm0%202A3.5%203.5%200%200%200%204%207.5v9A3.5%203.5%200%200%200%207.5%2020h9a3.5%203.5%200%200%200%203.5-3.5v-9A3.5%203.5%200%200%200%2016.5%204h-9ZM12%207a5%205%200%201%201%200%2010%205%205%200%200%201%200-10Zm0%202a3%203%200%201%200%200%206%203%203%200%200%200%200-6Zm5.25-2.25a1.15%201.15%200%201%201%200%202.3%201.15%201.15%200%200%201%200-2.3Z'/%3E%3C/svg%3E");
}

.social-links a[aria-label*="TikTok"] {
  --social-icon: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M15.6%202c.28%202.42%201.62%203.86%204.02%204.04v3.28a7.4%207.4%200%200%201-4.02-1.2v6.78c0%203.62-2.24%206.1-5.72%206.1-3.18%200-5.5-2.12-5.5-5.12%200-3.2%202.5-5.38%205.88-5.12v3.34c-1.48-.22-2.54.46-2.54%201.74%200%201.12.9%201.82%202.02%201.82%201.4%200%202.24-.82%202.24-2.7V2h3.62Z'/%3E%3C/svg%3E");
}

.social-links a[aria-label*="Facebook"] {
  --social-icon: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M14.02%2022v-8.02h2.68l.42-3.12h-3.1V8.88c0-.9.24-1.52%201.54-1.52h1.64V4.58c-.28-.04-1.26-.12-2.4-.12-2.38%200-4%201.46-4%204.14v2.26H8.12v3.12h2.68V22h3.22Z'/%3E%3C/svg%3E");
}

.social-links a[aria-label*="WhatsApp"] {
  --social-icon: url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%2024%2024'%3E%3Cpath%20d='M12.04%202a9.9%209.9%200%200%201%208.5%2014.98L21.8%2022l-5.16-1.22A9.9%209.9%200%200%201%202.12%2012.1%209.94%209.94%200%200%201%2012.04%202Zm0%202A7.93%207.93%200%200%200%204.1%2012.1a7.85%207.85%200%200%200%2011.78%206.76l.38-.24%202.82.66-.68-2.74.25-.4A7.9%207.9%200%200%200%2012.04%204Zm-3.1%203.82c.18-.01.38-.01.58-.01.14%200%20.3.02.44.34.18.42.58%201.44.64%201.54.06.1.1.24.02.38-.12.24-.2.34-.38.54-.1.12-.22.26-.1.48.34.68.84%201.32%201.44%201.84.7.62%201.3.82%201.52.92.22.1.34.08.48-.08.14-.16.56-.66.72-.88.16-.22.3-.18.52-.1.22.08%201.38.66%201.62.78.24.12.4.18.46.28.06.1.06.6-.14%201.18-.2.58-1.12%201.1-1.56%201.14-.42.04-.96.06-1.56-.1-.36-.1-.82-.26-1.4-.52-2.46-1.06-4.06-3.54-4.18-3.7-.12-.16-1-1.34-1-2.56s.62-1.82.84-2.06c.22-.24.48-.34.64-.36.14-.02.28-.02.4-.02Z'/%3E%3C/svg%3E");
}

.social-links a:hover,
.social-links a:focus-visible {
  color: #a34831;
  border-color: rgba(var(--coral-rgb),0.48);
  background: rgba(255,135,102,0.12);
  box-shadow: 0 12px 28px rgba(var(--coral-rgb),0.18);
  transform: translateY(-2px);
}

.nav-social {
  justify-content: flex-start;
}

.hero {
  position: relative;
  min-height: calc(100svh - var(--header-height));
  display: grid;
  align-items: center;
  overflow: hidden;
  padding: clamp(84px, 10vw, 130px) 0 clamp(92px, 12vw, 150px);
  color: var(--paper);
  background: var(--graphite);
}

.hero-layer,
.hero-shine {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero-back {
  z-index: 0;
}

.hero-back img {
  width: 100%;
  height: 116%;
  object-fit: cover;
  object-position: 56% 50%;
  filter: saturate(0.82) contrast(1.12) brightness(0.52);
  transform: translate3d(0, var(--parallax-y, 0), 0) scale(1.03);
  will-change: transform;
}

.hero-mid {
  z-index: 1;
  background:
    radial-gradient(circle at 22% 46%, rgba(var(--coral-rgb), 0.28), transparent 28rem),
    linear-gradient(90deg, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.62) 46%, rgba(0,0,0,0.28) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.14), rgba(0,0,0,0.78));
}

.hero-shine {
  z-index: 2;
  width: 46vw;
  min-width: 280px;
  height: 180vh;
  left: auto;
  right: 6vw;
  background: linear-gradient(105deg, transparent 18%, rgba(255,255,255,0.12) 50%, transparent 82%);
  transform: translate3d(0, var(--parallax-y, 0), 0) rotate(16deg);
  opacity: 0.42;
}

.hero-content {
  position: relative;
  z-index: 3;
}

.hero-title {
  max-width: 1000px;
  font-size: clamp(3.1rem, 12vw, 9rem);
  line-height: 0.94;
  text-wrap: balance;
}

.hero-lede {
  max-width: 660px;
  margin: 26px 0 0;
  color: rgba(255,248,243,0.78);
  font-size: clamp(1.02rem, 2vw, 1.28rem);
}

.hero-actions,
.contact-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.light-intro {
  padding: clamp(70px, 10vw, 120px) 0;
  background:
    linear-gradient(90deg, rgba(var(--coral-rgb), 0.11), transparent 50%),
    var(--paper);
}

.intro-grid {
  display: grid;
  gap: 22px;
}

.services-grid,
.packages-grid,
.projects-grid {
  display: grid;
  gap: 16px;
}

.service-card,
.process-step,
.contact-card {
  position: relative;
  border: 1px solid var(--dark-line);
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(255,255,255,0.1), rgba(255,255,255,0.025)),
    rgba(10,10,11,0.72);
  box-shadow: 0 24px 70px rgba(0,0,0,0.26);
  overflow: hidden;
}

.service-card::before,
.process-step::before,
.contact-card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(125deg, rgba(var(--coral-rgb),0.24), transparent 35%, rgba(255,255,255,0.06));
  opacity: 0;
  transition: opacity 300ms ease;
}

.service-card:hover::before,
.process-step:hover::before,
.contact-card:hover::before {
  opacity: 1;
}

.service-card {
  min-height: 264px;
  padding: 24px;
  transition: transform 320ms var(--ease), border-color 320ms ease, box-shadow 320ms ease;
}

.service-card:hover {
  transform: translateY(-6px);
  border-color: rgba(var(--coral-rgb),0.42);
  box-shadow: 0 34px 90px rgba(0,0,0,0.36), var(--glow);
}

.service-card span,
.process-step span {
  display: inline-flex;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(var(--coral-rgb),0.34);
  border-radius: 50%;
  color: var(--peach);
  font-size: 0.74rem;
  font-weight: 900;
}

.service-card h3,
.process-step h3,
.project-card h3,
.package-card h3 {
  margin: 22px 0 12px;
  font-size: clamp(1.08rem, 2vw, 1.34rem);
  line-height: 1.2;
}

.service-card p,
.process-step p {
  margin: 0;
  color: rgba(255,248,243,0.68);
}

.parallax-banner,
.contact-quick,
.project-hero {
  position: relative;
  min-height: 72svh;
  display: grid;
  align-items: center;
  overflow: hidden;
  color: var(--paper);
  background: var(--graphite);
}

.banner-image,
.contact-bg,
.project-hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

.banner-image img,
.contact-bg img,
.project-hero-bg img {
  width: 100%;
  height: 115%;
  object-fit: cover;
  filter: saturate(0.8) contrast(1.08) brightness(0.5);
  transform: translate3d(0, var(--parallax-y, 0), 0);
}

.parallax-banner::after,
.contact-quick::after,
.project-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    radial-gradient(circle at 20% 48%, rgba(var(--coral-rgb),0.24), transparent 28rem),
    linear-gradient(90deg, rgba(0,0,0,0.88), rgba(0,0,0,0.42), rgba(0,0,0,0.76));
}

.banner-content,
.contact-card,
.project-hero-content {
  position: relative;
  z-index: 2;
}

.packages-grid {
  align-items: stretch;
}

.package-card {
  position: relative;
  min-height: 430px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 24px;
  padding: 26px;
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background:
    linear-gradient(160deg, rgba(255,255,255,0.92), rgba(255,255,255,0.66)),
    var(--paper-soft);
  box-shadow: 0 18px 52px rgba(0,0,0,0.1);
  overflow: hidden;
  transition: transform 320ms var(--ease), border-color 320ms ease, box-shadow 320ms ease;
}

.package-card:hover {
  transform: translateY(-8px);
  border-color: rgba(var(--coral-rgb),0.45);
  box-shadow: 0 34px 80px rgba(0,0,0,0.16);
}

.package-featured,
.package-luxe {
  background:
    linear-gradient(160deg, rgba(var(--coral-rgb), 0.18), rgba(255,255,255,0.82)),
    var(--paper);
}

.package-card small {
  position: absolute;
  top: 18px;
  right: 18px;
  padding: 8px 10px;
  border: 1px solid rgba(var(--coral-rgb),0.32);
  border-radius: 999px;
  color: #9d3e27;
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.package-card p {
  margin: 0 0 10px;
  color: #a74a32;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.package-card strong {
  display: block;
  color: var(--ink);
  font-family: "Times New Roman", Georgia, serif;
  font-size: clamp(2rem, 4vw, 3rem);
  line-height: 1;
}

.package-card ul {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
  color: var(--smoke);
}

.package-card li {
  position: relative;
  padding-left: 18px;
}

.package-card li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.67em;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--coral);
}

.package-card a {
  align-self: flex-start;
  border: 1px solid rgba(var(--coral-rgb),0.42);
  background: var(--ink);
  color: var(--paper);
}

.process-layout,
.faq-layout,
.project-split {
  display: grid;
  gap: 34px;
}

.sticky-copy {
  align-self: start;
}

.process-steps {
  display: grid;
  gap: 16px;
}

.process-step {
  padding: 28px;
}

.projects-section {
  color: var(--ink);
}

.project-card {
  position: relative;
  min-height: 420px;
  display: grid;
  align-items: end;
  overflow: hidden;
  border-radius: var(--radius);
  border: 1px solid var(--light-line);
  background: var(--ink);
  box-shadow: 0 22px 64px rgba(0,0,0,0.14);
  transition: transform 320ms var(--ease), box-shadow 320ms ease;
}

.project-card:hover {
  transform: translateY(-7px);
  box-shadow: 0 36px 90px rgba(0,0,0,0.2);
}

.project-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.86) contrast(1.06) brightness(0.7);
  transform: scale(1.02);
  transition: transform 600ms var(--ease), filter 320ms ease;
}

.project-card:hover img {
  transform: scale(1.07);
  filter: saturate(0.95) contrast(1.08) brightness(0.82);
}

.project-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 10%, rgba(0,0,0,0.82) 100%);
}

.project-card div {
  position: relative;
  z-index: 1;
  padding: 24px;
  color: var(--paper);
}

.project-card p {
  margin: 0;
  color: var(--peach);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.project-card span {
  display: inline-flex;
  margin-top: 10px;
  color: rgba(255,248,243,0.72);
  font-weight: 800;
}

.brands-section {
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 0%, rgba(var(--coral-rgb),0.16), transparent 26rem),
    #080808;
  color: var(--paper);
}

.brand-marquee {
  position: relative;
  overflow: hidden;
  border: 1px solid var(--dark-line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.04);
  box-shadow: var(--shadow);
}

.brand-marquee::before,
.brand-marquee::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 2;
  width: 70px;
  pointer-events: none;
}

.brand-marquee::before {
  left: 0;
  background: linear-gradient(90deg, #080808, transparent);
}

.brand-marquee::after {
  right: 0;
  background: linear-gradient(270deg, #080808, transparent);
}

.brand-track {
  display: flex;
  width: max-content;
  gap: 12px;
  padding: 18px;
  animation: brandFlow 32s linear infinite;
}

.brand-track span {
  min-width: 170px;
  min-height: 92px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.06);
  color: rgba(255,248,243,0.82);
  font-family: "Times New Roman", Georgia, serif;
  font-size: 1.42rem;
  letter-spacing: 0.02em;
}

@keyframes brandFlow {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

.faq-list {
  display: grid;
  gap: 12px;
}

.faq-item {
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.68);
  box-shadow: 0 16px 46px rgba(0,0,0,0.08);
  overflow: hidden;
}

.faq-question {
  width: 100%;
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  padding: 18px 20px;
  background: transparent;
  color: var(--ink);
  font-weight: 850;
  text-align: left;
  cursor: pointer;
}

.faq-question span {
  position: relative;
  flex: 0 0 28px;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(var(--coral-rgb),0.42);
  border-radius: 50%;
}

.faq-question span::before,
.faq-question span::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 12px;
  height: 2px;
  background: #a34831;
  transform: translate(-50%, -50%);
  transition: transform 220ms ease;
}

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

.faq-question[aria-expanded="true"] span::after {
  transform: translate(-50%, -50%) rotate(0deg);
}

.faq-answer {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 260ms var(--ease);
}

.faq-item.is-open .faq-answer {
  grid-template-rows: 1fr;
}

.faq-answer p {
  min-height: 0;
  overflow: hidden;
  margin: 0;
  padding: 0 20px;
  color: var(--smoke);
}

.faq-item.is-open .faq-answer p {
  padding-bottom: 22px;
}

.contact-quick {
  min-height: 82svh;
  padding: clamp(86px, 14vw, 170px) 0;
}

.contact-card {
  max-width: 780px;
  padding: clamp(26px, 5vw, 52px);
  backdrop-filter: blur(18px);
}

.contact-card p {
  max-width: 620px;
  color: rgba(255,248,243,0.72);
}

.site-footer {
  padding: clamp(44px, 7vw, 76px) 0 34px;
  border-top: 1px solid rgba(8,7,6,0.1);
  background: var(--paper);
  color: var(--ink);
}

.footer-grid {
  display: grid;
  gap: 22px;
}

.footer-grid h2 {
  margin: 0 0 8px;
  font-size: 1.2rem;
  letter-spacing: 0.14em;
}

.footer-grid p {
  margin: 0;
  color: var(--smoke);
}

.footer-grid address {
  display: grid;
  gap: 8px;
  font-style: normal;
}

.footer-social {
  margin-top: 8px;
}

.footer-social a {
  background: rgba(8,7,6,0.035);
}

.footer-grid address a {
  color: var(--ink);
  font-weight: 800;
}

.footer-grid address a:hover {
  color: #a34831;
}

.copyright {
  padding-top: 14px;
  border-top: 1px solid var(--light-line);
  font-size: 0.88rem;
}

.floating-actions {
  position: fixed;
  z-index: 120;
  right: 16px;
  bottom: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.floating-actions a {
  min-width: 104px;
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  border-radius: 999px;
  color: #170704;
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  box-shadow: 0 14px 38px rgba(0,0,0,0.24);
}

.float-whatsapp {
  background: linear-gradient(135deg, var(--coral), var(--peach));
  border: 1px solid rgba(var(--coral-rgb),0.75);
}

.project-hero {
  min-height: 64svh;
  padding: clamp(90px, 12vw, 150px) 0;
}

.project-hero-content {
  max-width: 880px;
}

.project-hero h1 {
  margin: 0;
  font-family: "Times New Roman", Georgia, serif;
  font-size: clamp(3rem, 10vw, 7.6rem);
  line-height: 0.96;
}

.project-hero p {
  max-width: 660px;
  color: rgba(255,248,243,0.76);
  font-size: clamp(1rem, 1.8vw, 1.22rem);
}

.project-split {
  align-items: start;
}

.project-copy {
  max-width: 700px;
}

.project-copy p {
  color: var(--smoke);
  font-size: 1.05rem;
}

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

.service-list li {
  position: relative;
  padding: 16px 18px 16px 40px;
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.7);
  color: var(--ink);
  font-weight: 750;
}

.service-list li::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--coral);
  transform: translateY(-50%);
}

.project-result {
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background:
    linear-gradient(145deg, rgba(var(--coral-rgb),0.12), rgba(255,255,255,0.9)),
    var(--paper);
  padding: clamp(24px, 4vw, 40px);
  box-shadow: 0 18px 54px rgba(0,0,0,0.1);
}

.project-result strong {
  display: block;
  margin-bottom: 12px;
  color: #a34831;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.project-result p {
  margin: 0;
  color: var(--smoke);
}

.gallery-grid,
.before-after-grid {
  display: grid;
  gap: 18px;
}

.compare-card {
  padding: 10px;
  border: 1px solid var(--light-line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.72);
  box-shadow: 0 18px 54px rgba(0,0,0,0.09);
}

.compare-card h3 {
  margin: 16px 8px 10px;
  color: var(--ink);
  font-size: 1.04rem;
}

.compare {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  border-radius: calc(var(--radius) - 2px);
  background: #050505;
}

.compare::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: var(--position, 50%);
  z-index: 4;
  width: 1px;
  background: rgba(255,255,255,0.92);
  box-shadow: 0 0 24px rgba(var(--coral-rgb),0.5);
  pointer-events: none;
}

.compare img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.compare-before {
  filter: grayscale(0.9) brightness(0.62) contrast(1.08);
}

.compare-after-wrap {
  position: absolute;
  inset: 0;
  width: 100%;
  overflow: hidden;
  clip-path: inset(0 calc(100% - var(--position, 50%)) 0 0);
}

.compare-after {
  filter: saturate(1.08) contrast(1.06);
}

.compare-label {
  position: absolute;
  top: 14px;
  z-index: 5;
  padding: 7px 10px;
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 999px;
  background: rgba(0,0,0,0.46);
  color: var(--paper);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
}

.compare-label-before {
  right: 14px;
}

.compare-label-after {
  left: 14px;
  color: var(--peach);
}

.compare-range {
  position: absolute;
  inset: 0;
  z-index: 6;
  width: 100%;
  height: 100%;
  opacity: 0;
  cursor: ew-resize;
}

.cta-panel {
  border-radius: var(--radius);
  background:
    radial-gradient(circle at 20% 20%, rgba(var(--coral-rgb),0.22), transparent 24rem),
    #080808;
  color: var(--paper);
  padding: clamp(30px, 7vw, 68px);
  overflow: hidden;
}

.cta-panel p {
  max-width: 620px;
  color: rgba(255,248,243,0.72);
}

.reveal {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 760ms var(--ease), transform 760ms var(--ease);
}

.reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

[data-text-reveal] .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(0.52em);
  transition: opacity 700ms var(--ease), transform 700ms var(--ease);
  transition-delay: calc(var(--word-index) * 46ms);
}

[data-text-reveal].is-visible .word {
  opacity: 1;
  transform: translateY(0);
}

@media (hover: hover) and (pointer: fine) {
  .magnetic {
    will-change: transform;
  }
}

@media (min-width: 520px) {
  :root {
    --container: min(1180px, calc(100% - 44px));
  }

  .services-grid,
  .packages-grid,
  .projects-grid,
  .before-after-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .compare {
    aspect-ratio: 16 / 13;
  }
}

@media (min-width: 768px) {
  :root {
    --container: min(1180px, calc(100% - 64px));
  }

  .intro-grid {
    grid-template-columns: 0.75fr 1.6fr;
  }

  .intro-grid .dark-copy {
    grid-column: 2;
  }

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

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

  .compare {
    aspect-ratio: 4 / 5;
  }

  .process-layout,
  .faq-layout,
  .project-split {
    grid-template-columns: 0.86fr 1.14fr;
  }

  .sticky-copy {
    position: sticky;
    top: calc(var(--header-height) + 28px);
  }

  .footer-grid {
    grid-template-columns: 0.78fr 1fr 0.72fr;
    align-items: start;
  }

  .copyright {
    grid-column: 1 / -1;
  }
}

@media (min-width: 1024px) {
  .menu-toggle {
    display: none;
  }

  .nav-panel {
    position: static;
    display: flex;
    align-items: center;
    gap: 30px;
    padding: 0;
    border: 0;
    background: transparent;
    box-shadow: none;
    opacity: 1;
    visibility: visible;
    transform: none;
  }

  .nav-links {
    display: flex;
    align-items: center;
    gap: 24px;
  }

  .nav-links a {
    padding: 6px 0;
  }

  .nav-cta {
    width: auto;
    min-height: 42px;
    padding-inline: 18px;
  }

  .nav-social a {
    width: 36px;
    height: 36px;
  }

  .hero-content {
    padding-right: 280px;
  }

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

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

  .project-card {
    min-height: 470px;
  }
}

@media (min-width: 1440px) {
  :root {
    --container: min(1320px, calc(100% - 96px));
  }

  .service-card {
    min-height: 300px;
  }
}

@media (max-width: 767px) {
  :root {
    --header-height: 78px;
  }

  .brand img,
  .footer-brand img {
    width: 150px;
    max-height: 58px;
  }

  .hero {
    min-height: 88svh;
    padding-bottom: 96px;
  }

  .hero-back img,
  .banner-image img,
  .contact-bg img,
  .project-hero-bg img {
    height: 106%;
  }

  .hero-actions .button,
  .contact-buttons .button {
    width: 100%;
  }

  .parallax-banner,
  .contact-quick,
  .project-hero {
    min-height: auto;
    padding-block: 92px;
  }

  .floating-actions {
    right: 12px;
    bottom: 12px;
  }

  .floating-actions a {
    min-width: 92px;
    min-height: 44px;
    font-size: 0.68rem;
  }
}

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

  .hero-back img,
  .hero-shine,
  .banner-image img,
  .contact-bg img,
  .project-hero-bg img {
    transform: none !important;
  }
}
