*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --dark:#0a0a0f;
  --dark-surface:#12121a;
  --dark-card:rgba(18,18,30,0.55);
  --accent:#00d4ff;
  --accent2:#7b5cfa;
  --accent3:#00ff88;
  --glass:rgba(255,255,255,0.06);
  --glass-border:rgba(255,255,255,0.1);
  --glass-hover:rgba(255,255,255,0.12);
  --text:#e8e8f0;
  --text-dim:rgba(255,255,255,0.5);
  --gradient:linear-gradient(135deg,#00d4ff,#7b5cfa);
}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  font-family:'Outfit',sans-serif;
  background:var(--dark);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
}

/* ── ANIMATED BACKGROUND ── */
.bg-grid{
  position:fixed;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.03) 1px,transparent 1px);
  background-size:60px 60px;
  pointer-events:none;
}
.bg-orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.bg-orbs .orb{
  position:absolute;border-radius:50%;filter:blur(120px);opacity:.3;
  animation:orbFloat 20s ease-in-out infinite alternate;
}
.bg-orbs .orb:nth-child(1){width:600px;height:600px;background:var(--accent);top:-200px;left:-200px;animation-duration:25s}
.bg-orbs .orb:nth-child(2){width:500px;height:500px;background:var(--accent2);bottom:-150px;right:-150px;animation-duration:30s;animation-delay:-5s}
.bg-orbs .orb:nth-child(3){width:400px;height:400px;background:var(--accent3);top:50%;left:50%;transform:translate(-50%,-50%);animation-duration:22s;animation-delay:-10s;opacity:.15}
@keyframes orbFloat{
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(60px,-40px) scale(1.1)}
  66%{transform:translate(-30px,50px) scale(0.9)}
  100%{transform:translate(40px,30px) scale(1.05)}
}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1rem 2rem;
  background:rgba(10,10,15,0.6);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--glass-border);
  display:flex;align-items:center;justify-content:space-between;
  transition:all .4s;
}
nav.scrolled{background:rgba(10,10,15,0.85);padding:.7rem 2rem}
.nav-logo{display:flex;align-items:center;gap:.75rem;text-decoration:none}
.nav-logo img{height:42px;filter:drop-shadow(0 0 12px rgba(0,212,255,.3))}
.nav-logo span{font-weight:700;font-size:1.3rem;color:#fff;letter-spacing:-.02em}
.nav-links{display:flex;gap:.5rem;align-items:center}
.nav-links a{
  color:var(--text-dim);text-decoration:none;font-weight:500;font-size:.95rem;
  padding:.55rem 1.2rem;border-radius:10px;
  transition:all .3s;position:relative;
}
.nav-links a:hover,.nav-links a.active{color:#fff;background:var(--glass);border:1px solid var(--glass-border)}
.nav-links a.active{color:var(--accent)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:none;padding:8px}
.mobile-toggle span{width:24px;height:2px;background:#fff;border-radius:2px;transition:.3s}

/* ── SECTIONS ── */
section{position:relative;z-index:1;min-height:100vh;padding:8rem 2rem 4rem}
.container{max-width:1200px;margin:0 auto}

/* ── HERO ── */
#home{display:flex;align-items:center;min-height:100vh;padding-top:6rem}
.hero-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.hero-badge{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--glass);border:1px solid var(--glass-border);
  padding:.4rem 1rem;border-radius:100px;font-size:.8rem;color:var(--accent);
  margin-bottom:1.5rem;font-family:'JetBrains Mono',monospace;
  animation:fadeUp .8s ease-out;
}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--accent3);border-radius:50%;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.3}}
.hero-title{
  font-size:clamp(2.5rem,5.5vw,4.2rem);font-weight:800;line-height:1.05;
  letter-spacing:-.03em;margin-bottom:1.5rem;
  animation:fadeUp .8s ease-out .1s both;
}
.hero-title .gradient-text{
  background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
}
.hero-desc{
  font-size:1.15rem;color:var(--text-dim);max-width:520px;margin-bottom:2.5rem;
  animation:fadeUp .8s ease-out .2s both;line-height:1.7;
}
.hero-buttons{display:flex;gap:1rem;flex-wrap:wrap;animation:fadeUp .8s ease-out .3s both}
.btn-primary{
  padding:.85rem 2rem;border-radius:12px;font-weight:600;font-size:.95rem;
  border:none;cursor:pointer;font-family:inherit;
  background:var(--gradient);color:#fff;
  box-shadow:0 4px 24px rgba(0,212,255,.25);
  transition:all .3s;position:relative;overflow:hidden;
  text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,212,255,.35)}
