/* ============================================
   COTIZACIÓN CONTLA × LOS ASKIS
   Equilibrio Creativo · 2025
   Dark · Liquid Glass · Cinematic
   ============================================ */

@property --border-angle {
    syntax: '<angle>';
    initial-value: 0deg;
    inherits: false;
}

/* ── TOKENS ──────────────────────────────── */
:root {
    --black:        #0a0a0a;
    --black-soft:   #111111;
    --black-mid:    #161616;
    --black-light:  #1a1a1a;
    --white:        #ffffff;
    --gray-100:     #e5e5e5;
    --gray-200:     #c4c4c4;
    --gray-300:     #8a8a8a;
    --gray-400:     #666666;
    --gray-500:     #444444;
    --gray-600:     #2a2a2a;

    --orange:       #ff5e00;
    --orange-light: #ff7a2e;
    --neon-cyan:    #00f0ff;
    --neon-magenta: #ff00aa;
    --neon-purple:  #8b5cf6;

    --glass-bg:     rgba(255,255,255,0.04);
    --glass-border: rgba(255,255,255,0.09);
    --glass-shine:  rgba(255,255,255,0.06);
    --glass-blur:   blur(24px) saturate(160%);
    --glass-shadow: 0 24px 60px rgba(0,0,0,0.55), inset 0 1px 0 rgba(255,255,255,0.07);

    --gradient-text: linear-gradient(90deg, #ff5e00, #ff00aa, #00f0ff);
    --font-display: 'Bebas Neue', Impact, sans-serif;
    --font-body:    'Inter', -apple-system, sans-serif;

    --ease-expo:  cubic-bezier(0.16, 1, 0.3, 1);
    --ease-quart: cubic-bezier(0.25, 1, 0.5, 1);
    --t-fast:   0.2s var(--ease-quart);
    --t-med:    0.4s var(--ease-expo);
    --t-slow:   0.8s var(--ease-expo);

    --max-w: 1400px;
    --nav-h: 76px;
    --r:     6px;
}

/* ── RESET ───────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; font-size:16px; -webkit-font-smoothing:antialiased; }
body { font-family:var(--font-body); background:var(--black); color:var(--white); overflow-x:hidden; cursor:none; }
a { color:inherit; text-decoration:none; cursor:none; }
button { cursor:none; }
ul { list-style:none; }
img { max-width:100%; height:auto; display:block; }
::selection { background:var(--orange); color:var(--black); }

/* ── NOISE ───────────────────────────────── */
.noise-overlay {
    position:fixed; inset:0; pointer-events:none; z-index:9999; opacity:.032;
    background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── CURSOR ──────────────────────────────── */
.cursor {
    position:fixed; width:8px; height:8px; background:var(--orange); border-radius:50%;
    pointer-events:none; z-index:10001; transform:translate(-50%,-50%);
    mix-blend-mode:difference; transition:width .2s ease, height .2s ease, background .2s ease;
}
.cursor-follower {
    position:fixed; width:40px; height:40px; border:1px solid rgba(255,255,255,.4);
    border-radius:50%; pointer-events:none; z-index:10000; transform:translate(-50%,-50%);
    transition:width .3s ease, height .3s ease, border-color .2s ease; opacity:.5;
}
.cursor.hover { width:16px; height:16px; background:var(--neon-cyan); }
.cursor-follower.hover { width:60px; height:60px; border-color:var(--orange); }
@media(hover:none) { .cursor,.cursor-follower{display:none} body,a,button{cursor:auto} a,button{cursor:pointer} }

/* ── TYPOGRAPHY ──────────────────────────── */
h1,h2,h3,h4 { font-family:var(--font-display); font-weight:400; line-height:.92; letter-spacing:.02em; text-transform:uppercase; }
.t-accent { color:var(--orange); }
.t-outline { color:transparent; -webkit-text-stroke:1.5px var(--white); }
.gradient-text { background:var(--gradient-text); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; background-size:200% auto; animation:grad-shift 4s ease infinite; }
@keyframes grad-shift { 0%,100%{background-position:0%} 50%{background-position:100%} }

/* ── CONTAINER ───────────────────────────── */
.container { max-width:var(--max-w); margin:0 auto; padding:0 2rem; }
.section-padded { padding:7rem 0; }

/* ── LIQUID GLASS BASE ───────────────────── */
.glass-card {
    background:var(--glass-bg);
    backdrop-filter:var(--glass-blur);
    -webkit-backdrop-filter:var(--glass-blur);
    border:1px solid var(--glass-border);
    box-shadow:var(--glass-shadow);
    border-radius:var(--r);
    position:relative;
    overflow:hidden;
}

/* Rotating gradient border on glass cards */
.glass-card::before {
    content:'';
    position:absolute; inset:-1px;
    border-radius:inherit;
    padding:1px;
    background:conic-gradient(from var(--border-angle), transparent 60%, rgba(255,94,0,.35) 75%, rgba(0,240,255,.2) 85%, transparent 95%);
    -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
    -webkit-mask-composite:xor; mask-composite:exclude;
    pointer-events:none;
    animation:border-spin 8s linear infinite;
}
@keyframes border-spin { to { --border-angle:360deg; } }

.glass-card:hover::before {
    animation-duration:4s;
    background:conic-gradient(from var(--border-angle), transparent 50%, rgba(255,94,0,.6) 68%, rgba(0,240,255,.3) 82%, transparent 95%);
}

/* ── HEADER ──────────────────────────────── */
.header {
    position:fixed; top:0; left:0; right:0; z-index:1000;
    transition:background var(--t-med), backdrop-filter var(--t-med);
    height:var(--nav-h);
}
.header.scrolled { background:rgba(10,10,10,.88); backdrop-filter:blur(20px); border-bottom:1px solid var(--glass-border); }
.nav {
    display:flex; align-items:center; justify-content:space-between;
    height:var(--nav-h); padding:0 2rem; max-width:var(--max-w); margin:0 auto;
}
.logo-img { height:36px; width:auto; object-fit:contain; flex-shrink:0; }
.logo-text { font-family:var(--font-display); font-size:1.1rem; letter-spacing:.15em; color:var(--white); }
.nav-tagline { font-size:.65rem; text-transform:uppercase; letter-spacing:.3em; color:var(--gray-400); }
.quote-number { font-size:.65rem; text-transform:uppercase; letter-spacing:.2em; color:var(--orange); border:1px solid rgba(255,94,0,.3); padding:.3rem .7rem; border-radius:20px; }

/* ── HERO ────────────────────────────────── */
.hero {
    min-height:100vh; position:relative; overflow:hidden;
    display:flex; flex-direction:column;
    padding-top:var(--nav-h);
}

/* Background orbs */
.hero-orbs { position:absolute; inset:0; pointer-events:none; }
.orb { position:absolute; border-radius:50%; filter:blur(70px); animation:orb-drift ease-in-out infinite; }
.orb-1 { width:500px; height:500px; top:-10%; right:-5%; background:radial-gradient(circle, rgba(255,94,0,.12) 0%, transparent 70%); animation-duration:12s; }
.orb-2 { width:400px; height:400px; bottom:5%; left:-8%; background:radial-gradient(circle, rgba(0,240,255,.08) 0%, transparent 70%); animation-duration:16s; animation-delay:-4s; }
.orb-3 { width:280px; height:280px; top:50%; right:25%; background:radial-gradient(circle, rgba(255,0,170,.07) 0%, transparent 70%); animation-duration:10s; animation-delay:-8s; }
@keyframes orb-drift { 0%,100%{transform:translate(0,0)} 33%{transform:translate(30px,-25px)} 66%{transform:translate(-20px,20px)} }

/* BG text */
.hero-bg-text {
    position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
    font-family:var(--font-display); font-size:clamp(18vw,28vw,38vw);
    color:var(--black-light); white-space:nowrap; pointer-events:none;
    user-select:none; z-index:0; opacity:.45; letter-spacing:.05em;
}

.hero-inner {
    flex:1; display:grid; grid-template-columns:1fr 1fr;
    gap:3rem; max-width:var(--max-w); margin:0 auto; width:100%;
    padding:3rem 2rem; align-items:center; position:relative; z-index:1;
}

/* Hero left */
.hero-left { padding-top:2rem; }

.hero-badge {
    display:inline-flex; align-items:center; gap:.6rem;
    font-size:.65rem; text-transform:uppercase; letter-spacing:.25em;
    color:var(--gray-300); border:1px solid var(--glass-border);
    padding:.4rem 1rem; border-radius:20px; background:var(--glass-bg);
    backdrop-filter:blur(10px); margin-bottom:2.5rem;
    opacity:0;
}
.badge-dot { width:6px; height:6px; background:var(--orange); border-radius:50%; animation:pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.8)} }
.badge-sep { color:var(--gray-500); }

