/* ═══════════════════════════════════════════════════════════
   NEBIRON — Main Stylesheet
   nebiron.gr
═══════════════════════════════════════════════════════════ */

/* ── RESET ── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }

/* ── PREVENT HORIZONTAL OVERFLOW (Android / POCO fix) ── */
html, body {
  max-width: 100%;
  overflow-x: hidden;
  position: relative;
}
html {
  /* Prevent iOS/Android from zooming on input focus */
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

/* ── TOKENS ── */
:root {
  --bg:          #020408;
  --bg2:         #040810;
  --cyan:        #00f5ff;
  --cyan2:       #00c4cc;
  --purple:      #7c3aed;
  --purple2:     #a855f7;
  --green:       #00ff88;
  --amber:       #ffb800;
  --red:         #ff2d5b;
  --text:        #c8d8e8;
  --muted:       #4a6070;
  --bright:      #e8f4ff;
  --nav-h:       70px;
  --grid-color:  rgba(0,245,255,0.04);
}

/* ── BASE ── */
html { scroll-behavior:smooth; font-size:17px; }
body {
  background:var(--bg); color:var(--text);
  font-family:'Space Grotesk',sans-serif;
  overflow-x:hidden;
  min-height:100vh;
  width:100%;
  /* Prevent content shifting right due to scrollbar on desktop */
  scrollbar-gutter: stable;
}
a { color:inherit; text-decoration:none; }
::selection { background:rgba(0,245,255,0.25); color:#fff; }
::-webkit-scrollbar { width:4px; }
::-webkit-scrollbar-track { background:#020408; }
::-webkit-scrollbar-thumb { background:var(--cyan); }

/* ── AMBIENT LAYERS ── */
.grid-bg {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:
    linear-gradient(var(--grid-color) 1px, transparent 1px),
    linear-gradient(90deg, var(--grid-color) 1px, transparent 1px);
  background-size:60px 60px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 40%, black 20%, transparent 100%);
}
.scanline {
  position:fixed; inset:0; z-index:1; pointer-events:none;
  background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,245,255,0.007) 2px,rgba(0,245,255,0.007) 4px);
}
.blob { position:fixed; border-radius:50%; pointer-events:none; z-index:0; filter:blur(120px); mix-blend-mode:screen;
  /* Prevent blobs from expanding page width on mobile */
  max-width:100vw; overflow:hidden;
}
.blob-1 { width:min(700px,120vw);height:min(700px,120vw);top:-200px;left:-200px;background:radial-gradient(circle,rgba(124,58,237,0.25),transparent 70%);animation:bf 18s ease-in-out infinite; }
.blob-2 { width:min(600px,100vw);height:min(600px,100vw);bottom:-100px;right:-150px;background:radial-gradient(circle,rgba(0,245,255,0.15),transparent 70%);animation:bf 22s ease-in-out infinite reverse; }
.blob-3 { width:min(400px,80vw);height:min(400px,80vw);top:45%;left:35%;background:radial-gradient(circle,rgba(0,255,136,0.08),transparent 70%);animation:bf 15s ease-in-out infinite 5s; }
@keyframes bf { 0%,100%{transform:translate(0,0);} 33%{transform:translate(40px,-30px);} 66%{transform:translate(-20px,20px);} }

/* ── CURSOR ── */
#cursor {
  position:fixed; pointer-events:none; z-index:9999;
  width:12px; height:12px; border:1px solid var(--cyan); border-radius:50%;
  transform:translate(-50%,-50%); transition:width .25s,height .25s,opacity .25s;
  mix-blend-mode:difference;
}
#cursor-trail {
  position:fixed; pointer-events:none; z-index:9998;
  width:280px; height:280px;
  background:radial-gradient(circle,rgba(0,245,255,0.06),transparent 70%);
  border-radius:50%; transform:translate(-50%,-50%);
  transition:left .2s ease,top .2s ease;
}

/* ── NAV ── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-h);
  display:flex; align-items:center;
  padding:0 5vw;
  /* Safe area insets for notched phones */
  padding-left:max(5vw, env(safe-area-inset-left));
  padding-right:max(5vw, env(safe-area-inset-right));
  width:100%;
  background:rgba(2,4,8,0.65); backdrop-filter:blur(24px) saturate(200%);
  border-bottom:1px solid rgba(0,245,255,0.07); transition:all .4s;
}
nav::after {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent); opacity:.25;
}
nav.scrolled { background:rgba(2,4,8,0.92); box-shadow:0 0 50px rgba(0,245,255,0.04); }

