/*
Theme Name: Texeira Futuro Scroll
Author: Texeira Marketing Digital
Description: Tema futurista (dark + neon) con animaciones de scroll (GSAP + SplitType + Lenis). Mantiene tu estructura original.
Version: 1.0.0
Text Domain: texeira-futuro-scroll
*/
:root{
  --bg:#070b14; 
  --panel:#0d1321; 
  --text:#eaf2ff; 
  --muted:#9db0cf; 
  --line:#233356;
  --cyan:#00e5ff; 
  --accent:#59ffa7; 
  --violet:#7a5cff;
  /* Mejora accesibilidad: informa que el tema soporta dark/light */
  color-scheme: dark light;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{ scroll-behavior:smooth; }

body{
  color:var(--text);
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,sans-serif;
  background:
    radial-gradient(1200px 600px at 80% -20%, rgba(0,224,255,.12), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(122,92,255,.10), transparent 60%),
    radial-gradient(800px 400px at 10% 100%, rgba(89,255,167,.08), transparent 60%),
    var(--bg);
}

a{color:inherit;text-decoration:none}

.container{max-width:1180px;margin:0 auto;padding:0 20px}

/* Botones unificados */
.btn,
.btn-submit{
  display:inline-block;
  background:var(--cyan);
  color:#08121E;
  padding:10px 16px;
  border-radius:12px;
  font-weight:800;
  transition:transform .2s ease, box-shadow .2s ease;
}
.btn:hover,
.btn-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 22px -12px rgba(0,0,0,.5);
}

/* Si querés usar outline puntual, lo mantenemos como variante secundaria */
.btn-outline{
  border:1px solid var(--line);
  background:transparent;
  color:var(--text);
}

.panel{
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.12);
  border-radius:16px;
  padding:18px;
  transition:transform .25s ease, box-shadow .25s ease;
}
.panel:hover{
  transform:translateY(-4px) rotateX(.3deg) rotateY(.3deg);
  box-shadow:0 14px 38px -20px rgba(0,0,0,.6);
}

h1{font-size:clamp(32px,5vw,56px);margin:12px 0 8px}
h2.title{font-size:clamp(26px,3.6vw,34px);margin:0 0 8px;color:var(--cyan)}
p.sub{color:var(--muted);margin:0 0 18px}

.tag{
  display:inline-block;
  font-size:12px;
  border:1px solid var(--cyan);
  color:var(--cyan);
  padding:2px 8px;
  border-radius:999px;
  background:rgba(0,229,255,.1);
}

.nav{
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(12,18,32,.8),rgba(12,18,32,.5));
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  position:sticky;
  top:0;
  z-index:50;
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}

.brand{display:flex;align-items:center;gap:10px}
.logo-box{
  width:34px;height:34px;border-radius:8px;
  background:#0E1526;
  border:1px solid var(--line);
  display:grid;place-items:center;
  font-weight:900;color:var(--cyan);
}

.menu{display:flex;gap:14px}
.menu a{color:var(--muted)}
.menu a:hover{color:var(--text)}

.hero{padding:72px 0;border-bottom:1px solid var(--line)}
.grid-hero{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:24px;
  align-items:center;
}

.eyebrow{
  display:inline-block;
  font-size:12px;
  color:var(--muted);
  border:1px solid var(--line);
  padding:6px 10px;
  border-radius:999px;
  background:linear-gradient(90deg, rgba(0,229,255,.12), rgba(89,255,167,.12));
}

.hero-img{
  aspect-ratio:4/3;
  background:#0F172A;
  border:1px dashed #2a3a5f;
  border-radius:16px;
  display:grid;
  place-items:center;
  color:var(--muted);
  overflow:hidden;
}
.hero-img img{width:100%;height:100%;object-fit:cover}

.section{
  padding:64px 0;
  border-bottom:1px solid var(--line);
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:16px;
}
.grid-2{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:16px;
}
.grid-logos{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:14px;
}

input,textarea{
  width:100%;
  background:#0E1629;
  border:1px solid var(--line);
  color:var(--text);
  padding:12px 14px;
  border-radius:10px;
  margin:6px 0;
}

button{all:unset}

/* btn-submit se apoya en .btn; solo ajustamos algún detalle si querés */
.btn-submit{
  border-radius:10px;
}

/* Footer */
footer{
  padding:28px 0;
  color:var(--muted);
}

/* Responsivo */
@media (max-width: 960px){
  .grid-hero,
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr 1fr}
  .grid-logos{grid-template-columns:repeat(3,1fr)}
}
@media (max-width: 640px){
  .grid-3{grid-template-columns:1fr}
  .grid-logos{grid-template-columns:repeat(2,1fr)}
}

/* Video */
#video-presentacion .panel{
  max-width:960px;
  margin:0 auto;
  overflow:hidden;
  border-radius:16px;
  padding:0;
}
#video-presentacion .panel video{
  display:block;
  width:100%;
  height:auto;
  aspect-ratio:16/9;
  object-fit:cover;
  max-height:60vh;
  border-radius:16px;
  margin:0 auto;
}
@media (max-width: 860px){
  #video-presentacion .panel{ max-width:none; }
  #video-presentacion .panel video{ max-height:none; }
}

