
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --ap:#12133a;--as:#060f30;--at:#024858;
  --bg:#010101;--gb:rgba(1,9,38,0.12);
  --gb2:rgba(255,255,255,0.18);--gh:rgba(255,255,255,0.22);
  --tp:#f8fafc;--ts:#94a3b8;--tm:#64748b;
  --sw:300px;--rl:28px;--rm:18px;--rs:12px;
  --gold:#3adffa;
  --liquid-primary:#1c1f43;
  --liquid-secondary:#0a4d60;
  --liquid-tertiary:#081843;
  --liquid-bg:#000204;
  --liquid-surface:rgba(1,2,6,0.94);
  --liquid-text:#dee5ff;
  --liquid-text-muted:#a3aac4;
--gold-light:#646aa3;
  --font-serif:'Inter',serif;
  --font-sans:'Inter','Segoe UI',system-ui,sans-serif;
  --glass:rgba(1,9,38,0.12);
  --glass-border:rgba(255,255,255,0.18);
}
body{font-family:'Inter',system-ui,sans-serif;font-weight:400;background:var(--bg);color:var(--tp);overflow-x:hidden}
a{text-decoration:none;color:inherit}
#sp{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,var(--ap),var(--as),var(--at));z-index:999;transition:width .1s linear}
.blobs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.blob{position:absolute;border-radius:50%;filter:blur(80px);animation:bm 20s ease-in-out infinite;will-change:transform;transform:translateZ(0)}
.b1{width:700px;height:700px;background:var(--ap);top:-20%;left:-15%;opacity:.05}
.b2{width:600px;height:600px;background:var(--as);bottom:-10%;right:-10%;opacity:.04;animation-delay:-7s}
.b3{width:500px;height:500px;background:var(--at);top:40%;left:40%;opacity:.03;animation-delay:-14s}
@keyframes bm{0%{transform:translate(0,0) scale(1)}33%{transform:translate(60px,-40px) scale(1.08)}66%{transform:translate(-40px,60px) scale(.94)}100%{transform:translate(0,0) scale(1)}}
.ov{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:189;opacity:0;pointer-events:none;transition:opacity .3s}
body.sb-open .ov{opacity:1;pointer-events:auto}
.sb{position:fixed;top:0;left:0;width:var(--sw);height:100vh;background:rgba(1,9,38,0.18);backdrop-filter:blur(20px) saturate(200%);-webkit-backdrop-filter:blur(20px) saturate(200%);border-right:1px solid rgba(255,255,255,0.18);box-shadow:0 0 48px rgba(0,0,0,0.3),inset 1px 0 0 rgba(255,255,255,0.1);display:flex;flex-direction:column;z-index:200;transform:translateX(-100%);transition:transform .35s cubic-bezier(.4,0,.2,1)}
body.sb-open .sb{transform:translateX(0)}
.sb-hd{padding:32px 24px 24px;border-bottom:1px solid var(--gb2);flex-shrink:0}
.sb-hd h1{font-size:26px;font-weight:700;letter-spacing:2px;background:linear-gradient(135deg,var(--ap),var(--as));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sb-hd p{font-size:11px;color:var(--tm);margin-top:4px}
.sb-nav{padding:20px 12px;flex:1;overflow-y:auto}
.sb-nav a{display:flex;align-items:center;gap:12px;padding:11px 16px;border-radius:var(--rs);color:var(--tm);font-size:13px;margin-bottom:2px;transition:all .2s;cursor:pointer}
.sb-nav a:hover{background:rgba(14,20,80,.12);color:var(--ts)}
.sb-nav a.active{background:rgba(14,20,80,.18);color:var(--ap);box-shadow:inset 3px 0 0 var(--ap)}
.sb-nav a svg{width:17px;height:17px;flex-shrink:0;stroke-width:1.7}
.sb-div{height:1px;background:var(--gb2);margin:12px 16px}
.sb-lbl{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--tm);padding:8px 16px 4px;display:block}
.sb-ft{padding:16px;border-top:1px solid var(--gb2);flex-shrink:0}
.sb-ft a{display:flex;align-items:center;gap:8px;color:var(--tm);font-size:12px;padding:9px 12px;border-radius:var(--rs);transition:.2s;cursor:pointer}
.sb-ft a:hover{color:var(--ap);background:rgba(14,20,80,.12)}
.tb{position:fixed;top:18px;left:18px;z-index:210;width:44px;height:44px;border-radius:var(--rs);background:rgba(1,1,4,.96);backdrop-filter:blur(20px);border:1px solid var(--gh);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s}
.tb:hover{background:rgba(20,22,80,.3);border-color:rgba(30,32,96,.5)}
.tb svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2}
.main{position:relative;z-index:1}

/* SPA Page Sections */
.page-section{display:none;position:relative;z-index:1;min-height:100vh;content-visibility:auto;contain-intrinsic-size:0 600px}
.page-section.active{display:block}

/* Homepage vertical gradient: near-black top → dark navy bottom */
#home {
    background: linear-gradient(
        to bottom,
        #010101 0%,
        #020305 22%,
        #03060f 45%,
        #050a1c 68%,
        #080f2a 85%,
        #0d1840 100%
    );
}

/* FIX: Ocultar sidebar de webs cuando su seccion no esta activa */
#webs:not(.active),#webs:not(.active) *{display:none!important;visibility:hidden!important;opacity:0!important}
#webs.active,#webs.active .webs-sidebar{display:flex!important;visibility:visible!important;opacity:1!important}

