/* ════════════════════════════════════════════
   i+DENT by AIVORIQ — style.css
   Aesthetic: luxury clinic · Ivory dominant
   Ultra-thin type · horizontal lines · refined
   ════════════════════════════════════════════ */

/* ── ANTIQUE LEGACY ── */
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Thin/AntiqueLegacy-Thin.woff2')format('woff2'),url('../fonts/Antique-Legacy-Thin/AntiqueLegacy-Thin.woff')format('woff');font-weight:100;font-style:normal;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Light/AntiqueLegacy-Light.woff2')format('woff2'),url('../fonts/Antique-Legacy-Light/AntiqueLegacy-Light.woff')format('woff');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Light-Italic/AntiqueLegacy-LightItalic.woff2')format('woff2'),url('../fonts/Antique-Legacy-Light-Italic/AntiqueLegacy-LightItalic.woff')format('woff');font-weight:300;font-style:italic;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Book/AntiqueLegacy-Book.woff2')format('woff2'),url('../fonts/Antique-Legacy-Book/AntiqueLegacy-Book.woff')format('woff');font-weight:350;font-style:normal;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Regular/AntiqueLegacy-Regular.woff2')format('woff2'),url('../fonts/Antique-Legacy-Regular/AntiqueLegacy-Regular.woff')format('woff');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Italic/AntiqueLegacy-Italic.woff2')format('woff2'),url('../fonts/Antique-Legacy-Italic/AntiqueLegacy-Italic.woff')format('woff');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Medium/AntiqueLegacy-Medium.woff2')format('woff2'),url('../fonts/Antique-Legacy-Medium/AntiqueLegacy-Medium.woff')format('woff');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Antique Legacy';src:url('../fonts/Antique-Legacy-Bold/AntiqueLegacy-Bold.woff2')format('woff2'),url('../fonts/Antique-Legacy-Bold/AntiqueLegacy-Bold.woff')format('woff');font-weight:700;font-style:normal;font-display:swap}

/* ── THEINHARDT MONO ── */
@font-face{font-family:'Theinhardt Mono';src:url('../fonts/Theinhardt-Mono-Regular/TheinhardtMono-Regular.woff2')format('woff2'),url('../fonts/Theinhardt-Mono-Regular/TheinhardtMono-Regular.woff')format('woff');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Theinhardt Mono';src:url('../fonts/Theinhardt-Mono-Light/TheinhardtMono-Light.woff2')format('woff2'),url('../fonts/Theinhardt-Mono-Light/TheinhardtMono-Light.woff')format('woff');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Theinhardt Mono';src:url('../fonts/Theinhardt-Mono-Medium/TheinhardtMono-Medium.woff2')format('woff2'),url('../fonts/Theinhardt-Mono-Medium/TheinhardtMono-Medium.woff')format('woff');font-weight:500;font-style:normal;font-display:swap}

/* ════════════════════════════════════════════
   VARIABLES
   ════════════════════════════════════════════ */
:root{
  --at:#C16950;    /* Atelier */
  --iv:#FCF9EE;    /* Ivory */
  --mn:#757A82;    /* Mineral */
  --lq:#E5E3DD;    /* Liquid */
  --bk:#000000;    /* Black */
  --dk:#0A0A0A;    /* Near black */
  --f:'Antique Legacy',Arial,sans-serif;
  --m:'Theinhardt Mono','Courier New',monospace;
  --ease:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.16,1,.3,1);
}

/* ════════════════════════════════════════════
   RESET
   ════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--f);
  background:var(--iv);
  color:var(--bk);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%}
a{text-decoration:none;color:inherit}
video{display:block;width:100%}

/* ════════════════════════════════════════════
   NAV — ultra minimal, ivory background
   Diferencia: fondo claro, línea inferior fina,
   sin blur. El logo es el símbolo + wordmark
   ════════════════════════════════════════════ */
.nav{
  position:fixed;
  top:0;left:0;right:0;
  z-index:300;
  height:64px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 48px;
  background:var(--iv);
  border-bottom:0.5px solid rgba(0,0,0,.1);
  transition:background .3s,border-color .3s;
}

.nav.nav--dark{
  background:var(--dk);
  border-color:rgba(255,255,255,.06);
}