.btn-secondary{
  padding:.85rem 2rem;border-radius:12px;font-weight:600;font-size:.95rem;
  border:1px solid var(--glass-border);cursor:pointer;font-family:inherit;
  background:var(--glass);color:#fff;backdrop-filter:blur(12px);
  transition:all .3s;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem;
}
.btn-secondary:hover{background:var(--glass-hover);border-color:rgba(255,255,255,.2);transform:translateY(-2px)}

/* Hero Visual */
.hero-visual{
  position:relative;display:flex;justify-content:center;align-items:center;
  animation:fadeUp 1s ease-out .4s both;
}
.shield-container{
  width:340px;height:340px;position:relative;
  display:flex;align-items:center;justify-content:center;
}
.shield-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1px solid rgba(0,212,255,.2);
  animation:ringPulse 4s ease-in-out infinite;
}
.shield-ring:nth-child(2){inset:20px;border-color:rgba(123,92,250,.2);animation-delay:-1.3s}
.shield-ring:nth-child(3){inset:40px;border-color:rgba(0,255,136,.15);animation-delay:-2.6s}
@keyframes ringPulse{0%,100%{opacity:.3;transform:scale(1)}50%{opacity:.8;transform:scale(1.03)}}
.shield-icon{
  width:120px;height:120px;
  filter:drop-shadow(0 0 40px rgba(0,212,255,.4));
  animation:float 6s ease-in-out infinite;
}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

/* Floating stat cards */
.float-card{
  position:absolute;
  background:rgba(18,18,30,0.7);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:16px;padding:1rem 1.3rem;
  display:flex;align-items:center;gap:.75rem;
  animation:floatCard 5s ease-in-out infinite;
  box-shadow:0 8px 32px rgba(0,0,0,.3);
}
.float-card:nth-child(5){top:10%;right:-20px;animation-delay:-1s}
.float-card:nth-child(6){bottom:15%;left:-30px;animation-delay:-3s}
.float-card:nth-child(7){bottom:5%;right:10%;animation-delay:-2s}
@keyframes floatCard{0%,100%{transform:translateY(0)}50%{transform:translateY(-8px)}}
.float-card .fc-icon{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;
}
.float-card .fc-icon.blue{background:rgba(0,212,255,.15);color:var(--accent)}
.float-card .fc-icon.purple{background:rgba(123,92,250,.15);color:var(--accent2)}
.float-card .fc-icon.green{background:rgba(0,255,136,.15);color:var(--accent3)}
.float-card .fc-val{font-weight:700;font-size:1.1rem;line-height:1.2}
.float-card .fc-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.06em}

