/* ============================================================
   TECROSOFT – MAIN STYLESHEET
   ============================================================ */
:root{
  --bg:#060c18;--bg2:#0a1220;--bg3:#0f1a2e;--bg4:#142040;
  --accent:#00d4ff;--accent2:#0099cc;--gold:#ffb700;--green:#00ffaa;
  --red:#ff4455;--text:#e4edf8;--muted:#7a90b0;
  --border:rgba(0,212,255,0.15);--card:rgba(255,255,255,.03);
  --glow:0 0 40px rgba(0,212,255,.2);--shadow:0 20px 60px rgba(0,0,0,.5);
  --font-head:'Orbitron',sans-serif;
  --font-body:'Exo 2',sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
/* First visit: body starts hidden so loader looks clean */
body{font-family:var(--font-body);background:var(--bg);color:var(--text);overflow-x:hidden;
  opacity:0;transition:opacity .3s ease}
/* Returning visitor: body is instantly visible (class set before CSS loads) */
html.tecro-loaded body{opacity:1!important;transition:none!important;animation:none!important}
/* GUARANTEED fallback: body always becomes visible at 2s even if ALL JS fails */
@keyframes bodyReveal{0%{opacity:0}100%{opacity:1}}
body{animation:bodyReveal .4s ease 2s both}

/* LOADER auto-hide: disappears at 2.5s if JS never runs */
@keyframes loaderAutoHide{0%,90%{opacity:1;visibility:visible;pointer-events:auto}100%{opacity:0;visibility:hidden;pointer-events:none}}
.page-loader{animation:loaderAutoHide 3s ease forwards}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--accent2);border-radius:10px}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}

/* ── CANVAS ── */
#netCanvas{position:fixed;inset:0;z-index:1;pointer-events:none}
section,nav,footer,.page-loader,.social-sidebar,.top-bar,
.chat-btn,.chatbot-modal,.scroll-top-btn,.auth-page,.page-wrap,.cta-banner,.ticker,
.admin-layout{position:relative;z-index:2}

/* ── PAGE LOADER ── */
.page-loader{position:fixed;inset:0;background:var(--bg);display:flex;flex-direction:column;
  align-items:center;justify-content:center;z-index:99999;transition:opacity .5s,visibility .5s}
.page-loader.fade-out{opacity:0;visibility:hidden;animation:none!important}
.loader-logo{font-family:var(--font-head);font-size:3rem;font-weight:900;color:var(--accent);
  text-shadow:0 0 30px rgba(0,212,255,.6);letter-spacing:4px;margin-bottom:8px}
.loader-sub{color:var(--muted);font-size:.78rem;letter-spacing:3px;margin-bottom:28px;text-transform:uppercase}
.loader-bar{width:200px;height:3px;background:rgba(0,212,255,.12);border-radius:3px;overflow:hidden}
.loader-fill{height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--green));
  border-radius:3px;animation:loadFill 1.6s ease forwards}
@keyframes loadFill{to{width:100%}}
.loader-text{color:var(--muted);font-size:.72rem;letter-spacing:2px;margin-top:14px;animation:blinkAnim 1s infinite}
@keyframes blinkAnim{0%,100%{opacity:1}50%{opacity:.3}}



/* ── SOCIAL SIDEBAR ── */
.social-sidebar{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:9980;
  display:flex;flex-direction:column;background:rgba(6,12,24,.88);backdrop-filter:blur(14px);
  border-right:1px solid var(--border);border-radius:0 10px 10px 0;padding:4px 0;overflow:hidden}
.soc-btn{width:38px;height:36px;display:flex;align-items:center;justify-content:center;
  text-decoration:none;transition:.22s;position:relative}
.soc-btn::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;
  background:transparent;transition:.2s}