.nav-logo{
  display:flex;
  align-items:center;
  gap:9px;
}
.nav-logo-img{
  height:64px;
  width:auto;
  display:block;
  transition:filter .3s;
}
.nav--dark .nav-logo-img{
  filter:brightness(0) invert(1);
}
.footer-logo-img{
  height:57px;
  width:auto;
  display:block;
  margin-bottom:16px;
  filter:brightness(0) invert(1);
}

.nav-mark{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:3px;
}
.nav-mark span{
  display:block;
  width:6px;height:6px;
  background:var(--at);
}

.nav-logotype{
  font-family:var(--f);
  font-weight:300;
  font-size:18px;
  letter-spacing:3px;
  color:var(--bk);
  text-transform:uppercase;
  transition:color .3s;
}

.nav--dark .nav-logotype{color:var(--iv)}

.nav-logotype sub{
  font-size:10px;
  font-family:var(--m);
  letter-spacing:1px;
  color:var(--at);
  vertical-align:super;
  font-weight:400;
}

.nav-links{
  display:flex;
  align-items:center;
  gap:40px;
  list-style:none;
}

.nav-links a{
  font-family:var(--f);
  font-weight:300;
  font-size:13px;
  letter-spacing:1px;
  color:rgba(0,0,0,.5);
  transition:color .2s;
  position:relative;
}

.nav--dark .nav-links a{color:rgba(255,255,255,.4)}
.nav-links a:hover,.nav-links a.active{color:var(--bk)}
.nav--dark .nav-links a:hover,.nav--dark .nav-links a.active{color:var(--iv)}

/* línea hover */
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:-2px;left:0;right:0;
  height:0.5px;
  background:var(--at);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .3s var(--spring);
}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}

.nav-cta{
  font-family:var(--m)!important;
  font-size:10px!important;
  letter-spacing:1.5px!important;
  text-transform:uppercase!important;
  color:var(--iv)!important;
  background:var(--bk);
  padding:10px 20px;
  transition:background .2s!important;
  white-space:nowrap;
}
.nav-cta:hover{background:var(--at)!important}
.nav-cta::after{display:none!important}

.nav--dark .nav-cta{background:var(--at);color:var(--bk)!important}

.nav-burger{
  display:none;
  flex-direction:column;
  gap:5px;
  cursor:pointer;
  background:none;border:none;padding:4px;
}
.nav-burger span{
  display:block;width:20px;height:0.5px;
  background:var(--bk);
  transition:.3s;
}
.nav--dark .nav-burger span{background:var(--iv)}

/* ════════════════════════════════════════════
   HERO — Pantalla completa, vídeo de fondo
   Nuevo: texto muy fino (weight 100), video
   en loop como fondo con overlay Ivory suave.
   ════════════════════════════════════════════ */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;
  flex-direction:column;
  justify-content:center;
  overflow:hidden;
  padding-top:64px;
  background:var(--dk);
}

/* Imagen/vídeo de fondo */
.hero-media{
  position:absolute;
  inset:0;
  object-fit:cover;
  width:100%;height:100%;
  opacity:.45;
}

/* Degradado sobre el fondo */
.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.92) 0%,rgba(10,10,10,.3) 60%,transparent 100%);
  z-index:1;
}

.hero-slides{
  position:absolute;
  inset:0;
  z-index:0;
}
.hero-slide{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:0;
  transition:opacity 1.5s ease;
}
.hero-slide.active{
  opacity:.45;
}

.hero-body{
  position:relative;
  z-index:2;
  padding:72px 64px 80px;
  display:flex;
  flex-direction:column;
  align-items:center;
  text-align:center;
  gap:32px;
  width:100%;
}

.hero-eyebrow{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--at);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
}
.hero-eyebrow::before,
.hero-eyebrow::after{
  content:'';display:block;
  width:32px;height:0.5px;
  background:var(--at);
}

.hero-title{
  font-size:clamp(22px,3.6vw,46px);
  font-weight:100;
  color:var(--iv);
  line-height:1.1;
  letter-spacing:-2px;
  max-width:900px;
  min-height:1.2em;
}

.hero-cursor{
  display:inline-block;
  width:3px;
  height:.8em;
  background:var(--at);
  margin-left:4px;
  vertical-align:middle;
  animation:blink 1s step-end infinite;
}

@keyframes blink{
  0%,100%{opacity:1}
  50%{opacity:0}
}

.hero-btns{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  justify-content:center;
}

/* ════════════════════════════════════════════
   TIPO GLOBAL
   ════════════════════════════════════════════ */
