:root{
  --paper:#f4ede0;
  --paper-deep:#ebe2d0;
  --ink:#191613;
  --ink-soft:#3a342c;
  --ink-mute:#7a6f5e;
  --copper:#a8501e;
  --copper-deep:#7d3a13;
  --oxblood:#5c1a26;
  --rule:rgba(25,22,19,.18);
  --rule-soft:rgba(25,22,19,.08);

  --display:'Fraunces',Georgia,serif;
  --sans:'Inter Tight',-apple-system,sans-serif;
  --mono:'JetBrains Mono',monospace;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--paper);
  color:var(--ink);
  line-height:1.55;
  font-feature-settings:"ss01","ss02","kern";
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;background:none;border:none;cursor:pointer;color:inherit}

.container{max-width:1280px;margin:0 auto;padding:0 32px}

/* ============ GRID OVERLAY (decorativo) ============ */
.grid-overlay{
  position:fixed;inset:0;pointer-events:none;z-index:1;
  background-image:
    linear-gradient(var(--rule-soft) 1px,transparent 1px),
    linear-gradient(90deg,var(--rule-soft) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.6),rgba(0,0,0,.2) 60%,transparent);
}

/* ============ HEADER ============ */
.header{
  position:sticky;top:0;z-index:50;
  background:var(--paper);
  border-bottom:1px solid var(--rule);
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 32px;max-width:1280px;margin:0 auto;
}
.logo{display:flex;align-items:center;gap:14px}
.logo-mark{
  width:36px;height:36px;border:1.5px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--display);font-style:italic;font-weight:500;
  font-size:22px;
}
.logo-name{
  font-family:var(--mono);font-size:11px;
  letter-spacing:1.5px;text-transform:uppercase;
  font-weight:500;
}
.logo-name em{
  font-family:var(--display);font-style:italic;
  font-weight:400;text-transform:none;letter-spacing:0;
  font-size:18px;color:var(--copper);margin-left:4px;
}

.nav{display:flex;align-items:center;gap:36px}
.nav a{
  font-family:var(--mono);font-size:11px;
  letter-spacing:1.5px;text-transform:uppercase;
  font-weight:500;position:relative;padding:4px 0;
  transition:color .25s;
}
.nav a:hover{color:var(--copper)}
.nav a::after{
  content:"";position:absolute;bottom:0;left:0;
  width:0;height:1px;background:var(--copper);
  transition:width .3s ease;
}
.nav a:hover::after{width:100%}

.nav-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;font-weight:500;
  padding:10px 18px;border:1.5px solid var(--ink);
  transition:all .3s;
}
.nav-cta:hover{background:var(--ink);color:var(--paper)}

.menu-btn{
  display:none;width:48px;height:48px;
  flex-direction:column;justify-content:center;align-items:center;gap:5px;
  border:1px solid var(--ink);
}
.menu-btn span{display:block;width:18px;height:1.5px;background:var(--ink);transition:.3s}

@media(max-width:1024px){
  .nav,.nav-cta{display:none}
  .menu-btn{display:flex}
}

/* ============ MOBILE MENU FULLSCREEN ============ */
.mobile-menu{
  position:fixed;inset:0;z-index:100;
  background:var(--paper);
  display:flex;flex-direction:column;
  transform:translateY(-100%);
  transition:transform .55s cubic-bezier(.7,0,.3,1);
}
.mobile-menu.open{transform:translateY(0)}
.mobile-menu-head{
  display:flex;justify-content:space-between;align-items:center;
  padding:18px 32px;border-bottom:1px solid var(--rule);
}
.mobile-menu-close{
  width:48px;height:48px;border:1px solid var(--ink);
  position:relative;
}
.mobile-menu-close::before,.mobile-menu-close::after{
  content:"";position:absolute;top:50%;left:50%;
  width:18px;height:1.5px;background:var(--ink);
}
.mobile-menu-close::before{transform:translate(-50%,-50%) rotate(45deg)}
.mobile-menu-close::after{transform:translate(-50%,-50%) rotate(-45deg)}

.mobile-menu-body{
  flex:1;padding:24px 28px 32px;
  display:flex;flex-direction:column;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
}
.mobile-menu-body a{
  display:flex;align-items:baseline;gap:16px;
  padding:14px 0;border-bottom:1px solid var(--rule);
  font-family:var(--display);font-size:30px;font-weight:400;
  letter-spacing:-.5px;line-height:1;
  transition:color .3s,padding-left .3s;
  position:relative;
}
.mobile-menu-body a span.num{
  font-family:var(--mono);font-size:10px;color:var(--ink-mute);
  letter-spacing:1.5px;flex-shrink:0;
  width:22px;
}
.mobile-menu-body a span.tag{
  margin-left:auto;font-family:var(--mono);font-size:9px;
  letter-spacing:1.5px;text-transform:uppercase;
  color:var(--ink-mute);font-weight:500;align-self:center;
}
.mobile-menu-body a:hover,.mobile-menu-body a:active{
  color:var(--copper);padding-left:8px;
}
.mobile-menu-body a em{
  font-style:italic;color:var(--copper);font-weight:400;
}
.mobile-menu-section{
  font-family:var(--mono);font-size:9px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink-mute);
  padding:18px 0 8px;font-weight:500;
  display:flex;align-items:center;gap:12px;
}
.mobile-menu-section::after{
  content:"";flex:1;height:1px;background:var(--rule);
}
.mobile-menu-foot{
  padding:20px 28px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;font-family:var(--mono);
  font-size:10px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--ink-mute);flex-wrap:wrap;gap:8px;
}
@media(max-height:700px){
  .mobile-menu-body a{font-size:24px;padding:10px 0}
  .mobile-menu-section{padding:12px 0 6px}
}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:760px;
  padding:120px 0;
  border-bottom:1px solid var(--rule);
  overflow:hidden;
  background:#0e0c08;
  isolation:isolate;
}
.hero-photo{
  position:absolute;inset:0;
  background-image:url("https://images.unsplash.com/photo-1530103862676-de8c9debad1d?auto=format&fit=crop&w=2400&q=80");
  background-size:cover;
  background-position:center 60%;
  opacity:.55;
  z-index:0;
  filter:saturate(.85) contrast(1.05);
}
.hero-photo::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(135deg,rgba(14,12,8,.85) 0%,rgba(14,12,8,.6) 40%,rgba(14,12,8,.4) 75%,rgba(168,80,30,.25) 100%),
    linear-gradient(180deg,rgba(14,12,8,.7) 0%,rgba(14,12,8,.4) 50%,rgba(14,12,8,.85) 100%);
}
.hero::before{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(244,237,224,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,237,224,.05) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.4),transparent 70%);
}
.hero-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1fr 5fr 1fr 3fr;
  gap:32px;align-items:end;
  max-width:1280px;margin:0 auto;padding:0 32px;
}
.hero-side{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:rgba(244,237,224,.55);
  writing-mode:vertical-rl;transform:rotate(180deg);
  align-self:start;padding-top:20px;
}
.hero-main{padding:40px 0}
.hero-tag{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:#e6a363;
  padding:6px 14px;border:1px solid rgba(230,163,99,.6);
  background:rgba(168,80,30,.15);
  backdrop-filter:blur(4px);
  margin-bottom:32px;
}
.hero-tag::before{
  content:"";width:6px;height:6px;background:#e6a363;
  border-radius:50%;animation:pulse 2s ease-in-out infinite;
  box-shadow:0 0 10px #e6a363;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero h1{
  font-family:var(--display);
  font-size:clamp(52px,9vw,144px);
  line-height:.88;font-weight:400;
  letter-spacing:-.04em;
  margin-bottom:24px;
  color:#f4ede0;
  text-shadow:0 2px 40px rgba(0,0,0,.4);
}
.hero h1 .word-1{display:block;font-weight:300}
.hero h1 .word-2{display:block;font-style:italic;color:#e6a363;font-weight:500}
.hero h1 .word-3{display:block;font-weight:300}

.hero-divider{
  width:80px;height:2px;background:#e6a363;margin:32px 0;
}
.hero-lead{
  font-family:var(--display);font-size:21px;font-weight:400;
  font-style:italic;line-height:1.4;color:rgba(244,237,224,.85);
  max-width:540px;margin-bottom:40px;
  text-shadow:0 1px 20px rgba(0,0,0,.3);
}

.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.btn{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;font-weight:500;
  padding:18px 28px;display:inline-flex;align-items:center;gap:10px;
  transition:all .3s;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--copper)}
.btn-outline{border:1.5px solid var(--ink)}
.btn-outline:hover{background:var(--ink);color:var(--paper)}
.btn .arrow{transition:transform .3s}
.btn:hover .arrow{transform:translateX(4px)}

.hero-aside{
  align-self:end;padding-bottom:40px;
  border-left:1px solid rgba(244,237,224,.18);padding-left:24px;
  background:rgba(14,12,8,.4);
  backdrop-filter:blur(8px);
  padding:28px 24px;
  border:1px solid rgba(244,237,224,.12);
}
.hero-aside-num{
  font-family:var(--display);font-size:80px;font-weight:300;
  line-height:.9;letter-spacing:-3px;color:#e6a363;
}
.hero-aside-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.6);margin-top:8px;
}
.hero-aside-divider{height:1px;background:rgba(244,237,224,.18);margin:24px 0}
.hero-aside-meta{
  font-family:var(--display);font-style:italic;
  font-size:14px;color:rgba(244,237,224,.8);line-height:1.5;
}

