/* ============================================================
   TORAIZON — SHARED STYLES
   ============================================================ */
:root {
  --black: #020408;
  --deep: #050c14;
  --panel: #080f1a;
  --panel-2: #0a131e;
  --border: rgba(0,200,255,0.12);
  --border-strong: rgba(0,200,255,0.3);
  --cyan: #00c8ff;
  --cyan2: #00ffcc;
  --red: #ff2244;
  --gold: #ffd060;
  --white: #e8f4ff;
  --muted: rgba(232,244,255,0.45);
  --muted-2: rgba(232,244,255,0.65);
  --glow: 0 0 40px rgba(0,200,255,0.25);
  --whatsapp: #25d366;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;overflow-x:hidden;-webkit-tap-highlight-color:transparent;}
body{background:var(--black);color:var(--white);font-family:'Syne',sans-serif;overflow-x:hidden;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}

/* CUSTOM CURSOR — desktop only */
@media (hover:hover) and (pointer:fine) {
  body{cursor:none;}
  #cursor{position:fixed;width:12px;height:12px;background:var(--cyan);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform 0.1s,background 0.2s;mix-blend-mode:screen;}
  #cursor-ring{position:fixed;width:36px;height:36px;border:1px solid rgba(0,200,255,0.5);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:all 0.15s ease;}
  body:has(a:hover) #cursor,body:has(button:hover) #cursor{background:var(--gold);transform:translate(-50%,-50%) scale(1.8);}
  body:has(a:hover) #cursor-ring,body:has(button:hover) #cursor-ring{transform:translate(-50%,-50%) scale(1.4);border-color:var(--gold);}
}
@media (hover:none) {
  #cursor,#cursor-ring{display:none!important;}
}

/* CANVAS */
#hero-canvas{position:fixed;top:0;left:0;width:100%;height:100%;z-index:0;pointer-events:none;}

/* NAV */
nav{position:fixed;top:0;left:0;width:100%;z-index:100;padding:20px 48px;display:flex;align-items:center;justify-content:space-between;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);background:rgba(2,4,8,0.6);transition:background 0.3s,padding 0.3s;}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:4px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-decoration:none;}
.nav-logo:hover{filter:brightness(1.2);}
.nav-links{display:flex;gap:32px;list-style:none;}
.nav-links a{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);text-decoration:none;transition:color 0.3s;font-family:'JetBrains Mono',monospace;position:relative;}
.nav-links a:hover,.nav-links a.active{color:var(--cyan);}
.nav-links a.active::after{content:'';position:absolute;bottom:-4px;left:0;width:100%;height:1px;background:var(--cyan);}
.nav-cta{background:transparent;border:1px solid var(--cyan);color:var(--cyan);padding:10px 24px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;transition:all 0.3s;text-decoration:none;display:inline-block;}
.nav-cta:hover{background:var(--cyan);color:var(--black);box-shadow:0 0 24px rgba(0,200,255,0.4);}

/* SECTIONS */
section{position:relative;z-index:1;}

/* COMMON BUTTONS */
.btn-primary{background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:var(--black);padding:14px 36px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;border:none;font-weight:700;transition:transform 0.3s,box-shadow 0.3s;text-decoration:none;display:inline-block;}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 8px 40px rgba(0,200,255,0.4);}
.btn-outline{background:transparent;border:1px solid rgba(0,200,255,0.4);color:var(--cyan);padding:14px 36px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:2px;text-transform:uppercase;transition:all 0.3s;text-decoration:none;display:inline-block;}
.btn-outline:hover{border-color:var(--cyan);background:rgba(0,200,255,0.08);}

/* SECTION COMMON */
.section-header{text-align:center;margin-bottom:80px;}
.section-tag{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:4px;color:var(--cyan);text-transform:uppercase;display:inline-block;padding:6px 16px;border:1px solid rgba(0,200,255,0.3);margin-bottom:20px;}
.section-title{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,6vw,80px);line-height:1;letter-spacing:1px;}
.section-title span{color:var(--cyan);}
.section-sub{max-width:560px;margin:20px auto 0;color:var(--muted);font-size:14px;line-height:1.8;}

