/* PROCESS TIMELINE */
.process{padding:90px 0}
.process-head{margin-bottom:24px; text-align:center}
.process-title{font-family:Orbitron; font-size:clamp(26px,4.4vw,40px); margin:0 0 6px}
.process-sub{margin:0; color:#7ff1cf}
.timeline{position:relative; display:grid; gap:24px}
.timeline .rail{position:absolute; left:28px; top:0; bottom:0; width:2px; background:linear-gradient(180deg, rgba(255,255,255,0.3), rgba(0,200,255,0.2))}
.step{display:grid; grid-template-columns:56px 1fr; gap:14px; align-items:stretch}
.step-num{width:28px; height:28px; border-radius:50%; border:2px solid rgba(255,255,255,0.6); display:grid; place-items:center; color:#cfe7ff; font-weight:700; margin-left:14px; background:rgba(2,6,23,0.8)}
.step-card{border:1px solid var(--border); border-radius:14px; padding:18px; display:grid; grid-template-columns:120px 1fr; gap:18px; align-items:center; background:linear-gradient(145deg, rgba(255,255,255,0.04), rgba(255,255,255,0.015)); box-shadow:0 10px 40px rgba(0,200,255,0.1)}
.step-icon{width:100px; height:100px; border-radius:14px; background:radial-gradient(60% 60% at 40% 40%, rgba(255,255,255,0.06), rgba(0,0,0,0.2)); display:grid; place-items:center; color:#cfe7ff}
.step-icon svg{width:56px; height:56px}
.step-title{margin:0 0 6px; letter-spacing:.08em}
.step-link{color:#7ff1cf; text-decoration:none}
.step-link:hover{text-decoration:underline}
.step-text{margin:4px 0 0; color:var(--muted)}

/* reveal */
.reveal{opacity:0; transform:translateY(16px); transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1; transform:translateY(0)}

@media (max-width:900px){
  .timeline .rail{left:18px}
  .step{grid-template-columns:46px 1fr}
  .step-card{grid-template-columns:1fr; gap:12px}
  .step-icon{width:100%; height:120px}
}
/* TECH SECTION */
.tech{padding:80px 0}
.tech-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:center}
.tech-title{font-family:'Exo 2', Inter, sans-serif; letter-spacing:.08em; color:#7ff1cf; font-weight:700; margin:0 0 8px; font-size:clamp(18px,2.8vw,24px)}
.tech-sub{font-family:Inter, sans-serif; font-weight:800; font-size:clamp(22px,4.8vw,36px); margin:0 0 12px}
.tech-sep{height:2px; width:220px; background:linear-gradient(90deg, rgba(255,255,255,0.7), transparent); opacity:.6; margin:6px 0 16px}
.benefits{list-style:none; padding:0; margin:0; display:grid; gap:16px}
.benefit{display:grid; grid-template-columns:auto 1fr; gap:12px; align-items:flex-start}
.benefit-icon{width:20px; height:20px; border-radius:50%; border:1px solid rgba(156,201,255,0.5); box-shadow:0 0 14px rgba(0,200,255,0.25) inset}
.benefit-title{margin:0 0 4px; color:#cfe7ff}
.benefit-text{margin:0; color:var(--muted)}
.tech-visual{display:grid; place-items:center}
.logo-badges{display:flex; gap:22px; align-items:center}
.badge{width:180px; height:180px; border-radius:20px; background:linear-gradient(145deg, rgba(255,255,255,0.04), rgba(255,255,255,0.01)); border:1px solid var(--border); box-shadow:var(--shadow); position:relative; overflow:hidden; display:grid; place-items:center}
.badge.airtable .shape{position:absolute; border-radius:6px}
.badge.airtable .y{background:#ffcb2b; width:80px; height:40px; transform:translate(-20px,-20px) rotate(35deg)}
.badge.airtable .r{background:#ff5555; width:80px; height:40px; transform:translate(-40px,20px) rotate(35deg)}
.badge.airtable .b{background:#2bc3ff; width:80px; height:40px; transform:translate(20px,20px) rotate(35deg)}
.badge.make .bars{display:block; width:90px; height:90px; border-radius:50%; background:radial-gradient(circle at 40% 40%, #9934ff, #5b00ff)}
.badge.make .bars::before{content:""; position:absolute; width:12px; height:44px; border-radius:6px; background:#fff; left:50%; top:50%; transform:translate(-130%, -50%) rotate(10deg)}
.badge.make .bars::after{content:""; position:absolute; width:12px; height:44px; border-radius:6px; background:#fff; left:50%; top:50%; transform:translate(30%, -50%) rotate(-10deg)}
@media (max-width:900px){.tech-grid{grid-template-columns:1fr; gap:18px}}
/* Fuente: Inter + Orbitron para títulos */
:root{
  --bg:#020617;
  --bg2:#0a0f1f;
  --neon:#00c8ff;
  --neon-soft:#9cc9ff;
  --silver:#c5e0ff;
  --metal:#b1b1b1;
  --text:#e6f0ff;
  --muted:#a8b3c7;
  --white:#ffffff;
  --glass: rgba(255,255,255,0.06);
  --border: rgba(156,201,255,0.18);
  --shadow: 0 20px 60px rgba(0,200,255,0.12), inset 0 0 40px rgba(0,200,255,0.06);
}
*{box-sizing:border-box}
html,body{height:100%;}
body{
  margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text); background:#000; overflow-x:hidden; position:relative;
}
/* Metallic animated auras (global), stays behind particles and hero */
body::before{
  content:""; position:fixed; inset:-10% -10% -10% -10%; z-index:-2; pointer-events:none;
  background:
    radial-gradient(40% 30% at 15% 20%, rgba(180,190,210,0.12), transparent 60%),
    radial-gradient(35% 30% at 85% 25%, rgba(0,180,255,0.12), transparent 65%),
    radial-gradient(30% 40% at 35% 85%, rgba(170,120,255,0.10), transparent 60%),
    radial-gradient(25% 30% at 80% 80%, rgba(160,170,190,0.10), transparent 70%);
  filter: saturate(1.2) contrast(1.05);
  animation: auras-move 18s ease-in-out infinite alternate;
}
@keyframes auras-move{
  0%{ transform: translate3d(0,0,0) scale(1); filter: blur(0px) saturate(1.1); }
  50%{ transform: translate3d(0,-1%,0) scale(1.02); filter: blur(0.2px) saturate(1.2); }
  100%{ transform: translate3d(0,1%,0) scale(1.03); filter: blur(0.4px) saturate(1.25); }
}
.container{width:min(1200px, 92%); margin-inline:auto}
.section-title{font-family:'Exo 2', Inter, sans-serif; font-weight:700; letter-spacing:0.02em; font-size:clamp(28px,4.4vw,44px); margin:0 0 18px}
.shiny-title{
  font-family:'Exo 2', Inter, sans-serif;
  font-weight:800;
  letter-spacing:0.03em;
  font-size:clamp(36px,6.4vw,72px);
  margin:0 0 18px;
  text-align:center;
  background:
    repeating-linear-gradient(112deg,
      rgba(255,255,255,0.00) 0%,
      rgba(255,255,255,0.00) 6%,
      rgba(255,255,255,0.65) 9%,
      rgba(255,255,255,0.00) 12%,
      rgba(255,255,255,0.00) 24%),
    linear-gradient(180deg, rgba(255,255,255,0.98), rgba(197,224,255,0.55) 60%, rgba(120,160,210,0.35) 100%),
    radial-gradient(120% 80% at 50% 0%, rgba(0,200,255,0.35), transparent 60%);
  background-size:200% 100%, auto, auto;
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  -webkit-text-stroke:0.5px rgba(168,198,240,0.35);
  text-shadow:0 1px 1px rgba(255,255,255,0.65), 0 0 18px rgba(255,255,255,0.35), 0 0 38px rgba(200,220,255,0.28);
  animation: metallic-shimmer 8s linear infinite;
}
.lead{font-size:clamp(16px,2.2vw,18px); color:var(--muted); line-height:1.7}

/* Subtítulo grande para 'La lógica de Novax' */
.logic-big{
  font-family:'Exo 2', Inter, sans-serif;
  font-weight:700;
  letter-spacing:0.02em;
  font-size:clamp(28px,4.4vw,44px);
  margin:0 0 18px;
}

/* Header */
.site-header{position:sticky; top:0; z-index:40; backdrop-filter:blur(8px); background:linear-gradient(180deg, rgba(2,6,23,0.85), rgba(2,6,23,0.35)); border-bottom:1px solid rgba(156,201,255,0.08)}
.nav{display:flex; align-items:center; justify-content:space-between; padding:16px 0}
.brand{display:flex; align-items:center; gap:12px}
.logo{font-family:Orbitron; font-weight:800; letter-spacing:0.08em}
.logo-glow{width:14px; height:14px; border-radius:50%; background:radial-gradient(circle, var(--neon), transparent 70%); box-shadow:0 0 20px var(--neon)}
nav a{color:var(--text); text-decoration:none; margin-left:22px; opacity:.85}
nav a:hover{opacity:1; color:var(--neon-soft)}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:12px; text-decoration:none; font-weight:600; letter-spacing:.02em; transition:0.25s ease; border:1px solid var(--border)}
.btn.primary{background:linear-gradient(180deg, rgba(0,200,255,0.18), rgba(0,200,255,0.06)); color:var(--white); box-shadow:var(--shadow)}
.btn.primary:hover{transform:translateY(-2px); box-shadow:0 28px 70px rgba(0,200,255,0.22)}
.btn.ghost{background:rgba(255,255,255,0.02); color:var(--text)}
.btn.ghost:hover{background:rgba(255,255,255,0.06)}
.btn.big{padding:16px 26px; font-size:18px; border-radius:14px}

/* HERO */
.hero{position:relative; min-height:90vh; display:grid; place-items:center; overflow:hidden; padding-top:40px}
.hero{background:#000}
.hero-bg{position:absolute; inset:0}
.orb-container{position:absolute; inset:0; pointer-events:none; z-index:0}
.beam{position:absolute; width:60vw; height:60vw; filter:blur(40px); opacity:.28; mix-blend-mode:screen; border-radius:50%}
.beam-1{background:radial-gradient(circle at 30% 30%, var(--neon), transparent 60%); left:-10vw; top:-20vh; animation:float 14s ease-in-out infinite}
.beam-2{background:radial-gradient(circle at 70% 70%, var(--neon-soft), transparent 60%); right:-20vw; bottom:-30vh; animation:float 16s ease-in-out infinite reverse}
.mesh-overlay{position:absolute; inset:-20%; background:radial-gradient(1200px 450px at 50% -10%, rgba(0,200,255,0.15), transparent 60%),
                            repeating-linear-gradient(135deg, rgba(156,201,255,0.05) 0 2px, transparent 2px 18px);
  opacity:.5; mask-image:radial-gradient(circle at 50% 40%, black 55%, transparent 70%)}
.hero-content{text-align:center; position:relative; z-index:2; padding:120px 0; background:transparent !important}
.hero-title{font-family:Orbitron; font-weight:800; letter-spacing:.06em; font-size:clamp(32px,5vw,56px); margin:0 0 12px; text-shadow:0 10px 40px rgba(0,200,255,0.16)}
.hero-sub{color:var(--muted); font-size:clamp(16px,2.4vw,20px); margin:0 0 24px}
.hero-cta{display:flex; gap:14px; justify-content:center}
.code-stream{position:absolute; inset:auto 10% 6% 10%; height:140px; opacity:0; display:none}
@keyframes scan{0%{background-position:0 140px}100%{background-position:0 -140px}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Brand hero NOVAX */
.brand-hero{
  background-color: transparent;
  isolation: isolate;
  font-family: Orbitron, 'Michroma', Inter, sans-serif;
  font-weight: 600;
  letter-spacing: 0.08em;
  font-size: clamp(40px, 8.5vw, 120px);
  margin: 0;
  line-height: 1.02;
  display: inline-block;
  white-space: nowrap;
  background:
    /* Sheen principal (ancho moderado) */
    repeating-linear-gradient(115deg,
      rgba(255,255,255,0.00) 0%,
      rgba(255,255,255,0.00) 7.2%,
      rgba(255,255,255,1.00) 9.5%,
      rgba(255,255,255,0.00) 12.6%,
      rgba(255,255,255,0.00) 30%),
    /* Microdetalles metálicos sutiles */
    repeating-linear-gradient(115deg,
      rgba(255,255,255,0.00) 0%,
      rgba(255,255,255,0.08) 1.6%,
      rgba(255,255,255,0.00) 3.2%),
    linear-gradient(180deg,
      rgba(250,252,255,1) 0%,
      rgba(205,230,255,0.85) 40%,
      rgba(150,185,230,0.55) 68%,
      rgba(110,150,220,0.45) 100%),
    linear-gradient(120deg, rgba(0,200,255,0.72), rgba(169,108,255,0.48) 45%, rgba(0,200,255,0.56) 90%);
  background-size: 500% 100%, 500% 100%, auto, auto;
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  -webkit-text-fill-color: transparent;
  -webkit-text-stroke: 1.1px rgba(200,225,255,0.42);
  text-shadow: none;
  /* drop-shadow eliminado para evitar banda oscura */
  position: relative;
  will-change: background-position;
  contain: paint;
  animation: metallic-shimmer 9s linear infinite;
}
.brand-hero span{ display:inline-block; padding:0 0.22em; }
.brand-hero span{
  background: inherit;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: metallic-shimmer 9s linear infinite;
}
.brand-hero::before,
.brand-hero::after{ display:none !important; content: none !important; }

@keyframes metallic-shimmer{
  0%{
    background-position: 0% 0, 0 0, 0 0;
  }
  100%{
    background-position: 240% 0, 0 0, 0 0;
  }
}

@keyframes halo-pulse{
  0%,100%{ transform: translate(-50%, -50%) scale(1); opacity:0.55; filter: blur(28px); }
  50%{ transform: translate(-50%, -50%) scale(1.04); opacity:0.72; filter: blur(30px); }
}

/* ABOUT */
.about{padding:80px 0}
.glass{background:linear-gradient(180deg, rgba(255,255,255,0.06), rgba(255,255,255,0.02)); border:1px solid var(--border); border-radius:20px; box-shadow:var(--shadow); backdrop-filter:blur(16px)}
.panel{padding:28px}
.about-grid{display:grid; grid-template-columns:1.2fr .8fr; gap:28px; align-items:center}
.about-image{display:grid; place-items:center}
.hand-ia{width:100%; max-width:520px}

.subhead{margin:16px 0 8px; font-weight:600; letter-spacing:0.02em; color:#cfe7ff}
.about-col{position:relative; padding-left:18px}
.about-col::before{content:""; position:absolute; left:0; top:4px; bottom:4px; width:2px; border-radius:2px; background:linear-gradient(180deg, rgba(156,201,255,0.0), rgba(156,201,255,0.6), rgba(156,201,255,0.0))}
.sep{height:1px; margin:16px 0; background:linear-gradient(90deg, transparent, rgba(156,201,255,0.5), transparent); filter:blur(0.2px); opacity:.8}
.about-stack{display:grid; gap:6px}

/* SERVICES */
.services{padding:80px 0}
.services-neon{display:grid; grid-template-columns:repeat(3,1fr); gap:34px; align-items:stretch}
.service{display:grid; justify-items:center; gap:16px; text-align:center; padding:24px; border-radius:20px; background:linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.02)); border:1px solid var(--border); box-shadow:var(--shadow); position:relative; z-index:0}
.service-icon{width:100%; max-width:420px; height:380px; background:radial-gradient(60% 60% at 50% 40%, rgba(0,0,0,0.0), rgba(0,0,0,0.7)); display:grid; place-items:center; border-radius:18px; overflow:hidden; position:relative}
.service svg{width:60%; height:auto; max-height:70%; filter: drop-shadow(0 0 10px rgba(0,200,255,0.5)) drop-shadow(0 0 24px rgba(255,0,120,0.25))}
/* Background image for first service */
.service--web .service-icon{ background: url("../fotos/imagen_2025-10-18_213559961.png") center/contain no-repeat transparent; }
.service--web .service-icon svg{ display:none; }
.service--auto .service-icon{ background: url("../fotos/imagenpage2.png") center/contain no-repeat transparent; }
.service--auto .service-icon svg{ display:none; }
.service--crm .service-icon{ background: url("../fotos/imagenpage3.png") center/contain no-repeat transparent; }
.service--crm .service-icon svg{ display:none; }
.stroke-blue{fill:none; stroke:#00c8ff; stroke-width:4; stroke-linecap:round; stroke-linejoin:round; filter: drop-shadow(0 0 6px rgba(0,200,255,0.6))}
.stroke-pink{fill:none; stroke:#ff2bbf; stroke-width:4; stroke-linecap:round; stroke-linejoin:round; filter: drop-shadow(0 0 6px rgba(255,43,191,0.6))}
.stroke-red{fill:none; stroke:#ff2b66; stroke-width:4; stroke-linecap:round; stroke-linejoin:round; filter: drop-shadow(0 0 6px rgba(255,43,102,0.65))}
.stroke-yellow{fill:none; stroke:#ffd84d; stroke-width:4; stroke-linecap:round; stroke-linejoin:round; filter: drop-shadow(0 0 6px rgba(255,216,77,0.7))}
.stroke-silver{fill:none; stroke:#cfe7ff; stroke-width:3; opacity:.9}
.service-title{margin:0 0 6px}
.services-neon .service .btn.neon{position:relative; z-index:3; pointer-events:auto}
.btn.neon{display:inline-block; padding:14px 22px; border-radius:999px; border:1px solid rgba(156,201,255,0.35); color:#cfe7ff; text-decoration:none; transition:transform .2s, box-shadow .2s, background .2s; position:relative; overflow:hidden; cursor:pointer; z-index:1}
.btn.neon::before{content:""; position:absolute; inset:0; border-radius:inherit; padding:2px; background:linear-gradient(120deg, rgba(0,200,255,0.0), rgba(0,200,255,0.8), rgba(146,186,255,0.0)); -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); -webkit-mask-composite: xor; mask-composite: exclude; animation: btn-border 3.2s linear infinite; pointer-events:none}
/* Añadir propiedad estándar para compatibilidad */
.btn.neon::before{ mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0); }
.btn.neon:hover{transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,200,255,0.25), 0 0 30px rgba(0,200,255,0.2) inset; background:rgba(255,255,255,0.03)}
@keyframes btn-border{0%{background-position:0% 50%}100%{background-position:200% 50%}}
@media (max-width:900px){
  .services-neon{grid-template-columns:1fr; gap:22px}
  .service{padding:18px}
  .service-icon{width:100%; max-width:100%; height:320px}
}

/* CASES */
.cases{padding:80px 0}
.carousel{position:relative}
.track{display:flex; gap:18px; overflow:hidden}
.slide{min-width:100%;}
.mockup{height:240px; border-radius:18px; background:linear-gradient(145deg, rgba(0,200,255,0.12), rgba(255,255,255,0.02)); border:1px solid var(--border); display:grid; place-content:center; text-align:center; box-shadow:var(--shadow); position:relative}
.mockup::after{content:""; position:absolute; inset:0; background:radial-gradient(400px 180px at 80% 0%, rgba(0,200,255,0.25), transparent 60%)}
.carousel .nav{position:absolute; top:50%; transform:translateY(-50%); background:rgba(2,6,23,0.6); border:1px solid var(--border); color:var(--text); width:44px; height:44px; border-radius:50%; display:grid; place-items:center; cursor:pointer}
.carousel .prev{left:-8px}
.carousel .next{right:-8px}

/* PERSONALIZATION */
.personalization{padding:90px 0; position:relative}
.personalization-grid{display:grid; grid-template-columns:1fr 1.1fr; gap:34px; align-items:center}
.personalization-title{font-family:'Exo 2', Inter, sans-serif; font-weight:700; letter-spacing:.01em; font-size:clamp(30px,5.2vw,54px); line-height:1.12; margin:0 0 14px; color:#e6f0ff; text-shadow:0 1px 1px rgba(255,255,255,0.22), 0 0 10px rgba(0,200,255,0.12)}
.personalization-title::after{content:""; display:block; width:min(320px,48%); height:2px; margin-top:10px; background:linear-gradient(90deg, rgba(0,200,255,0.8), rgba(146,186,255,0.0)); filter:blur(.2px)}
.personalization-copy{display:grid; gap:12px; max-width:60ch}
.personalization-copy p{margin:0; font-size:clamp(16px,2.2vw,18px); line-height:1.75; color:var(--muted); animation:fadeUp .6s ease both}
.personalization-copy p:first-child{color:var(--text); font-size:clamp(17px,2.6vw,20px)}
.personalization-visual{
  min-height:560px;
  position:relative;
  display:block;
  background: url('../fotos/test.png') center/contain no-repeat transparent;
  border:0;
  border-radius:0;
  box-shadow:none;
  animation: float-soft 6s ease-in-out infinite;
}
.personalization-visual::before{content:""; position:absolute; left:-2px; top:6%; bottom:6%; width:22px; pointer-events:none; border-radius:10px;
  background: linear-gradient(90deg, rgba(0,200,255,0.55), rgba(0,200,255,0.0)); filter: blur(6px); opacity:.55}
.personalization-visual::after{content:""; position:absolute; pointer-events:none; left:58%; top:52%; width:280px; height:280px; transform:translate(-50%,-50%);
  background: radial-gradient(closest-side, rgba(0,200,255,0.22), rgba(0,200,255,0.12) 45%, rgba(169,108,255,0.10) 65%, transparent 85%);
  filter: blur(12px); opacity:.55; mix-blend-mode:screen; border-radius:50%; animation:holo-pulse 5.8s ease-in-out infinite}
.personalization-actions{margin-top:18px}
.personalization-actions{margin-top:22px}
.btn.personal-cta{display:inline-flex; align-items:center; gap:10px; padding:14px 20px; border-radius:999px; border:1px solid rgba(0,200,255,0.5); color:#00121d; background:linear-gradient(180deg, #7fe7ff, #00c8ff); text-decoration:none; font-weight:800; letter-spacing:.02em; box-shadow:0 12px 36px rgba(0,200,255,0.28), inset 0 1px 0 rgba(255,255,255,0.4)}
.btn.personal-cta:hover{transform:translateY(-1px); box-shadow:0 18px 50px rgba(0,200,255,0.35)}
.btn.personal-cta:active{transform:translateY(0)}

/* Acentos azules dentro de la copia */
.accent{color:#00c8ff}

/* Óvalo decorativo debajo del texto (sin texto legible) */
.decor-oval{ display:inline-block; width:220px; height:44px; margin-left:12px; border-radius:999px;
  background: linear-gradient(180deg, #8feeff, #00c8ff);
  box-shadow: 0 10px 34px rgba(0,200,255,0.35), inset 0 1px 0 rgba(255,255,255,0.5);
  filter: saturate(1.05);
  position:relative; overflow:hidden; vertical-align:middle;
  animation: oval-pulse 2.6s ease-in-out infinite;
}
.decor-oval::before{ content:""; position:absolute; inset:0; border-radius:inherit;
  background: linear-gradient(115deg, rgba(255,255,255,0.0) 0%, rgba(255,255,255,0.85) 12%, rgba(255,255,255,0.0) 28%);
  mix-blend-mode: screen; opacity:.5; animation: oval-sheen 3.8s linear infinite;
}

@keyframes oval-pulse{ 0%,100%{ transform:scale(1); box-shadow:0 10px 34px rgba(0,200,255,0.30)} 50%{ transform:scale(1.02); box-shadow:0 18px 52px rgba(0,200,255,0.40)} }
@keyframes oval-sheen{ 0%{ background-position:-50% 0 } 100%{ background-position:150% 0 } }
@keyframes holo-pulse{ 0%,100%{ opacity:.52; filter:blur(12px) } 50%{ opacity:.68; filter:blur(14px) } }

/* Reflejo suave desde el robot hacia la columna izquierda */
.personalization::before{
  content:""; position:absolute; right:0; top:10%; bottom:10%; width:45%; pointer-events:none;
  background: radial-gradient(50% 60% at 85% 40%, rgba(0,200,255,0.20), transparent 65%),
              radial-gradient(35% 55% at 70% 70%, rgba(169,108,255,0.12), transparent 70%);
  filter: blur(26px) saturate(1.06);
  opacity:.30; mix-blend-mode:screen;
}

@keyframes float-soft{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}
@keyframes fadeUp{from{opacity:0; transform:translateY(8px)}to{opacity:1; transform:translateY(0)}}

@media (max-width:900px){
  .personalization-grid{grid-template-columns:1fr; gap:18px}
  .personalization-visual{min-height:420px}
}
.carousel .nav:hover{box-shadow:0 12px 40px rgba(0,200,255,0.22)}

/* CTA */
.cta{position:relative; padding:120px 0; background: linear-gradient(180deg, rgba(0,0,0,0.55), rgba(0,0,0,0.55)), url("../fotos/imagfenpage4.png") center/cover no-repeat}
.cta-inner{display:grid; place-items:center; gap:18px; text-align:center}
.cta-title{font-family:Orbitron; font-size:clamp(28px,4.6vw,46px); margin:0; text-shadow:0 2px 6px rgba(0,0,0,0.85), 0 0 18px rgba(255,255,255,0.18)}

/* FOOTER */
.site-footer{border-top:1px solid rgba(156,201,255,0.08); background:#000; padding:24px 0; position:relative; overflow:hidden}
.footer-grid{display:flex; align-items:center; justify-content:space-between; gap:12px}
.footer-nav a{color:#cfd8ea; text-decoration:none; margin-left:18px; opacity:.85}
.footer-nav a:hover{opacity:1; color:var(--neon-soft)}
.site-footer::before{content:""; position:absolute; inset:auto 0 0 0; height:1px; background:linear-gradient(90deg, transparent, rgba(156,201,255,0.45), transparent)}

/* Blog: ocultar breadcrumbs y mantener espacio bajo nav fijo */
.site-bc{display:none !important}
.subpage .post-hero{padding-top:120px !important}

/* Blog: ocultar breadcrumbs (kill switch en todas las variantes) */
.site-bc,
section.site-bc,
.subpage .site-bc,
nav.bc[aria-label="Migas de pan"]{
  display:none !important;
}
/* Asegurar espacio en listados y posts bajo el nav fijo */
.subpage .post-hero{padding-top:120px !important}
.subpage .hero-landing{padding-top:120px !important}

/* Partículas canvas full-screen */
#bg-particles{position:fixed; inset:0; z-index:-1}

/* Responsive */
@media (max-width: 920px){
  .about-grid{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr 1fr}
}
@media (max-width: 620px){
  .grid{grid-template-columns:1fr}
  .hero-cta{flex-direction:column}
}

@media (max-width: 720px){
  .glass-nav{overflow-x:auto; -webkit-overflow-scrolling:touch}
  .menu{display:flex; flex-direction:row; flex-wrap:nowrap !important; white-space:nowrap !important; justify-content:flex-start !important; align-items:center}
  .glass-nav a{flex:0 0 auto; line-height:1.2}
  /* Mayor especificidad para subpáginas que inyectan estilos a 720px */
  .site-header .menu{display:flex !important; flex-direction:row !important; flex-wrap:nowrap !important; white-space:nowrap !important; justify-content:flex-start !important; align-items:center !important}
  .site-header .glass-nav{overflow-x:auto !important; -webkit-overflow-scrolling:touch}
  .site-header .glass-nav a{flex:0 0 auto !important; line-height:1.2 !important}
}

/* Navegación móvil global: menú mucho más pequeño SOLO en móviles */
@media (max-width: 600px){
  .glass-nav{
    padding:3px 6px;
    gap:2px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:calc(100vw - 16px);
  }
  .menu{
    display:flex;
    gap:2px;
    flex-wrap:nowrap !important;
    white-space:nowrap !important;
    justify-content:flex-start;
    align-items:center;
  }
  .glass-nav a{
    font-size:0.68rem;
    padding:3px 4px;
    letter-spacing:-0.02em;
    margin:0;
    line-height:1.2;
    flex:0 0 auto; /* Evita que los enlaces colapsen o envuelvan */
  }
  .cta-link{margin-left:2px}
  /* Ocultar scrollbar visual de la nav en móviles manteniendo scroll táctil */
  .glass-nav::-webkit-scrollbar{ display:none }
  .glass-nav{ scrollbar-width:none; -ms-overflow-style:none }
}
/* Reglas con mayor especificidad para subpáginas que inyectan estilos locales */
@media (max-width: 600px){
  .site-header .glass-nav{
    padding:3px 6px !important;
    gap:2px !important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:calc(100vw - 16px) !important;
  }
  .site-header .menu{
    display:flex !important;
    gap:2px !important;
    flex-wrap:nowrap !important;
    white-space:nowrap !important;
    justify-content:flex-start !important;
    align-items:center !important;
  }
  .site-header .glass-nav a{
    font-size:0.68rem !important;
    padding:3px 4px !important;
    letter-spacing:-0.02em !important;
    margin:0 !important;
    line-height:1.2 !important;
    flex:0 0 auto !important;
  }
}
@media (max-width: 380px){
  .glass-nav{
    padding:2px 4px;
    gap:1px;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
    max-width:calc(100vw - 12px);
  }
  .menu{gap:1px; flex-wrap:nowrap !important; white-space:nowrap !important}
  .glass-nav a{
    font-size:0.64rem;
    padding:2px 4px;
    letter-spacing:-0.02em;
    line-height:1.15;
    flex:0 0 auto;
  }
}
@media (max-width: 380px){
  .site-header .glass-nav{
    padding:2px 4px !important;
    gap:1px !important;
    max-width:calc(100vw - 12px) !important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .site-header .menu{gap:1px !important; flex-wrap:nowrap !important; white-space:nowrap !important}
  .site-header .glass-nav a{
    font-size:0.64rem !important;
    padding:2px 4px !important;
    letter-spacing:-0.02em !important;
    line-height:1.15 !important;
    flex:0 0 auto !important;
  }
}
@media (max-width: 340px){
  .glass-nav{
    padding:2px 3px;
    gap:1px;
    max-width:calc(100vw - 10px);
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .menu{gap:1px}
  .glass-nav a{
    font-size:0.6rem;
    padding:2px 3px;
    line-height:1.1;
    flex:0 0 auto;
  }
}
@media (max-width: 340px){
  .site-header .glass-nav{
    padding:2px 3px !important;
    gap:1px !important;
    max-width:calc(100vw - 10px) !important;
    overflow-x:auto;
    -webkit-overflow-scrolling:touch;
  }
  .site-header .menu{gap:1px !important}
  .site-header .glass-nav a{
    font-size:0.6rem !important;
    padding:2px 3px !important;
    line-height:1.1 !important;
    flex:0 0 auto !important;
  }
}
