/* ============================================================
   Escalitics — style.css
   Black bg + grid lines + #00D4FF cyan + #0055FF blue
   ============================================================ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --bg:          #050505;
  --bg-alt:      #080808;
  --surface:     #0d0d0d;
  --card:        #111;
  --border:      rgba(255,255,255,0.07);
  --border-md:   rgba(255,255,255,0.12);
  --border-hi:   rgba(255,255,255,0.20);
  --text:        #f5f5f5;
  --text-muted:  #aaa;
  --text-soft:   #c8c8c8;
  --accent:      #00D4FF;
  --accent2:     #0055FF;
  --accent-glow: rgba(0,212,255,0.20);
  --accent-glow2:rgba(0,85,255,0.12);
  --accent-dark: rgba(0,212,255,0.07);
  --grid-color:  rgba(255,255,255,0.038);
  --grid-size:   60px;

  --sans: 'Inter', system-ui, -apple-system, sans-serif;
  --mono: 'JetBrains Mono', 'Courier New', monospace;

  --r:    4px;
  --r-md: 8px;
  --r-lg: 14px;
  --r-xl: 9999px;

  --ease: cubic-bezier(0.16,1,0.3,1);
  --t-f: 150ms ease;
  --t-b: 250ms ease;
  --t-s: 600ms var(--ease);

  --max-w: 1200px;
  --px: 24px;
}


/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body{
  background-color:var(--bg);
  background-image:
    linear-gradient(var(--grid-color) 1px,transparent 1px),
    linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);
  background-size:var(--grid-size) var(--grid-size);
  color:var(--text);font-family:var(--sans);font-size:16px;line-height:1.6;overflow-x:hidden;
  transition:background-color .4s ease,color .4s ease;
}
a{color:inherit;text-decoration:none}
ul{list-style:none}
svg{display:block;flex-shrink:0}
button{cursor:pointer;background:none;border:none;font:inherit;color:inherit}
input,textarea{font:inherit;color:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.block{display:block}
.muted{color:var(--text-muted)}
.d-lg{display:none!important}
.d-mobile{display:flex!important}

/* ── Cursor glow ────────────────────────────────────────────── */
#cursor-glow{
  position:fixed;width:300px;height:300px;border-radius:50%;
  pointer-events:none;z-index:0;transform:translate(-50%,-50%);
  background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);
  opacity:0;transition:opacity .3s ease;
}

/* ── Mono ────────────────────────────────────────────────────── */
.mono-xs{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.15em;color:var(--text-muted)}
.accent-text{color:var(--accent)}
.accent-link{color:var(--accent);transition:opacity var(--t-f)}
.accent-link:hover{opacity:.75}

/* ── Container ──────────────────────────────────────────────── */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--px);position:relative;z-index:2}

/* ── Live dot ───────────────────────────────────────────────── */
.live-dot{position:relative;display:inline-flex;width:8px;height:8px;flex-shrink:0}
.live-dot.small{width:6px;height:6px}
.ld-ping{position:absolute;inset:0;border-radius:50%;background:var(--accent);opacity:.7;animation:ping 1.5s cubic-bezier(0,0,.2,1) infinite}
.ld-core{position:relative;width:100%;height:100%;border-radius:50%;background:var(--accent)}
@keyframes ping{75%,100%{transform:scale(2.2);opacity:0}}