/* ── STATS BAR ── */
.stats-bar{
  display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;
  margin-top:5rem;padding:2.5rem;
  background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);border-radius:20px;
}
.stat-item{text-align:center}
.stat-num{font-size:2.2rem;font-weight:800;background:var(--gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.stat-label{font-size:.85rem;color:var(--text-dim);margin-top:.3rem}

/* ── SERVICES SECTION (inside Home scroll) ── */
.services-section{padding:6rem 0}
.section-tag{
  font-family:'JetBrains Mono',monospace;font-size:.8rem;color:var(--accent);
  text-transform:uppercase;letter-spacing:.15em;margin-bottom:.75rem;
}
.section-title{font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:700;letter-spacing:-.02em;margin-bottom:1rem}
.section-desc{color:var(--text-dim);max-width:600px;font-size:1.05rem;margin-bottom:3rem}

.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.service-card{
  background:var(--glass);backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);border-radius:20px;
  padding:2rem;transition:all .4s;position:relative;overflow:hidden;
  cursor:default;
}
.service-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--gradient);transform:scaleX(0);transform-origin:left;transition:transform .4s;
}
.service-card:hover::before{transform:scaleX(1)}
.service-card:hover{background:var(--glass-hover);border-color:rgba(255,255,255,.15);transform:translateY(-4px)}
.sc-icon{
  width:52px;height:52px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  font-size:1.5rem;margin-bottom:1.2rem;
}
.sc-icon.i1{background:rgba(0,212,255,.12);color:var(--accent)}
.sc-icon.i2{background:rgba(123,92,250,.12);color:var(--accent2)}
.sc-icon.i3{background:rgba(0,255,136,.12);color:var(--accent3)}
.sc-icon.i4{background:rgba(255,107,107,.12);color:#ff6b6b}
.sc-icon.i5{background:rgba(255,193,7,.12);color:#ffc107}
.sc-icon.i6{background:rgba(0,212,255,.12);color:var(--accent)}
.service-card h3{font-size:1.15rem;font-weight:600;margin-bottom:.6rem}
.service-card p{font-size:.9rem;color:var(--text-dim);line-height:1.6}

/* ── ABOUT ── */
#about{background:transparent}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.about-visual{position:relative}
.about-glass{
  background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);border-radius:24px;
  padding:3rem;position:relative;overflow:hidden;
}
.about-glass::after{
  content:'';position:absolute;top:-50%;right:-50%;width:200%;height:200%;
  background:radial-gradient(circle,rgba(0,212,255,.06),transparent 60%);
  pointer-events:none;
}
.about-terminal{
  font-family:'JetBrains Mono',monospace;font-size:.85rem;line-height:1.8;
}
.about-terminal .line{display:flex;gap:.75rem}
.about-terminal .prompt{color:var(--accent3);user-select:none}
.about-terminal .cmd{color:var(--accent)}
.about-terminal .output{color:var(--text-dim);padding-left:1.5rem}
.about-terminal .cursor{display:inline-block;width:8px;height:16px;background:var(--accent);animation:blink 1s step-end infinite;vertical-align:middle}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

.about-content .section-title{margin-bottom:1.5rem}
.about-text{color:var(--text-dim);font-size:1rem;line-height:1.8;margin-bottom:2rem}
.about-features{display:flex;flex-direction:column;gap:1rem}
.about-feat{
  display:flex;align-items:center;gap:1rem;
  padding:1rem 1.3rem;border-radius:14px;
  background:var(--glass);border:1px solid var(--glass-border);
  transition:all .3s;
}
.about-feat:hover{background:var(--glass-hover)}
.about-feat .af-icon{
  width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:1.1rem;
}
.about-feat h4{font-size:.95rem;font-weight:600}
.about-feat p{font-size:.8rem;color:var(--text-dim)}

/* ── CASES ── */
#cases{background:transparent}
.cases-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.case-card{
  background:var(--glass);backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);border-radius:20px;
  overflow:hidden;transition:all .4s;cursor:default;
}
.case-card:hover{transform:translateY(-6px);border-color:rgba(0,212,255,.3)}
.case-header{
  padding:2rem 2rem 1rem;position:relative;
}
.case-tag{
  display:inline-block;font-family:'JetBrains Mono',monospace;
  font-size:.7rem;padding:.3rem .8rem;border-radius:100px;
  margin-bottom:1rem;text-transform:uppercase;letter-spacing:.06em;
}
.case-tag.financial{background:rgba(0,212,255,.12);color:var(--accent)}
.case-tag.gov{background:rgba(123,92,250,.12);color:var(--accent2)}
.case-tag.enterprise{background:rgba(0,255,136,.12);color:var(--accent3)}
.case-card h3{font-size:1.15rem;font-weight:600;margin-bottom:.6rem}
.case-card .case-desc{font-size:.88rem;color:var(--text-dim);line-height:1.6}
.case-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:1px solid var(--glass-border);margin-top:1.5rem;
}
.case-stat{
  padding:1.2rem;text-align:center;
  border-right:1px solid var(--glass-border);
}
.case-stat:last-child{border-right:none}
.case-stat .cs-val{font-weight:700;font-size:1.1rem;color:var(--accent)}
.case-stat .cs-label{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.04em;margin-top:.2rem}