/* Botones del hero sobre foto */
.hero .btn-primary{background:#e6a363;color:#0e0c08}
.hero .btn-primary:hover{background:#f4ede0}
.hero .btn-outline{
  border:1.5px solid rgba(244,237,224,.7);color:#f4ede0;
  background:rgba(244,237,224,.06);backdrop-filter:blur(4px);
}
.hero .btn-outline:hover{background:#f4ede0;color:#0e0c08;border-color:#f4ede0}

@media(max-width:1024px){
  .hero{min-height:auto;padding:80px 0 100px}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero-side{display:none}
  .hero-aside{padding:24px;}
}

/* ============ MARQUEE ============ */
.marquee{
  border-bottom:1px solid var(--rule);
  background:var(--ink);color:var(--paper);
  overflow:hidden;padding:18px 0;
}
.marquee-track{
  display:flex;gap:60px;
  animation:scroll 40s linear infinite;
  white-space:nowrap;
}
.marquee-item{
  font-family:var(--display);font-size:36px;font-weight:300;
  font-style:italic;letter-spacing:-1px;
  display:flex;align-items:center;gap:60px;
}
.marquee-item::after{
  content:"✦";color:var(--copper);font-size:22px;font-style:normal;
}
@keyframes scroll{
  to{transform:translateX(calc(-50% - 30px))}
}

/* ============ SECTION INTRO (capítulos) ============ */
.section-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding:80px 0 40px;border-bottom:1px solid var(--rule);
  margin-bottom:60px;
}
.section-head-left{flex:1}
.section-num{
  font-family:var(--mono);font-size:11px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--ink-mute);margin-bottom:12px;
}
.section-num span{color:var(--copper)}
.section-title{
  font-family:var(--display);font-size:clamp(40px,5vw,72px);
  font-weight:400;line-height:1;letter-spacing:-.03em;
}
.section-title em{font-style:italic;color:var(--copper);font-weight:500}
.section-head-right{
  font-family:var(--display);font-style:italic;font-size:16px;
  color:var(--ink-soft);max-width:280px;text-align:right;
  line-height:1.5;
}

@media(max-width:768px){
  .section-head{flex-direction:column;align-items:flex-start;gap:18px}
  .section-head-right{text-align:left}
}

/* ============ EVENTOS GRID ============ */
.section-events{padding-bottom:80px}
.events-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.event-card{
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:36px 32px;display:flex;flex-direction:column;gap:14px;
  position:relative;background:var(--paper);
  transition:background .3s;min-height:280px;
}
.event-card:hover{background:var(--paper-deep)}
.event-card-num{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  color:var(--copper);font-weight:500;
}
.event-card h3{
  font-family:var(--display);font-size:34px;font-weight:400;
  line-height:1.05;letter-spacing:-1px;margin-top:8px;
}
.event-card h3 em{font-style:italic;color:var(--copper)}
.event-card p{font-size:14px;color:var(--ink-soft);flex:1}
.event-card-foot{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-mute);
  padding-top:14px;border-top:1px solid var(--rule);
}

@media(max-width:1024px){.events-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.events-grid{grid-template-columns:1fr}}

/* ============ MANIFIESTO ============ */
.manifesto{
  padding:120px 0;background:var(--ink);color:var(--paper);
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
  position:relative;overflow:hidden;
}
.manifesto::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(244,237,224,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,237,224,.04) 1px,transparent 1px);
  background-size:80px 80px;pointer-events:none;
}
.manifesto-inner{position:relative}
.manifesto-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--copper);margin-bottom:32px;
  display:flex;align-items:center;gap:14px;
}
.manifesto-tag::before{
  content:"";width:60px;height:1px;background:var(--copper);
}
.manifesto h2{
  font-family:var(--display);font-size:clamp(44px,7vw,108px);
  font-weight:300;line-height:.95;letter-spacing:-.04em;
  margin-bottom:48px;max-width:1100px;
}
.manifesto h2 em{font-style:italic;color:var(--copper);font-weight:400}
.manifesto-stats{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid rgba(244,237,224,.2);
  margin-top:60px;
}
.stat{
  padding:32px 0;padding-right:32px;
  border-right:1px solid rgba(244,237,224,.2);
}
.stat:last-child{border-right:none}
.stat-num{
  font-family:var(--display);font-size:64px;font-weight:300;
  line-height:1;letter-spacing:-2px;color:var(--paper);
}
.stat-num em{font-style:italic;color:var(--copper)}
.stat-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.6);margin-top:12px;
}
@media(max-width:768px){
  .manifesto-stats{grid-template-columns:repeat(2,1fr)}
  .stat{border-right:none;border-bottom:1px solid rgba(244,237,224,.2);
    padding:24px 0}
  .stat-num{font-size:48px}
}

/* ============ TIRA DE CIUDADES (compacta) ============ */
.ciudades-strip{
  padding:48px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--paper-deep);
}
.ciudades-strip-inner{
  display:flex;align-items:baseline;gap:32px;flex-wrap:wrap;
}
.ciudades-strip-eyebrow{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
  flex-shrink:0;
}
.ciudades-strip-list{
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
}
.ciudades-strip-list a{
  font-family:var(--display);font-size:28px;font-weight:400;
  letter-spacing:-.5px;line-height:1.1;
  color:var(--ink);transition:color .25s,transform .25s;
  position:relative;padding-bottom:2px;
}
.ciudades-strip-list a::after{
  content:"";position:absolute;left:0;right:0;bottom:0;
  height:1px;background:var(--copper);
  transform:scaleX(0);transform-origin:left;
  transition:transform .3s ease;
}
.ciudades-strip-list a:hover{color:var(--copper)}
.ciudades-strip-list a:hover::after{transform:scaleX(1)}
.ciudades-strip-list a.soon{color:var(--ink-mute);font-style:italic}
.ciudades-strip-list a.soon:hover{color:var(--copper)}
.ciudades-strip-list .dot{
  font-family:var(--display);font-size:20px;color:var(--ink-mute);
  user-select:none;
}
.ciudades-strip-soon{
  font-family:var(--mono);font-size:9px;letter-spacing:2px;
  text-transform:uppercase;color:var(--copper);
  margin:0 8px 0 12px;padding:4px 10px;
  border:1px solid var(--copper);font-weight:500;
}
@media(max-width:768px){
  .ciudades-strip{padding:36px 0}
  .ciudades-strip-list a{font-size:22px}
  .ciudades-strip-list{gap:10px}
}

/* ============ CIUDADES (legacy — ya no se usa) ============ */
.section-ciudades{padding:80px 0 120px}
.ciudades-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--ink);border-left:1px solid var(--ink);
}
.ciudad{
  border-right:1px solid var(--ink);border-bottom:1px solid var(--ink);
  padding:0;background:var(--paper);
  display:flex;flex-direction:column;
  position:relative;overflow:hidden;
  min-height:340px;cursor:pointer;
  transition:background .35s;
}
.ciudad:hover{background:var(--ink);color:var(--paper)}
.ciudad-head{padding:28px 28px 16px;display:flex;justify-content:space-between}
.ciudad-num{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  font-weight:500;
}
.ciudad-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--copper);
}
.ciudad:hover .ciudad-tag{color:var(--copper)}
.ciudad-name{
  padding:16px 28px;flex:1;
  display:flex;align-items:flex-end;
}
.ciudad-name h3{
  font-family:var(--display);font-size:80px;
  font-weight:300;line-height:.85;letter-spacing:-3px;
  transition:transform .3s;
}
.ciudad:hover .ciudad-name h3{transform:translateX(8px)}
.ciudad-name h3 em{font-style:italic;color:var(--copper);font-weight:500}
.ciudad-foot{
  padding:20px 28px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;
}
.ciudad:hover .ciudad-foot{border-top-color:rgba(244,237,224,.2)}
.ciudad-foot-arrow{font-size:20px;color:var(--copper);transition:transform .3s}
.ciudad:hover .ciudad-foot-arrow{transform:translateX(8px)}

.ciudad-soon{opacity:.55}
.ciudad-soon:hover{opacity:1}

@media(max-width:1024px){.ciudades-grid{grid-template-columns:repeat(2,1fr)}
  .ciudad{min-height:260px}
  .ciudad-name h3{font-size:60px}
}
@media(max-width:560px){.ciudades-grid{grid-template-columns:1fr}}

/* ============ CITA / TESTIMONIO BLOCK ============ */
.cita{
  padding:120px 32px;background:var(--paper-deep);
  border-bottom:1px solid var(--rule);
}
.cita-inner{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 4fr;gap:48px;
}
.cita-mark{
  font-family:var(--display);font-style:italic;font-weight:300;
  font-size:200px;line-height:.7;color:var(--copper);
}
.cita-body blockquote{
  font-family:var(--display);font-size:clamp(28px,3.5vw,52px);
  font-weight:400;font-style:italic;line-height:1.2;
  letter-spacing:-1px;margin-bottom:32px;
}
.cita-body cite{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;font-style:normal;color:var(--ink-mute);
  display:flex;align-items:center;gap:14px;
}
.cita-body cite::before{
  content:"";width:40px;height:1px;background:var(--copper);
}

@media(max-width:768px){
  .cita-inner{grid-template-columns:1fr;gap:0}
  .cita-mark{font-size:120px;margin-bottom:-30px}
}

/* ============ CTA FINAL ============ */
.cta-final{
  padding:140px 0 80px;text-align:center;
  border-bottom:1px solid var(--rule);
}
.cta-final h2{
  font-family:var(--display);font-size:clamp(56px,9vw,140px);
  font-weight:300;line-height:.92;letter-spacing:-.04em;
  margin-bottom:40px;max-width:1100px;margin-left:auto;margin-right:auto;
}
.cta-final h2 em{font-style:italic;color:var(--copper);font-weight:500}
.cta-final p{
  font-family:var(--display);font-size:20px;font-style:italic;
  color:var(--ink-soft);max-width:520px;margin:0 auto 40px;line-height:1.4;
}

/* ============ FOOTER ============ */
.footer{padding:60px 0 32px;background:var(--paper)}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  padding-bottom:40px;border-bottom:1px solid var(--rule);
  margin-bottom:24px;
}
.footer-brand h3{
  font-family:var(--display);font-size:42px;font-weight:300;
  line-height:1;margin-bottom:16px;letter-spacing:-1px;
}
.footer-brand h3 em{font-style:italic;color:var(--copper);font-weight:500}
.footer-brand p{font-size:13px;color:var(--ink-soft);max-width:300px}
.footer-col h4{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--copper);font-weight:500;margin-bottom:18px;
}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.footer-col a{font-size:13px;color:var(--ink-soft);transition:color .25s}
.footer-col a:hover{color:var(--copper)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-mute);flex-wrap:wrap;gap:14px;
}
.footer-bottom-links{display:flex;gap:24px}

