/* ===== MOBILE ROOT ===== */

#mobile-app{
  position:fixed;
  inset:0;
  background:#000;
  z-index:9999;
  overflow:hidden;
  font-family: Helvetica, Arial, sans-serif;
}

/* ===== LANDING ===== */

.mobile-landing{
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;

  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
  background-color: #000;
  background-size: cover;
  background-position: center;
}

.mobile-landing video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
}

.mobile-menu{
  position:relative;
  z-index:2;
  display:flex;
  flex-wrap:wrap;
  justify-content:center;
  gap:12px 18px;
  max-width:90vw;
  text-align:center;
}

.mobile-menu a{
  font-size:10px;
  letter-spacing:1.6px;
  text-transform:uppercase;
  color:#fff;
  opacity:0.8;
}

/* ===== HEADER ===== */

.mobile-header{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  padding:20px;
  display:flex;
  justify-content:space-between;
  z-index:10;
}

.mobile-logo{
  font-size:10px;
  letter-spacing:1.6px;
}

.mobile-logo span{
  display:block;
  color:#777;
  margin-top:2px;
}

.mobile-nav{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  max-width:55%;
  justify-content:flex-end;
}

.mobile-nav a{
  font-size:9px;
  letter-spacing:1.4px;
  color:#888;
}

.mobile-header{
  position:fixed;
  z-index:20;
}

.mobile-logo{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
}

.logo-main{
  white-space:nowrap;
  font-size:10px;
  letter-spacing:1.6px;
}

.logo-sub{
  font-size:10px;
  letter-spacing:1.6px;
  color:#777;
  margin-top:2px;
}

/* ===== VIEW ===== */

.mobile-view{
  position:absolute;
  inset:0;
}

/* ===== CAROUSEL ===== */

.mobile-carousel{
  display:flex;
  height:100%;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
}

.mobile-slide{
  min-width:100vw;
  height:100%;
  position:relative;
  scroll-snap-align:center;
}

.mobile-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.mobile-title{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  text-align:center;

  text-shadow: 0 2px 10px rgba(0,0,0,0.3);

  font-size:14px;
  letter-spacing:1.5px;

  opacity:0;
  transition: opacity 0.6s ease;

  padding:40px 30px;
  z-index:20;
  pointer-events:auto;
}

.mobile-title.text-visible{
  opacity:1;
}

.mobile-title.text-hidden{
  opacity:0;
}

.mobile-title.tap-active{
  transform: translate(-50%, -50%) scale(0.96);
  opacity: 0.85;
}

.mobile-carousel{
  position:absolute;
  inset:0;
}

.mobile-arrow{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  
  
  width:60px;           /* 👈 área grande */
  height:60px;          /* 👈 área grande */
  
  display:flex;
  align-items:center;
  justify-content:center;

  font-size:24px;       /* 👈 visual sigue chico */
  color:#fff;
  opacity:0.6;
  z-index:40;

  backdrop-filter: blur(2px);   /* 👈 sutil glass */
  background: rgba(0,0,0,0.2);  /* 👈 leve fondo */
  border-radius: 50%;
}

.mobile-arrow.tap-active{
  transform: translateY(-50%) scale(0.92);
  opacity: 0.85;
}

.mobile-carousel-fade{
  position:absolute;
  inset:0;
}

.mobile-slide-fade{
  position:absolute;
  inset:0;
  opacity:0;
  transition: opacity 0.6s ease;
  pointer-events:none;
}

.mobile-slide-fade img{
  width:100%;
  height:100%;
  object-fit:cover;
}



.mobile-arrow.left{ left:0px; }
.mobile-arrow.right{ right:0px; }

/* ===== VIDEO VIEW ===== */

.mobile-video{
  position:absolute;
  inset:0;
}

.mobile-video iframe{
  width:100vw;
  height:100vh;
}

/* ===== CONTACT ===== */

.mobile-contact{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-size:11px;
  letter-spacing:1.6px;
}

.mobile-title-main{
  font-size:18px;            
  letter-spacing:2px;
  line-height:1.2;
  text-transform:uppercase;
  margin-bottom:10px;
  font-weight:500;
}

.mobile-meta{
  font-size:8px;
  letter-spacing:1.2px;
  opacity:0.6;
  line-height:1.4;
}


/* animación base */
.tap-feedback{
  transition: transform 0.15s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.15s ease;
}

/* ===== LOADER ===== */

.mobile-loader{
  position:fixed;
  inset:0;
  background:#000;
  z-index:999999;
  display:flex;
  align-items:center;
  justify-content:center;
  color: hsl(168, 40%, 60%);
  font-family:"URWDIN", sans-serif;
}

/* líneas base */
.line{
  font-size:11px;
  letter-spacing:1.8px;
  text-transform:uppercase;
  margin-bottom:6px;
  min-height:1.2em;
  white-space:nowrap;
}

.line span{
  display:inline-block;
}

/* IZQUIERDA */
.l1, .l2{
  margin-left:10%;
  text-align:left;
}

/* DERECHA (pero alineadas entre sí) */
.l3, .l4{
  margin-left:50%;
  text-align:left;
}

#loadingPercent{
  display:inline-block;
  min-width:44px;
}

/* ===== LOADER FIX (IMPORTANTE) ===== */

.loader-text-block{
  position:fixed;
  inset:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  padding:20px;
  font-family:"URWDIN", sans-serif;
  width:100%;
}


/* ancho fijo para % */
#loadingPercent{
  display:inline-block;
  min-width:44px;
}


/* VIDEO FULL COVER PERFECTO */

.mobile-landing-content{
  position:relative;
  z-index:0;
}

.mobile-landing{
  position:relative;
  width:100%;
  height:100vh;
  overflow:hidden;
}

.mobile-landing video{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:0;
  display:block;
}