/* ── Loader ──────────────────────────────────────────────────── */
#loader{
  position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;
  background:var(--bg);
  transition:opacity .6s ease,visibility .6s ease;
}
#loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:60px 60px;opacity:.5}
.loader-inner{position:relative;display:flex;flex-direction:column;align-items:center;gap:16px}
.loader-logo{width:56px;height:56px;object-fit:contain;animation:loader-spin 2s linear infinite;filter:drop-shadow(0 0 10px var(--accent))}
@keyframes loader-spin{to{transform:rotate(360deg)}}
.loader-label{font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted)}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn-primary{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  height:48px;padding:0 24px;background:transparent;color:var(--accent);
  font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.08em;
  border:1px solid rgba(0,212,255,.5);border-radius:var(--r);
  box-shadow:0 0 14px var(--accent-glow);
  transition:all var(--t-b);white-space:nowrap;
}
.btn-primary:hover{background:var(--accent);color:#000;border-color:var(--accent);transform:scale(1.03);box-shadow:0 0 36px var(--accent-glow)}


/* ── Hamburger ───────────────────────────────────────────────── */
.hamburger{flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:rgba(255,255,255,.06);border:1px solid var(--border);border-radius:var(--r-md)}
.hamburger span{display:block;width:16px;height:1px;background:var(--text);transition:transform var(--t-b),opacity var(--t-b)}
.hamburger.open span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* ── 3D Tilt ─────────────────────────────────────────────────── */
.tilt-card{transform-style:preserve-3d;transition:transform .15s ease}

/* ── Reveal ──────────────────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(16px);transition:opacity var(--t-s),transform var(--t-s)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-x{opacity:0;transform:translateX(24px);transition:opacity var(--t-s),transform var(--t-s)}
.reveal-x.visible{opacity:1;transform:translateX(0)}

/* ════════════════════════════════════
   HEADER
════════════════════════════════════ */
#header{position:fixed;top:0;left:0;right:0;z-index:100;background:transparent;border:none}
.header-inner{max-width:var(--max-w);margin:0 auto;padding:0 var(--px);height:72px;display:flex;align-items:center;justify-content:space-between;position:relative}

/* Logo — no background, plain */
.logo-link{display:flex;align-items:center;gap:10px;white-space:nowrap;transition:opacity var(--t-f);z-index:2}
.logo-link:hover{opacity:.75}
.logo-icon{width:28px;height:28px;object-fit:contain}
.logo-name{font-size:16px;font-weight:600;letter-spacing:-.02em;line-height:1}

/* Right section */
.header-right{display:flex;align-items:center;gap:10px;z-index:2}
.header-email-btn{width:46px;height:46px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:#383838;color:rgba(255,255,255,.75);transition:color var(--t-f),background var(--t-f)}
.header-email-btn:hover{color:#fff;background:#484848}
.header-email-btn svg{width:19px;height:19px}

/* Nav pill — solid gray, centered, Lesse-style */
.nav-pill{
  position:absolute;left:50%;top:50%;transform:translateX(-50%) translateY(-50%);
  display:flex;align-items:center;gap:0;justify-content:space-between;
  background:#383838;
  border-radius:27px;
  padding:6px 8px;height:54px;
  min-width:680px;
  transition:border-bottom-left-radius .2s ease,border-bottom-right-radius .2s ease;
}
.nav-pill:has(.nav-pill-btn.open){
  border-bottom-left-radius:0;
  border-bottom-right-radius:0;
}
.nav-pill-link{
  display:flex;align-items:center;gap:6px;
  padding:0 30px;height:42px;border-radius:var(--r-xl);
  font-family:var(--sans);font-size:15.5px;font-weight:400;
  text-transform:none;letter-spacing:-.01em;
  color:rgba(255,255,255,.8);background:none;border:none;cursor:pointer;
  transition:color var(--t-f),background var(--t-f);white-space:nowrap;text-decoration:none;
}
.nav-pill-link:hover{color:#fff;background:rgba(255,255,255,.1)}
.nav-pill-btn.open{color:#fff;background:rgba(255,255,255,.1)}
.nav-chevron{width:13px;height:13px;flex-shrink:0;transition:transform .25s ease}
.nav-pill-btn.open .nav-chevron{transform:rotate(180deg)}
.nav-drop-wrap{position:relative}
.nav-pill-accent{
  display:flex;align-items:center;
  padding:0 26px;height:42px;border-radius:var(--r-xl);
  font-family:var(--sans);font-size:15.5px;font-weight:500;letter-spacing:-.01em;
  background:var(--accent);color:#000;white-space:nowrap;text-decoration:none;
  border:1px solid var(--accent);
  transition:background var(--t-f),color var(--t-f),box-shadow var(--t-f),transform var(--t-f);
}
.nav-pill-accent:hover{transform:scale(1.03);box-shadow:0 0 20px var(--accent-glow)}

/* ── Services dropdown panel ─────────────────────────────── */
.svc-drop-panel{
  position:fixed;top:63px;left:50%;
  transform:translateX(-50%) translateY(-6px);
  width:680px;max-width:calc(100vw - 32px);
  z-index:99;pointer-events:none;opacity:0;visibility:hidden;
  background:#383838;
  border-radius:0 0 18px 18px;
  padding:6px;
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
}
.svc-drop-panel.open{opacity:1;visibility:visible;pointer-events:auto;transform:translateX(-50%) translateY(0)}
.svc-drop-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.svc-g-card{
  position:relative;height:88px;
  background:#2c2c2c;border-radius:10px;
  overflow:hidden;text-decoration:none;
  display:flex;align-items:center;
  cursor:pointer;transition:background .2s;
}
.svc-g-card:hover{background:#333}
.svc-g-bg{position:absolute;inset:0;z-index:0}
.svc-g-img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:0;transition:opacity .4s ease}
.svc-g-overlay{position:absolute;inset:0;background:linear-gradient(160deg,rgba(0,0,0,.3) 0%,rgba(0,0,0,.7) 100%);opacity:0;transition:opacity .4s ease}
.svc-g-card:hover .svc-g-img{opacity:1}
.svc-g-card:hover .svc-g-overlay{opacity:1}
.svc-g-content{position:relative;z-index:1;display:flex;flex-direction:row;align-items:center;gap:12px;width:100%;padding:0 16px}
.svc-g-top{display:flex;align-items:center;justify-content:space-between;flex:1;gap:8px}
.svc-g-name{font-size:14px;font-weight:400;letter-spacing:-.01em;color:rgba(255,255,255,.75);transition:color .2s;line-height:1}
.svc-g-card:hover .svc-g-name{color:#fff}
.svc-g-count{font-family:var(--mono);font-size:10px;letter-spacing:.04em;color:rgba(255,255,255,.3);white-space:nowrap}
.svc-g-icon{order:-1;width:18px;height:18px;color:rgba(255,255,255,.35);transition:color .2s;flex-shrink:0}
.svc-g-card:hover .svc-g-icon{color:rgba(255,255,255,.7)}
.svc-g-icon svg{width:100%;height:100%}

/* Mobile menu */
.mobile-menu{background:var(--bg);max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.mobile-menu.open{max-height:500px;border-top:1px solid var(--border)}
.mob-link{display:block;padding:16px 24px;font-family:var(--mono);font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border-bottom:1px solid var(--border);transition:color var(--t-f)}
.mob-link:hover{color:var(--text)}
.accent-mob{color:var(--accent)}

/* ════════════════════════════════════
   HERO
════════════════════════════════════ */
.hero-section{
  position:relative;display:flex;flex-direction:column;min-height:100svh;padding-top:64px;
  z-index:2;
}
/* Gradient fade at hero bottom to blend into next section */
.grid-hero{
  position:absolute;inset-x:0;top:0;height:100%;
  background:radial-gradient(ellipse 90% 60% at 50% 0%,rgba(0,212,255,0.06) 0%,transparent 60%);
  pointer-events:none;
}
.hero-fade-btm{
  position:absolute;inset-x:0;bottom:0;height:160px;
  background:linear-gradient(to bottom,transparent,var(--bg));
  pointer-events:none;z-index:1;
}
.hero-content{position:relative;flex:1;display:flex;align-items:center;padding:48px 0 32px;z-index:2}
.hero-grid{max-width:var(--max-w);margin:0 auto;padding:0 var(--px);width:100%;display:grid;grid-template-columns:1fr;gap:32px;align-items:center}

/* Copy */
.hero-copy{display:flex;flex-direction:column;gap:20px}
.hero-badges{display:flex;flex-wrap:wrap;gap:8px}
.badge{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);border:.5px solid var(--border);border-radius:var(--r);padding:4px 10px}
.hero-h1{font-size:38px;font-weight:500;letter-spacing:-.03em;line-height:1.05}
.hero-line{display:block}
.hero-rotating{position:relative;display:block;height:2.3em}
.rw{position:absolute;inset:0;color:var(--accent);opacity:0;transform:translateY(10px);transition:opacity 250ms ease,transform 250ms ease;text-shadow:0 0 30px var(--accent-glow)}
.rw.active{opacity:1;transform:translateY(0)}
.rw.exit{opacity:0;transform:translateY(-10px)}
.hero-sub{font-size:17px;color:var(--text-muted);line-height:1.65;max-width:440px}
.hero-ctas{display:flex;flex-wrap:wrap;gap:12px}

/* Right column */
.hero-right{display:flex;flex-direction:column;gap:14px}

/* ── Media card (showreel style) ─────────────────────────────── */
@keyframes neon-pulse{
  0%,100%{filter:drop-shadow(0 0 8px rgba(0,212,255,.3)) drop-shadow(0 0 24px rgba(0,212,255,.1))}
  50%    {filter:drop-shadow(0 0 18px rgba(0,212,255,.65)) drop-shadow(0 0 48px rgba(0,212,255,.22))}
}
.media-card{
  position:relative;width:100%;overflow:hidden;
  border-radius:var(--r-md);border:1px solid rgba(0,212,255,.35);
  background:#000;
  aspect-ratio:16/9;
  animation:neon-pulse 3s ease-in-out infinite;
}
.media-card-grid{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:40px 40px;
  opacity:.7;
}
.media-card-gradient{
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(0,212,255,.08) 0%,transparent 50%,rgba(0,85,255,.06) 100%);
}
/* Badge top-left */
.media-badge{
  position:absolute;top:16px;left:16px;z-index:2;
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;
  color:rgba(255,255,255,.8);border:.5px solid rgba(255,255,255,.18);
  background:rgba(0,0,0,.45);backdrop-filter:blur(8px);
  padding:5px 12px;border-radius:var(--r);
}
/* Bottom right tag */
.media-footer-tag{
  position:absolute;bottom:14px;right:16px;z-index:2;
  font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.1em;
  color:rgba(255,255,255,.3);border:.5px solid rgba(255,255,255,.1);
  background:rgba(0,0,0,.4);backdrop-filter:blur(6px);
  padding:4px 10px;border-radius:var(--r);
}

/* ── Hero images (crossfade) ─────────────────────────────────── */
.hero-img-wrap{position:absolute;inset:0;z-index:2;border-radius:inherit}
.hero-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  display:block;border-radius:inherit;
  opacity:0;transition:opacity .9s ease;
}
.hero-img.active{opacity:1}

/* ── Contact card (below media) ──────────────────────────────── */
.contact-card-link{
  display:block;border:1px solid var(--border);border-radius:var(--r-md);
  background:var(--surface);overflow:hidden;
  transition:border-color var(--t-b),transform .15s;
}
.contact-card-link:hover{border-color:rgba(0,212,255,.35);transform:translateY(-2px)}
.contact-card-inner{display:flex;align-items:center;gap:16px;padding:16px 20px}
.cc-avatar{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:11px;color:var(--accent);flex-shrink:0}
.cc-info{flex:1;min-width:0}
.cc-status{display:flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px}
.cc-name{font-size:16px;font-weight:500;letter-spacing:-.01em;line-height:1.3}
.cc-arrow{width:40px;height:40px;border-radius:50%;background:var(--accent);color:#000;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:transform var(--t-f);box-shadow:0 0 12px var(--accent-glow)}
.contact-card-link:hover .cc-arrow{transform:translateX(2px)}


/* ════════════════════════════════════
   SECTIONS
════════════════════════════════════ */
.section{padding:80px 0;position:relative;z-index:2}
.section-alt{background:var(--bg-alt)}
.section-h2{font-size:32px;font-weight:500;letter-spacing:-.03em;line-height:1.1;max-width:680px}
.sh-grid{display:grid;grid-template-columns:1fr;gap:32px;margin-bottom:56px;align-items:start}
.sh-left{display:flex;flex-direction:column;gap:16px}


/* ── Services ─────────────────────────────────────────────────── */
#servicios .container{max-width:1480px}
.svc-grid{display:grid;grid-template-columns:1fr;gap:16px}
.svc-card{position:relative;background:var(--card);border:1px solid var(--border-md);border-radius:var(--r-lg);padding:32px;display:flex;flex-direction:column;gap:20px;transition:border-color var(--t-b)}
.svc-card:hover{border-color:rgba(0,212,255,.35)}
.svc-tag{display:inline-block;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.22);border-radius:4px;padding:5px 10px;width:fit-content}
.svc-name{font-size:26px;font-weight:500;letter-spacing:-.03em;line-height:1.15}
.svc-desc{font-size:14px;color:var(--text-muted);line-height:1.6}
.svc-list{display:flex;flex-direction:column;gap:10px;flex:1}
.svc-list li{font-size:14px;color:var(--text-soft);padding-left:22px;position:relative}
.svc-list li::before{content:'✓';position:absolute;left:0;color:var(--accent);font-size:13px;font-weight:700}
.svc-btn{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border:1px solid var(--border-md);border-radius:var(--r-md);font-family:var(--mono);font-size:11px;letter-spacing:.12em;color:var(--text);text-decoration:none;transition:background var(--t-b),border-color var(--t-b),color var(--t-b)}
.svc-btn:hover{background:var(--accent);border-color:var(--accent);color:#000}
.svc-btn svg{width:16px;height:16px;flex-shrink:0;transition:transform .2s}
.svc-btn:hover svg{transform:translate(3px,-3px)}

/* ── Cases ───────────────────────────────────────────────────── */
.cases-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:48px}
.case-card{border:1px solid var(--border);border-radius:var(--r-md);background:var(--card);padding:28px;display:flex;flex-direction:column;gap:12px;transition:border-color var(--t-b)}
.case-card:hover{border-color:rgba(0,212,255,.25)}
.case-tag{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}
.case-brand{font-size:20px;font-weight:500;letter-spacing:-.02em}
.case-result{font-size:30px;font-weight:700;letter-spacing:-.04em;color:var(--accent);text-shadow:0 0 20px var(--accent-glow)}
.case-sub{font-size:16px;font-weight:400;color:var(--text)}
.case-desc{font-size:14px;color:var(--text-muted);line-height:1.6}
.chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.chip{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-soft);border:.5px solid var(--border);border-radius:var(--r);padding:4px 10px}

/* ── Process ─────────────────────────────────────────────────── */
.process-list{display:flex;flex-direction:column;gap:0;margin-top:48px;max-width:640px}
.ps{display:flex;gap:24px;padding:24px 0}
.ps-line{width:2px;height:28px;background:linear-gradient(to bottom,var(--accent),var(--accent2));margin-left:23px;opacity:.35;box-shadow:0 0 6px var(--accent)}
.ps-num{font-family:var(--mono);font-size:12px;font-weight:500;color:var(--accent);flex-shrink:0;width:48px;height:48px;border:1px solid rgba(0,212,255,.25);border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--accent-dark);box-shadow:0 0 14px var(--accent-glow)}
.ps-body{flex:1;padding-top:10px}
.ps-title{font-size:18px;font-weight:500;letter-spacing:-.01em;margin-bottom:8px}
.ps-desc{font-size:14px;color:var(--text-muted);line-height:1.65}

#trabajos,#contacto{overflow:hidden}
.section-particles{position:absolute;inset:0;width:100%;height:100%;z-index:0;pointer-events:none}

/* ── Network / Alcance ───────────────────────────────────────── */
.globe-section{overflow:hidden}
#proceso{padding-bottom:40px}
#alcance{padding-top:40px}
.globe-wrap{max-width:var(--max-w);margin:0 auto;padding:40px var(--px) 80px;display:grid;grid-template-columns:1fr;gap:48px;align-items:center;position:relative;z-index:2}
.globe-copy{display:flex;flex-direction:column;gap:20px}
.globe-desc{font-size:16px;color:var(--text-muted);line-height:1.7;max-width:480px}
.globe-btns{display:flex;flex-wrap:wrap;gap:12px}
.network-area{position:relative;width:100%;max-width:520px;margin:0 auto;aspect-ratio:4/3;border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--card)}
.network-img{width:100%;height:100%;object-fit:cover;object-position:center;display:block;border-radius:inherit}


/* ── Contact ─────────────────────────────────────────────────── */
.contact-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:48px}
.contact-left{display:flex;flex-direction:column;gap:16px}