/* HOME STYLES */
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:80px 40px;overflow:hidden}
.hv{position:absolute;inset:0;z-index:0}
.hv video{width:100%;height:100%;object-fit:cover}
.ho{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,2,.88),rgba(0,0,2,.97));z-index:1}
.hc{text-align:center;position:relative;z-index:2;max-width:900px}
.hdg{display:inline-flex;align-items:center;gap:8px;padding:8px 22px;background:rgba(14,20,80,.22);border:1px solid rgba(255,255,255,.12);border-top-color:rgba(255,255,255,.2);border-radius:50px;font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--ts);margin-bottom:36px}
.hdg-dot{width:6px;height:6px;border-radius:50%;background:var(--at);animation:pu 2s infinite}
@keyframes pu{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.hero h1{font-size:clamp(58px,10vw,138px);font-weight:700;line-height:1;letter-spacing:-2px;margin-bottom:28px}
.grad{background:linear-gradient(135deg,var(--ap),var(--as),var(--at));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-sub{font-size:16px;color:var(--ts);line-height:1.8;max-width:600px;margin:0 auto 44px;font-weight:300}
.hbtns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.btn-p{padding:15px 38px;background:linear-gradient(135deg,var(--ap),var(--as));color:#fff;font-size:13px;letter-spacing:1px;font-weight:600;border:none;border-radius:50px;cursor:pointer;transition:all .3s;font-family:inherit;box-shadow:0 0 40px rgba(14,20,80,.25)}
.btn-p:hover{transform:translateY(-2px);box-shadow:0 8px 50px rgba(14,20,80,.4)}
.btn-o{padding:15px 38px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.18);color:var(--tp);font-size:13px;letter-spacing:1px;font-weight:500;border-radius:50px;cursor:pointer;transition:all .3s;font-family:inherit}
.btn-o:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.3)}
.hscr{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer;z-index:3;animation:fu 1s ease 1.5s both;opacity:0}
.hscr span{font-size:9px;color:var(--tm);letter-spacing:2.5px;text-transform:uppercase}
.sln{width:1px;height:40px;background:linear-gradient(to bottom,transparent,var(--ap));animation:sl 2s infinite}
@keyframes sl{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}51%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}
@keyframes fu{from{opacity:0;transform:translateX(-50%) translateY(20px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.sec{position:relative;z-index:1;padding:100px 50px;max-width:1200px;margin:0 auto;width:100%}
.sec-lbl{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--ap);margin-bottom:12px;font-weight:500}
.sec-title{font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:-1px;color:#fff;margin-bottom:14px;line-height:1.1}
.sec-desc{font-size:15px;color:var(--ts);max-width:560px;line-height:1.8;margin-bottom:52px;font-weight:300}
.sec-c{text-align:center}.sec-c .sec-desc{margin-left:auto;margin-right:auto}
.stats-wr{padding:0 50px 60px;max-width:1100px;margin:0 auto;width:100%}
.stats-inner{display:flex;justify-content:space-around;align-items:center;flex-wrap:wrap;gap:24px;background:rgba(1,9,38,0.28);border:1px solid rgba(255,255,255,0.18);border-top:1px solid rgba(255,255,255,0.22);border-radius:var(--rl);padding:40px 48px;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.stat{text-align:center;flex:1;min-width:130px}
.stat-dv{width:1px;height:50px;background:var(--gb2);flex-shrink:0}
.sn{font-size:38px;font-weight:700;letter-spacing:-1px;background:linear-gradient(135deg,var(--ap),var(--as),var(--at));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}
.sl2{font-size:11px;color:var(--tm);letter-spacing:1.5px;text-transform:uppercase;margin-top:6px}
.sg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sc{background:rgba(1,9,38,0.28);border:1px solid var(--gb2);border-top:1px solid var(--gh);border-radius:var(--rl);overflow:hidden;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;cursor:pointer;display:block;color:inherit;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.sc::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--ap),var(--as),var(--at));opacity:0;transition:opacity .4s;z-index:2}
.sc:hover{border-color:rgba(14,20,80,.35);transform:translateY(-8px) scale(1.01);box-shadow:0 24px 80px rgba(0,0,0,.7)}
.sc:hover::before,.sc:hover .sa{opacity:1}
.sc:hover .si img{transform:scale(1.08)}
.si{width:100%;height:190px;overflow:hidden;position:relative}
.si img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.sio{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,2,.99) 0%,rgba(0,0,2,.5) 60%,transparent 100%)}
.sb2{padding:24px 26px 28px}
.sb2 h3{font-size:18px;font-weight:600;color:#fff;margin-bottom:10px}
.sb2 p{font-size:13px;color:var(--ts);line-height:1.7;margin-bottom:16px;font-weight:300}
.sts{display:flex;flex-wrap:wrap;gap:6px}
.st{padding:4px 12px;background:rgba(14,20,80,.12);border:1px solid rgba(14,20,80,.25);border-radius:50px;font-size:10px;color:var(--ap);font-weight:500}
.sa{position:absolute;bottom:22px;right:22px;width:32px;height:32px;border-radius:50%;background:rgba(14,20,80,.18);border:1px solid rgba(14,20,80,.35);display:flex;align-items:center;justify-content:center;transition:.3s;opacity:0}
.sa svg{width:14px;height:14px;stroke:var(--ap)}
.bgb{position:relative;overflow:hidden;min-height:55vh;display:flex;align-items:center;justify-content:center}
.bgbc{position:absolute;inset:0;z-index:0}
.bgs{position:absolute;inset:0;opacity:0;transition:opacity 1.5s ease}
.bgs.active{opacity:1}
.bgs img{width:100%;height:100%;object-fit:cover}
.bgbo{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,2,.93),rgba(0,0,2,.99));z-index:1}
.bgbc2{position:relative;z-index:2;text-align:center;padding:60px 40px;max-width:800px}
.bgbc2 h2{font-size:clamp(26px,4vw,40px);font-weight:700;letter-spacing:-1px;color:#fff;margin-bottom:14px}
.bgbc2 p{font-size:15px;color:var(--ts);line-height:1.8;font-weight:300}
.pt{display:grid;grid-template-columns:repeat(4,1fr);gap:0;position:relative}
.pt::before{content:'';position:absolute;top:52px;left:12.5%;right:12.5%;height:1px;background:linear-gradient(90deg,var(--ap),var(--as),var(--at));z-index:0;opacity:.5}
.ps{text-align:center;padding:0 16px;position:relative;z-index:1}
.po{width:104px;height:104px;border-radius:50%;background:rgba(1,9,38,0.32);border:1px solid rgba(255,255,255,0.22);display:flex;align-items:center;justify-content:center;margin:0 auto 24px;transition:all .4s cubic-bezier(.16,1,.3,1);position:relative;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.po::before{content:'';position:absolute;inset:-1px;border-radius:50%;background:linear-gradient(135deg,var(--ap),var(--as));opacity:0;transition:opacity .4s;z-index:-1}
.ps:hover .po{transform:scale(1.1);box-shadow:0 0 40px rgba(62,65,160,.3)}
.ps:hover .po::before{opacity:.6}
.pon{font-size:32px;font-weight:700;background:linear-gradient(135deg,var(--ap),var(--as));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.pt-title{font-size:15px;font-weight:600;color:#fff;margin-bottom:8px}
.pt-desc{font-size:12px;color:var(--ts);line-height:1.6;font-weight:300}
.pg{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.pi{background:rgba(1,9,38,0.28);border:1px solid var(--gb2);border-top:1px solid var(--gh);border-radius:var(--rl);overflow:hidden;cursor:pointer;transition:all .4s cubic-bezier(.16,1,.3,1);display:block;color:inherit;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.pi:hover{border-color:rgba(14,20,80,.35);transform:translateY(-6px);box-shadow:0 24px 60px rgba(0,0,0,.75)}
.pim{aspect-ratio:4/3;overflow:hidden;position:relative}
.pim img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.pi:hover .pim img{transform:scale(1.04)}
.pio{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,2,.99) 0%,transparent 50%);display:flex;align-items:flex-end;padding:20px;opacity:0;transition:opacity .3s}
.pi:hover .pio{opacity:1}
.pb{font-size:9px;text-transform:uppercase;letter-spacing:1.5px;padding:5px 12px;border-radius:50px;background:rgba(14,20,80,.22);color:var(--ap);border:1px solid rgba(14,20,80,.35);font-weight:500}
.pin{padding:20px 22px}
.pin h4{font-size:16px;font-weight:600;color:#eee;margin-bottom:4px}
.pin p{font-size:12px;color:var(--tm);font-weight:300}
.pcta{display:flex;align-items:center;justify-content:center;padding:16px 0 8px}
.pcta a{font-size:12px;letter-spacing:1.5px;color:var(--ap);text-transform:uppercase;font-weight:600;transition:.3s;padding:12px 32px;border:1px solid rgba(62,65,160,.25);border-radius:50px}
.pcta a:hover{background:rgba(14,20,80,.12)}
.strip-sec{position:relative;padding:80px 0;overflow:hidden}
.strip-hd{text-align:center;margin-bottom:48px;padding:0 40px}
.strip-hd h2{font-size:clamp(26px,4vw,40px);font-weight:700;letter-spacing:-1px;color:#fff}
.strip-hd p{font-size:15px;color:var(--ts);line-height:1.8;font-weight:300;margin-top:12px}
.strip-out{overflow:hidden;position:relative}
.strip-out::before,.strip-out::after{content:'';position:absolute;top:0;bottom:0;width:120px;z-index:2;pointer-events:none}
.strip-out::before{left:0;background:linear-gradient(to right,var(--bg),transparent)}
.strip-out::after{right:0;background:linear-gradient(to left,var(--bg),transparent)}
.strip-tr{display:flex;gap:20px;width:max-content;animation:ss 30s linear infinite;will-change:transform;transform:translateZ(0)}
.strip-tr:hover{animation-play-state:paused}
@keyframes ss{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.scard{width:300px;flex-shrink:0;border-radius:var(--rm);overflow:hidden;border:1px solid var(--gb2);border-top:1px solid var(--gh);transition:transform .3s}
.scard:hover{transform:scale(1.03)}
.scard img{width:100%;height:200px;object-fit:cover;display:block}
.tg{display:grid;grid-template-columns:repeat(5,1fr);gap:16px}
.ti{background:rgba(1,9,38,0.28);border:1px solid var(--gb2);border-top:1px solid var(--gh);border-radius:var(--rm);padding:24px 16px;text-align:center;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.ti:hover{border-color:rgba(14,20,80,.35);transform:translateY(-4px);box-shadow:0 12px 40px rgba(0,0,0,.4)}
.tiw{width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 12px;background:rgba(255,255,255,.04);border:1px solid var(--gb2)}
.tiw svg{width:28px;height:28px}
.tn{font-size:11px;color:var(--ts);letter-spacing:.5px;font-weight:500}
.tsg{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ts2{background:rgba(1,9,38,0.28);border:1px solid var(--gb2);border-top:1px solid var(--gh);border-radius:var(--rl);padding:32px;transition:.3s;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.ts2:hover{border-color:rgba(14,20,80,.3);transform:translateY(-4px)}
.tss{font-size:13px;margin-bottom:18px;letter-spacing:3px;background:linear-gradient(135deg,var(--ap),var(--as));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.ts2 p{font-size:14px;color:var(--ts);line-height:1.8;font-style:italic;margin-bottom:22px;font-weight:300}
.tauth{display:flex;align-items:center;gap:14px}
.tav{width:42px;height:42px;border-radius:50%;overflow:hidden;border:2px solid rgba(14,20,80,.35)}
.tav img{width:100%;height:100%;object-fit:cover}
.tan{font-size:13px;color:#ddd;font-weight:600}
.tar{font-size:11px;color:var(--tm)}
.cta-sec{position:relative;z-index:1;text-align:center;padding:100px 50px;width:100%}
.cta-box{max-width:800px;margin:0 auto;background:rgba(1,9,38,0.3);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,0.18);border-top:1px solid rgba(255,255,255,0.22);border-radius:var(--rl);padding:60px 48px;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.cta-box h2{font-size:clamp(26px,4vw,38px);font-weight:700;letter-spacing:-1px;color:#fff;margin-bottom:14px}
.cta-box p{font-size:15px;color:var(--ts);max-width:480px;margin:0 auto 36px;line-height:1.8;font-weight:300}
.cf{max-width:420px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.ci{padding:14px 18px;background:rgba(255,255,255,.02);border:1px solid var(--gb2);border-radius:var(--rs);color:#fff;font-size:14px;outline:none;font-family:inherit;transition:border-color .2s;width:100%}
.ci:focus{border-color:rgba(14,20,96,.6);box-shadow:0 0 0 3px rgba(14,20,96,.1)}
.ci::placeholder{color:var(--tm)}
.ci option{background:#030303;color:#fff}
.ft{position:relative;z-index:1;border-top:1px solid var(--gb2);padding:60px 50px;width:100%}
.ftg{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;max-width:1100px;margin:0 auto}
.ft-brand h3{font-size:22px;font-weight:700;letter-spacing:1px;background:linear-gradient(135deg,var(--ap),var(--as));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:10px}
.ft-brand p{font-size:13px;color:var(--tm);line-height:1.7;max-width:280px;font-weight:300}
.fc h5{font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--tm);margin-bottom:16px;font-weight:500}
.fc a{display:block;font-size:13px;color:var(--tm);padding:5px 0;transition:.2s}
.fc a:hover{color:var(--ap)}
.ft-sep{height:1px;background:linear-gradient(90deg,transparent,var(--gb2),transparent);max-width:1100px;margin:40px auto 24px}
.ft-bot{text-align:center;max-width:1100px;margin:0 auto;padding-bottom:20px}
.ft-bot p{font-size:11px;color:var(--tm)}
::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(14,20,80,.25);border-radius:4px}
.rev{opacity:0;transform:translateY(20px);transition:opacity .7s cubic-bezier(.16,1,.3,1),transform .7s cubic-bezier(.16,1,.3,1)}
.rev.vis{opacity:1;transform:translateY(0)}

/* SVC IA PAGE STYLES - Exactamente como estaba */
.svc-page{background: linear-gradient(to bottom, #010101 0%, #020305 22%, #03060f 45%, #050a1c 68%, #080f2a 85%, #0d1840 100%);color:var(--tp)}
.svc-glow-1{position:fixed;width:500px;height:500px;background:radial-gradient(circle,rgba(58,223,250,0.04),transparent 70%);border-radius:50%;pointer-events:none;z-index:0;top:10%;right:0}
.svc-glow-2{position:fixed;width:400px;height:400px;background:radial-gradient(circle,rgba(58,223,250,0.03),transparent 70%);border-radius:50%;pointer-events:none;z-index:0;bottom:10%;left:5%}

.svc-hero{min-height:100vh;display:flex;align-items:center;position:relative;padding:100px 60px 80px;overflow:hidden}
.svc-hero-bg{position:absolute;inset:0;z-index:0}
.svc-hero-bg img{width:100%;height:100%;object-fit:cover;opacity:0.25}
.svc-hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,0.95) 0%,rgba(0,0,0,0.6) 50%,rgba(0,0,0,0.4) 100%)}
.svc-hero-content{position:relative;z-index:2;max-width:700px}
.svc-hero-badge{display:inline-block;padding:6px 18px;background:rgba(58,223,250,0.08);border:1px solid rgba(58,223,250,0.2);border-radius:20px;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:24px}
.svc-hero h1{font-family:var(--font-serif);font-size:60px;font-weight:800;letter-spacing:-0.03em;line-height:1.15;margin-bottom:20px;color:#fff}
.svc-hero-desc{font-size:16px;color:#888;line-height:1.8;max-width:560px;margin-bottom:32px}
.svc-hero-tags{display:flex;flex-wrap:wrap;gap:8px}
.svc-hero-tag{padding:6px 16px;background:rgba(58,223,250,0.06);border:1px solid rgba(58,223,250,0.15);border-radius:8px;font-size:11px;color:var(--gold);letter-spacing:0.5px}
.svc-hero-scroll{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;cursor:pointer}
.svc-hero-scroll span{font-size:10px;color:#555;letter-spacing:2px;text-transform:uppercase}
.svc-hero-scroll .mouse{width:24px;height:38px;border:2px solid rgba(58,223,250,0.2);border-radius:12px;display:flex;justify-content:center;padding-top:8px}
.svc-hero-scroll .mouse::before{content:'';width:3px;height:7px;background:var(--gold);border-radius:2px;animation:scrollW 2s infinite}
@keyframes scrollW{0%{transform:translateY(0);opacity:1}100%{transform:translateY(10px);opacity:0}}
.svc-section{position:relative;z-index:1;padding:80px 60px;max-width:1200px;margin:0 auto;width:100%}
.svc-section-label{font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.svc-section-title{font-family:var(--font-serif);font-size:36px;font-weight:800;letter-spacing:-0.03em;color:#fff;margin-bottom:16px}
.svc-section-desc{font-size:14px;color:#555;max-width:560px;line-height:1.7;margin-bottom:50px}
.svc-section.center{text-align:center}
.svc-section.center .svc-section-desc{margin-left:auto;margin-right:auto}
.svc-projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.svc-project-card{display:block;background:rgba(1,2,6,0.82);border:1px solid var(--glass-border);border-top:1px solid rgba(255,255,255,0.22);border-radius:20px;overflow:hidden;transition:all .4s;text-decoration:none;color:inherit;position:relative;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.svc-project-card:hover{border-color:rgba(58,223,250,0.3);transform:translateY(-4px);box-shadow:0 16px 50px rgba(0,0,0,.5)}
.svc-proj-img{width:100%;height:200px;overflow:hidden;position:relative}
.svc-proj-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.svc-project-card:hover .svc-proj-img img{transform:scale(1.05)}
.svc-proj-img-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.8),transparent 60%)}
.svc-proj-body{padding:28px}
.svc-proj-body h3{font-family:var(--font-serif);font-size:20px;color:#fff;margin-bottom:10px;letter-spacing:1px}
.svc-proj-body p{font-size:13px;color:#666;line-height:1.7;margin-bottom:16px}


.svc-proj-arrow{position:absolute;bottom:24px;right:24px;width:32px;height:32px;border-radius:50%;background:rgba(58,223,250,0.08);border:1px solid rgba(58,223,250,0.2);display:flex;align-items:center;justify-content:center;transition:.3s;opacity:0}
.svc-project-card:hover .svc-proj-arrow{opacity:1}
.svc-proj-arrow svg{width:14px;height:14px;stroke:var(--gold)}
.svc-features-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-feature{background:rgba(1,2,6,0.82);border:1px solid var(--glass-border);border-top:1px solid rgba(255,255,255,0.22);border-radius:16px;padding:32px 24px;text-align:center;transition:.3s;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.svc-feature:hover{border-color:rgba(58,223,250,0.25);transform:translateY(-3px)}
.svc-feature-icon{width:52px;height:52px;border-radius:14px;background:rgba(58,223,250,0.08);border:1px solid rgba(58,223,250,0.15);display:flex;align-items:center;justify-content:center;margin:0 auto 16px;font-family:var(--font-serif);font-size:18px;font-weight:700;color:var(--gold)}
.svc-feature h4{font-size:14px;color:#ddd;margin-bottom:8px;letter-spacing:0.5px}
.svc-feature p{font-size:12px;color:#555;line-height:1.6}
.svc-cta{position:relative;z-index:1;text-align:center;padding:80px 60px;width:100%}
.svc-cta-box{max-width:700px;margin:0 auto;background:rgba(58,223,250,0.07);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(58,223,250,0.15);border-radius:24px;padding:52px 40px}
.svc-cta-box h2{font-family:var(--font-serif);font-size:30px;color:#fff;letter-spacing:2px;margin-bottom:14px}
.svc-cta-box p{font-size:14px;color:#666;max-width:480px;margin:0 auto 28px;line-height:1.7}
.svc-cta-btn{display:inline-block;padding:16px 40px;background:linear-gradient(135deg,var(--gold),#31c4f3);color:#000;font-size:12px;letter-spacing:2px;text-transform:uppercase;font-weight:700;border:none;border-radius:10px;cursor:pointer;transition:all .3s;font-family:inherit}
.svc-cta-btn:hover{transform:translateY(-2px);box-shadow:0 12px 40px rgba(58,223,250,0.25)}
.svc-footer{position:relative;z-index:1;border-top:1px solid var(--glass-border);padding:30px 60px;text-align:center;width:100%}
.svc-footer p{font-size:11px;color:#444}
.bg-band{position:relative;overflow:hidden;min-height:50vh;display:flex;align-items:center;justify-content:center}
.bg-band-img{position:absolute;inset:0;z-index:0}
.bg-band-img img{width:100%;height:100%;object-fit:cover}
.bg-band-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(0,0,0,0.7),rgba(0,0,0,0.85));z-index:1}
.bg-band-content{position:relative;z-index:2;text-align:center;padding:60px 40px;max-width:800px}
.bg-band-content h2{font-family:var(--font-serif);font-size:36px;color:#fff;letter-spacing:2px;margin-bottom:12px}
.bg-band-content p{font-size:14px;color:#888;line-height:1.7}
.snap-section{scroll-snap-align:start;min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;z-index:1}
.snap-section.auto-h{min-height:auto}

@media(max-width:1100px){.sg{grid-template-columns:repeat(2,1fr)}.tsg{grid-template-columns:repeat(2,1fr)}.tg{grid-template-columns:repeat(4,1fr)}.ftg{grid-template-columns:1fr 1fr}.svc-projects-grid{grid-template-columns:1fr}}
@media(max-width:900px){.pt{grid-template-columns:repeat(2,1fr)}.pt::before{display:none}.pg{grid-template-columns:1fr}.tg{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){
  .hero{padding:70px 20px 50px}.hbtns{flex-direction:column;gap:10px;width:100%}.hbtns .btn-p,.hbtns .btn-o{width:100%}
  .sec{padding:60px 20px}.sg,.tsg{grid-template-columns:1fr;gap:14px}.stats-wr{padding:0 20px 48px}.stats-inner{padding:28px 24px}.sn{font-size:28px}.stat-dv{display:none}
  .cta-sec{padding:60px 20px}.cta-box{padding:40px 24px}.ft{padding:48px 20px}.ftg{grid-template-columns:1fr;gap:28px;text-align:center}.ft-brand p{max-width:100%;margin:0 auto}
  .tg{grid-template-columns:repeat(3,1fr)}.tb{top:14px;left:14px}.sb{width:285px}
  .svc-hero{padding:80px 20px 60px}.svc-hero h1{font-size:32px}.svc-section{padding:60px 20px}.svc-features-grid{grid-template-columns:1fr}.svc-cta{padding:40px 20px}
}
@media(max-width:480px){.pt{grid-template-columns:1fr}.tg{grid-template-columns:repeat(2,1fr)}.scard{width:240px}}
@supports(padding:max(0px)){.hero{padding-top:max(80px,env(safe-area-inset-top))}}
@media(prefers-reduced-motion:reduce){.blob,.strip-tr,.sln{animation:none}.rev{transition:none}}
/* SVC WEB & AUDIOVISUAL ADDITIONAL STYLES */
.svc-hero-carousel{position:absolute;inset:0;z-index:0}
/* Video de fondo audiovisual */
.svc-hero-carousel video{width:100%;height:100%;object-fit:cover;}
.yt-carousel-wrap{position:relative;padding:0 60px;overflow:hidden}
.yt-carousel{display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;padding:20px 0}
.yt-carousel::-webkit-scrollbar{height:4px}
.yt-carousel::-webkit-scrollbar-thumb{background:rgba(58,223,250,0.2);border-radius:2px}
.yt-item{flex:0 0 420px;scroll-snap-align:start;background:rgba(1,2,6,0.82);border:1px solid var(--glass-border);border-top:1px solid rgba(255,255,255,0.22);border-radius:16px;overflow:hidden;transition:.3s;box-shadow:0 8px 32px rgba(0,0,0,0.25),inset 0 1px 2px rgba(255,255,255,0.18)}
.yt-item:hover{border-color:rgba(58,223,250,0.3);transform:translateY(-3px)}
.yt-item iframe{width:100%;aspect-ratio:16/9;border:none;display:block}
.yt-item .yt-label{padding:12px 16px;font-size:12px;color:#888;letter-spacing:0.5px}
@media(max-width:1000px){.yt-item{flex:0 0 320px}.yt-carousel-wrap{padding:0 20px}}
@media(max-width:600px){.yt-item{flex:0 0 280px}}

/* ═══ SVC BRANDING PAGE — duplicate CSS removed (definitions above at line 254-296) ═══ */

/* ═══ WEBS PORTFOLIO PAGE ═══ */
.webs-sidebar{width:260px;background:rgba(8,8,11,0.65);backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);border-right:1px solid rgba(255,255,255,0.06);height:100vh;position:fixed;left:0;top:0;overflow-y:auto;z-index:100;display:flex;flex-direction:column}
.webs-sb-header{padding:24px 20px 16px;border-bottom:1px solid rgba(255,255,255,0.06)}
.webs-sb-header h2{font-family:var(--font-serif);font-size:18px;background:linear-gradient(135deg,#3adffa,#646aa3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:4px}
.webs-sb-header p{font-size:11px;color:#555}
.webs-sb-section{padding:20px;border-bottom:1px solid rgba(255,255,255,0.05)}
.webs-sb-section h4{font-size:10px;text-transform:uppercase;color:#555;letter-spacing:1px;margin-bottom:12px}
.webs-filter-btn{display:block;width:100%;text-align:left;padding:10px 14px;margin-bottom:6px;background:rgba(255,255,255,0.02);border:1px solid rgba(255,255,255,0.06);border-radius:10px;color:#777;font-size:12px;cursor:pointer;transition:all .2s ease}
.webs-filter-btn:hover{border-color:rgba(0,212,255,0.3);color:#00d4ff;background:rgba(0,212,255,0.04)}
.webs-filter-btn.active{background:rgba(0,212,255,0.08);border-color:rgba(0,212,255,0.25);color:#00d4ff;box-shadow:0 0 14px rgba(0,212,255,0.06)}
.webs-sb-footer{padding:16px 20px;margin-top:auto;border-top:1px solid rgba(255,255,255,0.05)}
.webs-sb-footer a{color:#555;font-size:11px;text-decoration:none;transition:.2s;cursor:pointer}
.webs-sb-footer a:hover{color:#00d4ff}
.webs-main{margin-left:260px;flex:1;min-height:100vh;position:relative;z-index:1;background:#000}
.webs-topbar{position:sticky;top:0;z-index:50;background:rgba(8,8,11,0.55);backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-bottom:1px solid rgba(255,255,255,0.06);padding:0 30px;height:56px;display:flex;align-items:center;justify-content:space-between}
.webs-tb-brand{font-size:16px;background:linear-gradient(135deg,#00d4ff,#624ecc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;font-weight:600;letter-spacing:-.3px}
.webs-tb-back{font-size:12px;color:#666;border:1px solid rgba(255,255,255,0.08);padding:7px 18px;border-radius:8px;transition:all .2s ease;background:rgba(255,255,255,0.03);cursor:pointer}
.webs-tb-back:hover{border-color:rgba(0,212,255,0.3);color:#00d4ff}
.webs-port-header{padding:50px 40px 30px;text-align:center}
.webs-port-header h1{font-family:var(--font-serif);font-size:36px;font-weight:400;letter-spacing:3px;color:#fff;margin-bottom:12px}
.webs-port-header p{font-size:13px;color:#555;max-width:600px;margin:0 auto;line-height:1.6}
.webs-portfolio{padding:0 40px 60px}
.webs-port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.webs-port-card{background:rgba(255,255,255,0.04);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,0.06);border-radius:16px;overflow:hidden;cursor:pointer;transition:all .3s ease}
.webs-port-card:hover{border-color:rgba(58,223,250,0.4);transform:translateY(-6px);box-shadow:0 20px 60px rgba(0,0,0,.5)}
.webs-port-card.hidden{display:none}
.webs-port-thumb{aspect-ratio:16/10;position:relative;overflow:hidden}
.webs-port-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}
.webs-port-card:hover .webs-port-thumb img{transform:scale(1.05)}
.webs-port-info{padding:18px}
.webs-port-info h3{font-family:var(--font-serif);font-size:16px;color:#eee;font-weight:500;margin-bottom:6px}
.webs-port-badge{font-size:9px;text-transform:uppercase;letter-spacing:1px;padding:4px 10px;border-radius:12px;background:rgba(58,223,250,.15);color:var(--gold);border:1px solid rgba(58,223,250,.25)}
.webs-port-desc{font-size:11px;color:#444;margin-top:10px;line-height:1.5}
.webs-port-price{font-size:14px;color:var(--gold);font-weight:600;margin-top:12px}
@media(max-width:1200px){.webs-port-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.webs-sidebar{display:none}.webs-main{margin-left:0}.webs-port-grid{grid-template-columns:1fr}}

/* ═══ PROJECT DETAIL PAGES ═══ */
.proj-detail-hero{min-height:80vh}


/* ===== MERGED FROM INLINE STYLES ===== */


/* Animaciones de texto */
.animated-text {
    background: linear-gradient(90deg, #3adffa, #646aa3, #fff, #3adffa, #646aa3);
    background-size: 200% auto;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    animation: textShine 4s linear infinite;
}

@keyframes textShine {
    0% { background-position: 0% center; }
    100% { background-position: 200% center; }
}

/* Efecto de brillo en hover para títulos */
h1, h2, h3 {
    transition: all 0.3s ease;
}

h1:hover, h2:hover {
    text-shadow: 0 0 20px rgba(58,223,250,0.5);
}

/* Animación de pulso para elementos dorados */
.gold-pulse {
    animation: goldPulse 2s ease-in-out infinite;
}

@keyframes goldPulse {
    0%, 100% { box-shadow: 0 0 5px rgba(58,223,250,0.5); }
    50% { box-shadow: 0 0 20px rgba(58,223,250,0.8), 0 0 40px rgba(58,223,250,0.4); }
}

/* Efecto de ondas en el header */
#header-ripple {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    border-radius: 50px;
    border: 1px solid rgba(58,223,250,0.3);
    animation: ripple 3s ease-out infinite;
    pointer-events: none;
}

@keyframes ripple {
    0% { transform: translate(-50%, -50%) scale(0.95); opacity: 1; }
    100% { transform: translate(-50%, -50%) scale(1.1); opacity: 0; }
}


/* ===== MERGED FROM INLINE STYLES ===== */


@keyframes gradientShift {
    0%, 100% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
}


/* ===== MERGED FROM INLINE STYLES ===== */


/* ── Dock — wrapper de posicionamiento ──────────────── */
.dock-glow-wrapper {
  position: fixed;
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
  width: 70%;
  max-width: 960px;
  z-index: 220;
}

@media (max-width: 768px) {
  .dock-glow-wrapper { top: 10px; width: 80%; }
}

/* ── Spinning light border — solo el botón CTA ──────── */
@property --border-angle {
  syntax: '<angle>';
  initial-value: 0deg;
  inherits: false;
}

.btn-wrap {
  position: relative;
  overflow: hidden;
  border-radius: 100px;
  padding: 2px;
  flex-shrink: 0;
}

.btn-wrap::before {
  content: '';
  position: absolute;
  width: 220%;
  aspect-ratio: 1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: conic-gradient(
    from var(--border-angle),
    transparent 70%,
    #00f0ff 83%,
    #0066ff 89%,
    #00f0ff 95%,
    transparent
  );
  animation: spinBorder 3.5s linear infinite;
  will-change: transform;
}

@keyframes spinBorder {
  to { --border-angle: 360deg; }
}

/* Variante solo cyan — Ver Proyectos */
.btn-wrap-cyan {
  position: relative;
  overflow: hidden;
  border-radius: 100px;
  padding: 2px;
  flex-shrink: 0;
}

.btn-wrap-cyan::before {
  content: '';
  position: absolute;
  width: 220%;
  aspect-ratio: 1;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: conic-gradient(
    from var(--border-angle),
    transparent 70%,
    #00f0ff 83%,
    #00cfff 89%,
    #00f0ff 95%,
    transparent
  );
  animation: spinBorder 3.5s linear infinite;
  will-change: transform;
}


/* ===== MERGED FROM INLINE STYLES ===== */


@keyframes shine {
    0% { background-position: 0% 50%; }
    100% { background-position: 300% 50%; }
}


/* ===== MERGED FROM INLINE STYLES ===== */


.material-symbols-outlined {
    font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
    font-family: 'Material Symbols Outlined', sans-serif;
}
.glass-panel {
    backdrop-filter: blur(40px) saturate(150%);
    -webkit-backdrop-filter: blur(40px) saturate(150%);
}
.glow-blob {
    filter: blur(120px);
    position: absolute;
    z-index: -1;
    opacity: 0.4;
}
/* Portfolio grayscale effect */
.portfolio-item {
    position: relative;
    overflow: hidden;
    cursor: pointer;
}
.portfolio-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    filter: grayscale(100%);
    transition: all 0.7s ease;
}
.portfolio-item:hover img {
    filter: grayscale(0%);
    transform: scale(1.05);
}
.portfolio-overlay {
    position: absolute;
    inset: 0;
    background: rgba(4,11,25,0.6);
    opacity: 0;
    transition: opacity 0.3s;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 40px;
    backdrop-filter: blur(4px);
}
.portfolio-item:hover .portfolio-overlay {
    opacity: 1;
}


/* ===== MERGED FROM INLINE STYLES ===== */


@keyframes blobMove1 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(100px,50px) scale(1.1)} }
@keyframes blobMove2 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(-80px,100px) scale(0.9)} }
@keyframes blobMove3 { 0%,100%{transform:translate(0,0) scale(1)} 50%{transform:translate(120px,-80px) scale(1.15)} }


/* ===== MERGED FROM INLINE STYLES ===== */


        @keyframes scrollBounce {
            0%, 100% { transform: translateY(0); opacity: 1; }
            50% { transform: translateY(10px); opacity: 0; }
        }
    

/* ===== MERGED FROM INLINE STYLES ===== */


            .stats-spin-wrapper::before {
                content: '';
                position: absolute;
                inset: 0;
                border-radius: 24px;
                padding: 2px;
                background: conic-gradient(
                    from var(--border-angle),
                    transparent 70%,
                    #3adffa 83%,
                    #fff 89%,
                    #3adffa 95%,
                    transparent
                );
                animation: spinBorderStats 3.5s linear infinite;
                -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
                -webkit-mask-composite: xor;
                mask-composite: exclude;
                pointer-events: none;
            }
            @keyframes spinBorderStats {
                to { --border-angle: 360deg; }
            }
            @property --border-angle {
                syntax: '<angle>';
                initial-value: 0deg;
                inherits: false;
            }
        

/* ===== MERGED FROM INLINE STYLES ===== */


        @keyframes pulseBlob {
            0%, 100% { transform: translate(-50%,-50%) scale(1); opacity: 0.1; }
            50% { transform: translate(-50%,-50%) scale(1.2); opacity: 0.15; }
        }
        @keyframes float {
            0%, 100% { transform: translateY(0); }
            50% { transform: translateY(-10px); }
        }
        @keyframes glow {
            0%, 100% { box-shadow: 0 0 20px rgba(159,167,255,0.3); }
            50% { box-shadow: 0 0 40px rgba(159,167,255,0.6); }
        }
    

/* ===== MERGED FROM INLINE STYLES ===== */


#calculator-modal .calc-card {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(100,210,255,0.12);
    border-radius: 12px;
    padding: 14px;
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    transition: border-color .2s;
}
#calculator-modal .calc-card:hover {
    border-color: rgba(100,210,255,0.28);
}
#calculator-modal .calc-card h4 {
    color: #67e8f9;
    font-size: 12px;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-bottom: 10px;
    display: flex;
    align-items: center;
    gap: 6px;
}
#calculator-modal .calc-card label {
    display: flex;
    align-items: center;
    gap: 7px;
    margin-bottom: 8px;
    cursor: pointer;
}
#calculator-modal .calc-card label:last-child { margin-bottom: 0; }
#calculator-modal .calc-card label span.name { color: rgba(255,255,255,0.85); font-size: 12px; }
#calculator-modal .calc-card label span.price { color: #38bdf8; margin-left: auto; font-size: 12px; font-weight: 600; }
#calculator-modal input[type="checkbox"] { accent-color: #00d4ff; width: 13px; height: 13px; flex-shrink: 0; }
#calculator-modal select {
    width: 100%;
    padding: 7px 10px;
    background: rgba(0,20,50,0.55);
    border: 1px solid rgba(100,210,255,0.18);
    border-radius: 7px;
    color: #e0f2fe;
    font-size: 11px;
    margin-top: 3px;
    outline: none;
}
#calculator-modal select:focus { border-color: rgba(100,210,255,0.4); }


/* ===== MERGED FROM INLINE STYLES ===== */


/* ══════════════════════════════════════════
   LIQUID GLASS GLOBAL — mismo DNA que el dock
   ══════════════════════════════════════════ */

/* Regla maestra: aplica a todos los contenedores de servicio, calc, cart, process */
.svc-cta-box,
.calc-category,
#cart-panel,
.webs-sb-section,
.snap-section .svc-feature,
.bg-band-content,
[class*="svc-proj"],
[class*="glass-panel"] {
    background: rgba(1,9,38,0.12) !important;
    backdrop-filter: blur(20px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(200%) !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    border-top: 1px solid rgba(255,255,255,0.22) !important;
    box-shadow: 0 8px 32px rgba(0,0,0,0.25), inset 0 1px 2px rgba(255,255,255,0.18) !important;
}

/* Modal calculadora presupuesto */
#calculator-modal > div {
    background: rgba(1,9,38,0.18) !important;
    backdrop-filter: blur(20px) saturate(200%) !important;
    -webkit-backdrop-filter: blur(20px) saturate(200%) !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    border-top: 1px solid rgba(255,255,255,0.22) !important;
    box-shadow: 0 8px 48px rgba(0,0,0,0.35), inset 0 1px 2px rgba(255,255,255,0.18) !important;
}

/* Tarjetas dentro del modal calculadora */
#calculator-modal .calc-card {
    background: rgba(1,9,38,0.12) !important;
    border: 1px solid rgba(255,255,255,0.18) !important;
    border-top: 1px solid rgba(255,255,255,0.22) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.1) !important;
}

/* Efecto Océano Tranquilo - CSS Only */
/* Base liquid glass para todos los fondos */
.liquid-glass-bg {
    backdrop-filter: blur(15px) saturate(180%);
    -webkit-backdrop-filter: blur(15px) saturate(180%);
}

/* Océano tranquilo - olas sutiles con CSS */
.ocean-tranquilo {
    position: absolute;
    inset: 0;
    z-index: 2;
    pointer-events: none;
    overflow: hidden;
}

/* Capa de olas suaves - movimiento muy lento */
.wave-layer {
    position: absolute;
    width: 200%;
    height: 100%;
    left: -50%;
    background: 
        radial-gradient(ellipse 80% 20% at 20% 30%, rgba(58,223,250,0.08) 0%, transparent 50%),
        radial-gradient(ellipse 60% 15% at 70% 60%, rgba(100,106,163,0.06) 0%, transparent 50%),
        radial-gradient(ellipse 90% 25% at 40% 80%, rgba(58,223,250,0.05) 0%, transparent 40%);
    animation: waveMove 25s ease-in-out infinite;
}

.wave-layer:nth-child(2) {
    background: 
        radial-gradient(ellipse 70% 18% at 60% 20%, rgba(100,106,163,0.07) 0%, transparent 45%),
        radial-gradient(ellipse 80% 22% at 30% 70%, rgba(58,223,250,0.06) 0%, transparent 45%);
    animation: waveMove2 30s ease-in-out infinite;
    animation-delay: -5s;
}

.wave-layer:nth-child(3) {
    background: 
        radial-gradient(ellipse 50% 12% at 80% 40%, rgba(58,223,250,0.05) 0%, transparent 50%),
        radial-gradient(ellipse 75% 20% at 10% 50%, rgba(100,106,163,0.04) 0%, transparent 50%);
    animation: waveMove3 35s ease-in-out infinite;
    animation-delay: -10s;
}

@keyframes waveMove {
    0%, 100% { transform: translateX(-5%) translateY(0); }
    50% { transform: translateX(5%) translateY(-2%); }
}

@keyframes waveMove2 {
    0%, 100% { transform: translateX(3%) translateY(0); }
    50% { transform: translateX(-3%) translateY(2%); }
}

@keyframes waveMove3 {
    0%, 100% { transform: translateX(-2%) translateY(0); }
    50% { transform: translateX(2%) translateY(-1%); }
}

/* Líneas de surcos de olas estáticas con gradiente */
.wave-ridges {
    position: absolute;
    inset: 0;
    background: 
        repeating-linear-gradient(
            170deg,
            transparent 0px,
            transparent 100px,
            rgba(58,223,250,0.03) 100px,
            rgba(58,223,250,0.03) 102px,
            transparent 102px,
            transparent 180px
        ),
        repeating-linear-gradient(
            175deg,
            transparent 0px,
            transparent 150px,
            rgba(100,106,163,0.02) 150px,
            rgba(100,106,163,0.02) 152px,
            transparent 152px,
            transparent 220px
        );
    opacity: 0.8;
}


/* ===== MERGED FROM INLINE STYLES ===== */


#byb-chat-btn {
  position: fixed; bottom: 32px; right: 32px;
  width: 64px; height: 64px; border-radius: 50%;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.15);
  backdrop-filter: blur(32px) saturate(180%);
  -webkit-backdrop-filter: blur(32px) saturate(180%);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.2), inset 0 1px 2px rgba(255, 255, 255, 0.1);
  cursor: pointer; z-index: 9999;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.3s ease;
}
#byb-chat-btn:hover { 
  transform: scale(1.12); 
  background: rgba(255, 255, 255, 0.08);
  box-shadow: 0 12px 44px rgba(0, 0, 0, 0.3), inset 0 1px 2px rgba(255, 255, 255, 0.2); 
  border-color: rgba(255, 255, 255, 0.25); 
}
#byb-chat-panel {
  position: fixed; bottom: 112px; right: 32px;
  width: 356px; height: 520px; border-radius: 36px;
  background: rgba(1, 6, 20, 0.25);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-top: 1px solid rgba(255, 255, 255, 0.22);
  backdrop-filter: blur(40px) saturate(200%);
  -webkit-backdrop-filter: blur(40px) saturate(200%);
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.6), inset 0 1px 2px rgba(255, 255, 255, 0.2);
  z-index: 9998; display: none; flex-direction: column; overflow: hidden;
}
#byb-chat-panel.byb-open { display: flex; animation: chatIn 0.35s cubic-bezier(.34,1.56,.64,1); }
@keyframes chatIn { from { opacity:0; transform:translateY(24px) scale(0.96); } to { opacity:1; transform:translateY(0) scale(1); } }
#byb-chat-header { padding: 18px 20px 14px; border-bottom: 1px solid rgba(58,223,250,0.1); display:flex; align-items:center; gap:12px; }
.byb-avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,#0a1a50,#0d2d70); border:1.5px solid rgba(58,223,250,0.5); display:flex; align-items:center; justify-content:center; flex-shrink:0; box-shadow:0 0 12px rgba(58,223,250,0.3); }
.byb-header-text h4 { font-family:'Inter',sans-serif; font-size:13px; font-weight:700; color:#fff; letter-spacing:.5px; }
.byb-header-text p { font-size:11px; color:rgba(58,223,250,0.8); margin-top:1px; }
.byb-status-dot { width:7px; height:7px; border-radius:50%; background:#3adffa; box-shadow:0 0 6px #3adffa; animation:bybPulse 2s infinite; flex-shrink:0; margin-left:auto; }
@keyframes bybPulse { 0%,100%{opacity:1} 50%{opacity:.35} }
#byb-chat-messages { flex:1; overflow-y:auto; padding:14px 14px; display:flex; flex-direction:column; gap:10px; scrollbar-width:thin; scrollbar-color:rgba(58,223,250,0.18) transparent; }
#byb-chat-messages::-webkit-scrollbar { width:4px; }
#byb-chat-messages::-webkit-scrollbar-thumb { background:rgba(58,223,250,0.2); border-radius:4px; }
.byb-msg { max-width:88%; padding:10px 14px; border-radius:18px; font-family:'Inter',sans-serif; font-size:13px; line-height:1.55; animation:msgFade .25s ease; }
@keyframes msgFade { from{opacity:0;transform:translateY(6px)} to{opacity:1;transform:translateY(0)} }
.byb-msg-bot { background:rgba(58,223,250,0.07); border:1px solid rgba(58,223,250,0.14); color:rgba(255,255,255,0.9); align-self:flex-start; border-bottom-left-radius:6px; }
.byb-msg-user { background:linear-gradient(135deg,rgba(100,106,163,0.4),rgba(58,223,250,0.18)); border:1px solid rgba(159,167,255,0.2); color:#fff; align-self:flex-end; border-bottom-right-radius:6px; }
.byb-typing { display:flex; gap:4px; align-items:center; padding:12px 16px; }
.byb-typing span { width:6px; height:6px; border-radius:50%; background:rgba(58,223,250,0.6); animation:dotBounce 1.2s infinite; }
.byb-typing span:nth-child(2){animation-delay:.2s} .byb-typing span:nth-child(3){animation-delay:.4s}
@keyframes dotBounce { 0%,80%,100%{transform:translateY(0);opacity:.4} 40%{transform:translateY(-6px);opacity:1} }
#byb-input-area { padding:12px 14px; border-top:1px solid rgba(58,223,250,0.1); display:flex; gap:8px; align-items:flex-end; }
#byb-input { flex:1; background:rgba(255,255,255,0.05); border:1px solid rgba(255,255,255,0.12); border-radius:18px; padding:10px 16px; color:#fff; font-family:'Inter',sans-serif; font-size:13px; resize:none; outline:none; line-height:1.4; max-height:80px; transition:border-color .2s; }
#byb-input::placeholder { color:rgba(255,255,255,0.3); }
#byb-input:focus { border-color:rgba(58,223,250,0.4); }
#byb-send { width:38px; height:38px; border-radius:50%; background:linear-gradient(135deg,#3adffa,#646aa3); border:none; cursor:pointer; display:flex; align-items:center; justify-content:center; flex-shrink:0; transition:all .2s; box-shadow:0 4px 14px rgba(58,223,250,0.3); }
#byb-send:hover { transform:scale(1.1); box-shadow:0 6px 20px rgba(58,223,250,0.5); }
#byb-send:disabled { opacity:.4; cursor:not-allowed; transform:none; }


/* ================================================================
   FASE 3: Hover classes — reemplaza inline onmouseover/onmouseout
   Elimina reflows causados por JS modificando style attribute
   ================================================================ */

/* Nav links */
.nav-link {
  color: rgba(255,255,255,0.85);
  font-size: 14px;
  font-weight: 500;
  transition: color .3s, text-shadow .3s;
  cursor: pointer;
  text-decoration: none;
}
.nav-link:hover { color: #3adffa; }
.nav-link-mkt:hover { color: #646aa3; }

/* Budget cart icon */
.btn-cart {
  transition: transform .3s, background .3s, box-shadow .3s !important;
}
.btn-cart:hover {
  transform: scale(1.1) !important;
  background: rgba(159,167,255,0.15) !important;
  box-shadow: 0 0 30px rgba(159,167,255,0.3) !important;
}

/* Presupuesto button (header) */
.btn-presupuesto-sm {
  transition: transform .3s, box-shadow .3s !important;
}
.btn-presupuesto-sm:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 30px rgba(159,167,255,0.5) !important;
}

/* Hero CTA — botón dorado primario */
.btn-hero-primary {
  transition: transform .3s, box-shadow .3s !important;
}
.btn-hero-primary:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 35px rgba(159,167,255,0.6) !important;
}

/* Hero CTA — botón ghost */
.btn-hero-ghost {
  transition: background .3s !important;
}
.btn-hero-ghost:hover {
  background: rgba(255,255,255,0.2) !important;
}

/* Calc presupuesto (sidebar) */
.btn-calc-sidebar { transition: transform .2s; }
.btn-calc-sidebar:hover { transform: translateY(-2px); }

/* Service grid cards */
.svc-grid-card {
  transition: border-color .4s, transform .4s, box-shadow .4s;
}
.svc-grid-card-ia:hover {
  border-color: rgba(58,223,250,0.5) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(58,223,250,0.2);
}
.svc-grid-card-web:hover, .svc-grid-card-branding:hover {
  border-color: rgba(159,167,255,0.3) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(159,167,255,0.15);
}
.svc-grid-card-av:hover {
  border-color: rgba(29,79,188,0.3) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(29,79,188,0.15);
}
.svc-grid-card-mkt:hover {
  border-color: rgba(58,223,250,0.3) !important;
  transform: translateY(-5px);
  box-shadow: 0 20px 60px rgba(58,223,250,0.15);
}

/* IA feature cards (inline backdrop-filter eliminado vía clase) */
.ia-feature-card {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 24px;
  padding: 40px;
  transition: transform .3s, border-color .3s;
}
.ia-feature-card:hover { transform: translateY(-5px); }
.ia-feature-card-purple:hover { border-color: rgba(159,167,255,0.3) !important; }
.ia-feature-card-cyan:hover   { border-color: rgba(58,223,250,0.3) !important; }
.ia-feature-card-blue:hover   { border-color: rgba(29,79,188,0.3) !important; }

/* Portfolio carousel buttons */
.btn-carousel { transition: background .3s, border-color .3s; }
.btn-carousel-prev:hover {
  background: rgba(255,255,255,0.15) !important;
  border-color: rgba(159,167,255,0.5) !important;
}
.btn-carousel-next:hover {
  background: rgba(255,255,255,0.2) !important;
  border-color: rgba(58,223,250,0.5) !important;
}

/* IA service circles */
.ia-circle { transition: border-color .4s, transform .4s, box-shadow .4s; }
.ia-circle-purple:hover {
  border-color: #646aa3 !important;
  transform: scale(1.1);
  box-shadow: 0 0 40px rgba(159,167,255,0.4);
}
.ia-circle-cyan:hover {
  border-color: #3adffa !important;
  transform: scale(1.1);
  box-shadow: 0 0 40px rgba(58,223,250,0.4);
}
.ia-circle-blue:hover {
  border-color: #3adffa !important;
  transform: scale(1.1);
  box-shadow: 0 0 40px rgba(29,79,188,0.4);
}

/* Social / icon buttons */
.social-icon-btn { transition: background .3s; }
.social-icon-btn:hover { background: rgba(255,255,255,0.1) !important; }

/* Strip text words */
.strip-word { cursor: pointer; transition: color .3s; }
.strip-word:hover { color: #fff !important; }

/* Social circles (footer/contact) */
.social-circle { transition: border-color .3s; }
.social-circle:hover        { border-color: rgba(58,223,250,0.5) !important; }
.social-circle-purple:hover { border-color: rgba(159,167,255,0.5) !important; }

/* Hamburger menu button hover */
.tb:hover {
  background: rgba(58,223,250,0.2) !important;
  box-shadow: 0 0 15px rgba(58,223,250,0.4) !important;
}

/* Sidebar nav links */
.sb-link { display:block;font-size:14px;color:rgba(255,255,255,0.6);padding:6px 0;cursor:pointer;transition:color .2s; }
.sb-link:hover { color:#646aa3; }

/* Footer links */
.footer-link { font-size:12px;color:rgba(255,255,255,0.4);transition:color .2s; }
.footer-link:hover { color:#3adffa; }

/* Video carousel buttons */
.btn-video-prev { transition:background .3s; }
.btn-video-prev:hover { background:rgba(255,255,255,0.15) !important; }
.btn-video-next { transition:background .3s; }
.btn-video-next:hover { background:rgba(255,255,255,0.2) !important; }

/* Form submit */
.btn-form-submit { transition:transform .3s, box-shadow .3s; }
.btn-form-submit:hover { transform:translateY(-2px) !important; box-shadow:0 8px 30px rgba(159,167,255,0.5) !important; }

/* Modal close button */
.btn-modal-close { transition:background .2s, color .2s; }
.btn-modal-close:hover { background:rgba(100,210,255,0.12) !important; color:#fff !important; }

/* Modal action buttons */
.btn-modal-cancel { transition:border-color .2s, color .2s; }
.btn-modal-cancel:hover { border-color:rgba(100,210,255,0.45) !important; color:#fff !important; }
.btn-modal-submit { transition:background .2s, border-color .2s; }
.btn-modal-submit:hover { background:linear-gradient(135deg,rgba(0,180,255,0.45),rgba(56,189,248,0.38)) !important; border-color:rgba(100,210,255,0.6) !important; }

/* Header calc button */
.btn-header-calc { transition:transform .3s, box-shadow .3s; }
.btn-header-calc:hover { transform:translateY(-2px) !important; box-shadow:0 8px 30px rgba(159,167,255,0.5) !important; }


/* ================================================================
   MERGE desde remote 72e6a9d: Mobile Responsive Fixes
   Fix: Eliminados videos YouTube placeholder, mejorado responsive mobile
   ================================================================ */

/* MOBILE RESPONSIVE FIXES — Liquid Glass Design */
@media(max-width:768px){
  .hero-section > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns:1fr!important;
    gap:40px!important;
    padding:0 20px!important;
  }
  .hero-section h1 {
    font-size:clamp(32px,8vw,48px)!important;
    line-height:1.1!important;
  }
  .hero-section .glass-panel {
    width:min(280px,60vw)!important;
    height:min(280px,60vw)!important;
  }
  #servicios > div > div[style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns:1fr!important;
  }
  #servicios > div > div > div[style*="grid-column:span 2"] {
    grid-column:span 1!important;
    min-height:auto!important;
  }
  .portfolio-slide {
    flex:0 0 85vw!important;
    min-width:280px;
  }
  #contact > div > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns:1fr!important;
    gap:40px!important;
  }
  #contact form > div[style*="grid-template-columns:1fr 1fr"] {
    grid-template-columns:1fr!important;
  }
  footer > div > div[style*="grid-template-columns:2fr 1fr 1fr 1fr"] {
    grid-template-columns:1fr!important;
    text-align:center!important;
    gap:40px!important;
  }
}

@media(max-width:900px){
  #servicios > div > div[style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns:1fr!important;
  }
}

@media(max-width:600px){
  #calculator-modal > div {
    margin:20px!important;
    max-height:90vh!important;
    overflow-y:auto!important;
  }
  #calculator-modal .calculator-grid {
    grid-template-columns:1fr!important;
  }
}

@media(max-width:1024px){
  .hero-section {
    font-size:15px!important;
  }
  .hero-container > div:last-child {
    order:-1;
  }
  .hero-container .glass-panel {
    width:min(280px,60vw)!important;
    height:min(280px,60vw)!important;
  }
}

@media(max-width:480px){
  section[id]{padding:60px 16px!important}
  section[style*="grid-template-columns:repeat(4,1fr)"] {
    grid-template-columns:1fr!important;
  }
}