.nav-logo {
  font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.25rem;
  letter-spacing:.12em; color:var(--bright); margin-right:auto; cursor:pointer; position:relative;
}
.nav-logo-glow {
  position:absolute; inset:0; color:var(--cyan); opacity:0; filter:blur(6px);
  pointer-events:none; animation:logoGlitch 9s infinite;
  font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.25rem; letter-spacing:.12em;
}
@keyframes logoGlitch {
  0%,94%,100%{opacity:0;transform:none;}
  95%{opacity:.9;transform:translateX(-2px);}
  97%{opacity:.5;transform:translateX(2px);}
  99%{opacity:0;}
}

.nav-links { display:flex; gap:2.5rem; list-style:none; align-items:center; }
.nav-links a {
  font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--muted);
  letter-spacing:.12em; text-transform:uppercase; transition:color .2s;
}
.nav-links a::before { content:'./'; color:var(--cyan); opacity:0; transition:opacity .2s; font-size:.65rem; }
.nav-links a:hover::before, .nav-links a.active::before { opacity:1; }
.nav-links a:hover, .nav-links a.active { color:var(--cyan); }

.nav-cta {
  margin-left:2rem; padding:.5rem 1.4rem; border:1px solid var(--cyan);
  font-family:'JetBrains Mono',monospace; font-size:.68rem; letter-spacing:.12em; text-transform:uppercase;
  color:var(--cyan)!important; position:relative; overflow:hidden; transition:all .3s; border-radius:2px;
}
.nav-cta::before { content:''; position:absolute; inset:0; background:var(--cyan); transform:translateX(-101%); transition:transform .3s; z-index:0; }
.nav-cta:hover::before { transform:translateX(0); }
.nav-cta span { position:relative; z-index:1; }
.nav-cta:hover { color:var(--bg)!important; }
.nav-cta::after { display:none!important; }

.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; margin-left:auto; }
.hamburger span { width:22px; height:1px; background:var(--cyan); transition:all .3s; }
.hamburger.open span:nth-child(1) { transform:rotate(45deg) translate(4px,4px); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:rotate(-45deg) translate(4px,-4px); }

.mobile-menu {
  display:none; position:fixed; inset:0; top:var(--nav-h);
  background:rgba(2,4,8,0.98); backdrop-filter:blur(20px);
  flex-direction:column; align-items:center; justify-content:center; gap:3rem; z-index:999;
}
.mobile-menu.open { display:flex; }
.mobile-menu a { font-family:'Orbitron',sans-serif; font-size:1.4rem; color:var(--text); letter-spacing:.1em; }

/* ── PAGES ── */
.page { display:none; min-height:100vh; padding-top:var(--nav-h); position:relative; z-index:1; width:100%; }
.page.active { display:block; }

/* ── COMMON LAYOUT ── */
.section { padding:7rem 5vw; width:100%; }

.section-label {
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:'JetBrains Mono',monospace; font-size:.68rem; font-weight:500;
  letter-spacing:.18em; text-transform:uppercase; color:var(--cyan); margin-bottom:1.5rem;
}
.section-label::before { content:'//'; opacity:.4; }
.section-label::after { content:''; width:50px; height:1px; background:linear-gradient(90deg,var(--cyan),transparent); }

.section-title {
  font-family:'Orbitron',sans-serif; font-weight:700;
  font-size:clamp(1.8rem,3.5vw,3.2rem); line-height:1.15;
  letter-spacing:-.01em; margin-bottom:1.5rem; color:var(--bright);
}
.section-body { color:var(--muted); font-size:1.08rem; line-height:1.85; max-width:580px; }
.cx { color:var(--cyan); }

/* ── CYBER CARD ── */
.cyber-card {
  background:rgba(4,8,16,0.85); border:1px solid rgba(0,245,255,0.1); border-radius:3px;
  position:relative; overflow:hidden; transition:all .4s cubic-bezier(.23,1,.32,1); backdrop-filter:blur(10px);
}
.cyber-card::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent); opacity:0; transition:opacity .4s;
}
.cyber-card:hover::before { opacity:1; }
.cyber-card:hover {
  border-color:rgba(0,245,255,0.28);
  box-shadow:0 0 50px rgba(0,245,255,0.06),inset 0 0 30px rgba(0,245,255,0.02);
  transform:translateY(-5px);
}
.corner { position:absolute; width:10px; height:10px; border-color:var(--cyan); border-style:solid; opacity:.4; }
.corner.tl { top:7px; left:7px; border-width:1px 0 0 1px; }
.corner.tr { top:7px; right:7px; border-width:1px 1px 0 0; }
.corner.bl { bottom:7px; left:7px; border-width:0 0 1px 1px; }
.corner.br { bottom:7px; right:7px; border-width:0 1px 1px 0; }