h1,h2,h3,h4{font-family:var(--f);font-weight:300;line-height:1.15}

/* TAG / EYEBROW (reemplaza overline) */
.tag{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:12px;
  margin-bottom:20px;
}
.tag::before{
  content:'';display:block;
  width:24px;height:0.5px;
  background:currentColor;
}
.tag--at{color:var(--at)}
.tag--iv{color:rgba(252,249,238,.4)}
.tag--dk{color:rgba(0,0,0,.35)}

/* DIVISOR horizontal fino */
.hr{
  border:none;
  border-top:0.5px solid rgba(0,0,0,.1);
  margin:0;
}
.hr--light{border-color:rgba(255,255,255,.07)}

/* ════════════════════════════════════════════
   BOTONES — estilo diferente: sin fondo
   sólo borde + texto fino
   ════════════════════════════════════════════ */
.btn{
  display:inline-flex;
  align-items:center;
  gap:14px;
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  padding:13px 28px;
  border:0.5px solid currentColor;
  cursor:pointer;
  background:transparent;
  transition:all .25s var(--ease);
}

.btn-dot{
  display:block;
  width:5px;height:5px;
  border-radius:50%;
  background:currentColor;
  flex-shrink:0;
  transition:transform .25s var(--spring);
}
.btn:hover .btn-dot{transform:scale(1.8)}

.btn--bk{color:var(--bk);border-color:rgba(0,0,0,.25)}
.btn--bk:hover{background:var(--bk);color:var(--iv)}
.btn--iv{color:var(--iv);border-color:rgba(252,249,238,.25)}
.btn--iv:hover{background:var(--iv);color:var(--bk)}
.btn--at{color:var(--bk);background:var(--at);border-color:var(--at)}
.btn--at:hover{background:transparent;color:var(--at)}
.btn--at-o{color:var(--at);border-color:rgba(193,105,80,.35)}
.btn--at-o:hover{background:var(--at);color:var(--bk)}

/* ════════════════════════════════════════════
   LAYOUT
   ════════════════════════════════════════════ */
.w{max-width:1280px;margin:0 auto;padding:0 64px}
.w--sm{max-width:960px}
.sec{position:relative}
.sec--iv{background:var(--iv)}
.sec--gr{background:#FFFFFF}
.sec--bk{background:var(--dk)}
.sec--at{background:var(--at)}
.sec--mn{background:var(--mn)}
.sec--lq{background:var(--lq)}

.pad{padding:96px 0}
.pad-sm{padding:64px 0}
.pad-lg{padding:128px 0}

/* MARCA 4 puntos */
.mark{display:grid;grid-template-columns:1fr 1fr;gap:3px;flex-shrink:0}
.mark span{display:block;width:5px;height:5px}
.mark--at span{background:var(--at)}
.mark--iv span{background:var(--iv)}
.mark--bk span{background:var(--bk)}

/* ════════════════════════════════════════════
   SECCIÓN FLUJO DIGITAL (home sección 1)
   Grid 60/40 con vídeo a la derecha
   ════════════════════════════════════════════ */
.digital-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
}

.digital-content{
  padding:96px 64px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.digital-title{
  font-size:clamp(28px,3.5vw,48px);
  font-weight:100;
  color:var(--bk);
  line-height:1.12;
  letter-spacing:-.5px;
  margin-bottom:24px;
}

.digital-title strong{font-weight:300;color:var(--at)}

.digital-body{
  font-size:15px;
  font-weight:300;
  color:rgba(0,0,0,.55);
  line-height:1.85;
  margin-bottom:36px;
}

/* Vídeo / media */
.media-block{
  position:relative;
  overflow:hidden;
  background:var(--dk);
}

/* Para poner vídeo: <video src="..." autoplay muted loop playsinline class="media-fill"> */
.media-fill{
  position:absolute;
  inset:0;
  width:100%;height:100%;
  object-fit:cover;
}

.media-ph{
  width:100%;height:100%;min-height:480px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:var(--dk);
}

.media-ph-text{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  color:rgba(252,249,238,.2);
  text-transform:uppercase;
}

/* Play overlay */
.play-overlay{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:3;
  cursor:pointer;
  transition:background .2s;
}
.play-overlay:hover{background:rgba(0,0,0,.1)}

.play-btn{
  width:64px;height:64px;
  border:0.5px solid rgba(252,249,238,.4);
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:all .2s;
}
.play-overlay:hover .play-btn{
  background:var(--at);
  border-color:var(--at);
}
.play-btn svg{
  width:18px;height:18px;
  fill:var(--iv);
  margin-left:3px;
}

/* ════════════════════════════════════════════
   SECCIÓN SOLUCIONES MONOLÍTICAS
   Fondo oscuro · vídeo izquierda · texto derecha
   ════════════════════════════════════════════ */
.mono-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:560px;
}

