/* ═══════════════════════════════════════════
   VICOSG · styles.css · v1.0
   Edita aquí para cambiar colores, fuentes, etc.
═══════════════════════════════════════════ */

/* ── VARIABLES ── */
:root {
  --ink:   #070708;
  --ink2:  #0e0e10;
  --ink3:  #161618;
  --lime:  #c8f000;
  --lime2: #a3c700;
  --lg:    rgba(200,240,0,0.07);
  --white: #f2ede6;
  --off:   #b0aa9f;
  --muted: #555260;
  --line:  rgba(255,255,255,0.07);
  --line2: rgba(255,255,255,0.13);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--ink);color:var(--white);font-family:"DM Sans",sans-serif;font-weight:300;overflow-x:hidden;cursor:none}

.cur{position:fixed;width:10px;height:10px;background:var(--lime);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);mix-blend-mode:exclusion;transition:width .3s,height .3s}
.cur-r{position:fixed;width:36px;height:36px;border:1.5px solid var(--lime);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);opacity:.45;transition:width .3s,height .3s,opacity .3s}

body::before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.05'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.3}

@keyframes fadeUp{from{opacity:0;transform:translateY(36px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes scaleIn{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s ease,transform .75s ease}
.reveal.on{opacity:1;transform:translateY(0)}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:500;padding:0 48px;height:66px;display:flex;align-items:center;justify-content:space-between;background:rgba(7,7,8,.88);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);animation:fadeIn .8s ease .2s both}
.logo{font-family:"Bebas Neue",sans-serif;font-size:24px;letter-spacing:4px;color:var(--white);text-decoration:none}
.logo span{color:var(--lime)}
.nav-links{display:flex;gap:32px;list-style:none}
.nav-links a{font-family:"DM Mono",monospace;font-size:10px;letter-spacing:2px;color:var(--muted);text-decoration:none;text-transform:uppercase;transition:color .2s}
.nav-links a:hover{color:var(--white)}
.nav-r{display:flex;gap:10px;align-items:center}

/* BUTTONS */
.btn{font-family:"Oswald",sans-serif;font-weight:600;font-size:12px;letter-spacing:2.5px;text-transform:uppercase;text-decoration:none;padding:11px 26px;border-radius:3px;cursor:none;border:none;transition:all .25s;display:inline-flex;align-items:center;gap:8px}
.btn-p{background:var(--lime);color:var(--ink)}
.btn-p:hover{background:var(--lime2);transform:translateY(-1px);box-shadow:0 8px 28px rgba(200,240,0,.2)}
.btn-g{background:transparent;color:var(--white);border:1px solid var(--line2)}
.btn-g:hover{border-color:var(--white)}
.btn-lg{font-size:14px;padding:17px 42px;letter-spacing:3px}
.btn-full{width:100%;justify-content:center}

/* HERO */
.hero{min-height:100vh;padding-top:66px;display:grid;grid-template-columns:1fr 1fr;position:relative;overflow:hidden}
.hero-l{padding:70px 48px 70px 80px;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}
.hero-eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:24px;animation:fadeUp .8s ease .4s both}
.eyebrow-line{width:38px;height:2px;background:var(--lime);transform-origin:left;animation:scaleIn .6s ease .8s both}
.eyebrow-txt{font-family:"DM Mono",monospace;font-size:10px;letter-spacing:4px;color:var(--lime);text-transform:uppercase}
.hero-h1{font-family:"Bebas Neue",sans-serif;font-size:clamp(68px,8vw,116px);line-height:.87;letter-spacing:2px;margin-bottom:28px;animation:fadeUp .8s ease .5s both}
.hero-h1 .gl{color:var(--lime)}
.hero-h1 .gd{color:rgba(242,237,230,.15)}
.hero-desc{font-size:15px;line-height:1.7;color:var(--off);max-width:390px;margin-bottom:36px;animation:fadeUp .8s ease .65s both}
.hero-actions{display:flex;align-items:center;gap:14px;margin-bottom:48px;animation:fadeUp .8s ease .75s both}
.hero-proof{display:flex;align-items:center;gap:16px;animation:fadeUp .8s ease .85s both}
.proof-avs{display:flex}
.proof-av{width:30px;height:30px;border-radius:50%;border:2px solid var(--ink);margin-left:-9px;overflow:hidden;flex-shrink:0;background:var(--ink3)}
.proof-av:first-child{margin-left:0}
.proof-av img{width:100%;height:100%;object-fit:cover}
.proof-av-plus{display:flex;align-items:center;justify-content:center;font-family:"Bebas Neue",sans-serif;font-size:10px;color:var(--lime)}
.proof-txt{font-size:12px;color:var(--muted);line-height:1.4}
.proof-txt strong{color:var(--white);font-weight:500}
.hero-r{position:relative;overflow:hidden;animation:fadeIn 1s ease .3s both}
.hero-photo-main{position:absolute;inset:0;overflow:hidden}
.hero-photo-main img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:brightness(.7) contrast(1.1)}
.hero-photo-main::after{content:"";position:absolute;inset:0;background:linear-gradient(to right,var(--ink) 0%,transparent 35%),linear-gradient(to top,var(--ink) 0%,transparent 30%)}
.hero-float-card{position:absolute;bottom:48px;right:40px;background:rgba(14,14,16,.9);backdrop-filter:blur(12px);border:1px solid var(--line2);border-radius:14px;padding:20px 24px;animation:float 6s ease-in-out infinite}
.hero-float-card::before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,transparent,var(--lime),transparent);border-radius:14px 14px 0 0}
.fc-label{font-family:"DM Mono",monospace;font-size:8px;letter-spacing:3px;color:var(--lime);text-transform:uppercase;margin-bottom:6px}
.fc-val{font-family:"Bebas Neue",sans-serif;font-size:52px;color:var(--white);line-height:1;letter-spacing:-1px}
.fc-val sup{font-size:22px;color:var(--lime);font-family:"DM Sans",sans-serif;font-weight:300}
.fc-sub{font-size:12px;color:var(--off);margin-top:4px;font-weight:300}
.prog-track{height:3px;background:var(--ink);border-radius:2px;margin-top:14px;overflow:hidden}
.prog-fill{height:100%;background:var(--lime);border-radius:2px;width:70%;animation:scaleIn 1.4s ease 1s both;transform-origin:left}
.live-badge{position:absolute;top:20px;left:20px;display:flex;align-items:center;gap:6px;background:rgba(7,7,8,.85);backdrop-filter:blur(8px);border:1px solid var(--line2);border-radius:100px;padding:5px 12px;font-family:"DM Mono",monospace;font-size:9px;color:var(--lime);letter-spacing:2px}
.live-dot-g{width:6px;height:6px;border-radius:50%;background:var(--lime);animation:pulse 1.5s ease infinite;flex-shrink:0}