@media(max-width:1024px){.footer-top{grid-template-columns:1fr 1fr;gap:36px}}
@media(max-width:560px){.footer-top{grid-template-columns:1fr}}

/* ============ FX HOVER REVEAL ============ */
.event-card,.ciudad{
  transition:background .35s,color .35s;
}

/* ============ NOTE BANNER ============ */
.note{
  position:fixed;bottom:24px;left:24px;right:24px;
  max-width:520px;
  background:var(--ink);color:var(--paper);
  padding:18px 22px;font-family:var(--mono);font-size:11px;
  letter-spacing:1px;line-height:1.5;z-index:99;
  box-shadow:0 12px 40px rgba(0,0,0,.18);
}
.note strong{color:var(--copper);font-weight:500;letter-spacing:1.5px;text-transform:uppercase;display:block;margin-bottom:6px;font-size:10px}
.note button{
  position:absolute;top:8px;right:8px;
  width:28px;height:28px;color:var(--paper);
  font-size:18px;
}
/* ============ PÁGINA DE CIUDAD ============ */
.hero-city{
  min-height:560px;padding:100px 0 80px;
}
.hero-city .hero-grid{
  grid-template-columns:1fr 6fr 1fr 2fr;
}
.breadcrumb{
  display:flex;align-items:center;gap:10px;
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.55);margin-bottom:24px;
}
.breadcrumb a{color:#e6a363;transition:color .25s}
.breadcrumb a:hover{color:#f4ede0}
.breadcrumb-sep{color:rgba(244,237,224,.3)}
.hero-city h1{font-size:clamp(48px,8vw,120px)}
.hero-city .hero-aside{padding-bottom:24px}

/* Sección genérica para subpáginas */
.section{padding:100px 0;border-bottom:1px solid var(--rule)}
.section-light{background:var(--paper)}
.section-deep{background:var(--paper-deep)}
.section-dark{background:var(--ink);color:var(--paper)}
.section-dark .section-num,.section-dark .section-head-right{color:rgba(244,237,224,.6)}
.section-dark .section-num span{color:#e6a363}
.section-dark .section-title{color:var(--paper)}
.section-dark .section-title em{color:#e6a363}

/* Marcas en ciudad */
.brands-city{
  display:grid;grid-template-columns:repeat(2,1fr);gap:0;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.brand-city{
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:40px 36px;display:flex;flex-direction:column;gap:14px;
  background:var(--paper);transition:all .35s;
  text-decoration:none;color:inherit;
  min-height:300px;position:relative;
}
.brand-city:hover{background:var(--ink);color:var(--paper)}
.brand-city-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--copper);font-weight:500;
}
.brand-city h3{
  font-family:var(--display);font-size:38px;font-weight:400;
  line-height:1.05;letter-spacing:-1px;margin-top:8px;
}
.brand-city h3 em{font-style:italic;color:var(--copper)}
.brand-city p{font-size:14px;line-height:1.6;flex:1;color:var(--ink-soft)}
.brand-city:hover p{color:rgba(244,237,224,.8)}
.brand-city-link{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--copper);
  padding-top:14px;border-top:1px solid var(--rule);
  display:flex;justify-content:space-between;align-items:center;
}
.brand-city:hover .brand-city-link{border-top-color:rgba(244,237,224,.2)}
.brand-city-link span{font-size:18px;transition:transform .3s}
.brand-city:hover .brand-city-link span{transform:translateX(6px)}

@media(max-width:768px){.brands-city{grid-template-columns:1fr}}

/* Actividades — chips brutalistas */
.activities{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:0;
  margin-top:40px;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
}
.activity{
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:28px 24px;background:var(--paper);
  display:flex;align-items:center;gap:16px;
  transition:background .3s;
}
.activity:hover{background:var(--paper-deep)}
.activity-num{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  color:var(--copper);font-weight:500;flex-shrink:0;
}
.activity-name{
  font-family:var(--display);font-size:18px;font-weight:400;
  line-height:1.3;font-style:italic;color:var(--ink);
}

/* Por qué nosotros */
.why-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:32px 64px;margin-top:48px;
}
.why-item{
  display:flex;gap:18px;
  padding-top:24px;border-top:1px solid rgba(244,237,224,.2);
}
.section-dark .why-item{border-top-color:rgba(244,237,224,.2)}
.section-light .why-item{border-top-color:var(--rule)}
.why-num{
  font-family:var(--display);font-size:36px;font-weight:300;font-style:italic;
  color:#e6a363;line-height:1;flex-shrink:0;
}
.why-content h4{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;font-weight:500;
  margin-bottom:10px;color:#f4ede0;
}
.section-light .why-content h4{color:var(--ink)}
.why-content p{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.45;color:rgba(244,237,224,.8);
}
.section-light .why-content p{color:var(--ink-soft)}

@media(max-width:768px){.why-grid{grid-template-columns:1fr;gap:20px}}

/* Próximamente — soon */
.soon-grid{
  display:grid;grid-template-columns:1.4fr 1fr;gap:64px;margin-top:48px;
}
.soon-features{
  list-style:none;display:grid;grid-template-columns:1fr;gap:0;
  border-top:1px solid var(--rule);
}
.soon-features li{
  padding:18px 0;border-bottom:1px solid var(--rule);
  font-family:var(--display);font-size:20px;font-style:italic;
  display:flex;align-items:baseline;gap:14px;
}
.soon-features li::before{
  content:counter(soon-counter,decimal-leading-zero);counter-increment:soon-counter;
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  color:var(--copper);font-style:normal;font-weight:500;
  flex-shrink:0;
}
.soon-features{counter-reset:soon-counter}

.soon-card{
  background:var(--ink);color:var(--paper);
  padding:48px 36px;align-self:start;
  border:1px solid var(--ink);
}
.soon-card-tag{
  display:inline-block;font-family:var(--mono);font-size:10px;
  letter-spacing:2.5px;text-transform:uppercase;font-weight:500;
  color:var(--ink);background:#e6a363;
  padding:6px 14px;margin-bottom:24px;
}
.soon-card h3{
  font-family:var(--display);font-size:36px;font-weight:300;
  line-height:1.1;letter-spacing:-1px;margin-bottom:18px;
}
.soon-card h3 em{font-style:italic;color:#e6a363;font-weight:500}
.soon-card p{
  font-size:14px;color:rgba(244,237,224,.75);line-height:1.6;margin-bottom:28px;
}
.soon-card .btn{width:100%;justify-content:center;margin-bottom:14px;background:#e6a363;color:var(--ink)}
.soon-card .btn:hover{background:#f4ede0}
.soon-card-email{
  display:block;text-align:center;font-family:var(--mono);font-size:11px;
  letter-spacing:1px;color:rgba(244,237,224,.55);
}
.soon-card-email:hover{color:#e6a363}

@media(max-width:1024px){.soon-grid{grid-template-columns:1fr;gap:40px}}
/* =================== AJUSTE TAMAÑOS — versión más sobria =================== */

/* Hero principal */
.hero h1{
  font-size:clamp(40px,6.5vw,96px);
  line-height:.92;
  letter-spacing:-.03em;
}
.hero-lead{font-size:18px}
.hero-aside-num{font-size:60px;letter-spacing:-2px}

/* Hero de páginas de ciudad */
.hero-city h1{font-size:clamp(36px,5.5vw,80px)}
.hero-city{min-height:480px;padding:80px 0 60px}

/* Títulos de sección (h2 capítulos) */
.section-title{
  font-size:clamp(30px,4vw,52px);
  line-height:1.05;
  letter-spacing:-.02em;
}

/* Manifiesto */
.manifesto h2{
  font-size:clamp(34px,5vw,72px);
  line-height:1;
}
.manifesto-stats .stat-num{font-size:48px}

/* CTA final */
.cta-final h2{
  font-size:clamp(40px,6.5vw,88px);
  line-height:.95;
}
.cta-final{padding:100px 0 70px}

/* Cards de eventos / marcas */
.event-card h3{font-size:28px;line-height:1.1}
.brand-city h3{font-size:30px;line-height:1.1}
.brand-city{min-height:260px;padding:32px 28px}
.event-card{min-height:240px;padding:32px 28px}

/* Tarjetas de ciudad legacy (por si las usas) */
.ciudad-name h3{font-size:60px;letter-spacing:-2px}

/* Cita */
.cita{padding:90px 32px}
.cita-mark{font-size:140px}
.cita-body blockquote{
  font-size:clamp(22px,2.8vw,38px);
  letter-spacing:-.5px;
}

/* Marquee */
.marquee-item{font-size:28px}
.marquee{padding:14px 0}

/* Footer */
.footer-brand h3{font-size:34px}

/* Soon card */
.soon-card h3{font-size:28px}
.soon-features li{font-size:17px}

/* Activity name */
.activity-name{font-size:16px}
.activity{padding:22px 20px}

/* Section head — cabeceras de capítulo */
.section-head{padding:60px 0 32px;margin-bottom:48px}
.section{padding:80px 0}

/* Mobile menu — más compacto */
.mobile-menu-body a{font-size:26px;padding:12px 0}

/* Respiro general */
.section-events{padding-bottom:60px}
.manifesto{padding:90px 0}
/* =================== ÍNDICE DE CIUDADES =================== */
.cities-index{
  padding:100px 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:var(--paper);
}
.cities-index-head{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding-bottom:32px;border-bottom:1px solid var(--rule);margin-bottom:8px;
  gap:24px;flex-wrap:wrap;
}
.cities-index-meta{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.cities-index-list{list-style:none;margin:0;padding:0}
.city-row{border-bottom:1px solid var(--rule)}
.city-row:last-child{border-bottom:none}
.city-row a{
  display:grid;
  grid-template-columns:60px 1fr auto auto;
  gap:32px;align-items:baseline;
  padding:28px 0;
  transition:padding .35s ease, color .25s, background .25s;
  text-decoration:none;color:var(--ink);
  position:relative;
}
.city-row a:hover{padding-left:24px;background:var(--paper-deep)}
.city-row-num{
  font-family:var(--mono);font-size:12px;letter-spacing:2px;
  color:var(--ink-mute);font-weight:500;align-self:center;
}
.city-row-name{
  font-family:var(--display);font-size:clamp(40px,5.5vw,68px);
  font-weight:300;line-height:1;letter-spacing:-1.5px;
  transition:color .25s, transform .35s ease;
}
.city-row-name em{font-style:italic;color:var(--ink);font-weight:400}
.city-row a:hover .city-row-name{color:var(--copper)}
.city-row a:hover .city-row-name em{color:var(--copper)}
.city-row-meta{
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
  text-align:right;align-self:center;
}
.city-row-arrow{
  font-family:var(--display);font-size:28px;color:var(--copper);
  align-self:center;width:36px;text-align:right;
  transition:transform .3s ease;
}
.city-row a:hover .city-row-arrow{transform:translateX(8px)}
.city-row-tag{
  font-family:var(--mono);font-size:9px;letter-spacing:2px;
  text-transform:uppercase;color:var(--copper);font-weight:500;
  border:1px solid var(--copper);padding:5px 10px;
  align-self:center;
}

/* Próximamente — más apagado, italic en serif */
.city-row-soon a{color:var(--ink-mute)}
.city-row-soon .city-row-name{font-style:italic;font-weight:300;color:var(--ink-mute)}
.city-row-soon a:hover .city-row-name{color:var(--copper)}

@media(max-width:768px){
  .cities-index{padding:60px 0}
  .cities-index-head{flex-direction:column;align-items:flex-start;gap:14px}
  .city-row a{grid-template-columns:40px 1fr;gap:14px;padding:20px 0}
  .city-row-meta{grid-column:2/3;text-align:left;font-size:10px}
  .city-row-arrow{display:none}
  .city-row-tag{grid-column:2/3;justify-self:start;margin-top:6px}
  .city-row a:hover{padding-left:8px}
}
/* === ÍNDICE CIUDADES — versión más sobria === */
.cities-index{padding:80px 0}
.city-row a{
  grid-template-columns:50px 1fr auto auto;
  gap:24px;padding:20px 0;
}
.city-row-name{
  font-size:clamp(26px,3.2vw,42px);
  letter-spacing:-1px;
}
.city-row-num{font-size:11px}
.city-row-meta{font-size:10px}
.city-row-arrow{font-size:22px;width:30px}
.city-row-tag{font-size:9px;padding:4px 9px}
.city-row a:hover{padding-left:16px}

@media(max-width:768px){
  .city-row a{padding:16px 0;gap:12px}
  .city-row-name{font-size:24px}
}
/* =================== RESERVA / FORMULARIO =================== */
.reserva{
  padding:100px 0;background:var(--paper-deep);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.reserva-grid{
  display:grid;grid-template-columns:1.5fr 1fr;gap:64px;align-items:start;
}

/* Form */
.reserva-form{display:flex;flex-direction:column;gap:24px}
.form-row{display:flex;flex-direction:column;gap:24px}
.form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.form-field{display:flex;flex-direction:column;gap:8px}
.form-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.form-label small{
  font-size:9px;color:var(--copper);text-transform:none;letter-spacing:1px;margin-left:4px;
}

.reserva-form input,
.reserva-form select,
.reserva-form textarea{
  font-family:var(--display);font-size:18px;font-weight:400;
  background:transparent;color:var(--ink);
  border:none;border-bottom:1.5px solid var(--rule);
  padding:14px 0;outline:none;width:100%;
  transition:border-color .25s;
  appearance:none;-webkit-appearance:none;border-radius:0;
}
.reserva-form input::placeholder,
.reserva-form textarea::placeholder{
  color:var(--ink-mute);font-style:italic;font-weight:300;
}
.reserva-form input:focus,
.reserva-form select:focus,
.reserva-form textarea:focus{
  border-bottom-color:var(--copper);
}
.reserva-form select{
  background-image:linear-gradient(45deg,transparent 50%,var(--copper) 50%),
                   linear-gradient(135deg,var(--copper) 50%,transparent 50%);
  background-position:right 8px top 22px,right 4px top 22px;
  background-size:5px 5px,5px 5px;background-repeat:no-repeat;
  cursor:pointer;padding-right:24px;
}
.reserva-form textarea{resize:vertical;min-height:96px;font-family:var(--display)}

.form-check{
  display:flex;align-items:flex-start;gap:12px;
  margin:8px 0 8px;cursor:pointer;
}
.form-check input{
  margin-top:4px;accent-color:var(--copper);
  width:18px;height:18px;flex-shrink:0;
}
.form-check span{
  font-family:var(--sans);font-size:13px;color:var(--ink-soft);line-height:1.5;
}
.form-check a{color:var(--copper);text-decoration:underline;text-underline-offset:3px}

.form-actions{
  display:flex;gap:14px;flex-wrap:wrap;margin-top:20px;
  padding-top:24px;border-top:1px solid var(--rule);
}

/* Aside */
.reserva-aside{
  position:sticky;top:120px;
  background:var(--ink);color:var(--paper);
  padding:48px 36px;
}
.reserva-aside-tag{
  display:inline-block;font-family:var(--mono);font-size:10px;
  letter-spacing:2.5px;text-transform:uppercase;font-weight:500;
  color:var(--ink);background:#e6a363;
  padding:6px 14px;margin-bottom:24px;
}
.reserva-aside-head h3{
  font-family:var(--display);font-size:32px;font-weight:300;
  line-height:1.05;letter-spacing:-1px;margin-bottom:32px;
}
.reserva-aside-head h3 em{font-style:italic;color:#e6a363;font-weight:500}

.reserva-channels{
  list-style:none;display:flex;flex-direction:column;gap:0;
  margin-bottom:32px;padding:0;
}
.reserva-channels li{
  display:flex;gap:18px;align-items:flex-start;
  padding:18px 0;border-top:1px solid rgba(244,237,224,.15);
}
.reserva-channels li:last-child{border-bottom:1px solid rgba(244,237,224,.15)}
.ch-num{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  color:#e6a363;font-weight:500;flex-shrink:0;width:24px;padding-top:3px;
}
.ch-body{display:flex;flex-direction:column;gap:4px}
.ch-label{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(244,237,224,.55);font-weight:500;
}
.ch-body a,.ch-static{
  font-family:var(--display);font-size:18px;font-style:italic;
  color:var(--paper);transition:color .25s;
}
.ch-body a:hover{color:#e6a363}

.reserva-quote{
  font-family:var(--display);font-style:italic;font-size:16px;
  line-height:1.5;color:rgba(244,237,224,.75);
  padding-top:24px;border-top:1px solid rgba(244,237,224,.15);
}

@media(max-width:1024px){
  .reserva-grid{grid-template-columns:1fr;gap:40px}
  .reserva-aside{position:static}
}
@media(max-width:640px){
  .form-row-2{grid-template-columns:1fr}
  .reserva-aside{padding:36px 28px}
  .reserva-aside-head h3{font-size:28px}
}
/* === FIX checkbox RGPD === */
.form-check{
  display:flex;align-items:flex-start;gap:14px;
  margin:8px 0;cursor:pointer;
  padding:14px 16px;border:1px solid var(--rule);
  background:var(--paper);transition:border-color .25s,background .25s;
}
.form-check:hover{border-color:var(--copper);background:var(--paper-deep)}

.reserva-form .form-check input[type="checkbox"]{
  appearance:auto;-webkit-appearance:auto;
  width:18px;height:18px;flex-shrink:0;
  margin:2px 0 0;padding:0;
  border:none;border-bottom:none;
  background:transparent;
  accent-color:var(--copper);
  cursor:pointer;
}
.form-check span{
  font-family:var(--sans);font-size:13px;
  color:var(--ink-soft);line-height:1.55;font-weight:400;
}
.form-check a{
  color:var(--copper);text-decoration:underline;
  text-underline-offset:3px;text-decoration-thickness:1px;
}
.form-check a:hover{text-decoration-thickness:2px}
/* =================== ATELIER · BODAS & COMUNIONES =================== */
.atelier{
  position:relative;
  padding:140px 0 120px;
  background:#0a0907;color:var(--paper);
  overflow:hidden;isolation:isolate;
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.atelier-photo{
  position:absolute;inset:0;z-index:0;
  background-image:url("https://images.unsplash.com/photo-1519225421980-715cb0215aed?auto=format&fit=crop&w=2400&q=85");
  background-size:cover;background-position:center 40%;
  opacity:.32;
  filter:saturate(.7) contrast(1.08);
}
.atelier-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(10,9,7,.4) 0%,rgba(10,9,7,.7) 60%,rgba(10,9,7,.95) 100%),
    radial-gradient(ellipse at 80% 20%,rgba(168,80,30,.18),transparent 55%);
}
.atelier-grid-bg{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(244,237,224,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,237,224,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.6),transparent 80%);
}
.atelier-inner{position:relative;z-index:2}

/* Cabecera */
.atelier-head{
  max-width:780px;margin-bottom:80px;
}
.atelier-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
  margin-bottom:32px;
}
.atelier h2{
  font-family:var(--display);
  font-size:clamp(48px,7vw,108px);
  font-weight:300;line-height:.95;
  letter-spacing:-.04em;margin-bottom:32px;
  color:var(--paper);
}
.atelier h2 em{
  font-style:italic;color:#e6a363;font-weight:400;
  margin:0 .1em;
}
.atelier-italic{font-style:italic;font-weight:400;color:#e6a363}
.atelier-lead{
  font-family:var(--display);font-size:21px;font-style:italic;
  line-height:1.45;color:rgba(244,237,224,.75);
  max-width:560px;font-weight:300;
}

/* Cards 2 columnas */
.atelier-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid rgba(244,237,224,.18);
  margin-bottom:80px;
}
.atelier-card{
  padding:48px 44px;
  border-right:1px solid rgba(244,237,224,.18);
  display:flex;flex-direction:column;gap:18px;
  background:rgba(10,9,7,.4);
  backdrop-filter:blur(6px);
  transition:background .35s;
}
.atelier-card:last-child{border-right:none}
.atelier-card:hover{background:rgba(10,9,7,.65)}

.atelier-card-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
}
.atelier-card h3{
  font-family:var(--display);font-size:42px;font-weight:300;
  line-height:1.05;letter-spacing:-1px;
  color:var(--paper);
}
.atelier-card h3 em{font-style:italic;color:#e6a363;font-weight:400}
.atelier-card-lead{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.5;color:rgba(244,237,224,.7);
}

.atelier-includes{
  list-style:none;padding:0;margin:8px 0 24px;
  display:flex;flex-direction:column;
  border-top:1px solid rgba(244,237,224,.15);
}
.atelier-includes li{
  padding:14px 0;border-bottom:1px solid rgba(244,237,224,.15);
  font-family:var(--display);font-size:16px;font-weight:300;
  color:rgba(244,237,224,.85);
  display:flex;align-items:center;gap:12px;
}
.atelier-includes li::before{
  content:"";width:18px;height:1px;background:#e6a363;flex-shrink:0;
}

.atelier-card-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
  padding:18px 0 0;border-top:1px solid rgba(244,237,224,.15);
  display:flex;justify-content:space-between;align-items:center;
  text-decoration:none;transition:color .25s,padding-left .25s;
  margin-top:auto;
}
.atelier-card-cta span{font-size:18px;transition:transform .3s}
.atelier-card-cta:hover{color:#f4ede0}
.atelier-card-cta:hover span{transform:translateX(8px)}

/* Footer atelier */
.atelier-foot{
  display:grid;grid-template-columns:auto 1fr auto;gap:48px;
  align-items:center;padding-top:48px;
  border-top:1px solid rgba(244,237,224,.18);
}
.atelier-foot-left{display:flex;flex-direction:column;gap:6px}
.atelier-foot-num{
  font-family:var(--display);font-size:64px;font-weight:300;
  font-style:italic;color:#e6a363;line-height:1;letter-spacing:-2px;
}
.atelier-foot-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.55);font-weight:500;
}
.atelier-foot-quote{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.5;color:rgba(244,237,224,.7);
  max-width:480px;
}
.atelier-foot-cta{
  font-family:var(--display);font-size:24px;font-style:italic;
  color:#e6a363;font-weight:400;letter-spacing:-.3px;
  padding:18px 28px;border:1px solid rgba(230,163,99,.5);
  transition:all .3s;text-decoration:none;
  white-space:nowrap;
}
.atelier-foot-cta:hover{
  background:#e6a363;color:#0a0907;border-color:#e6a363;
}

@media(max-width:1024px){
  .atelier-cards{grid-template-columns:1fr}
  .atelier-card{border-right:none;border-bottom:1px solid rgba(244,237,224,.18)}
  .atelier-card:last-child{border-bottom:none}
  .atelier-foot{grid-template-columns:1fr;gap:24px;text-align:center}
  .atelier-foot-quote{max-width:none}
}
@media(max-width:640px){
  .atelier{padding:90px 0 70px}
  .atelier-card{padding:32px 28px}
  .atelier-card h3{font-size:32px}
  .atelier-foot-num{font-size:48px}
}
/* =================== ATELIER · BODAS & COMUNIONES =================== */
.atelier{
  position:relative;
  padding:140px 0 120px;
  background:#0a0907;color:var(--paper);
  overflow:hidden;isolation:isolate;
  border-top:1px solid var(--ink);border-bottom:1px solid var(--ink);
}
.atelier-photo{
  position:absolute;inset:0;z-index:0;
  background-image:url("https://images.unsplash.com/photo-1519225421980-715cb0215aed?auto=format&fit=crop&w=2400&q=85");
  background-size:cover;background-position:center 40%;
  opacity:.32;
  filter:saturate(.7) contrast(1.08);
}
.atelier-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg,rgba(10,9,7,.4) 0%,rgba(10,9,7,.7) 60%,rgba(10,9,7,.95) 100%),
    radial-gradient(ellipse at 80% 20%,rgba(168,80,30,.18),transparent 55%);
}
.atelier-grid-bg{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(244,237,224,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,237,224,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.6),transparent 80%);
}
.atelier-inner{position:relative;z-index:2}

/* Cabecera */
.atelier-head{
  max-width:780px;margin-bottom:80px;
}
.atelier-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
  margin-bottom:32px;
}
.atelier h2{
  font-family:var(--display);
  font-size:clamp(48px,7vw,108px);
  font-weight:300;line-height:.95;
  letter-spacing:-.04em;margin-bottom:32px;
  color:var(--paper);
}
.atelier h2 em{
  font-style:italic;color:#e6a363;font-weight:400;
  margin:0 .1em;
}
.atelier-italic{font-style:italic;font-weight:400;color:#e6a363}
.atelier-lead{
  font-family:var(--display);font-size:21px;font-style:italic;
  line-height:1.45;color:rgba(244,237,224,.75);
  max-width:560px;font-weight:300;
}

/* Cards 2 columnas */
.atelier-cards{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid rgba(244,237,224,.18);
  margin-bottom:80px;
}
.atelier-card{
  padding:48px 44px;
  border-right:1px solid rgba(244,237,224,.18);
  display:flex;flex-direction:column;gap:18px;
  background:rgba(10,9,7,.4);
  backdrop-filter:blur(6px);
  transition:background .35s;
}
.atelier-card:last-child{border-right:none}
.atelier-card:hover{background:rgba(10,9,7,.65)}

.atelier-card-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
}
.atelier-card h3{
  font-family:var(--display);font-size:42px;font-weight:300;
  line-height:1.05;letter-spacing:-1px;
  color:var(--paper);
}
.atelier-card h3 em{font-style:italic;color:#e6a363;font-weight:400}
.atelier-card-lead{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.5;color:rgba(244,237,224,.7);
}

.atelier-includes{
  list-style:none;padding:0;margin:8px 0 24px;
  display:flex;flex-direction:column;
  border-top:1px solid rgba(244,237,224,.15);
}
.atelier-includes li{
  padding:14px 0;border-bottom:1px solid rgba(244,237,224,.15);
  font-family:var(--display);font-size:16px;font-weight:300;
  color:rgba(244,237,224,.85);
  display:flex;align-items:center;gap:12px;
}
.atelier-includes li::before{
  content:"";width:18px;height:1px;background:#e6a363;flex-shrink:0;
}

.atelier-card-cta{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
  padding:18px 0 0;border-top:1px solid rgba(244,237,224,.15);
  display:flex;justify-content:space-between;align-items:center;
  text-decoration:none;transition:color .25s,padding-left .25s;
  margin-top:auto;
}
.atelier-card-cta span{font-size:18px;transition:transform .3s}
.atelier-card-cta:hover{color:#f4ede0}
.atelier-card-cta:hover span{transform:translateX(8px)}

/* Footer atelier */
.atelier-foot{
  display:grid;grid-template-columns:auto 1fr auto;gap:48px;
  align-items:center;padding-top:48px;
  border-top:1px solid rgba(244,237,224,.18);
}
.atelier-foot-left{display:flex;flex-direction:column;gap:6px}
.atelier-foot-num{
  font-family:var(--display);font-size:64px;font-weight:300;
  font-style:italic;color:#e6a363;line-height:1;letter-spacing:-2px;
}
.atelier-foot-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.55);font-weight:500;
}
.atelier-foot-quote{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.5;color:rgba(244,237,224,.7);
  max-width:480px;
}
.atelier-foot-cta{
  font-family:var(--display);font-size:24px;font-style:italic;
  color:#e6a363;font-weight:400;letter-spacing:-.3px;
  padding:18px 28px;border:1px solid rgba(230,163,99,.5);
  transition:all .3s;text-decoration:none;
  white-space:nowrap;
}
.atelier-foot-cta:hover{
  background:#e6a363;color:#0a0907;border-color:#e6a363;
}