.mono-media{
  position:relative;
  overflow:hidden;
  background:var(--bk);
}

.mono-content{
  padding:80px 64px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:var(--dk);
}

.mono-title{
  font-size:clamp(26px,3vw,42px);
  font-weight:100;
  color:var(--iv);
  line-height:1.1;
  margin-bottom:20px;
}

.mono-title strong{color:var(--at);font-weight:300}

.mono-body{
  font-size:15px;
  font-weight:300;
  color:rgba(252,249,238,.5);
  line-height:1.85;
  margin-bottom:32px;
}

.blender-link{
  display:inline-flex;
  align-items:center;
  gap:10px;
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--at);
  transition:gap .2s;
  margin-bottom:36px;
}
.blender-link::after{content:'→'}
.blender-link:hover{gap:18px}

/* ════════════════════════════════════════════
   MATERIALES — layout tabla/lista elegante
   ════════════════════════════════════════════ */
.materials-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  align-items:stretch;
}

.materials-left{
  padding:96px 64px;
  border-right:0.5px solid rgba(0,0,0,.08);
}

.materials-right{
  padding:0;
  overflow:hidden;
}

.materials-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.materials-img-ph{
  width:100%;
  height:100%;
  min-height:400px;
  background:var(--lq);
  display:flex;
  align-items:center;
  justify-content:center;
}

.material-list{
  list-style:none;
  border-top:0.5px solid rgba(0,0,0,.08);
  margin-bottom:32px;
}

.material-list li{
  padding:14px 0;
  border-bottom:0.5px solid rgba(0,0,0,.08);
  font-size:14px;
  font-weight:300;
  color:rgba(0,0,0,.7);
  display:flex;
  align-items:center;
  gap:12px;
  transition:color .2s,padding-left .2s;
}

.material-list li::before{
  content:'';display:block;
  width:4px;height:4px;
  border-radius:50%;
  background:var(--at);
  flex-shrink:0;
}

.material-list li:hover{color:var(--bk);padding-left:8px}

.treatments-list{
  list-style:none;
}

.treatments-list li{
  padding:12px 0;
  border-bottom:0.5px solid rgba(0,0,0,.06);
  font-size:13px;
  font-weight:300;
  color:rgba(0,0,0,.6);
  line-height:1.6;
  position:relative;
  padding-left:16px;
}

.treatments-list li::before{
  content:'·';
  position:absolute;
  left:0;
  color:var(--at);
  font-size:18px;
  line-height:1.3;
}

/* ════════════════════════════════════════════
   PLATAFORMAS — imagen + texto lado a lado
   ════════════════════════════════════════════ */
.plataformas-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  min-height:480px;
}

.plataformas-img{
  position:relative;
  overflow:hidden;
}

.plataformas-img img{
  width:100%;height:100%;
  object-fit:cover;
  display:block;
}

.plataformas-img-ph{
  width:100%;height:100%;
  min-height:480px;
  background:var(--lq);
  display:flex;
  align-items:center;
  justify-content:center;
}

.plataformas-content{
  padding:80px 64px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:var(--iv);
}

.plataformas-title{
  font-size:clamp(22px,2.5vw,34px);
  font-weight:100;
  line-height:1.2;
  letter-spacing:-.3px;
  margin-bottom:20px;
}

.plataformas-title em{font-style:italic;color:var(--at);font-weight:300}

.platform-chips{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  margin:24px 0;
}

.chip{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  padding:7px 14px;
  border:0.5px solid rgba(0,0,0,.15);
  color:rgba(0,0,0,.5);
  transition:all .2s;
}

.chip:hover{border-color:var(--at);color:var(--at)}

/* ════════════════════════════════════════════
   IMPRESIÓN DIGITAL — full width con vídeo
   ════════════════════════════════════════════ */
.digital3d-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:520px;
}

.digital3d-media{
  position:relative;
  overflow:hidden;
  background:var(--bk);
  order:2;
}

.digital3d-content{
  padding:80px 64px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  background:var(--iv);
  order:1;
}