/* ── HERO ── */
.hero { min-height:calc(100vh - var(--nav-h)); display:grid; place-items:center; text-align:center; padding:4rem 5vw 6rem; position:relative; overflow:hidden; width:100%; }
.hero-lines { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.hline { position:absolute; width:100%; height:1px; background:linear-gradient(90deg,transparent,rgba(0,245,255,0.12),transparent); animation:scanH 7s linear infinite; }
.hline:nth-child(2) { animation-delay:-3.5s; opacity:.5; }
@keyframes scanH { from{top:-2%;} to{top:105%;} }

.hero-terminal {
  display:inline-flex; align-items:center; gap:.8rem;
  background:rgba(0,245,255,0.04); border:1px solid rgba(0,245,255,0.14); border-radius:3px;
  padding:.55rem 1.3rem; font-family:'JetBrains Mono',monospace; font-size:.82rem;
  color:var(--cyan); letter-spacing:.06em; margin-bottom:2.5rem; animation:fadeUp .6s ease both;
}
.tdots { display:flex; gap:5px; margin-right:.5rem; }
.td { width:8px; height:8px; border-radius:50%; }
.td.r { background:#ff5f57; } .td.y { background:#febc2e; } .td.g { background:#28c840; }
.blink { animation:blink .8s step-end infinite; }
@keyframes blink { 0%,100%{opacity:1;} 50%{opacity:0;} }

.hero-title {
  font-family:'Orbitron',sans-serif; font-weight:900;
  font-size:clamp(2.4rem,5.5vw,5.5rem); line-height:1.05; letter-spacing:-.02em;
  margin-bottom:1.5rem; color:var(--bright); animation:fadeUp .6s .1s ease both;
}
.hero-title .grad {
  display:block;
  background:linear-gradient(90deg,var(--cyan) 0%,var(--purple2) 50%,var(--green) 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200%; animation:fadeUp .6s .2s ease both, gradShift 5s linear infinite;
}
@keyframes gradShift { 0%{background-position:0%;} 100%{background-position:200%;} }

.hero-sub { font-size:1.15rem; color:var(--muted); max-width:640px; margin:0 auto 3rem; line-height:1.85; animation:fadeUp .6s .3s ease both; }
.hero-actions { display:flex; gap:1.2rem; justify-content:center; flex-wrap:wrap; animation:fadeUp .6s .4s ease both; }

.btn { display:inline-flex; align-items:center; gap:.6rem; padding:.9rem 2.2rem; border-radius:2px; font-family:'JetBrains Mono',monospace; font-size:.9rem; font-weight:500; letter-spacing:.08em; cursor:pointer; transition:all .3s; border:none; }
.btn-primary { background:var(--cyan); color:var(--bg); box-shadow:0 0 30px rgba(0,245,255,0.3); }
.btn-primary:hover { background:#fff; box-shadow:0 0 60px rgba(0,245,255,0.7); transform:translateY(-2px); }
.btn-ghost { background:transparent; border:1px solid rgba(0,245,255,0.3); color:var(--cyan); }
.btn-ghost:hover { border-color:var(--cyan); background:rgba(0,245,255,0.06); transform:translateY(-2px); }

.hero-scroll { position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); display:flex; flex-direction:column; align-items:center; gap:.4rem; font-family:'JetBrains Mono',monospace; font-size:.58rem; color:var(--muted); letter-spacing:.12em; animation:fadeUp .6s .8s ease both; }
.scroll-bar { width:1px; height:40px; background:linear-gradient(to bottom,var(--cyan),transparent); animation:sa 1.6s ease-in-out infinite; }
@keyframes sa { 0%{transform:scaleY(0);transform-origin:top;} 45%{transform:scaleY(1);transform-origin:top;} 55%{transform:scaleY(1);transform-origin:bottom;} 100%{transform:scaleY(0);transform-origin:bottom;} }

/* ── STATS ── */
.stats-strip { display:grid; grid-template-columns:repeat(4,1fr); position:relative; overflow:hidden; width:100%; }
.stats-strip::before { content:''; position:absolute; inset:0; border-top:1px solid rgba(0,245,255,0.08); border-bottom:1px solid rgba(0,245,255,0.08); }
.stats-strip::after { content:''; position:absolute; inset:0; background:linear-gradient(90deg,transparent,rgba(0,245,255,0.04),transparent); animation:sg 5s ease-in-out infinite; }
@keyframes sg { 0%,100%{opacity:0;transform:translateX(-100%);} 50%{opacity:1;transform:translateX(100%);} }
.stat { padding:2.5rem 2rem; text-align:center; border-right:1px solid rgba(0,245,255,0.06); position:relative; z-index:1; }
.stat:last-child { border-right:none; }
.stat-num { font-family:'Orbitron',sans-serif; font-weight:700; font-size:2.8rem; color:var(--cyan); letter-spacing:.05em; text-shadow:0 0 30px rgba(0,245,255,0.5); }
.stat-label { font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--muted); letter-spacing:.12em; margin-top:.5rem; }

/* ── SERVICES ── */
.services-grid {
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:1px; margin-top:4rem; background:rgba(0,245,255,0.05);
}
.service-card { padding:2.2rem; background:var(--bg2); position:relative; overflow:hidden; transition:all .3s; }
.service-card::before { content:''; position:absolute; top:0; left:0; width:2px; height:0; background:var(--cyan); transition:height .4s; }
.service-card:hover::before { height:100%; }
.service-card:hover { background:rgba(0,245,255,0.03); }
.svc-index { font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--muted); letter-spacing:.12em; margin-bottom:1.2rem; }
.svc-icon { width:48px; height:48px; border:1px solid rgba(0,245,255,0.18); display:grid; place-items:center; font-size:1.35rem; margin-bottom:1.4rem; position:relative; }
.svc-icon::after { content:''; position:absolute; bottom:-1px; right:-1px; width:5px; height:5px; background:var(--cyan); }
.svc-title { font-weight:600; font-size:1.05rem; color:var(--bright); margin-bottom:.8rem; }
.svc-body { color:var(--muted); font-size:.95rem; line-height:1.8; }

/* ── BRANDS ── */
.brands-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(300px,1fr)); gap:1.5rem; margin-top:4rem; }
.brand-card { padding:2.5rem; }
.brand-header { display:flex; align-items:center; gap:1.2rem; margin-bottom:2rem; }
.brand-badge { width:52px; height:52px; display:grid; place-items:center; font-family:'Orbitron',sans-serif; font-weight:700; font-size:.85rem; border:1px solid; position:relative; flex-shrink:0; }
.brand-badge::before { content:''; position:absolute; top:-3px; right:-3px; width:5px; height:5px; }
.brand-badge::after { content:''; position:absolute; bottom:-3px; left:-3px; width:5px; height:5px; }
.brand-badge.bm { border-color:var(--cyan); color:var(--cyan); }
.brand-badge.bm::before, .brand-badge.bm::after { background:var(--cyan); }
.brand-badge.bp { border-color:var(--purple2); color:var(--purple2); }
.brand-badge.bp::before, .brand-badge.bp::after { background:var(--purple2); }
.brand-badge.wd { border-color:var(--amber); color:var(--amber); }
.brand-badge.wd::before, .brand-badge.wd::after { background:var(--amber); }
.brand-name { font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.3rem; letter-spacing:.05em; }
.brand-name.bm { color:var(--cyan); }
.brand-name.bp { color:var(--purple2); }
.brand-name.wd { color:var(--amber); }
.brand-url { font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--muted); letter-spacing:.08em; margin-top:.2rem; }
.brand-tag { margin-left:auto; padding:.25rem .75rem; font-family:'JetBrains Mono',monospace; font-size:.65rem; letter-spacing:.1em; text-transform:uppercase; border:1px solid; border-radius:2px; flex-shrink:0; }
.brand-tag.bm { border-color:rgba(0,245,255,0.25); color:var(--cyan); }
.brand-tag.bp { border-color:rgba(168,85,247,0.25); color:var(--purple2); }
.brand-tag.wd { border-color:rgba(255,184,0,0.25); color:var(--amber); }
.brand-body { color:var(--muted); font-size:1rem; line-height:1.8; margin-bottom:2rem; }
.brand-link { display:inline-flex; align-items:center; gap:.6rem; font-family:'JetBrains Mono',monospace; font-size:.8rem; letter-spacing:.1em; transition:gap .3s; }
.brand-link.bm { color:var(--cyan); }
.brand-link.bp { color:var(--purple2); }
.brand-link.wd { color:var(--amber); }
.brand-card:hover .brand-link { gap:1rem; }