/* ── PENTEST SECTION ── */
#pentest{background:transparent}
.pentest-layout{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:start}
.pentest-info .section-title{margin-bottom:1.5rem}
.pentest-info .pentest-text{color:var(--text-dim);font-size:1rem;line-height:1.8;margin-bottom:2rem}
.pentest-steps{display:flex;flex-direction:column;gap:1rem}
.p-step{
  display:flex;gap:1rem;align-items:flex-start;
  padding:1.2rem 1.5rem;border-radius:16px;
  background:var(--glass);border:1px solid var(--glass-border);
  transition:all .3s;
}
.p-step:hover{background:var(--glass-hover);transform:translateX(6px)}
.p-step-num{
  width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:'JetBrains Mono',monospace;font-weight:700;font-size:.85rem;flex-shrink:0;
  background:var(--gradient);color:#fff;
}
.p-step h4{font-size:.95rem;font-weight:600;margin-bottom:.2rem}
.p-step p{font-size:.82rem;color:var(--text-dim)}

/* Pentest Form */
.pentest-form-card{
  background:var(--glass);backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);border-radius:24px;
  padding:2.5rem;position:relative;overflow:hidden;
}
.pentest-form-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--gradient);
}
.pentest-form-card h3{font-size:1.3rem;font-weight:700;margin-bottom:.5rem}
.pentest-form-card .form-sub{color:var(--text-dim);font-size:.9rem;margin-bottom:2rem}
.form-group{margin-bottom:1.3rem}
.form-group label{display:block;font-size:.85rem;font-weight:500;margin-bottom:.5rem;color:var(--text)}
.form-group input,.form-group select,.form-group textarea{
  width:100%;padding:.8rem 1rem;border-radius:12px;border:1px solid var(--glass-border);
  background:rgba(255,255,255,.04);color:#fff;font-family:inherit;font-size:.9rem;
  transition:all .3s;outline:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{
  border-color:var(--accent);background:rgba(0,212,255,.04);
  box-shadow:0 0 0 3px rgba(0,212,255,.1);
}
.form-group textarea{min-height:100px;resize:vertical}
.form-group select option{background:var(--dark-surface);color:#fff}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.btn-submit{
  width:100%;padding:1rem;border-radius:14px;border:none;
  background:var(--gradient);color:#fff;font-weight:700;font-size:1rem;
  font-family:inherit;cursor:pointer;transition:all .3s;
  box-shadow:0 4px 24px rgba(0,212,255,.25);
  margin-top:.5rem;
}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,212,255,.4)}

/* ── FOOTER ── */
footer{
  position:relative;z-index:1;
  border-top:1px solid var(--glass-border);
  padding:3rem 2rem;
  background:rgba(10,10,15,.5);
  backdrop-filter:blur(20px);
}
.footer-inner{
  max-width:1200px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1.5rem;
}
.footer-brand{display:flex;align-items:center;gap:.75rem}
.footer-brand img{height:32px;opacity:.7}
.footer-brand span{font-weight:600;color:var(--text-dim)}
.footer-copy{font-size:.8rem;color:var(--text-dim)}
.footer-links{display:flex;gap:1.5rem}
.footer-links a{color:var(--text-dim);text-decoration:none;font-size:.85rem;transition:color .3s}
.footer-links a:hover{color:var(--accent)}