/* ════════════════════════════════════════════
   TIEMPOS DE ENTREGA
   Diferente: franja ancha con imagen de fondo
   ════════════════════════════════════════════ */
.tiempos-block{
  position:relative;
  overflow:hidden;
  min-height:480px;
  display:flex;
  align-items:center;
}

.tiempos-bg{
  position:absolute;
  inset:0;
  object-fit:cover;
  width:100%;height:100%;
  opacity:.2;
}

.tiempos-bg-ph{
  position:absolute;
  inset:0;
  background:var(--dk);
}

.tiempos-block::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(10,10,10,.95) 40%,rgba(10,10,10,.5) 100%);
  z-index:1;
}

.tiempos-inner{
  position:relative;
  z-index:2;
  padding:0 64px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:center;
  width:100%;
}

.tiempos-title{
  font-size:clamp(28px,3.5vw,48px);
  font-weight:100;
  color:var(--iv);
  line-height:1.1;
  margin-bottom:16px;
}

.tiempos-num{
  font-size:clamp(64px,8vw,120px);
  font-weight:100;
  color:var(--at);
  line-height:.9;
  letter-spacing:-3px;
  display:block;
}

.tiempos-unit{
  font-family:var(--m);
  font-size:14px;
  letter-spacing:3px;
  color:rgba(252,249,238,.4);
  text-transform:uppercase;
  display:block;
  margin-top:8px;
}

/* ════════════════════════════════════════════
   VENTAJAS — tabla horizontal con 5 celdas
   ════════════════════════════════════════════ */
.ventajas-row{
  display:grid;
  grid-template-columns:repeat(5,1fr);
}

.ventaja-cell{
  padding:48px 40px;
  margin:0 8px;
  border-radius:8px;
  position:relative;
  transition:background .25s, box-shadow .25s;
  background:#fff;
  box-shadow:0 2px 16px rgba(0,0,0,.07);
}

.ventaja-cell:last-child{border-right:none}
.ventaja-cell:hover{background:rgba(193,105,80,.05)}

.ventaja-icon{
  width:40px;height:40px;
  margin-bottom:20px;
  object-fit:contain;
  opacity:.7;
  filter:none;
}

/* Placeholder icono si no hay imagen */
.ventaja-icon-ph{
  width:40px;height:40px;
  border:0.5px solid rgba(193,105,80,.4);
  display:flex;
  align-items:center;
  justify-content:center;
  margin-bottom:20px;
}

.ventaja-icon-ph::after{
  content:'';
  display:block;
  width:16px;height:16px;
  background:var(--at);
  clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%);
}

.ventaja-num{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:2px;
  color:var(--at);
  margin-bottom:12px;
  display:block;
}

.ventaja-title{
  font-size:14px;
  font-weight:400;
  color:var(--bk);
  margin-bottom:8px;
  line-height:1.4;
}

.ventaja-desc{
  font-size:12px;
  font-weight:300;
  color:rgba(0,0,0,.4);
  line-height:1.6;
}

/* ════════════════════════════════════════════
   VALIJA CTA — franja Atelier
   ════════════════════════════════════════════ */
.valija-strip{
  background:var(--at);
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:48px 64px;
  flex-wrap:wrap;
  gap:24px;
}

.valija-text h2{
  font-size:clamp(20px,2.5vw,32px);
  font-weight:300;
  color:var(--bk);
  line-height:1.2;
  margin-bottom:8px;
}

.valija-text p{
  font-size:14px;
  font-weight:300;
  color:rgba(0,0,0,.6);
}

/* ════════════════════════════════════════════
   MODAL DE BIENVENIDA — popup flotante
   ════════════════════════════════════════════ */
.welcome-overlay{
  position:fixed;
  inset:0;
  background:rgba(10,10,10,.7);
  z-index:999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
  opacity:0;
  pointer-events:none;
  transition:opacity .3s;
}

.welcome-overlay.active{
  opacity:1;
  pointer-events:all;
}

.welcome-modal{
  background:var(--iv);
  max-width:500px;
  width:100%;
  padding:56px 48px;
  position:relative;
}

.welcome-modal-mark{
  position:absolute;
  top:20px;right:20px;
}

.welcome-close{
  position:absolute;
  top:20px;left:20px;
  background:none;border:none;
  font-family:var(--m);font-size:10px;
  letter-spacing:2px;
  color:rgba(0,0,0,.35);
  cursor:pointer;
  text-transform:uppercase;
}
.welcome-close:hover{color:var(--bk)}

