:root {
  --primary: #2ab8d4;
  --primary-dark: #1a8fa8;
  --teal: #3ecfbd;
  --bg: #050d14;
  --bg2: #071520;
  --text: #e8f4f8;
  --muted: #7ba8ba;
  --card: rgba(42,184,212,0.05);
  --border: rgba(42,184,212,0.18);
  --glow: 0 0 40px rgba(42,184,212,0.25);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;cursor:none;}
#cursor{position:fixed;width:12px;height:12px;background:var(--primary);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,background .2s;}
#cursor-ring{position:fixed;width:36px;height:36px;border:1.5px solid var(--primary);border-radius:50%;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .15s ease,width .2s,height .2s,opacity .2s;opacity:.6;}
@media(pointer:coarse){#cursor,#cursor-ring{display:none;}body{cursor:auto;}}
#loader{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;transition:opacity .8s ease,visibility .8s;}
#loader.hide{opacity:0;visibility:hidden;pointer-events:none;}
.loader-logo{font-family:'Syne',sans-serif;font-size:2.5rem;font-weight:800;color:var(--primary);}
.loader-logo span{color:var(--teal);}
.loader-bar-wrap{width:220px;height:2px;background:rgba(255,255,255,0.1);border-radius:99px;overflow:hidden;}
.loader-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--primary),var(--teal));border-radius:99px;animation:loadprog 2s ease forwards;}
@keyframes loadprog{0%{width:0%}60%{width:70%}100%{width:100%}}
.loader-text{font-size:.8rem;color:var(--muted);letter-spacing:3px;text-transform:uppercase;animation:pulse 1.2s infinite;}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
#progress-bar{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--primary),var(--teal));width:0%;z-index:9000;transition:width .1s;box-shadow:0 0 10px var(--primary);}
#particles{position:fixed;inset:0;z-index:0;pointer-events:none;}
nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 5%;display:flex;align-items:center;justify-content:space-between;background:rgba(5,13,20,0.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);transition:background .3s;}
nav.scrolled{background:rgba(5,13,20,0.97);}
.logo{font-family:'Syne',sans-serif;font-size:1.5rem;font-weight:800;color:var(--text);text-decoration:none;letter-spacing:-.5px;}
.logo span{color:var(--primary);}
.nav-links{display:flex;gap:28px;list-style:none;align-items:center;}
.nav-links a{color:var(--muted);text-decoration:none;font-size:.85rem;font-weight:500;letter-spacing:.5px;transition:color .2s;position:relative;}
.nav-links a::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--primary);transition:width .3s;}
.nav-links a:hover,.nav-links a.active{color:var(--primary);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px;background:none;border:none;}
.hamburger span{display:block;width:24px;height:2px;background:var(--primary);border-radius:2px;transition:all .3s;}
.mobile-menu{display:none;position:fixed;top:65px;left:0;right:0;background:rgba(5,13,20,0.98);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);padding:20px 5%;flex-direction:column;gap:0;z-index:999;}
.mobile-menu.open{display:flex;}
.mobile-menu a{color:var(--muted);text-decoration:none;font-size:1rem;font-weight:500;padding:14px 0;border-bottom:1px solid rgba(42,184,212,0.08);}
.mobile-menu a:hover,.mobile-menu a.active{color:var(--primary);}
.mobile-menu .nav-cta-m{margin-top:16px;background:var(--primary);color:#fff !important;text-align:center;border-radius:8px;padding:14px !important;font-family:'Syne',sans-serif;font-weight:700;border-bottom:none !important;}
.float-btns{position:fixed;right:16px;bottom:80px;display:flex;flex-direction:column;gap:12px;z-index:800;}
.float-btn{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 4px 20px rgba(0,0,0,0.4);transition:transform .2s,box-shadow .2s;cursor:pointer;}
.float-btn:hover{transform:translateY(-3px) scale(1.08);}
.float-btn.whatsapp{background:#25d366;}
.float-btn.call{background:var(--primary);}
.float-btn svg{width:24px;height:24px;fill:#fff;}
#btt{position:fixed;bottom:22px;right:16px;width:44px;height:44px;background:var(--bg2);border:1px solid var(--border);color:var(--primary);border-radius:10px;font-size:1.1rem;cursor:pointer;z-index:900;opacity:0;transform:translateY(10px);transition:opacity .3s,transform .3s;font-weight:700;}
#btt.show{opacity:1;transform:translateY(0);}
#btt:hover{background:var(--primary);color:#fff;}
.marquee-wrap{background:var(--primary);padding:14px 0;overflow:hidden;white-space:nowrap;position:relative;z-index:1;}
.marquee-track{display:inline-flex;animation:marquee 20s linear infinite;}
.marquee-item{font-family:'Syne',sans-serif;font-size:.88rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:2px;padding:0 32px;}
.marquee-item::after{content:'★';margin-left:32px;opacity:.5;}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
section{padding:100px 5%;position:relative;z-index:1;}
.section-label{display:inline-block;font-size:.72rem;letter-spacing:3px;text-transform:uppercase;color:var(--primary);margin-bottom:12px;font-weight:600;}
.section-title{font-family:'Syne',sans-serif;font-size:clamp(2rem,4vw,3.2rem);font-weight:800;letter-spacing:-1.5px;line-height:1.15;margin-bottom:16px;}
.section-sub{color:var(--muted);font-size:1rem;line-height:1.75;max-width:540px;font-weight:300;}
.section-header{margin-bottom:64px;}
.hero{min-height:100vh;display:flex;align-items:center;padding:120px 5% 80px;position:relative;overflow:hidden;z-index:1;}
.hero-grid-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(42,184,212,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(42,184,212,0.04) 1px,transparent 1px);background-size:60px 60px;z-index:-1;}
.hero-glow{position:absolute;top:20%;left:50%;transform:translateX(-50%);width:700px;height:700px;background:radial-gradient(ellipse,rgba(42,184,212,0.1) 0%,transparent 70%);pointer-events:none;z-index:-1;}
.hero-content{max-width:720px;}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(42,184,212,0.08);border:1px solid var(--border);padding:7px 16px;border-radius:99px;font-size:.78rem;color:var(--primary);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:28px;animation:fadeUp .8s ease both;}
.hero-badge::before{content:'';width:6px;height:6px;background:var(--primary);border-radius:50%;animation:blink 1.5s infinite;}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}
h1{font-family:'Syne',sans-serif;font-size:clamp(2.4rem,5.5vw,5rem);font-weight:800;line-height:1.08;letter-spacing:-2px;margin-bottom:24px;animation:fadeUp .8s .15s ease both;}
h1 .line2{color:var(--primary);}
h1 .line3{-webkit-text-stroke:1px rgba(42,184,212,0.5);color:transparent;}
.hero-sub{font-size:1.05rem;color:var(--muted);line-height:1.75;max-width:500px;margin-bottom:40px;font-weight:300;animation:fadeUp .8s .3s ease both;}
.hero-btns{display:flex;gap:16px;flex-wrap:wrap;animation:fadeUp .8s .45s ease both;}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;padding:14px 32px;border-radius:8px;font-weight:700;text-decoration:none;font-size:.95rem;font-family:'Syne',sans-serif;transition:transform .2s,box-shadow .3s;display:inline-flex;align-items:center;gap:8px;border:none;cursor:pointer;}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 20px 50px rgba(42,184,212,0.35);}
.btn-outline{border:1.5px solid var(--border);color:var(--text);padding:14px 32px;border-radius:8px;font-weight:500;text-decoration:none;font-size:.95rem;transition:border-color .2s,background .2s;display:inline-flex;align-items:center;gap:8px;}
.btn-outline:hover{border-color:var(--primary);background:rgba(42,184,212,0.06);}
.hero-stats{display:flex;gap:48px;margin-top:64px;animation:fadeUp .8s .6s ease both;flex-wrap:wrap;}
.stat-item .stat-num{font-family:'Syne',sans-serif;font-size:2.2rem;font-weight:800;color:var(--primary);}
.stat-item .stat-label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px;}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
.page-hero{padding:140px 5% 70px;position:relative;z-index:1;text-align:center;overflow:hidden;}
.page-hero h1{font-family:'Syne',sans-serif;font-size:clamp(2rem,5vw,3.8rem);font-weight:800;letter-spacing:-2px;margin-bottom:16px;animation:fadeUp .8s ease both;}
.page-hero p{color:var(--muted);font-size:1rem;max-width:540px;margin:0 auto;line-height:1.75;font-weight:300;animation:fadeUp .8s .15s ease both;}
.breadcrumb{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:.82rem;margin-bottom:20px;animation:fadeUp .8s ease both;}
.breadcrumb a{color:var(--primary);text-decoration:none;}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;}
.form-group label{font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:1px;font-weight:500;}
.form-group input,.form-group textarea,.form-group select{background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.08);border-radius:8px;padding:12px 16px;color:var(--text);font-family:'DM Sans',sans-serif;font-size:.9rem;outline:none;transition:border-color .2s;width:100%;}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:rgba(42,184,212,0.4);box-shadow:0 0 0 3px rgba(42,184,212,0.06);}
.form-group textarea{resize:vertical;min-height:110px;}
.form-group select option{background:#071520;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:0;}
.btn-submit{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:8px;font-family:'Syne',sans-serif;font-size:.95rem;font-weight:800;cursor:pointer;transition:transform .2s,box-shadow .3s;letter-spacing:.5px;margin-top:8px;}
.btn-submit:hover{transform:translateY(-2px);box-shadow:0 20px 40px rgba(42,184,212,0.3);}
footer{background:var(--bg2);border-top:1px solid var(--border);padding:64px 5% 32px;position:relative;z-index:1;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;}
.footer-brand p{color:var(--muted);font-size:.85rem;line-height:1.7;max-width:280px;margin-bottom:20px;}
.footer-col h4{font-family:'Syne',sans-serif;font-size:.88rem;font-weight:700;margin-bottom:20px;letter-spacing:.5px;}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:12px;}
.footer-col ul a{color:var(--muted);text-decoration:none;font-size:.85rem;transition:color .2s;}
.footer-col ul a:hover{color:var(--primary);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:32px;border-top:1px solid rgba(255,255,255,0.05);flex-wrap:wrap;gap:16px;}
.footer-bottom p{color:var(--muted);font-size:.8rem;}
.footer-links a{color:var(--muted);text-decoration:none;font-size:.8rem;margin-left:20px;transition:color .2s;}
.footer-links a:hover{color:var(--primary);}
.social-links{display:flex;gap:10px;}
.social-links a{width:38px;height:38px;border:1px solid var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:all .2s;color:var(--muted);}
.social-links a:hover{border-color:var(--primary);color:var(--primary);background:rgba(42,184,212,0.08);}
.social-links a svg{width:17px;height:17px;fill:currentColor;}
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}
.reveal-left{opacity:0;transform:translateX(-40px);transition:opacity .7s ease,transform .7s ease;}
.reveal-left.visible{opacity:1;transform:translateX(0);}
.reveal-right{opacity:0;transform:translateX(40px);transition:opacity .7s ease,transform .7s ease;}
.reveal-right.visible{opacity:1;transform:translateX(0);}
@media(max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;}.form-row{grid-template-columns:1fr;}}
@media(max-width:640px){.nav-links{display:none;}.hamburger{display:flex;}section{padding:70px 5%;}.page-hero{padding:110px 5% 50px;}.hero-stats{gap:28px;}.footer-grid{grid-template-columns:1fr;}.footer-bottom{flex-direction:column;text-align:center;}h1{letter-spacing:-1px;}}

