
:root {
  --bg: #050505;
  --panel: rgba(255,255,255,0.06);
  --panel-strong: rgba(255,255,255,0.1);
  --text: rgba(255,255,255,0.96);
  --muted: rgba(255,255,255,0.68);
  --line: rgba(255,255,255,0.12);
  --accent: #ff0000;
  --accent-soft: rgba(255,0,0,0.24);
  --shadow: 0 20px 60px rgba(0,0,0,0.45);
  --header-h: 136px;
  --radius: 5px;
  --page-pad: clamp(23px, 4vw, 36px);
  --tracking-body: -0.04rem;
  --tracking-display: -0.33rem;
  --font-thin: "FS Hackney Thin";
  --font-light: "FS Hackney Light";
  --font-regular: "FS Hackney Regular";
  --font-bold: "FS Hackney Bold";
  --font-heavy: "FS Hackney Heavy";
}

@font-face {
  font-family: "FS Hackney Thin";
  src: url("../fonts/FSHackneyThin.otf") format("opentype");
  font-weight: 100; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "FS Hackney Light";
  src: url("../fonts/FSHackneyLight.otf") format("opentype");
  font-weight: 300; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "FS Hackney Regular";
  src: url("../fonts/FSHackneyRegular.otf") format("opentype");
  font-weight: 400; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "FS Hackney Bold";
  src: url("../fonts/FSHackneyBold.otf") format("opentype");
  font-weight: 600; font-style: normal; font-display: swap;
}
@font-face {
  font-family: "FS Hackney Heavy";
  src: url("../fonts/FSHackneyHeavy.otf") format("opentype");
  font-weight: 800; font-style: normal; font-display: swap;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: clip; }
body {
  margin: 0; overflow-x: clip;
  font-family: var(--font-regular), sans-serif;
  background: var(--bg); color: var(--text);
  letter-spacing: var(--tracking-body);
  cursor: none;
}
body, button, input, textarea, a, p, li, div, label, small {
  letter-spacing: var(--tracking-body); text-transform: none;
}
h1, h2, h3, .hero-slide-title, .service-word, .works-card-title,
.client-logo-chip, .header-brand-stack, .yt-track-text {
  letter-spacing: var(--tracking-body);
  font-family: var(--font-bold), sans-serif;
}
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
button { cursor: none; }
img { display: block; max-width: 100%; }
textarea { resize: vertical; }

/* CUSTOM CURSOR */
.cursor-dot {
  position: fixed; top: 0; left: 0;
  width: 7px; height: 7px;
  background: #ff0000; border-radius: 50%;
  pointer-events: none; z-index: 99999;
  transform: translate(-50%, -50%);
  transition: width 0.18s ease, height 0.18s ease, background 0.18s ease;
  mix-blend-mode: difference;
  will-change: transform;
}
.cursor-ring {
  position: fixed; top: 0; left: 0;
  width: 70px; height: 70px;
  border: 1.5px solid rgba(255, 255, 255, 0.23);
  border-radius: 50%;
  pointer-events: none; z-index: 99998;
  transform: translate(-50%, -50%);
  transition: width 0.3s ease, height 0.3s ease, border-color 0.2s ease;
  mix-blend-mode: difference;
  will-change: transform;
}
body.cursor-hover .cursor-dot { width: 9px; height: 9px; background: #ff0000; }
body.cursor-hover .cursor-ring { width: 30px; height: 30px; border-color: rgba(255,0,0,0.5); }
body.cursor-click .cursor-dot { width: 46px; height: 46px; }
@media (hover: none) {
  .cursor-dot, .cursor-ring { display: none; }
  body, button { cursor: auto; }
  button { cursor: pointer; }
}

/* PAGE LOADER */
.page-loader {
  position: fixed; inset: 0; z-index: 99990;
  background: #ffffff;
  display: flex; align-items: center; justify-content: center;
  flex-direction: column; gap: 24px;
  transition: opacity 2.3s ease, visibility 2.3s ease;
}
.page-loader.hidden { opacity: 0; visibility: hidden; pointer-events: none; }
.loader-logo { width: 68px; animation: loaderPulse 1.3s ease-in-out infinite; }
.loader-bar {
  width: 150px; height: 2px;
  background: rgba(255,255,255,0.1);
  border-radius: 999px; overflow: hidden;
}
.loader-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, #ff0000, #fff);
  border-radius: 999px;
  animation: loaderFill 2.3s linear forwards;
}
@keyframes loaderPulse {
  0%,100% { opacity: 0.6; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.07); }
}
@keyframes loaderFill { from { width: 0%; } to { width: 100%; } }

/* SCROLL PROGRESS */
.scroll-progress {
  position: fixed; top: 0; left: 0;
  height: 3px; width: 0%;
  background: linear-gradient(90deg, #bd0000, #ff0000);
  z-index: 99997;
  box-shadow: 0 0 8px rgba(255,255,255,0.5);
  transition: width 0s ease;
}

/* SCROLL REVEAL */
.reveal {
  opacity: 0; transform: translateY(28px);
  transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1);
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.22s; }
.reveal-delay-3 { transition-delay: 0.36s; }

/* BACKGROUND */
.site-bg {
  position: fixed; inset: 0; z-index: -3;
  background:
    radial-gradient(circle at bottom right, rgba(255,0,0,0.46), transparent 28%),
    radial-gradient(circle at 60% 0%, rgba(0,162,255,0.23), transparent 20%),
    linear-gradient(180deg, #000 0%, #000 100%);
}

/* HEADER */
.site-header {
  position: fixed; inset: 0 0 auto 0; z-index: 1000;
  height: var(--header-h);
  display: grid; grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center; gap: 14px;
  padding: 12px var(--page-pad);
  backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);
  transition: background 0.4s ease, box-shadow 0.4s ease;
}
.site-header.scrolled {
  background: rgba(255,255,255,0);
  box-shadow: 0 1px 0 rgba(255,255,255,0.06);
}
.brand-link { display: inline-flex; align-items: center; top:-20px;}
.brand-logo {
  width: clamp(74px, 7vw, 88px); height: auto;
  transition: none;
}
.brand-link:hover .brand-logo,
.brand-link:focus-visible .brand-logo {
  transform: none;
  filter: none;
}
.header-word-rotator {
  min-width: 0; overflow: hidden; white-space: nowrap;
  font-size: clamp(0.92rem,1.45vw,1.16rem);
  font-family: var(--font-bold),sans-serif; font-weight: 700;
  color: #fff; mix-blend-mode: difference;
  -webkit-font-smoothing: antialiased;
}
#header-word-text {
  display: inline-block; white-space: nowrap;
  text-overflow: ellipsis; overflow: hidden;
  opacity: 1; transform: translateY(0);
  transition: opacity 0.32s ease, transform 0.32s ease;
}
#header-word-text.is-fading-out { opacity: 0; transform: translateY(10px); }
#header-word-text.is-fading-in { opacity: 1; transform: translateY(0); }
.header-actions { display: flex; align-items: center; gap: clamp(18px,3vw,23px); }
.header-player {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  min-width: clamp(170px,18vw,220px); max-width: clamp(170px,18vw,220px);
}
.yt-player-hidden { position: absolute; width: 0; height: 0; overflow: hidden; }
.yt-track-marquee {
  position: relative; width: 100%; height: 22px;
  overflow: hidden; margin-bottom: 8px;
  display: flex; align-items: center; justify-content: center;
}
.yt-track-text {
  display: inline-block; min-width: max-content;
  padding-inline: 18px; font-size: 0.82rem;
  color: rgba(255,255,255,0.94); white-space: nowrap;
}
.yt-track-text.is-scrolling { animation: ytMarquee 13s linear infinite; }
.yt-track-fade { position: absolute; inset: 0 auto 0 0; width: 20px; z-index: 2; pointer-events: none; }
.yt-track-fade-left { background: linear-gradient(90deg, rgba(5,5,5,0.96), rgba(5,5,5,0)); }
.yt-track-fade-right { left: auto; right: 0; background: linear-gradient(270deg, rgba(5,5,5,0.96), rgba(5,5,5,0)); }
@keyframes ytMarquee {
  0% { transform: translateX(102%); opacity: 0; }
  8% { opacity: 1; }
  92% { opacity: 1; }
  100% { transform: translateX(-102%); opacity: 0; }
}
.music-controls { display: flex; align-items: center; gap: 4px; }