/* ── APPROACH ── */
.approach-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; margin-top:4rem; }
.approach-points { display:flex; flex-direction:column; }
.ap-item { display:flex; gap:1.5rem; padding:1.8rem 1.5rem; border-left:1px solid rgba(0,245,255,0.07); position:relative; transition:all .3s; cursor:default; }
.ap-item::before { content:''; position:absolute; left:-1px; top:0; bottom:0; width:1px; background:var(--cyan); transform:scaleY(0); transform-origin:top; transition:transform .4s; }
.ap-item:hover::before { transform:scaleY(1); }
.ap-item:hover { background:rgba(0,245,255,0.02); border-left-color:transparent; }
.ap-num { font-family:'JetBrains Mono',monospace; font-weight:700; font-size:1.8rem; color:rgba(0,245,255,0.1); line-height:1; flex-shrink:0; padding-top:.1rem; transition:color .3s; }
.ap-item:hover .ap-num { color:rgba(0,245,255,0.4); }
.ap-text h4 { font-weight:600; font-size:1.05rem; color:var(--bright); margin-bottom:.5rem; }
.ap-text p { color:var(--muted); font-size:.97rem; line-height:1.75; }

/* ── HEX VISUAL ── */
.hex-visual { display:grid; place-items:center; aspect-ratio:1; position:relative; max-width:420px; margin:0 auto; }
.hex-ring { position:absolute; border:1px solid; border-radius:50%; animation:hSpin 20s linear infinite; }
.hex-ring:nth-child(1) { width:88%; height:88%; border-color:rgba(0,245,255,0.08); animation-duration:32s; }
.hex-ring:nth-child(2) { width:66%; height:66%; border-color:rgba(124,58,237,0.12); animation-direction:reverse; animation-duration:20s; }
.hex-ring:nth-child(3) { width:44%; height:44%; border-color:rgba(0,255,136,0.16); animation-duration:12s; }
@keyframes hSpin { from{transform:rotate(0);} to{transform:rotate(360deg);} }
.hex-dot { position:absolute; width:8px; height:8px; border-radius:50%; top:6%; left:50%; transform:translate(-50%,-50%); }
.hex-dot.c { background:var(--cyan); box-shadow:0 0 14px var(--cyan); }
.hex-dot.p { background:var(--purple2); box-shadow:0 0 14px var(--purple2); }
.hex-dot.g { background:var(--green); box-shadow:0 0 14px var(--green); }
.hex-center { width:95px; height:95px; background:var(--bg2); border:1px solid rgba(0,245,255,0.22); display:grid; place-items:center; position:relative; box-shadow:0 0 60px rgba(0,245,255,0.1),inset 0 0 30px rgba(0,245,255,0.04); }
.hex-center::before, .hex-center::after { content:''; position:absolute; border:1px solid rgba(0,245,255,0.08); }
.hex-center::before { inset:-9px; }
.hex-center::after { inset:-18px; }
.hex-n { font-family:'Orbitron',sans-serif; font-weight:900; font-size:2rem; color:var(--cyan); text-shadow:0 0 30px rgba(0,245,255,0.8); animation:nPulse 3s ease-in-out infinite; }
@keyframes nPulse { 0%,100%{text-shadow:0 0 20px rgba(0,245,255,0.5);} 50%{text-shadow:0 0 50px rgba(0,245,255,1),0 0 80px rgba(0,245,255,0.4);} }
.data-stream { position:absolute; display:flex; flex-direction:column; gap:3px; font-family:'JetBrains Mono',monospace; font-size:.48rem; color:rgba(0,245,255,0.2); letter-spacing:.04em; pointer-events:none; line-height:1.5; }
.data-stream.left { right:calc(100% + 16px); text-align:right; }
.data-stream.right { left:calc(100% + 16px); }