/* ── MOBILE OVERFLOW FIX ── */
html, body {
  overflow-x: hidden !important;
  max-width: 100vw;
}
* {
  max-width: 100%;
}
img, canvas, iframe, video {
  max-width: 100%;
}
.hero-glow {
  width: min(700px, 100vw) !important;
  overflow: hidden;
}
section {
  overflow: hidden;
}
.page-hero {
  overflow: hidden;
}
/* Fix marquee overflow */
.marquee-wrap {
  overflow: hidden !important;
  max-width: 100vw;
}
/* Fix process grid mobile */
@media(max-width:640px) {
  .process-grid { grid-template-columns: 1fr 1fr !important; }
  .hero-stats { gap: 20px !important; }
  .hero-btns { flex-direction: column !important; }
  .hero-btns a { width: 100%; justify-content: center; text-align: center; }
  .pricing-preview { grid-template-columns: 1fr !important; }
  .pp-card.featured { transform: none !important; }
  .port-preview, .port-grid { grid-template-columns: 1fr !important; }
  .port-card.wide, .port-card:first-child { grid-column: span 1 !important; }
  .testi-grid { grid-template-columns: 1fr !important; }
  .values-grid, .team-grid { grid-template-columns: 1fr !important; }
  .ot-grid { grid-template-columns: 1fr !important; }
  .about-hero-wrap { grid-template-columns: 1fr !important; padding: 110px 5% 60px !important; }
  .contact-layout { grid-template-columns: 1fr !important; }
  .service-block { grid-template-columns: 1fr !important; gap: 24px !important; }
  .service-block:nth-child(even) { direction: ltr !important; }
  .stats-row { grid-template-columns: 1fr 1fr !important; }
}