.hero-title { font-size:clamp(5rem,12vw,10rem); line-height:.88; margin-bottom:2.5rem; }
.title-line { display:block; overflow:hidden; }
.title-word { display:inline-block; transform:translateY(105%); }
.title-word-sm { font-size:.52em; }

.hero-client { display:flex; align-items:center; gap:1.5rem; margin-bottom:2.5rem; opacity:0; }
.client-col { display:flex; flex-direction:column; gap:.25rem; }
.client-label { font-size:.6rem; text-transform:uppercase; letter-spacing:.3em; color:var(--gray-400); }
.client-name { font-family:var(--font-display); font-size:1.8rem; letter-spacing:.1em; line-height:1; }
.client-x { font-family:var(--font-display); font-size:2rem; color:var(--orange); opacity:.6; }

.hero-meta-row { display:flex; gap:0; opacity:0; }
.hm-item { display:flex; flex-direction:column; gap:.3rem; padding:0 1.5rem 0 0; }
.hm-item:first-child { padding-left:0; }
.hm-label { font-size:.6rem; text-transform:uppercase; letter-spacing:.2em; color:var(--gray-400); }
.hm-val { font-size:.95rem; font-weight:500; color:var(--gray-100); }
.hm-price { color:var(--orange); font-family:var(--font-display); font-size:1.3rem; }
.hm-sep { width:1px; background:var(--gray-600); margin:0 1.5rem; align-self:stretch; }