/* ── CTA BANNER ── */
.cta-banner {
  margin:0 5vw 7rem; padding:5rem 4rem;
  background:rgba(4,8,16,0.9); border:1px solid rgba(0,245,255,0.1); border-radius:3px;
  text-align:center; position:relative; overflow:hidden;
}
.cta-banner::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--cyan),var(--purple2),transparent); }
.cta-banner::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at center,rgba(0,245,255,0.04),transparent 70%); pointer-events:none; }
.cta-banner h2 { font-family:'Orbitron',sans-serif; font-weight:700; font-size:clamp(1.6rem,3vw,2.6rem); color:var(--bright); margin-bottom:1rem; }
.cta-banner p { color:var(--muted); margin-bottom:2.5rem; font-family:'JetBrains Mono',monospace; font-size:.9rem; letter-spacing:.06em; }

/* ── ABOUT ── */
.about-hero { padding:7rem 5vw 4rem; display:grid; grid-template-columns:1fr 1fr; gap:6rem; align-items:start; }
.timeline { position:relative; padding-left:2.5rem; display:flex; flex-direction:column; }
.timeline::before { content:''; position:absolute; left:0; top:0; bottom:0; width:1px; background:linear-gradient(to bottom,var(--cyan),rgba(0,245,255,0.05)); }
.tl-item { position:relative; padding:1.5rem 0; }
.tl-dot { position:absolute; left:-2.9rem; top:1.9rem; width:8px; height:8px; border:1px solid var(--cyan); background:var(--bg); box-shadow:0 0 10px var(--cyan); }
.tl-year { font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--cyan); letter-spacing:.12em; margin-bottom:.4rem; }
.tl-title { font-weight:600; font-size:1.05rem; color:var(--bright); margin-bottom:.4rem; }
.tl-body { color:var(--muted); font-size:.94rem; line-height:1.75; }