@media(max-width:1024px){
  .atelier-cards{grid-template-columns:1fr}
  .atelier-card{border-right:none;border-bottom:1px solid rgba(244,237,224,.18)}
  .atelier-card:last-child{border-bottom:none}
  .atelier-foot{grid-template-columns:1fr;gap:24px;text-align:center}
  .atelier-foot-quote{max-width:none}
}
@media(max-width:640px){
  .atelier{padding:90px 0 70px}
  .atelier-card{padding:32px 28px}
  .atelier-card h3{font-size:32px}
  .atelier-foot-num{font-size:48px}
}
/* === ATELIER · FIX FORZADO TAMAÑOS === */
.atelier{padding:80px 0 60px !important}

.atelier-head{margin-bottom:48px !important}
.atelier h2{
  font-size:clamp(28px,3.6vw,52px) !important;
  line-height:1 !important;
  letter-spacing:-.02em !important;
  margin-bottom:20px !important;
}
.atelier-eyebrow{
  font-size:10px !important;
  letter-spacing:2.5px !important;
  margin-bottom:18px !important;
}
.atelier-lead{
  font-size:15px !important;
  line-height:1.5 !important;
  max-width:480px !important;
}

.atelier-card{padding:28px 24px !important;gap:12px !important}
.atelier-card-tag{
  font-size:9px !important;
  letter-spacing:2px !important;
}
.atelier-card h3{
  font-size:24px !important;
  letter-spacing:-.3px !important;
  line-height:1.1 !important;
}
.atelier-card-lead{
  font-size:13px !important;
  line-height:1.55 !important;
}

