/* ============================================================
   WORDNITY — global.css
   Place in: /assets/css/global.css
   ============================================================ */

:root {
  --bg:      #020817;
  --bg2:     #0a0f1e;
  --bg3:     #0d1526;
  --cyan:    #00e5ff;
  --cyan2:   #00bcd4;
  --purple:  #7c3aed;
  --purple2: #a855f7;
  --green:   #00ff88;
  --orange:  #fb923c;
  --text:    #e2e8f0;
  --muted:   #64748b;
  --muted2:  #94a3b8;
  --card:    rgba(255,255,255,0.03);
  --border:  rgba(0,229,255,0.12);
  --radius:  12px;
  --shadow:  0 0 40px rgba(0,229,255,0.1);
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Outfit', sans-serif;
  overflow-x: hidden;
  cursor: none;
  line-height: 1.6;
}
a, button, input[type=submit], input[type=button], label[for], select { cursor: pointer; }

/* Noise texture */
body::before {
  content:'';
  position:fixed; inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events:none; z-index:1; opacity:.35;
}

/* Canvas */
#bg-canvas {
  position:fixed; top:0; left:0;
  width:100%; height:100%;
  z-index:0; opacity:.55;
  pointer-events:none;
}

/* ── CURSOR ─────────────────────────────────────────────── */
.cursor {
  width:12px; height:12px; border-radius:50%;
  background:var(--cyan); position:fixed; top:0; left:0;
  pointer-events:none; z-index:9999; mix-blend-mode:difference;
  transition:transform .1s; will-change:transform;
}
.cursor-trail {
  width:36px; height:36px; border-radius:50%;
  border:1px solid var(--cyan); position:fixed; top:0; left:0;
  pointer-events:none; z-index:9998; opacity:.45;
  transition:all .12s ease; will-change:transform;
}

/* ── NAVBAR ─────────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:70px;
  padding:0 5%;
  display:flex; align-items:center;
  background:rgba(2,8,23,.72); backdrop-filter:blur(28px);
  border-bottom:1px solid var(--border);
  transition:all .3s;
  box-sizing:border-box;
}
nav.scrolled { background:rgba(2,8,23,.96); box-shadow:0 4px 32px rgba(0,0,0,.35); }

/* Inner wrapper */
nav > .nav-inner {
  max-width:1200px; width:100%; height:100%;
  margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:1.2rem;
}