.music-btn, .menu-toggle, .lang-btn, .works-modal-close,
.ai-support-toggle, .ai-support-close, .ai-support-form button,
.ai-support-chip, .ai-support-whatsapp {
  border: 0px solid var(--line);
  background: rgba(255,255,255,0.06);
  color: #fff; border-radius: var(--radius);
  transition: background 0.22s ease, transform 0.18s ease, box-shadow 0.22s ease, border-color 0.22s ease;
}
.music-btn:hover, .menu-toggle:hover, .lang-btn:hover,
.works-modal-close:hover, .ai-support-toggle:hover,
.ai-support-close:hover, .ai-support-form button:hover,
.ai-support-chip:hover, .ai-support-whatsapp:hover {
  background: rgba(255,255,255,0.13);
  transform: translateY(-1px);
  box-shadow: 0 5px 18px rgba(0,0,0,0.3);
}
.music-btn:active { transform: scale(0.93); }
.music-btn { min-width: 36px; min-height: 36px; padding: 8px 10px; }
.header-brand-stack {
  display: grid; gap: 0; line-height: 1;
  font-size: 0.9rem; text-align: right;
  color: rgba(255,255,255,0.92);
}
.header-brand-stack span { display: block; }
.menu-toggle {
  width: 48px; height: 48px; padding: 0;
  position: relative; display: inline-flex;
  align-items: center; justify-content: center;
}
.menu-toggle span {
  position: absolute; width: 28px; height: 2px;
  background: #fff; 
  transition: transform 0.35s ease, opacity 0.35s ease;
}
.menu-toggle span:first-child { transform: translateY(-5px); }
.menu-toggle span:last-child { transform: translateY(5px); }
.menu-toggle.active span:first-child { transform: rotate(45deg); }
.menu-toggle.active span:last-child { transform: rotate(-45deg); }

.menu-toggle:hover, .menu-toggle:active { transform: none; }

.menu-backdrop {
  position: fixed; inset: 0; z-index: 950;
  opacity: 0; pointer-events: none;
  background: rgba(0,0,0,0.28);
  backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px);
  transition: opacity 0.35s ease;
}
.menu-backdrop.active { opacity: 1; pointer-events: auto; }