/* Hero right */
.hero-right { position:relative; display:flex; justify-content:center; padding-top:2rem; }

.hero-img-frame {
    width:100%; max-width:480px; aspect-ratio:4/5;
    overflow:hidden; opacity:0;
}
.hero-img { width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease-expo); }
.hero-img-frame:hover .hero-img { transform:scale(1.04); }
.frame-shine {
    position:absolute; inset:0;
    background:linear-gradient(135deg, rgba(255,255,255,.04) 0%, transparent 50%, rgba(255,94,0,.04) 100%);
    pointer-events:none;
}
.frame-tag {
    position:absolute; bottom:1rem; left:1rem;
    display:flex; align-items:center; gap:.5rem;
    font-size:.65rem; text-transform:uppercase; letter-spacing:.2em; color:var(--gray-200);
    background:rgba(10,10,10,.7); backdrop-filter:blur(8px);
    padding:.4rem .8rem; border-radius:20px; border:1px solid var(--glass-border);
}
.ft-dot { width:5px; height:5px; background:var(--orange); border-radius:50%; }

/* Float cards */
.hero-float-card {
    position:absolute; display:flex; flex-direction:column; align-items:center;
    gap:.3rem; padding:1rem 1.4rem; border-radius:var(--r); opacity:0;
    text-align:center;
}
.float-cameras { top:15%; right:-5%; }
.float-drones  { bottom:20%; right:-8%; }
.fc-icon { color:var(--orange); margin-bottom:.2rem; }
.fc-num { font-family:var(--font-display); font-size:2rem; line-height:1; color:var(--white); }
.fc-lbl { font-size:.6rem; text-transform:uppercase; letter-spacing:.15em; color:var(--gray-300); }