/* SCAN LINE */
.scanline{pointer-events:none;position:fixed;top:0;left:0;width:100%;height:100%;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,200,255,0.015) 2px,rgba(0,200,255,0.015) 4px);z-index:50;}
@media(max-width:768px){.scanline{display:none;}}

/* SCROLL REVEAL */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.8s,transform 0.8s;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* HAMBURGER MENU */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;z-index:200;background:none;border:none;-webkit-tap-highlight-color:transparent;min-width:44px;min-height:44px;align-items:center;justify-content:center;}
.hamburger span{display:block;width:24px;height:1.5px;background:var(--cyan);transition:all 0.3s;}
.hamburger.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0);}
.hamburger.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

/* MOBILE DRAWER */
.mobile-nav{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(2,4,8,0.98);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);z-index:150;flex-direction:column;align-items:center;justify-content:center;gap:8px;opacity:0;pointer-events:none;transition:opacity 0.3s;padding:24px;overflow-y:auto;}
.mobile-nav.open{opacity:1;pointer-events:all;}
.mobile-nav-inner{width:100%;max-width:320px;display:flex;flex-direction:column;gap:8px;}
.mobile-nav a{font-family:'JetBrains Mono',monospace;font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--muted-2);text-decoration:none;padding:16px 24px;border:1px solid transparent;transition:all 0.25s;text-align:center;display:block;border-radius:2px;}
.mobile-nav a:hover,.mobile-nav a:active,.mobile-nav a.active{color:var(--cyan);border-color:rgba(0,200,255,0.3);background:rgba(0,200,255,0.04);}
.mobile-nav .mobile-cta{margin-top:12px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));color:var(--black)!important;font-weight:700;border-color:transparent!important;}
.mobile-nav .mobile-wa{background:var(--whatsapp)!important;color:#fff!important;font-weight:700;border-color:transparent!important;}

/* WHATSAPP FLOATING BUTTON */
.wa-float{position:fixed;bottom:24px;right:24px;width:60px;height:60px;border-radius:50%;background:var(--whatsapp);display:flex;align-items:center;justify-content:center;z-index:200;box-shadow:0 8px 32px rgba(37,211,102,0.45),0 0 0 0 rgba(37,211,102,0.5);text-decoration:none;transition:transform 0.3s,box-shadow 0.3s;animation:wa-pulse 2.4s infinite;}
.wa-float:hover{transform:scale(1.1) translateY(-2px);box-shadow:0 12px 40px rgba(37,211,102,0.6);}
.wa-float svg{width:32px;height:32px;color:#fff;}
.wa-float::before{content:attr(data-tooltip);position:absolute;right:75px;top:50%;transform:translateY(-50%);background:var(--panel);color:var(--white);padding:10px 16px;font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:1px;text-transform:uppercase;white-space:nowrap;border:1px solid var(--border);opacity:0;pointer-events:none;transition:opacity 0.3s;}
.wa-float:hover::before{opacity:1;}
@keyframes wa-pulse{0%{box-shadow:0 8px 32px rgba(37,211,102,0.45),0 0 0 0 rgba(37,211,102,0.5);}70%{box-shadow:0 8px 32px rgba(37,211,102,0.45),0 0 0 16px rgba(37,211,102,0);}100%{box-shadow:0 8px 32px rgba(37,211,102,0.45),0 0 0 0 rgba(37,211,102,0);}}

/* FOOTER */
footer{background:var(--black);border-top:1px solid var(--border);padding:64px 48px 32px;}
.footer-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-bottom:48px;border-bottom:1px solid var(--border);}
.footer-brand .footer-logo{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:4px;background:linear-gradient(135deg,var(--cyan),var(--cyan2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px;}
.footer-brand p{font-size:13px;line-height:1.8;color:var(--muted);max-width:340px;}
.footer-col h5{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:3px;color:var(--cyan);text-transform:uppercase;margin-bottom:16px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-col a{font-size:13px;color:var(--muted);text-decoration:none;transition:color 0.25s;}
.footer-col a:hover{color:var(--cyan);}
.footer-bottom{max-width:1400px;margin:24px auto 0;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:16px;}
.footer-copy{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:2px;}
.footer-locations{font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--muted);letter-spacing:2px;}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}
@keyframes marquee{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.5;transform:scale(0.8);}}
@keyframes scrollPulse{0%{opacity:1;transform:scaleY(1);}100%{opacity:0;transform:scaleY(0.3);}}
@keyframes rotate{from{transform:rotate(0deg);}to{transform:rotate(360deg);}}
@keyframes glitch{0%,100%{clip-path:inset(0 0 98% 0);}20%{clip-path:inset(15% 0 65% 0);}40%{clip-path:inset(80% 0 5% 0);}60%{clip-path:inset(40% 0 40% 0);}80%{clip-path:inset(70% 0 15% 0);}}
@keyframes shimmer{0%{background-position:-200% 0;}100%{background-position:200% 0;}}

/* GLITCH TEXT */
.glitch{position:relative;}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;top:0;left:0;background:inherit;-webkit-background-clip:text;background-clip:text;}
.glitch::before{color:var(--red);animation:glitch 4s infinite;opacity:0.6;left:2px;}
.glitch::after{color:var(--cyan);animation:glitch 4s 0.1s infinite;opacity:0.6;left:-2px;}