.logo {
  font-family:'Orbitron',sans-serif; font-size:1.5rem; font-weight:900;
  letter-spacing:.05em; display:flex; align-items:center; gap:10px;
  text-decoration:none; color:var(--text);
}
.logo span {
  background:linear-gradient(135deg,var(--cyan),var(--purple2));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.logo-dot {
  width:10px; height:10px; background:var(--cyan); border-radius:50%;
  animation:pulse 2s infinite; box-shadow:0 0 15px var(--cyan); flex-shrink:0;
}

.nav-links { display:flex; gap:2rem; list-style:none; }
.nav-links > li { position:relative; }
.nav-links a {
  color:var(--muted); text-decoration:none; font-size:.9rem;
  font-weight:500; letter-spacing:.03em; transition:color .3s; white-space:nowrap;
}
.nav-links a::after {
  content:''; position:absolute; bottom:-4px; left:0;
  width:0; height:1px; background:var(--cyan); transition:width .3s;
}
.nav-links a:hover,
.nav-links a.active { color:var(--cyan); }
.nav-links a:hover::after,
.nav-links a.active::after { width:100%; }

/* Dropdown */
.dropdown {
  position:absolute; top:calc(100% + 14px); left:-16px;
  background:var(--bg2); border:1px solid var(--border); border-radius:12px;
  padding:.5rem; min-width:230px;
  opacity:0; pointer-events:none; transition:opacity .2s;
  box-shadow:0 20px 40px rgba(0,0,0,.5);
  display:grid; grid-template-columns:1fr 1fr;
}
.has-dropdown:hover .dropdown { opacity:1; pointer-events:all; }
.dropdown a {
  display:flex; align-items:center; gap:.6rem;
  padding:.55rem .8rem; border-radius:7px;
  color:var(--muted); font-size:.82rem; transition:all .2s;
}
.dropdown a i{ font-size:.75rem; width:14px; text-align:center; }
.dropdown a:last-child{ grid-column:1/-1; }
.dropdown a:hover { background:rgba(0,229,255,.06); color:var(--cyan); }
.dropdown a::after { display:none; }

/* Nav Buttons */
.nav-cta { display:flex; gap:.8rem; align-items:center; }
.btn-ghost {
  padding:8px 20px; border:1px solid var(--border);
  color:var(--text); text-decoration:none; border-radius:7px;
  font-size:.88rem; font-family:'Outfit',sans-serif; transition:all .3s;
}
.btn-ghost:hover { border-color:var(--cyan); color:var(--cyan); background:rgba(0,229,255,.05); }
.btn-primary {
  padding:8px 22px;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  color:#000; text-decoration:none; border-radius:7px;
  font-size:.88rem; font-weight:700; font-family:'Outfit',sans-serif;
  transition:all .3s; box-shadow:0 0 20px rgba(0,229,255,.25); cursor:pointer;
  border:none;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 0 35px rgba(0,229,255,.5); }

/* Hamburger */
.hamburger {
  display:none; flex-direction:column; gap:5px; background:none;
  border:none; cursor:pointer; padding:4px;
}
.hamburger span { width:24px; height:2px; background:var(--text); border-radius:2px; transition:all .3s; }

/* Mobile menu */
.mobile-menu {
  position:fixed; inset:0; background:var(--bg); z-index:300;
  padding:4rem 2rem 2rem; display:flex; flex-direction:column;
  transform:translateX(100%); transition:transform .35s cubic-bezier(.77,0,.18,1);
}
.mobile-menu.open { transform:translateX(0); }
.mobile-menu ul { list-style:none; display:flex; flex-direction:column; gap:.5rem; }
.mobile-menu ul a {
  display:block; padding:.7rem 0; color:var(--muted);
  text-decoration:none; font-size:1.1rem; border-bottom:1px solid rgba(255,255,255,.04);
  transition:color .2s;
}
.mobile-menu ul a:hover { color:var(--cyan); }
.mobile-close {
  position:absolute; top:1.5rem; right:1.5rem;
  background:none; border:1px solid var(--border); border-radius:8px;
  color:var(--text); font-size:1.1rem; padding:6px 12px; cursor:pointer;
}

/* ── SECTION BASICS ─────────────────────────────────────── */
section { position:relative; z-index:2; }
.container { max-width:1200px; margin:0 auto; padding:0 5%; }

.section-header { text-align:center; margin-bottom:4rem; }
.section-tag {
  display:inline-block; padding:5px 16px;
  border:1px solid rgba(124,58,237,.35); background:rgba(124,58,237,.08);
  border-radius:50px; font-size:.75rem; color:var(--purple2);
  letter-spacing:.12em; text-transform:uppercase; margin-bottom:1rem; font-weight:600;
}
.section-title {
  font-family:'Orbitron',sans-serif;
  font-size:clamp(1.8rem,4vw,2.8rem); font-weight:700; line-height:1.2; margin-bottom:1rem;
}
.section-desc {
  color:var(--muted); font-size:1rem; max-width:520px;
  margin:0 auto; line-height:1.75;
}

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 30px; border-radius:8px; font-family:'Outfit',sans-serif;
  font-size:.95rem; font-weight:600; text-decoration:none; transition:all .3s; cursor:pointer; border:none;
}
.btn-filled {
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  color:#000; box-shadow:0 0 25px rgba(0,229,255,.3);
}
.btn-filled:hover { transform:translateY(-3px); box-shadow:0 0 45px rgba(0,229,255,.5); }
.btn-outline {
  border:1px solid var(--border); color:var(--text); background:rgba(255,255,255,.02);
}
.btn-outline:hover { border-color:var(--cyan); color:var(--cyan); background:rgba(0,229,255,.04); }