/* Scroll indicator */
.hero-scroll {
    display:flex; flex-direction:column; align-items:flex-start; gap:.5rem;
    position:absolute; bottom:2.5rem; left:2rem; z-index:2; opacity:0;
}
.scroll-text { font-size:.6rem; text-transform:uppercase; letter-spacing:.25em; color:var(--gray-400); }
.scroll-line { width:1px; height:60px; background:linear-gradient(to bottom, var(--orange), transparent); animation:scroll-pulse 2s ease-in-out infinite; }
@keyframes scroll-pulse { 0%,100%{opacity:1;transform:scaleY(1)} 50%{opacity:.4;transform:scaleY(.6)} }

/* ── OVERVIEW CARDS ──────────────────────── */
.overview { padding:3rem 0 5rem; }
.overview-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.ov-card { display:flex; align-items:flex-start; gap:1.2rem; padding:2rem; transition:transform var(--t-med); }
.ov-card:hover { transform:translateY(-4px); }
.ov-icon { color:var(--orange); flex-shrink:0; margin-top:.2rem; opacity:.9; }
.ov-body { display:flex; flex-direction:column; gap:.3rem; }
.ov-label { font-size:.6rem; text-transform:uppercase; letter-spacing:.25em; color:var(--orange); }
.ov-value { font-family:var(--font-display); font-size:1.4rem; letter-spacing:.05em; color:var(--white); }
.ov-sub { font-size:.8rem; color:var(--gray-300); }

/* ── SECTION HEADER ──────────────────────── */
.section-header { margin-bottom:4rem; }
.section-meta { display:flex; align-items:center; gap:1rem; margin-bottom:1.2rem; }
.s-num { font-size:.65rem; letter-spacing:.3em; color:var(--orange); font-family:var(--font-body); font-weight:500; }
.s-label { font-size:.65rem; text-transform:uppercase; letter-spacing:.25em; color:var(--gray-400); }
.s-title { font-size:clamp(2.5rem,5vw,4.5rem); line-height:.92; }
.s-desc { font-size:1rem; color:var(--gray-300); line-height:1.7; max-width:520px; margin-top:1.2rem; }

/* ── ALCANCE ──────────────────────────────── */
.alcance-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.al-card { padding:2rem; transition:transform var(--t-med); }
.al-card:hover { transform:translateY(-5px); }
.al-wide { grid-column:span 3; }
.al-wide .al-desc { max-width:640px; }
.al-icon { color:var(--orange); opacity:.85; margin-bottom:1.2rem; }
.al-title { font-family:var(--font-display); font-size:1.3rem; letter-spacing:.05em; margin-bottom:.7rem; color:var(--white); }
.al-desc { font-size:.875rem; color:var(--gray-300); line-height:1.7; }

/* ── EQUIPO ───────────────────────────────── */
.equipo-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5rem; }
.eq-card { padding:1.8rem 1.5rem; position:relative; transition:transform var(--t-med); }
.eq-card:hover { transform:translateY(-6px) scale(1.02); }
.eq-badge {
    display:inline-block; font-size:.55rem; font-weight:600; text-transform:uppercase;
    letter-spacing:.2em; padding:.25rem .7rem; border-radius:20px; margin-bottom:1.5rem;
}
.badge-terrestre { color:var(--orange); background:rgba(255,94,0,.1); border:1px solid rgba(255,94,0,.2); }
.badge-aereo { color:var(--neon-cyan); background:rgba(0,240,255,.08); border:1px solid rgba(0,240,255,.2); }
.badge-audio { color:var(--neon-magenta); background:rgba(255,0,170,.08); border:1px solid rgba(255,0,170,.2); }
.badge-luz { color:var(--neon-purple); background:rgba(139,92,246,.08); border:1px solid rgba(139,92,246,.2); }
.eq-icon-wrap { color:var(--gray-200); margin-bottom:1.2rem; opacity:.7; }
.eq-name { font-family:var(--font-display); font-size:1.1rem; letter-spacing:.04em; margin-bottom:.4rem; }
.eq-spec { font-size:.75rem; color:var(--gray-400); text-transform:uppercase; letter-spacing:.1em; }

