:root {
  --cv-bg: #05090b;
  --cv-bg-2: #081015;
  --cv-bg-3: #10181f;
  --cv-panel: rgba(7, 11, 14, 0.8);
  --cv-panel-strong: rgba(5, 8, 10, 0.92);
  --cv-text: #f4eee3;
  --cv-muted: rgba(244, 238, 227, 0.72);
  --cv-soft: rgba(244, 238, 227, 0.46);
  --cv-line: rgba(216, 189, 127, 0.24);
  --cv-line-soft: rgba(255, 255, 255, 0.09);
  --cv-accent: #d8bd7f;
  --cv-accent-2: #f1d9a1;
  --cv-shadow: 0 28px 80px rgba(0, 0, 0, 0.38);
  --cv-font-display: "Aptos Display", "SF Pro Display", "Segoe UI Variable Display", "Avenir Next", "Helvetica Neue", Arial, sans-serif;
  --cv-font-body: "Aptos", "Inter", "Segoe UI", "Helvetica Neue", Arial, sans-serif;
  --cv-container: min(1320px, calc(100vw - 40px));
  --cv-type-scale: 1;
  --cv-hero-title-scale: 1;
  --cv-hero-lead-scale: 1;
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background:
    radial-gradient(circle at 50% 0%, rgba(105, 136, 131, 0.22), transparent 38rem),
    linear-gradient(180deg, #091116 0%, #05090b 58%, #030607 100%);
  color: var(--cv-text);
  font-family: var(--cv-font-body);
  font-size: calc(16px * var(--cv-type-scale));
  line-height: 1.65;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; height: auto; }
button, input, textarea, select { font: inherit; }
.screen-reader-text {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}
.skip-link:focus {
  position: fixed !important;
  left: 10px; top: 10px; z-index: 100000;
  width: auto; height: auto; clip: auto;
  margin: 0; padding: 10px 14px;
  background: var(--cv-accent); color: #111; font-weight: 700;
}
.cv-container { width: var(--cv-container); margin-inline: auto; }

/* Header */
.cv-site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 999;
  background: linear-gradient(180deg, rgba(4, 7, 9, 0.9), rgba(4, 7, 9, 0.25) 72%, transparent);
  border-bottom: 1px solid transparent;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transition: background .25s ease, border-color .25s ease;
}
.cv-site-header.is-scrolled {
  background: rgba(4, 7, 9, 0.94);
  border-color: var(--cv-line-soft);
}
.admin-bar .cv-site-header { top: 32px; }
.cv-header-inner {
  min-height: 94px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}
.cv-brand {
  display: inline-flex;
  flex-direction: column;
  gap: 7px;
  letter-spacing: .34em;
  text-transform: uppercase;
  line-height: .86;
}
.cv-logo-text {
  font-family: var(--cv-font-display);
  font-size: clamp(1.35rem, 2vw, 2.1rem);
  font-weight: 560;
}
.cv-logo-sub {
  color: var(--cv-muted);
  font-size: .60rem;
  line-height: 1;
  letter-spacing: .28em;
}
.cv-logo-img img { max-height: 72px; width: auto; }
.cv-primary-nav { display: flex; align-items: center; }
.cv-menu {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  align-items: center;
  gap: clamp(20px, 3vw, 48px);
}
.cv-menu a {
  color: rgba(244, 238, 227, 0.84);
  font-size: .76rem;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.cv-menu a:hover,
.cv-menu a:focus { color: var(--cv-accent-2); }
.cv-menu li:not(:last-child) { position: relative; }
.cv-menu li:not(:last-child)::after {
  content: "";
  position: absolute;
  top: 50%; right: calc(clamp(20px, 3vw, 48px) / -2);
  transform: translateY(-50%);
  width: 1px; height: 16px;
  background: rgba(255,255,255,.18);
}
.cv-menu-toggle {
  display: none;
  width: 48px; height: 48px;
  border-radius: 999px;
  border: 1px solid var(--cv-line);
  background: rgba(8,13,16,.78);
  color: var(--cv-text);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 4px;
}
.cv-menu-toggle span:not(.screen-reader-text) {
  display: block;
  width: 18px; height: 1px;
  background: currentColor;
  transition: transform .2s ease, opacity .2s ease;
}
.menu-open .cv-menu-toggle span:nth-child(1) { transform: translateY(5px) rotate(45deg); }
.menu-open .cv-menu-toggle span:nth-child(2) { opacity: 0; }
.menu-open .cv-menu-toggle span:nth-child(3) { transform: translateY(-5px) rotate(-45deg); }

/* Buttons */
.cv-button {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  padding: 0 18px;
  border: 1px solid var(--cv-line);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-size: .78rem;
  font-weight: 700;
}
.cv-button-primary {
  color: #0b0b0b;
  background: var(--cv-accent);
  border-color: transparent;
}
.cv-button-primary:hover,
.cv-button-primary:focus { background: var(--cv-accent-2); }
.cv-button-secondary {
  background: transparent;
  color: var(--cv-text);
}

/* Home scene */
.cv-main { min-height: 70vh; }
.cv-scene-home {
  position: relative;
  min-height: 100vh;
  padding: 126px 0 52px;
  overflow: hidden;
}
.cv-scene-wrap {
  position: relative;
  min-height: calc(100vh - 178px);
  border: 1px solid rgba(255,255,255,.06);
  background:
    linear-gradient(180deg, rgba(7, 10, 12, 0.58), rgba(7, 10, 12, 0.76)),
    radial-gradient(circle at 50% 14%, rgba(199, 208, 205, 0.18), transparent 30rem),
    var(--cv-scene-bg, linear-gradient(150deg, #1b242b 0%, #0a1218 48%, #05090b 100%));
  background-size: cover;
  background-position: center;
  border-radius: 22px;
  box-shadow: var(--cv-shadow);
}
.cv-scene-wrap::before {
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px calc(25% - 1px), rgba(255,255,255,.04) calc(25% - 1px) 25%, transparent 25%),
    linear-gradient(180deg, rgba(255,255,255,.03) 0 1px, transparent 1px 33%, rgba(255,255,255,.03) 33% 33.2%, transparent 33.2% 100%);
  mix-blend-mode: screen;
  opacity: .18;
  pointer-events: none;
  border-radius: inherit;
}
.cv-scene-ambient {
  position: absolute; inset: 0;
  pointer-events: none;
  overflow: hidden;
  border-radius: inherit;
}
.cv-scene-light {
  position: absolute;
  filter: blur(34px);
  opacity: .48;
}
.cv-scene-light--a {
  left: 10%; top: 7%;
  width: 30%; height: 24%;
  background: radial-gradient(circle, rgba(209, 177, 111, .20), transparent 70%);
}
.cv-scene-light--b {
  right: 4%; top: 12%;
  width: 40%; height: 30%;
  background: radial-gradient(circle, rgba(107, 142, 137, .22), transparent 70%);
}
.cv-scene-floor {
  position: absolute;
  left: 8%; right: 8%; bottom: -1%;
  height: 26%;
  transform: perspective(950px) rotateX(70deg);
  transform-origin: bottom center;
  background:
    linear-gradient(90deg, transparent 0 49.4%, rgba(241,217,161,.38) 49.6% 50.2%, transparent 50.4%),
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.02) 30%, rgba(3,7,9,.95));
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .82;
}
.cv-scene-line {
  position: absolute;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
}
.cv-scene-line--a { left: 14%; right: 14%; top: 34%; height: 1px; }
.cv-scene-line--b { left: 22%; right: 18%; top: 59%; height: 1px; }
.cv-scene-line--c {
  top: 18%; bottom: 10%; left: 56%; width: 1px;
  background: linear-gradient(180deg, transparent, rgba(255,255,255,.10), transparent);
}

.cv-scene-wall {
  position: relative;
  z-index: 2;
  padding: clamp(32px, 4vw, 52px);
  min-height: calc(100vh - 190px);
  display: grid;
  grid-template-columns: minmax(290px, 1.2fr) minmax(220px, .95fr) minmax(220px, .78fr) minmax(220px, .9fr);
  grid-template-rows: repeat(4, minmax(132px, auto));
  gap: 22px;
  perspective: 1800px;
  align-items: stretch;
}