/* ── CARDS ───────────────────────────────────────────────── */
.card {
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius);
  transition:all .35s;
}
.card:hover { border-color:rgba(0,229,255,.3); transform:translateY(-4px); box-shadow:var(--shadow); }

/* ── BADGE ───────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:6px 16px; background:rgba(0,229,255,.08);
  border:1px solid rgba(0,229,255,.2); border-radius:50px;
  font-size:.8rem; color:var(--cyan); margin-bottom:2rem;
  letter-spacing:.05em; font-weight:500;
}
.badge-dot { width:6px; height:6px; background:var(--green); border-radius:50%; animation:pulse 1.5s infinite; box-shadow:0 0 8px var(--green); }

/* ── TAGS ────────────────────────────────────────────────── */
.tag { padding:3px 10px; border-radius:4px; font-size:.72rem; font-weight:600; letter-spacing:.05em; }
.tag-cyan   { background:rgba(0,229,255,.1);  color:var(--cyan); }
.tag-purple { background:rgba(168,85,247,.1); color:var(--purple2); }
.tag-green  { background:rgba(0,255,136,.1);  color:var(--green); }
.tag-orange { background:rgba(249,115,22,.1); color:var(--orange); }

/* ── FORM ELEMENTS ───────────────────────────────────────── */
.form-group { margin-bottom:1.2rem; }
.form-label { display:block; font-size:.85rem; color:var(--muted2); margin-bottom:.5rem; font-weight:500; }
.form-control {
  width:100%; padding:13px 18px;
  background:rgba(255,255,255,.04); border:1px solid var(--border);
  border-radius:8px; color:var(--text); font-family:'Outfit',sans-serif;
  font-size:.95rem; outline:none; transition:all .3s;
}
.form-control:focus { border-color:var(--cyan); background:rgba(0,229,255,.04); box-shadow:0 0 0 3px rgba(0,229,255,.08); }
.form-control::placeholder { color:var(--muted); }

/* ── MARQUEE ─────────────────────────────────────────────── */
.marquee-wrap {
  position:relative; z-index:2; padding:18px 0;
  background:rgba(0,229,255,.04);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border); overflow:hidden;
}
.marquee-track { display:flex; gap:3rem; animation:marquee 28s linear infinite; width:max-content; }
.marquee-item {
  display:flex; align-items:center; gap:10px;
  font-size:.82rem; color:var(--muted); font-weight:500;
  letter-spacing:.06em; text-transform:uppercase; white-space:nowrap;
}
.marquee-item .dot { width:4px; height:4px; background:var(--cyan); border-radius:50%; }

/* ── FOOTER ─────────────────────────────────────────────── */
footer {
  background:var(--bg2); border-top:1px solid var(--border);
  padding:70px 5% 30px; position:relative; z-index:2;
}
.footer-grid {
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr 1.2fr;
  gap:2.5rem; margin-bottom:3rem;
}
.footer-brand p { color:var(--muted); font-size:.88rem; line-height:1.75; margin-top:1rem; max-width:240px; }
.footer-col h4 { font-family:'Orbitron',sans-serif; font-size:.72rem; letter-spacing:.12em; color:var(--text); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:.65rem; }
.footer-col ul a { color:var(--muted); text-decoration:none; font-size:.87rem; transition:color .3s; }
.footer-col ul a:hover { color:var(--cyan); }
.footer-socials { display:flex; gap:.7rem; margin-top:1.5rem; }
.social-link {
  width:36px; height:36px; border:1px solid var(--border); border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  text-decoration:none; font-size:.85rem; transition:all .3s; color:var(--muted);
}
.social-link:hover { border-color:var(--cyan); background:rgba(0,229,255,.08); color:var(--cyan); }
.footer-bottom {
  padding-top:2rem; border-top:1px solid var(--border);
  display:flex; align-items:center; justify-content:space-between;
}
.footer-bottom p { color:var(--muted); font-size:.82rem; }