.welcome-eyebrow{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  color:var(--at);
  text-transform:uppercase;
  margin-bottom:16px;
  display:block;
}

.welcome-title{
  font-size:26px;
  font-weight:300;
  line-height:1.25;
  margin-bottom:12px;
}

.welcome-desc{
  font-size:14px;
  font-weight:300;
  color:rgba(0,0,0,.55);
  line-height:1.7;
  margin-bottom:32px;
}

/* ════════════════════════════════════════════
   FORMULARIO INFO — sidebar/modal lateral
   ════════════════════════════════════════════ */
.info-form-wrap{
  background:var(--iv);
  padding:80px 64px;
  border-top:0.5px solid rgba(0,0,0,.08);
}

.info-form-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}

.info-form-left h2{
  font-size:clamp(24px,3vw,40px);
  font-weight:100;
  line-height:1.15;
  margin-bottom:16px;
}

.info-form-left p{
  font-size:14px;
  font-weight:300;
  color:rgba(0,0,0,.5);
  line-height:1.75;
}

.form-field{margin-bottom:20px}

.form-field label{
  display:block;
  font-family:var(--m);
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(0,0,0,.35);
  margin-bottom:8px;
}

.form-field input,
.form-field textarea,
.form-field select{
  width:100%;
  border:none;
  border-bottom:0.5px solid rgba(0,0,0,.15);
  background:transparent;
  padding:10px 0;
  font-family:var(--f);
  font-size:15px;
  font-weight:300;
  color:var(--bk);
  outline:none;
  transition:border-color .2s;
  border-radius:0;
  -webkit-appearance:none;
}

.form-field input:focus,
.form-field textarea:focus,
.form-field select:focus{
  border-color:var(--at);
}

.form-field textarea{min-height:100px;resize:none}

.form-grid-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0 28px;
}

.form-checkbox{
  display:flex;
  align-items:flex-start;
  gap:10px;
  margin-bottom:28px;
}

.form-checkbox input[type="checkbox"]{
  width:14px;height:14px;
  border:0.5px solid rgba(0,0,0,.25);
  margin-top:2px;
  flex-shrink:0;
  accent-color:var(--at);
  cursor:pointer;
}

.form-checkbox label{
  font-size:12px;
  font-weight:300;
  color:rgba(0,0,0,.4);
  line-height:1.6;
  cursor:pointer;
}

.form-checkbox label a{color:var(--at)}

/* ════════════════════════════════════════════
   PAGE HERO — páginas interiores
   Diferente: fondo Ivory con línea de color
   en el título y sin imagen de fondo.
   ════════════════════════════════════════════ */
.page-hero{
  padding:128px 64px 64px;
  background:var(--iv);
  border-bottom:0.5px solid rgba(0,0,0,.08);
  position:relative;
}

.page-hero::after{
  content:'';
  position:absolute;
  left:64px;bottom:0;
  width:64px;height:2px;
  background:var(--at);
}

.page-hero-title{
  font-size:clamp(36px,5vw,72px);
  font-weight:100;
  line-height:1;
  letter-spacing:-1.5px;
  max-width:720px;
  margin-top:16px;
}

.page-hero-sub{
  font-size:16px;
  font-weight:300;
  color:rgba(0,0,0,.45);
  max-width:480px;
  line-height:1.75;
  margin-top:20px;
}

/* ════════════════════════════════════════════
   TRABAJOS / SERVICIOS — grid de tarjetas
   estilo: borde sutil, hover con borde Atelier
   ════════════════════════════════════════════ */
.works-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
}

.work-card{
  position:relative;
  min-height:420px;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  overflow:hidden;
  background:var(--dk);
  cursor:default;
}

.work-card-bg{
  position:absolute;
  inset:0;
  background-size:cover;
  background-position:center;
  opacity:.4;
  transition:opacity .5s,transform .5s var(--ease);
}
.work-card:hover .work-card-bg{
  opacity:.55;
  transform:scale(1.04);
}

.work-card::after{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.94) 0%,rgba(10,10,10,.5) 55%,rgba(10,10,10,.1) 100%);
  z-index:1;
}

.work-card-inner{
  position:relative;
  z-index:2;
  padding:40px 36px;
  display:flex;
  flex-direction:column;
  gap:10px;
}