.sidebar-panel {
  position: fixed;
  top: calc(var(--header-h) + 8px); right: 8px;
  width: min(420px, calc(100% - 16px));
  height: calc(100vh - var(--header-h) - 16px);
  z-index: 1001; transform: translateX(105%);
  transition: transform 0.42s cubic-bezier(0.22,1,0.36,1);
  background: rgba(8,8,8,0.96);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: -16px 0 44px rgba(0,0,0,0.32);
  border-radius: var(--radius); padding: 16px;
  display: flex; flex-direction: column; gap: 18px;
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
}
.sidebar-panel.active { transform: translateX(0); }
.sidebar-top {
  display: flex; align-items: center;
  justify-content: flex-start; gap: 12px;
  order: 3; margin-top: 50px;
}
.sidebar-panel nav { order: 1; }
.language-switcher { display: flex; flex-wrap: wrap; gap: 8px; }
.lang-btn {
  min-width: 46px; padding: 6px 8px;
  font-family: var(--font-bold),sans-serif; font-size: 1rem;
}
.lang-btn.active {
  background: linear-gradient(90deg, rgba(255,0,0,0.58), rgba(255,0,0,1));
  border-color: transparent;
  box-shadow: 0 0 14px rgba(255,0,0,0.3);
}
.sidebar-links {
  font-family: var(--font-bold),sans-serif;
  list-style: none; padding: 0; margin: 0;
  display: grid; gap: 8px;
}
.sidebar-links a {
  display: block; padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  font-size: 1.32rem; color: rgba(255,255,255,0.97);
  transition: font-size 0.22s ease, padding-left 0.22s ease, color 0.22s ease;
  position: relative;
}
.sidebar-links a::after {
  content: ''; position: absolute;
  bottom: 0; left: 0; height: 1px; width: 0;
  background: #ff0000; transition: width 0.3s ease;
}
.sidebar-links a:hover { font-size: 1.66rem; padding-left: 10px; }
.sidebar-links a:hover::after { width: 100%; }
.sidebar-contact { order: 2; margin-top: auto; display: grid; gap: 10px; color: var(--muted); }
.sidebar-support { order: 3; margin-top: clamp(18px, 4vh, 48px); width: 100%; position: relative; }
.sidebar-contact p { margin: 0; color: #fff; }

main { padding-top: 0; position: relative; z-index: 1; }
.hero-slider-section { position: relative; min-height: 100vh; display: flex; align-items: stretch; }
.hero-swiper, .hero-swiper .swiper-wrapper, .hero-slide { width: 100%; min-height: 100vh; }
.hero-slide { position: relative; overflow: hidden; }
.hero-slide-image {
  position: absolute; inset: 0; width: 100%; height: 100%;
  object-fit: cover; transform: scale(1.06);
  transition: transform 6.5s ease-out;
}
.swiper-slide-active .hero-slide-image { transform: scale(1.0); }
.hero-slide-overlay {
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,0) 20%, rgba(0,0,0,1) 100%),
    linear-gradient(-45deg, rgba(255,0,0,1) 0%, rgba(255,255,255,0) 50%, rgba(255,255,255,1) 100%);
  mix-blend-mode: hard-light;
}
.hero-slide-content {
  position: relative; z-index: 2; min-height: 100vh;
  padding: clamp(120px,14vw,170px) var(--page-pad) clamp(42px,8vw,74px);
  display: flex; flex-direction: column;
  justify-content: flex-end; max-width: 1320px;
}
.hero-slide-kicker {
  margin-bottom: 12px; color: rgba(255,255,255,0.92); font-size: 1rem;
  opacity: 0; transform: translateY(12px);
  animation: heroIn 0.7s 0.3s cubic-bezier(0.22,1,0.36,1) forwards;
}
.hero-slide-title {
  margin: 0; display: flex; flex-direction: column; gap: 0;
  line-height: 0.9; font-size: clamp(2.8rem,10vw,8.2rem);
  letter-spacing: -0.33rem !important;
  opacity: 0; transform: translateY(22px);
  animation: heroIn 0.85s 0.5s cubic-bezier(0.22,1,0.36,1) forwards;
}
.hero-slide-title span:last-child { color: #ff0000; }
.hero-slide-caption {
  margin: 20px 0 0; max-width: 720px;
  color: rgba(255,255,255,0.96);
  font-size: clamp(1.02rem,1.9vw,1.34rem); line-height: 1.5;
  opacity: 0; transform: translateY(14px);
  animation: heroIn 0.8s 0.72s cubic-bezier(0.22,1,0.36,1) forwards;
}



.hero-slide-title span,
.hero-slide-caption {
    display: block;
    opacity: 0;
    transform: translate3d(-11vw, 0, 0);
    will-change: transform, opacity;
}

.hero-slide-title span {
    transition:
        transform 0.92s cubic-bezier(0.16, 1, 0.3, 1),
        opacity 0.96s ease;
}

.hero-slide-title span:nth-child(2) {
    transition-delay: 0.2s;
}



.hero-slide.swiper-slide-active .hero-slide-kicker,
.hero-slide.swiper-slide-active .hero-slide-title span,
.hero-slide.swiper-slide-active .hero-slide-caption {
    opacity: 1;
    transform: translate3d(0, 0, 0);
}

.hero-slide.hero-title-out .hero-slide-kicker,
.hero-slide.hero-title-out .hero-slide-title span,
.hero-slide.hero-title-out .hero-slide-caption {
    opacity: 0;
    transform: translate3d(12vw, 0, 0);
}























@keyframes heroIn { to { opacity: 1; transform: translateY(0); } }
.hero-slider-ui {
  position: absolute; left: var(--page-pad); right: var(--page-pad);
  bottom: 22px; z-index: 3; display: flex; justify-content: flex-end;
}
.hero-slider-pagination { width: auto !important; display: inline-flex; gap: 8px; }
.hero-slider-pagination .swiper-pagination-bullet {
  width: 36px; height: 4px; border-radius: 999px;
  background: rgba(255,255,255,0.24); opacity: 1;
  transition: width 0.3s ease, background 0.3s ease;
}
.hero-slider-pagination .swiper-pagination-bullet-active { background: #fff; width: 52px; }

.section-heading { display: grid; gap: 8px; padding: 0 var(--page-pad) 88px; }
.section-heading h2, .site-footer h3, #works-modal-title {
  margin: 0; font-size: clamp(1.9rem,4.8vw,3.95rem); line-height: 0.98;
}
.section-copy, .works-modal-description { margin: 0; color: var(--muted); line-height: 1.56; }
.section-eyebrow, .footer-kicker, .works-modal-eyebrow {
  font-family: var(--font-bold),sans-serif; margin: 0;
  color: #ff0000; font-size: 0.88rem;
  letter-spacing: 0.1em; text-transform: uppercase;
}
.services-section, .works-section, .clients-section, .site-footer { position: relative; z-index: 2; }

.services-section { padding: 70px 0 34px; overflow: visible; }
.services-swiper { width: 100%; padding: 4px var(--page-pad) 6px; overflow: visible; }
.services-swiper .swiper-wrapper { align-items: stretch; }
.services-slide { width: min(76vw,700px); max-width: calc(100vw - (var(--page-pad) * 2)); }
.service-panel {
  min-height: 260px; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04); box-shadow: var(--shadow);
  padding: 18px; display: flex; flex-direction: column;
  justify-content: space-between; gap: 12px; overflow: hidden;
  position: relative;
  transition: border-color 0.3s ease, background 0.3s ease, transform 0.3s ease, box-shadow 0.3s ease;
}
.service-panel::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(255,0,0,0.05), transparent 65%);
  opacity: 0; transition: opacity 0.4s ease; pointer-events: none;
}
.service-panel:hover {
  border-color: rgba(255,0,0,0.2); background: rgba(255,255,255,0.07);
  transform: translateY(-4px);
  box-shadow: 0 28px 70px rgba(255,0,0,0.55), 0 0 0 2px rgba(255,0,0,0.23);
}
.service-panel:hover::before { opacity: 1; }
.service-word {
  display: block; line-height: 0.92;
  font-size: clamp(1.9rem,5.5vw,5.2rem);
  color: rgba(255,255,255,0.96);
  background-image: none; background-size: cover; background-position: center;
  max-width: 100%; word-break: break-word;
  transition: letter-spacing 0.3s ease;
}
.service-panel:hover .service-word { letter-spacing: -0.08rem; }
.service-word.has-image {
  color: transparent; -webkit-text-fill-color: transparent;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-stroke: 1px rgba(255,255,255,0.18);
}
.service-caption { margin: 0; color: rgba(255,255,255,0.84); font-size: 0.98rem; line-height: 1.48; }