/* MARQUEE */
.marquee{background:var(--lime);padding:13px 0;overflow:hidden;border-top:1px solid rgba(0,0,0,.1);border-bottom:1px solid rgba(0,0,0,.1)}
.marquee-track{display:flex;animation:marquee 24s linear infinite;width:max-content}
.mi{display:flex;align-items:center;gap:18px;padding:0 28px;white-space:nowrap;font-family:"Bebas Neue",sans-serif;font-size:14px;letter-spacing:3px;color:var(--ink)}
.md{width:4px;height:4px;border-radius:50%;background:rgba(7,7,8,.3);flex-shrink:0}

/* COMMONS */
.container{max-width:1180px;margin:0 auto;padding:0 80px}
.sec-eye{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.sec-eye span{font-family:"DM Mono",monospace;font-size:10px;letter-spacing:4px;color:var(--lime);text-transform:uppercase}
.sec-eye::after{content:"";flex:1;height:1px;background:var(--line)}
.sec-eye-center{justify-content:center}
.sec-eye-center::after{display:none}
.sec-h2{font-family:"Bebas Neue",sans-serif;font-size:clamp(44px,4.5vw,68px);letter-spacing:1px;line-height:.9;margin-bottom:18px}
.sec-h2 em{color:var(--lime);font-style:normal}
.sec-p{font-size:14px;color:var(--off);line-height:1.75;font-weight:300;margin-bottom:14px}
.sec-sub-sm{font-size:14px;color:var(--off);line-height:1.65;font-weight:300;max-width:480px;margin-top:12px}
.text-center{text-align:center}

/* ABOUT */
.about{padding:110px 0;background:var(--ink2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.mosaic{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:auto auto;gap:10px;position:relative}
.mosaic-a{grid-column:1;grid-row:1/3;border-radius:14px;overflow:hidden;aspect-ratio:3/4}
.mosaic-b{grid-column:2;grid-row:1;border-radius:14px;overflow:hidden;aspect-ratio:1/1}
.mosaic-c{grid-column:2;grid-row:2;border-radius:14px;overflow:hidden;aspect-ratio:1/1}
.mosaic img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s ease;display:block}
.mosaic-a img{object-position:center 20%}
.mosaic div:hover img{transform:scale(1.04)}
.mosaic-tag{position:absolute;bottom:-16px;right:-16px;background:var(--lime);color:var(--ink);font-family:"Bebas Neue",sans-serif;font-size:12px;letter-spacing:2px;padding:8px 16px;border-radius:6px;animation:float 5s ease-in-out 1s infinite}
.about-creds{margin-top:24px;display:flex;flex-direction:column;gap:10px}
.cred{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--off)}
.cred::before{content:"";width:22px;height:1.5px;background:var(--lime);flex-shrink:0}
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px;padding-top:28px;border-top:1px solid var(--line)}
.st-v{font-family:"Bebas Neue",sans-serif;font-size:38px;color:var(--white);line-height:1;margin-bottom:3px}
.st-v sup{font-size:18px;color:var(--lime)}
.st-l{font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}