/* ── GALERÍA ──────────────────────────────── */
.galeria-grid {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    grid-auto-rows:200px;
    gap:1rem;
}
.gal-item { position:relative; overflow:hidden; border-radius:var(--r); border:1px solid var(--glass-border); }
.gal-item img { width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-expo); }
.gal-item:hover img { transform:scale(1.07); }
.gal-shine { position:absolute; inset:0; background:linear-gradient(135deg,rgba(255,255,255,.05) 0%,transparent 60%); pointer-events:none; opacity:0; transition:opacity var(--t-med); }
.gal-item:hover .gal-shine { opacity:1; }
.gal-wide { grid-column:span 2; }
.gal-tall { grid-row:span 2; }

/* ── VIDEOS ───────────────────────────────── */
.videos-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.vid-card { overflow:hidden; transition:transform var(--t-med); }
.vid-card:hover { transform:translateY(-4px); }
.vid-frame { position:relative; aspect-ratio:16/9; overflow:hidden; background:var(--black-soft); }
.vid-frame iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }
.vid-info { padding:1.5rem; }
.vid-tag { font-size:.6rem; text-transform:uppercase; letter-spacing:.25em; color:var(--orange); display:block; margin-bottom:.6rem; }
.vid-title { font-family:var(--font-display); font-size:1.3rem; letter-spacing:.05em; margin-bottom:.3rem; }
.vid-sub { font-size:.8rem; color:var(--gray-400); }

/* ── ENTREGABLES ─────────────────────────── */
.ent-grid { display:grid; grid-template-columns:1fr 1fr; gap:2rem; }
.ent-card { padding:2.5rem; }
.terminos-card { padding:2.5rem; }
.ent-play-icon { color:var(--orange); margin-bottom:1.5rem; }
.ent-title { font-family:var(--font-display); font-size:1.5rem; letter-spacing:.05em; margin-bottom:1.8rem; color:var(--white); }
.ent-item { display:flex; gap:1rem; align-items:flex-start; margin-bottom:1.5rem; }
.ent-num-tag { font-family:var(--font-display); font-size:2rem; color:var(--orange); opacity:.4; line-height:1; flex-shrink:0; }
.ent-name { font-weight:600; color:var(--white); margin-bottom:.3rem; }
.ent-detail { font-size:.875rem; color:var(--gray-300); line-height:1.6; }
.ent-specs { display:flex; flex-wrap:wrap; gap:.5rem; margin-top:1rem; }
.spec-tag { font-size:.65rem; text-transform:uppercase; letter-spacing:.15em; padding:.25rem .7rem; border:1px solid var(--glass-border); border-radius:20px; color:var(--gray-200); background:var(--glass-bg); }