.atelier-includes{margin:4px 0 14px !important}
.atelier-includes li{
  font-size:13px !important;
  padding:9px 0 !important;
}
.atelier-includes li::before{width:12px !important}

.atelier-card-cta{
  font-size:10px !important;
  letter-spacing:1.5px !important;
  padding-top:12px !important;
}
.atelier-card-cta span{font-size:14px !important}

.atelier-cards{margin-bottom:40px !important}

.atelier-foot{padding-top:28px !important;gap:24px !important}
.atelier-foot-num{
  font-size:32px !important;
  letter-spacing:-.5px !important;
}
.atelier-foot-label{font-size:9px !important}
.atelier-foot-quote{
  font-size:13px !important;
  line-height:1.5 !important;
  max-width:340px !important;
}
.atelier-foot-cta{
  font-size:15px !important;
  padding:12px 20px !important;
}

@media(max-width:640px){
  .atelier h2{font-size:26px !important}
  .atelier-card h3{font-size:20px !important}
  .atelier-foot-num{font-size:26px !important}
}
/* === ATELIER · ajuste fino, un punto más grande === */
.atelier h2{
  font-size:clamp(38px,4.6vw,72px) !important;
  line-height:1 !important;
}
.atelier-eyebrow{font-size:11px !important;letter-spacing:3px !important}
.atelier-lead{font-size:17px !important}