.soc-btn:hover{background:rgba(255,255,255,.06);transform:translateX(2px)}
.soc-btn:hover::before{background:var(--accent)}
.soc-btn svg{width:15px;height:15px;fill:var(--muted);transition:.2s}
.soc-btn:hover svg{fill:#dde}
@media(max-width:1024px){.social-sidebar{display:none}}

/* ── TOP BAR ── */
.top-bar{position:fixed;top:0;left:0;right:0;z-index:10000;height:34px;
  background:rgba(0,212,255,.05);border-bottom:1px solid rgba(0,212,255,.1);
  display:flex;align-items:center;justify-content:space-between;padding:0 5%;
  font-size:.7rem;color:var(--muted);letter-spacing:.3px;transition:transform .3s ease}
.top-bar-left{display:flex;align-items:center;gap:16px}
.top-bar-item{display:flex;align-items:center;gap:4px}
.top-bar-right{display:flex;align-items:center;gap:12px}
.top-bar-right a{color:var(--muted);font-size:.68rem;transition:.2s;letter-spacing:.5px}
.top-bar-right a:hover{color:var(--accent)}
.top-bar-sep{width:1px;height:12px;background:var(--border)}
.live-pill{background:rgba(255,68,85,.1);border:1px solid rgba(255,68,85,.28);color:#ff8899;
  padding:2px 8px;border-radius:10px;display:flex;align-items:center;gap:4px;font-size:.65rem}
.live-pill-dot{width:5px;height:5px;border-radius:50%;background:var(--red);animation:blinkAnim 1s infinite}
@media(max-width:900px){.top-bar .top-bar-left{display:none}}

/* ── NAV ── */
nav{position:fixed;top:34px;left:0;right:0;z-index:9999;display:flex;align-items:center;
  justify-content:space-between;padding:0 5%;height:62px;
  background:rgba(6,12,24,.96);backdrop-filter:blur(20px);border-bottom:1px solid var(--border);
  transition:all .3s}
nav.scrolled{top:0;box-shadow:0 4px 40px rgba(0,0,0,.5);background:rgba(6,12,24,.99)}
.nav-logo{font-family:var(--font-head);font-weight:900;font-size:1.2rem;color:var(--accent);
  cursor:pointer;letter-spacing:2px;flex-shrink:0;text-shadow:0 0 15px rgba(0,212,255,.3);text-decoration:none}
.nav-logo span{color:#fff}
.nav-center{display:flex;align-items:center;gap:2px;list-style:none}
.nav-center>li{position:relative}
.nav-center>li>a{display:flex;align-items:center;gap:4px;color:var(--muted);text-decoration:none;
  font-size:.78rem;font-weight:600;letter-spacing:.4px;padding:8px 13px;border-radius:8px;
  transition:.2s;white-space:nowrap}
.nav-center>li>a:hover,.nav-active>a{color:#fff!important;background:rgba(255,255,255,.05)}
.nav-center>li.nav-active>a{color:var(--accent)!important;background:rgba(0,212,255,.07)!important}
.arrow{font-size:.55rem;transition:transform .2s;opacity:.5}
.nav-center>li:hover .arrow{transform:rotate(180deg)}
.has-drop:hover>.nav-drop,.has-drop:hover>.nav-mega{opacity:1!important;visibility:visible!important;transform:translateX(-50%) translateY(0)!important}
.nav-drop{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(-8px);
  background:rgba(6,12,24,.98);backdrop-filter:blur(20px);border:1px solid var(--border);
  border-radius:14px;padding:8px;min-width:220px;opacity:0;visibility:hidden;
  transition:.25s cubic-bezier(.4,0,.2,1);z-index:10000;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.nav-drop li{list-style:none}
.nav-drop a{display:flex;align-items:flex-start;gap:9px;padding:9px 10px;border-radius:8px;
  font-size:.78rem;color:var(--muted);text-decoration:none;transition:.18s}
.nav-drop a:hover{background:rgba(0,212,255,.07);color:#fff}
.nav-drop a:hover .di-lbl{color:var(--accent)}
.di{font-size:.95rem;width:22px;text-align:center;flex-shrink:0;margin-top:1px}
.di-lbl{font-weight:600;font-size:.78rem;color:var(--text);line-height:1.3}
.di-sub{font-size:.67rem;color:var(--muted);margin-top:1px}
.nav-drop-section{padding:5px 8px 3px;font-size:.62rem;color:rgba(0,212,255,.45);
  text-transform:uppercase;letter-spacing:2px;font-weight:700;margin-top:4px}
.nav-drop-sep{height:1px;background:var(--border);margin:6px 4px}
.nav-mega{position:absolute;top:calc(100% + 10px);left:50%;transform:translateX(-50%) translateY(-8px);
  background:rgba(6,12,24,.98);backdrop-filter:blur(20px);border:1px solid var(--border);
  border-radius:16px;padding:16px;min-width:460px;opacity:0;visibility:hidden;
  transition:.25s cubic-bezier(.4,0,.2,1);z-index:10000;box-shadow:0 20px 50px rgba(0,0,0,.5)}
.mega-cols{display:grid;grid-template-columns:1fr 1fr;gap:6px}
.mega-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:10px;
  cursor:pointer;transition:.18s;text-decoration:none}
.mega-item:hover{background:rgba(0,212,255,.06)}
.mega-icon{width:36px;height:36px;border-radius:9px;background:rgba(0,212,255,.08);
  border:1px solid rgba(0,212,255,.15);display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0}
.mega-lbl{font-size:.78rem;font-weight:700;color:var(--text);margin-bottom:2px}
.mega-sub{font-size:.67rem;color:var(--muted)}
.mega-item:hover .mega-lbl{color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.nav-cart-btn{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);color:var(--text);padding:8px 14px;border-radius:22px;
  cursor:pointer;font-size:.78rem;font-weight:600;transition:.2s;white-space:nowrap;font-family:var(--font-body)}
.nav-cart-btn:hover{border-color:var(--accent);color:var(--accent)}
.cart-badge{background:var(--accent);color:#000;font-size:.58rem;font-weight:800;
  width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.nav-login-btn{background:transparent;border:1px solid var(--border);color:var(--text);
  padding:8px 16px;border-radius:22px;font-size:.78rem;font-weight:600;cursor:pointer;
  transition:.2s;font-family:var(--font-body);white-space:nowrap;text-decoration:none;display:inline-flex}
.nav-login-btn:hover{border-color:var(--accent);color:var(--accent)}
.nav-cta-btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#000;
  padding:8px 18px;border-radius:22px;font-weight:700;font-size:.78rem;border:none;cursor:pointer;
  transition:.2s;white-space:nowrap;font-family:var(--font-body);letter-spacing:.3px;text-decoration:none;display:inline-flex}
.nav-cta-btn:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,212,255,.4)}
.nav-user{align-items:center;gap:8px}
.nav-user-info{text-align:right}
.nav-user-name{color:var(--accent);font-size:.78rem;font-weight:700;line-height:1.3}
.nav-user-role{color:var(--gold);font-size:.65rem}
.nav-admin-btn{background:rgba(0,212,255,.08);border:1px solid rgba(0,212,255,.18);color:var(--accent);
  padding:6px 12px;border-radius:18px;font-size:.72rem;font-weight:700;cursor:pointer;transition:.2s;
  font-family:var(--font-body);text-decoration:none;display:inline-flex}
.nav-admin-btn:hover{background:rgba(0,212,255,.15)}
.nav-logout-btn{background:rgba(255,68,85,.06);border:1px solid rgba(255,68,85,.18);color:var(--red);
  padding:6px 12px;border-radius:18px;font-size:.72rem;font-weight:700;cursor:pointer;transition:.2s;
  font-family:var(--font-body);text-decoration:none;display:inline-flex}
.nav-logout-btn:hover{background:rgba(255,68,85,.12)}
.notif-badge{background:var(--red);color:#fff;font-size:9px;font-weight:800;
  width:15px;height:15px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;background:none;border:none}
.hamburger span{width:22px;height:2px;background:var(--text);border-radius:2px;transition:.3s;display:block}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.mobile-nav{position:fixed;inset:0;background:rgba(4,8,18,.98);z-index:9000;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  transform:translateY(-100%);transition:.4s cubic-bezier(.4,0,.2,1);
  overflow-y:auto;padding:1rem 0}
.mobile-nav.open{transform:translateY(0)}
.mobile-nav a{font-family:var(--font-head);font-size:1rem;font-weight:700;
  color:rgba(255,255,255,.7);text-decoration:none;transition:.2s;
  padding:12px 30px;border-radius:10px;width:80%;text-align:center;
  min-height:48px;display:flex;align-items:center;justify-content:center}
.mobile-nav a:hover,.mobile-nav a:active{color:var(--accent);background:rgba(0,212,255,.08)}
.mobile-nav-cart{display:flex;gap:12px;margin-top:1rem;flex-wrap:wrap;justify-content:center;padding:0 1rem}

/* ── SECTIONS ── */
section{padding:5.5rem 5%;z-index:2}
.sec-label{font-size:.7rem;color:var(--accent);letter-spacing:3px;text-transform:uppercase;
  font-weight:600;margin-bottom:.8rem;display:flex;align-items:center;gap:8px}
.sec-label::before{content:'';width:20px;height:2px;background:var(--accent)}
.sec-title{font-family:var(--font-head);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:800;
  margin-bottom:.8rem;line-height:1.2;background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.sec-sub{color:var(--muted);font-size:.95rem;max-width:560px;line-height:1.7}
.sec-head{margin-bottom:3rem}
.sec-head.center{text-align:center}
.sec-head.center .sec-sub{margin:0 auto}

/* ── HERO ── */
#home{min-height:100vh;display:flex;align-items:center;justify-content:space-between;
  padding:130px 5% 70px 6%;gap:3rem}
.hero-content{flex:1;max-width:620px}
.hero-tag{font-size:.72rem;letter-spacing:4px;color:var(--accent);text-transform:uppercase;
  font-weight:600;margin-bottom:18px;display:flex;align-items:center;gap:8px}
.hero-tag::before{content:'';width:28px;height:2px;background:var(--accent)}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:rgba(0,212,255,.07);
  border:1px solid rgba(0,212,255,.22);padding:.3rem .9rem;border-radius:25px;font-size:.72rem;
  color:var(--accent);margin-bottom:18px;font-weight:500;letter-spacing:.5px}
.live-dot{width:6px;height:6px;border-radius:50%;background:var(--red);animation:blinkAnim 1s infinite}
h1{font-family:var(--font-head);font-size:clamp(2rem,5vw,3.8rem);font-weight:900;
  line-height:1.1;margin-bottom:18px;letter-spacing:-1px}
.gr{background:linear-gradient(135deg,var(--accent),var(--green));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.gr2{background:linear-gradient(135deg,var(--gold),#ff8c00);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.hero-p{font-size:1rem;color:var(--muted);max-width:500px;margin-bottom:32px;line-height:1.75}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#000;
  padding:.8rem 2rem;border-radius:28px;font-weight:700;font-size:.88rem;text-decoration:none;
  transition:.2s;box-shadow:0 0 28px rgba(0,212,255,.32);display:inline-flex;align-items:center;gap:6px;border:none;cursor:pointer}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 40px rgba(0,212,255,.5)}
.btn-secondary{border:1px solid var(--border);color:var(--text);padding:.8rem 2rem;border-radius:28px;
  font-weight:600;font-size:.88rem;text-decoration:none;transition:.2s;display:inline-flex;align-items:center;gap:6px;background:transparent;cursor:pointer}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}
.hero-stats{display:flex;gap:2.5rem;margin-top:2.8rem;flex-wrap:wrap}
.stat-item .snum{font-family:var(--font-head);font-size:1.8rem;font-weight:900;color:#fff}
.stat-item .snum span{color:var(--accent)}
.stat-item .slbl{font-size:.68rem;color:var(--muted);letter-spacing:1px;text-transform:uppercase;margin-top:2px}

/* ── SUPER GLOBE SCENE ── */
.hero-visual{flex:1;display:flex;align-items:center;justify-content:center;position:relative;min-width:460px}
.globe-scene{position:relative;width:460px;height:460px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pulse-ring{position:absolute;border-radius:50%;border:1px solid rgba(0,212,255,.16);animation:pulseRingAnim 3.5s ease-out infinite}
.pr1{width:340px;height:340px;animation-delay:0s}
.pr2{width:385px;height:385px;animation-delay:1.1s;border-color:rgba(0,212,255,.09)}
.pr3{width:435px;height:435px;animation-delay:2.2s;border-color:rgba(0,212,255,.05)}
@keyframes pulseRingAnim{0%{transform:scale(.9);opacity:.8}100%{transform:scale(1.07);opacity:0}}
.orbit-track{position:absolute;border-radius:50%;border:1px dashed rgba(0,212,255,.16);top:50%;left:50%}
.ot1{width:370px;height:120px;margin:-60px 0 0 -185px;animation:orbitTilt1 18s linear infinite;border-color:rgba(0,212,255,.2)}
.ot2{width:320px;height:130px;margin:-65px 0 0 -160px;animation:orbitTilt2 14s linear infinite;border-color:rgba(255,183,0,.2)}
.ot3{width:280px;height:280px;margin:-140px 0 0 -140px;animation:orbitTilt3 22s linear infinite;border-color:rgba(0,255,170,.1)}
@keyframes orbitTilt1{from{transform:rotate3d(1,.3,0,70deg) rotate(0deg)}to{transform:rotate3d(1,.3,0,70deg) rotate(360deg)}}
@keyframes orbitTilt2{from{transform:rotate3d(.5,1,.2,55deg) rotate(0deg)}to{transform:rotate3d(.5,1,.2,55deg) rotate(-360deg)}}
@keyframes orbitTilt3{from{transform:rotate3d(.2,.8,.4,45deg) rotate(0deg)}to{transform:rotate3d(.2,.8,.4,45deg) rotate(360deg)}}
.sat{position:absolute;border-radius:50%;box-shadow:0 0 12px currentColor,0 0 22px currentColor}
.sat1{width:9px;height:9px;top:-4px;left:50%;margin-left:-4px;background:#00d4ff;color:#00d4ff;animation:satGlow 2s ease-in-out infinite alternate}
.sat2{width:7px;height:7px;top:-3px;left:30%;background:#ffb700;color:#ffb700;animation:satGlow 1.6s ease-in-out infinite alternate}
.sat3{width:8px;height:8px;top:-4px;right:20%;background:#00ffaa;color:#00ffaa;animation:satGlow 2.4s ease-in-out infinite alternate}
@keyframes satGlow{0%{opacity:.7;transform:scale(.9)}100%{opacity:1;transform:scale(1.2)}}
#globeCanvas{position:relative;z-index:5;border-radius:50%;filter:drop-shadow(0 0 40px rgba(0,212,255,.55)) drop-shadow(0 0 80px rgba(0,212,255,.2))}
.globe-atmos{position:absolute;width:340px;height:340px;border-radius:50%;z-index:6;pointer-events:none;
  background:radial-gradient(ellipse at 30% 25%,rgba(0,212,255,.07) 0%,rgba(0,150,255,.04) 40%,rgba(0,212,255,.1) 70%,transparent 72%);
  animation:atmosShift 6s ease-in-out infinite alternate}
@keyframes atmosShift{0%{box-shadow:0 0 60px 20px rgba(0,212,255,.15)}100%{box-shadow:0 0 90px 35px rgba(0,150,255,.22)}}
.data-node{position:absolute;z-index:8;background:rgba(6,12,24,.85);backdrop-filter:blur(8px);
  border:1px solid rgba(0,212,255,.32);border-radius:8px;padding:4px 9px;font-size:.62rem;
  font-weight:700;color:var(--accent);letter-spacing:1px;white-space:nowrap;
  box-shadow:0 0 12px rgba(0,212,255,.18),0 4px 15px rgba(0,0,0,.4);animation:nodeFloat 4s ease-in-out infinite}
.data-node::before{content:'';position:absolute;width:4px;height:4px;background:var(--accent);
  border-radius:50%;right:-2px;top:50%;margin-top:-2px;box-shadow:0 0 6px var(--accent)}
.dn1{top:5%;right:5%;animation-delay:0s;animation-duration:4.5s}
.dn2{top:18%;left:-2%;animation-delay:.8s;animation-duration:5s;border-color:rgba(0,255,170,.32);color:var(--green)}
.dn2::before{background:var(--green);box-shadow:0 0 6px var(--green)}
.dn3{bottom:22%;right:2%;animation-delay:1.6s;animation-duration:3.8s}
.dn4{bottom:8%;left:5%;animation-delay:2.4s;animation-duration:5.2s;border-color:rgba(255,183,0,.32);color:var(--gold)}
.dn4::before{background:var(--gold);box-shadow:0 0 6px var(--gold)}
.dn5{top:50%;right:-4%;animation-delay:3.2s;animation-duration:4.2s}
.dn6{top:40%;left:-6%;animation-delay:.4s;animation-duration:4.8s;border-color:rgba(255,68,85,.28);color:#ff8899}
.dn6::before{background:#ff8899;box-shadow:0 0 6px #ff8899}
@keyframes nodeFloat{0%,100%{transform:translateY(0) scale(1)}50%{transform:translateY(-8px) scale(1.04)}}

/* ── TICKER ── */
.ticker{background:var(--bg2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:.6rem 0;overflow:hidden;white-space:nowrap;position:relative;z-index:2}
.ticker-track{display:inline-flex;animation:tickerMove 30s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.tick-item{padding:0 2.2rem;color:var(--muted);font-size:.78rem;letter-spacing:.5px}
.tick-item span{color:var(--accent);margin-right:.4rem}
@keyframes tickerMove{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── CARDS ── */
.svcs-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(290px,1fr));gap:1.5rem}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:18px;
  padding:2rem;transition:.3s;position:relative;overflow:hidden}
.svc-card::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(0,212,255,.04),transparent);opacity:0;transition:.3s;pointer-events:none;z-index:1}
.svc-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:var(--glow)}
.svc-card:hover::before{opacity:1}
.svc-card-body{padding:1.5rem;position:relative;z-index:2}
.svc-icon{width:50px;height:50px;border-radius:13px;background:rgba(0,212,255,.07);
  border:1px solid rgba(0,212,255,.18);display:flex;align-items:center;justify-content:center;
  font-size:1.4rem;margin-bottom:1.2rem}
.svc-card h3{font-family:var(--font-head);font-size:.95rem;font-weight:700;color:var(--accent);margin-bottom:.6rem}
.svc-card p{color:var(--muted);font-size:.83rem;line-height:1.65}

/* ── TECH PILLS ── */
.tech-wrap{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}
.tech-pill{background:var(--card);border:1px solid var(--border);padding:.55rem 1.3rem;
  border-radius:25px;font-size:.82rem;font-weight:600;transition:.2s;display:flex;align-items:center;gap:.5rem;color:var(--text)}
.tech-pill:hover{border-color:var(--accent);color:var(--accent);transform:scale(1.05)}
.tech-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}

/* ── SHOP ── */
.shop-filters{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2.5rem;justify-content:center}
.filter-btn{background:var(--card);border:1px solid var(--border);color:var(--muted);
  padding:.5rem 1.3rem;border-radius:25px;font-size:.8rem;font-weight:600;cursor:pointer;transition:.2s}
.filter-btn:hover,.filter-btn.active{background:rgba(0,212,255,.1);border-color:var(--accent);color:var(--accent)}
.shop-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.8rem}
.prod-card{background:var(--bg2);border:1px solid var(--border);border-radius:20px;
  overflow:hidden;transition:.3s;display:flex;flex-direction:column}
.prod-card:hover{border-color:var(--accent);transform:translateY(-5px);box-shadow:var(--glow)}
.prod-img{height:200px;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;border-bottom:1px solid var(--border);background:var(--bg3)}
.prod-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease;display:block}
.prod-card:hover .prod-img img{transform:scale(1.05)}
.prod-img .prod-img-placeholder{font-size:3.5rem;opacity:.35;user-select:none}
.prod-img .prod-img-overlay{position:absolute;inset:0;background:linear-gradient(180deg,transparent 50%,rgba(0,0,0,.5))}
/* service card image */
.svc-img{width:100%;height:160px;object-fit:cover;border-radius:12px 12px 0 0;display:block}
.svc-card{background:var(--card);border:1px solid var(--border);border-radius:18px;
  overflow:hidden;transition:.3s;position:relative}
.prod-badge{position:absolute;top:12px;right:12px;font-size:.6rem;font-weight:800;
  padding:.22rem .65rem;border-radius:18px;letter-spacing:.5px;text-transform:uppercase}
.badge-hot{background:var(--red);color:#fff}
.badge-new{background:var(--accent);color:#000}
.badge-sale{background:var(--gold);color:#000}
.badge-pro{background:var(--green);color:#000}
.pi-1{background:linear-gradient(135deg,#0a1a30,#0d2040)}
.pi-2{background:linear-gradient(135deg,#0a2018,#0d3020)}
.pi-3{background:linear-gradient(135deg,#1a0a30,#200d40)}
.pi-4{background:linear-gradient(135deg,#201a0a,#302810)}
.pi-5{background:linear-gradient(135deg,#0a1830,#0d2045)}
.pi-6{background:linear-gradient(135deg,#1a100a,#301808)}
.pi-7{background:linear-gradient(135deg,#0a2030,#0d3040)}
.pi-8{background:linear-gradient(135deg,#120a30,#1a0d40)}
.pi-9{background:linear-gradient(135deg,#0a2010,#0d3015)}
.pi-10{background:linear-gradient(135deg,#201a0a,#352810)}
.pi-11{background:linear-gradient(135deg,#200a0a,#350d0d)}
.pi-12{background:linear-gradient(135deg,#0a1a35,#0d2050)}
.prod-info{padding:1.3rem;flex:1;display:flex;flex-direction:column}
.prod-cat{font-size:.68rem;color:var(--accent);letter-spacing:1px;text-transform:uppercase;font-weight:600;margin-bottom:.4rem}
.prod-info h3{font-family:var(--font-head);font-size:.88rem;font-weight:700;margin-bottom:.5rem;line-height:1.3}
.prod-info p{color:var(--muted);font-size:.8rem;line-height:1.6;flex:1;margin-bottom:1rem}
.prod-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:.5rem}
.prod-price{font-family:var(--font-head);font-size:1.1rem;font-weight:800}
.prod-price small{font-size:.62rem;color:var(--muted);font-family:var(--font-body);display:block;line-height:1}
.prod-price .old-price{font-size:.72rem;color:var(--muted);text-decoration:line-through;font-family:var(--font-body);margin-bottom:2px}
.add-btn{background:var(--accent);color:#000;border:none;cursor:pointer;padding:.5rem 1rem;
  border-radius:18px;font-size:.78rem;font-weight:800;transition:.2s;white-space:nowrap;font-family:var(--font-body)}
.add-btn:hover{background:var(--green);transform:scale(1.06)}
.view-btn{border:1px solid var(--border);color:var(--muted);padding:.45rem .9rem;border-radius:18px;
  font-size:.75rem;font-weight:600;transition:.2s;white-space:nowrap;text-decoration:none;display:inline-flex}
.view-btn:hover{border-color:var(--accent);color:var(--accent)}

/* ── PORTFOLIO ── */
.port-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.8rem}
.port-card{background:var(--bg3);border:1px solid var(--border);border-radius:20px;overflow:hidden;transition:.3s}
.port-card:hover{border-color:var(--accent);transform:translateY(-5px)}
.port-thumb{height:180px;display:flex;align-items:center;justify-content:center;font-size:3.5rem;position:relative}
.port-overlay{position:absolute;inset:0;background:rgba(0,212,255,.07);opacity:0;transition:.3s;
  display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;color:var(--accent)}
.port-card:hover .port-overlay{opacity:1}
.port-body{padding:1.4rem}
.port-body h3{font-family:var(--font-head);font-size:.88rem;font-weight:700;margin-bottom:.5rem}
.port-body p{color:var(--muted);font-size:.8rem;line-height:1.6;margin-bottom:.8rem}
.port-tags{display:flex;flex-wrap:wrap;gap:.4rem}
.ptag{background:rgba(0,212,255,.07);border:1px solid rgba(0,212,255,.16);color:var(--accent);font-size:.67rem;padding:.2rem .65rem;border-radius:18px}

/* ── ANNOUNCEMENTS ── */
.ann-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.ann-card{background:var(--card);border:1px solid rgba(0,212,255,.1);border-radius:16px;padding:1.8rem;transition:.3s}
.ann-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--glow)}
.ann-badge-label{display:inline-block;padding:4px 12px;border-radius:18px;font-size:.65rem;font-weight:700;margin-bottom:.8rem;letter-spacing:.5px}
.ann-date{color:var(--muted);font-size:.73rem;margin-bottom:.4rem}
.ann-title{color:#fff;font-size:.98rem;font-weight:700;margin-bottom:.6rem;font-family:var(--font-head)}
.ann-content{color:var(--muted);font-size:.82rem;line-height:1.65}
.ann-author{color:var(--muted);font-size:.7rem;margin-top:.8rem;border-top:1px solid var(--border);padding-top:.7rem}

/* ── TESTIMONIALS ── */
.testi-slider{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}
.testi-card{background:var(--bg2);border:1px solid var(--border);
  border-radius:20px;padding:2rem;transition:.3s;
  display:flex;flex-direction:column;height:260px}
.testi-text{flex:1;overflow:hidden;display:-webkit-box;-webkit-line-clamp:5;-webkit-box-orient:vertical}
.testi-card:hover{border-color:var(--accent);box-shadow:var(--glow)}
.stars{color:#FFB700;font-size:.9rem;margin-bottom:.8rem;letter-spacing:2px}
.testi-text{color:var(--muted);font-size:.87rem;line-height:1.75;margin-bottom:1.3rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:.8rem}
.testi-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--green));
  display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;color:#000;flex-shrink:0}
.testi-name{font-weight:700;font-size:.87rem}
.testi-role{color:var(--muted);font-size:.73rem;margin-top:2px}

/* ── COMMUNITY / ABOUT ── */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center}
.two-col p{color:var(--muted);line-height:1.85;margin-bottom:1rem}
.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
.stat-card{text-align:center;padding:2rem;background:rgba(0,212,255,.04);
  border:1px solid rgba(0,212,255,.14);border-radius:14px;transition:.3s}
.stat-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.big-num{font-family:var(--font-head);font-size:2.2rem;font-weight:900;color:var(--accent);margin-bottom:.4rem}
.stat-card .lbl{color:var(--muted);font-size:.75rem;text-transform:uppercase;letter-spacing:1px}

/* ── LIVE / EVENTS ── */
.live-frame,.events-wrap{background:var(--card);border:1px solid var(--border);border-radius:20px;padding:20px;max-width:900px;margin:0 auto}
.live-frame{margin-bottom:22px}
.live-frame h3,.events-wrap h3{color:var(--accent);font-family:var(--font-head);font-size:.88rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.live-frame iframe{width:100%;height:460px;border-radius:14px;border:none}
.event-item{background:rgba(255,255,255,.02);border:1px solid rgba(0,212,255,.08);border-radius:10px;
  padding:14px;margin-bottom:10px;display:flex;justify-content:space-between;align-items:flex-start;gap:10px;flex-wrap:wrap}
.event-info h4{color:var(--accent);font-size:.85rem;margin-bottom:4px;font-family:var(--font-head)}
.event-info p{color:var(--muted);font-size:.77rem;margin-top:3px}
.days-badge{background:rgba(0,212,255,.09);color:var(--accent);padding:4px 10px;border-radius:12px;font-size:.7rem;white-space:nowrap;flex-shrink:0}

/* ── CONTACT / FORMS ── */
.contact-wrap{display:grid;grid-template-columns:1fr 1.3fr;gap:3.5rem;align-items:start}
.c-items{display:flex;flex-direction:column;gap:1.2rem}
.c-item{display:flex;align-items:flex-start;gap:.9rem;background:var(--card);
  border:1px solid var(--border);border-radius:14px;padding:1.2rem;transition:.3s}
.c-item:hover{border-color:var(--accent);transform:translateX(5px)}
.c-icon-wrap{width:42px;height:42px;border-radius:11px;background:rgba(0,212,255,.07);
  border:1px solid rgba(0,212,255,.16);display:flex;align-items:center;justify-content:center;font-size:1.1rem;flex-shrink:0}
.c-lbl{font-size:.67rem;color:var(--accent);letter-spacing:1px;text-transform:uppercase;margin-bottom:.2rem;font-weight:600}
.c-val{font-size:.83rem;color:var(--text)}
.form-wrap{display:flex;flex-direction:column;gap:.9rem}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.fg{display:flex;flex-direction:column;gap:.4rem}
.fg label{font-size:.73rem;color:var(--muted);letter-spacing:.3px;font-weight:500}
.fg input,.fg textarea,.fg select{background:var(--bg3);border:1px solid var(--border);border-radius:10px;
  padding:.8rem 1rem;color:var(--text);font-family:var(--font-body);font-size:.87rem;transition:.2s;outline:none;resize:none}
.fg input:focus,.fg textarea:focus,.fg select:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,212,255,.07)}
.fg textarea{min-height:120px}
.fg select option{background:var(--bg3);color:var(--text)}
.submit-btn{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#000;
  border:none;cursor:pointer;padding:1rem 2rem;border-radius:25px;font-weight:800;
  font-size:.88rem;transition:.2s;box-shadow:0 0 22px rgba(0,212,255,.28);letter-spacing:.3px;font-family:var(--font-body)}
.submit-btn:hover{transform:translateY(-2px);box-shadow:0 0 35px rgba(0,212,255,.45)}

/* ── CTA BANNER ── */
.cta-banner{background:linear-gradient(135deg,rgba(0,212,255,.06),rgba(0,255,170,.04));
  border-top:1px solid var(--border);border-bottom:1px solid var(--border);text-align:center;padding:5rem 5%;z-index:2;position:relative}
.cta-banner h2{font-family:var(--font-head);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:900;margin-bottom:.8rem}
.cta-banner p{color:var(--muted);margin-bottom:2rem;font-size:.95rem}

/* ── FOOTER ── */
footer{background:var(--bg);border-top:1px solid var(--border);padding:3rem 5% 1.5rem;position:relative;z-index:2}
.foot-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.3fr;gap:3rem;margin-bottom:2.5rem}
.foot-logo{font-family:var(--font-head);font-weight:900;font-size:1.2rem;color:var(--accent);letter-spacing:2px;display:inline-block}
.foot-logo span{color:#fff}
.foot-brand p{color:var(--muted);font-size:.82rem;line-height:1.7;margin:1rem 0 1.2rem}
.foot-socials{display:flex;gap:.6rem;flex-wrap:wrap}
.foot-soc{width:34px;height:34px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;
  justify-content:center;font-size:.72rem;color:var(--muted);text-decoration:none;transition:.2s;font-weight:700}
.foot-soc:hover{border-color:var(--accent);color:var(--accent)}
.foot-col h4{font-family:var(--font-head);font-weight:700;font-size:.82rem;color:#fff;margin-bottom:1rem;letter-spacing:.5px}
.foot-col ul{list-style:none}
.foot-col li{margin-bottom:.55rem}
.foot-col a{color:var(--muted);text-decoration:none;font-size:.82rem;transition:.2s}
.foot-col a:hover{color:var(--accent)}
.newsletter-wrap{display:flex;gap:.5rem;margin-top:.5rem}
.newsletter-wrap input{flex:1;background:var(--bg2);border:1px solid var(--border);border-radius:8px;
  padding:.55rem .8rem;color:var(--text);font-size:.8rem;outline:none;transition:.2s;font-family:var(--font-body)}
.newsletter-wrap input:focus{border-color:var(--accent)}
.newsletter-wrap button{background:var(--accent);color:#000;border:none;cursor:pointer;
  padding:.55rem .9rem;border-radius:8px;font-weight:800;font-size:.8rem;transition:.2s}
.newsletter-wrap button:hover{background:var(--green)}
.foot-bottom{border-top:1px solid var(--border);padding-top:1.2rem;display:flex;
  justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}
.foot-bottom p{color:var(--muted);font-size:.77rem}

/* ── SCROLL TOP — sits ABOVE the chat button ── */
.scroll-top-btn{position:fixed;bottom:96px;right:26px;width:44px;height:44px;background:var(--accent);
  color:#000;border:none;border-radius:50%;cursor:pointer;display:none;align-items:center;justify-content:center;
  font-size:1.2rem;z-index:9998;transition:.3s;box-shadow:0 4px 20px rgba(0,212,255,.38);font-weight:700}
.scroll-top-btn:hover{transform:translateY(-3px);box-shadow:0 8px 28px rgba(0,212,255,.6)}
.scroll-top-btn.show{display:flex}

/* ── CHATBOT — fixed at bottom-right ── */
.chat-btn{position:fixed;bottom:26px;right:26px;z-index:9999;width:56px;height:56px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent2));border:none;color:#000;
  font-size:.62rem;font-weight:800;cursor:pointer;box-shadow:0 6px 25px rgba(0,212,255,.48);
  transition:.3s;display:flex;align-items:center;justify-content:center;text-align:center;
  line-height:1.2;letter-spacing:.5px;text-transform:uppercase;animation:chatPulse 2.5s infinite}
@keyframes chatPulse{0%,100%{box-shadow:0 6px 25px rgba(0,212,255,.48)}50%{box-shadow:0 6px 40px rgba(0,212,255,.9)}}
.chat-btn:hover{transform:scale(1.08)}
.chatbot-modal{display:none;position:fixed;bottom:96px;right:26px;width:360px;
  max-width:calc(100vw - 40px);height:480px;background:rgba(6,12,24,.97);backdrop-filter:blur(20px);
  border-radius:22px;border:1px solid rgba(0,212,255,.28);z-index:10000;
  box-shadow:0 20px 60px rgba(0,0,0,.6);flex-direction:column}
.chatbot-modal.open{display:flex}
.chat-head{background:rgba(0,212,255,.07);border-bottom:1px solid rgba(0,212,255,.18);
  padding:14px 16px;display:flex;align-items:center;justify-content:space-between}
.chat-title{font-family:var(--font-head);font-size:.83rem;font-weight:700;color:var(--accent);display:flex;align-items:center;gap:7px}
.chat-status{font-size:.67rem;padding:2px 9px;border-radius:12px;background:rgba(0,212,255,.13);color:var(--accent)}
.chat-head-right{display:flex;align-items:center;gap:.4rem}
.chat-clear-btn{background:rgba(255,68,68,.09);border:1px solid rgba(255,68,68,.18);color:var(--red);
  padding:3px 9px;border-radius:12px;font-size:.63rem;cursor:pointer;transition:.2s}
.chat-x-btn{background:none;border:none;color:var(--muted);font-size:1.1rem;cursor:pointer;transition:.2s}
.chat-x-btn:hover{color:var(--red)}
.chat-body{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:10px}
.chat-msg{max-width:84%;padding:10px 13px;border-radius:16px;word-wrap:break-word;animation:msgIn .3s ease}
@keyframes msgIn{from{opacity:0;transform:translateY(7px)}to{opacity:1;transform:translateY(0)}}
.chat-msg.bot{background:rgba(255,255,255,.04);border:1px solid rgba(0,212,255,.14);align-self:flex-start;border-bottom-left-radius:4px}
.chat-msg.user{background:rgba(0,212,255,.11);border:1px solid rgba(0,212,255,.23);align-self:flex-end;border-bottom-right-radius:4px}
.msg-sender{font-size:.67rem;color:var(--accent);font-weight:700;margin-bottom:3px}
.msg-sender.user{color:var(--green)}
.msg-time{font-size:.58rem;color:rgba(255,255,255,.28);text-align:right;margin-top:3px}
.chat-msg .chat-text{font-size:.8rem;line-height:1.6}
.typing-dots{display:flex;gap:4px;padding:10px 13px;background:rgba(255,255,255,.04);
  border:1px solid rgba(0,212,255,.13);border-radius:16px;align-self:flex-start;border-bottom-left-radius:4px}
.typing-dots span{width:6px;height:6px;background:var(--accent);border-radius:50%;animation:typBounce 1.4s infinite ease-in-out}
.typing-dots span:nth-child(1){animation-delay:-0.32s}
.typing-dots span:nth-child(2){animation-delay:-0.16s}
@keyframes typBounce{0%,80%,100%{transform:scale(.6);opacity:.6}40%{transform:scale(1);opacity:1}}
.sugg-wrap{display:flex;flex-wrap:wrap;gap:5px;padding:7px 9px;background:rgba(255,255,255,.02);border-radius:10px}
.sugg-q{background:rgba(0,212,255,.07);border:1px solid rgba(0,212,255,.16);color:var(--accent);
  padding:5px 10px;border-radius:16px;font-size:.67rem;cursor:pointer;transition:.2s}
.sugg-q:hover{background:rgba(0,212,255,.16);transform:translateY(-1px)}
.chat-input-wrap{padding:12px 14px;background:rgba(6,12,24,.8);border-top:1px solid rgba(0,212,255,.13);display:flex;gap:8px}
.chat-input-wrap input{flex:1;padding:9px 14px;background:rgba(255,255,255,.04);
  border:1px solid rgba(0,212,255,.16);border-radius:22px;color:var(--text);font-family:var(--font-body);font-size:.8rem}
.chat-input-wrap input:focus{outline:none;border-color:var(--accent)}
.chat-input-wrap input::placeholder{color:rgba(255,255,255,.22)}
.chat-send-btn{background:var(--accent);border:none;border-radius:50%;width:38px;height:38px;
  color:#000;cursor:pointer;transition:.2s;font-size:.95rem;font-weight:800;flex-shrink:0}
.chat-send-btn:hover{background:var(--green);transform:scale(1.08)}

/* ── FLASH MESSAGES ── */
.flash-msg,.global-flash{padding:12px 18px;border-radius:10px;font-size:.85rem;
  margin-bottom:1rem;display:flex;align-items:center;gap:8px;animation:fadeInDown .4s ease}
.flash-success,.global-flash.flash-success{background:rgba(0,200,83,.12);border:1px solid rgba(0,200,83,.28);color:#00C853}
.flash-error,.global-flash.flash-error{background:rgba(255,68,68,.12);border:1px solid rgba(255,68,68,.28);color:#ff5252}
.flash-info,.global-flash.flash-info{background:rgba(0,212,255,.1);border:1px solid rgba(0,212,255,.25);color:var(--accent)}
.flash-warning,.global-flash.flash-warning{background:rgba(255,183,0,.1);border:1px solid rgba(255,183,0,.25);color:var(--gold)}
.global-flash{position:fixed;top:110px;right:20px;z-index:10002;max-width:360px;
  box-shadow:0 8px 30px rgba(0,0,0,.4);backdrop-filter:blur(12px)}
@keyframes fadeInDown{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}

/* ── AUTH / FORM PAGES ── */
.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:100px 20px 40px;background:var(--bg)}
.auth-box{background:var(--bg2);border:1px solid var(--border);border-radius:22px;
  padding:2.5rem;width:100%;max-width:460px;box-shadow:0 30px 80px rgba(0,0,0,.5);
  position:relative;z-index:10}
.auth-box h2{font-family:var(--font-head);font-size:1.3rem;color:#fff;text-align:center;margin-bottom:1.5rem}
.auth-tabs{display:flex;border-bottom:1px solid var(--border);margin-bottom:1.8rem}
.auth-tab-btn{padding:11px 22px;background:none;border:none;color:var(--muted);font-size:.88rem;
  cursor:pointer;transition:.2s;border-bottom:3px solid transparent;font-family:var(--font-body)}
.auth-tab-btn:hover{color:#fff}
.auth-tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.google-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:10px;padding:13px;
  background:#fff;color:#333;border:none;border-radius:25px;font-size:.87rem;font-weight:700;
  cursor:pointer;transition:.3s;margin-bottom:14px;font-family:var(--font-body)}
.google-btn:hover{box-shadow:0 4px 15px rgba(66,133,244,.2);transform:translateY(-1px)}
.auth-divider{display:flex;align-items:center;gap:12px;color:var(--muted);font-size:.77rem;margin:10px 0}
.auth-divider::before,.auth-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.auth-input{width:100%;padding:12px 16px;background:rgba(255,255,255,.03);border:1px solid var(--border);
  border-radius:10px;color:#fff;font-family:var(--font-body);font-size:.88rem;transition:.2s;margin-bottom:12px;outline:none}
.auth-input:focus{border-color:var(--accent);background:rgba(255,255,255,.04);box-shadow:0 0 0 3px rgba(0,212,255,.07)}
.auth-submit{width:100%;padding:13px;background:linear-gradient(135deg,var(--accent),var(--accent2));
  color:#000;border:none;border-radius:25px;font-weight:800;font-size:.88rem;cursor:pointer;
  transition:.2s;letter-spacing:.3px;font-family:var(--font-body)}
.auth-submit:hover{transform:translateY(-2px);box-shadow:0 6px 25px rgba(0,212,255,.4)}
.auth-link{color:var(--muted);font-size:.8rem;text-align:center;margin-top:14px}
.auth-link a{color:var(--accent);cursor:pointer;text-decoration:none}
.auth-link a:hover{text-decoration:underline}

/* ── CART / CHECKOUT / DASHBOARD ── */
.page-wrap{padding:120px 5% 5rem;min-height:100vh}
.page-title{font-family:var(--font-head);font-size:1.8rem;font-weight:900;margin-bottom:1.5rem;
  background:linear-gradient(135deg,#fff,rgba(255,255,255,.7));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}
.card{background:var(--bg2);border:1px solid var(--border);border-radius:18px;padding:1.8rem;margin-bottom:1.5rem;transition:.3s}
.card:hover{border-color:rgba(0,212,255,.25)}
.card h3{font-family:var(--font-head);font-size:1rem;font-weight:700;color:var(--accent);margin-bottom:1rem}
.cart-layout{display:grid;grid-template-columns:1fr 360px;gap:1.8rem;align-items:start}
.cart-item-row{display:flex;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--border)}
.ci-icon{width:52px;height:52px;border-radius:12px;background:rgba(0,212,255,.07);
  border:1px solid rgba(0,212,255,.14);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.ci-info{flex:1}
.ci-name{font-size:.87rem;font-weight:600;margin-bottom:.2rem}
.ci-price{color:var(--accent);font-size:.82rem;font-weight:700}
.ci-qty{display:flex;align-items:center;gap:.4rem;margin-top:.4rem}
.qty-b{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:none;
  color:var(--text);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:.2s}
.qty-b:hover{border-color:var(--accent);color:var(--accent)}
.ci-del{background:none;border:none;color:var(--muted);cursor:pointer;font-size:.85rem;transition:.2s;padding:.2rem}
.ci-del:hover{color:var(--red)}
.summary-row{display:flex;justify-content:space-between;padding:.6rem 0;font-size:.88rem}
.summary-row.total{border-top:1px solid var(--border);margin-top:.5rem;padding-top:1rem;font-weight:700;font-size:1rem}
.empty-cart{text-align:center;padding:4rem 1rem;color:var(--muted)}
.empty-cart .empty-icon{font-size:4rem;display:block;margin-bottom:1rem}
.order-btn{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent2));color:#000;
  border:none;cursor:pointer;padding:1rem;border-radius:12px;font-weight:800;font-size:.92rem;
  transition:.2s;box-shadow:0 0 22px rgba(0,212,255,.28);letter-spacing:.3px;font-family:var(--font-body)}
.order-btn:hover{background:linear-gradient(135deg,var(--green),var(--accent));transform:translateY(-2px)}
.table-wrap{overflow-x:auto}
table{width:100%;border-collapse:collapse;font-size:.83rem}
th{padding:10px 14px;background:rgba(0,212,255,.05);color:var(--accent);font-weight:700;
  text-align:left;font-size:.72rem;letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--border)}
td{padding:12px 14px;border-bottom:1px solid rgba(0,212,255,.06);color:var(--text);vertical-align:middle}
tr:hover td{background:rgba(255,255,255,.02)}
.badge{display:inline-block;padding:3px 10px;border-radius:12px;font-size:.68rem;font-weight:700;letter-spacing:.5px}
.badge-pending{background:rgba(255,183,0,.12);color:var(--gold);border:1px solid rgba(255,183,0,.2)}
.badge-confirmed{background:rgba(0,212,255,.1);color:var(--accent);border:1px solid rgba(0,212,255,.2)}
.badge-delivered{background:rgba(0,200,83,.1);color:#00C853;border:1px solid rgba(0,200,83,.2)}
.badge-cancelled{background:rgba(255,68,68,.1);color:var(--red);border:1px solid rgba(255,68,68,.2)}

/* ── ADMIN ── */
.admin-layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}
.admin-sidebar{background:var(--bg2);border-right:1px solid var(--border);padding:100px 0 2rem;position:sticky;top:0;height:100vh;overflow-y:auto}
.admin-nav-logo{font-family:var(--font-head);font-size:1rem;font-weight:900;color:var(--accent);padding:0 1.5rem 1.5rem;display:block;text-decoration:none}
.admin-nav-logo span{color:#fff}
.adm-link{display:flex;align-items:center;gap:10px;padding:11px 1.5rem;color:var(--muted);text-decoration:none;font-size:.82rem;font-weight:600;transition:.2s;border-left:3px solid transparent}
.adm-link:hover,.adm-link.active{color:#fff;background:rgba(0,212,255,.06);border-left-color:var(--accent)}
.adm-link.active{color:var(--accent)}
.adm-link .adm-icon{font-size:1.1rem;width:22px;text-align:center}
.admin-content{padding:90px 2rem 3rem;overflow-x:hidden}
.adm-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.8rem;flex-wrap:wrap;gap:1rem}
.adm-head h1{font-family:var(--font-head);font-size:1.3rem;font-weight:800;color:var(--accent)}
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:2rem}
.adm-stat{background:rgba(0,212,255,.04);border:1px solid rgba(0,212,255,.12);border-radius:14px;
  padding:1.5rem;text-align:center;transition:.3s}
.adm-stat:hover{border-color:var(--accent);transform:translateY(-3px)}
.adm-stat .n{font-family:var(--font-head);font-size:2rem;font-weight:900;color:var(--accent);margin-bottom:.3rem}
.adm-stat .l{color:var(--muted);font-size:.72rem;text-transform:uppercase;letter-spacing:.5px}

/* ── RESPONSIVE ── */
@media(max-width:1024px){.two-col,.contact-wrap,.cart-layout,.foot-grid{grid-template-columns:1fr}.admin-layout{grid-template-columns:1fr}}
@media(max-width:900px){.nav-center,.nav-login-btn,.nav-cta-btn{display:none}.hamburger{display:flex}.top-bar .top-bar-left{display:none}}
@media(max-width:768px){
  #home{flex-direction:column;text-align:center;padding:110px 5% 50px}
  .hero-visual{min-width:unset;transform:scale(.72);transform-origin:top center}
  .hero-btns{justify-content:center}.hero-stats{justify-content:center}
  .frow{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}
  section{padding:3.5rem 5%}.ann-grid{grid-template-columns:1fr}
  .admin-sidebar{display:none}.adm-stat .n{font-size:1.5rem}
  .data-node{display:none}
}
@media(max-width:480px){.hero-btns{flex-direction:column;align-items:center}}

/* ── CLIENTS / TRUSTED BY ── */
.clients-section{background:var(--bg2)}
.clients-section .sec-sub{max-width:600px;margin:0 auto}

/* Filter pills — matches reference */
.clients-filter{display:flex;gap:.55rem;flex-wrap:wrap;justify-content:center;margin-bottom:2.8rem;margin-top:1.2rem}
.cf-btn{background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--muted);
  padding:.42rem 1.2rem;border-radius:30px;font-size:.78rem;font-weight:600;cursor:pointer;
  transition:.22s;text-decoration:none;display:inline-block;white-space:nowrap}
.cf-btn:hover{border-color:rgba(0,212,255,.4);color:var(--text)}
.cf-btn.active{background:var(--accent);border-color:var(--accent);color:#000;font-weight:700}

/* Grid — 4 columns like reference */
.clients-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
@media(max-width:1100px){.clients-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){.clients-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.clients-grid{grid-template-columns:1fr}}

/* Card — matches reference exactly */
.client-card{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:1.4rem;
  display:flex;flex-direction:column;gap:0;
  transition:.25s;position:relative;overflow:hidden;
  min-height:190px}
.client-card:hover{
  border-color:rgba(255,255,255,.18);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,.45);
  background:rgba(255,255,255,.05)}

/* Top row: avatar + name + category */
.client-card-head{display:flex;align-items:center;gap:.85rem;margin-bottom:.9rem}
.client-av{
  width:50px;height:50px;border-radius:14px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-size:.88rem;font-weight:900;
  color:#fff;letter-spacing:.5px;
  /* subtle inner shadow for depth like reference */
  box-shadow:inset 0 -2px 6px rgba(0,0,0,.25),0 4px 12px rgba(0,0,0,.3)}
.client-name{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.3;margin-bottom:.18rem}
.client-cat{font-size:.72rem;color:var(--muted);font-weight:500}

/* Description */
.client-desc{font-size:.78rem;color:rgba(255,255,255,.42);line-height:1.65;
  flex:1;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}

/* Country — italic at bottom like reference */
.client-country{
  display:block;margin-top:.8rem;
  font-size:.72rem;font-style:italic;color:rgba(255,255,255,.3);font-weight:400}

/* ── TECRO AI CHATBOT ── */
.chat-ai-icon{color:var(--accent);font-size:.9rem;margin-right:2px}
.chat-title{font-family:var(--font-head);font-size:.85rem;font-weight:800;
  color:var(--accent);display:flex;align-items:center;gap:6px;letter-spacing:.5px}
.tecro-ai-badge{background:linear-gradient(135deg,var(--accent),#0099cc);color:#000;
  font-size:.58rem;font-weight:900;padding:1px 6px;border-radius:8px;
  font-family:var(--font-head);letter-spacing:1px}
.msg-sender.bot{display:flex;align-items:center;gap:5px;font-size:.67rem;
  color:var(--accent);font-weight:700;margin-bottom:3px}
.chat-footer-bar{background:rgba(0,212,255,.05);border-top:1px solid rgba(0,212,255,.1);
  padding:6px 14px;font-size:.62rem;color:rgba(0,212,255,.4);text-align:center;
  font-family:var(--font-head);letter-spacing:1px}