.cv-scene-hero {
  grid-column: 1 / span 2;
  grid-row: 1 / span 2;
  position: relative;
  min-height: 420px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(4,8,10,.70), rgba(4,8,10,.88));
  overflow: hidden;
  isolation: isolate;
}
.cv-panel-glow::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(125deg, rgba(216,189,127,.08), transparent 30%, transparent 70%, rgba(216,189,127,.05));
  pointer-events: none;
}
.cv-scene-hero__inner {
  position: relative;
  z-index: 2;
  padding: clamp(36px, 4vw, 52px);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  min-height: 100%;
}
.cv-scene-hero h1 {
  margin: 0;
  max-width: 7.6ch;
  font-family: var(--cv-font-display);
  font-weight: 560;
  font-size: clamp(2.4rem, calc(1.5rem + 3.6vw * var(--cv-hero-title-scale)), 5.4rem);
  line-height: .94;
  letter-spacing: .01em;
  text-transform: uppercase;
  text-wrap: balance;
  overflow-wrap: anywhere;
}
.cv-scene-hero__lead {
  margin: 22px 0 0;
  max-width: 30ch;
  font-size: clamp(1rem, calc(.84rem + .5vw * var(--cv-hero-lead-scale)), 1.32rem);
  color: var(--cv-muted);
}
.cv-scene-contact-box {
  margin-top: 30px;
  padding: 18px 20px;
  border: 1px solid rgba(216,189,127,.18);
  background: rgba(4, 8, 10, 0.42);
  display: flex;
  flex-direction: column;
  gap: 8px;
  max-width: 430px;
}
.cv-scene-contact-box span { color: rgba(244,238,227,.88); }

.cv-scene-object {
  --cv-zone-text-scale: 1;
  position: relative;
  min-width: 0;
  min-height: 220px;
  padding: 22px;
  border-radius: 28px;
  border: 1px solid rgba(255,255,255,.10);
  color: var(--cv-text);
  overflow: hidden;
  isolation: isolate;
  box-shadow: 0 26px 60px rgba(0,0,0,.26);
  background:
    linear-gradient(180deg, rgba(4,8,10,.18), rgba(4,8,10,.70)),
    var(--cv-zone-bg, linear-gradient(145deg, #1a2228 0%, #0a1218 100%));
  background-size: cover;
  background-position: center;
  transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease, filter .35s ease;
  will-change: transform;
  transform-style: preserve-3d;
}
.cv-scene-object::before,
.cv-scene-object::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.cv-scene-object::before {
  background: linear-gradient(180deg, rgba(255,255,255,.12), transparent 24%, rgba(4,8,10,.55) 72%, rgba(4,8,10,.88));
  z-index: -1;
}
.cv-scene-object::after {
  background: radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(255,255,255,.18), transparent 24%);
  opacity: 0;
  transition: opacity .3s ease;
}
.cv-scene-object:hover,
.cv-scene-object:focus-visible {
  transform: rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(-8px) scale(1.012);
  border-color: rgba(216,189,127,.42);
  box-shadow: 0 32px 85px rgba(0,0,0,.38);
  filter: saturate(1.06);
}
.cv-scene-object:hover::after,
.cv-scene-object:focus-visible::after { opacity: 1; }
.cv-scene-object__frame,
.cv-scene-object__glass {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.cv-scene-object__frame {
  inset: 10px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.08);
}
.cv-scene-object__glass {
  background: linear-gradient(125deg, rgba(255,255,255,.10), transparent 34%, transparent 68%, rgba(255,255,255,.04));
  mix-blend-mode: screen;
  opacity: .56;
}
.cv-scene-object__icon {
  position: absolute;
  right: 18px; top: 16px;
  width: 58px; height: 58px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  overflow: hidden;
  background: rgba(4,8,10,.42);
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.04);
}
.cv-scene-object__icon img { width: 100%; height: 100%; object-fit: cover; }
.cv-scene-object h2 {
  margin: 0;
  max-width: 11ch;
  font-family: var(--cv-font-display);
  font-size: clamp(1.28rem, calc(1rem + 1.05vw * var(--cv-zone-text-scale)), 2.75rem);
  line-height: .97;
  font-weight: 540;
  letter-spacing: .01em;
  text-wrap: balance;
  overflow-wrap: anywhere;
}
.cv-scene-object p,
.cv-scene-contact-lines {
  margin: 14px 0 0;
  max-width: 28ch;
  color: rgba(244,238,227,.84);
  font-size: clamp(.92rem, calc(.82rem + .2vw * var(--cv-zone-text-scale)), 1.12rem);
  line-height: 1.45;
}
.cv-scene-contact-lines {
  display: flex;
  flex-direction: column;
  gap: 7px;
  margin-top: 18px;
}
.cv-scene-contact-lines span { display: block; }

/* Support types */
.cv-scene-object--portfolio {
  grid-column: 3 / span 1;
  grid-row: 1 / span 2;
  border-radius: 18px 18px 28px 28px;
}
.cv-scene-object--portfolio::before {
  background:
    linear-gradient(180deg, rgba(255,255,255,.11), transparent 15%, rgba(4,8,10,.58) 75%, rgba(4,8,10,.9)),
    linear-gradient(0deg, rgba(0,0,0,.15), rgba(0,0,0,.15));
}
.cv-scene-object--portfolio .cv-scene-object__frame {
  inset: 12px 12px 16px;
  border-radius: 12px 12px 24px 24px;
}

.cv-scene-object--projects {
  grid-column: 3 / span 1;
  grid-row: 3 / span 1;
  transform: rotateZ(-1.4deg);
  min-height: 250px;
}
.cv-scene-object--projects:hover,
.cv-scene-object--projects:focus-visible {
  transform: rotateZ(-1.4deg) rotateX(var(--rx, 0deg)) rotateY(var(--ry, 0deg)) translateY(-8px) scale(1.012);
}

.cv-scene-object--post {
  grid-column: 4 / span 1;
  grid-row: 1 / span 1;
  min-height: 280px;
  border-radius: 24px;
}
.cv-scene-object--post .cv-scene-object__frame {
  inset: 12px;
  border-radius: 20px;
}

.cv-scene-object--interview {
  grid-column: 4 / span 1;
  grid-row: 2 / span 2;
  min-height: 370px;
  border-radius: 32px 32px 18px 18px;
}
.cv-scene-object--interview .cv-scene-object__frame {
  inset: 14px;
  border-radius: 26px 26px 12px 12px;
}

.cv-scene-object--contact {
  grid-column: 2 / span 2;
  grid-row: 4 / span 1;
  min-height: 220px;
  background:
    linear-gradient(180deg, rgba(4,8,10,.20), rgba(4,8,10,.70)),
    var(--cv-zone-bg, linear-gradient(145deg, #231b13 0%, #0b1012 100%));
}
.cv-scene-object--contact .cv-scene-object__frame {
  inset: 14px;
  border-radius: 18px;
}

/* Content pages */
.cv-content-main { padding: 132px 0 58px; }
.cv-city-back-link {
  display: block;
  width: var(--cv-container);
  margin: 0 auto 18px;
  color: var(--cv-accent);
  font-size: .78rem;
  letter-spacing: .13em;
  text-transform: uppercase;
  font-weight: 700;
}
.cv-page-layout,
.cv-entry,
.cv-archive-head { max-width: 980px; margin-inline: auto; }
.cv-entry,
.cv-archive-head {
  padding: 34px;
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(255,255,255,.025), rgba(255,255,255,.012));
  box-shadow: 0 18px 48px rgba(0,0,0,.18);
}
.cv-entry h1,
.cv-archive-head h1,
.cv-404-copy h1 { 
  margin: 0 0 18px;
  font-family: var(--cv-font-display);
  line-height: .98;
  font-weight: 550;
  text-wrap: balance;
}
.cv-entry h1,
.cv-archive-head h1 { font-size: clamp(2rem, 4vw, 3.5rem); }
.cv-entry-content { color: rgba(244,238,227,.88); }
.cv-entry-content img { border-radius: 18px; }
.cv-entry-summary { color: var(--cv-muted); max-width: 42ch; }
.cv-eyebrow {
  margin: 0 0 10px;
  color: var(--cv-accent);
  letter-spacing: .18em;
  text-transform: uppercase;
  font-size: .74rem;
  font-weight: 700;
}
.cv-entry-media { margin: 24px 0; }

/* 404 */
.cv-404-main { padding: 126px 0 50px; }
.cv-404-stage {
  min-height: calc(100vh - 180px);
  position: relative;
  display: grid;
  grid-template-columns: minmax(290px, 1fr) minmax(280px, .88fr);
  gap: 28px;
  align-items: stretch;
  padding: clamp(34px, 4vw, 54px);
  border: 1px solid rgba(255,255,255,.08);
  background:
    linear-gradient(180deg, rgba(4,8,10,.76), rgba(4,8,10,.88)),
    var(--cv-404-image, linear-gradient(155deg, #101a22 0%, #060a0c 100%));
  background-size: cover;
  background-position: center;
  box-shadow: var(--cv-shadow);
  overflow: hidden;
}
.cv-404-stage::before {
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.03) 0 1px, transparent 1px 100%);
  opacity: .25;
}
.cv-404-copy { position: relative; z-index: 2; align-self: center; max-width: 40rem; }
.cv-404-copy h1 {
  max-width: 8ch;
  font-size: clamp(2.35rem, 5.2vw, 4.8rem);
}
.cv-404-copy p:last-of-type { max-width: 38ch; color: var(--cv-muted); margin-bottom: 28px; }
.cv-404-visual {
  position: relative;
  min-height: 420px;
  border: 1px solid rgba(255,255,255,.07);
  background: linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
}
.cv-404-orbit,
.cv-404-door {
  position: absolute;
}
.cv-404-orbit {
  border: 1px solid rgba(216,189,127,.28);
  border-radius: 999px;
}
.cv-404-orbit-a { width: 180px; height: 180px; top: 14%; left: 12%; }
.cv-404-orbit-b { width: 280px; height: 280px; right: 8%; bottom: 8%; }
.cv-404-door {
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 180px; height: 260px;
  border: 1px solid rgba(216,189,127,.26);
  background: linear-gradient(180deg, rgba(255,255,255,.08), rgba(4,8,10,.55));
}

/* Footer */
.cv-site-footer {
  padding: 28px 0 42px;
  border-top: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(4,7,8,.18), rgba(4,7,8,.94));
}
.cv-footer-grid {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 18px;
  align-items: center;
}
.cv-footer-contact {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
}
.cv-footer-contact a,
.cv-footer-contact span { color: rgba(244,238,227,.74); font-size: .92rem; }
.cv-footer-home {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--cv-accent);
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  font-weight: 700;
}