.work-num{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  color:var(--at);
}

.work-title{
  font-size:clamp(17px,1.6vw,22px);
  font-weight:100;
  color:var(--iv);
  line-height:1.2;
  letter-spacing:-.3px;
}

.work-desc{
  font-size:13px;
  font-weight:300;
  color:rgba(252,249,238,.45);
  line-height:1.7;
}

.work-link{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--at);
  display:inline-flex;
  align-items:center;
  gap:8px;
  transition:gap .2s;
  margin-top:6px;
}
.work-link::after{content:'→'}
.work-card:hover .work-link{gap:14px}

/* ════════════════════════════════════════════
   SOBRE NOSOTROS — team cards
   ════════════════════════════════════════════ */
.founder-block{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  min-height:520px;
}

.founder-img{
  position:relative;
  overflow:hidden;
}

.founder-img img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:top center;
  display:block;
}

.founder-img-ph{
  width:100%;height:100%;
  min-height:520px;
  background:var(--lq);
  display:flex;
  align-items:center;
  justify-content:center;
}

.founder-content{
  padding:80px 64px;
  background:var(--dk);
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.founder-name{
  font-size:clamp(28px,3.5vw,48px);
  font-weight:100;
  color:var(--iv);
  margin-bottom:6px;
}

.founder-role{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:2px;
  color:var(--at);
  text-transform:uppercase;
  margin-bottom:28px;
}

.founder-bio{
  font-size:15px;
  font-weight:300;
  color:rgba(252,249,238,.5);
  line-height:1.85;
}

/* Team grid */
.team-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1px;
  background:rgba(0,0,0,.06);
}

.team-card{
  background:var(--iv);
  overflow:hidden;
  position:relative;
}

.team-card-img{
  width:100%;
  aspect-ratio:3/4;
  object-fit:cover;
  object-position:top center;
  display:block;
  transition:transform .5s var(--ease);
  filter:grayscale(20%);
}

.team-card-img-ph{
  width:100%;
  aspect-ratio:3/4;
  background:var(--lq);
  display:flex;
  align-items:flex-end;
  padding:16px;
}

.team-card:hover .team-card-img{transform:scale(1.03);filter:none}

.team-card-body{
  padding:20px 20px 24px;
  background:var(--iv);
}

.team-name{
  font-size:15px;
  font-weight:400;
  color:var(--bk);
  margin-bottom:4px;
}

.team-role{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:rgba(0,0,0,.35);
}

/* ════════════════════════════════════════════
   CONTACTO — layout split
   ════════════════════════════════════════════ */
.contact-split{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:600px;
  margin:0 64px;
}

.contact-valija{
  margin-top:48px;
  padding-top:36px;
  border-top:0.5px solid rgba(0,0,0,.08);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
  flex-wrap:wrap;
}
.contact-valija p{
  font-size:15px;
  font-weight:300;
  color:rgba(0,0,0,.65);
  line-height:1.6;
}

.contact-info-panel{
  background:var(--dk);
  padding:80px 64px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}

.contact-form-panel{
  background:var(--iv);
  padding:80px 64px;
}

.contact-big-title{
  font-size:clamp(36px,5vw,72px);
  font-weight:100;
  color:var(--iv);
  line-height:.95;
  letter-spacing:-2px;
}

.contact-big-title em{
  font-style:italic;
  color:var(--at);
}

.c-info-group{margin-bottom:36px}

.c-info-label{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:2.5px;
  text-transform:uppercase;
  color:var(--at);
  margin-bottom:10px;
  display:block;
}

.c-info-val{
  font-size:14px;
  font-weight:300;
  color:rgba(252,249,238,.55);
  line-height:1.85;
}

.c-info-val a{
  color:rgba(252,249,238,.55);
  transition:color .2s;
  display:block;
}
.c-info-val a:hover{color:var(--iv)}

/* ════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════ */
.footer{
  background:var(--at);
  border-top:none;
}

.footer-top{
  display:grid;
  grid-template-columns:280px 1fr 1fr 1fr;
  gap:56px;
  padding:64px;
  border-bottom:0.5px solid rgba(0,0,0,.15);
}

.footer-brand{}

.footer-logo{
  display:flex;
  align-items:center;
  gap:10px;
  margin-bottom:16px;
}

.footer-logo-text{
  font-family:var(--f);
  font-weight:300;
  font-size:16px;
  letter-spacing:2px;
  color:#fff;
  text-transform:uppercase;
}