.works-section, .presentations-section { padding: 68px 0 40px; overflow: clip; }
.works-columns, .presentations-columns {
  display: grid; grid-template-columns: repeat(4,minmax(0,1fr));
  gap: 14px; padding: 0 var(--page-pad); height: 980px; overflow: hidden;
}
.works-column {
  position: relative; overflow: hidden;
  border-radius: var(--radius); min-width: 0;
  mask-image: linear-gradient(180deg,transparent 0%,black 8%,black 92%,transparent 100%);
  -webkit-mask-image: linear-gradient(180deg,transparent 0%,black 8%,black 92%,transparent 100%);
}
.works-track { display: flex; flex-direction: column; gap: 14px; will-change: transform; }
.works-track.is-animated {
  animation-name: worksUp; animation-timing-function: linear;
  animation-iteration-count: infinite; animation-duration: var(--works-duration,44s);
}
.works-column.reverse .works-track.is-animated { animation-name: worksDown; }
@keyframes worksUp { from { transform: translateY(0); } to { transform: translateY(-50%); } }
@keyframes worksDown { from { transform: translateY(-50%); } to { transform: translateY(0); } }
.works-card {
  position: relative; overflow: hidden; display: block; width: 100%;
  border-radius: var(--radius); background: #111;
  border: 1px solid rgba(255,255,255,0.08); 
  cursor: none; min-height: 0; padding: 0;
  transition: transform 0.35s cubic-bezier(0.22,1,0.36,1), border-color 0.3s ease, box-shadow 0.35s ease;
}
.works-card:hover {
  transform: scale(1.035); border-color: rgba(255,0,0,0.22);
  box-shadow: 0 28px 60px rgba(0,0,0,0.65), 0 0 0 1px rgba(255,0,0,0.1);
  z-index: 2;
}
.works-card[data-size="tall"], .works-card[data-size="medium"], .works-card[data-size="short"] { min-height: 0; }
.works-card img {
  position: relative; display: block; width: 100%; height: auto;
  object-fit: contain; filter: saturate(0.94) contrast(1.04);
  transition: filter 0.4s ease, transform 0.5s ease;
}
.works-card:hover img { filter: saturate(1.1) contrast(1.06); transform: scale(1.04); }
.works-card::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg,rgba(0,0,0,0.08),rgba(0,0,0,0.76));
}
.works-card-meta {
  position: absolute; inset: auto 5px 5px 5px; z-index: 2;
  display: grid; gap: 5px;
  background: linear-gradient(rgba(0,0,0,0),rgba(0,0,0,0.96));
  padding: 10px; border-radius: 5px;
  transform: translateY(4px); transition: transform 0.3s ease;
}
.works-card:hover .works-card-meta { transform: translateY(0); }
.works-card-client { color: #ff0000; font-size: 1rem; font-family: var(--font-bold),sans-serif; }
.works-card-title { font-size: clamp(1.05rem,1.6vw,1.5rem); line-height: 1; color: #fff; }

.clients-section { padding: 72px 0 90px; overflow: clip; }
.clients-swiper { width: 100%; padding: 4px var(--page-pad); overflow: hidden; }
.client-slide { width: auto; max-width: min(72vw,320px); }
.client-logo-chip {
  min-width: clamp(168px,18vw,230px); height: 110px; max-width: 100%;
  padding: 14px 18px; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.06);
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.94); font-size: clamp(1rem,1.7vw,1.36rem);
  text-align: center; overflow-wrap: anywhere;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.3s ease, border-color 0.3s ease, transform 0.3s ease;
}
.client-logo-chip:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.12); transform: translateY(-3px); }
.client-logo-chip.has-logo { min-width: 220px; }
.client-logo-image {
  display: block; max-width: 180px; width: 100%; max-height: 72px;
  object-fit: contain; filter: brightness(0.85) grayscale(0.3);
  transition: filter 0.3s ease;
}
.client-logo-chip:hover .client-logo-image { filter: brightness(1) grayscale(0); }

.works-modal-backdrop {
  position: fixed; inset: 0; z-index: 1190; opacity: 0; pointer-events: none;
  background: rgba(0,0,0,0.32); backdrop-filter: blur(0px); -webkit-backdrop-filter: blur(0px);
  transition: opacity 0.42s ease, backdrop-filter 0.42s ease, -webkit-backdrop-filter 0.42s ease;
}
.works-modal-shell {
  position: fixed; inset: 0; z-index: 1200; display: grid;
  place-items: center; padding: 18px; opacity: 0; pointer-events: none;
  transition: opacity 0.42s ease;
}
.works-modal-shell.active, .works-modal-backdrop.active { opacity: 1; pointer-events: auto; }
.works-modal-backdrop.active { backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); }
.works-modal-shell.closing, .works-modal-backdrop.closing { opacity: 0; pointer-events: none; }
.works-modal {
  width: min(1100px,100%); max-height: calc(100vh - 36px); overflow: auto;
  border-radius: var(--radius); border: 1px solid rgba(255,255,255,0.08);
  background: rgba(10,10,10,0.97); box-shadow: var(--shadow);
  padding: 58px 18px 18px; position: relative;
  backdrop-filter: blur(24px); -webkit-backdrop-filter: blur(24px);
  transform: scale(0.97) translateY(10px);
  transition: transform 0.42s cubic-bezier(0.22,1,0.36,1);
}
.works-modal-shell.active .works-modal { transform: scale(1) translateY(0); }
.works-modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 42px; height: 42px; font-size: 1.4rem; z-index: 40;
  transition: transform 0.2s ease, background 0.2s ease;
}
.works-modal-close:hover { transform: rotate(90deg) scale(1.1); }
.works-modal-grid { display: grid; grid-template-columns: minmax(0,1.24fr) minmax(300px,0.76fr); gap: 18px; }
.works-modal-media, .works-modal-copy { min-width: 0; }
.works-modal-swiper { border-radius: var(--radius); overflow: hidden; }
.works-modal-slide { display: grid; }
.works-modal-slide-inner { min-height: min(68vh, 820px); display: grid; place-items: center; border-radius: var(--radius); background: radial-gradient(circle at top, rgba(255,255,255,0.08), rgba(255,255,255,0.03)); padding: 14px; }
.works-modal-slide img { width: 100%; height: min(64vh, 760px); object-fit: contain; display: block; }
.works-modal-pagination { margin-top: 8px; display: flex; justify-content: center; gap: 8px; }
.works-modal-pagination .swiper-pagination-bullet { width: 30px; height: 4px; border-radius: 999px; background: rgba(255,255,255,0.22); opacity: 1; }
.works-modal-pagination .swiper-pagination-bullet-active { background: #fff; }
.works-modal-copy { display: grid; align-content: start; gap: 10px; padding-top: 5px; }
.works-modal-meta { display: grid; gap: 10px; }
.works-modal-meta-item {
  display: grid; gap: 4px; padding: 10px 12px;
  border-radius: var(--radius); border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  transition: border-color 0.2s ease, background 0.2s ease;
}
.works-modal-meta-item:hover { border-color: rgba(255,0,0,0.18); background: rgba(255,255,255,0.06); }
.works-modal-meta-label { font-family: var(--font-bold),sans-serif; color: #ff0000; font-size: 1rem; }
.works-modal-meta-value { color: rgba(255,255,255,0.92); }

.presentation-card { position: relative; }
.presentation-card-media { position: relative; width: 100%; display: block; overflow: hidden; background: rgba(255,255,255,0.04); min-height: 0; }
.presentation-card-media img { width: 100%; height: auto; object-fit: contain; display: block; }
.presentation-card-placeholder { width: 100%; min-height: 240px; display: grid; place-items: center; background: linear-gradient(135deg, rgba(255,255,255,0.06), rgba(255,0,0,0.08)); }
.presentation-card-placeholder span { font-family: var(--font-bold), sans-serif; letter-spacing: 0.12em; color: rgba(255,255,255,0.78); }
.presentation-card-badge { position: absolute; top: 14px; right: 14px; z-index: 2; border-radius: 999px; padding: 7px 11px; background: rgba(5,5,5,0.76); border: 1px solid rgba(255,255,255,0.1); font-size: 0.76rem; }
.presentation-modal-backdrop { position: fixed; inset: 0; z-index: 1235; opacity: 0; pointer-events: none; background: rgba(0,0,0,0.64); transition: opacity 0.3s ease; }
.presentation-modal-shell { position: fixed; inset: 0; z-index: 1240; display: grid; place-items: center; padding: 20px; opacity: 0; pointer-events: none; transition: opacity 0.3s ease; }
.presentation-modal-shell.active, .presentation-modal-backdrop.active { opacity: 1; pointer-events: auto; }
.presentation-modal-backdrop.active { backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); }
.presentation-modal-shell.closing, .presentation-modal-backdrop.closing { opacity: 0; pointer-events: none; }
.presentation-modal { position: relative; width: min(90vw, 1680px); max-width: 90vw; max-height: calc(100vh - 36px); overflow: auto; padding: 54px 18px 18px; border-radius: 24px; border: 1px solid rgba(255,255,255,0.12); background: rgba(5,5,5,0.95); box-shadow: 0 26px 80px rgba(0,0,0,0.48); transform: scale(0.96) translateY(16px); transition: transform 0.32s ease; }
.presentation-modal-shell.active .presentation-modal { transform: scale(1) translateY(0); }
.presentation-modal-close { position: absolute; top: 12px; right: 12px; z-index: 2; width: 44px; height: 44px; font-size: 1.4rem; }
.presentation-modal-grid { display: grid; grid-template-columns: minmax(0,1.35fr) minmax(280px,0.65fr); gap: 18px; }
.presentation-modal-viewer-wrap { min-width: 0; border-radius: var(--radius); overflow: hidden; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03); }
.presentation-modal-viewer { width: 100%; min-height: min(78vh, 980px); border: 0; background: #111; }
.presentation-modal-copy { display: grid; align-content: start; gap: 12px; min-width: 0; }
.presentation-modal-link { display: inline-flex; align-items: center; justify-content: center; min-height: 46px; border-radius: var(--radius); text-decoration: none; padding: 0 18px; border: 1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.06); color: #fff; transition: transform 0.25s ease, border-color 0.25s ease, background 0.25s ease; }
.presentation-modal-link:hover { transform: translateY(-2px); border-color: rgba(255,0,0,0.24); background: rgba(255,255,255,0.1); }
.ai-support-widget { position: relative; z-index: 3; display: grid; align-items: stretch; gap: 10px; width: 100%; overflow: visible; }
.ai-support-toggle { display: inline-flex; align-items: center; justify-content: space-between; gap: 10px; width: 100%; padding: 12px 16px; }
.ai-support-toggle:hover { box-shadow: 0 8px 24px rgba(0,0,0,0.4), 0 0 0 1px rgba(255,0,0,0.18); }
.ai-support-panel {
  position: absolute;
  right: 0;
  bottom: calc(100% + 12px);
  width: min(100%, 380px);
  background: rgba(10,10,10,0.97); border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius); box-shadow: var(--shadow); padding: 16px;
  display: none; backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  transform-origin: bottom right;
  z-index: 20;
}
.ai-support-widget.open .ai-support-panel, .ai-support-panel.active { display: block; animation: panelIn 0.36s cubic-bezier(0.22,1,0.36,1) forwards; }
@keyframes panelIn { from { opacity: 0; transform: scale(0.92) translateY(12px); } to { opacity: 1; transform: scale(1) translateY(0); } }
.ai-support-header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.ai-support-header h3, .ai-support-header p { margin: 0; }
.ai-support-header h3 { font-size: 1.42rem; }
.ai-support-header p { color: var(--muted); font-size: 0.82rem; }
.ai-support-close { width: 42px; height: 42px; font-size: 1.3rem; }
.ai-support-messages { display: flex; flex-direction: column; gap: 10px; max-height: 280px; overflow: auto; padding-right: 4px; margin-bottom: 12px; }
.ai-support-message {
  max-width: 92%; padding: 12px 14px; border-radius: var(--radius);
  line-height: 1.5; font-size: 0.95rem;
  animation: msgIn 0.28s cubic-bezier(0.22,1,0.36,1) forwards;
}
@keyframes msgIn { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: translateY(0); } }
.ai-support-message.bot { background: rgba(255,255,255,0.07); color: rgba(255,255,255,0.92); }
.ai-support-message.user { background: linear-gradient(90deg, rgba(120,0,0,1), rgba(255,0,0,1)); align-self: flex-end; }
.ai-support-suggestions { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
.ai-support-chip { padding: 8px 12px; }
.ai-support-form { display: grid; grid-template-columns: 1fr auto; gap: 10px; margin-bottom: 10px; }
.ai-support-form input {
  min-width: 0; border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.06); color: #fff; padding: 13px 14px;
  transition: border-color 0.2s ease, background 0.2s ease;
}
.ai-support-form input:focus { outline: none; border-color: rgba(255,0,0,0.38); background: rgba(255,255,255,0.09); }
.ai-support-form input::placeholder { color: rgba(255,255,255,0.46); }
.ai-support-form button, .ai-support-whatsapp { border-radius: var(--radius); padding: 13px 14px; text-align: center; }
.ai-support-whatsapp { display: block; }