/* Maintenance */
.cv-maintenance-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
}
.cv-maintenance {
  width: min(960px, calc(100vw - 36px));
  padding: 26px;
}
.cv-maintenance-card {
  position: relative;
  padding: clamp(32px, 4vw, 52px);
  border: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(180deg, rgba(4,8,10,.84), rgba(4,8,10,.94));
  box-shadow: var(--cv-shadow);
}
.cv-maintenance-kicker {
  margin: 18px 0 10px;
  color: var(--cv-accent);
  letter-spacing: .16em;
  text-transform: uppercase;
  font-size: .74rem;
}
.cv-maintenance-card h1 {
  margin: 0 0 12px;
  font-family: var(--cv-font-display);
  font-size: clamp(2rem, 4vw, 3.6rem);
  line-height: .98;
}
.cv-maintenance-text { max-width: 42ch; color: var(--cv-muted); margin-bottom: 24px; }
.cv-maintenance-pillars {
  display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px;
}
.cv-maintenance-pillars span {
  padding: 10px 14px;
  border: 1px solid rgba(255,255,255,.08);
  color: rgba(244,238,227,.82);
  font-size: .84rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.cv-maintenance-city { display:none; }

/* Reveal */
.cv-reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity .55s ease, transform .55s ease;
}
.cv-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}

/* Responsive */
@media (max-width: 1180px) {
  .cv-scene-wall {
    grid-template-columns: minmax(260px, 1fr) minmax(220px, 1fr) minmax(220px, 1fr);
    grid-template-rows: repeat(5, minmax(126px, auto));
  }
  .cv-scene-hero { grid-column: 1 / span 2; grid-row: 1 / span 2; }
  .cv-scene-object--portfolio { grid-column: 3; grid-row: 1 / span 2; }
  .cv-scene-object--post { grid-column: 1; grid-row: 3; }
  .cv-scene-object--interview { grid-column: 2 / span 2; grid-row: 3 / span 2; }
  .cv-scene-object--projects { grid-column: 1; grid-row: 4; transform: none; }
  .cv-scene-object--projects:hover,
  .cv-scene-object--projects:focus-visible { transform: rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg)) translateY(-8px) scale(1.012); }
  .cv-scene-object--contact { grid-column: 1 / span 3; grid-row: 5; }
}

@media (max-width: 900px) {
  .cv-menu-toggle { display: inline-flex; }
  .cv-primary-nav {
    position: fixed;
    inset: 94px 14px auto 14px;
    z-index: 998;
    padding: 16px;
    border: 1px solid rgba(255,255,255,.10);
    background: rgba(5,9,11,.95);
    box-shadow: 0 18px 44px rgba(0,0,0,.35);
    opacity: 0; visibility: hidden;
    transform: translateY(-8px);
    transition: opacity .22s ease, visibility .22s ease, transform .22s ease;
  }
  body.menu-open .cv-primary-nav { opacity: 1; visibility: visible; transform: translateY(0); }
  .cv-menu { width: 100%; flex-direction: column; align-items: flex-start; gap: 18px; }
  .cv-menu li:not(:last-child)::after { display: none; }

  .cv-scene-home { padding-top: 108px; }
  .cv-scene-wrap { min-height: auto; }
  .cv-scene-wall {
    min-height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: none;
    gap: 18px;
    padding: 20px;
  }
  .cv-scene-hero,
  .cv-scene-object--portfolio,
  .cv-scene-object--projects,
  .cv-scene-object--post,
  .cv-scene-object--interview,
  .cv-scene-object--contact {
    grid-column: auto;
    grid-row: auto;
    min-height: 250px;
  }
  .cv-scene-hero { min-height: auto; }
  .cv-scene-hero__inner { min-height: auto; }
  .cv-scene-hero h1 { max-width: 9ch; font-size: clamp(2.1rem, calc(1.55rem + 6vw * var(--cv-hero-title-scale)), 4rem); }
  .cv-scene-object {
    transform: none !important;
    border-radius: 24px;
  }
  .cv-scene-object h2 { max-width: 12ch; }
  .cv-scene-floor { height: 16%; opacity: .52; }
  .cv-scene-line--c { display: none; }
  .cv-footer-grid,
  .cv-404-stage { grid-template-columns: 1fr; }
  .cv-404-visual { min-height: 260px; }
}

@media (max-width: 767px) {
  .admin-bar .cv-site-header { top: 46px; }
  .cv-header-inner { min-height: 80px; }
  .cv-container { width: min(100vw - 22px, 1320px); }
  .cv-scene-home { padding: 98px 0 24px; }
  .cv-scene-wrap { border-radius: 16px; }
  .cv-scene-wall { padding: 16px; gap: 16px; }
  .cv-scene-hero__inner { padding: 22px; }
  .cv-scene-contact-box { max-width: none; margin-top: 24px; }
  .cv-scene-object { min-height: 228px; padding: 18px; }
  .cv-scene-object__icon { width: 48px; height: 48px; right: 14px; top: 14px; border-radius: 14px; }
  .cv-scene-object h2 { font-size: clamp(1.25rem, calc(1rem + 3.2vw * var(--cv-zone-text-scale)), 2.2rem); }
  .cv-scene-object p,
  .cv-scene-contact-lines { font-size: 1rem; max-width: none; }
  .cv-content-main,
  .cv-404-main { padding-top: 106px; }
  .cv-entry,
  .cv-archive-head,
  .cv-404-stage { padding: 24px; }
}

/* ==========================================================================
   v3.1 — fondo ciudad/fachada 3D visible + contacto único
   ========================================================================== */

.cv-city-page .cv-site-footer {
  display: none;
}