.footer-logo-text sub{
  font-family:var(--m);
  font-size:9px;
  letter-spacing:1px;
  color:rgba(0,0,0,.45);
  vertical-align:super;
}

.footer .nav-mark span{
  background:rgba(0,0,0,.3);
}

.footer-tagline{
  font-size:12px;
  font-weight:300;
  color:rgba(255,255,255,.65);
  line-height:1.7;
}

.footer-col h5{
  font-family:var(--m);
  font-size:12px;
  letter-spacing:2px;
  text-transform:uppercase;
  color:rgba(0,0,0,.85);
  margin-bottom:20px;
}

.footer-col a,
.footer-col p{
  display:block;
  font-size:13px;
  font-weight:300;
  color:rgba(255,255,255,.85);
  line-height:2.1;
  transition:color .2s;
}
.footer-col a:hover{color:#fff}

.footer-social{
  display:flex;
  gap:16px;
  margin-top:20px;
}
.footer-social a{
  display:flex;
  align-items:center;
  color:#fff;
  opacity:.75;
  transition:opacity .2s;
  line-height:1;
}
.footer-social a:hover{opacity:1}

.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding:18px 64px;
  flex-wrap:wrap;
  gap:12px;
  background:#955441;
}

.footer-copy{
  font-family:var(--m);
  font-size:10px;
  letter-spacing:1px;
  color:rgba(255,255,255,.35);
}

/* ════════════════════════════════════════════
   ANIMACIONES
   ════════════════════════════════════════════ */
/* Reveal: el texto sube desde abajo con clip */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity .7s var(--spring),transform .7s var(--spring);
}
.reveal.in{opacity:1;transform:none}

/* Reveal horizontal para imágenes */
.reveal-x{
  opacity:0;
  transform:translateX(-20px);
  transition:opacity .7s var(--spring),transform .7s var(--spring);
}
.reveal-x.in{opacity:1;transform:none}

/* Delay helpers */
.d1{transition-delay:.1s}
.d2{transition-delay:.2s}
.d3{transition-delay:.3s}
.d4{transition-delay:.4s}

/* ════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════ */
@media(max-width:1024px){
  .digital-grid,.mono-grid,.materials-layout,
  .plataformas-grid,.digital3d-block,
  .founder-block,.contact-split{
    grid-template-columns:1fr;
    margin:0;
  }
  .digital3d-content{order:1}
  .digital3d-media{order:2;min-height:340px}
  .ventajas-row{grid-template-columns:repeat(3,1fr)}
  .team-grid{grid-template-columns:repeat(3,1fr)}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
  .works-grid{grid-template-columns:1fr 1fr}
  .tiempos-inner{grid-template-columns:1fr}
}

@media(max-width:768px){
  .nav{padding:0 24px;height:56px}
  .nav-links{display:none}
  .nav-links.open{
    display:flex;flex-direction:column;
    position:fixed;top:56px;left:0;right:0;
    background:var(--iv);
    padding:28px 24px;gap:24px;
    border-bottom:0.5px solid rgba(0,0,0,.08);
  }
  .nav-burger{display:flex}
  .hero-body{padding:48px 24px 56px;}
  .w{padding:0 24px}
  .pad{padding:64px 0}
  .pad-lg{padding:80px 0}
  .page-hero{padding:96px 24px 48px}
  .page-hero::after{left:24px}
  .digital-content,.mono-content,.plataformas-content,
  .digital3d-content,.founder-content,
  .contact-info-panel,.contact-form-panel{padding:56px 24px}
  .materials-left,.materials-right{padding:56px 24px}
  .materials-left{border-right:none;border-bottom:0.5px solid rgba(0,0,0,.08)}
  .ventajas-row{grid-template-columns:1fr 1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr;padding:40px 24px}
  .footer-bottom{padding:16px 24px;flex-direction:column;text-align:center}
  .valija-strip{padding:40px 24px;flex-direction:column;text-align:center}
  .info-form-layout{grid-template-columns:1fr}
  .info-form-wrap{padding:56px 24px}
  .tiempos-block{min-height:auto}
  .tiempos-inner{padding:64px 24px}
  .works-grid{grid-template-columns:1fr}
}

@media(max-width:480px){
  .ventajas-row{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr 1fr}
  .footer-top{grid-template-columns:1fr}
  .form-grid-2{grid-template-columns:1fr}
}