.site-footer { padding: 0 var(--page-pad) 24px; }
.footer-grid {
  display: grid; grid-template-columns: minmax(0,1.4fr) minmax(220px,0.7fr);
  gap: 24px; padding: 28px 0 18px;
  border-top: 0;
}
.footer-contact { display: grid; gap: 12px; align-content: start; justify-items: start; color: var(--muted); font-size: 2rem; }
.footer-contact a { position: relative; transition: color 0.2s ease; }
.footer-contact a::after {
  content: ''; position: absolute; bottom: -2px; left: 0; right: 0;
  height: 1px; background: #ff0000;
  transform: scaleX(0); transform-origin: left; transition: transform 0.3s ease;
}
.footer-contact a:hover { color: #fff; }
.footer-contact a:hover::after { transform: scaleX(1); }
.footer-copy { margin: 0; color: rgba(255,255,255,0.54); font-size: 0.9rem; }

/* REVEAL */
.reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.22s; }
.reveal-delay-3 { transition-delay: 0.36s; }

@media (max-width: 1180px) {
  .works-columns, .presentations-columns { grid-template-columns: repeat(3,minmax(0,1fr)); height: 920px; }
  .works-column[data-hidden="true"] { display: none; }
}
@media (max-width: 920px) {
  :root { --header-h: 94px; }
  .site-header { gap: 10px; }
  .header-actions { margin-left: auto; padding-right: 58px; }
  .menu-toggle { position: absolute; right: var(--page-pad); top: 50%; transform: translateY(-50%); }
  .menu-toggle:hover, .menu-toggle:active { transform: translateY(-50%); }
  .header-player { min-width: 164px; max-width: 164px; }
  .works-columns, .presentations-columns { grid-template-columns: repeat(2,minmax(0,1fr)); height: 860px; }
  .works-modal-grid, .presentation-modal-grid, .footer-grid { grid-template-columns: 1fr; }
}
@media (max-width: 760px) {
  .sidebar-support { margin-top: 18px; }
  .sidebar-panel[data-menu-variant="slide-left"] { left: 8px; right: auto; }
  .sidebar-panel[data-menu-variant="lift-up"] { left: 8px; right: 8px; width: auto; }
  .ai-support-panel { left: 0; right: auto; bottom: calc(100% + 10px); width: min(100%, 320px); }

  :root { --header-h: 88px; --page-pad: 14px; }
  .site-header { padding: 10px var(--page-pad); }
  .brand-logo { width: 72px; }
  .header-word-rotator { display: none; }
  .header-player { min-width: 134px; max-width: 134px; }
  .yt-track-marquee { display: none; }
  .header-brand-stack { display: none; }
  .hero-slide-content { padding: 112px var(--page-pad) 46px; }
  .services-section { padding-top: 58px; }
  .services-slide { width: min(86vw,520px); }
  .service-panel { min-height: 180px; }
  .works-columns, .presentations-columns { grid-template-columns: 1fr; height: 720px; }
  .works-modal-shell, .presentation-modal-shell { padding: 10px; }
  .works-modal, .presentation-modal { width: calc(100vw - 8px); max-width: calc(100vw - 8px); padding: 52px 14px 14px; }
  .presentation-modal-viewer { min-height: 72vh; }
}
@media (max-width: 520px) {
  .music-controls { gap: 2px; }
  .music-btn { min-width: 32px; min-height: 32px; padding: 6px 8px; }
  .menu-toggle { width: 42px; height: 42px; top: 50%; transform: translateY(-50%); }
  .menu-toggle:hover, .menu-toggle:active { transform: translateY(-50%); }
  .client-slide { max-width: 78vw; }
  .footer-contact { display: grid; gap: 12px; align-content: start; justify-items: start; color: var(--muted); font-size: 1.2rem; }
}