.atelier-card{padding:32px 28px !important}
.atelier-card h3{font-size:30px !important;letter-spacing:-.5px !important}
.atelier-card-lead{font-size:14px !important}
.atelier-card-tag{font-size:10px !important}

.atelier-includes li{font-size:14px !important;padding:11px 0 !important}
.atelier-card-cta{font-size:11px !important}
.atelier-card-cta span{font-size:16px !important}

.atelier-foot-num{font-size:40px !important}
.atelier-foot-quote{font-size:14px !important;max-width:380px !important}
.atelier-foot-cta{font-size:18px !important;padding:14px 22px !important}
/* =================== DESPEDIDAS DE SOLTERA =================== */
.bride{
  position:relative;
  background:var(--paper);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:100px 0 0;
  overflow:hidden;
}
.bride-grid{
  display:grid;grid-template-columns:1.35fr 1fr;
  gap:80px;align-items:start;
  padding-bottom:90px;
}

/* Contenido izquierda */
.bride-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--copper);font-weight:500;
  margin-bottom:28px;
}
.bride h2{
  font-family:var(--display);
  font-size:clamp(34px,4.4vw,64px);
  font-weight:300;line-height:1;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:24px;
}
.bride h2 em{
  font-style:italic;color:var(--oxblood);font-weight:400;
}
.bride-lead{
  font-family:var(--display);font-size:18px;font-style:italic;
  font-weight:300;line-height:1.55;color:var(--ink-soft);
  max-width:540px;margin-bottom:40px;
}

/* Lista de momentos */
.bride-moments{
  list-style:none;padding:0;margin:0 0 36px;
  border-top:1px solid var(--rule);
}
.bride-moments li{
  display:grid;grid-template-columns:50px 1fr;
  gap:24px;align-items:flex-start;
  padding:22px 0;border-bottom:1px solid var(--rule);
  transition:padding-left .3s ease;
}
.bride-moments li:hover{padding-left:8px}
.bride-num{
  font-family:var(--mono);font-size:11px;letter-spacing:2px;
  color:var(--copper);font-weight:500;padding-top:6px;
}
.bride-moments h4{
  font-family:var(--display);font-size:22px;font-weight:400;
  line-height:1.15;letter-spacing:-.5px;
  color:var(--ink);margin-bottom:6px;
}
.bride-moments p{
  font-size:14px;color:var(--ink-soft);line-height:1.55;
}

/* Acciones */
.bride-actions{
  display:flex;align-items:center;gap:24px;flex-wrap:wrap;
  padding-top:24px;border-top:1px solid var(--rule);
}
.bride-btn-primary{
  font-family:var(--mono);font-size:11px;letter-spacing:1.8px;
  text-transform:uppercase;font-weight:500;
  background:var(--oxblood);color:var(--paper);
  padding:18px 28px;display:inline-flex;align-items:center;gap:12px;
  transition:all .3s;text-decoration:none;
}
.bride-btn-primary:hover{background:var(--ink)}
.bride-btn-primary span{transition:transform .3s}
.bride-btn-primary:hover span{transform:translateX(6px)}
.bride-btn-link{
  font-family:var(--display);font-size:15px;font-style:italic;
  color:var(--ink-soft);text-decoration:none;
  border-bottom:1px solid var(--rule);padding-bottom:2px;
  transition:color .25s,border-color .25s;
}
.bride-btn-link:hover{color:var(--copper);border-bottom-color:var(--copper)}

/* Aside derecha */
.bride-aside{
  position:relative;align-self:stretch;
  display:flex;flex-direction:column;gap:0;
}
.bride-photo{
  width:100%;height:520px;
  background-image:url("https://images.unsplash.com/photo-1530103862676-de8c9debad1d?auto=format&fit=crop&w=1600&q=85");
  background-size:cover;background-position:center;
  filter:saturate(.85) contrast(1.05);
}
.bride-photo-tag{
  background:var(--ink);color:var(--paper);
  padding:24px 28px;display:flex;align-items:baseline;gap:18px;
  border-bottom:1px solid rgba(244,237,224,.15);
}
.bride-photo-num{
  font-family:var(--display);font-size:42px;font-style:italic;
  font-weight:300;color:#e6a363;line-height:1;letter-spacing:-1px;
}
.bride-photo-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.7);font-weight:500;
}
.bride-photo-quote{
  background:var(--ink);color:var(--paper);
  padding:24px 28px 28px;
}
.bride-photo-quote p{
  font-family:var(--display);font-size:17px;font-style:italic;
  line-height:1.45;color:rgba(244,237,224,.85);
  margin-bottom:14px;font-weight:300;
}
.bride-photo-quote cite{
  font-family:var(--mono);font-size:10px;letter-spacing:1.8px;
  text-transform:uppercase;color:#e6a363;font-style:normal;font-weight:500;
}

/* Marquee inferior */
.bride-marquee{
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--paper-deep);
  overflow:hidden;padding:18px 0;
}
.bride-marquee-track{
  display:flex;align-items:center;gap:24px;
  animation:scroll-bride 50s linear infinite;
  white-space:nowrap;
}
.bride-marquee-track span{
  font-family:var(--display);font-size:22px;font-style:italic;
  color:var(--ink);font-weight:300;letter-spacing:-.3px;
}
.bride-marquee-track span:nth-child(2n){
  color:var(--oxblood);font-size:14px;
}
@keyframes scroll-bride{to{transform:translateX(calc(-50% - 12px))}}

@media(max-width:1024px){
  .bride-grid{grid-template-columns:1fr;gap:48px}
  .bride-photo{height:380px}
}
@media(max-width:640px){
  .bride{padding:64px 0 0}
  .bride-grid{padding-bottom:64px;gap:36px}
  .bride h2{font-size:32px}
  .bride-photo{height:280px}
  .bride-actions{flex-direction:column;align-items:flex-start;gap:14px}
  .bride-btn-primary{width:100%;justify-content:center}
  .bride-marquee-track span{font-size:18px}
}
/* =================== NOCHEVIEJA · Ticket de gala =================== */
.nye2{
  position:relative;
  background:#0a0805;color:var(--paper);
  padding:120px 0 0;
  overflow:hidden;isolation:isolate;
  border-top:1px solid var(--ink);
}
.nye2-photo{
  position:absolute;inset:0;z-index:0;
  background-image:url("https://images.unsplash.com/photo-1530541930197-ff16ac917b0e?auto=format&fit=crop&w=2400&q=85");
  background-size:cover;background-position:center 50%;
  opacity:.32;
  filter:saturate(.7) contrast(1.1);
}
.nye2-overlay{
  position:absolute;inset:0;z-index:1;
  background:
    radial-gradient(ellipse at 70% 25%,rgba(212,175,55,.22),transparent 55%),
    linear-gradient(180deg,rgba(10,8,5,.45) 0%,rgba(10,8,5,.7) 50%,rgba(10,8,5,.95) 100%);
}
.nye2-grid-bg{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background-image:
    linear-gradient(rgba(244,237,224,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(244,237,224,.04) 1px,transparent 1px);
  background-size:80px 80px;
  mask-image:linear-gradient(180deg,rgba(0,0,0,.55),transparent 80%);
}
.nye2-grid{
  position:relative;z-index:2;
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:80px;align-items:start;padding-bottom:80px;
}

/* Contenido izquierda */
.nye2-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:#e6a363;font-weight:500;
  margin-bottom:28px;padding:6px 14px;
  border:1px solid rgba(230,163,99,.5);
  background:rgba(212,175,55,.08);
}
.nye2 h2{
  font-family:var(--display);
  font-size:clamp(40px,5.6vw,84px);
  font-weight:300;line-height:.95;letter-spacing:-.025em;
  color:var(--paper);margin-bottom:28px;
}
.nye2 h2 em{
  font-style:italic;color:#e6a363;font-weight:400;
}
.nye2-lead{
  font-family:var(--display);font-size:17px;font-style:italic;
  font-weight:300;line-height:1.55;color:rgba(244,237,224,.78);
  max-width:480px;margin-bottom:36px;
}

/* Lista incluye */
.nye2-includes{
  list-style:none;padding:0;margin:0 0 36px;
  border-top:1px solid rgba(244,237,224,.18);
}
.nye2-includes li{
  display:grid;grid-template-columns:32px 1fr;
  gap:18px;align-items:flex-start;
  padding:18px 0;border-bottom:1px solid rgba(244,237,224,.18);
}
.nye2-check{
  font-family:var(--display);font-size:18px;color:#e6a363;
  line-height:1.4;font-style:normal;
}
.nye2-includes strong{
  display:block;font-family:var(--display);font-size:18px;font-weight:400;
  color:var(--paper);margin-bottom:4px;letter-spacing:-.2px;
}
.nye2-includes span{
  display:block;font-size:13px;color:rgba(244,237,224,.65);
  line-height:1.5;
}