.values-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; margin-top:4rem; background:rgba(0,245,255,0.05); }
.value-card { padding:2.5rem 2rem; background:var(--bg2); text-align:center; }
.value-icon { width:52px; height:52px; border:1px solid rgba(0,245,255,0.18); display:grid; place-items:center; font-size:1.3rem; margin:0 auto 1.5rem; position:relative; }
.value-icon::before { content:''; position:absolute; inset:-5px; border:1px solid rgba(0,245,255,0.07); }
.value-title { font-family:'Orbitron',sans-serif; font-weight:700; font-size:.88rem; color:var(--bright); letter-spacing:.1em; margin-bottom:.8rem; }
.value-body { color:var(--muted); font-size:.97rem; line-height:1.75; }

.how-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:1px; margin-top:4rem; background:rgba(0,245,255,0.05); }
.how-card { padding:2rem; background:var(--bg2); }
.step-num { font-family:'Orbitron',sans-serif; font-weight:900; font-size:3rem; color:rgba(0,245,255,0.06); line-height:1; margin-bottom:1rem; }
.how-title { font-weight:600; font-size:1.05rem; color:var(--bright); margin-bottom:.7rem; }
.how-body { color:var(--muted); font-size:.95rem; line-height:1.75; }

/* ── CONTACT ── */
.contact-wrap { padding:6rem 5vw; display:grid; grid-template-columns:1fr 1.5fr; gap:5rem; align-items:start; }
.contact-info h2 { font-family:'Orbitron',sans-serif; font-weight:700; font-size:clamp(1.6rem,3vw,2.5rem); color:var(--bright); letter-spacing:-.01em; margin-bottom:1.5rem; line-height:1.2; }
.contact-info p { color:var(--muted); line-height:1.85; margin-bottom:2.5rem; font-size:1.02rem; }
.contact-methods { display:flex; flex-direction:column; gap:.8rem; }
.contact-method { display:flex; gap:1rem; align-items:center; padding:1rem 1.2rem; background:rgba(0,245,255,0.02); border:1px solid rgba(0,245,255,0.07); border-radius:2px; }
.cm-icon { width:38px; height:38px; border:1px solid rgba(0,245,255,0.2); display:grid; place-items:center; font-family:'JetBrains Mono',monospace; font-size:.88rem; color:var(--cyan); flex-shrink:0; }
.cm-label { font-family:'JetBrains Mono',monospace; font-size:.65rem; color:var(--muted); letter-spacing:.1em; text-transform:uppercase; margin-bottom:.15rem; }
.cm-value { font-size:.98rem; color:var(--bright); }
.services-checklist { margin-top:2.5rem; }
.services-checklist h4 { font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--cyan); letter-spacing:.15em; text-transform:uppercase; margin-bottom:1rem; }
.check-item { display:flex; align-items:center; gap:.8rem; padding:.65rem 0; border-bottom:1px solid rgba(0,245,255,0.04); font-family:'JetBrains Mono',monospace; font-size:.85rem; color:var(--muted); }
.check-item:last-child { border-bottom:none; }
.check-icon { color:var(--cyan); }