/* SERVICE PAGE — HERO */
.svc-hero{min-height:90vh;display:flex;align-items:center;padding:120px 48px 80px;position:relative;overflow:hidden;}
.svc-hero-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:center;width:100%;}
.svc-hero-text{position:relative;z-index:2;}
.svc-breadcrumb{display:flex;align-items:center;gap:10px;margin-bottom:24px;font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);}
.svc-breadcrumb a{color:var(--cyan);text-decoration:none;transition:color 0.3s;}
.svc-breadcrumb a:hover{color:var(--cyan2);}
.svc-breadcrumb span{color:var(--muted);}
.svc-tag{font-family:'JetBrains Mono',monospace;font-size:11px;letter-spacing:3px;color:var(--cyan);text-transform:uppercase;margin-bottom:24px;display:inline-block;padding:6px 14px;border:1px solid rgba(0,200,255,0.3);}
.svc-hero h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(56px,8vw,120px);line-height:0.92;letter-spacing:1px;margin-bottom:24px;}
.svc-hero h1 em{color:var(--cyan);font-style:normal;}
.svc-hero h1 .stroke{-webkit-text-stroke:1px rgba(0,200,255,0.5);color:transparent;display:block;font-size:0.6em;}
.svc-hero p.lead{font-size:16px;line-height:1.8;color:var(--muted-2);max-width:560px;margin-bottom:36px;}
.svc-hero-cta{display:flex;gap:16px;flex-wrap:wrap;}
.svc-hero-visual{position:relative;height:480px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(0,200,255,0.04),rgba(0,255,204,0.02));overflow:hidden;}
.svc-hero-visual canvas{width:100%;height:100%;}
.svc-hero-stats{position:absolute;bottom:24px;left:24px;right:24px;display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);}
.svc-hero-stat{background:rgba(2,4,8,0.85);backdrop-filter:blur(8px);padding:14px 16px;text-align:center;}
.svc-hero-stat-num{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--cyan);line-height:1;}
.svc-hero-stat-lbl{font-family:'JetBrains Mono',monospace;font-size:8px;letter-spacing:2px;color:var(--muted);text-transform:uppercase;margin-top:4px;}

