/* ============================================================
   NJEVENTS — estilo OCELOT
   Crema + carbón + naranja · Anton display · jungla/editorial
   Intro cinematográfica · menú partido · scroll horizontal
   ============================================================ */

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
img,picture,video{display:block;max-width:100%;height:auto}
button,input,textarea,select{font:inherit;color:inherit}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}
:focus-visible{outline:2px solid var(--acc);outline-offset:3px}
::selection{background:var(--acc);color:#fff}
::-moz-selection{background:var(--acc);color:#fff}

/* ---------- Tokens ---------- */
:root{
  --cream:#f1ebdd;        /* marfil cálido */
  --cream-2:#f5f0e4;
  --paper:#f7f2e7;
  --dark:#16130d;         /* negro cálido */
  --dark-2:#211d15;
  --acc:#c89b43;          /* dorado champán */
  --acc-2:#a87f2c;
  --wine-acc:#8c2b2f;     /* vino (del logo) para detalles */

  --ink:#16130d;
  --ink-dim:#5c5648;
  --muted:#8c8576;
  --line:#16130d22;       /* divisor suave */
  --line-hard:#16130d;

  /* alias heredados */
  --bg:var(--cream);
  --gold:var(--acc);
  --gold-soft:var(--acc);
  --ember:var(--acc-2);
  --wine:var(--dark);

  --shell:min(94vw,1500px);
  --gutter:clamp(1.1rem,4vw,3.4rem);

  --step--1:clamp(.78rem,.74rem + .2vw,.9rem);
  --step-0:clamp(1rem,.95rem + .28vw,1.18rem);
  --step-1:clamp(1.2rem,1.02rem + .8vw,1.7rem);
  --step-2:clamp(1.7rem,1.1rem + 2.6vw,3.2rem);
  --step-3:clamp(2.4rem,1.2rem + 5.4vw,5.6rem);
  --step-4:clamp(3rem,.4rem + 11.5vw,9.5rem);
  --step-5:clamp(3.6rem,-1.4rem + 23vw,18rem);

  --font-display:"Anton",Impact,system-ui,sans-serif;
  --font-body:"Familjen Grotesk",system-ui,sans-serif;

  --ease:cubic-bezier(.22,1,.36,1);
  --slow:cubic-bezier(.16,1,.3,1);
}

/* ---------- Base ---------- */
body{
  background:var(--cream);
  color:var(--ink);
  font-family:var(--font-body);
  font-size:var(--step-0);
  line-height:1.55;
  font-weight:450;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
body.lock{overflow:hidden}

.display{font-family:var(--font-display);font-weight:400;line-height:.92;letter-spacing:.005em;text-transform:uppercase}
em,.it{font-style:italic}

/* secciones de color */
.sec-dark{background:var(--dark);color:var(--cream)}
.sec-dark .lede,.sec-dark .prose p{color:#cfc9ba}
.sec-dark .prose strong{color:#fff}
.sec-cream{background:var(--cream)}
.sec-paper{background:var(--paper)}

/* ---------- Atmósfera ---------- */
.grain{position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.045;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.8' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.glow{display:none}

/* ---------- Preloader ---------- */
.preloader{position:fixed;inset:0;z-index:9000;background:var(--dark);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:1.2rem;overflow:hidden}
.preloader.done{pointer-events:none}
.pre-count{display:none}
.pre-bar{display:none}
.pre-word{font-family:var(--font-display);font-size:var(--step-2);letter-spacing:.04em;text-transform:uppercase;color:var(--cream)}
.pre-word b{color:var(--acc)}
.no-pre .preloader{display:none}

/* ---------- Cursor ---------- */
.cursor{position:fixed;top:0;left:0;width:8px;height:8px;border-radius:50%;background:var(--acc);z-index:9999;pointer-events:none;transform:translate(-50%,-50%)}
.cursor-ring{position:fixed;top:0;left:0;width:38px;height:38px;border:1.5px solid var(--acc);border-radius:50%;z-index:9998;pointer-events:none;transform:translate(-50%,-50%);transition:width .3s var(--ease),height .3s var(--ease),background .3s,opacity .3s}
.cursor-ring.is-hot{width:66px;height:66px;background:color-mix(in oklab,var(--acc) 14%,transparent)}
@media (hover:none),(pointer:coarse){.cursor,.cursor-ring{display:none}}

/* ---------- Helpers ---------- */
.shell{width:var(--shell);margin-inline:auto;padding-inline:var(--gutter)}
section{position:relative;z-index:2}
.eyebrow{font-family:var(--font-body);font-size:var(--step--1);font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--acc);display:inline-flex;align-items:center;gap:.6em}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--acc)}
.lede{color:var(--ink-dim);font-size:var(--step-1);line-height:1.4;max-width:42ch;font-weight:500}
/* pretítulos (eyebrows) fuera */
.eyebrow{display:none!important}
/* palabras para el iluminado por scroll */
.il-w{display:inline-block;will-change:opacity}

/* ---------- Header ---------- */
.site-head{position:fixed;top:0;left:0;right:0;z-index:120;display:flex;align-items:center;justify-content:space-between;padding:1.1rem var(--gutter);transition:transform .5s var(--ease)}
.site-head.hide{transform:translateY(-130%)}
.brand{display:inline-flex;align-items:baseline;gap:.12rem;font-family:var(--font-display);font-size:1.7rem;letter-spacing:.01em;color:var(--cream);text-transform:uppercase;text-shadow:0 1px 12px rgba(0,0,0,.4);transition:color .4s}
.brand b{color:var(--acc)}
.brand span{display:none}
.site-head.on-light .brand{color:var(--ink);text-shadow:none}
/* Logo NJevents (blanco sobre oscuro · negro+vino sobre claro) */
.brand-logo{height:clamp(26px,3.4vw,34px);width:auto;display:block;filter:brightness(0) invert(1);transition:filter .4s}
.site-head.on-light .brand-logo{filter:none}
.hero-mark img{height:clamp(42px,6vw,66px);width:auto;filter:brightness(0) invert(1)}
.menu-logo{align-self:flex-start;flex:none;height:clamp(40px,5vw,54px);width:auto;max-width:70%;margin-bottom:.4rem}
.foot-logo{height:clamp(46px,6vw,68px);width:auto;filter:brightness(0) invert(1)}
.nav{display:none}
.menu-btn{display:inline-flex;align-items:center;gap:.6em;background:var(--acc);color:var(--ink);font-family:var(--font-body);font-weight:700;font-size:var(--step--1);letter-spacing:.12em;text-transform:uppercase;padding:.72em 1.2em;border:0;border-radius:999px;cursor:pointer;transition:transform .35s var(--ease),background .3s,color .3s}
.menu-btn:hover{background:var(--ink);color:var(--cream);transform:translateY(-2px)}
.menu-btn i{display:flex;flex-direction:column;gap:3px}
.menu-btn i b{width:16px;height:2px;background:currentColor;display:block}
.nav-cta{display:none}
.burger{display:none}

/* ---------- Menú partido (overlay) ---------- */
.menu-overlay{position:fixed;inset:0;z-index:200;display:grid;grid-template-columns:1fr;pointer-events:none;visibility:hidden;transition:visibility 0s linear .75s}
@media(min-width:900px){.menu-overlay{grid-template-columns:1.15fr .85fr}}
.menu-panel{position:relative;overflow:hidden auto;transform:translateY(-100%);transition:transform .7s var(--slow)}
.menu-overlay.open{pointer-events:auto;visibility:visible;transition:visibility 0s}
.menu-overlay.open .menu-panel{transform:translateY(0)}
.menu-left{background:var(--cream);padding:clamp(1.6rem,5vw,4rem);display:flex;flex-direction:column;gap:2rem;transition-delay:.06s}
.menu-right{background:var(--dark);color:var(--cream);padding:clamp(1.6rem,4vw,3.4rem);display:flex;flex-direction:column;justify-content:center}
.menu-social{display:flex;gap:1rem}
.menu-social a{width:40px;height:40px;border:1.5px solid var(--line-hard);border-radius:50%;display:grid;place-items:center;transition:background .3s,color .3s,transform .3s var(--ease)}
.menu-social a:hover{background:var(--acc);border-color:var(--acc);color:#fff;transform:translateY(-3px)}
.menu-links{display:flex;flex-direction:column;margin-top:auto;margin-bottom:auto}
.menu-links a{font-family:var(--font-display);font-size:clamp(2.4rem,8vw,5rem);line-height:1.04;color:var(--ink);text-transform:uppercase;width:max-content;max-width:100%;position:relative;transition:color .3s,transform .4s var(--ease)}
.menu-links a:hover{color:var(--acc);transform:translateX(14px)}
.menu-links a.soon{color:#b3ad9c;pointer-events:none;position:relative}
.menu-links a.soon::after{content:"PRÓXIMAMENTE";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-3deg);font-family:var(--font-body);font-weight:700;font-size:clamp(.8rem,2.4vw,1.4rem);letter-spacing:.1em;color:var(--ink);text-decoration:underline wavy var(--acc);white-space:nowrap}
.menu-foot{display:flex;flex-direction:column;gap:.5rem;font-size:var(--step--1);color:var(--ink-dim);font-weight:500}
.menu-foot a:hover{color:var(--acc)}
.menu-foot .lang a{font-weight:700;color:var(--ink)}
.menu-close{position:absolute;top:1rem;right:1rem;z-index:210;width:54px;height:54px;background:var(--acc);border:0;border-radius:12px;color:var(--ink);cursor:pointer;display:grid;place-items:center;transition:transform .35s var(--ease),background .3s,color .3s;opacity:0}
.menu-close:hover{color:var(--cream)}
.menu-overlay.open .menu-close{opacity:1;transition-delay:.35s}
.menu-close:hover{transform:rotate(90deg);background:var(--ink)}
.menu-close svg{width:22px;height:22px}
.menu-right h3{font-family:var(--font-display);font-size:var(--step-2);text-transform:uppercase;margin-bottom:.6rem}
.menu-right>p{color:#cfc9ba;margin-bottom:1.8rem;max-width:42ch}

/* ---------- Botones ---------- */
.btn{display:inline-flex;align-items:center;gap:.7em;padding:1em 1.7em;border-radius:999px;background:var(--acc);color:var(--ink);font-family:var(--font-body);font-weight:700;font-size:var(--step--1);letter-spacing:.06em;text-transform:uppercase;border:1.5px solid var(--acc);position:relative;overflow:hidden;transition:color .4s,transform .4s var(--ease);will-change:transform}
.btn .dot{width:7px;height:7px;border-radius:50%;background:var(--ink);transition:background .4s}
.btn:hover .dot{background:var(--acc)}
.btn::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .45s var(--ease);z-index:-1}
.btn:hover{color:#fff;transform:translateY(-2px)}
.btn:hover::before{transform:translateY(0)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--line-hard)}
.btn--ghost .dot{background:var(--acc)}
.btn--ghost::before{background:var(--acc)}
.btn--ghost:hover{color:#fff;border-color:var(--acc)}
.sec-dark .btn--ghost{color:var(--cream);border-color:#ffffff44}

.link-arrow{display:inline-flex;align-items:center;gap:.5em;font-family:var(--font-body);font-weight:700;font-size:var(--step--1);letter-spacing:.06em;text-transform:uppercase;color:var(--ink)}
.link-arrow svg{transition:transform .4s var(--ease)}
.link-arrow:hover svg{transform:translate(5px,-5px)}
.link-arrow span{border-bottom:2px solid var(--acc);padding-bottom:.12em}
.sec-dark .link-arrow{color:var(--cream)}

/* ---------- HERO ---------- */
.hero{min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;padding-bottom:clamp(2.2rem,6vh,4.5rem);padding-top:24vh;position:relative;overflow:hidden;background:var(--dark)}
.hero-bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.35);filter:brightness(.62) saturate(1.05);will-change:transform}
.hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,26,23,.5) 0%,rgba(27,26,23,.2) 45%,rgba(27,26,23,.92) 100%)}
.hero-inner{position:relative;z-index:3;color:var(--cream)}
.hero .eyebrow{color:var(--acc)}
.hero h1{font-size:var(--step-5);color:var(--cream);letter-spacing:.005em}
.hero h1 .row{display:block;overflow:hidden}
.hero h1 .row span{display:block}
.hero h1 .o{color:transparent;-webkit-text-stroke:1.4px var(--cream)}
.hero h1 em{font-style:normal;color:var(--acc)}
.hero-foot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:2rem;margin-top:clamp(1.6rem,4vh,2.8rem)}
.hero-foot .lede{max-width:42ch;color:#e7e1d2}
.scroll-cue{display:flex;align-items:center;gap:.6em;font-size:var(--step--1);letter-spacing:.2em;text-transform:uppercase;color:#cfc9ba;font-weight:600}
.scroll-cue i{width:2px;height:46px;background:#ffffff33;display:block;position:relative;overflow:hidden}
.scroll-cue i::after{content:"";position:absolute;top:0;left:0;width:100%;height:42%;background:var(--acc);animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:translateY(-110%)}60%,100%{transform:translateY(260%)}}

/* ---------- HERO centrado (estilo OCELOT) ---------- */
.hero--center{justify-content:center;align-items:center;text-align:center;padding-top:0;padding-bottom:0}
.hero--center .hero-inner{display:flex;flex-direction:column;align-items:center;gap:clamp(1rem,2.4vw,1.8rem);width:min(94vw,1120px);margin-inline:auto;padding-inline:var(--gutter)}
.hero-vign{position:absolute;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(125% 82% at 50% 46%,transparent 26%,rgba(22,17,26,.5) 60%,rgba(22,17,26,.96) 100%)}
.hero--center .hero-bg::after{background:linear-gradient(180deg,rgba(22,17,26,.35),rgba(22,17,26,.45))}
.hero-mark{font-family:var(--font-display);font-size:clamp(1.3rem,2.4vw,1.8rem);text-transform:uppercase;letter-spacing:.03em;color:var(--cream)}
.hero-mark b{color:var(--acc)}
.hero--center h1{font-size:clamp(2.5rem,8.4vw,7.2rem);color:var(--cream);text-align:center}
.hero--center h1 em{font-style:normal;color:var(--acc)}
.hero-tags{font-family:var(--font-body);font-weight:700;font-size:var(--step--1);letter-spacing:.1em;text-transform:uppercase;color:#e7e1d2;max-width:42ch}
.hero--center .scroll-cue{position:absolute;left:50%;bottom:clamp(1.4rem,4vh,2.4rem);transform:translateX(-50%);flex-direction:column;gap:.5em}
.hero--center .scroll-cue i{order:2}

/* ---------- HERO profundidad / fly-through ---------- */
.hero--depth .hero-bg img{will-change:transform}
.depth{position:absolute;inset:0;z-index:2;pointer-events:none;overflow:hidden}
.fg{position:absolute;width:clamp(150px,20vw,330px);aspect-ratio:3/4;border-radius:14px;overflow:hidden;filter:brightness(.96) contrast(1.04);box-shadow:0 30px 70px rgba(0,0,0,.45);will-change:transform,opacity}
.fg img{transition:filter .4s}
.fg img{width:100%;height:100%;object-fit:cover}
.fg--tl{top:-7%;left:-3%}
.fg--tr{top:-9%;right:-3%;width:clamp(140px,17vw,290px)}
.fg--l{top:32%;left:-7%}
.fg--r{top:40%;right:-6%;width:clamp(150px,18vw,310px)}
.fg--bl{bottom:-8%;left:1%}
.fg--br{bottom:-9%;right:-2%}
@media(max-width:899px){.depth{display:none}}

/* ---------- Sección iPhone 3D (spot) ---------- */
.phone-sec{padding-block:clamp(4.5rem,11vh,9rem);overflow:hidden}
.phone-wrap{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,5vw,4.5rem);align-items:center}
@media(min-width:900px){.phone-wrap{grid-template-columns:1.05fr .95fr}}
.phone-copy h2{font-family:var(--font-display);font-size:var(--step-3);text-transform:uppercase;line-height:.95;max-width:14ch}
.phone-copy h2 em{color:var(--acc);font-style:normal}
.phone-copy .lede{margin-top:1.2rem}
.phone-copy .actions{margin-top:2rem;display:flex;flex-wrap:wrap;gap:1rem}
.phone-stage{perspective:1500px;display:flex;justify-content:center}
.iphone{position:relative;width:clamp(238px,27vw,310px);aspect-ratio:9/19.3;transform-style:preserve-3d;will-change:transform;transform:rotateY(-22deg) rotateX(5deg)}
.iphone-frame{position:absolute;inset:0;border-radius:48px;padding:11px;
  background:linear-gradient(145deg,#5a5a5f,#15151a 32%,#34343a 60%,#0c0c0f 100%);
  box-shadow:0 60px 100px rgba(0,0,0,.6),0 10px 30px rgba(0,0,0,.5),inset 0 0 0 2px rgba(255,255,255,.07)}
.iphone-frame::before{content:"";position:absolute;inset:5px;border-radius:43px;box-shadow:inset 0 0 0 2px rgba(0,0,0,.6);pointer-events:none;z-index:4}
.iphone-screen{width:100%;height:100%;object-fit:cover;border-radius:38px;background:#0a0a0c;display:block}
.iphone-island{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:32%;height:25px;background:#000;border-radius:20px;z-index:3;box-shadow:inset 0 0 0 1px #1a1a1a}
.iphone-island::after{content:"";position:absolute;right:9px;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#2b3a4a,#070b10)}
.iphone-glare{position:absolute;inset:11px;border-radius:38px;z-index:2;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,0) 38%,rgba(255,255,255,0) 70%,rgba(255,255,255,.08))}
.iphone-btn{position:absolute;background:#1c1c20;border-radius:3px;z-index:-1}
.iphone-btn.b1{left:-3px;top:22%;width:4px;height:34px}
.iphone-btn.b2{left:-3px;top:33%;width:4px;height:58px}
.iphone-btn.b3{left:-3px;top:45%;width:4px;height:58px}
.iphone-btn.b4{right:-3px;top:30%;width:4px;height:84px}
.phone-play{position:absolute;left:50%;bottom:-26px;transform:translateX(-50%);z-index:5;background:var(--acc);color:var(--ink);border:0;border-radius:999px;padding:.6em 1.2em;font-family:var(--font-body);font-weight:700;font-size:var(--step--1);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;box-shadow:0 12px 30px rgba(0,0,0,.4);display:inline-flex;align-items:center;gap:.5em}
.phone-play:hover{background:#fff}

/* ---------- Deck de servicios (tarjetas que se despliegan) ---------- */
.svc-deck{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,290px),1fr));gap:clamp(.8rem,1.5vw,1.2rem);perspective:1900px}
.svc-card{position:relative;overflow:hidden;border:1.5px solid var(--line-hard);border-radius:18px;background:var(--paper);padding:clamp(1.5rem,3vw,2.3rem);min-height:230px;display:flex;flex-direction:column;justify-content:flex-end;gap:.55rem;isolation:isolate;transform-origin:top center;backface-visibility:hidden;will-change:transform,opacity;transition:transform .4s var(--ease),background .35s,color .35s}
.svc-card:hover{transform:translateY(-6px)}
.svc-card .svc-tag{font-family:var(--font-body);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700;border:1.5px solid var(--line-hard);border-radius:999px;padding:.25em .7em;width:max-content;transition:background .3s,color .3s,border-color .3s}
.svc-card h3{font-family:var(--font-display);font-size:var(--step-1);text-transform:uppercase;line-height:1;color:var(--ink)}
.svc-card p{font-size:var(--step--1);color:var(--ink-dim);font-weight:500;max-width:34ch}
.svc-img{position:absolute;inset:0;z-index:-1;opacity:0;transition:opacity .5s var(--ease),transform 1.1s var(--ease);transform:scale(1.12)}
.svc-img img{width:100%;height:100%;object-fit:cover}
.svc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,19,13,.2),rgba(22,19,13,.85))}
.svc-card:hover .svc-img{opacity:1;transform:scale(1)}
.svc-card:hover h3{color:#fff}.svc-card:hover p{color:#e7e1d2}
.svc-card:hover .svc-tag{background:var(--acc);border-color:var(--acc);color:var(--ink)}

/* ---------- Servicios: pila de cartas que cambian al scroll ---------- */
.svc-stack-sec{background:var(--cream)}
.svc-stack-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.6rem;padding-block:clamp(4rem,9vh,6rem) clamp(1.4rem,4vh,2.4rem)}
.svc-stack-pin{position:relative}
.svc-stack{display:flex;flex-direction:column;gap:clamp(1.8rem,5vh,3.5rem);width:min(92vw,840px);margin-inline:auto;padding-bottom:16vh}
.stack-card{position:sticky;top:clamp(86px,13vh,128px);height:clamp(340px,58vh,500px);border:1.5px solid var(--line-hard);border-radius:24px;overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;background:var(--dark);box-shadow:0 30px 70px rgba(22,19,13,.22)}
.stack-card .sc-img{position:absolute;inset:0;z-index:0}
.stack-card .sc-img img{width:100%;height:100%;object-fit:cover}
.stack-card .sc-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(22,19,13,.1),rgba(22,19,13,.86))}
.stack-card .sc-body{position:relative;z-index:1;padding:clamp(1.8rem,4vw,3rem)}
.stack-card .sc-tag{font-family:var(--font-body);font-weight:700;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--acc)}
.stack-card h3{font-family:var(--font-display);font-size:var(--step-3);text-transform:uppercase;line-height:.95;color:#fff;margin:.4rem 0 .6rem}
.stack-card p{color:#e7e1d2;font-size:var(--step-0);font-weight:500;max-width:48ch}
.svc-progress{display:none}
@media(max-width:899px){
  .svc-stack{gap:1rem;padding-bottom:clamp(3rem,8vh,5rem)}
  .stack-card{position:relative;top:auto;height:clamp(300px,62vh,420px)}
}

/* ---------- Hero end: COMIENZA TU EVENTO ---------- */
.hero-end{position:absolute;inset:0;z-index:6;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;pointer-events:none;text-align:center;padding:var(--gutter)}
.hero-end span{font-family:var(--font-display);font-size:var(--step-4);text-transform:uppercase;color:var(--cream);line-height:.92;text-shadow:0 6px 40px rgba(0,0,0,.6)}
.hero-end em{font-style:normal;color:var(--acc)}

/* ---------- iPhone pin (negro + logo blanco brillante) ---------- */
.phone-sec{background:#000;color:var(--cream);position:relative;padding:0}
.phone-pin{height:100svh;position:relative;overflow:hidden;perspective:1500px}
.phone-logo-bg{position:absolute;inset:0;display:grid;place-items:center;z-index:1;pointer-events:none}
.phone-logo-bg img{width:min(74vw,840px);filter:brightness(0) invert(1) drop-shadow(0 0 55px rgba(255,255,255,.55)) drop-shadow(0 0 130px rgba(255,255,255,.3));opacity:.16}
.phone-copy{position:absolute;left:50%;top:clamp(9%,13vh,17%);transform:translateX(-50%);z-index:3;width:min(92vw,880px);text-align:center;padding:0 var(--gutter)}
.phone-copy h2{font-family:var(--font-display);font-size:var(--step-4);text-transform:uppercase;line-height:.9;color:var(--cream)}
.phone-copy h2 em{color:var(--acc);font-style:normal}
.phone-copy .lede{margin-top:1.1rem;color:#cfc9ba;margin-inline:auto}
.phone-holder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;transform-style:preserve-3d}
.phone-sec .iphone{position:relative;margin:0;will-change:transform}
.phone-play{position:absolute;left:50%;bottom:clamp(1.4rem,4vh,2.6rem);top:auto;transform:translateX(-50%);z-index:6;background:var(--acc);color:var(--ink);box-shadow:0 12px 30px rgba(0,0,0,.5)}
@media(max-width:899px){
  .phone-pin{height:auto;display:flex;flex-direction:column;align-items:center;gap:1.6rem;padding-block:clamp(3.5rem,9vh,6rem)}
  .phone-copy{position:static;transform:none;width:100%;text-align:center;padding:0}
  .phone-holder{position:static;transform:none}
  .phone-holder .iphone{transform:none!important;width:clamp(220px,70vw,280px)}
  .phone-play{position:static;transform:none}
  .phone-logo-bg img{opacity:.08}
}

/* ---------- Logo dentro de la pantalla del móvil (cuando no reproduce) ---------- */
.screen-logo{position:absolute;inset:11px;border-radius:38px;background:#0a0a0c;display:grid;place-items:center;z-index:2;transition:opacity .6s var(--ease)}
.screen-logo img{width:58%;max-width:165px;filter:brightness(0) invert(1) drop-shadow(0 0 16px rgba(255,255,255,.45))}
.iphone.playing .screen-logo{opacity:0;pointer-events:none}
.phone-sec .iphone{cursor:pointer}
@media(max-width:899px){.phone-copy h2{font-size:var(--step-2)}}

/* ---------- Configurador de evento ---------- */
.conf{max-width:900px;margin-inline:auto}
.conf-step{margin-bottom:clamp(2rem,5vw,3.4rem);border-top:2px solid var(--line-hard);padding-top:1.6rem}
.conf-step>h3{font-family:var(--font-display);font-size:var(--step-1);text-transform:uppercase;margin-bottom:1.3rem;display:flex;align-items:baseline;gap:.7rem}
.conf-step>h3 b{color:var(--acc);font-size:.75em}
.opt-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:.7rem}
.opt{position:relative}
.opt input{position:absolute;opacity:0;inset:0;cursor:pointer;margin:0}
.opt span{display:flex;align-items:center;gap:.65em;padding:.95em 1.1em;border:2px solid var(--line-hard);border-radius:12px;font-weight:600;font-size:var(--step--1);text-transform:uppercase;letter-spacing:.03em;transition:background .25s,color .25s,border-color .25s}
.opt span::before{content:"";width:15px;height:15px;border:2px solid var(--ink);border-radius:4px;flex:none;transition:background .2s,border-color .2s}
.opt input[type=radio]+span::before{border-radius:50%}
.opt:hover span{border-color:var(--acc)}
.opt input:checked+span{background:var(--ink);color:var(--cream);border-color:var(--ink)}
.opt input:checked+span::before{background:var(--acc);border-color:var(--acc)}
.opt input:focus-visible+span{outline:2px solid var(--acc);outline-offset:2px}
.conf-row{display:grid;grid-template-columns:1fr;gap:1.3rem}
@media(min-width:620px){.conf-row{grid-template-columns:1fr 1fr}}
.conf-field{margin-bottom:1.3rem}
.conf-field label{display:block;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:.5rem}
.conf-field input,.conf-field textarea{width:100%;background:var(--paper);border:2px solid var(--line-hard);border-radius:12px;padding:.9rem 1rem;color:var(--ink);font-size:var(--step-0);font-weight:500;transition:border-color .25s}
.conf-field input:focus,.conf-field textarea:focus{border-color:var(--acc);outline:none}
.conf-field textarea{min-height:120px;resize:vertical}
.field-miss{border-color:var(--wine-acc)!important}

/* ---------- Marquee ---------- */
.marquee{overflow:hidden;white-space:nowrap;background:var(--acc);color:var(--ink);padding-block:clamp(.7rem,1.7vw,1.2rem)}
.marquee-track{display:inline-flex;gap:1.8rem;will-change:transform}
.marquee-track span{font-family:var(--font-display);font-size:var(--step-2);text-transform:uppercase;display:inline-flex;align-items:center;gap:1.8rem;color:var(--ink);letter-spacing:.01em}
.marquee-track span::after{content:"✳";font-size:.6em}
.marquee-track .o{color:transparent;-webkit-text-stroke:1.5px var(--ink)}

/* ---------- Secciones ---------- */
.section-pad{padding-block:clamp(4.5rem,11vh,9rem)}
.split{display:grid;grid-template-columns:1fr;gap:clamp(2rem,5vw,4.5rem)}
@media(min-width:900px){.split{grid-template-columns:.85fr 1.15fr;align-items:start}}
.section-title{font-family:var(--font-display);font-size:var(--step-3);max-width:18ch;line-height:.95;text-transform:uppercase}
.section-title em{font-style:normal;color:var(--acc)}
.prose p{color:var(--ink-dim);max-width:56ch;margin-bottom:1.1em;font-weight:480}
.prose strong{color:var(--ink);font-weight:700;text-decoration:underline wavy var(--acc);text-underline-offset:4px}

/* ---------- Stats ---------- */
.stats{display:grid;grid-template-columns:repeat(2,1fr);gap:0}
@media(min-width:760px){.stats{grid-template-columns:repeat(4,1fr)}}
.stat{padding:clamp(1.4rem,3.5vw,2.6rem) clamp(1rem,2.5vw,2rem);border-top:2px solid currentColor}
.stat b{display:block;font-family:var(--font-display);font-size:var(--step-4);line-height:.9;color:inherit}
.stat b i{font-style:normal;color:var(--acc)}
.stat p{margin-top:.6rem;font-size:var(--step--1);text-transform:uppercase;letter-spacing:.12em;font-weight:600;opacity:.7}

/* ---------- Servicios (cards) ---------- */
.bento{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.7rem,1.4vw,1.1rem)}
@media(min-width:880px){.bento{grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(195px,auto)}}
.cell{position:relative;overflow:hidden;border:1.5px solid var(--line-hard);border-radius:16px;background:var(--paper);padding:clamp(1.2rem,2.4vw,1.8rem);display:flex;flex-direction:column;justify-content:flex-end;gap:.4rem;min-height:195px;isolation:isolate;transition:transform .5s var(--ease),background .4s}
.cell:hover{transform:translateY(-6px)}
.cell .num{position:absolute;top:1.1rem;left:1.3rem;font-family:var(--font-body);font-weight:700;font-size:var(--step--1);color:var(--acc)}
.cell h3{font-family:var(--font-display);font-size:var(--step-1);text-transform:uppercase;line-height:1;color:var(--ink)}
.cell p{font-size:var(--step--1);color:var(--ink-dim);max-width:32ch;font-weight:500}
.cell .cell-img{position:absolute;inset:0;z-index:-1;opacity:0;transition:opacity .5s var(--ease),transform 1.1s var(--ease);transform:scale(1.12)}
.cell .cell-img img{width:100%;height:100%;object-fit:cover}
.cell .cell-img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(27,26,23,.2),rgba(27,26,23,.85))}
.cell:hover .cell-img{opacity:1;transform:scale(1)}
.cell:hover h3,.cell:hover .num{color:#fff}
.cell:hover p{color:#e7e1d2}
.cell:hover .tag{background:var(--acc);color:#fff;border-color:var(--acc)}
.cell--wide{grid-column:span 2}
.cell--tall{grid-row:span 2}
.cell .tag{font-family:var(--font-body);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink);font-weight:700;border:1.5px solid var(--line-hard);border-radius:999px;padding:.25em .7em;width:max-content;transition:background .3s,color .3s,border-color .3s}

/* ---------- Portfolio horizontal ---------- */
.hscroll{background:var(--dark);color:var(--cream);overflow:hidden}
.hscroll-head{padding:clamp(3.5rem,8vh,6rem) var(--gutter) clamp(1.5rem,4vh,3rem);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:1.4rem;width:var(--shell);margin-inline:auto}
.hscroll-head h2{font-family:var(--font-display);font-size:var(--step-3);text-transform:uppercase;line-height:.95;max-width:16ch}
.hscroll-head h2 em{font-style:normal;color:var(--acc)}
.hscroll-viewport{padding-bottom:clamp(3.5rem,8vh,6rem);overflow-x:auto;scrollbar-width:none}
.hscroll-viewport::-webkit-scrollbar{display:none}
.htrack{display:flex;gap:clamp(1rem,2vw,1.6rem);padding-inline:var(--gutter);will-change:transform}
.hcard{position:relative;flex:0 0 clamp(260px,40vw,460px);aspect-ratio:4/5;border-radius:16px;overflow:hidden;border:1.5px solid #ffffff22}
.hcard img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);filter:saturate(1.05)}
.hcard:hover img{transform:scale(1.06)}
.hcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(27,26,23,.9))}
.hcard .meta{position:absolute;left:1.3rem;bottom:1.3rem;z-index:2}
.hcard .meta b{display:block;font-family:var(--font-display);font-size:var(--step-1);text-transform:uppercase;color:#fff;line-height:1}
.hcard .meta span{font-size:var(--step--1);color:var(--acc);font-weight:700;text-transform:uppercase;letter-spacing:.1em}
.hint{font-size:var(--step--1);color:#cfc9ba;font-weight:600;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:.6em}

/* ---------- Band ---------- */
.band{position:relative;min-height:clamp(58vh,76vh,840px);display:flex;align-items:center;overflow:hidden}
.band-media{position:absolute;inset:-12% 0;z-index:0}
.band-media img{width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(1.05)}
.band::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(27,26,23,.7),rgba(27,26,23,.25));z-index:1}
.band .shell{position:relative;z-index:2}
.band blockquote{font-family:var(--font-display);font-size:var(--step-3);line-height:.98;max-width:20ch;color:var(--cream);text-transform:uppercase}
.band blockquote em{font-style:normal;color:var(--acc)}
.band cite{display:block;margin-top:1.4rem;font-style:normal;font-size:var(--step--1);letter-spacing:.14em;text-transform:uppercase;color:#cfc9ba;font-weight:600}

/* ---------- Gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.7rem,1.3vw,1.1rem)}
@media(min-width:760px){.gal{grid-template-columns:repeat(12,1fr)}}
.shot{position:relative;overflow:hidden;border-radius:14px;background:var(--dark-2);border:1.5px solid var(--line-hard)}
.shot img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease),filter .5s;filter:saturate(1.05)}
.shot:hover img{transform:scale(1.07)}
.shot figcaption{position:absolute;left:.9rem;bottom:.9rem;padding:.4em .8em;font-family:var(--font-body);font-weight:700;font-size:var(--step--1);text-transform:uppercase;letter-spacing:.06em;color:#fff;background:var(--acc);border-radius:999px;transform:translateY(160%);transition:transform .45s var(--ease);z-index:2}
.shot::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(27,26,23,.6));opacity:0;transition:opacity .5s;z-index:1}
.shot:hover figcaption{transform:translateY(0)}
.shot:hover::after{opacity:1}
.gal .c2{grid-column:span 2}.gal .c3{grid-column:span 3}.gal .c4{grid-column:span 4}
.gal .c5{grid-column:span 5}.gal .c6{grid-column:span 6}.gal .c7{grid-column:span 7}.gal .c8{grid-column:span 8}
.gal .r2{aspect-ratio:3/4}.gal .r1{aspect-ratio:4/3}.gal .rw{aspect-ratio:16/9}
@media(max-width:759px){.gal .c2,.gal .c3,.gal .c4,.gal .c5,.gal .c6,.gal .c7,.gal .c8{grid-column:auto}.gal .shot{aspect-ratio:1}}

/* ---------- CTA ---------- */
.cta{position:relative;text-align:center;padding-block:clamp(5rem,14vh,11rem);overflow:hidden;background:var(--dark);color:var(--cream)}
.cta .glow-cta{display:none}
.cta h2{font-family:var(--font-display);font-size:var(--step-4);line-height:.9;max-width:16ch;margin-inline:auto;text-transform:uppercase}
.cta h2 em{font-style:normal;color:var(--acc)}
.cta .eyebrow{justify-content:center}
.cta .actions{margin-top:2.4rem;display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}
.cta .btn--ghost{color:var(--cream);border-color:#ffffff66}
.cta .btn--ghost:hover{color:var(--ink);border-color:var(--acc)}

/* ---------- Footer ---------- */
.site-foot{border-top:0;padding-block:clamp(3rem,7vh,5rem);background:var(--dark);color:var(--cream);position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1fr;gap:2.6rem}
@media(min-width:820px){.foot-grid{grid-template-columns:1.4fr .8fr .8fr}}
.foot-brand{font-family:var(--font-display);font-size:var(--step-3);line-height:.9;text-transform:uppercase}
.foot-brand b{color:var(--acc)}
.foot-col h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--acc);margin-bottom:1rem;font-weight:700}
.foot-col a,.foot-col p{display:block;color:#cfc9ba;margin-bottom:.6rem;transition:color .25s,transform .25s var(--ease);font-size:var(--step-0);font-weight:480}
.foot-col a:hover{color:var(--acc);transform:translateX(5px)}
.site-foot .lede{color:#cfc9ba}
.foot-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid #ffffff1f;display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;font-size:var(--step--1);color:var(--muted)}
.foot-bottom a:hover{color:var(--acc)}

/* ---------- Page hero (interior) ---------- */
.page-hero{padding-top:clamp(8rem,18vh,12rem);padding-bottom:clamp(2.5rem,6vh,4.5rem);background:var(--cream)}
.page-hero h1{font-family:var(--font-display);font-size:var(--step-4);text-transform:uppercase;line-height:.9;color:var(--ink)}
.page-hero h1 em{font-style:normal;color:var(--acc)}
.page-hero .crumb{font-size:var(--step--1);letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:1.4rem;font-weight:700}
.page-hero .crumb a:hover{color:var(--acc)}

/* ---------- Lista servicios ---------- */
.srv-list{border-top:2px solid var(--line-hard)}
.srv-row{display:grid;grid-template-columns:1fr;gap:.5rem;padding-block:clamp(1.6rem,4vw,2.6rem);border-bottom:2px solid var(--line-hard);position:relative;cursor:pointer;transition:padding-left .45s var(--ease),background .3s,color .3s}
@media(min-width:820px){.srv-row{grid-template-columns:.5fr 1.5fr 1fr;align-items:center;gap:2rem}}
.srv-row:hover{padding-left:clamp(0px,2.5vw,2.5rem);background:var(--dark);color:var(--cream)}
.srv-row .s-num{font-weight:700;font-size:var(--step--1);color:var(--acc);letter-spacing:.06em}
.srv-row h3{font-family:var(--font-display);font-size:var(--step-2);text-transform:uppercase;line-height:1;color:inherit}
.srv-row p{color:var(--ink-dim);font-size:var(--step-0);max-width:42ch;font-weight:500}
.srv-row:hover p{color:#cfc9ba}
.srv-hoverimg{position:fixed;width:320px;height:215px;border-radius:14px;overflow:hidden;pointer-events:none;z-index:90;opacity:0;transform:translate(-50%,-50%) scale(.82);transition:opacity .35s,transform .45s var(--ease)}
.srv-hoverimg img{width:100%;height:100%;object-fit:cover}
.srv-hoverimg.show{opacity:1;transform:translate(-50%,-50%) scale(1)}
@media(hover:none){.srv-hoverimg{display:none}}

/* ---------- Valores ---------- */
.values{display:grid;grid-template-columns:1fr;gap:clamp(.7rem,1.4vw,1.1rem)}
@media(min-width:760px){.values{grid-template-columns:repeat(3,1fr)}}
.value{padding:clamp(1.8rem,4vw,2.8rem);display:flex;flex-direction:column;gap:.8rem;border:1.5px solid var(--line-hard);border-radius:16px;background:var(--paper);transition:transform .45s var(--ease),background .4s,color .4s}
.value:hover{transform:translateY(-6px);background:var(--dark);color:var(--cream)}
.value:hover p{color:#cfc9ba}
.value .v-i{font-family:var(--font-display);font-size:var(--step-3);color:var(--acc);line-height:1}
.value h3{font-size:var(--step-1);font-family:var(--font-display);text-transform:uppercase}
.value p{color:var(--ink-dim);font-size:var(--step-0);font-weight:500}

/* ---------- Contacto ---------- */
.contact-grid{display:grid;grid-template-columns:1fr;gap:clamp(2.5rem,6vw,5rem)}
@media(min-width:920px){.contact-grid{grid-template-columns:1fr 1fr}}
.field{position:relative;margin-bottom:1.6rem}
.field input,.field textarea{width:100%;background:transparent;border:0;border-bottom:2px solid var(--line-hard);padding:.9rem 0;color:var(--ink);font-size:var(--step-1);font-weight:500;transition:border-color .4s}
.field textarea{resize:vertical;min-height:120px}
.field label{position:absolute;left:0;top:.9rem;color:var(--muted);pointer-events:none;font-weight:600;transition:transform .32s var(--ease),color .32s,font-size .32s}
.field input:focus,.field textarea:focus{border-color:var(--acc)}
.field input:focus+label,.field textarea:focus+label,
.field input:not(:placeholder-shown)+label,.field textarea:not(:placeholder-shown)+label{transform:translateY(-2rem);font-size:var(--step--1);color:var(--acc);letter-spacing:.08em;text-transform:uppercase}
.contact-info .ci-row{padding-block:1.3rem;border-bottom:2px solid var(--line-hard)}
.contact-info .ci-row span{display:block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.4rem;font-weight:700}
.contact-info .ci-row a,.contact-info .ci-row p{font-family:var(--font-display);font-size:var(--step-2);text-transform:uppercase;color:var(--ink);transition:color .25s}
.contact-info .ci-row a:hover{color:var(--acc)}
.form-note{font-size:var(--step--1);color:var(--muted);margin-top:1rem}

/* menú: formulario dentro del overlay */
.menu-right .field input,.menu-right .field textarea{color:var(--cream);border-bottom-color:#ffffff33}
.menu-right .field label{color:#a9a293}
.menu-right .field input:focus,.menu-right .field textarea:focus{border-color:var(--acc)}

/* ---------- Responsive ---------- */
@media(max-width:899px){
  .menu-left{min-height:62vh}
  .menu-right{min-height:38vh}
}

/* ---------- Reduced motion ---------- */
@media (prefers-reduced-motion:reduce){
  .marquee-track{animation:none}
}


/* ---------- v1.2.1 · Ajuste fino móvil: subir un poco la sección del spot ---------- */
@media(max-width:899px){
  .phone-sec{margin-top:-1.25rem}
  .phone-pin{padding-top:clamp(1.8rem,5vh,2.8rem);padding-bottom:clamp(3rem,8vh,5rem);gap:1.2rem}
}
@media(max-width:480px){
  .phone-sec{margin-top:-1.6rem}
  .phone-pin{padding-top:1.4rem;padding-bottom:3.5rem;gap:1rem}
}