/* GALLERY */
.gallery{overflow:hidden;background:var(--ink3);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.gallery-inner{display:flex;gap:4px}
.gallery-item{flex:1;min-width:200px;height:320px;overflow:hidden;cursor:none;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .6s ease,filter .4s ease;filter:brightness(.75) contrast(1.05);display:block}
.gallery-item:hover img{transform:scale(1.06);filter:brightness(.9) contrast(1.1)}
.gallery-item:hover .g-overlay{opacity:1}
.g-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(7,7,8,.8) 0%,transparent 50%);display:flex;align-items:flex-end;padding:16px;opacity:0;transition:opacity .3s}
.g-tag{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:2px;color:var(--lime);text-transform:uppercase}

/* PILLARS */
.pillars{padding:110px 0}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin-top:60px}
.pillar{background:var(--ink);padding:40px 32px;position:relative;overflow:hidden;transition:background .3s;cursor:none}
.pillar:hover{background:var(--ink2)}
.pillar::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--lime);transform:scaleX(0);transform-origin:left;transition:transform .4s ease}
.pillar:hover::after{transform:scaleX(1)}
.pillar-alt{background:var(--ink2)}
.p-num{font-family:"Bebas Neue",sans-serif;font-size:78px;color:rgba(255,255,255,.03);line-height:1;position:absolute;top:14px;right:18px;letter-spacing:-2px;pointer-events:none}
.p-icon{font-size:34px;margin-bottom:18px;display:block}
.p-name{font-family:"Bebas Neue",sans-serif;font-size:28px;letter-spacing:1px;margin-bottom:10px}
.p-desc{font-size:13px;color:var(--off);line-height:1.65;font-weight:300}
.p-list{list-style:none;margin-top:18px;display:flex;flex-direction:column;gap:7px}
.p-list li{font-size:11px;color:var(--muted);display:flex;align-items:flex-start;gap:8px;line-height:1.4}
.p-list li::before{content:"→";color:var(--lime);font-size:10px;flex-shrink:0;margin-top:1px}