/* Timeline */
.timeline { display:flex; flex-direction:column; }
.tl-item { display:flex; gap:1rem; padding-bottom:1.5rem; }
.tl-item:last-child { padding-bottom:0; }
.tl-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; margin-top:.4rem; }
.tl-free .tl-dot { background:var(--orange); box-shadow:0 0 10px rgba(255,94,0,.5); }
.tl-connector { position:absolute; width:1px; background:var(--glass-border); }
.tl-dot-extra { background:var(--gray-500); }
.tl-body { flex:1; }
.tl-row { display:flex; align-items:center; gap:.8rem; margin-bottom:.5rem; flex-wrap:wrap; }
.tl-round { font-family:var(--font-display); font-size:1.1rem; letter-spacing:.05em; color:var(--white); }
.tl-tag { font-size:.58rem; font-weight:600; text-transform:uppercase; letter-spacing:.15em; padding:.2rem .6rem; border-radius:20px; }
.tl-free-tag { color:var(--orange); background:rgba(255,94,0,.1); border:1px solid rgba(255,94,0,.25); }
.tl-extra-tag { color:var(--gray-300); background:rgba(255,255,255,.05); border:1px solid var(--glass-border); }
.tl-desc { font-size:.85rem; color:var(--gray-400); line-height:1.6; }

/* Timeline connector line */
.tl-item { position:relative; }
.tl-connector { position:absolute; left:4.5px; top:14px; width:1px; height:calc(100% - 10px); background:var(--glass-border); }

/* ── INVERSIÓN ───────────────────────────── */
.featured-glass {
    box-shadow:0 0 80px rgba(255,94,0,.12), 0 24px 60px rgba(0,0,0,.6), inset 0 1px 0 rgba(255,255,255,.07);
}
.featured-glass::before {
    animation-duration:5s;
    background:conic-gradient(from var(--border-angle), transparent 45%, rgba(255,94,0,.7) 62%, rgba(255,122,46,.4) 75%, rgba(0,240,255,.2) 85%, transparent 95%);
}

.inv-card { display:grid; grid-template-columns:1.1fr auto 1fr; gap:0; padding:3.5rem; align-items:center; }
.inv-left { padding-right:3rem; }
.inv-badge { font-size:.6rem; text-transform:uppercase; letter-spacing:.3em; color:var(--orange); display:block; margin-bottom:1.2rem; }
.inv-price-wrap { display:flex; align-items:flex-start; gap:.3rem; margin-bottom:.8rem; }
.inv-currency { font-family:var(--font-display); font-size:2.5rem; color:var(--orange); margin-top:.8rem; opacity:.7; }
.inv-amount { font-family:var(--font-display); font-size:clamp(5rem,9vw,8rem); line-height:1; color:var(--white); }
.inv-mxn { font-family:var(--font-display); font-size:1.8rem; color:var(--gray-400); align-self:flex-end; margin-bottom:.5rem; }
.inv-note { font-size:.8rem; color:var(--gray-400); text-transform:uppercase; letter-spacing:.15em; }
.inv-divider { width:1px; background:var(--glass-border); align-self:stretch; }
.inv-right { padding-left:3rem; }
.inv-inc-label { font-size:.6rem; text-transform:uppercase; letter-spacing:.3em; color:var(--gray-400); display:block; margin-bottom:1.5rem; }
.inv-list { display:flex; flex-direction:column; gap:.9rem; }
.inv-list li { display:flex; align-items:center; gap:.8rem; font-size:.95rem; color:var(--gray-200); }
.inv-check { color:var(--orange); font-size:1rem; flex-shrink:0; }
.inv-footer { max-width:600px; margin:2.5rem auto 0; text-align:center; font-size:.9rem; color:var(--gray-400); line-height:1.7; }

/* ── CTA ─────────────────────────────────── */
.cta-section { border-top:1px solid var(--gray-600); }
.cta-grid { display:grid; grid-template-columns:1fr 1fr; gap:4rem; align-items:center; }
.cta-title { font-size:clamp(3rem,7vw,6rem); line-height:.92; margin-bottom:1.5rem; }
.cta-desc { font-size:1rem; color:var(--gray-300); line-height:1.7; margin-bottom:2.5rem; max-width:420px; }
.cta-btns { display:flex; gap:1.5rem; align-items:center; flex-wrap:wrap; }