.cv-scene-wrap {
  background:
    linear-gradient(180deg, rgba(7,10,12,.40), rgba(7,10,12,.72)),
    var(--cv-scene-bg, linear-gradient(155deg, #243238 0%, #0c1519 48%, #05090b 100%));
}

.cv-3d-city {
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  overflow: hidden;
  border-radius: inherit;
  perspective: 1400px;
  transform-style: preserve-3d;
}

.cv-3d-wall,
.cv-3d-tower,
.cv-3d-sign,
.cv-3d-avenue {
  position: absolute;
  display: block;
}

.cv-3d-wall--left {
  left: -6%;
  top: 5%;
  width: 48%;
  height: 86%;
  transform: perspective(1100px) rotateY(14deg) skewY(-1.6deg);
  transform-origin: left center;
  background:
    linear-gradient(90deg, rgba(216,189,127,.12), transparent 22% 74%, rgba(255,255,255,.04)),
    repeating-linear-gradient(180deg, rgba(255,255,255,.055) 0 1px, transparent 1px 76px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.045) 0 1px, transparent 1px 86px),
    linear-gradient(145deg, rgba(34,44,48,.85), rgba(8,15,18,.92));
  border-right: 1px solid rgba(255,255,255,.08);
  box-shadow: inset -80px 0 100px rgba(0,0,0,.28), 50px 0 110px rgba(0,0,0,.20);
  opacity: .92;
}

.cv-3d-wall--right {
  right: -8%;
  top: 7%;
  width: 48%;
  height: 83%;
  transform: perspective(1100px) rotateY(-15deg) skewY(1.4deg);
  transform-origin: right center;
  background:
    linear-gradient(270deg, rgba(216,189,127,.12), transparent 24% 72%, rgba(255,255,255,.035)),
    repeating-linear-gradient(180deg, rgba(255,255,255,.055) 0 1px, transparent 1px 70px),
    repeating-linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 82px),
    linear-gradient(215deg, rgba(31,43,49,.9), rgba(7,12,15,.94));
  border-left: 1px solid rgba(255,255,255,.08);
  box-shadow: inset 80px 0 100px rgba(0,0,0,.26), -50px 0 120px rgba(0,0,0,.22);
  opacity: .92;
}

.cv-3d-tower {
  border: 1px solid rgba(255,255,255,.08);
  background:
    repeating-linear-gradient(180deg, rgba(255,255,255,.08) 0 1px, transparent 1px 34px),
    linear-gradient(180deg, rgba(48,61,65,.58), rgba(7,12,15,.72));
  box-shadow: 0 28px 90px rgba(0,0,0,.34);
}

.cv-3d-tower--a {
  left: 42%;
  top: 15%;
  width: 8%;
  height: 48%;
  transform: perspective(900px) rotateY(8deg);
}

.cv-3d-tower--b {
  left: 52%;
  top: 10%;
  width: 9%;
  height: 58%;
  transform: perspective(900px) rotateY(-6deg);
  opacity: .76;
}

.cv-3d-tower--c {
  left: 62%;
  top: 23%;
  width: 7%;
  height: 41%;
  transform: perspective(900px) rotateY(-10deg);
  opacity: .58;
}

.cv-3d-sign {
  width: 130px;
  height: 42px;
  border: 1px solid rgba(216,189,127,.28);
  background:
    linear-gradient(180deg, rgba(216,189,127,.14), rgba(7,11,13,.56)),
    linear-gradient(90deg, transparent, rgba(255,255,255,.10), transparent);
  box-shadow: 0 18px 48px rgba(0,0,0,.32);
  opacity: .68;
}

.cv-3d-sign--a { left: 26%; top: 18%; transform: rotate(-3deg); }
.cv-3d-sign--b { right: 21%; top: 18%; transform: rotate(2deg); }

.cv-3d-avenue {
  left: 13%;
  right: 13%;
  bottom: -8%;
  height: 34%;
  transform: perspective(1000px) rotateX(68deg);
  transform-origin: bottom center;
  background:
    linear-gradient(90deg, transparent 0 49.2%, rgba(216,189,127,.46) 49.4% 50%, transparent 50.2% 100%),
    linear-gradient(180deg, rgba(255,255,255,.12), rgba(255,255,255,.02) 18%, rgba(4,7,9,.95) 72%);
  border-top: 1px solid rgba(255,255,255,.08);
  opacity: .88;
}

.cv-scene-wall {
  z-index: 4;
  grid-template-columns: minmax(310px, 1.12fr) minmax(230px, .82fr) minmax(230px, .86fr) minmax(250px, .95fr);
  grid-template-rows: minmax(230px, auto) minmax(210px, auto) minmax(210px, auto);
  gap: clamp(18px, 2vw, 28px);
}

.cv-scene-hero {
  grid-column: 1 / span 2;
  grid-row: 1 / span 2;
  min-height: 500px;
}

.cv-scene-object--portfolio {
  grid-column: 3 / span 1;
  grid-row: 1 / span 2;
  min-height: 500px;
}

.cv-scene-object--post {
  grid-column: 4;
  grid-row: 1;
  min-height: 238px;
}

.cv-scene-object--interview {
  grid-column: 4;
  grid-row: 2 / span 2;
  min-height: 430px;
}

.cv-scene-object--projects {
  grid-column: 2 / span 2;
  grid-row: 3;
  min-height: 230px;
  transform: rotateZ(-.7deg);
}

.cv-scene-hero,
.cv-scene-object {
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}

.cv-scene-hero h1 {
  max-width: 8.4ch;
  font-size: clamp(2.45rem, calc(1.45rem + 3vw * var(--cv-hero-title-scale)), 4.8rem);
}

.cv-scene-contact-box {
  max-width: 480px;
  border-color: rgba(216,189,127,.26);
  background: linear-gradient(180deg, rgba(4,8,10,.58), rgba(4,8,10,.38));
}

.cv-scene-contact-box span {
  line-height: 1.3;
}

.cv-scene-object h2 {
  max-width: 12ch;
}

@media (max-width: 1180px) {
  .cv-scene-wall {
    grid-template-columns: minmax(280px, 1fr) minmax(230px, .9fr) minmax(230px, .9fr);
    grid-template-rows: auto;
  }
  .cv-scene-hero { grid-column: 1 / span 2; grid-row: 1 / span 2; min-height: 440px; }
  .cv-scene-object--portfolio { grid-column: 3; grid-row: 1 / span 2; min-height: 440px; }
  .cv-scene-object--post { grid-column: 1; grid-row: 3; min-height: 250px; }
  .cv-scene-object--interview { grid-column: 2 / span 2; grid-row: 3; min-height: 250px; }
  .cv-scene-object--projects { grid-column: 1 / span 3; grid-row: 4; min-height: 230px; }
}

@media (max-width: 900px) {
  .cv-3d-wall--left,
  .cv-3d-wall--right {
    width: 70%;
    height: 94%;
    opacity: .66;
  }
  .cv-3d-wall--left { left: -25%; }
  .cv-3d-wall--right { right: -25%; }
  .cv-3d-tower--a,
  .cv-3d-tower--b,
  .cv-3d-tower--c { opacity: .34; }
  .cv-scene-wall {
    grid-template-columns: 1fr;
    grid-template-rows: none;
  }
  .cv-scene-hero,
  .cv-scene-object--portfolio,
  .cv-scene-object--projects,
  .cv-scene-object--post,
  .cv-scene-object--interview {
    grid-column: auto;
    grid-row: auto;
    min-height: 260px;
  }
  .cv-scene-hero h1 {
    max-width: 8ch;
    font-size: clamp(2.1rem, calc(1.25rem + 8vw * var(--cv-hero-title-scale)), 3.85rem);
  }
  .cv-scene-contact-box {
    max-width: none;
  }
}