.contact-info-card,
.contact-call-card,
.contact-form-card{
  border:1px solid var(--border);border-radius:var(--r-md);
  background:var(--card);padding:28px;
  display:flex;flex-direction:column;gap:16px;
  transition:border-color var(--t-b);
}
.contact-info-card:hover,.contact-call-card:hover,.contact-form-card:hover{border-color:var(--border-md)}
.cic-title{font-size:20px;font-weight:500;letter-spacing:-.02em}
.cic-sub{font-size:14px;color:var(--text-muted);line-height:1.6}
.cic-row{display:flex;align-items:baseline;gap:16px}
.cic-label{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);flex-shrink:0;width:80px}
.cic-value{font-size:15px;font-weight:500;color:var(--text);transition:color var(--t-f)}
.cic-value:hover{color:var(--accent)}

.call-profile{display:flex;align-items:center;gap:14px}
.call-avatar{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);background:var(--accent-dark);display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:12px;color:var(--accent);flex-shrink:0}
.call-name{font-size:16px;font-weight:500;letter-spacing:-.01em}

.contact-cta-btn{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;
  font-family:var(--mono);font-size:12px;font-weight:500;text-transform:uppercase;letter-spacing:.1em;
  color:var(--accent);border:1px solid rgba(0,212,255,.4);border-radius:var(--r);
  background:rgba(0,212,255,.04);
  transition:color var(--t-b),border-color var(--t-b),background var(--t-b);
  cursor:pointer;width:100%;text-align:left;
}
.contact-cta-btn:hover{color:#000;border-color:var(--accent);background:var(--accent)}
.submit-btn{margin-top:4px}

/* Form */
.contact-form{display:flex;flex-direction:column;gap:12px}
.form-group{display:flex;flex-direction:column}
.form-input,.form-textarea{
  width:100%;padding:14px 16px;
  background:var(--surface);border:1px solid rgba(0,212,255,.15);border-radius:var(--r);
  color:var(--text);font-size:14px;
  transition:border-color var(--t-b),box-shadow var(--t-b);
  outline:none;resize:vertical;
}
.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}
.form-input:focus,.form-textarea:focus{border-color:rgba(0,212,255,.4);box-shadow:0 0 0 3px var(--accent-dark)}
.form-input.input-error,.form-textarea.input-error{border-color:rgba(255,70,70,.6);box-shadow:0 0 0 3px rgba(255,70,70,.08)}
.form-error-msg{font-family:var(--mono);font-size:10px;color:#ff4646;margin-top:5px;display:none;letter-spacing:.04em}
.form-error-msg.visible{display:block}

/* ── Footer ──────────────────────────────────────────────────── */
.footer{border-top:1px solid var(--border);position:relative;z-index:2;background:var(--bg)}

/* Main bar */
.footer-bar{
  max-width:var(--max-w);margin:0 auto;padding:24px var(--px);
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:20px;
}

/* Clock */
.footer-clock-wrap{display:flex;align-items:center;gap:14px}
#clock-canvas{display:block;flex-shrink:0}
.clock-text{display:flex;flex-direction:column;gap:2px}
.clock-time{font-family:var(--mono);font-size:16px;font-weight:500;letter-spacing:.05em;color:var(--accent)}
.clock-date,.clock-tz{font-family:var(--mono);font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}

/* CTA pill */
.footer-cta-pill{
  display:inline-flex;align-items:center;gap:12px;
  padding:0 20px;height:48px;border-radius:var(--r-xl);
  border:1px solid var(--border-md);
  font-family:var(--mono);font-size:11px;text-transform:uppercase;letter-spacing:.1em;
  color:var(--text);white-space:nowrap;
  transition:all var(--t-b);
}
.footer-cta-pill:hover{border-color:var(--accent);color:var(--accent);box-shadow:0 0 16px var(--accent-glow)}
.footer-pill-icon{font-size:16px;color:var(--accent)}
.footer-pill-arrow{font-size:14px;color:var(--accent)}

/* Right */
.footer-right{display:flex;align-items:center;gap:12px;justify-content:flex-end}
.footer-socials{display:flex;align-items:center;gap:8px}
.footer-social{
  display:flex;align-items:center;justify-content:center;
  width:36px;height:36px;border:1px solid var(--border);border-radius:var(--r);
  color:var(--text-muted);transition:all var(--t-f);
}
.footer-social svg{width:15px;height:15px}
.footer-social:hover{color:var(--text);border-color:var(--border-md)}
.footer-sep-v{width:1px;height:20px;background:var(--border);flex-shrink:0}
.footer-mini-link{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);transition:color var(--t-f);background:none;border:none;cursor:pointer;padding:0}
.footer-mini-link:hover{color:var(--text)}