/* Buttons */
.btn-primary {
    display:inline-flex; align-items:center; gap:.8rem;
    padding:.9rem 2rem; background:var(--white); color:var(--black);
    font-size:.8rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em;
    border:none; position:relative; overflow:hidden; border-radius:2px;
    transition:color var(--t-med);
}
.btn-primary::before {
    content:''; position:absolute; inset:0;
    background:var(--orange); transform:translateX(-100%);
    transition:transform var(--t-med);
}
.btn-primary:hover { color:var(--white); }
.btn-primary:hover::before { transform:translateX(0); }
.btn-text,.btn-arrow { position:relative; z-index:1; }
.btn-arrow { transition:transform var(--t-fast); }
.btn-primary:hover .btn-arrow { transform:translateX(4px); }

.btn-ghost {
    display:inline-flex; align-items:center;
    padding:.9rem 0; font-size:.8rem; font-weight:500;
    text-transform:uppercase; letter-spacing:.1em; color:var(--gray-300);
    position:relative; transition:color var(--t-fast);
}
.btn-ghost::after { content:''; position:absolute; bottom:0; left:0; width:0; height:1px; background:var(--white); transition:width var(--t-med); }
.btn-ghost:hover { color:var(--white); }
.btn-ghost:hover::after { width:100%; }

/* Brand card */
.cta-brand-card { padding:2.5rem; display:flex; flex-direction:column; gap:1.2rem; }
.cta-logo { height:40px; width:auto; object-fit:contain; flex-shrink:0; max-width:180px; }
.cta-logo-fallback { font-family:var(--font-display); font-size:1.2rem; letter-spacing:.15em; color:var(--white); }
.cta-brand-info { display:flex; flex-direction:column; gap:.3rem; }
.cta-brand-name { font-family:var(--font-display); font-size:1.4rem; letter-spacing:.08em; }
.cta-brand-tag { font-size:.8rem; color:var(--gray-300); }
.cta-divider { height:1px; background:var(--glass-border); }
.cta-contact { display:flex; flex-direction:column; gap:.4rem; }
.cta-link { font-size:.8rem; color:var(--gray-300); transition:color var(--t-fast); }
.cta-link:hover { color:var(--orange); }