@media (max-width: 767px) {
  .cv-scene-wrap {
    background:
      linear-gradient(180deg, rgba(7,10,12,.40), rgba(7,10,12,.76)),
      var(--cv-scene-bg, linear-gradient(155deg, #243238 0%, #0c1519 48%, #05090b 100%));
  }
  .cv-3d-sign { display: none; }
  .cv-scene-wall { padding: 14px; }
  .cv-scene-hero,
  .cv-scene-object--portfolio,
  .cv-scene-object--projects,
  .cv-scene-object--post,
  .cv-scene-object--interview {
    min-height: 236px;
  }
  .cv-scene-object h2 {
    max-width: 14ch;
  }
}

/* ==========================================================================
   v3.2 — palabras completas, contacto al final y enlaces activables
   ========================================================================== */

.cv-scene-hero h1,
.cv-scene-object h2 {
  overflow-wrap: normal !important;
  word-break: normal !important;
  hyphens: none !important;
  text-wrap: balance;
}

.cv-scene-hero h1 {
  max-width: 14ch !important;
  font-size: clamp(2.1rem, calc(1.15rem + 2.25vw * var(--cv-hero-title-scale)), 4.15rem) !important;
  line-height: .94;
}

.cv-scene-object h2 {
  max-width: 100% !important;
  font-size: clamp(1.24rem, calc(.98rem + .78vw * var(--cv-zone-text-scale)), 2.18rem) !important;
  line-height: 1.03;
}

.cv-scene-wall {
  grid-template-columns: minmax(330px, 1.12fr) minmax(230px, .82fr) minmax(230px, .86fr) minmax(260px, .95fr);
  grid-template-rows: minmax(218px, auto) minmax(218px, auto) minmax(210px, auto) minmax(172px, auto);
}

.cv-scene-object--contact {
  grid-column: 1 / span 4;
  grid-row: 4;
  min-height: 172px;
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(4,8,10,.18), rgba(4,8,10,.70)),
    var(--cv-zone-bg, linear-gradient(135deg, rgba(40,31,20,.72), rgba(7,12,15,.92)));
}

.cv-scene-object--contact .cv-scene-object__frame {
  inset: 12px;
  border-radius: 18px;
}

.cv-scene-object--contact h2,
.cv-scene-object--contact p,
.cv-scene-contact-lines {
  max-width: 100% !important;
}

.cv-scene-object--contact {
  display: grid;
  grid-template-columns: minmax(180px, .35fr) minmax(220px, .65fr);
  align-content: center;
  column-gap: 22px;
}

.cv-scene-object--contact h2,
.cv-scene-object--contact p {
  grid-column: 1;
}

.cv-scene-contact-lines {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin: 0;
}

.cv-scene-contact-lines span {
  min-width: 0;
  padding: 14px 16px;
  border: 1px solid rgba(216,189,127,.18);
  background: rgba(4,8,10,.42);
  color: rgba(244,238,227,.88);
  line-height: 1.25;
}

.cv-scene-object:not(a) {
  cursor: default;
}

@media (max-width: 1180px) {
  .cv-scene-wall {
    grid-template-columns: minmax(280px, 1fr) minmax(230px, .9fr) minmax(230px, .9fr);
    grid-template-rows: auto;
  }
  .cv-scene-object--contact {
    grid-column: 1 / span 3;
    grid-row: 5;
  }
  .cv-scene-hero h1 {
    font-size: clamp(2rem, calc(1.1rem + 3.1vw * var(--cv-hero-title-scale)), 3.7rem) !important;
    max-width: 14ch !important;
  }
}

@media (max-width: 900px) {
  .cv-scene-object--contact,
  .cv-scene-object--portfolio,
  .cv-scene-object--projects,
  .cv-scene-object--post,
  .cv-scene-object--interview,
  .cv-scene-hero {
    grid-column: auto;
    grid-row: auto;
  }
  .cv-scene-hero h1 {
    max-width: 14ch !important;
    font-size: clamp(1.8rem, calc(1.05rem + 5vw * var(--cv-hero-title-scale)), 3rem) !important;
  }
  .cv-scene-object--contact {
    display: block;
    min-height: 260px;
  }
  .cv-scene-contact-lines {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 18px;
  }
}

@media (max-width: 767px) {
  .cv-scene-hero h1 {
    max-width: 13ch !important;
    font-size: clamp(1.72rem, calc(1.05rem + 8vw * var(--cv-hero-title-scale)), 2.75rem) !important;
  }
  .cv-scene-object h2 {
    font-size: clamp(1.18rem, calc(.96rem + 5vw * var(--cv-zone-text-scale)), 2rem) !important;
  }
}

@media (max-width: 420px) {
  .cv-scene-hero h1 {
    font-size: clamp(1.58rem, 9vw, 2.25rem) !important;
  }
  .cv-scene-object h2 {
    font-size: clamp(1.08rem, 7vw, 1.75rem) !important;
  }
}

/* ==========================================================================
   v3.3 — responsive pro: no clipping, no horizontal recorte, city adapts
   ========================================================================== */

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

.cv-scene-home,
.cv-scene-wrap,
.cv-scene-wall,
.cv-scene-hero,
.cv-scene-object {
  max-width: 100%;
}

.cv-scene-hero h1,
.cv-scene-object h2 {
  word-break: normal !important;
  overflow-wrap: normal !important;
  hyphens: none !important;
  white-space: normal;
}

.cv-scene-wall,
.cv-scene-hero,
.cv-scene-object {
  min-width: 0;
}

.cv-scene-object {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  width: 100%;
}

.cv-scene-object p,
.cv-scene-contact-lines {
  min-width: 0;
  overflow-wrap: break-word;
}

.cv-scene-contact-lines span {
  overflow-wrap: break-word;
}

/* Large tablets and small laptops: two-column city, never clipped */
@media (max-width: 1280px) {
  :root {
    --cv-container: min(100vw - 32px, 1180px);
  }

  .cv-scene-home {
    overflow-x: hidden;
  }

  .cv-scene-wrap {
    overflow: hidden;
  }

  .cv-scene-wall {
    padding: clamp(22px, 3vw, 36px) !important;
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    grid-template-rows: auto !important;
    gap: clamp(16px, 2.2vw, 24px) !important;
    align-items: stretch;
  }

  .cv-scene-hero,
  .cv-scene-object--portfolio,
  .cv-scene-object--projects,
  .cv-scene-object--post,
  .cv-scene-object--interview,
  .cv-scene-object--contact {
    grid-column: auto !important;
    grid-row: auto !important;
    transform: none !important;
    min-width: 0 !important;
    width: 100% !important;
  }

  .cv-scene-hero {
    grid-column: 1 / -1 !important;
    min-height: 330px !important;
  }

  .cv-scene-object {
    min-height: 260px !important;
  }

  .cv-scene-object--contact {
    grid-column: 1 / -1 !important;
    min-height: 210px !important;
    display: grid !important;
    grid-template-columns: minmax(0, .42fr) minmax(0, .58fr);
    gap: 18px;
    align-content: center;
  }

  .cv-scene-object--contact h2,
  .cv-scene-object--contact p {
    grid-column: 1;
  }

  .cv-scene-contact-lines {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: center;
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 10px;
    margin: 0 !important;
  }

  .cv-scene-hero h1 {
    max-width: 100% !important;
    font-size: clamp(2rem, calc(1.1rem + 4.2vw * var(--cv-hero-title-scale)), 4.35rem) !important;
    line-height: .96 !important;
  }

  .cv-scene-object h2 {
    max-width: 100% !important;
    font-size: clamp(1.4rem, calc(1rem + 1.8vw * var(--cv-zone-text-scale)), 2.55rem) !important;
    line-height: 1.02 !important;
  }
}

/* Portrait tablet / mobile: same city language, single readable flow */
@media (max-width: 920px) {
  :root {
    --cv-container: min(100vw - 22px, 720px);
  }

  .cv-scene-home {
    padding: 106px 0 26px !important;
  }

  .cv-scene-wrap {
    border-radius: 18px;
    min-height: auto !important;
  }

  .cv-scene-wall {
    grid-template-columns: 1fr !important;
    grid-template-rows: none !important;
    padding: 18px !important;
    gap: 18px !important;
  }

  .cv-scene-hero,
  .cv-scene-object,
  .cv-scene-object--contact {
    grid-column: 1 / -1 !important;
    grid-row: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    transform: none !important;
  }

  .cv-scene-hero {
    min-height: auto !important;
  }

  .cv-scene-hero__inner {
    padding: clamp(22px, 5vw, 34px) !important;
    min-height: auto !important;
  }

  .cv-scene-object {
    min-height: 235px !important;
    padding: 20px !important;
    border-radius: 24px !important;
  }

  .cv-scene-object--contact {
    display: flex !important;
    flex-direction: column;
    justify-content: flex-end;
    min-height: 260px !important;
  }

  .cv-scene-object--contact h2,
  .cv-scene-object--contact p,
  .cv-scene-contact-lines {
    grid-column: auto !important;
    grid-row: auto !important;
  }

  .cv-scene-contact-lines {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr;
    gap: 10px;
    margin-top: 16px !important;
  }

  .cv-scene-hero h1 {
    max-width: 100% !important;
    font-size: clamp(1.95rem, calc(1.05rem + 7.2vw * var(--cv-hero-title-scale)), 3.35rem) !important;
    line-height: .98 !important;
    letter-spacing: .005em !important;
  }

  .cv-scene-hero__lead {
    max-width: 100% !important;
    font-size: clamp(1rem, calc(.93rem + 1.3vw * var(--cv-hero-lead-scale)), 1.25rem) !important;
  }

  .cv-scene-object h2 {
    max-width: calc(100% - 64px) !important;
    font-size: clamp(1.28rem, calc(.95rem + 5.2vw * var(--cv-zone-text-scale)), 2.2rem) !important;
    line-height: 1.04 !important;
  }

  .cv-scene-object p,
  .cv-scene-contact-lines {
    max-width: 100% !important;
    font-size: clamp(.96rem, 2.6vw, 1.08rem) !important;
    line-height: 1.45 !important;
  }

  .cv-3d-wall--left,
  .cv-3d-wall--right,
  .cv-3d-tower--a,
  .cv-3d-tower--b,
  .cv-3d-tower--c {
    opacity: .20 !important;
  }

  .cv-3d-sign {
    display: none !important;
  }
}

@media (max-width: 480px) {
  :root {
    --cv-container: calc(100vw - 18px);
  }

  .cv-site-header {
    position: sticky;
  }

  .cv-header-inner {
    min-height: 78px;
  }

  .cv-logo-text {
    font-size: clamp(1.18rem, 7vw, 1.62rem);
  }

  .cv-logo-sub {
    font-size: .52rem;
    letter-spacing: .22em;
  }

  .cv-scene-home {
    padding-top: 18px !important;
  }

  .cv-scene-wrap {
    border-radius: 14px;
  }

  .cv-scene-wall {
    padding: 12px !important;
    gap: 14px !important;
  }

  .cv-scene-hero__inner {
    padding: 20px !important;
  }

  .cv-scene-hero h1 {
    font-size: clamp(1.8rem, calc(1rem + 7vw * var(--cv-hero-title-scale)), 2.55rem) !important;
  }

  .cv-scene-object {
    min-height: 220px !important;
    padding: 18px !important;
  }

  .cv-scene-object h2 {
    font-size: clamp(1.18rem, calc(.9rem + 4.8vw * var(--cv-zone-text-scale)), 1.86rem) !important;
  }

  .cv-scene-object__icon {
    width: 44px !important;
    height: 44px !important;
    border-radius: 14px !important;
  }
}

/* ==========================================================================
   v3.4 — fix icon overlap on headings and descriptions
   ========================================================================== */

.cv-scene-object__icon {
  z-index: 4;
}

.cv-scene-object__icon ~ h2 {
  max-width: calc(100% - 96px) !important;
  padding-right: 92px;
}

.cv-scene-object__icon ~ p,
.cv-scene-object__icon ~ .cv-scene-contact-lines {
  max-width: calc(100% - 84px) !important;
  padding-right: 80px;
}

.cv-scene-object--portfolio .cv-scene-object__icon ~ h2,
.cv-scene-object--projects .cv-scene-object__icon ~ h2,
.cv-scene-object--post .cv-scene-object__icon ~ h2,
.cv-scene-object--interview .cv-scene-object__icon ~ h2 {
  text-wrap: pretty;
}

@media (max-width: 920px) {
  .cv-scene-object__icon ~ h2 {
    max-width: calc(100% - 78px) !important;
    padding-right: 74px;
  }

  .cv-scene-object__icon ~ p,
  .cv-scene-object__icon ~ .cv-scene-contact-lines {
    max-width: calc(100% - 68px) !important;
    padding-right: 64px;
  }
}

@media (max-width: 480px) {
  .cv-scene-object__icon ~ h2 {
    max-width: calc(100% - 64px) !important;
    padding-right: 60px;
  }

  .cv-scene-object__icon ~ p,
  .cv-scene-object__icon ~ .cv-scene-contact-lines {
    max-width: calc(100% - 56px) !important;
    padding-right: 52px;
  }
}

/* ==========================================================================
   v3.5 — portfolio card wider, better frame spacing and desktop balance
   ========================================================================== */

@media (min-width: 1281px) {
  .cv-scene-wall {
    grid-template-columns: minmax(320px, 1.02fr) minmax(180px, .36fr) minmax(250px, .72fr) minmax(250px, .72fr) minmax(270px, .86fr) !important;
    grid-template-rows: minmax(226px, auto) minmax(226px, auto) minmax(224px, auto) minmax(176px, auto) !important;
    gap: 24px !important;
  }

  .cv-scene-hero {
    grid-column: 1 / span 2 !important;
    grid-row: 1 / span 2 !important;
  }

  .cv-scene-object--portfolio {
    grid-column: 3 / span 2 !important;
    grid-row: 1 / span 2 !important;
    min-height: 476px !important;
    padding: 24px 26px 22px !important;
  }

  .cv-scene-object--portfolio .cv-scene-object__frame {
    inset: 14px 14px 18px !important;
    border-radius: 18px 18px 26px 26px !important;
  }

  .cv-scene-object--portfolio h2 {
    max-width: calc(100% - 104px) !important;
    padding-right: 96px !important;
    font-size: clamp(1.56rem, calc(1.08rem + 1.12vw * var(--cv-zone-text-scale)), 2.4rem) !important;
    line-height: 1.02 !important;
  }

  .cv-scene-object--portfolio p {
    max-width: calc(100% - 92px) !important;
    padding-right: 84px !important;
    font-size: clamp(.98rem, calc(.88rem + .32vw * var(--cv-zone-text-scale)), 1.18rem) !important;
    line-height: 1.5 !important;
  }

  .cv-scene-object--post {
    grid-column: 5 !important;
    grid-row: 1 !important;
    min-height: 280px !important;
  }

  .cv-scene-object--interview {
    grid-column: 5 !important;
    grid-row: 2 / span 2 !important;
    min-height: 420px !important;
  }

  .cv-scene-object--projects {
    grid-column: 2 / span 3 !important;
    grid-row: 3 !important;
    min-height: 230px !important;
  }

  .cv-scene-object--contact {
    grid-column: 1 / span 5 !important;
    grid-row: 4 !important;
  }
}

/* ==========================================================================
   v3.6 — lower studio / production room section after contact
   ========================================================================== */

.cv-studio-section {
  position: relative;
  padding: clamp(34px, 5vw, 70px) 0 clamp(58px, 7vw, 96px);
  background:
    radial-gradient(circle at 50% 0%, rgba(216,189,127,.10), transparent 26rem),
    linear-gradient(180deg, rgba(4,8,10,0) 0%, rgba(4,8,10,.70) 35%, rgba(4,8,10,.96) 100%);
}

.cv-studio-card {
  --cv-studio-image: linear-gradient(135deg, #1a2429 0%, #05090b 100%);
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(310px, .65fr);
  min-height: clamp(420px, 48vw, 640px);
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 30px;
  background: #05090b;
  box-shadow: 0 34px 110px rgba(0,0,0,.42);
  isolation: isolate;
}

.cv-studio-card::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0 58%, rgba(4,8,10,.78) 78%, rgba(4,8,10,.94) 100%),
    linear-gradient(180deg, rgba(4,8,10,.04), rgba(4,8,10,.26) 68%, rgba(4,8,10,.70));
  z-index: 1;
  pointer-events: none;
}