/* Ciudades */
.nye2-cities{
  display:flex;align-items:baseline;gap:12px;flex-wrap:wrap;
  padding-top:24px;border-top:1px solid rgba(244,237,224,.18);
}
.nye2-cities-label{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  text-transform:uppercase;color:rgba(244,237,224,.55);
  font-weight:500;margin-right:8px;
}
.nye2-cities a{
  font-family:var(--display);font-size:24px;font-weight:300;
  color:var(--paper);transition:color .25s;text-decoration:none;
  position:relative;padding-bottom:2px;
}
.nye2-cities a em{font-style:italic;color:var(--paper);font-weight:400}
.nye2-cities a:hover{color:#e6a363}
.nye2-cities a:hover em{color:#e6a363}
.nye2-dot{
  font-family:var(--display);color:rgba(244,237,224,.4);font-size:18px;
}

/* === TICKET DERECHA === */
.nye2-ticket{
  background:var(--paper);color:var(--ink);
  padding:32px 36px 36px;
  position:relative;
  border:1px solid rgba(0,0,0,.1);
  box-shadow:0 30px 80px rgba(0,0,0,.55);
  align-self:start;
}
.nye2-ticket::before,
.nye2-ticket::after{
  content:"";position:absolute;
  width:24px;height:24px;
  background:#0a0805;border-radius:50%;
  top:50%;transform:translateY(-50%);
}
.nye2-ticket::before{left:-12px}
.nye2-ticket::after{right:-12px}

.nye2-ticket-head{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:18px;border-bottom:1px dashed var(--rule);
  margin-bottom:24px;
}
.nye2-ticket-tag{
  font-family:var(--mono);font-size:10px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--ink);background:#e6a363;
  padding:5px 12px;font-weight:500;
}
.nye2-ticket-id{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  color:var(--ink-mute);font-weight:500;
}

.nye2-ticket-date{
  text-align:center;padding:8px 0;
}
.nye2-ticket-day{
  display:block;
  font-family:var(--display);font-size:96px;font-weight:300;
  line-height:.9;color:var(--ink);letter-spacing:-3px;
}
.nye2-ticket-month{
  display:block;font-family:var(--mono);font-size:11px;
  letter-spacing:5px;text-transform:uppercase;
  color:var(--copper);font-weight:600;margin-top:6px;
}
.nye2-ticket-year{
  display:block;font-family:var(--display);font-size:14px;
  font-style:italic;color:var(--ink-mute);margin-top:2px;font-weight:400;
}

.nye2-ticket-arrow{
  text-align:center;font-size:18px;
  color:var(--copper);padding:12px 0;font-weight:300;
}

.nye2-ticket-date.alt .nye2-ticket-day{
  color:var(--copper-deep);font-style:italic;
}

.nye2-ticket-perforation{
  margin:24px -36px;height:1px;
  background-image:repeating-linear-gradient(90deg,var(--rule) 0 6px,transparent 6px 12px);
}

.nye2-ticket-meta{
  display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:24px;
}
.nye2-ticket-meta > div{
  display:flex;flex-direction:column;gap:4px;
}
.nye2-ticket-label{
  font-family:var(--mono);font-size:9px;letter-spacing:1.8px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.nye2-ticket-meta strong{
  font-family:var(--display);font-size:22px;font-weight:400;
  font-style:italic;color:var(--ink);letter-spacing:-.3px;
}

.nye2-ticket-cta{
  display:flex;justify-content:space-between;align-items:center;
  background:var(--ink);color:var(--paper);
  padding:18px 22px;text-decoration:none;
  font-family:var(--mono);font-size:11px;letter-spacing:1.5px;
  text-transform:uppercase;font-weight:500;
  margin-bottom:10px;transition:background .3s;
}
.nye2-ticket-cta:hover{background:var(--copper)}
.nye2-ticket-cta span{font-size:16px;transition:transform .3s}
.nye2-ticket-cta:hover span{transform:translateX(6px)}

.nye2-ticket-link{
  display:block;text-align:center;
  font-family:var(--display);font-size:13px;font-style:italic;
  color:var(--ink-mute);text-decoration:none;transition:color .25s;
}
.nye2-ticket-link:hover{color:var(--copper)}

/* Marquee */
.nye2-marquee{
  position:relative;z-index:2;
  border-top:1px solid rgba(244,237,224,.18);
  border-bottom:1px solid rgba(244,237,224,.18);
  padding:18px 0;overflow:hidden;
  background:rgba(10,8,5,.6);backdrop-filter:blur(4px);
}
.nye2-marquee-track{
  display:flex;align-items:center;gap:32px;
  animation:scroll-nye2 60s linear infinite;
  white-space:nowrap;
}
.nye2-marquee-track span{
  font-family:var(--display);font-size:22px;font-style:italic;
  color:var(--paper);font-weight:300;letter-spacing:-.3px;
}
.nye2-marquee-track .m-dot{
  font-style:normal;color:#e6a363;font-size:14px;
}
@keyframes scroll-nye2{to{transform:translateX(calc(-50% - 16px))}}

@media(max-width:1024px){
  .nye2{padding:80px 0 0}
  .nye2-grid{grid-template-columns:1fr;gap:48px}
  .nye2-ticket{max-width:420px;margin:0 auto}
}
@media(max-width:640px){
  .nye2 h2{font-size:36px}
  .nye2-ticket{padding:28px 28px 32px}
  .nye2-ticket-day{font-size:72px}
  .nye2-cities a{font-size:20px}
  .nye2-marquee-track span{font-size:18px}
}
/* =================== FOTOGRAFÍA · Hoja de contactos =================== */
.photo2{
  position:relative;
  background:var(--paper);
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:100px 0;
}

/* Cabecera */
.photo2-head{
  display:grid;grid-template-columns:1.5fr 1fr;gap:64px;
  padding-bottom:60px;border-bottom:1px solid var(--rule);
  margin-bottom:60px;align-items:start;
}
.photo2-eyebrow{
  display:inline-block;
  font-family:var(--mono);font-size:11px;letter-spacing:3px;
  text-transform:uppercase;color:var(--copper);font-weight:500;
  margin-bottom:24px;
}
.photo2 h2{
  font-family:var(--display);
  font-size:clamp(34px,4.4vw,64px);
  font-weight:300;line-height:1;letter-spacing:-.025em;
  color:var(--ink);margin-bottom:24px;
}
.photo2 h2 em{font-style:italic;color:var(--copper);font-weight:400}
.photo2-lead{
  font-family:var(--display);font-size:17px;font-style:italic;
  font-weight:300;line-height:1.5;color:var(--ink-soft);
  max-width:540px;
}

/* Specs aside */
.photo2-specs{
  background:var(--ink);color:var(--paper);
  padding:28px 32px;border:1px solid var(--ink);
}
.photo2-specs-tag{
  display:inline-block;
  font-family:var(--mono);font-size:9px;letter-spacing:2.5px;
  text-transform:uppercase;color:var(--ink);background:#e6a363;
  padding:5px 11px;font-weight:600;margin-bottom:24px;
}
.photo2-specs dl{
  display:flex;flex-direction:column;gap:0;margin:0;padding:0;
}
.photo2-specs dl > div{
  display:flex;justify-content:space-between;align-items:baseline;
  padding:12px 0;border-bottom:1px dashed rgba(244,237,224,.18);
}
.photo2-specs dl > div:last-child{border-bottom:none;padding-bottom:0}
.photo2-specs dt{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(244,237,224,.55);font-weight:500;
}
.photo2-specs dd{
  font-family:var(--display);font-size:14px;font-style:italic;
  color:var(--paper);font-weight:400;
}

/* Hoja de contactos */
.photo2-sheet{
  background:var(--paper-deep);
  border:1px solid var(--rule);
  padding:24px;margin-bottom:60px;
}
.photo2-sheet-head{
  display:flex;justify-content:space-between;align-items:center;
  padding-bottom:16px;margin-bottom:20px;
  border-bottom:1px dashed var(--rule);
}
.photo2-sheet-id,.photo2-sheet-date,.photo2-sheet-meta{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}

.photo2-frames{
  display:grid;grid-template-columns:repeat(3,1fr);gap:16px;
}
.photo2-frame{
  margin:0;padding:8px;
  background:var(--paper);
  border:1px solid var(--rule);
  position:relative;
  display:flex;flex-direction:column;gap:8px;
  transition:all .35s;
}
.photo2-frame:hover{
  background:var(--ink);border-color:var(--ink);
  transform:translateY(-3px);
  box-shadow:0 18px 40px rgba(0,0,0,.18);
}
.photo2-frame-num{
  font-family:var(--mono);font-size:9px;letter-spacing:1.5px;
  color:var(--ink-mute);font-weight:500;
  display:flex;justify-content:space-between;align-items:center;
}
.photo2-frame:hover .photo2-frame-num{color:rgba(244,237,224,.7)}
.photo2-frame-img{
  aspect-ratio:4/3;width:100%;
  background-size:cover;background-position:center;
  background-color:var(--rule-soft);
  filter:saturate(.85) contrast(1.05);
  transition:filter .35s;
}
.photo2-frame:hover .photo2-frame-img{filter:saturate(1) contrast(1.1)}
.photo2-frame-label{
  font-family:var(--mono);font-size:9px;letter-spacing:1.2px;
  text-transform:uppercase;color:var(--ink-mute);font-weight:500;
}
.photo2-frame:hover .photo2-frame-label{color:#e6a363}

/* Frame seleccionado en cobre (estilo selección rotulador) */
.photo2-frame-mark{
  border-color:var(--copper);
  box-shadow:0 0 0 3px rgba(168,80,30,.12);
}
.photo2-frame-mark .photo2-frame-num{color:var(--copper);font-weight:600}
.photo2-frame-mark .photo2-frame-num::after{
  content:"✦";color:var(--copper);font-size:11px;
}
.photo2-frame-mark .photo2-frame-label{color:var(--copper);font-weight:600}

.photo2-sheet-foot{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:20px;margin-top:20px;
  border-top:1px dashed var(--rule);flex-wrap:wrap;gap:12px;
}
.photo2-sheet-link{
  font-family:var(--mono);font-size:10px;letter-spacing:1.5px;
  text-transform:uppercase;color:var(--copper);font-weight:600;
  text-decoration:none;transition:color .25s;
}
.photo2-sheet-link:hover{color:var(--ink)}

/* 4 servicios */
.photo2-services{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);border-left:1px solid var(--rule);
  margin-bottom:60px;
}
.photo2-service{
  border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
  padding:32px 28px;background:var(--paper);
  display:flex;flex-direction:column;gap:12px;
  transition:background .3s;
}
.photo2-service:hover{background:var(--paper-deep)}
.photo2-service-num{
  font-family:var(--mono);font-size:10px;letter-spacing:2px;
  color:var(--copper);font-weight:500;
}
.photo2-service h3{
  font-family:var(--display);font-size:24px;font-weight:400;
  letter-spacing:-.3px;color:var(--ink);line-height:1.1;
}
.photo2-service p{font-size:13px;color:var(--ink-soft);line-height:1.55}

/* CTA final */
.photo2-cta{
  display:flex;justify-content:space-between;align-items:center;
  gap:48px;padding-top:48px;
  border-top:1px solid var(--rule);flex-wrap:wrap;
}
.photo2-cta-text{
  font-family:var(--display);font-size:18px;font-style:italic;
  color:var(--ink-soft);max-width:520px;line-height:1.5;
}
.photo2-cta-actions{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
}
.photo2-btn-primary{
  font-family:var(--mono);font-size:11px;letter-spacing:1.8px;
  text-transform:uppercase;font-weight:500;
  background:var(--ink);color:var(--paper);
  padding:18px 26px;display:inline-flex;align-items:center;gap:12px;
  text-decoration:none;transition:background .3s;
}
.photo2-btn-primary:hover{background:var(--copper)}
.photo2-btn-primary span{transition:transform .3s}
.photo2-btn-primary:hover span{transform:translateX(6px)}
.photo2-btn-link{
  font-family:var(--display);font-size:14px;font-style:italic;
  color:var(--ink-soft);text-decoration:none;
  border-bottom:1px solid var(--rule);padding-bottom:2px;
  transition:color .25s,border-color .25s;
}
.photo2-btn-link:hover{color:var(--copper);border-bottom-color:var(--copper)}

@media(max-width:1024px){
  .photo2-head{grid-template-columns:1fr;gap:36px}
  .photo2-frames{grid-template-columns:repeat(2,1fr)}
  .photo2-services{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:560px){
  .photo2{padding:64px 0}
  .photo2 h2{font-size:30px}
  .photo2-frames{grid-template-columns:1fr}
  .photo2-services{grid-template-columns:1fr}
  .photo2-cta{flex-direction:column;align-items:flex-start}
}
/* === FIX HERO CIUDAD EN MÓVIL === */
@media(max-width:1024px){
  .hero-city .hero-grid{
    grid-template-columns:1fr !important;
    gap:32px !important;
  }
  .hero-city{
    min-height:auto !important;
    padding:60px 0 60px !important;
  }
  .hero-city .hero-side{display:none !important}
  .hero-city .hero-main{padding:0 !important}
  .hero-city h1{
    font-size:clamp(36px,8vw,56px) !important;
    line-height:.95 !important;
  }
  .hero-city .hero-lead{
    font-size:16px !important;
    line-height:1.55 !important;
    max-width:none !important;
  }
  .hero-city .hero-aside{
    padding:24px !important;
    margin-top:8px !important;
  }
  .hero-city .hero-aside-num{font-size:48px !important}
  .hero-city .hero-aside-meta{font-size:13px !important}
}

@media(max-width:640px){
  .hero-city{padding:48px 0 56px !important}
  .hero-city .breadcrumb{font-size:9px !important;margin-bottom:16px !important}
  .hero-city .hero-tag{font-size:9px !important;margin-bottom:20px !important}
  .hero-city h1{font-size:36px !important;letter-spacing:-1px !important}
  .hero-city .hero-divider{margin:20px 0 !important;width:60px !important}
  .hero-city .hero-lead{font-size:15px !important}
  .hero-city .hero-actions{flex-direction:column !important;gap:10px !important}
  .hero-city .hero-actions a{width:100% !important;justify-content:center !important}
}
/* === FIX SCROLL LATERAL · candado global === */
html, body{
  overflow-x:hidden !important;
  max-width:100% !important;
  width:100% !important;
  position:relative;
}

section, header, footer, main, article, aside{
  overflow-x:clip;
  max-width:100vw;
}

img, video, iframe, svg{
  max-width:100%;
  height:auto;
}

/* Container con padding seguro */
.container{
  max-width:1280px;
  width:100%;
  margin:0 auto;
  padding-left:24px;
  padding-right:24px;
  box-sizing:border-box;
}

/* Hero ciudad — fuerza 1 columna en mobile y evita desbordes */
@media (max-width:1024px){
  body section.hero.hero-city{
    min-height:auto !important;
    padding:60px 0 60px !important;
    overflow-x:clip;
  }
  body section.hero.hero-city .hero-grid{
    display:flex !important;
    flex-direction:column !important;
    grid-template-columns:none !important;
    gap:28px !important;
    padding-left:24px !important;
    padding-right:24px !important;
    box-sizing:border-box;
    width:100%;
    max-width:100%;
  }
  body section.hero.hero-city .hero-side{display:none !important}
  body section.hero.hero-city .hero-main,
  body section.hero.hero-city .hero-aside{
    width:100% !important;max-width:100% !important;padding-left:0;padding-right:0;
  }
  body section.hero.hero-city h1{
    font-size:42px !important;
    line-height:.98 !important;
    letter-spacing:-1px !important;
    word-break:break-word;
    overflow-wrap:break-word;
  }
  body section.hero.hero-city .hero-lead{
    font-size:16px !important;
    line-height:1.55 !important;
    max-width:100% !important;
  }
}

@media (max-width:640px){
  .container{padding-left:18px;padding-right:18px}
  body section.hero.hero-city h1{font-size:34px !important}
  body section.hero.hero-city .hero-actions{
    flex-direction:column !important;gap:10px !important;
  }
  body section.hero.hero-city .hero-actions a{
    width:100% !important;justify-content:center !important;
  }
}
/* === FIX MOBILE PÁGINAS DE CIUDAD · resuelve scroll lateral === */
html, body{
  overflow-x:hidden !important;
  width:100% !important;
  max-width:100vw !important;
}

.container{
  max-width:1280px;
  width:100%;
  margin:0 auto;
  padding-left:24px;
  padding-right:24px;
  box-sizing:border-box;
}

/* Hero ciudad → 1 columna real en mobile/tablet */
@media (max-width:1024px){
  .hero.hero-city{
    min-height:auto !important;
    padding:60px 0 !important;
    overflow-x:clip;
  }
  .hero.hero-city .hero-grid{
    display:flex !important;
    flex-direction:column !important;
    grid-template-columns:none !important;
    gap:28px !important;
    padding:0 24px !important;
    width:100% !important;
    max-width:100% !important;
    box-sizing:border-box;
  }
  .hero.hero-city .hero-side{display:none !important}
  .hero.hero-city .hero-main,
  .hero.hero-city .hero-aside{
    width:100% !important;
    max-width:100% !important;
    padding:0 !important;
    box-sizing:border-box;
  }
  .hero.hero-city .hero-aside{
    padding:24px !important;
    margin-top:0 !important;
  }
  .hero.hero-city h1{
    font-size:clamp(34px,7vw,52px) !important;
    word-break:break-word;
    overflow-wrap:break-word;
  }
  .hero.hero-city .hero-lead{
    font-size:16px !important;
    line-height:1.55 !important;
    max-width:100% !important;
  }
  .hero.hero-city .hero-aside-num{font-size:48px !important}
}

/* Brands ciudad → 1 columna móvil */
@media (max-width:768px){
  .brands-city{grid-template-columns:1fr !important}
  .brand-city{padding:28px 24px !important;min-height:auto !important}
  .brand-city h3{font-size:24px !important}
}

/* Activities → 1 columna en móvil */
@media (max-width:560px){
  .activities{grid-template-columns:1fr !important}
  .activity{padding:18px 16px !important}
  .activity-name{font-size:15px !important}
}

/* Section head → flex column en mobile */
@media (max-width:768px){
  .section-head{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:16px !important;
    padding:48px 0 24px !important;
    margin-bottom:32px !important;
  }
  .section-head-right{
    text-align:left !important;
    max-width:100% !important;
    font-size:15px !important;
  }
  .section-title{
    font-size:clamp(28px,6vw,40px) !important;
  }
}

/* Why grid → 1 col en mobile */
@media (max-width:768px){
  .why-grid{grid-template-columns:1fr !important;gap:20px !important}
  .why-content h4{font-size:11px !important}
  .why-content p{font-size:15px !important}
}

/* CTA final → botones apilados */
@media (max-width:640px){
  .cta-final{padding:72px 0 56px !important}
  .cta-final h2{
    font-size:clamp(32px,8vw,52px) !important;
    word-break:break-word;
    overflow-wrap:break-word;
  }
  .cta-final .hero-actions{
    flex-direction:column !important;
    gap:10px !important;
    align-items:stretch !important;
  }
  .cta-final .hero-actions a{
    width:100% !important;
    justify-content:center !important;
  }
}

/* Footer → grid 2 cols mobile, 1 col móvil pequeño */
@media (max-width:768px){
  .footer-top{grid-template-columns:1fr 1fr !important;gap:32px !important}
}
@media (max-width:480px){
  .footer-top{grid-template-columns:1fr !important}
  .footer-bottom{
    flex-direction:column !important;
    text-align:center;gap:12px;
  }
}

/* Sections con overflow seguro */
section, header, footer{overflow-x:clip}
/* === FIX BRAND CITY · dominio largo móvil === */
@media (max-width:768px){
  .brand-city{
    padding:24px 22px !important;
    min-height:auto !important;
    overflow:hidden;
  }
  .brand-city h3{
    font-size:24px !important;
    line-height:1.1 !important;
    word-break:normal;
  }
  .brand-city p{
    font-size:13px !important;
    line-height:1.55 !important;
  }
  .brand-city-link{
    flex-direction:row;
    flex-wrap:wrap;
    gap:6px 12px;
  }
  .brand-city-link span:first-child{
    font-size:11px !important;
    letter-spacing:1px !important;
    word-break:break-all;
    overflow-wrap:break-word;
    flex:1;
    min-width:0;
  }
  .brand-city-link span:last-child{
    flex-shrink:0;font-size:14px !important;
  }
}

@media (max-width:420px){
  .brand-city-link span:first-child{
    font-size:10px !important;
    letter-spacing:.5px !important;
  }
}