/* ═══════════════════════════════════════
   THREE.JS CANVAS BACKGROUND
   ═══════════════════════════════════════ */
#three-canvas {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.9;
}

/* ═══════════════════════════════════════
   ANIMATED TYPO MARQUEE BANNER
   ═══════════════════════════════════════ */
.typo-marquee-strip {
  position: relative;
  z-index: 2;
  overflow: hidden;
  padding: 22px 0;
  border-top: 1px solid rgba(255,255,255,0.1);
  border-bottom: 1px solid rgba(255,255,255,0.1);
  margin-bottom: 72px;
  user-select: none;
}
.typo-marquee-strip::before{
  content:'';
  position:absolute;
  inset:0;
  z-index:0;
  pointer-events:none;
  background:transparent;
  opacity:0;
}
.typo-marquee-track {
  position:relative;
  z-index:1;
  display: flex;
  gap: 0;
  width: max-content;
  animation: typoMarquee 28s linear infinite;
}
.typo-marquee-track.reverse {
  animation-direction: reverse;
  animation-duration: 22s;
}
.typo-marquee-item {
  display: inline-flex;
  align-items: center;
  gap: 50px;
  padding: 0 28px;
  font-family: var(--font-heavy), sans-serif;
  font-size: clamp(1.6rem, 3.5vw, 3rem);
  color: transparent;
  -webkit-text-stroke: 1px rgba(255,255,255,0.18);
  letter-spacing: -0.02em;
  white-space: nowrap;
  text-transform: uppercase;
}
.typo-marquee-item .dot {
  width: 8px; height: 8px;
  background: #ff0000;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.typo-marquee-item.filled {
  color: rgba(255,255,255,0.07);
  -webkit-text-stroke: 0;
}
@keyframes typoMarquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* ═══════════════════════════════════════
   SPLIT TEXT / CHAR REVEAL
   ═══════════════════════════════════════ */
.split-reveal {
  overflow: visible;
}
.split-reveal .char {
  display: inline-block;
  opacity: 0;
  transform: translateY(110%);
  transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.22, 1, 0.36, 1);
}
.split-reveal.visible .char {
  opacity: 1;
  transform: translateY(0);
}

/* ═══════════════════════════════════════
   GLITCH EFFECT on section eyebrows
   ═══════════════════════════════════════ */
.glitch {
  position: relative;
  display: inline-block;
}
.glitch::before,
.glitch::after {
  content: attr(data-text);
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  color: #ff0000;
}
.glitch::before {
  animation: glitchTop 3.5s infinite linear;
  clip-path: polygon(0 0, 100% 0, 100% 40%, 0 40%);
  transform: translateX(-2px);
  opacity: 0;
}
.glitch::after {
  animation: glitchBot 3.5s infinite linear;
  clip-path: polygon(0 60%, 100% 60%, 100% 100%, 0 100%);
  transform: translateX(2px);
  opacity: 0;
}
@keyframes glitchTop {
  0%, 90%, 100% { opacity: 0; transform: translateX(0); }
  91% { opacity: 0.8; transform: translateX(-3px); }
  93% { opacity: 0.5; transform: translateX(3px); }
  95% { opacity: 0.8; transform: translateX(-2px); }
  97% { opacity: 0; }
}
@keyframes glitchBot {
  0%, 88%, 100% { opacity: 0; transform: translateX(0); }
  89% { opacity: 0.6; transform: translateX(3px); }
  92% { opacity: 0.4; transform: translateX(-3px); }
  94% { opacity: 0.6; transform: translateX(2px); }
  96% { opacity: 0; }
}

/* ═══════════════════════════════════════
   COUNTER NUMBERS  
   ═══════════════════════════════════════ */
.stat-counter {
  font-family: var(--font-bold), sans-serif;
  font-size: clamp(3rem, 8vw, 6.5rem);
  line-height: 1;
  color: #fff;
  letter-spacing: -0.04em;
}
.stat-counter sup {
  font-size: 0.4em;
  color: #ff0000;
  vertical-align: super;
  letter-spacing: -0.03rem;
  margin-left: 5px;
}

/* ═══════════════════════════════════════
   STATS SECTION
   ═══════════════════════════════════════ */
.stats-section {
  position: relative; z-index: 2;
  padding: 80px var(--page-pad) 80px;
  display: grid;
  gap: 34px;
  border-top: 0;
}
.stats-heading {
  max-width: min(720px, 100%);
}
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 40px;
}
.stats-item { display: grid; gap: 8px; }
.stats-label {
  color: var(--muted);
  font-size: 0.88rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}


#presentation-modal-title { display: none; }