.cv-studio-card::after {
  content: "";
  position: absolute;
  inset: 18px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 22px;
  z-index: 3;
  pointer-events: none;
}

.cv-studio-image {
  position: absolute;
  inset: 0;
  z-index: 0;
  background-image: var(--cv-studio-image);
  background-size: cover;
  background-position: center;
  transform: scale(1.01);
  transition: transform .7s ease, filter .7s ease;
}

.cv-studio-card:hover .cv-studio-image {
  transform: scale(1.035);
  filter: saturate(1.06) contrast(1.03);
}

.cv-studio-content {
  position: relative;
  z-index: 4;
  grid-column: 2;
  align-self: end;
  padding: clamp(28px, 4vw, 52px);
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-end;
  min-width: 0;
}

.cv-studio-content h2 {
  margin: 0;
  max-width: 10ch;
  font-family: var(--cv-font-display);
  font-size: clamp(2rem, 4vw, 4.4rem);
  line-height: .96;
  font-weight: 540;
  text-wrap: balance;
}

.cv-studio-content p:not(.cv-eyebrow) {
  margin: 18px 0 0;
  max-width: 34ch;
  color: rgba(244,238,227,.84);
  font-size: clamp(1rem, 1.25vw, 1.18rem);
  line-height: 1.5;
}

.cv-studio-content .cv-button {
  margin-top: 26px;
}

@media (max-width: 1180px) {
  .cv-studio-card {
    grid-template-columns: 1fr;
    min-height: clamp(460px, 62vw, 620px);
  }

  .cv-studio-card::before {
    background:
      linear-gradient(180deg, rgba(4,8,10,.06) 0%, rgba(4,8,10,.18) 42%, rgba(4,8,10,.88) 100%);
  }

  .cv-studio-content {
    grid-column: 1;
    align-self: end;
    max-width: 720px;
  }

  .cv-studio-content h2 {
    max-width: 12ch;
  }
}

@media (max-width: 767px) {
  .cv-studio-section {
    padding: 24px 0 48px;
  }

  .cv-studio-card {
    min-height: 520px;
    border-radius: 22px;
  }

  .cv-studio-card::after {
    inset: 12px;
    border-radius: 16px;
  }

  .cv-studio-image {
    background-position: 40% center;
  }

  .cv-studio-content {
    padding: 24px;
  }

  .cv-studio-content h2 {
    max-width: 100%;
    font-size: clamp(1.8rem, 9vw, 3rem);
  }

  .cv-studio-content p:not(.cv-eyebrow) {
    max-width: 100%;
    font-size: 1rem;
  }
}