/* RESULTS */
.results{padding:110px 0;background:var(--ink2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.nums-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;background:var(--line);border:1px solid var(--line);border-radius:16px;overflow:hidden;margin:60px 0}
.num-cell{background:var(--ink2);padding:40px 28px;text-align:center;transition:background .3s;cursor:none}
.num-cell:hover{background:var(--ink3)}
.num-v{font-family:"Bebas Neue",sans-serif;font-size:66px;color:var(--white);line-height:1;letter-spacing:-1px;margin-bottom:6px}
.num-v sup{font-size:26px;color:var(--lime);letter-spacing:0}
.num-l{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;line-height:1.5}
.testis{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.testi{background:var(--ink3);border:1px solid var(--line);border-radius:12px;padding:26px;transition:border-color .2s,transform .2s;cursor:none}
.testi:hover{border-color:var(--line2);transform:translateY(-3px)}
.tq{font-family:"Bebas Neue",sans-serif;font-size:30px;color:var(--lime);line-height:1;margin-bottom:10px;opacity:.45}
.tt{font-size:13px;color:var(--off);line-height:1.65;font-style:italic;margin-bottom:18px;font-weight:300}
.ta{display:flex;align-items:center;gap:10px}
.ta-av{width:34px;height:34px;border-radius:50%;overflow:hidden;flex-shrink:0;border:1px solid var(--line2)}
.ta-av img{width:100%;height:100%;object-fit:cover;object-position:center top}
.ta-av-txt{display:flex;align-items:center;justify-content:center;background:var(--ink2);font-family:"Bebas Neue",sans-serif;font-size:13px;color:var(--lime)}
.ta-name{font-weight:500;font-size:13px}
.ta-loc{font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:1px;margin-top:1px}
.tr{margin-top:14px;padding-top:14px;border-top:1px solid var(--line);font-family:"DM Mono",monospace;font-size:10px;color:var(--lime);letter-spacing:1px}

/* IA */
.ia-sec{padding:110px 0}
.ia-grid{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;margin-top:60px}
.chat-box{background:var(--ink2);border:1px solid var(--line2);border-radius:20px;overflow:hidden;box-shadow:0 40px 80px rgba(0,0,0,.5)}
.chat-top{padding:14px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;background:var(--ink3)}
.chat-av{width:36px;height:36px;border-radius:50%;overflow:hidden;border:2px solid var(--lime);flex-shrink:0}
.chat-av img{width:100%;height:100%;object-fit:cover;object-position:center top}
.chat-info strong{font-size:14px;font-weight:500;display:block}
.online{font-family:"DM Mono",monospace;font-size:9px;color:var(--lime);letter-spacing:1px;display:flex;align-items:center;gap:4px}
.online::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--lime);box-shadow:0 0 6px var(--lime)}
.chat-body{padding:20px;display:flex;flex-direction:column;gap:12px}
.mb,.mu{max-width:75%;padding:11px 14px;border-radius:12px;font-size:13px;line-height:1.55}
.mb{background:var(--ink3);border:1px solid var(--line);color:var(--off);border-radius:3px 12px 12px 12px;align-self:flex-start}
.mb strong{color:var(--lime);font-weight:500}
.mu{background:var(--lg);border:1px solid rgba(200,240,0,.14);color:var(--white);border-radius:12px 3px 12px 12px;align-self:flex-end}
.chat-in{padding:12px 18px;border-top:1px solid var(--line);display:flex;gap:8px;align-items:center}
.chat-in-f{flex:1;background:var(--ink3);border:1px solid var(--line2);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--muted);font-family:"DM Sans",sans-serif}
.chat-send{width:32px;height:32px;background:var(--lime);border-radius:7px;display:flex;align-items:center;justify-content:center;color:var(--ink);font-size:13px;font-weight:700;flex-shrink:0}
.ia-feats{display:flex;flex-direction:column;gap:22px}
.ia-intro{font-size:15px;color:var(--off);line-height:1.7;font-weight:300;margin-bottom:32px}
.ia-feat{display:flex;gap:18px;align-items:flex-start}
.ia-feat-icon{width:42px;height:42px;background:var(--lg);border:1px solid rgba(200,240,0,.14);border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
.ia-feat h4{font-family:"Oswald",sans-serif;font-weight:600;font-size:15px;letter-spacing:.5px;margin-bottom:3px}
.ia-feat p{font-size:13px;color:var(--muted);line-height:1.55;font-weight:300}

/* PRICING */
.pricing{padding:110px 0;background:var(--ink2);border-top:1px solid var(--line)}
.pricing-sub{font-size:14px;color:var(--off);text-align:center;margin-top:10px;font-weight:300}
.price-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;max-width:940px;margin:60px auto 0}
.pc{background:var(--ink);border:1px solid var(--line);border-radius:16px;padding:34px 26px;position:relative;transition:transform .25s,border-color .25s;cursor:none}
.pc:hover{transform:translateY(-5px);border-color:var(--line2)}
.pc.ft{border-color:var(--lime);background:linear-gradient(160deg,rgba(200,240,0,.05) 0%,var(--ink) 60%)}
.pc-badge{position:absolute;top:-12px;left:50%;transform:translateX(-50%);background:var(--lime);color:var(--ink);font-family:"DM Mono",monospace;font-size:9px;font-weight:500;padding:4px 16px;border-radius:100px;letter-spacing:2px;white-space:nowrap;text-transform:uppercase}
.pc-period{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:3px;color:var(--muted);text-transform:uppercase;margin-bottom:14px}
.pc-price{font-family:"Bebas Neue",sans-serif;font-size:60px;color:var(--white);line-height:1;letter-spacing:-1px}
.pc-price .c{font-size:24px;color:var(--muted);vertical-align:top;margin-top:10px;display:inline-block}
.pc-price .dec{font-size:32px}
.pc-price .p{font-size:14px;color:var(--muted);font-family:"DM Sans",sans-serif;font-weight:300;letter-spacing:0}
.pc-save{font-family:"DM Mono",monospace;font-size:10px;color:var(--lime);letter-spacing:1px;height:18px;margin:4px 0 22px}
.pc-feats{list-style:none;display:flex;flex-direction:column;gap:9px;margin-bottom:24px}
.pc-feats li{display:flex;align-items:flex-start;gap:9px;font-size:13px;color:var(--off);line-height:1.4}
.pc-feats li::before{content:"✓";color:var(--lime);font-weight:700;font-size:11px;flex-shrink:0;margin-top:1px}
.pricing-legal{text-align:center;margin-top:22px;font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:1.5px}