/* Sidebar variants + map block */
.menu-toggle { --menu-toggle-size: 48px; }
.menu-toggle[data-toggle-variant="minimal"] { border-radius: 14px; }
.menu-toggle[data-toggle-variant="pill"] { width: calc(var(--menu-toggle-size) + 10px); border-radius: 999px; background: rgba(255,255,255,0.08); box-shadow: inset 0 0 0 1px rgba(255,255,255,0.08); }
.menu-toggle[data-toggle-variant="pill"] span { width: 24px; }
.menu-toggle[data-toggle-variant="diamond"] { border-radius: 16px; transform: rotate(45deg); }
.menu-toggle[data-toggle-variant="diamond"] span { transform: rotate(-45deg) translateY(-5px); }
.menu-toggle[data-toggle-variant="diamond"] span:last-child { transform: rotate(-45deg) translateY(5px); }
.menu-toggle[data-toggle-variant="diamond"].active span:first-child { transform: rotate(0deg); }
.menu-toggle[data-toggle-variant="diamond"].active span:last-child { transform: rotate(-90deg); }
.menu-toggle[data-toggle-variant="frame"] { background: transparent; box-shadow: inset 0 0 0 1px rgba(255,255,255,0.12); }
.menu-toggle[data-toggle-variant="frame"]::after { content:''; position:absolute; inset: 7px; border: 1px solid rgba(255,255,255,0.18); border-radius: calc(var(--radius) - 4px); opacity: .65; }
.menu-toggle[data-toggle-variant="orbital"] { border-radius: 999px; box-shadow: 0 0 0 1px rgba(255,255,255,0.12), 0 0 22px rgba(255,255,255,0.06); }
.menu-toggle[data-toggle-variant="orbital"]::before { content:''; position:absolute; inset:-4px; border-radius:999px; border:1px solid rgba(255,255,255,0.18); opacity:.5; }
.sidebar-panel[data-menu-variant="slide-right"] { right: 8px; left: auto; transform: translateX(105%); }
.sidebar-panel[data-menu-variant="slide-left"] { left: 8px; right: auto; transform: translateX(-105%); box-shadow: 16px 0 44px rgba(0,0,0,0.32); }
.sidebar-panel[data-menu-variant="lift-up"] { top: auto; bottom: 8px; right: 8px; transform: translateY(105%); }
.sidebar-panel[data-menu-variant="clip-reveal"] { transform: translateX(0) scale(0.96); opacity: 0; clip-path: inset(0 0 0 100% round var(--radius)); }
.sidebar-panel[data-menu-variant="soft-fade"] { transform: translateX(24px) scale(0.98); opacity: 0; }
.sidebar-panel.active[data-menu-variant="slide-right"],
.sidebar-panel.active[data-menu-variant="slide-left"],
.sidebar-panel.active[data-menu-variant="lift-up"] { transform: translate(0,0); }
.sidebar-panel.active[data-menu-variant="clip-reveal"] { opacity:1; clip-path: inset(0 0 0 0 round var(--radius)); transform: translateX(0) scale(1); }
.sidebar-panel.active[data-menu-variant="soft-fade"] { opacity:1; transform: translateX(0) scale(1); }
.site-map-section { position: relative; z-index: 2; padding: 18px var(--page-pad) 32px; }
.site-map-shell { display:grid; gap: 14px; }
.site-map-frame-wrap { border-radius: var(--radius); overflow: hidden; border: 1px solid rgba(255,255,255,0.08); background: rgba(255,255,255,0.03); box-shadow: var(--shadow); }
.site-map-frame { width: 100%; min-height: min(58vh, 520px); border: 0; display:block; }
.site-map-meta { display:flex; align-items:center; justify-content:flex-end; gap: 14px; flex-wrap:wrap; }
.site-map-links { display:flex; gap:12px; flex-wrap:wrap; }
.site-map-link { display:inline-flex; align-items:center; justify-content:center; min-height: 44px; padding: 0 18px; border-radius: var(--radius); border:1px solid rgba(255,255,255,0.1); background: rgba(255,255,255,0.06); color:#fff; text-decoration:none; transition: transform .24s ease, border-color .24s ease, background .24s ease; }
.site-map-link:hover { transform: translateY(-2px); border-color: rgba(255,0,0,0.24); background: rgba(255,255,255,0.1); }
@media (max-width: 920px) {
  .menu-toggle[data-toggle-variant="diamond"] { transform: translateY(-50%) rotate(45deg) !important; }
  .menu-toggle[data-toggle-variant="diamond"]:hover, .menu-toggle[data-toggle-variant="diamond"]:active { transform: translateY(-50%) rotate(45deg) !important; }
}
@media (max-width: 760px) {
  .site-map-frame { min-height: 360px; }
  .site-map-meta { align-items:flex-start; justify-content:flex-start; }
  .site-map-links { width:100%; }
}



/* phase 3 — leads */
.lead-section{padding:clamp(72px,8vw,120px) clamp(23px,4vw,36px);border-top:0;}
.lead-shell{max-width:1100px;margin:28px auto 0;padding:24px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.03);backdrop-filter:blur(10px);}
.lead-form{display:grid;gap:18px;}
.lead-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.lead-field{display:grid;gap:8px;}
.lead-field span,.lead-consent,.lead-status{font-size:13px;color:rgba(255,255,255,.72);}
.lead-field input,.lead-field textarea{width:100%;border:1px solid rgba(255,255,255,.12);border-radius:12px;background:rgba(255,255,255,.04);color:rgba(255,255,255,.96);padding:13px 14px;outline:none;transition:border-color .2s ease, background .2s ease;}
.lead-field input:focus,.lead-field textarea:focus{border-color:rgba(255,255,255,.28);background:rgba(255,255,255,.06);}
.lead-field-full{grid-column:1 / -1;}
.lead-form-actions{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.lead-consent{display:flex;align-items:flex-start;gap:10px;max-width:620px;}
.lead-submit-wrap{display:grid;justify-items:end;gap:8px;}
.lead-submit-btn{cursor:pointer}
.lead-status{min-height:1.3em;text-align:right;}
.lead-status.is-error{color:#ff9a9a}
.lead-status.is-success{color:#a7ffb5}
@media (max-width: 820px){
  .lead-grid{grid-template-columns:1fr;}
  .lead-field-full{grid-column:auto;}
  .lead-form-actions{flex-direction:column;align-items:stretch;}
  .lead-submit-wrap{justify-items:start;}
  .lead-status{text-align:left;}
}

/* Phase 4 — catalog */
.catalog-section{padding:clamp(70px,10vw,120px) clamp(24px,4vw,48px);position:relative;}
.catalog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;margin-top:24px;}
.catalog-card{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.1);border-radius:18px;overflow:hidden;box-shadow:0 18px 40px rgba(0,0,0,0.22);backdrop-filter:blur(8px);}
.catalog-card-media{aspect-ratio:4/3;background:rgba(255,255,255,0.03);overflow:hidden;}
.catalog-card-media img{width:100%;height:100%;object-fit:cover;display:block;}
.catalog-card-copy{padding:18px;display:grid;gap:10px;}
.catalog-card-category{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,0.56);margin:0;}
.catalog-card-title{font-size:clamp(20px,2.2vw,26px);line-height:1.05;margin:0;}
.catalog-card-price{margin:0;font-size:15px;color:rgba(255,255,255,0.88);display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.catalog-card-price-compare{text-decoration:line-through;color:rgba(255,255,255,0.42);font-size:13px;}
.catalog-card-desc{margin:0;color:rgba(255,255,255,0.72);font-size:14px;line-height:1.5;}
.catalog-card-meta{display:flex;flex-wrap:wrap;gap:8px;color:rgba(255,255,255,0.5);font-size:12px;}
.catalog-card-meta span{padding:6px 10px;border-radius:999px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);}
.catalog-card-btn{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:0 16px;border-radius:999px;text-decoration:none;color:rgba(255,255,255,0.96);background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);transition:transform .25s ease,background .25s ease,border-color .25s ease;}
.catalog-card-btn:hover{transform:translateY(-2px);background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.24);}
.catalog-empty{margin-top:18px;color:rgba(255,255,255,0.62);}