/* Privacy tooltip card */
.privacy-wrap{position:relative}
.privacy-btn{color:var(--text-muted)}
.privacy-btn:hover{color:var(--text)}
.privacy-card{
  position:absolute;bottom:calc(100% + 10px);right:0;
  width:260px;padding:14px 16px;
  background:var(--card);border:1px solid var(--border-md);border-radius:var(--r-md);
  box-shadow:0 8px 32px rgba(0,0,0,.55);
  opacity:0;visibility:hidden;pointer-events:none;
  transform:translateY(6px);
  transition:opacity .2s ease,transform .2s ease,visibility .2s;
  z-index:200;
}
.privacy-card::after{
  content:'';position:absolute;bottom:-5px;right:14px;
  width:8px;height:8px;background:var(--card);
  border-right:1px solid var(--border-md);border-bottom:1px solid var(--border-md);
  transform:rotate(45deg);
}
.privacy-wrap:hover .privacy-card,
.privacy-card.open{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}
.privacy-card-text{font-size:12px;color:var(--text-muted);line-height:1.65}

/* Bottom strip */
.footer-bottom{
  border-top:1px solid var(--border);
  max-width:var(--max-w);margin:0 auto;padding:16px var(--px);
  display:flex;justify-content:space-between;
}
.footer-copy{font-family:var(--mono);font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}