/* ── FORM ── */
.contact-form { background:rgba(4,8,16,0.9); border:1px solid rgba(0,245,255,0.1); border-radius:3px; padding:3rem; position:relative; }
.contact-form::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,var(--cyan),transparent); }
.form-title { font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.05rem; color:var(--bright); letter-spacing:.08em; margin-bottom:2rem; display:flex; align-items:center; gap:.7rem; }
.form-title::before { content:'>'; font-family:'JetBrains Mono',monospace; color:var(--cyan); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.form-group { display:flex; flex-direction:column; gap:.4rem; margin-bottom:1rem; }
.form-group label { font-family:'JetBrains Mono',monospace; font-size:.68rem; color:var(--muted); letter-spacing:.12em; text-transform:uppercase; }
.form-group input, .form-group textarea, .form-group select {
  background:rgba(0,245,255,0.02); border:1px solid rgba(0,245,255,0.1); border-radius:2px;
  padding:.9rem 1.1rem; color:var(--text); font-family:'Space Grotesk',sans-serif; font-size:1rem;
  outline:none; transition:all .3s; resize:vertical; -webkit-appearance:none;
}
.form-group input:focus, .form-group textarea:focus, .form-group select:focus {
  border-color:var(--cyan); background:rgba(0,245,255,0.03); box-shadow:0 0 0 2px rgba(0,245,255,0.07);
}
.form-group textarea { min-height:120px; }
.form-group select option { background:var(--bg2); }

/* Form states */
.form-group input.error, .form-group textarea.error, .form-group select.error {
  border-color:var(--red); box-shadow:0 0 0 2px rgba(255,45,91,0.1);
}
.form-group input.valid, .form-group textarea.valid, .form-group select.valid {
  border-color:rgba(0,255,136,0.35);
}
.field-error {
  font-family:'JetBrains Mono',monospace; font-size:.58rem; color:var(--red);
  letter-spacing:.08em; margin-top:.3rem;
  opacity:0; transform:translateY(-4px); transition:opacity .2s,transform .2s;
}
.field-error.show { opacity:1; transform:translateY(0); }

.form-error-banner {
  display:none; padding:.85rem 1rem; margin-bottom:1.2rem;
  background:rgba(255,45,91,0.06); border:1px solid rgba(255,45,91,0.2); border-radius:2px;
  font-family:'JetBrains Mono',monospace; font-size:.7rem; color:var(--red); letter-spacing:.05em;
}
.form-error-banner.show { display:block; }

.char-counter { font-family:'JetBrains Mono',monospace; font-size:.57rem; color:var(--muted); text-align:right; margin-top:.25rem; letter-spacing:.06em; }

/* Submit button */
.form-submit {
  width:100%; padding:.9rem; background:transparent; border:1px solid var(--cyan); border-radius:2px;
  color:var(--cyan); font-family:'JetBrains Mono',monospace; font-weight:500;
  font-size:.78rem; letter-spacing:.12em; text-transform:uppercase;
  cursor:pointer; transition:all .3s; position:relative; overflow:hidden;
  display:flex; align-items:center; justify-content:center; gap:.6rem;
}
.form-submit::before { content:''; position:absolute; inset:0; background:var(--cyan); transform:translateX(-101%); transition:transform .3s; z-index:0; }
.form-submit span { position:relative; z-index:1; }
.form-submit:hover::before { transform:translateX(0); }
.form-submit:hover { color:var(--bg); }
.form-submit:disabled { opacity:.6; pointer-events:none; }

.spinner {
  display:none; width:14px; height:14px;
  border:2px solid transparent; border-top-color:currentColor;
  border-radius:50%; animation:spin .7s linear infinite;
  position:relative; z-index:1;
}
.form-submit.loading .spinner { display:block; }
.form-submit.loading .btn-label { opacity:0; }
@keyframes spin { to{transform:rotate(360deg);} }

.success-msg { display:none; text-align:center; padding:3rem; font-family:'JetBrains Mono',monospace; color:var(--cyan); }
.success-msg .ok { font-size:2rem; color:var(--green); margin-bottom:1rem; }
.success-msg .ok-title { color:var(--bright); font-size:1rem; margin-bottom:.6rem; }
.success-msg .ok-sub { color:var(--muted); font-size:.75rem; line-height:1.7; margin-bottom:2rem; }
.btn-reset {
  background:transparent; border:1px solid rgba(0,245,255,0.2); color:var(--muted);
  font-family:'JetBrains Mono',monospace; font-size:.7rem; letter-spacing:.1em;
  padding:.6rem 1.2rem; cursor:pointer; border-radius:2px; transition:all .3s;
}
.btn-reset:hover { border-color:var(--cyan); color:var(--cyan); }

/* ── FOOTER ── */
footer { border-top:1px solid rgba(0,245,255,0.06); padding:4rem 5vw 2rem; background:rgba(2,4,8,0.8); backdrop-filter:blur(10px); position:relative; z-index:1; }
footer::before { content:''; position:absolute; top:0; left:0; right:0; height:1px; background:linear-gradient(90deg,transparent,rgba(0,245,255,0.2),transparent); }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:3rem; margin-bottom:4rem; }
.footer-brand .logo { font-family:'Orbitron',sans-serif; font-weight:700; font-size:1.2rem; color:var(--bright); letter-spacing:.12em; margin-bottom:1rem; }
.footer-brand p { color:var(--muted); font-size:.83rem; line-height:1.7; max-width:280px; }
.footer-col h5 { font-family:'JetBrains Mono',monospace; font-size:.63rem; letter-spacing:.15em; text-transform:uppercase; color:var(--cyan); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.7rem; }
.footer-col ul li a { color:var(--muted); font-size:.83rem; transition:color .2s; }
.footer-col ul li a:hover { color:var(--cyan); }
.footer-bottom { border-top:1px solid rgba(0,245,255,0.06); padding-top:2rem; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-bottom p { color:var(--muted); font-size:.72rem; font-family:'JetBrains Mono',monospace; }
.social-links { display:flex; gap:.8rem; }
.social-link { width:32px; height:32px; border:1px solid rgba(0,245,255,0.1); display:grid; place-items:center; font-family:'JetBrains Mono',monospace; font-size:.72rem; color:var(--muted); transition:all .3s; }
.social-link:hover { border-color:var(--cyan); color:var(--cyan); box-shadow:0 0 14px rgba(0,245,255,0.25); }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(24px);} to{opacity:1;transform:translateY(0);} }
.reveal { opacity:0; transform:translateY(28px); transition:opacity .6s ease,transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }

/* ── RESPONSIVE ── */
@media(max-width:1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media(max-width:900px) {
  .approach-grid, .about-hero { grid-template-columns:1fr; }
  .hex-visual { display:none; }
  .values-grid { grid-template-columns:1fr; }
  .contact-wrap { grid-template-columns:1fr; gap:3rem; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:1/-1; }
  .nav-links, .nav-cta { display:none; }
  .hamburger { display:flex; }
  .stats-strip { grid-template-columns:repeat(2,1fr); }
  .stat { border-bottom:1px solid rgba(0,245,255,0.06); }
}
@media(max-width:600px) {
  .form-row { grid-template-columns:1fr; }
  .footer-top { grid-template-columns:1fr; }
  .brands-grid, .services-grid, .how-grid, .values-grid { grid-template-columns:1fr; }
  .contact-form { padding:2rem 1.5rem; }
  .cta-banner { padding:3rem 1.5rem; margin:0 0 5rem; }
  .section { padding:5rem 5vw; }
}

/* ── ANDROID / POCO MOBILE FIX ──────────────────────────────
   Prevents content from being pushed right due to fixed
   elements, wide letter-spacing, or blob overflow.
   Targets all common Android viewport widths.
─────────────────────────────────────────────────────────── */
@media(max-width:768px) {
  /* Reset base font size back to 16px on mobile — the 17px
     bump is desktop-only */
  html { font-size: 16px; }

  /* Hard clamp everything to viewport */
  html, body, .page, .section,
  nav, footer, .hero, .stats-strip,
  .brands-grid, .services-grid, .how-grid,
  .contact-wrap, .about-hero, .cta-banner {
    max-width: 100vw;
    overflow-x: hidden;
  }

  /* Fix hero terminal bar — letter-spacing can push width */
  .hero-terminal {
    max-width: calc(100vw - 4rem);
    flex-wrap: wrap;
    font-size: .62rem;
    letter-spacing: .03em;
  }

  /* Fix section padding — use px not vw on very small screens */
  .section, .brands-section { padding-left: 1.2rem; padding-right: 1.2rem; }
  .about-hero { padding-left: 1.2rem; padding-right: 1.2rem; }
  .contact-wrap { padding-left: 1.2rem; padding-right: 1.2rem; }
  .cta-banner { margin-left: 1.2rem; margin-right: 1.2rem; }
  footer { padding-left: 1.2rem; padding-right: 1.2rem; }
  nav { padding-left: 1.2rem; padding-right: 1.2rem; }

  /* Cursor elements — hide on touch devices, they cause layout thrash */
  #cursor, #cursor-trail { display: none; }

  /* Data streams overflow fix */
  .data-stream { display: none; }

  /* Hero title letter-spacing reduction */
  .hero-title { letter-spacing: -.01em; }

  /* Section label — prevent overflow from wide letter-spacing */
  .section-label { letter-spacing: .1em; }

  /* Brand cards full width */
  .brand-card, .cyber-card { width: 100%; }

  /* Stats — 2 columns always on mobile */
  .stats-strip { grid-template-columns: repeat(2,1fr) !important; }
  .stat { border-right: none; border-bottom: 1px solid rgba(0,245,255,0.06); }

  /* Form row always single column */
  .form-row { grid-template-columns: 1fr; }

  /* Footer columns stack */
  .footer-top { grid-template-columns: 1fr; gap: 2rem; }
  .footer-brand { grid-column: auto; }
}

@media(max-width:390px) {
  /* Extra small phones — even tighter */
  .section, .brands-section,
  .about-hero, .contact-wrap { padding-left: 1rem; padding-right: 1rem; }
  nav { padding-left: 1rem; padding-right: 1rem; }
  .hero-terminal { font-size: .55rem; }
  .section-title { font-size: 1.5rem; }
}