/* Phase 5 — commerce / checkout */
.order-section{padding:clamp(70px,9vw,118px) clamp(24px,4vw,48px);border-top:0;}
.order-shell{max-width:1180px;margin:28px auto 0;display:grid;grid-template-columns:minmax(280px,360px) minmax(0,1fr);gap:20px;align-items:start;}
.order-summary-card{padding:22px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.03);backdrop-filter:blur(10px);display:grid;gap:14px;position:sticky;top:100px;}
.order-summary-head{display:flex;justify-content:space-between;align-items:center;gap:12px;}
.order-summary-head h3{margin:0;font-size:clamp(18px,2vw,24px);}
.order-cart-count{display:inline-flex;min-width:34px;height:34px;padding:0 12px;align-items:center;justify-content:center;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-size:14px;color:rgba(255,255,255,.96);}
.order-cart-list{display:grid;gap:12px;}
.order-cart-item{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);}
.order-cart-copy{display:grid;gap:6px;min-width:0;}
.order-cart-copy strong{font-size:15px;line-height:1.3;}
.order-cart-line-total{font-size:13px;color:rgba(255,255,255,.86);}
.order-cart-meta{display:flex;gap:8px;flex-wrap:wrap;color:rgba(255,255,255,.6);font-size:12px;}
.order-coupon-box{display:grid;gap:10px;padding-top:6px;border-top:1px solid rgba(255,255,255,.06);}
.order-coupon-field{gap:10px;}
.order-coupon-inline{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:10px;}
.order-coupon-inline input{min-width:0;}
.order-coupon-btn{white-space:nowrap;padding-inline:18px;}
.order-totals{display:grid;gap:10px;padding-top:8px;border-top:1px solid rgba(255,255,255,.06);}
.order-total-row{display:flex;align-items:center;justify-content:space-between;gap:16px;color:rgba(255,255,255,.74);font-size:14px;}
.order-total-row strong{font-size:15px;color:rgba(255,255,255,.94);}
.order-total-row-final{padding-top:4px;border-top:1px dashed rgba(255,255,255,.08);font-size:16px;color:#fff;}
.order-total-row-final strong{font-size:18px;color:#fff;}
.order-cart-actions{display:flex;align-items:center;gap:8px;}
.order-stepper,.order-remove-btn{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.05);color:#fff;cursor:pointer;transition:transform .2s ease, background .2s ease, border-color .2s ease;}
.order-stepper:hover,.order-remove-btn:hover{transform:translateY(-1px);background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.22);}
.order-cart-qty{min-width:20px;text-align:center;font-size:14px;color:rgba(255,255,255,.92);}
.order-form{padding:24px;border:1px solid rgba(255,255,255,.08);border-radius:18px;background:rgba(255,255,255,.03);backdrop-filter:blur(10px);}
@media (max-width: 920px){
  .order-shell{grid-template-columns:1fr;}
  .order-summary-card{position:static;}
}


/* Runtime page builder */
.page-builder-root {
  display: grid;
  gap: 0;
}
.page-builder-section {
  position: relative;
  min-height: var(--page-builder-min-height, 72vh);
  padding: clamp(48px, 7vw, 112px) clamp(20px, 5vw, 72px);
}
.page-builder-shell {
  width: min(1280px, 100%);
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(24px, 4vw, 56px);
  align-items: center;
}
.page-builder-section.is-center .page-builder-copy-inner { text-align: center; margin-inline: auto; }
.page-builder-section.is-right .page-builder-copy-inner { text-align: right; margin-left: auto; }
.page-builder-copy-inner {
  width: min(720px, 100%);
  display: grid;
  gap: 18px;
}
.page-builder-eyebrow {
  margin: 0;
  color: rgba(255,255,255,0.6);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-size: 0.78rem;
}
.page-builder-title {
  margin: 0;
  font-size: clamp(2.4rem, 8vw, 6.5rem);
  line-height: 0.96;
}
.page-builder-text {
  margin: 0;
  max-width: 64ch;
  color: rgba(255,255,255,0.76);
  font-size: clamp(1rem, 2vw, 1.18rem);
}
.page-builder-html {
  color: rgba(255,255,255,0.88);
}
.page-builder-html > *:first-child { margin-top: 0; }
.page-builder-html > *:last-child { margin-bottom: 0; }
.page-builder-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.page-builder-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.08);
  color: #fff;
  text-decoration: none;
}
.page-builder-btn--ghost {
  background: transparent;
}
.page-builder-media img,
.page-builder-gallery-item img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 16px;
}
.page-builder-items {
  display: grid;
  gap: 14px;
  grid-column: 1 / -1;
}
.page-builder-items--cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.page-builder-items--cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.page-builder-items--cols-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.page-builder-list-item {
  padding: 18px 20px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,0.08);
  background: rgba(255,255,255,0.04);
  color: rgba(255,255,255,0.82);
}
.page-builder-gallery-item {
  margin: 0;
}
.sidebar-links li[data-depth="1"] { padding-left: 16px; }
.sidebar-links li[data-depth="2"] { padding-left: 32px; }
.sidebar-links li[data-depth="3"] { padding-left: 48px; }
body.page-builder-mode-replace #hero-slider-section,
body.page-builder-mode-replace #typo-marquee-section,
body.page-builder-mode-replace #services-section,
body.page-builder-mode-replace #works-section,
body.page-builder-mode-replace #presentations-section,
body.page-builder-mode-replace #clients-section,
body.page-builder-mode-replace #stats-section,
body.page-builder-mode-replace #catalog-section,
body.page-builder-mode-replace #order-section,
body.page-builder-mode-replace #map-section,
body.page-builder-mode-replace #lead-section {
  display: none !important;
}
@media (max-width: 900px) {
  .page-builder-shell {
    grid-template-columns: 1fr;
  }
  .page-builder-items--cols-2,
  .page-builder-items--cols-3,
  .page-builder-items--cols-4 {
    grid-template-columns: 1fr;
  }
}


/* Page Builder heading should match site section heading */
.page-builder-heading{ text-align:left; align-items:flex-start; }
.page-builder-section.is-left .page-builder-shell{ justify-content:flex-start; }
.page-builder-section.is-left .page-builder-copy{ align-items:flex-start; }
.page-builder-section.is-left .page-builder-copy-inner{ align-items:flex-start; }


/* Admin fix: top-level section outlines should stay off on full-width section wrappers */
#services-section,
#works-section,
#presentations-section,
#catalog-section,
#order-section,
#map-section,
#lead-section,
.services-section,
.works-section,
.presentations-section,
.catalog-section,
.order-section,
.site-map-section,
.lead-section{
  border:0;
  outline:0;
  box-shadow:none;
}


#stats-section, .footer-grid { border-top: 0 !important; }
.site-map-frame iframe, #site-map-canvas iframe { width:100%; min-height:min(58vh,520px); border:0; display:block; }