/* ── PARTNERS SECTION ── */
#partners{background:transparent;min-height:auto;padding:4rem 2rem 6rem}
.partners-header{text-align:center;margin-bottom:3.5rem}
.partners-header .section-title{margin-bottom:.8rem}
.partners-header .section-desc{margin:0 auto}
.partners-track-wrapper{position:relative;overflow:hidden;padding:2rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.partners-track{display:flex;gap:2rem;width:max-content;animation:partnerScroll 35s linear infinite}
.partners-track:hover{animation-play-state:paused}
@keyframes partnerScroll{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

.partner-card{
  width:220px;flex-shrink:0;
  background:var(--dark-card);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:24px;
  padding:2rem 1.5rem;
  display:flex;flex-direction:column;align-items:center;
  text-align:center;gap:1rem;
  transition:all .4s cubic-bezier(.22,1,.36,1);
  position:relative;overflow:hidden;
  cursor:default;
}
.partner-card::before{
  content:'';position:absolute;inset:0;border-radius:24px;
  background:radial-gradient(ellipse at 50% 0%,rgba(0,212,255,.08),transparent 70%);
  opacity:0;transition:opacity .4s;pointer-events:none;
}
.partner-card:hover::before{opacity:1}
.partner-card:hover{
  transform:translateY(-8px) scale(1.02);
  border-color:rgba(0,212,255,.25);
  box-shadow:0 20px 60px rgba(0,0,0,.3),0 0 40px rgba(0,212,255,.08);
}
.partner-logo-wrap{
  width:100px;height:100px;
  border-radius:20px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;justify-content:center;
  padding:14px;
  transition:all .4s;
  position:relative;
  overflow:hidden;
}
.partner-card:hover .partner-logo-wrap{
  border-color:rgba(0,212,255,.2);
  background:rgba(0,212,255,.04);
  box-shadow:0 0 30px rgba(0,212,255,.1);
}
.partner-logo-wrap img{
  width:100%;height:100%;object-fit:contain;
  filter:brightness(0) invert(1);opacity:.7;
  transition:all .4s;
}
.partner-card:hover .partner-logo-wrap img{opacity:1;filter:none;transform:scale(1.08)}
.partner-logo-wrap .partner-placeholder{
  font-size:2.2rem;opacity:.4;transition:all .3s;
}
.partner-card:hover .partner-placeholder{opacity:.7;transform:scale(1.1)}
.partner-name{font-size:.95rem;font-weight:600;color:#fff;line-height:1.3}
.partner-type{
  font-family:'JetBrains Mono',monospace;font-size:.65rem;
  text-transform:uppercase;letter-spacing:.1em;
  padding:.25rem .7rem;border-radius:100px;
  background:rgba(0,212,255,.1);color:var(--accent);
}
.partner-type.gold{background:rgba(255,193,7,.1);color:#ffc107}
.partner-type.plat{background:rgba(123,92,250,.1);color:var(--accent2)}
.partner-type.cert{background:rgba(0,255,136,.1);color:var(--accent3)}

/* Partners static grid (below carousel) */
.partners-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:1.5rem;margin-top:3rem;
}

/* ── CONTACT SECTION ── */
#contacto{background:transparent;min-height:auto;padding:6rem 2rem}
.contact-layout{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.contact-phone-scene{perspective:1200px;display:flex;justify-content:center;align-items:center;min-height:500px}
.phone-3d{
  position:relative;width:220px;height:440px;
  transform-style:preserve-3d;
  transform:rotateY(-15deg) rotateX(5deg);
  transition:transform .8s cubic-bezier(.22,1,.36,1);
  animation:phoneIdle 6s ease-in-out infinite;
}
.phone-3d:hover{transform:rotateY(0) rotateX(0) scale(1.05);animation:none}
@keyframes phoneIdle{
  0%,100%{transform:rotateY(-15deg) rotateX(5deg)}
  50%{transform:rotateY(-10deg) rotateX(3deg) translateY(-8px)}
}
.phone-face{position:absolute;backface-visibility:hidden}
.phone-front{
  width:220px;height:440px;
  background:linear-gradient(160deg,#0a0a1a 0%,#12122a 50%,#0a0a18 100%);
  border:3px solid #2a2a40;border-radius:28px;
  padding:1.2rem;
  display:flex;flex-direction:column;
  transform:translateZ(6px);
  box-shadow:0 0 40px rgba(0,212,255,.1),inset 0 0 60px rgba(0,0,0,.3);
  overflow:hidden;
}
.phone-notch{
  width:80px;height:22px;background:#000;border-radius:0 0 14px 14px;
  margin:0 auto .8rem;position:relative;
}
.phone-notch::after{content:'';width:8px;height:8px;border-radius:50%;background:#1a1a2e;position:absolute;right:12px;top:7px;
  box-shadow:inset 0 0 3px rgba(0,212,255,.3);
}
.phone-status{display:flex;justify-content:space-between;font-size:.55rem;color:rgba(255,255,255,.5);margin-bottom:.6rem;padding:0 .2rem;font-family:'JetBrains Mono',monospace}
.phone-time{font-size:2.2rem;font-weight:700;color:#fff;text-align:center;margin:.5rem 0 .2rem;letter-spacing:-.02em}
.phone-date{font-size:.7rem;color:rgba(255,255,255,.4);text-align:center;margin-bottom:1.2rem}
.phone-screen{
  flex:1;display:flex;flex-direction:column;justify-content:flex-start;
  gap:1rem;
  padding:.95rem;
  border-radius:22px;
  background:
    linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,.015)),
    radial-gradient(circle at top left,rgba(0,212,255,.12),transparent 42%);
  border:1px solid rgba(255,255,255,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06);
}
.phone-app-head{
  display:flex;align-items:center;gap:.8rem;
  padding-bottom:.85rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.phone-app-badge{
  width:38px;height:38px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(37,211,102,.14);
  box-shadow:0 10px 30px rgba(37,211,102,.12);
  flex-shrink:0;
}
.phone-app-copy{min-width:0}
.phone-app-title{
  font-size:.82rem;font-weight:700;color:#fff;line-height:1.1;
}
.phone-app-subtitle{
  font-size:.62rem;
  color:rgba(255,255,255,.48);
  margin-top:.18rem;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.phone-wa-cards{display:flex;flex-direction:column;gap:.7rem}
.wa-contact-card{
  display:flex;align-items:center;gap:.8rem;
  padding:.8rem 1rem;border-radius:16px;
  background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.03));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 10px 22px rgba(0,0,0,.18);
  cursor:pointer;transition:all .3s;text-decoration:none;
}
.wa-contact-card:hover{background:rgba(37,211,102,.12);border-color:rgba(37,211,102,.28);transform:translateY(-2px) scale(1.01)}
.wa-icon{
  width:42px;height:42px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
  font-size:1.3rem;
}
.wa-icon.infra{background:rgba(0,212,255,.15)}
.wa-icon.ventas{background:rgba(123,92,250,.15)}
.wa-contact-card .wa-info{flex:1}
.wa-contact-card .wa-name{font-size:.8rem;font-weight:600;color:#fff}
.wa-contact-card .wa-dept{font-size:.6rem;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.05em}
.wa-contact-card .wa-phone{
  margin-top:.25rem;
  font-size:.72rem;
  font-family:'JetBrains Mono',monospace;
  color:var(--accent);
}
.wa-contact-card .wa-arrow{color:rgba(255,255,255,.2);font-size:.8rem;transition:all .3s}
.wa-contact-card:hover .wa-arrow{color:#25d366;transform:translateX(3px)}
.phone-dock{
  display:flex;justify-content:center;gap:1.25rem;
  padding:.85rem 0 .15rem;
  margin-top:.9rem;
}
.phone-dock-dot{
  display:inline-block;
  border:1px solid rgba(255,255,255,.28);
  background:rgba(255,255,255,.08);
}
.phone-dock-dot.is-circle{width:8px;height:8px;border-radius:50%}
.phone-dock-dot.is-pill{width:24px;height:8px;border-radius:999px}
.phone-dock-dot.is-square{width:8px;height:8px;border-radius:2px}

/* Phone side faces */
.phone-side-right{
  width:12px;height:440px;
  background:linear-gradient(180deg,#2a2a3e,#1a1a2e);
  border-radius:0 4px 4px 0;
  transform:rotateY(90deg) translateZ(110px) translateX(-6px);
}
.phone-side-left{
  width:12px;height:440px;
  background:linear-gradient(180deg,#2a2a3e,#1a1a2e);
  border-radius:4px 0 0 4px;
  transform:rotateY(-90deg) translateZ(110px) translateX(6px);
}
.phone-side-top{
  width:220px;height:12px;
  background:#2a2a3e;border-radius:4px;
  transform:rotateX(90deg) translateZ(6px);
}
.phone-side-bottom{
  width:220px;height:12px;
  background:#2a2a3e;border-radius:4px;
  transform:rotateX(-90deg) translateZ(434px);
}
.phone-back{
  width:220px;height:440px;
  background:linear-gradient(160deg,#0a0a15,#08081a);
  border-radius:28px;border:3px solid #222235;
  transform:translateZ(-6px) rotateY(180deg);
}
.phone-glow{
  position:absolute;width:300px;height:300px;
  background:radial-gradient(circle,rgba(0,212,255,.12),transparent 70%);
  top:50%;left:50%;transform:translate(-50%,-50%) translateZ(-20px);
  pointer-events:none;animation:phoneGlow 4s ease-in-out infinite alternate;
}
@keyframes phoneGlow{0%{opacity:.5;transform:translate(-50%,-50%) translateZ(-20px) scale(1)}100%{opacity:1;transform:translate(-50%,-50%) translateZ(-20px) scale(1.15)}}

/* Contact info side */
.contact-info{padding:1rem 0}
.contact-info .section-title{margin-bottom:1rem}
.contact-text{color:var(--text-dim);font-size:1rem;line-height:1.8;margin-bottom:2rem}
.contact-cards{display:flex;flex-direction:column;gap:1rem}
.contact-card{
  display:flex;align-items:center;gap:1.2rem;
  padding:1.3rem 1.5rem;border-radius:18px;
  background:var(--glass);backdrop-filter:blur(16px);
  border:1px solid var(--glass-border);
  transition:all .4s;text-decoration:none;color:inherit;
}
.contact-card:hover{background:rgba(37,211,102,.08);border-color:rgba(37,211,102,.25);transform:translateX(8px)}
.cc-icon{
  width:56px;height:56px;border-radius:16px;display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:1.5rem;
}
.cc-icon.wa-green{background:rgba(37,211,102,.15)}
.cc-icon.wa-blue{background:rgba(0,212,255,.15)}
.cc-body h4{font-size:1.05rem;font-weight:600;margin-bottom:.2rem}
.cc-body p{font-size:.85rem;color:var(--text-dim)}
.cc-body .cc-phone{font-family:'JetBrains Mono',monospace;font-size:.82rem;color:var(--accent);margin-top:.3rem}
.contact-card .cc-arrow{margin-left:auto;font-size:1.2rem;color:var(--text-dim);transition:all .3s}
.contact-card:hover .cc-arrow{color:#25d366;transform:translateX(4px)}

/* ── SOCIAL SIDEBAR (fixed left) ── */
.social-sidebar{
  position:fixed;left:0;top:50%;transform:translateY(-50%);
  z-index:100;display:flex;flex-direction:column;gap:0;
}
.social-sb-item{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  background:rgba(18,18,30,.7);backdrop-filter:blur(12px);
  border:1px solid var(--glass-border);border-left:none;
  cursor:pointer;transition:all .35s cubic-bezier(.22,1,.36,1);
  position:relative;overflow:hidden;
}
.social-sb-item:first-child{border-radius:0 12px 0 0}
.social-sb-item:last-child{border-radius:0 0 12px 0}
.social-sb-item svg{width:20px;height:20px;fill:rgba(255,255,255,.5);transition:all .3s;position:relative;z-index:1}
.social-sb-item .sb-bg{position:absolute;inset:0;opacity:0;transition:opacity .3s}
.social-sb-item:hover{width:54px;border-color:transparent}
.social-sb-item:hover svg{fill:#fff;transform:scale(1.15)}
.social-sb-item:hover .sb-bg{opacity:1}
.social-sb-item.x-tw .sb-bg{background:#000}
.social-sb-item.ig .sb-bg{background:linear-gradient(135deg,#ff7a00,#ff0169,#d300c5)}
.social-sb-item.fb .sb-bg{background:#316ff6}
.social-sb-item.gh .sb-bg{background:linear-gradient(180deg,#812290,#4d227c)}
.social-sb-item.wa .sb-bg{background:#25d366}

/* ── SCROLL ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.reveal{opacity:0;transform:translateY(40px);transition:all .7s cubic-bezier(.22,1,.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  .hero-grid,.about-grid,.pentest-layout{grid-template-columns:1fr}
  .hero-visual{order:-1;margin-bottom:2rem}
  .shield-container{width:250px;height:250px;margin:0 auto}
  .float-card:nth-child(7){display:none}
  .services-grid,.cases-grid{grid-template-columns:repeat(2,1fr)}
  .stats-bar{grid-template-columns:repeat(2,1fr)}
  .partner-card{width:190px}
  .contact-layout{grid-template-columns:1fr}
  .phone-3d{transform:rotateY(-8deg) rotateX(3deg)}
}
@media(max-width:768px){
  .nav-links{
    position:fixed;top:0;right:-100%;width:80%;max-width:320px;height:100vh;
    flex-direction:column;justify-content:center;gap:.5rem;
    background:rgba(10,10,15,.95);backdrop-filter:blur(30px);
    padding:2rem;transition:right .4s;z-index:999;
  }
  .nav-links.open{right:0}
  .mobile-toggle{display:flex;z-index:1001}
  .services-grid,.cases-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  section{padding:6rem 1.2rem 3rem}
  .float-card{display:none}
  .social-sidebar{
    position:fixed;left:auto;right:0;top:auto;bottom:0;
    transform:none;flex-direction:row;
    border-radius:12px 12px 0 0;
  }
  .social-sb-item{width:44px;height:44px;border:1px solid var(--glass-border);border-bottom:none;border-left:1px solid var(--glass-border)}
  .social-sb-item:first-child{border-radius:12px 0 0 0}
  .social-sb-item:last-child{border-radius:0 12px 0 0}
  .social-sb-item:hover{width:44px;height:50px}
  .contact-phone-scene{min-height:380px}
  .phone-3d{width:180px;height:360px}
  .phone-front{width:180px;height:360px}
  .phone-side-right{height:360px;transform:rotateY(90deg) translateZ(90px) translateX(-6px)}
  .phone-side-left{height:360px;transform:rotateY(-90deg) translateZ(90px) translateX(6px)}
  .phone-side-bottom{width:180px;transform:rotateX(-90deg) translateZ(354px)}
  .phone-side-top{width:180px}
  .phone-back{width:180px;height:360px}
}



/* ── EXTRA HELPERS FOR MVC PAGES ── */
.section-compact{position:relative;z-index:1;padding:0 2rem 4rem}
.page-hero{
  position:relative;z-index:1;
  min-height:45vh;padding:8rem 2rem 3rem;
  display:flex;align-items:end;
}
.page-hero-inner{
  background:var(--glass);
  backdrop-filter:blur(20px);
  border:1px solid var(--glass-border);
  border-radius:24px;
  padding:2.5rem;
}
.partners-note{
  text-align:center;margin-top:2rem;
}
.partners-note p{
  color:var(--text-dim);font-size:.85rem;max-width:700px;margin:0 auto;
}
.partners-note code{
  color:var(--accent);
  font-family:'JetBrains Mono',monospace;
  font-size:.78rem;
  background:rgba(0,212,255,.08);
  padding:.15rem .4rem;
  border-radius:4px;
}
.form-alert{
  border-radius:14px;
  padding:.9rem 1rem;
  margin-bottom:1rem;
  font-size:.9rem;
  border:1px solid transparent;
}
.form-alert.success{
  background:rgba(0,255,136,.08);
  border-color:rgba(0,255,136,.2);
  color:#9ff9ca;
}
.form-alert.error{
  background:rgba(255,107,107,.08);
  border-color:rgba(255,107,107,.2);
  color:#ffd4d4;
}
@media(max-width:768px){
  .section-compact{padding:0 1.2rem 3rem}
  .page-hero{padding:7rem 1.2rem 2rem}
  .page-hero-inner{padding:1.5rem}
}