/* SERVICE PAGE — SECTIONS */
.svc-section{padding:120px 48px;}
.svc-section.alt{background:var(--deep);}
.svc-inner{max-width:1400px;margin:0 auto;}
.svc-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2px;margin-top:60px;}
.svc-feature{background:var(--panel);border:1px solid var(--border);padding:40px 32px;transition:all 0.4s;position:relative;overflow:hidden;}
.svc-feature::before{content:'';position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,transparent,var(--cyan),transparent);transform:scaleX(0);transition:transform 0.4s;}
.svc-feature:hover::before{transform:scaleX(1);}
.svc-feature:hover{background:rgba(0,200,255,0.04);border-color:var(--border-strong);transform:translateY(-4px);}
.svc-feature-icon{width:48px;height:48px;margin-bottom:24px;color:var(--cyan);}
.svc-feature h3{font-size:18px;font-weight:700;margin-bottom:14px;letter-spacing:0.5px;}
.svc-feature p{font-size:13px;line-height:1.8;color:var(--muted);}
.svc-feature ul{margin-top:18px;list-style:none;display:flex;flex-direction:column;gap:8px;}
.svc-feature ul li{font-family:'JetBrains Mono',monospace;font-size:11px;color:var(--muted-2);padding-left:20px;position:relative;line-height:1.6;}
.svc-feature ul li::before{content:'›';position:absolute;left:0;color:var(--cyan);font-weight:700;}

/* PROCESS / FLOW */
.svc-flow{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:0;margin-top:40px;}
.flow-step{padding:40px 32px;border:1px solid var(--border);position:relative;transition:all 0.4s;background:var(--panel);}
.flow-step:not(:last-child)::after{content:'→';position:absolute;right:-12px;top:50%;transform:translateY(-50%);color:var(--cyan);font-size:18px;z-index:2;background:var(--black);padding:0 4px;}
.flow-step:hover{background:rgba(0,200,255,0.04);border-color:var(--border-strong);}
.flow-num{font-family:'Bebas Neue',sans-serif;font-size:48px;color:rgba(0,200,255,0.18);line-height:1;margin-bottom:12px;}
.flow-name{font-size:14px;font-weight:700;letter-spacing:1px;margin-bottom:10px;}
.flow-desc{font-size:12px;line-height:1.7;color:var(--muted);}

/* TECH STACK / CHIPS */
.chip-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;}
.chip{font-family:'JetBrains Mono',monospace;font-size:10px;letter-spacing:1px;padding:6px 14px;border:1px solid var(--border);color:var(--muted-2);text-transform:uppercase;transition:all 0.3s;}
.chip:hover{border-color:var(--cyan);color:var(--cyan);background:rgba(0,200,255,0.04);}

/* SPLIT CONTENT (image + text) */
.svc-split{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;margin-top:60px;}
.svc-split.reverse{grid-template-columns:1fr 1fr;}
.svc-split.reverse .svc-split-text{order:2;}
.svc-split-text h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(40px,5vw,68px);line-height:0.95;margin-bottom:24px;}
.svc-split-text h2 em{color:var(--cyan);font-style:normal;}
.svc-split-text p{color:var(--muted-2);font-size:14px;line-height:1.9;margin-bottom:18px;}
.svc-split-visual{height:440px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(0,200,255,0.04),rgba(0,255,204,0.02));position:relative;overflow:hidden;}
.svc-split-visual canvas{width:100%;height:100%;}

/* CTA SECTION */
.svc-cta{padding:120px 48px;background:linear-gradient(135deg,rgba(0,200,255,0.04),rgba(0,255,204,0.02));border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;position:relative;overflow:hidden;}
.svc-cta-inner{max-width:880px;margin:0 auto;position:relative;z-index:2;}
.svc-cta h2{font-family:'Bebas Neue',sans-serif;font-size:clamp(48px,7vw,96px);line-height:0.95;margin-bottom:24px;}
.svc-cta h2 em{color:var(--cyan);font-style:normal;}
.svc-cta p{color:var(--muted-2);font-size:16px;line-height:1.8;max-width:640px;margin:0 auto 40px;}
.svc-cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