/* ── FOOTER ───────────────────────────────── */
.footer { border-top:1px solid var(--gray-600); }
.footer-marquee { overflow:hidden; padding:.8rem 0; border-bottom:1px solid var(--gray-600); }
.marquee-track { display:flex; white-space:nowrap; animation:marquee 28s linear infinite; gap:1.5rem; }
.marquee-track span { font-family:var(--font-display); font-size:.85rem; letter-spacing:.25em; color:var(--gray-500); }
.m-sep { color:var(--orange) !important; }
@keyframes marquee { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.footer-bar { display:flex; align-items:center; gap:1rem; padding:1.5rem 2rem; max-width:var(--max-w); margin:0 auto; }
.footer-copy,.footer-client { font-size:.8rem; color:var(--gray-400); }
.footer-sep { color:var(--gray-600); }

/* ── SCROLL REVEALS ──────────────────────── */
.reveal {
    opacity:0;
    transform:translateY(40px);
    transition:opacity .8s var(--ease-expo) var(--delay,0s),
                transform .8s var(--ease-expo) var(--delay,0s);
}
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── RESPONSIVE ───────────────────────────── */
@media(max-width:1200px) {
    .equipo-grid { grid-template-columns:repeat(3,1fr); }
    .galeria-grid { grid-template-columns:repeat(3,1fr); }
}

@media(max-width:1024px) {
    .hero-inner { grid-template-columns:1fr; }
    .hero-right { justify-content:flex-start; }
    .hero-img-frame { max-width:100%; aspect-ratio:16/9; }
    .float-cameras,.float-drones { display:none; }
    .overview-grid { grid-template-columns:repeat(2,1fr); }
    .alcance-grid { grid-template-columns:1fr 1fr; }
    .al-wide { grid-column:span 2; }
    .equipo-grid { grid-template-columns:repeat(2,1fr); }
    .ent-grid { grid-template-columns:1fr; }
    .inv-card { grid-template-columns:1fr; gap:2rem; }
    .inv-divider { width:100%; height:1px; }
    .inv-right { padding-left:0; }
    .inv-left { padding-right:0; }
    .cta-grid { grid-template-columns:1fr; }
}

/* ── MOBILE (≤768px) — 2-col layout + performance ── */
@media(max-width:768px) {
    :root { --nav-h:56px; }
    .container { padding:0 1rem; }
    .section-padded { padding:3.5rem 0; }
    .section-header { margin-bottom:1.8rem; }
    .nav { padding:0 1rem; }
    .nav-tagline { display:none; }

    /* 2-col grids en toda la versión mobile */
    .overview-grid { grid-template-columns:repeat(2,1fr); gap:.75rem; }
    .alcance-grid  { grid-template-columns:repeat(2,1fr); gap:.75rem; }
    .al-wide       { grid-column:span 2; }
    .equipo-grid   { grid-template-columns:repeat(2,1fr); gap:.75rem; }
    .galeria-grid  { grid-template-columns:repeat(2,1fr); grid-auto-rows:140px; gap:.5rem; }
    .gal-wide      { grid-column:span 2; }
    .gal-tall      { grid-row:span 1; }
    .videos-grid   { grid-template-columns:1fr; }

    /* Reducción de padding en cards */
    .ov-card                   { padding:1rem; gap:.75rem; }
    .al-card                   { padding:1rem; }
    .eq-card                   { padding:1rem .85rem; }
    .ent-card,.terminos-card   { padding:1.5rem 1.2rem; }
    .inv-card                  { padding:1.5rem; }
    .cta-brand-card            { padding:1.5rem; }

    /* Hero */
    .hero-inner    { padding:1.5rem 1rem; gap:1.5rem; }
    .hero-badge    { margin-bottom:1.2rem; }
    .hero-client   { margin-bottom:1.2rem; }
    .hero-meta-row { flex-direction:column; gap:.8rem; }
    .hm-sep        { display:none; }

    /* Inversión */
    .inv-amount    { font-size:4.5rem; }
    .inv-currency  { font-size:2rem; margin-top:.5rem; }

    /* CTA */
    .cta-btns { flex-direction:column; align-items:flex-start; }

    /* Performance: reducir efectos pesados en mobile */
    .glass-card         { backdrop-filter:blur(10px) saturate(130%); -webkit-backdrop-filter:blur(10px) saturate(130%); }
    .glass-card::before { animation:none; }
    .orb                { display:none; }
}

/* ── XS (≤480px) — mantener 2 cols, ajustes de tipografía ── */
@media(max-width:480px) {
    html { font-size:13px; }

    /* Mantener 2 columnas en pantallas muy pequeñas */
    .overview-grid { grid-template-columns:repeat(2,1fr); }
    .alcance-grid  { grid-template-columns:repeat(2,1fr); }
    .al-wide       { grid-column:span 2; }
    .equipo-grid   { grid-template-columns:repeat(2,1fr); }
    .galeria-grid  { grid-template-columns:repeat(2,1fr); grid-auto-rows:120px; }
    .gal-wide      { grid-column:span 2; }

    /* Tipografía ajustada para pantallas pequeñas */
    .hero-title { font-size:clamp(3.5rem,16vw,5.5rem); }
    .s-title    { font-size:2rem; }
    .ov-value   { font-size:1.1rem; }
    .al-title   { font-size:1rem; }
    .eq-name    { font-size:.9rem; }
    .inv-amount { font-size:4rem; }

    /* Performance: ocultar elementos decorativos */
    .hero-bg-text  { display:none; }
    .noise-overlay { display:none; }
}

/* Print */
@media print {
    .noise-overlay,.cursor,.cursor-follower,.hero-orbs,.hero-bg-text { display:none !important; }
    body { background:white; color:black; }
}