/* CTA FINAL */
.cta-f{padding:150px 0;text-align:center;position:relative;overflow:hidden}
.cta-f::before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:700px;height:700px;background:radial-gradient(circle,rgba(200,240,0,.05) 0%,transparent 70%);pointer-events:none}
.cta-f-h{font-family:"Bebas Neue",sans-serif;font-size:clamp(60px,8vw,108px);line-height:.87;letter-spacing:2px;margin-bottom:22px;position:relative}
.cta-f-h em{color:var(--lime);font-style:normal}
.cta-f-h .dim{color:rgba(242,237,230,.12)}
.cta-f-sub{font-size:15px;color:var(--off);max-width:420px;margin:0 auto 40px;line-height:1.65;font-weight:300}
.cta-f-acts{display:flex;justify-content:center;align-items:center;gap:14px;flex-wrap:wrap}
.cta-guar{margin-top:18px;font-family:"DM Mono",monospace;font-size:10px;color:var(--muted);letter-spacing:1.5px;text-transform:uppercase}

/* FOOTER */
footer{background:var(--ink2);border-top:1px solid var(--line);padding:44px 80px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.f-logo{font-family:"Bebas Neue",sans-serif;font-size:20px;letter-spacing:3px}
.f-logo span{color:var(--lime)}
.f-links{display:flex;gap:24px;list-style:none}
.f-links a{font-family:"DM Mono",monospace;font-size:9px;letter-spacing:1.5px;color:var(--muted);text-decoration:none;text-transform:uppercase;transition:color .2s}
.f-links a:hover{color:var(--white)}
.f-ig{display:flex;align-items:center;gap:6px;font-family:"DM Mono",monospace;font-size:9px;color:var(--muted);letter-spacing:1px;text-decoration:none;transition:color .2s}
.f-ig:hover{color:var(--lime)}

/* RESPONSIVE */
@media(max-width:960px){
  nav{padding:0 20px}
  .nav-links{display:none}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-l{padding:80px 20px 40px}
  .hero-r{height:60vw;min-height:280px}
  .container{padding:0 20px}
  .about-grid,.ia-grid{grid-template-columns:1fr;gap:36px}
  .pillars-grid{grid-template-columns:1fr}
  .nums-grid{grid-template-columns:1fr 1fr}
  .testis{grid-template-columns:1fr}
  .price-grid{grid-template-columns:1fr;max-width:360px;margin-left:auto;margin-right:auto}
  .gallery-item{min-width:160px;height:240px}
  footer{flex-direction:column;padding:32px 20px;text-align:center}
  .f-links{flex-wrap:wrap;justify-content:center}
}