/* ── ALERTS ─────────────────────────────────────────────── */
.alert { padding:12px 18px; border-radius:8px; font-size:.9rem; margin-bottom:1rem; }
.alert-success { background:rgba(0,255,136,.08); border:1px solid rgba(0,255,136,.2); color:var(--green); }
.alert-error   { background:rgba(239,68,68,.08);  border:1px solid rgba(239,68,68,.2);  color:#f87171; }
.alert-info    { background:rgba(0,229,255,.08);  border:1px solid rgba(0,229,255,.2);  color:var(--cyan); }

/* ── GRADIENT TEXT ───────────────────────────────────────── */
.grad-text {
  background: linear-gradient(135deg, var(--cyan) 0%, var(--purple2) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

/* ── SERVICE / FEATURE ICONS ─────────────────────────────── */
.ic-cyan   { background:rgba(0,229,255,.08);  border:1px solid rgba(0,229,255,.2);  }
.ic-purple { background:rgba(168,85,247,.08); border:1px solid rgba(168,85,247,.2); }
.ic-green  { background:rgba(0,255,136,.08);  border:1px solid rgba(0,255,136,.2);  }
.ic-orange { background:rgba(249,115,22,.08); border:1px solid rgba(249,115,22,.2); }

/* ── PAGE HERO (shared across inner pages) ───────────────── */
.page-hero {
  position: relative;
  z-index: 2;
  padding: 160px 5% 80px;
  text-align: center;
  overflow: hidden;
}
.page-hero-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(0,229,255,.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,229,255,.03) 1px, transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at 50% 50%, black 30%, transparent 80%);
}
.page-hero h1 {
  font-family: 'Orbitron', sans-serif;
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 900;
  margin-bottom: 1rem;
}
.page-hero p {
  color: var(--muted);
  font-size: 1.05rem;
  max-width: 560px;
  margin: 0 auto 2rem;
  line-height: 1.75;
}

/* ── REVEAL ANIMATION ────────────────────────────────────── */
.reveal { opacity:1; transform:translateY(0); }

/* ── ANIMATIONS ──────────────────────────────────────────── */
@keyframes pulse    { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(.85)} }
@keyframes float    { 0%,100%{transform:translateY(0)}      50%{transform:translateY(-12px)} }
@keyframes marquee  { to{transform:translateX(-50%)} }
@keyframes spin     { to{transform:rotate(360deg)} }
@keyframes glow-pulse {
  0%,100%{box-shadow:0 0 20px rgba(0,229,255,.2),inset 0 0 20px rgba(0,229,255,.05);}
  50%{box-shadow:0 0 40px rgba(0,229,255,.4),inset 0 0 30px rgba(0,229,255,.1);}
}

/* ── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:1024px){
  .footer-grid{ grid-template-columns:1fr 1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
}
@media(max-width:900px){
  .nav-links,.nav-cta{ display:none; }
  .hamburger{ display:flex; }
}
@media(max-width:768px){
  /* Cursor off on mobile */
  .cursor,.cursor-trail{ display:none !important; }
  body{ cursor:auto; }
  
  /* Navbar */
  nav{ padding:14px 5%; }
  .logo{ font-size:1.2rem; }
  
  /* Mobile menu bigger links */
  .mobile-menu ul a{ font-size:1.2rem; padding:.9rem 0; }
  .mobile-close{ cursor:pointer; }
  .hamburger{ cursor:pointer; }
  
  /* Footer */
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .footer-brand{ grid-column:1/-1; }
  .footer-bottom{ flex-direction:column; gap:.8rem; text-align:center; }
}
@media(max-width:480px){
  .footer-grid{ grid-template-columns:1fr; }
  .footer-brand{ grid-column:auto; }
  nav{ padding:12px 4%; }
}