/* Scroll helpers */
[data-split]{display:block; overflow:hidden;}
[data-split] .line,
[data-split] .word{
  display:inline-block;
  will-change:transform,opacity;
}
[data-pin]{position:relative;}
[data-parallax]{display:inline-block; will-change:transform;}
.tmd-oversized{letter-spacing:-.02em; line-height:.95;}

/* Menú móvil */
.nav-toggle{
  display:none;
  background:transparent;
  border:1px solid var(--line);
  color:var(--text);
  padding:8px 10px;
  border-radius:10px;
  margin-left:12px;
  cursor:pointer;
}
.nav-toggle .bar{
  display:block;
  width:22px;
  height:2px;
  background:var(--text);
  margin:5px 0;
}

.drawer{
  position:fixed;
  inset:0;
  z-index:100;
  opacity:0;
  pointer-events:none;
  transition:opacity .2s ease;
}
.drawer.open{
  opacity:1;
  pointer-events:auto;
}
.drawer-backdrop{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.35);
}
.drawer-panel{
  position:absolute;
  top:0;right:0;
  height:100%;width:82vw;max-width:360px;
  background:var(--panel);
  border-left:1px solid var(--line);
  padding:18px;
  display:flex;
  flex-direction:column;
  gap:12px;
  box-shadow:-20px 0 40px rgba(0,0,0,.35);
  transform:translateX(20px);
  opacity:.98;
  transition:transform .25s ease;
}
.drawer.open .drawer-panel{transform:translateX(0)}

.drawer-close{
  align-self:flex-end;
  background:transparent;
  border:1px solid var(--line);
  color:var(--text);
  width:36px;height:36px;
  border-radius:8px;
  cursor:pointer;
}
.drawer-links a{
  display:block;
  padding:12px 10px;
  border-radius:10px;
  text-decoration:none;
  color:var(--text);
  border:1px solid transparent;
  background:rgba(255,255,255,.03);
  margin:2px 0;
}
.drawer-links a:hover{border-color:#3c5c9a}

@media (max-width: 860px){
  #primary-menu-desktop{display:none}
  .nav-toggle{display:inline-flex;align-items:center;gap:8px}
}
#drawer-menu[hidden]{display:none}

/* Micro-tilt cards (se suaviza con prefers-reduced-motion más abajo) */
.panel{transition:transform .25s ease, box-shadow .25s ease}
.panel:hover{
  transform:translateY(-4px) rotateX(.3deg) rotateY(.3deg);
  box-shadow:0 14px 38px -20px rgba(0,0,0,.6);
}

/* ===== HOTFIX VISIBILIDAD PLANES (limpio, sin duplicados) ===== */
#plan-mensual,
#plan-mensual .container{
  overflow:visible !important;
  height:auto !important;
}

#plan-mensual .plans-grid{
  display:grid !important;
  gap:18px !important;
  grid-template-columns:1fr !important;  /* móvil */
}
@media (min-width:641px){
  #plan-mensual .plans-grid{
    grid-template-columns:repeat(2,minmax(0,1fr)) !important;
  }
}
@media (min-width:1024px){
  #plan-mensual .plans-grid{
    grid-template-columns:repeat(3,minmax(0,1fr)) !important;
  }
}

#plan-mensual .plan-card,
#plan-mensual .plans-grid>*{
  display:block !important;
  visibility:visible !important;
  opacity:1 !important;
  transform:none !important;
  height:auto !important;
  overflow:visible !important;
  position:relative !important;
}

/* Por si algo global recorta secciones */
.section,
.hero{
  overflow:visible !important;
}

/* ===== PERF DESKTOP: suavizar scroll en PC (≥1024px) ===== */
@media (min-width: 1024px) {
  /* A) Desactivar blur caro en desktop si hay stutter */
  .nav,
  .panel {
    -webkit-backdrop-filter: none !important;
    backdrop-filter: none !important;
  }

  /* B) Hover más liviano (evita jank de re-raster por sombras grandes) */
  .panel {
    box-shadow: 0 10px 28px rgba(0,0,0,.22) !important;
  }
  .panel:hover {
    transform: none !important;
    box-shadow: 0 10px 28px rgba(0,0,0,.22) !important;
  }

  /* C) Pseudo-fondo radial gigante: apáguese si existe */
  .umbrel-slide::before { display: none !important; }

  /* D) Nada de recortes que fuercen repaints constantes */
  .section,
  .hero { overflow: visible !important; }

  /* E) Evitar “will-change” innecesario (mantiene capas vivas) */
  #servicios .container,
  .plan-card { will-change: auto !important; }
}

/* ===== Accesibilidad: reducir movimiento para quien lo pida ===== */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition:none !important;
    scroll-behavior:auto !important;
  }

  .panel:hover,
  .btn:hover,
  .btn-submit:hover{
    transform:none !important;
    box-shadow:none !important;
  }

  [data-split] .line,
  [data-split] .word{
    will-change:auto !important;
  }
}