/* MOBILE OPTIMIZATIONS — TABLET 900px */
@media(max-width:900px){
  body{cursor:auto;}
  *{cursor:auto!important;}

  nav{padding:14px 20px;}
  .nav-links,.nav-cta{display:none;}
  .hamburger{display:flex;}
  .mobile-nav{display:flex;}

  .svc-hero{padding:100px 20px 60px;min-height:auto;}
  .svc-hero-grid{grid-template-columns:1fr;gap:40px;}
  .svc-hero-visual{height:340px;order:2;}
  .svc-hero h1{font-size:clamp(48px,11vw,80px);}

  .svc-section{padding:80px 20px;}
  .svc-feature-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
  .svc-flow{grid-template-columns:1fr;}
  .flow-step:not(:last-child)::after{display:none;}
  .svc-split,.svc-split.reverse{grid-template-columns:1fr;gap:40px;}
  .svc-split.reverse .svc-split-text{order:1;}
  .svc-split-visual{height:320px;}

  .svc-cta{padding:80px 20px;}

  footer{padding:48px 20px 24px;}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;}
  .footer-brand{grid-column:1/-1;}
  .footer-bottom{flex-direction:column;text-align:center;}

  .section-header{margin-bottom:52px;}

  .wa-float{width:54px;height:54px;bottom:20px;right:20px;}
  .wa-float svg{width:28px;height:28px;}
  .wa-float::before{display:none;}
}

/* MOBILE — 600px */
@media(max-width:600px){
  nav{padding:12px 16px;}
  .nav-logo{font-size:22px;letter-spacing:3px;}

  .svc-hero{padding:90px 16px 48px;}
  .svc-hero h1{font-size:clamp(40px,12vw,64px);}
  .svc-hero p.lead{font-size:14px;}
  .svc-hero-cta{flex-direction:column;width:100%;}
  .svc-hero-cta .btn-primary,.svc-hero-cta .btn-outline{width:100%;text-align:center;}
  .svc-hero-visual{height:280px;}
  .svc-hero-stat-num{font-size:18px;}
  .svc-hero-stat-lbl{font-size:7px;}

  .svc-section{padding:60px 16px;}
  .svc-feature-grid{grid-template-columns:1fr;}
  .svc-feature{padding:32px 24px;}

  .section-title{font-size:clamp(36px,9vw,56px);}

  .svc-split-text h2{font-size:clamp(32px,8vw,48px);}
  .svc-split-visual{height:240px;}

  .svc-cta{padding:60px 16px;}
  .svc-cta h2{font-size:clamp(40px,10vw,68px);}
  .svc-cta p{font-size:14px;}
  .svc-cta-btns{flex-direction:column;width:100%;}
  .svc-cta-btns a{width:100%;text-align:center;}

  footer{padding:40px 16px 20px;}
  .footer-grid{grid-template-columns:1fr;gap:32px;padding-bottom:32px;}
  .footer-bottom{margin-top:20px;}

  .section-tag{font-size:9px;letter-spacing:2px;padding:5px 12px;}
}

/* SMALL PHONES — 380px */
@media(max-width:380px){
  .svc-hero h1{font-size:clamp(34px,13vw,52px);}
  .svc-hero p.lead{font-size:13px;}
  .svc-hero-stats{grid-template-columns:1fr 1fr 1fr;gap:1px;}
  .svc-hero-stat{padding:10px 8px;}
  .svc-hero-stat-num{font-size:16px;}
}

/* TOUCH OPTIMIZATIONS */
@media(hover:none) and (pointer:coarse){
  .btn-primary,.btn-outline,.nav-cta,.svc-feature,.flow-step,.chip,.fw,.iot-cat,.tcard,.cf,.vtype,.sd-item,.infra-card,.service-card,.soc-product,a{min-height:auto;-webkit-tap-highlight-color:rgba(0,200,255,0.15);}
  .btn-primary,.btn-outline,.nav-cta{padding:16px 32px;}
  .nav-links a,.mobile-nav a{padding:14px 20px;}
}

/* PREFERS REDUCED MOTION */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-iteration-count:1!important;transition-duration:0.01ms!important;scroll-behavior:auto!important;}
  .scanline,.glitch::before,.glitch::after,.wa-float{animation:none!important;}
}