/* ==========================================================================
   v3.7 — strategic lower sections for publishing plan and copyright
   ========================================================================== */

.cv-feature-sections {
  position: relative;
  padding-bottom: clamp(48px, 6vw, 84px);
}

.cv-feature-sections .cv-studio-section {
  padding-top: clamp(20px, 3vw, 30px);
  padding-bottom: 0;
}

.cv-feature-card {
  --cv-studio-image: linear-gradient(135deg, #1a2429 0%, #05090b 100%);
}

.cv-feature-card.publishing,
.cv-feature-card.copyright {
  min-height: clamp(380px, 44vw, 560px);
  background:
    linear-gradient(180deg, rgba(12,17,21,.88), rgba(5,9,11,.96));
}

.cv-feature-card.publishing::before,
.cv-feature-card.copyright::before {
  background:
    linear-gradient(90deg, rgba(4,8,10,.10) 0 32%, rgba(4,8,10,.78) 62%, rgba(4,8,10,.94) 100%),
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(4,8,10,.30) 66%, rgba(4,8,10,.78));
}

.cv-feature-card.copyright::before {
  background:
    linear-gradient(90deg, rgba(4,8,10,.12) 0 38%, rgba(4,8,10,.82) 68%, rgba(4,8,10,.96) 100%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(4,8,10,.26) 66%, rgba(4,8,10,.78));
}

.cv-feature-card--reverse {
  grid-template-columns: minmax(310px, .72fr) minmax(0, 1.28fr);
}

.cv-feature-card--reverse::before {
  background:
    linear-gradient(270deg, transparent 0 58%, rgba(4,8,10,.78) 78%, rgba(4,8,10,.94) 100%),
    linear-gradient(180deg, rgba(4,8,10,.04), rgba(4,8,10,.26) 68%, rgba(4,8,10,.70));
}

.cv-feature-card--reverse .cv-studio-content {
  grid-column: 1;
  align-self: end;
}

.cv-feature-card--reverse .cv-studio-image {
  background-position: center center;
}

.cv-feature-card.publishing .cv-studio-content h2,
.cv-feature-card.copyright .cv-studio-content h2 {
  max-width: 11ch;
}

.cv-feature-card.publishing .cv-studio-content p:not(.cv-eyebrow),
.cv-feature-card.copyright .cv-studio-content p:not(.cv-eyebrow) {
  max-width: 40ch;
}

@media (max-width: 1180px) {
  .cv-feature-card--reverse {
    grid-template-columns: 1fr;
  }

  .cv-feature-card--reverse::before {
    background:
      linear-gradient(180deg, rgba(4,8,10,.06) 0%, rgba(4,8,10,.18) 42%, rgba(4,8,10,.88) 100%);
  }
}

/* ==========================================================================
   v3.8 — two-column publishing and copyright blocks before contact
   ========================================================================== */

.cv-feature-grid-two {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(18px, 2.3vw, 26px);
  margin: clamp(20px, 3vw, 32px) 0 0;
  align-items: stretch;
}

.cv-feature-grid-two .cv-feature-section {
  padding-top: 0;
  padding-bottom: 0;
  min-width: 0;
}

.cv-feature-grid-two .cv-feature-card {
  min-height: clamp(380px, 38vw, 520px);
  grid-template-columns: 1fr;
}

.cv-feature-grid-two .cv-feature-card::before,
.cv-feature-grid-two .cv-feature-card--reverse::before {
  background:
    linear-gradient(180deg, rgba(4,8,10,.08) 0%, rgba(4,8,10,.20) 42%, rgba(4,8,10,.88) 100%);
}

.cv-feature-grid-two .cv-feature-card .cv-studio-content,
.cv-feature-grid-two .cv-feature-card--reverse .cv-studio-content {
  grid-column: 1;
  align-self: end;
  max-width: none;
  padding: clamp(24px, 3vw, 34px);
}

.cv-feature-grid-two .cv-feature-card .cv-studio-content h2 {
  max-width: 12ch;
  font-size: clamp(1.75rem, 2.4vw, 2.9rem);
  line-height: .98;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.cv-feature-grid-two .cv-feature-card .cv-studio-content p:not(.cv-eyebrow) {
  max-width: 34ch;
  font-size: clamp(1rem, 1.1vw, 1.08rem);
  line-height: 1.5;
  overflow-wrap: break-word;
}

.cv-feature-grid-two .cv-feature-card .cv-studio-content .cv-button {
  margin-top: 22px;
}

.cv-feature-grid-two .cv-feature-card .cv-studio-image {
  background-position: center center;
}

.cv-feature-section--contact {
  margin-top: clamp(20px, 3vw, 32px);
}

@media (max-width: 1100px) {
  .cv-feature-grid-two {
    grid-template-columns: 1fr;
  }

  .cv-feature-grid-two .cv-feature-card {
    min-height: clamp(360px, 54vw, 500px);
  }
}

@media (max-width: 767px) {
  .cv-feature-grid-two {
    gap: 16px;
    margin-top: 16px;
  }

  .cv-feature-grid-two .cv-feature-card .cv-studio-content {
    padding: 22px;
  }

  .cv-feature-grid-two .cv-feature-card .cv-studio-content h2 {
    font-size: clamp(1.55rem, 7.4vw, 2.3rem);
    max-width: 100%;
  }

  .cv-feature-grid-two .cv-feature-card .cv-studio-content p:not(.cv-eyebrow) {
    max-width: 100%;
    font-size: .98rem;
  }
}

/* ==========================================================================
   v3.9 — Plan, Registro y Contacto en tres columnas; estudio al final
   ========================================================================== */

.cv-feature-grid-three {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(16px, 2vw, 24px);
  margin: clamp(20px, 3vw, 34px) 0 0;
  align-items: stretch;
}

.cv-feature-grid-three .cv-feature-section {
  min-width: 0;
  padding: 0;
}

.cv-feature-grid-three .cv-feature-card {
  min-width: 0;
  min-height: clamp(300px, 31vw, 390px);
  display: grid;
  grid-template-columns: 1fr !important;
  border-radius: 24px;
  box-shadow: 0 24px 70px rgba(0,0,0,.30);
}

.cv-feature-grid-three .cv-feature-card::before,
.cv-feature-grid-three .cv-feature-card--reverse::before {
  background:
    linear-gradient(180deg, rgba(4,8,10,.10) 0%, rgba(4,8,10,.30) 38%, rgba(4,8,10,.88) 100%);
}

.cv-feature-grid-three .cv-feature-card::after {
  inset: 12px;
  border-radius: 18px;
}

.cv-feature-grid-three .cv-studio-content,
.cv-feature-grid-three .cv-feature-card--reverse .cv-studio-content {
  grid-column: 1 !important;
  align-self: end;
  justify-content: flex-end;
  max-width: none;
  width: 100%;
  padding: clamp(22px, 2.4vw, 30px);
}

.cv-feature-grid-three .cv-studio-content h2 {
  max-width: 11ch !important;
  font-size: clamp(1.45rem, 2vw, 2.25rem) !important;
  line-height: 1.02;
  letter-spacing: .005em;
  overflow-wrap: normal;
  word-break: normal;
  hyphens: none;
}

.cv-feature-grid-three .cv-studio-content p:not(.cv-eyebrow) {
  max-width: 34ch !important;
  margin-top: 14px;
  font-size: clamp(.94rem, 1vw, 1.02rem) !important;
  line-height: 1.46;
  overflow-wrap: break-word;
}

.cv-feature-grid-three .cv-eyebrow {
  margin-bottom: 9px;
  font-size: .68rem;
  letter-spacing: .16em;
}

.cv-feature-grid-three .cv-button {
  min-height: 46px;
  margin-top: 20px !important;
  padding-inline: 15px;
  font-size: .70rem;
}

.cv-feature-grid-three .cv-feature-card.contact {
  background:
    radial-gradient(circle at 82% 12%, rgba(216,189,127,.14), transparent 15rem),
    linear-gradient(145deg, rgba(14,21,26,.96) 0%, rgba(6,10,12,.98) 100%);
}

.cv-feature-grid-three .cv-feature-card.contact .cv-studio-image {
  background-image:
    linear-gradient(90deg, rgba(255,255,255,.04) 0 1px, transparent 1px 100%),
    linear-gradient(180deg, rgba(255,255,255,.03) 0 1px, transparent 1px 100%);
  background-size: 112px 100%, 100% 96px;
  opacity: .50;
}

.cv-feature-contact-lines {
  display: grid;
  grid-template-columns: 1fr;
  gap: 9px;
  width: 100%;
  margin-top: 16px;
}

.cv-feature-contact-lines span {
  display: block;
  min-width: 0;
  padding: 10px 12px;
  border: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.025);
  color: rgba(244,238,227,.86);
  font-size: .92rem;
  line-height: 1.28;
  overflow-wrap: anywhere;
}