/* ════════════════════════════════════
   RESPONSIVE — mobile footer
════════════════════════════════════ */
@media(max-width:767px){
  .footer-bar{grid-template-columns:1fr;justify-items:center;gap:16px}
  .footer-clock-wrap{justify-content:center}
  .footer-right{justify-content:center}
}

/* ════════════════════════════════════
   RESPONSIVE 768px+
════════════════════════════════════ */
@media(min-width:768px){
  :root{--px:48px}
  .hero-h1{font-size:46px}
  .section-h2{font-size:38px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .cases-grid{grid-template-columns:1fr 1fr}
  .contact-grid{grid-template-columns:1fr 1fr}
}

/* ════════════════════════════════════
   RESPONSIVE 1024px+
════════════════════════════════════ */
@media(min-width:1024px){
  .d-lg{display:flex!important}
  .d-mobile{display:none!important}
  .hero-grid{grid-template-columns:5fr 7fr;gap:48px}
  .hero-h1{font-size:50px}
  .sh-grid{grid-template-columns:3fr 2fr;gap:48px}
  .svc-grid{grid-template-columns:repeat(4,1fr)}
  .cases-grid{grid-template-columns:1fr 1fr 1fr}
  .globe-wrap{grid-template-columns:1fr 1fr}
  .network-area{max-width:100%}
  .footer-bar{padding:28px var(--px)}
}

/* ── Scrollbar ───────────────────────────────────────────────── */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:rgba(255,255,255,.08);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.15)}
