/* === 2G — Shared styles for subpages (eventos, galerías) === */
:root {
  --blue-900:#0d1638; --blue-800:#1a2364; --blue-700:#2a3a8c; --blue-600:#3548a5;
  --blue-500:#4361b8; --blue-400:#1ea3d8; --blue-300:#5fc8e8;
  --magenta:#e6128a; --magenta-glow:#ff1a99;
  --ink:#0a1230; --ink-2:#111a44;
  --paper:#f5f6fa; --paper-2:#eceef5; --line:#d8dce8;
  --text:#0a0e22; --muted:#5a6280;
  --font-display:'Archivo','Inter',system-ui,sans-serif;
  --font-mono:'JetBrains Mono',ui-monospace,monospace;
  --font-sans:'Inter',system-ui,sans-serif;
  --max:1320px;
}
* { box-sizing:border-box; margin:0; padding:0; }
html,body { background:var(--ink); color:#fff; font-family:var(--font-sans); -webkit-font-smoothing:antialiased; scroll-behavior:smooth; }
body { overflow-x:hidden; }
img { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
button { font:inherit; cursor:pointer; border:none; background:none; }

/* Nav */
.nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:18px 40px; display:flex; align-items:center; justify-content:space-between; transition:background .3s, padding .3s; }
.nav.scrolled { background:rgba(10,18,48,0.85); backdrop-filter:blur(12px); padding:12px 40px; border-bottom:1px solid rgba(255,255,255,0.08); }
.nav-logo { display:flex; align-items:center; gap:10px; color:#fff; }
.nav-logo img { height:34px; width:auto; }
.nav-links { display:flex; gap:32px; align-items:center; }
.nav-links a { font-size:13px; font-weight:500; letter-spacing:0.06em; text-transform:uppercase; opacity:0.8; transition:opacity .2s; }
.nav-links a:hover { opacity:1; }
.nav-burger { display:none; background:transparent; color:#fff; border:1px solid rgba(255,255,255,0.08); padding:8px 12px; border-radius:8px; font-size:18px; line-height:1; }
.nav-mobile { display:none; }
html.nav-open .nav-mobile { display:block; position:fixed; right:20px; top:70px; z-index:1200; background:rgba(10,18,48,0.96); border:1px solid rgba(255,255,255,0.06); padding:18px; border-radius:12px; box-shadow:0 30px 60px rgba(0,0,0,0.45); }
.nav-mobile a { display:block; padding:10px 6px; color:#fff; font-weight:700; }
.nav-mobile a:not(.nav-cta) { margin-bottom:10px; }
.nav-mobile .nav-cta { display:block; width:100%; padding:14px 16px; margin-top:16px; border-radius:999px; border:1px solid rgba(255,255,255,0.15); text-align:center; color:#fff; background:rgba(255,255,255,0.06); font-size:12px; font-family:var(--font-mono); letter-spacing:0.08em; text-transform:uppercase; transition:background .2s; }
.nav-mobile .nav-cta:hover { background:rgba(255,255,255,0.12); }
.nav-cta { font-family:var(--font-mono); font-size:12px; padding:10px 18px; border:1px solid currentColor; border-radius:100px; letter-spacing:0.08em; text-transform:uppercase; transition:background .2s, color .2s, border-color .2s; }
.nav-cta:hover { background:var(--magenta); border-color:var(--magenta); color:#fff; }
html.no-scroll { overflow:hidden; }
@media (max-width:760px){ .nav-links { display:none; } .nav { padding:14px 20px; } .nav-burger { display:inline-flex; } .nav-cta { display:none; } }

/* Buttons */
.btn { position:relative; display:inline-flex; align-items:center; gap:12px; padding:18px 32px; font-family:var(--font-display); font-weight:800; font-size:14px; letter-spacing:0.12em; text-transform:uppercase; border-radius:100px; transition:transform .2s, box-shadow .25s, background .25s; overflow:hidden; isolation:isolate; }
.btn .arrow { transition:transform .3s; }
.btn:hover .arrow { transform:translateX(6px); }
.btn-primary { background:var(--magenta); color:#fff; box-shadow:0 10px 30px rgba(230,18,138,0.4); }
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 16px 45px rgba(255,26,153,0.55); }
.btn-ghost { background:rgba(255,255,255,0.06); color:#fff; border:1.5px solid rgba(255,255,255,0.55); backdrop-filter:blur(6px); }
.btn-ghost:hover { background:#fff; color:var(--ink); transform:translateY(-2px); }

/* Hero */
.subhero { position:relative; min-height:72vh; display:grid; align-items:center; overflow:hidden; padding:160px 40px 90px; isolation:isolate; }
.subhero-grid { position:absolute; inset:0; z-index:-1; background-image:linear-gradient(rgba(255,255,255,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.04) 1px,transparent 1px); background-size:80px 80px; mask-image:radial-gradient(ellipse at 50% 40%,#000 30%,transparent 80%); }
.subhero-video { position:absolute; inset:0; z-index:-1; width:100%; height:100%; object-fit:cover; opacity:0.16; mix-blend-mode:luminosity; filter:saturate(0.5) contrast(1.05); mask-image:radial-gradient(ellipse 90% 80% at 50% 40%, #000 35%, transparent 85%); -webkit-mask-image:radial-gradient(ellipse 90% 80% at 50% 40%, #000 35%, transparent 85%); pointer-events:none; }
.subhero-glow1,.subhero-glow2 { position:absolute; border-radius:50%; filter:blur(120px); z-index:-1; }
.subhero-glow1 { width:560px; height:560px; background:var(--blue-500); top:-120px; left:-180px; opacity:0.45; }
.subhero-glow2 { width:460px; height:460px; background:var(--magenta); bottom:-160px; right:-100px; opacity:0.28; }
.speed-lines { position:absolute; inset:0; z-index:-1; }
.speed-line { position:absolute; height:1px; background:linear-gradient(90deg,transparent,var(--blue-300),transparent); box-shadow:0 0 8px rgba(95,200,232,0.4); animation:speedLine var(--dur,3s) linear infinite; animation-delay:var(--delay,0s); width:var(--w,200px); top:var(--y,50%); }
.speed-line.cyan { background:linear-gradient(90deg,transparent,var(--blue-400),transparent); height:1.5px; }
.speed-line.magenta { background:linear-gradient(90deg,transparent,var(--magenta-glow),transparent); }
@keyframes speedLine { 0%{transform:translateX(-100vw);opacity:0;} 10%{opacity:1;} 90%{opacity:1;} 100%{transform:translateX(100vw);opacity:0;} }
.subhero-inner { max-width:var(--max); margin:0 auto; width:100%; }
.eyebrow { display:inline-flex; align-items:center; gap:12px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue-300); margin-bottom:22px; }
.eyebrow::before { content:''; width:24px; height:1px; background:currentColor; }
.subhero-title { font-family:var(--font-display); font-weight:900; font-size:clamp(64px,12vw,200px); line-height:0.86; letter-spacing:-0.04em; text-transform:uppercase; }
.subhero-title .it { font-style:italic; background:linear-gradient(135deg,#fff 20%,var(--blue-300) 60%,var(--magenta-glow)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.subhero-sub { max-width:560px; font-size:18px; line-height:1.5; color:rgba(255,255,255,0.7); margin-top:26px; }

/* Section */
.section { padding:80px 40px 120px; }
.section-inner { max-width:var(--max); margin:0 auto; }

/* Race cards grid */
.ev-filters { display:flex; gap:8px; margin-bottom:48px; flex-wrap:wrap; }
.ev-chip { font-family:var(--font-mono); font-size:12px; letter-spacing:0.12em; text-transform:uppercase; padding:10px 20px; border-radius:100px; border:1px solid rgba(255,255,255,0.15); color:rgba(255,255,255,0.6); transition:all .25s; }
.ev-chip.active, .ev-chip:hover { background:var(--magenta); border-color:var(--magenta); color:#fff; }
.ev-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
@media (max-width:900px){ .ev-grid { grid-template-columns:1fr; } }
@media (max-width:640px){ .ev-grid { grid-template-columns:1fr; } .section{ padding:60px 20px 90px; } .subhero{ padding:130px 20px 70px; } }

.ev-card { position:relative; border-radius:16px; overflow:hidden; min-height:440px; display:flex; flex-direction:column; justify-content:flex-end; padding:38px; isolation:isolate; transition:transform .45s cubic-bezier(0.2,0.9,0.2,1), box-shadow .45s; }
.ev-card:hover { transform:translateY(-8px); box-shadow:0 36px 80px rgba(0,0,0,0.5); }
.ev-poster { position:absolute; inset:0; z-index:-2; }
.ev-poster img { width:100%; height:100%; object-fit:cover; transition:transform .7s ease; }
.ev-card:hover .ev-poster img { transform:scale(1.07); }
.ev-card::after { content:''; position:absolute; inset:0; z-index:-1; background:linear-gradient(160deg, rgba(13,22,56,0.55) 0%, rgba(13,22,56,0.2) 35%, rgba(10,18,48,0.92) 100%); }
.ev-ghost { position:absolute; top:-10px; left:-12px; z-index:-1; font-family:var(--font-display); font-weight:900; font-style:italic; font-size:170px; line-height:.8; letter-spacing:-0.05em; color:rgba(255,255,255,0.07); pointer-events:none; white-space:nowrap; }
.ev-status { position:absolute; top:24px; left:24px; z-index:3; font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; padding:8px 14px; border-radius:100px; backdrop-filter:blur(8px); }
.ev-status.open { background:rgba(16,185,129,0.25); border:1px solid rgba(16,185,129,0.5); color:#5ff0b0; }
.ev-status.soon { background:rgba(245,158,11,0.22); border:1px solid rgba(245,158,11,0.5); color:#ffce6b; }
.ev-status.done { background:rgba(255,255,255,0.12); border:1px solid rgba(255,255,255,0.25); color:#fff; }
.ev-dist { position:absolute; top:22px; right:26px; z-index:3; font-family:var(--font-display); font-weight:900; font-style:italic; font-size:52px; line-height:1; -webkit-text-stroke:2px rgba(255,255,255,0.85); color:transparent; }
.ev-loc { font-family:var(--font-mono); font-size:11px; letter-spacing:0.18em; text-transform:uppercase; color:var(--blue-300); margin-bottom:10px; }
.ev-name { font-family:var(--font-display); font-weight:900; font-size:clamp(34px,4.4vw,52px); line-height:0.92; text-transform:uppercase; letter-spacing:-0.02em; color:#fff; }
.ev-info { display:flex; gap:26px; margin-top:22px; font-family:var(--font-mono); font-size:10px; color:rgba(255,255,255,0.55); letter-spacing:0.12em; text-transform:uppercase; flex-wrap:wrap; }
.ev-info strong { display:block; color:#fff; font-family:var(--font-display); font-size:17px; letter-spacing:-0.01em; text-transform:none; margin-top:4px; font-weight:700; }
.ev-cta { margin-top:26px; display:inline-flex; align-items:center; justify-content:center; gap:10px; align-self:flex-start; font-family:var(--font-display); font-weight:800; font-size:13px; letter-spacing:0.1em; text-transform:uppercase; color:#fff; background:var(--magenta); padding:15px 28px; border-radius:100px; box-shadow:0 10px 28px rgba(230,18,138,0.4); transition:transform .25s, box-shadow .25s, background .25s; }
.ev-card:hover .ev-cta { background:var(--magenta-glow); box-shadow:0 14px 36px rgba(255,26,153,0.55); }
.ev-cta .arrow { transition:transform .3s; }
.ev-card:hover .ev-cta .arrow { transform:translateX(6px); }

/* Footer */
.footer { background:var(--ink-2); color:rgba(255,255,255,0.6); padding:70px 40px 30px; border-top:1px solid rgba(255,255,255,0.08); }
.footer-grid { max-width:var(--max); margin:0 auto; display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
.footer-brand img { height:38px; }
.footer-brand p { font-size:14px; line-height:1.6; margin-top:16px; max-width:320px; }
.footer h4 { font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:#fff; margin-bottom:14px; }
.footer ul { list-style:none; }
.footer ul li { padding:5px 0; font-size:14px; }
.footer ul li a:hover { color:#fff; }
.footer-bottom { max-width:var(--max); margin:50px auto 0; padding-top:28px; border-top:1px solid rgba(255,255,255,0.08); display:flex; justify-content:space-between; flex-wrap:wrap; gap:14px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.15em; text-transform:uppercase; }

/* WhatsApp float */
.wa-float { position:fixed; right:26px; bottom:26px; z-index:9000; width:62px; height:62px; border-radius:50%; background:#25d366; color:#fff; display:grid; place-items:center; box-shadow:0 10px 30px rgba(37,211,102,0.45); transition:transform .25s, box-shadow .25s; }
.wa-float::after { content:''; position:absolute; inset:0; border-radius:50%; border:2px solid #25d366; animation:waPulse 2.2s ease-out infinite; }
.wa-float:hover { transform:scale(1.08); box-shadow:0 14px 40px rgba(37,211,102,0.6); }
@keyframes waPulse { 0%{transform:scale(1);opacity:0.7;} 100%{transform:scale(1.6);opacity:0;} }
@media (max-width:640px){ .wa-float { right:16px; bottom:16px; width:56px; height:56px; } }

/* Reveal */
.reveal { opacity:0; transform:translateY(30px); transition:opacity .8s ease, transform .8s cubic-bezier(0.2,0.9,0.2,1); }
.reveal.in { opacity:1; transform:translateY(0); }
.reveal-d1 { transition-delay:.1s; } .reveal-d2 { transition-delay:.2s; } .reveal-d3 { transition-delay:.3s; }
.reveal-d4 { transition-delay:.4s; } .reveal-d5 { transition-delay:.5s; }

/* Back link */
.back-link { display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-bottom:40px; transition:color .2s; }
.back-link:hover { color:#fff; }

/* === Services showcase === */
.svc-section-head { max-width:var(--max); margin:0 auto 56px; }
.svc-grid { display:grid; grid-template-columns:repeat(6,1fr); gap:18px; max-width:var(--max); margin:0 auto; }
.svc-tile { position:relative; border-radius:14px; overflow:hidden; min-height:300px; display:flex; flex-direction:column; justify-content:flex-end; padding:28px; cursor:pointer; isolation:isolate; transition:transform .4s cubic-bezier(0.2,0.9,0.2,1), box-shadow .4s; }
.svc-tile:hover { transform:translateY(-8px); box-shadow:0 30px 70px rgba(0,0,0,0.5); }
.svc-tile .svc-img { position:absolute; inset:0; z-index:-2; }
.svc-tile .svc-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.svc-tile:hover .svc-img img { transform:scale(1.07); }
.svc-tile::after { content:''; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg,rgba(10,18,48,0.15) 0%,rgba(10,18,48,0.05) 30%,rgba(10,18,48,0.72) 68%,rgba(8,14,38,0.96) 100%); }
.svc-tile.wide { grid-column:span 4; } .svc-tile.med { grid-column:span 3; } .svc-tile.sm { grid-column:span 2; }
.svc-num { position:absolute; top:24px; left:28px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; color:var(--blue-300); }
.svc-ico { position:absolute; top:20px; right:24px; width:46px; height:46px; border-radius:12px; display:grid; place-items:center; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.18); backdrop-filter:blur(8px); }
.svc-ico svg { width:23px; height:23px; stroke:#fff; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.svc-tile:hover .svc-ico { background:rgba(255,255,255,0.16); }
.svc-name { font-family:var(--font-display); font-weight:800; font-size:26px; line-height:1.0; text-transform:uppercase; letter-spacing:-0.01em; text-shadow:0 2px 14px rgba(0,0,0,0.45); }
.svc-desc { font-size:13.5px; line-height:1.5; color:rgba(255,255,255,0.82); margin-top:10px; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
.svc-tile:hover .svc-desc { -webkit-line-clamp:5; }
.svc-chips { display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.svc-chips span { font-family:var(--font-mono); font-size:10px; letter-spacing:0.08em; text-transform:uppercase; padding:4px 10px; border:1px solid rgba(255,255,255,0.28); border-radius:100px; color:rgba(255,255,255,0.85); background:rgba(255,255,255,0.07); backdrop-filter:blur(6px); }
.svc-view { display:inline-flex; align-items:center; gap:8px; margin-top:16px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.14em; text-transform:uppercase; color:#fff; }
.svc-view .arrow { display:inline-flex; transition:transform .3s; color:var(--magenta-glow,#ff1a99); }
.svc-tile:hover .svc-view .arrow { transform:translateX(6px); }
.svc-view .cnt-fotos { color:rgba(255,255,255,0.55); margin-left:4px; letter-spacing:0.06em; }
@media (max-width:1024px){ .svc-grid{ grid-template-columns:repeat(2,1fr);} .svc-tile.wide,.svc-tile.med,.svc-tile.sm{ grid-column:span 1;} }
@media (max-width:640px){ .svc-grid{ grid-template-columns:1fr;} .svc-desc{ -webkit-line-clamp:4; } }

/* === Service videos === */
.vid-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:var(--max); margin:56px auto 0; }
.vid-card { position:relative; border-radius:14px; overflow:hidden; aspect-ratio:9/13; isolation:isolate; transition:transform .4s cubic-bezier(0.2,0.9,0.2,1), box-shadow .4s; }
.vid-card:hover { transform:translateY(-8px); box-shadow:0 30px 70px rgba(0,0,0,0.5); }
.vid-card video { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:-2; }
.vid-grad { position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(13,22,56,0.1) 0%, transparent 40%, rgba(10,18,48,0.9) 100%); }
.vid-meta { position:absolute; left:24px; right:24px; bottom:24px; }
.vid-tag { font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue-300); }
.vid-title { font-family:var(--font-display); font-weight:800; font-size:24px; line-height:1.05; text-transform:uppercase; letter-spacing:-0.01em; color:#fff; margin-top:8px; }
@media (max-width:760px){ .vid-grid{ grid-template-columns:1fr; } .vid-card{ aspect-ratio:9/12; } }

/* === Cotizador === */
.quote { background:var(--ink-2); border-top:1px solid rgba(255,255,255,0.08); }
.quote-wrap { max-width:1000px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:start; }
.quote-pick { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.qopt { position:relative; display:flex; align-items:center; gap:10px; padding:14px 16px; border-radius:12px; border:1.5px solid rgba(255,255,255,0.12); background:rgba(255,255,255,0.03); cursor:pointer; transition:all .2s; font-size:13.5px; font-weight:500; }
.qopt:hover { border-color:rgba(95,200,232,0.4); }
.qopt input { position:absolute; opacity:0; }
.qopt .box { width:20px; height:20px; border-radius:6px; border:1.5px solid rgba(255,255,255,0.3); flex:0 0 auto; display:grid; place-items:center; transition:all .2s; font-size:12px; color:transparent; }
.qopt.checked { border-color:var(--magenta); background:rgba(230,18,138,0.1); }
.qopt.checked .box { background:var(--magenta); border-color:var(--magenta); color:#fff; }
.quote-form { display:flex; flex-direction:column; gap:14px; }
.qfield { display:flex; flex-direction:column; gap:6px; }
.qfield label { font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:var(--blue-300); }
.qfield input, .qfield textarea, .qfield select { background:rgba(255,255,255,0.04); border:1px solid rgba(255,255,255,0.15); color:#fff; padding:14px 16px; border-radius:10px; font:inherit; font-size:15px; font-family:var(--font-sans); transition:border-color .2s, background .2s; }
.qfield input:focus, .qfield textarea:focus, .qfield select:focus { outline:none; border-color:var(--magenta); background:rgba(255,255,255,0.07); }
.qfield textarea { min-height:90px; resize:vertical; }
.q2 { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.quote-submit { display:inline-flex; align-items:center; justify-content:center; gap:12px; padding:20px; background:#25d366; color:#fff; font-family:var(--font-display); font-weight:800; font-size:15px; letter-spacing:0.1em; text-transform:uppercase; border-radius:100px; transition:transform .2s, box-shadow .25s, background .2s; box-shadow:0 10px 30px rgba(37,211,102,0.35); }
.quote-submit:hover { transform:translateY(-2px); box-shadow:0 16px 40px rgba(37,211,102,0.5); }
.quote-submit:disabled { opacity:.5; cursor:not-allowed; transform:none; box-shadow:none; }
.quote-note { font-family:var(--font-mono); font-size:11px; color:rgba(255,255,255,0.45); letter-spacing:0.05em; text-align:center; margin-top:4px; }
.quote-count { font-family:var(--font-mono); font-size:12px; color:var(--blue-300); margin-bottom:14px; }
@media (max-width:760px){ .quote-wrap{ grid-template-columns:1fr; gap:32px; } .quote-pick{ grid-template-columns:1fr 1fr; } .q2{ grid-template-columns:1fr; } }

/* === Áreas band === */
.areas-band { border-top:1px solid rgba(255,255,255,0.08); border-bottom:1px solid rgba(255,255,255,0.08); background:var(--ink-2); }
.areas-inner { max-width:var(--max); margin:0 auto; display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:rgba(255,255,255,0.08); }
.area-cell { background:var(--ink-2); padding:34px 22px; text-align:center; transition:background .3s; }
.area-cell:hover { background:var(--ink); }
.area-cell svg { width:30px; height:30px; stroke:#fff; fill:none; stroke-width:1.5; stroke-linecap:round; stroke-linejoin:round; margin:0 auto 14px; }
.area-cell:hover svg { stroke:var(--blue-300); }
.area-cell h4 { font-family:var(--font-display); font-weight:800; font-size:15px; text-transform:uppercase; letter-spacing:0.01em; }
.area-cell p { font-size:12px; color:rgba(255,255,255,0.5); margin-top:6px; line-height:1.4; }
@media (max-width:900px){ .areas-inner{ grid-template-columns:repeat(2,1fr);} }
@media (max-width:640px){ .areas-inner{ grid-template-columns:1fr; } }

/* === Process === */
.proc-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; max-width:var(--max); margin:56px auto 0; }
.proc-step { position:relative; padding:32px 26px; border-radius:14px; background:var(--ink-2); border:1px solid rgba(255,255,255,0.07); transition:transform .35s, border-color .35s; }
.proc-step:hover { transform:translateY(-6px); border-color:rgba(95,200,232,0.3); }
.proc-step .pico { width:52px; height:52px; border-radius:14px; display:grid; place-items:center; background:linear-gradient(135deg,var(--blue-700),var(--blue-400)); margin-bottom:20px; }
.proc-step .pico svg { width:25px; height:25px; stroke:#fff; fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.proc-num { position:absolute; top:24px; right:26px; font-family:var(--font-display); font-weight:900; font-size:40px; font-style:italic; color:rgba(255,255,255,0.08); line-height:1; }
.proc-step h4 { font-family:var(--font-display); font-weight:800; font-size:21px; text-transform:uppercase; letter-spacing:-0.01em; }
.proc-step p { font-size:14px; color:rgba(255,255,255,0.6); margin-top:10px; line-height:1.5; }
@media (max-width:900px){ .proc-grid{ grid-template-columns:1fr 1fr;} }
@media (max-width:560px){ .proc-grid{ grid-template-columns:1fr;} }

/* === Why 2G === */
.why { background:var(--ink-2); border-top:1px solid rgba(255,255,255,0.08); }
.why-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; max-width:var(--max); margin:56px auto 0; }
.why-card { text-align:center; padding:36px 24px; }
.why-card .wico { width:60px; height:60px; border-radius:50%; display:grid; place-items:center; margin:0 auto 20px; border:1.5px solid rgba(95,200,232,0.4); background:rgba(30,163,216,0.08); }
.why-card .wico svg { width:28px; height:28px; stroke:var(--blue-300); fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.why-num { font-family:var(--font-display); font-weight:900; font-size:46px; line-height:1; letter-spacing:-0.03em; }
.why-card h4 { font-family:var(--font-display); font-weight:800; font-size:18px; text-transform:uppercase; margin-top:8px; }
.why-card p { font-size:13px; color:rgba(255,255,255,0.55); margin-top:8px; line-height:1.5; }
@media (max-width:900px){ .why-grid{ grid-template-columns:1fr 1fr;} }
@media (max-width:640px){ .why-grid{ grid-template-columns:1fr; } }

/* === CTA band === */
.cta-band { position:relative; overflow:hidden; padding:120px 40px; text-align:center; background:linear-gradient(135deg,var(--blue-800),var(--ink)); }
.cta-band::before { content:'2G'; position:absolute; font-family:var(--font-display); font-weight:900; font-style:italic; font-size:clamp(200px,34vw,520px); color:rgba(255,255,255,0.04); top:50%; left:50%; transform:translate(-50%,-50%); pointer-events:none; letter-spacing:-0.05em; }
.cta-band-inner { position:relative; z-index:2; max-width:760px; margin:0 auto; }
.cta-band h2 { font-family:var(--font-display); font-weight:900; font-size:clamp(38px,6vw,76px); line-height:.95; letter-spacing:-0.03em; text-transform:uppercase; }
.cta-band h2 .it { font-style:italic; background:linear-gradient(135deg,#fff 30%,var(--blue-300),var(--magenta-glow)); -webkit-background-clip:text; background-clip:text; color:transparent; }
.cta-band p { color:rgba(255,255,255,0.7); font-size:18px; margin-top:20px; }
.cta-band .actions { display:flex; gap:14px; justify-content:center; margin-top:36px; flex-wrap:wrap; }

/* === Galería de servicios (filtros + carrusel) === */
.sec-bg { position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.sec-bg img { width:100%; height:100%; object-fit:cover; opacity:0.16; }
.sec-bg::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg, rgba(10,18,48,0.86) 0%, rgba(10,18,48,0.78) 50%, rgba(10,18,48,0.92) 100%); }
.gal-filters { display:flex; gap:10px; justify-content:center; flex-wrap:wrap; margin:36px auto 40px; max-width:var(--max); }
.gal-fchip { font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; text-transform:uppercase; padding:11px 22px; border-radius:100px; border:1px solid rgba(255,255,255,0.15); color:rgba(255,255,255,0.6); background:rgba(255,255,255,0.03); transition:all .25s; cursor:pointer; }
.gal-fchip:hover { color:#fff; border-color:rgba(95,200,232,0.4); }
.gal-fchip.active { background:var(--magenta); border-color:var(--magenta); color:#fff; box-shadow:0 8px 24px rgba(230,18,138,0.35); }
.gal-carousel { position:relative; max-width:var(--max); margin:0 auto; }
.gal-track { display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding:6px 4px 16px; scroll-behavior:smooth; }
.gal-track::-webkit-scrollbar { display:none; }
.gal-slide { position:relative; flex:0 0 clamp(280px,32vw,420px); aspect-ratio:4/5; border-radius:14px; overflow:hidden; scroll-snap-align:center; background:var(--ink-2); box-shadow:0 20px 50px rgba(0,0,0,0.35); }
.gal-slide img { width:100%; height:100%; object-fit:cover; transition:transform .6s ease; }
.gal-slide:hover img { transform:scale(1.06); }
.gal-slide::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 55%,rgba(10,18,48,0.88)); }
.gal-cap { position:absolute; left:20px; right:20px; bottom:20px; z-index:2; }
.gal-cap .area { font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue-300); }
.gal-cap .ttl { font-family:var(--font-display); font-weight:800; font-size:20px; text-transform:uppercase; letter-spacing:-0.01em; color:#fff; margin-top:6px; line-height:1.05; }
.gal-arrows { display:flex; gap:10px; justify-content:center; margin-top:24px; }
.gal-arrow { width:54px; height:54px; border-radius:50%; border:1.5px solid rgba(255,255,255,0.25); background:rgba(255,255,255,0.04); color:#fff; font-size:20px; display:grid; place-items:center; transition:all .25s; cursor:pointer; }
.gal-arrow:hover { background:var(--magenta); border-color:var(--magenta); transform:scale(1.06); }
.gal-count { text-align:center; font-family:var(--font-mono); font-size:12px; letter-spacing:0.1em; color:rgba(255,255,255,0.45); margin-top:16px; }

.svc-modal { position:fixed; inset:0; z-index:10000; display:none; align-items:center; justify-content:center; padding:24px; background:rgba(3,8,20,0.92); overflow-y:auto; }
.svc-modal.open { display:flex; }
.svc-modal-panel { position:relative; width:min(1120px,100%); max-width:1120px; max-height:calc(100vh - 80px); background:rgba(8,16,30,0.98); border:1px solid rgba(255,255,255,0.08); border-radius:24px; box-shadow:0 40px 120px rgba(0,0,0,0.65); overflow:hidden; display:flex; flex-direction:column; }
.svc-modal-close { position:absolute; top:18px; right:18px; width:44px; height:44px; border:none; border-radius:50%; background:rgba(255,255,255,0.08); color:#fff; font-size:26px; line-height:1; cursor:pointer; z-index:2; }
.svc-modal-head { padding:28px 28px 0; flex-shrink:0; }
.svc-modal-type { font-family:var(--font-mono); font-size:11px; letter-spacing:0.26em; text-transform:uppercase; color:var(--blue-300); }
.svc-modal-title { font-family:var(--font-display); font-weight:900; font-size:clamp(28px,3vw,44px); line-height:1.05; color:#fff; margin-top:12px; }
.svc-modal-body { flex:1 1 auto; min-height:0; overflow:auto; }
.svc-modal-grid { display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:18px; padding:24px 28px 0; min-height:0; }
.svc-modal-grid::-webkit-scrollbar { width:8px; }
.svc-modal-grid::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.16); border-radius:999px; }
.svc-modal-item { position:relative; width:100%; aspect-ratio:4/5; overflow:hidden; border-radius:18px; background:#07101f; }
.svc-modal-item img { width:100%; height:100%; object-fit:cover; transition:transform .4s ease; }
.svc-modal-item:hover img { transform:scale(1.04); }
.svc-modal-empty { min-height:240px; display:grid; place-items:center; text-align:center; color:rgba(255,255,255,0.7); font-family:var(--font-mono); font-size:14px; padding:48px 24px; }
.svc-modal-footer { padding:16px 28px 24px; border-top:1px solid rgba(255,255,255,0.08); color:rgba(255,255,255,0.55); font-family:var(--font-mono); font-size:12px; letter-spacing:0.18em; }

body.modal-open { overflow:hidden; }

@media (max-width:900px){ .svc-modal-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }
@media (max-width:760px){ .svc-modal { align-items:flex-start; padding:16px; } .svc-modal-panel { max-height:calc(100vh - 32px); } .svc-modal-close { top:14px; right:14px; } .svc-modal-head { padding:24px 22px 0; } .svc-modal-grid { padding:20px 22px 0; } .svc-modal-footer { padding:14px 22px 22px; } }
@media (max-width:640px){ .svc-modal-grid { grid-template-columns:1fr; } .gal-slide { flex:0 0 78vw; } .footer-grid { flex-direction: column; } .footer-bottom { flex-direction: column; align-items: flex-start; gap: 14px; } }

/* === Próximos eventos: carrusel destacado === */
.feat-wrap { max-width:var(--max); margin:48px auto 0; position:relative; }
.feat-empty { border:1px dashed rgba(255,255,255,0.18); background:rgba(255,255,255,0.03); border-radius:18px; padding:64px 32px; text-align:center; font-size:clamp(16px,2vw,20px); color:rgba(255,255,255,0.7); line-height:1.6; max-width:var(--max); margin:0 auto; }
.feat-empty strong { color:#fff; }
.feat-card { position:relative; border-radius:18px; overflow:hidden; min-height:520px; display:grid; grid-template-columns:1.25fr 1fr; gap:40px; align-items:center; padding:56px; isolation:isolate; }
.feat-bg { position:absolute; inset:0; z-index:-2; }
.feat-bg img { width:100%; height:100%; object-fit:cover; }
.feat-card::after { content:''; position:absolute; inset:0; z-index:-1; background:var(--feat-overlay-solid, rgba(13,22,56,0.82)); }
.feat-tag { font-family:var(--font-mono); font-size:12px; letter-spacing:0.18em; text-transform:uppercase; color:var(--feat-tag, var(--blue-300)); }
.feat-name { font-family:var(--font-display); font-weight:900; font-size:clamp(44px,6vw,84px); line-height:0.9; text-transform:uppercase; letter-spacing:-0.03em; color:#fff; margin-top:12px; }
.feat-name .km { font-style:italic; -webkit-text-stroke:2px #fff; color:transparent; }
.feat-meta { display:flex; gap:28px; flex-wrap:wrap; margin-top:26px; }
.feat-meta div { font-family:var(--font-mono); font-size:10px; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.55); }
.feat-meta strong { display:block; font-family:var(--font-display); font-size:17px; font-weight:700; color:#fff; text-transform:none; letter-spacing:-0.01em; margin-top:4px; }
.feat-cd-label { font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin:28px 0 12px; }
.feat-cd { display:flex; gap:12px; }
.feat-cd .u { background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.18); border-radius:12px; padding:14px 8px; min-width:74px; text-align:center; backdrop-filter:blur(6px); }
.feat-cd .n { font-family:var(--font-display); font-weight:900; font-size:38px; line-height:1; color:#fff; font-variant-numeric:tabular-nums; }
.feat-cd .l { font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.55); margin-top:4px; }
.feat-cta { display:flex; gap:12px; margin-top:30px; flex-wrap:wrap; }
.feat-side { position:relative; z-index:1; }
.feat-side img { width:100%; border-radius:12px; filter:drop-shadow(0 30px 60px rgba(0,0,0,0.45)); }
.feat-side model-viewer {
  position: absolute;
  top: -8%;
  right: -8%;
  width: 72%;
  height: 92%;
  background: transparent;
  pointer-events: auto;
  z-index: 3;
}
.feat-dots { display:flex; gap:10px; justify-content:center; margin-top:26px; }
.feat-dot { width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,0.25); border:none; cursor:pointer; transition:all .25s; }
.feat-dot.active { background:var(--feat-dot, var(--magenta)); width:30px; border-radius:100px; }
@media (max-width:860px){ .feat-card { grid-template-columns:1fr; padding:36px; min-height:0; } .feat-side { display:none; } }

/* === Historias en video === */
.stories-track { display:flex; gap:22px; overflow-x:auto; scroll-snap-type:x mandatory; scrollbar-width:none; padding:6px 0 18px; max-width:var(--max); margin:40px auto 0; }
.stories-track::-webkit-scrollbar { display:none; }
.story-card { position:relative; flex:0 0 clamp(300px,34vw,440px); aspect-ratio:4/5; border-radius:14px; overflow:hidden; scroll-snap-align:start; background:var(--ink-2); box-shadow:0 20px 50px rgba(0,0,0,0.4); transition:transform .4s; text-decoration:none; }
.story-card:hover { transform:translateY(-8px); }
.story-card video, .story-card img.sc-media { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block; }
.story-card::after { content:''; position:absolute; inset:0; background:linear-gradient(180deg,rgba(13,22,56,0.1) 0%,transparent 35%,rgba(10,18,48,0.92) 100%); z-index:1; }
.story-play { position:absolute; top:18px; left:18px; z-index:3; display:inline-flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11px; letter-spacing:0.1em; text-transform:uppercase; color:#fff; background:rgba(255,255,255,0.12); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,0.2); padding:8px 14px; border-radius:100px; }
.story-play span { color:var(--magenta-glow); }
.story-meta { position:absolute; left:22px; right:22px; bottom:22px; z-index:2; color:#fff; }
.story-meta .t { font-family:var(--font-mono); font-size:10px; letter-spacing:0.2em; text-transform:uppercase; color:var(--blue-300); }
.story-meta .n { font-family:var(--font-display); font-weight:800; font-size:28px; text-transform:uppercase; letter-spacing:-0.02em; line-height:1; margin-top:8px; }
.story-meta .s { font-family:var(--font-mono); font-size:12px; opacity:0.85; margin-top:8px; }

/* === Franja de números === */
.ev-stats { border-top:1px solid rgba(255,255,255,0.1); border-bottom:1px solid rgba(255,255,255,0.1); background:var(--ink-2); position:relative; }
.ev-stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:rgba(255,255,255,0.1); max-width:var(--max); margin:0 auto; }
.ev-stat { background:var(--ink-2); padding:54px 28px; text-align:center; }
.ev-stat .num { font-family:var(--font-display); font-weight:900; font-size:clamp(42px,5vw,76px); line-height:1; letter-spacing:-0.03em; color:#fff; }
.ev-stat .num .plus { color:var(--blue-300); }
.ev-stat .lbl { font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-top:14px; }
@media (max-width:760px){ .ev-stats-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:640px){ .ev-stats-grid { grid-template-columns:1fr; } }
@media (max-width:640px){ .story-card { flex:0 0 92vw; } .ev-card { min-height: auto; padding: 30px 22px; } .ev-dist { font-size: 40px; top: 18px; right: 18px; } .quote-pick { grid-template-columns: 1fr; } .q2 { grid-template-columns: 1fr; } }

/* ============================================================
   ANIMATION PACK — más movimiento (transform/opacity only)
   ============================================================ */

/* Barra de progreso de scroll */
#scrollProgress { position:fixed; top:0; left:0; height:3px; width:100%; z-index:3000; transform-origin:0 50%; transform:scaleX(0); background:linear-gradient(90deg, var(--blue-400,#3b82f6), var(--magenta-glow,#ff1a99)); pointer-events:none; }

/* Eyebrow: la línea se dibuja al revelar la sección */
.eyebrow::before { transform-origin:left; }
.reveal.in .eyebrow::before { animation:eyebrowDraw .6s cubic-bezier(.2,.9,.2,1) both; }
@keyframes eyebrowDraw { from { transform:scaleX(0); } to { transform:scaleX(1); } }

/* Palabra itálica del título: subrayado degradado que se dibuja */
h2 .it, h2 span[style*="italic"] { background-image:linear-gradient(90deg, var(--magenta-glow,#ff1a99), var(--blue-400,#3b82f6)); background-repeat:no-repeat; background-position:0 94%; background-size:0% 3px; }
.reveal.in h2 .it, .reveal.in h2 span[style*="italic"] { animation:underlineDraw .7s cubic-bezier(.2,.9,.2,1) .45s forwards; }
@keyframes underlineDraw { to { background-size:100% 3px; } }

/* Botones / CTAs: barrido de brillo al hover */
.btn, .ev-cta, .gal-arrow { position:relative; overflow:hidden; }
.btn::after, .ev-cta::after { content:''; position:absolute; inset:0; background:linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.28) 50%, transparent 70%); transform:translateX(-130%) skewX(-12deg); transition:transform .55s ease; pointer-events:none; }
.btn:hover::after, .ev-card:hover .ev-cta::after { transform:translateX(130%) skewX(-12deg); }

/* Feedback al presionar (scale-feedback) */
.btn:active, .gal-arrow:active, .ev-chip:active, .feat-dot:active { transform:scale(.95); transition-duration:.1s; }

/* Story cards: zoom sutil del media al hover */
.story-card video, .story-card img.sc-media { transition:transform .8s cubic-bezier(.2,.9,.2,1); }
.story-card:hover video, .story-card:hover img.sc-media { transform:scale(1.06); }
.story-card .story-meta { transition:transform .4s cubic-bezier(.2,.9,.2,1); }
.story-card:hover .story-meta { transform:translateY(-6px); }
.story-play { opacity:0; transform:translateY(-6px); transition:opacity .3s, transform .3s; }
.story-card:hover .story-play { opacity:1; transform:translateY(0); }

/* Imagen lateral del evento destacado: flota suavemente */
.feat-side img { animation:floatY 5.5s ease-in-out infinite; }
@keyframes floatY { 0%,100% { transform:translateY(0) rotate(0deg); } 50% { transform:translateY(-14px) rotate(-1deg); } }

/* Dot activo del carrusel destacado: pulso */
.feat-dot.active { animation:dotPulse 2s ease-in-out infinite; }
@keyframes dotPulse { 0%,100% { box-shadow:0 0 0 0 rgba(255,26,153,0.5); } 50% { box-shadow:0 0 0 6px rgba(255,26,153,0); } }

/* Stats: entrada con pop */
.ev-stat { transition:transform .3s ease; }
.ev-stat:hover { transform:translateY(-6px); }
.ev-stat .num { display:inline-block; }

/* Status pill "Inscripciones abiertas": latido */
.ev-status.open { animation:statusGlow 2.4s ease-in-out infinite; }
@keyframes statusGlow { 0%,100% { box-shadow:0 0 0 0 rgba(16,185,129,0.35); } 50% { box-shadow:0 0 14px 2px rgba(16,185,129,0.25); } }

/* Accesibilidad: respetar reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration:.01ms !important; animation-iteration-count:1 !important; transition-duration:.01ms !important; }
}

/* === Stats banner unificado — compacto con fondo parallax === */
.stats-banner { position:relative; isolation:isolate; padding:64px 40px; overflow:hidden; }
.stats-banner::before { content:""; position:absolute; inset:0; z-index:-2; background:url("assets/bg/numeros-bg.jpg") center/cover no-repeat; background-attachment:fixed; }
.stats-banner::after { content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(180deg, rgba(10,18,48,0.88) 0%, rgba(10,18,48,0.78) 50%, rgba(10,18,48,0.9) 100%); }
.stats-banner-grid { max-width:var(--max,1280px); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center; }
.sb-stat .sb-num { font-family:var(--font-display); font-weight:900; font-size:clamp(38px,4.5vw,60px); line-height:1; letter-spacing:-0.03em; color:#fff; }
.sb-stat .sb-num .plus { color:var(--magenta-glow,#ff1a99); }
.sb-stat .sb-lbl { font-family:var(--font-mono); font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:rgba(255,255,255,0.6); margin-top:12px; }
@media (max-width:1024px){ .stats-banner::before { background-attachment:scroll; } }
@media (max-width:760px){ .stats-banner { padding:48px 24px; } .stats-banner-grid { grid-template-columns:1fr 1fr; gap:32px 16px; } }


/* === Textos justificados (párrafos largos) === */
.subhero-sub, .why-card p, .proc-step p, .footer-brand p,
.svc-desc, .story-meta .s { text-align: justify; }

/* ============================================================
   RESPONSIVE MÓVIL — eventos & servicios
   Carruseles con swipe (sin flechas) y chips de filtro deslizables
   ============================================================ */
@media (max-width: 760px) {
  /* Carruseles: se navegan deslizando con el dedo → ocultar flechas */
  .gal-arrows { display: none; }

  /* Encabezados de carrusel: apilar título y dejar el ancho completo */
  .stories-head { flex-direction: column !important; align-items: flex-start !important; gap: 8px !important; }

  /* Galería "Fotos de nuestro trabajo" y track de historias: padding de borde uniforme */
  .stories-track { padding-left: 16px !important; padding-right: 16px !important; gap: 16px; }
  .story-card { flex: 0 0 84vw; max-width: 360px; }
  .gal-track { gap: 14px; padding-left: 16px; padding-right: 16px; }
  .gal-slide { flex: 0 0 80vw; max-width: 340px; }
  .gal-cap .ttl { font-size: 18px; }
  .gal-count { font-size: 11px; }

  /* Chips de filtro: fila deslizable (no se amontonan ni se ven gigantes) */
  .gal-filters, .ev-filters {
    flex-wrap: nowrap; justify-content: flex-start;
    overflow-x: auto; scrollbar-width: none;
    margin: 24px -16px 28px; padding: 0 16px 4px;
    scroll-snap-type: x proximity; -webkit-overflow-scrolling: touch;
  }
  .gal-filters::-webkit-scrollbar, .ev-filters::-webkit-scrollbar { display: none; }
  .gal-fchip, .ev-chip {
    flex: 0 0 auto; scroll-snap-align: start;
    font-size: 11px; padding: 9px 16px; letter-spacing: 0.08em;
  }
}

/* Evento destacado (próximos eventos) en móvil */
@media (max-width: 640px) {
  .feat-card { padding: 28px 20px !important; border-radius: 16px; }
  .feat-meta { gap: 16px 22px; }
  /* Contador: cuadrícula 4 columnas flexible, sin desbordar */
  .feat-cd { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; }
  .feat-cd .u { min-width: 0; padding: 12px 4px; }
  .feat-cd .n { font-size: clamp(22px, 7vw, 34px); }
  .feat-cta { flex-direction: column; align-items: stretch; }
  .feat-cta .btn { width: 100%; justify-content: center; }
  .ev-card { min-height: 380px; }
}

@media (max-width: 480px) {
  .story-card { flex: 0 0 88vw; }
  .gal-slide { flex: 0 0 86vw; }
  .subhero-title { font-size: clamp(52px, 16vw, 90px); }
  .subhero-sub { font-size: 15px; }
  .feat-name { font-size: clamp(38px, 12vw, 60px); }
}