.cv-feature-section--studio-final {
  margin-top: clamp(18px, 3vw, 34px);
}

.cv-feature-section--studio-final .cv-studio-card {
  min-height: clamp(430px, 48vw, 640px);
}

@media (max-width: 1120px) {
  .cv-feature-grid-three {
    grid-template-columns: 1fr;
  }

  .cv-feature-grid-three .cv-feature-card {
    min-height: clamp(280px, 45vw, 380px);
  }

  .cv-feature-grid-three .cv-studio-content h2,
  .cv-feature-grid-three .cv-studio-content p:not(.cv-eyebrow) {
    max-width: 100% !important;
  }
}

@media (max-width: 767px) {
  .cv-feature-grid-three {
    gap: 14px;
    margin-top: 16px;
  }

  .cv-feature-grid-three .cv-feature-card {
    min-height: auto;
  }

  .cv-feature-grid-three .cv-studio-content {
    padding: 22px;
    min-height: 270px;
  }

  .cv-feature-grid-three .cv-studio-content h2 {
    font-size: clamp(1.45rem, 7vw, 2.05rem) !important;
  }

  .cv-feature-section--studio-final .cv-studio-card {
    min-height: 520px;
  }
}

/* ==========================================================================
   v4.0 FX Safe Update — cinematic audiovisual atmosphere only
   Does not change saved texts, option IDs, dimensions, or layout structure.
   ========================================================================== */

:root {
  --cv-fx-x: 50%;
  --cv-fx-y: 30%;
  --cv-fx-gold: rgba(216,189,127,.36);
  --cv-fx-blue: rgba(104,167,214,.18);
  --cv-fx-cyan: rgba(128,217,255,.12);
}

body {
  position: relative;
}

body::before,
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
}

body::before {
  opacity: .115;
  mix-blend-mode: soft-light;
  background-image:
    radial-gradient(circle at 25% 20%, rgba(255,255,255,.48) 0 1px, transparent 1.4px),
    radial-gradient(circle at 72% 65%, rgba(255,255,255,.30) 0 .8px, transparent 1.2px),
    linear-gradient(90deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px);
  background-size: 160px 160px, 190px 190px, 4px 4px;
}

body::after {
  opacity: .72;
  background:
    radial-gradient(circle at var(--cv-fx-x) var(--cv-fx-y), rgba(216,189,127,.055), transparent 24rem),
    radial-gradient(circle at 50% 50%, transparent 50%, rgba(0,0,0,.32) 100%);
}

.cv-site-header {
  box-shadow:
    0 1px 0 rgba(255,255,255,.05),
    0 18px 52px rgba(0,0,0,.22);
}

.cv-scene-wrap,
.cv-studio-card,
.cv-feature-card,
.cv-scene-object,
.cv-scene-hero {
  backface-visibility: hidden;
}

.cv-scene-wrap {
  box-shadow:
    0 40px 120px rgba(0,0,0,.46),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(216,189,127,.08);
}

.cv-scene-wrap::before {
  background:
    radial-gradient(circle at var(--cv-fx-x) var(--cv-fx-y), rgba(216,189,127,.13), transparent 20rem),
    radial-gradient(circle at 80% 18%, var(--cv-fx-blue), transparent 22rem),
    linear-gradient(115deg, transparent 0 42%, rgba(255,255,255,.045) 47%, transparent 53% 100%);
  opacity: .58;
}

.cv-3d-city::after {
  content: "";
  position: absolute;
  left: 6%;
  right: 6%;
  bottom: 10%;
  height: 1px;
  pointer-events: none;
  background: linear-gradient(90deg, transparent, rgba(216,189,127,.38), rgba(128,217,255,.14), transparent);
  box-shadow:
    0 0 24px rgba(216,189,127,.24),
    0 -60px 90px rgba(128,217,255,.06);
  opacity: .72;
}

.cv-scene-object {
  box-shadow:
    0 26px 70px rgba(0,0,0,.34),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(0,0,0,.42);
}

.cv-scene-object__frame {
  box-shadow:
    inset 0 0 0 1px rgba(216,189,127,.05),
    inset 0 20px 38px rgba(255,255,255,.025),
    0 0 22px rgba(216,189,127,.035);
}

.cv-scene-object__glass {
  opacity: .68;
  background:
    linear-gradient(122deg, rgba(255,255,255,.14), transparent 28%, transparent 64%, rgba(216,189,127,.055)),
    radial-gradient(circle at var(--mx, 50%) var(--my, 50%), rgba(255,255,255,.18), transparent 18rem);
}

.cv-scene-object:hover .cv-scene-object__frame,
.cv-scene-object:focus-visible .cv-scene-object__frame {
  border-color: rgba(216,189,127,.18);
  box-shadow:
    inset 0 0 0 1px rgba(216,189,127,.12),
    inset 0 20px 38px rgba(255,255,255,.035),
    0 0 32px rgba(216,189,127,.12);
}

.cv-scene-object__icon {
  box-shadow:
    inset 0 0 0 1px rgba(255,255,255,.07),
    0 10px 26px rgba(0,0,0,.30),
    0 0 28px rgba(216,189,127,.08);
}

.cv-studio-card,
.cv-feature-card {
  box-shadow:
    0 34px 110px rgba(0,0,0,.44),
    inset 0 1px 0 rgba(255,255,255,.08),
    inset 0 -1px 0 rgba(216,189,127,.06);
}

.cv-studio-card::after,
.cv-feature-card::after {
  box-shadow:
    inset 0 0 0 1px rgba(216,189,127,.045),
    inset 0 22px 42px rgba(255,255,255,.025),
    0 0 36px rgba(216,189,127,.05);
}

.cv-studio-image {
  filter: saturate(1.04) contrast(1.02);
}

.cv-studio-card:hover .cv-studio-image,
.cv-feature-card:hover .cv-studio-image {
  filter: saturate(1.09) contrast(1.04) brightness(1.02);
}

.cv-studio-content,
.cv-scene-hero__inner {
  text-shadow: 0 1px 18px rgba(0,0,0,.35);
}

.cv-eyebrow {
  text-shadow: 0 0 18px rgba(216,189,127,.18);
}

.cv-button {
  position: relative;
  overflow: hidden;
  isolation: isolate;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.10),
    0 12px 34px rgba(0,0,0,.22),
    0 0 0 1px rgba(216,189,127,.06);
}

.cv-button::before {
  content: "";
  position: absolute;
  inset: -1px;
  z-index: -1;
  opacity: 0;
  background: linear-gradient(110deg, transparent 0 30%, rgba(255,255,255,.22) 46%, transparent 62% 100%);
  transform: translateX(-36%);
  transition: transform .55s ease, opacity .35s ease;
}

.cv-button:hover::before,
.cv-button:focus-visible::before {
  opacity: 1;
  transform: translateX(32%);
}

.cv-feature-grid-three .cv-feature-card,
.cv-feature-grid-two .cv-feature-card {
  border-color: rgba(255,255,255,.11);
}

.cv-feature-grid-three .cv-feature-card:hover,
.cv-feature-grid-two .cv-feature-card:hover {
  border-color: rgba(216,189,127,.20);
}

.cv-feature-contact-lines span,
.cv-scene-contact-lines span {
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,.06),
    0 10px 28px rgba(0,0,0,.18);
}

@media (prefers-reduced-motion: no-preference) {
  .cv-scene-wrap::before {
    animation: cvFxBreath 8s ease-in-out infinite alternate;
  }

  .cv-3d-city::after {
    animation: cvFxScan 7s ease-in-out infinite alternate;
  }

  .cv-scene-object__glass {
    transition: opacity .35s ease, background .35s ease;
  }
}

@keyframes cvFxBreath {
  from { opacity: .46; }
  to { opacity: .70; }
}

@keyframes cvFxScan {
  from { opacity: .44; transform: translateY(0); }
  to { opacity: .78; transform: translateY(-8px); }
}

@media (max-width: 767px) {
  body::before { opacity: .08; }
  body::after { opacity: .54; }

  .cv-scene-wrap::before {
    opacity: .42;
  }
}
