/*
╔══════════════════════════════════════════════════════════════════════╗
║          UNLIMITED IT — WEBSITE DESIGN SYSTEM                       ║
║          Version 1.0  |  unlimitedit.com.au                         ║
╠══════════════════════════════════════════════════════════════════════╣
║  HOW TO USE                                                          ║
║                                                                      ║
║  1. Add the Google Fonts <link> tag (below) to every page <head>    ║
║  2. Link this file:                                                  ║
║       <link rel="stylesheet" href="unlimited-it-theme.css">         ║
║  3. Add the two background divs at the top of every <body>:         ║
║       <div class="page-bg"></div>                                    ║
║       <div class="particles">                                        ║
║         <div class="particle"></div>  ← repeat 8 times              ║
║       </div>                                                         ║
║  4. Copy the standard <nav> and <footer> blocks from index.html     ║
║  5. Copy the JS block (Section 15) into every page                  ║
║  6. Page-specific styles go in a separate <style> block             ║
╚══════════════════════════════════════════════════════════════════════╝

GOOGLE FONTS — paste into every <head> before the CSS link:

<link href="https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800;900&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Lora:ital,wght@1,400;1,500&display=swap" rel="stylesheet">

*/


/* ═══════════════════════════════════════════════════════════════════
   1. DESIGN TOKENS
═══════════════════════════════════════════════════════════════════ */
:root {

  /* Brand colours */
  --teal:       #1A879C;
  --teal-dark:  #0f5f70;
  --teal-mid:   #2fa3ba;
  --lime:       #9EDC39;
  --lime-dark:  #78b82a;

  /* Text */
  --ink:        #0a1929;
  --ink-mid:    #2d4a5c;
  --ink-light:  #6b8fa0;

  /* Glass opacity layers */
  --g-white-96: rgba(255,255,255,0.96);
  --g-white-90: rgba(255,255,255,0.90);
  --g-white-82: rgba(255,255,255,0.82);
  --g-white-72: rgba(255,255,255,0.72);
  --g-white-55: rgba(255,255,255,0.55);

  /* Glass borders */
  --border-glass:  rgba(255,255,255,0.92);
  --border-strong: rgba(255,255,255,0.97);
  --border-teal:   rgba(26,135,156,0.18);

  /* Backdrop blur levels */
  --blur-xl: blur(48px) saturate(200%) brightness(1.04);
  --blur-lg: blur(32px) saturate(180%) brightness(1.02);
  --blur-md: blur(20px) saturate(160%);
  --blur-sm: blur(12px) saturate(140%);

  /* Shadows */
  --sh-card:  0 8px 32px rgba(13,31,46,0.08), 0 2px 8px rgba(13,31,46,0.04), inset 0 1px 0 rgba(255,255,255,0.95);
  --sh-float: 0 20px 60px rgba(26,135,156,0.16), 0 6px 20px rgba(13,31,46,0.06), inset 0 1px 0 rgba(255,255,255,0.9);
  --sh-hover: 0 32px 80px rgba(26,135,156,0.22), 0 10px 30px rgba(13,31,46,0.08), inset 0 1px 0 rgba(255,255,255,0.95);
  --sh-btn:   0 4px 16px rgba(26,135,156,0.35), inset 0 1px 0 rgba(255,255,255,0.18);

  /* Border radii */
  --r-xl: 24px;
  --r-lg: 18px;
  --r-md: 14px;
  --r-sm: 10px;

  /* Fonts */
  --fh: 'Plus Jakarta Sans', sans-serif;  /* Headings */
  --fb: 'DM Sans', sans-serif;            /* Body */
  --fq: 'Lora', serif;                    /* Quotes */
}


/* ═══════════════════════════════════════════════════════════════════
   2. RESET & BASE
═══════════════════════════════════════════════════════════════════ */
*,*::before,*::after { box-sizing:border-box;margin:0;padding:0; }
html { scroll-behavior:smooth; }
body {
  font-family: var(--fb);
  color: var(--ink);
  overflow-x: hidden;
  line-height: 1.65;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  background: #e4f3f8;
}
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:rgba(255,255,255,0.25); }
::-webkit-scrollbar-thumb { background:rgba(26,135,156,0.45);border-radius:3px; }


/* ═══════════════════════════════════════════════════════════════════
   3. PAGE BACKGROUND
   Requires: <div class="page-bg"></div> as first child of <body>
═══════════════════════════════════════════════════════════════════ */
.page-bg {
  position: fixed; inset: 0; z-index: -2;
  background:
    radial-gradient(ellipse 900px 700px at -10%  -5%, rgba(26,135,156,0.12) 0%, transparent 55%),
    radial-gradient(ellipse 700px 600px at  110%  5%, rgba(158,220,57,0.07) 0%, transparent 55%),
    radial-gradient(ellipse 600px 500px at  100% 60%, rgba(26,135,156,0.08) 0%, transparent 55%),
    radial-gradient(ellipse 500px 400px at   10% 90%, rgba(158,220,57,0.05) 0%, transparent 55%),
    radial-gradient(ellipse 400px 300px at   55% 45%, rgba(26,135,156,0.04) 0%, transparent 55%),
    linear-gradient(150deg, #daeef8 0%, #e0f4ec 30%, #d8eef8 65%, #e2f2f0 100%);
  animation: meshDrift 25s ease-in-out infinite alternate;
}
@keyframes meshDrift {
  0%   { filter:hue-rotate(0deg); }
  100% { filter:hue-rotate(8deg); }
}

/* Floating particles
   Requires: <div class="particles"> with 8× <div class="particle"></div> */
.particles { position:fixed;inset:0;z-index:-1;pointer-events:none;overflow:hidden; }
.particle {
  position: absolute; border-radius: 50%;
  background: radial-gradient(circle, rgba(26,135,156,0.55) 0%, transparent 70%);
  animation: floatParticle linear infinite;
}
.particle:nth-child(1) { width:6px;height:6px;left:12%;top:70%;animation-duration:18s;animation-delay:0s; }
.particle:nth-child(2) { width:4px;height:4px;left:30%;top:40%;animation-duration:22s;animation-delay:-5s; }
.particle:nth-child(3) { width:5px;height:5px;left:55%;top:80%;animation-duration:16s;animation-delay:-8s; }
.particle:nth-child(4) { width:3px;height:3px;left:75%;top:20%;animation-duration:24s;animation-delay:-3s; }
.particle:nth-child(5) { width:7px;height:7px;left:88%;top:60%;animation-duration:20s;animation-delay:-10s; }
.particle:nth-child(6) { width:4px;height:4px;left:20%;top:15%;animation-duration:26s;animation-delay:-15s;background:radial-gradient(circle,rgba(158,220,57,0.5) 0%,transparent 70%); }
.particle:nth-child(7) { width:5px;height:5px;left:65%;top:55%;animation-duration:19s;animation-delay:-7s;background:radial-gradient(circle,rgba(158,220,57,0.4) 0%,transparent 70%); }
.particle:nth-child(8) { width:3px;height:3px;left:42%;top:25%;animation-duration:21s;animation-delay:-12s; }
@keyframes floatParticle {
  0%   { transform:translateY(0) translateX(0) scale(1); opacity:0; }
  10%  { opacity:1; }
  90%  { opacity:0.6; }
  100% { transform:translateY(-120vh) translateX(40px) scale(0.5); opacity:0; }
}


/* ═══════════════════════════════════════════════════════════════════
   4. GLASS CARD TIERS
═══════════════════════════════════════════════════════════════════ */

/* Strong — hero dashboard, important overlays */
.glass-card-strong {
  background: var(--g-white-96);
  backdrop-filter: var(--blur-xl);
  -webkit-backdrop-filter: var(--blur-xl);
  border: 1px solid var(--border-strong);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-float);
}

/* Standard — most content cards */
.glass-card {
  background: var(--g-white-82);
  backdrop-filter: var(--blur-lg);
  -webkit-backdrop-filter: var(--blur-lg);
  border: 1px solid var(--border-glass);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-card);
}

/* Subtle — background panels, industry tiles */
.glass-card-subtle {
  background: var(--g-white-72);
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border: 1px solid rgba(255,255,255,0.82);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-card);
}

/* Teal-tinted — highlighted/featured panels */
.glass-card-teal {
  background: linear-gradient(145deg, rgba(26,135,156,0.08), var(--g-white-82));
  backdrop-filter: var(--blur-md);
  -webkit-backdrop-filter: var(--blur-md);
  border: 1px solid var(--border-teal);
  border-radius: var(--r-xl);
  box-shadow: var(--sh-card);
}

/* Dark glass — CTA sections, featured cards */
.glass-card-dark {
  background: linear-gradient(145deg, rgba(10,25,41,0.88), rgba(13,80,100,0.85));
  backdrop-filter: var(--blur-xl);
  -webkit-backdrop-filter: var(--blur-xl);
  border: 1px solid rgba(26,135,156,0.35);
  border-radius: var(--r-xl);
  box-shadow: 0 32px 80px rgba(13,31,46,0.22), inset 0 1px 0 rgba(255,255,255,0.1);
}


/* ═══════════════════════════════════════════════════════════════════
   5. UNIVERSAL HOVER CARD EFFECT  (.ch)
   Add class="ch" to any card for: lift + teal-to-lime bottom sweep line
═══════════════════════════════════════════════════════════════════ */
.ch {
  position: relative; overflow: hidden;
  transition: transform 0.25s ease, box-shadow 0.25s ease;
}
.ch::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2.5px;
  background: linear-gradient(90deg, var(--teal), var(--lime));
  border-radius: 2px;
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.3s ease;
  box-shadow: 0 0 8px rgba(158,220,57,0.5);
}
.ch:hover::after { transform: scaleX(1); }
.ch:hover { transform: translateY(-5px); box-shadow: var(--sh-hover); }


/* ═══════════════════════════════════════════════════════════════════
   6. NAVIGATION
═══════════════════════════════════════════════════════════════════ */
nav {
  position: fixed; top: 12px; left: 50%; transform: translateX(-50%);
  width: calc(100% - 48px); max-width: 1240px;
  z-index: 1000; height: 60px;
  display: flex; align-items: center; padding: 0 24px; justify-content: space-between;
  background: #edf8fc;
  backdrop-filter: blur(40px) saturate(200%);
  -webkit-backdrop-filter: blur(40px) saturate(200%);
  border: 1px solid rgba(26,135,156,0.14);
  border-radius: 18px;
  box-shadow: 0 4px 24px rgba(26,135,156,0.10), inset 0 1px 0 rgba(255,255,255,0.95), 0 0 0 1px rgba(26,135,156,0.05);
  transition: box-shadow 0.3s, background 0.3s;
}
nav.scrolled {
  box-shadow: 0 8px 40px rgba(26,135,156,0.15), inset 0 1px 0 rgba(255,255,255,0.95);
  background: #e8f6fb;
}

.logo { display:flex;align-items:center;gap:10px;text-decoration:none; }
.logo-mark {
  width:34px;height:34px;
  background: linear-gradient(145deg,var(--teal-mid),var(--teal-dark));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-family:var(--fh);font-weight:800;font-size:0.95rem;color:#fff;
  box-shadow: 0 3px 12px rgba(26,135,156,0.4), inset 0 1px 0 rgba(255,255,255,0.22);
}
.logo-text { font-family:var(--fh);font-size:1.05rem;font-weight:700;color:var(--ink);letter-spacing:-0.01em; }
.logo-text span { color:var(--teal); }

/* Nav links with lime underline sweep */
.nav-links { display:flex;gap:1px;list-style:none;align-items:center; }
.nav-links>li>a {
  color:var(--ink-mid); text-decoration:none;
  font-size:0.96rem; font-weight:500;
  padding:6px 12px 7px; border-radius:10px;
  transition:color 0.2s, background 0.2s;
  display:flex; align-items:center; gap:4px;
  position:relative; overflow:hidden;
}
.nav-links>li>a::after {
  content:'';
  position:absolute; bottom:2px; left:12px; right:12px; height:2px;
  background: linear-gradient(90deg, var(--lime), var(--teal));
  border-radius:2px;
  transform:scaleX(0); transform-origin:left;
  transition:transform 0.25s ease;
  box-shadow:0 0 6px rgba(158,220,57,0.5);
}
.nav-links>li>a:hover { color:var(--teal); background:rgba(26,135,156,0.07); }
.nav-links>li>a:hover::after { transform:scaleX(1); }

.nav-right { display:flex;align-items:center;gap:12px; }
.nav-cta {
  background: linear-gradient(145deg,var(--teal),var(--teal-dark));
  color:#fff; padding:8px 18px; border-radius:var(--r-md);
  font-size:0.84rem; font-weight:600; text-decoration:none;
  box-shadow:var(--sh-btn);
  transition:transform 0.15s, box-shadow 0.2s, filter 0.2s;
}
.nav-cta:hover { transform:translateY(-1px);filter:brightness(1.06);box-shadow:0 6px 24px rgba(26,135,156,0.45); }

.nav-hamburger { display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:6px; }
.nav-hamburger span { display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:all 0.25s; }

/* Mega dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown>a::after { content:"⌄";font-size:0.6rem;opacity:0.4;margin-left:2px;display:inline-block;transition:transform 0.2s; }
.nav-dropdown:hover>a::after { transform:rotate(-180deg); }
.mega-menu {
  visibility:hidden;opacity:0;pointer-events:none;
  position:absolute;top:100%;left:50%;
  transform:translateX(-50%);
  padding-top:10px;
  transition:opacity 0.18s,visibility 0.18s;
  z-index:999;min-width:740px;
}
.nav-dropdown:hover .mega-menu,
.nav-dropdown:focus-within .mega-menu { visibility:visible;opacity:1;pointer-events:auto; }

/* Wrapper creates the animated gradient border via padding trick */
.mega-inner-wrap {
  position: relative;
  border-radius: 0 0 var(--r-xl) var(--r-xl);
  padding: 2px;
  background: rgba(26,135,156,0.25); /* base border colour */
  box-shadow: 0 24px 60px rgba(13,31,46,0.14);
}
/* Animated gradient border — sweeps teal→lime→teal around all 4 sides */
.mega-inner-wrap::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, var(--teal), var(--lime), var(--teal));
  background-size: 200% 100%;
  background-position: 100% 0;
  transition: background-position 0.55s ease;
  z-index: 0;
}
.nav-dropdown:hover .mega-inner-wrap::before,
.nav-dropdown:focus-within .mega-inner-wrap::before {
  background-position: 0% 0;
}

.mega-inner {
  background: #f0fafd;
  backdrop-filter: blur(44px) saturate(200%);
  -webkit-backdrop-filter: blur(44px) saturate(200%);
  border-radius: 0 0 calc(var(--r-xl) - 2px) calc(var(--r-xl) - 2px);
  display: flex; overflow: hidden;
  position: relative;
  z-index: 1;
}
.mega-col-main { flex:1;padding:20px 22px; }
.mega-heading { display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:11px;border-bottom:1px solid rgba(26,135,156,0.12); }
.mega-heading-icon { font-size:1.1rem; }
.mega-heading-title { font-size:0.84rem;font-weight:700;color:var(--ink); }
.mega-heading-sub { font-size:0.67rem;color:var(--ink-light);margin-top:1px; }
.mega-grid { display:grid;grid-template-columns:1fr 1fr 1fr;gap:2px; }

/* Mega menu tiles — same green sweep line as .ch cards */
.mega-item {
  display:flex;align-items:flex-start;gap:9px;
  padding:8px 10px;border-radius:10px;text-decoration:none;
  border:1px solid transparent;
  position:relative;overflow:hidden;
  transition:background 0.18s,border-color 0.18s,transform 0.22s,box-shadow 0.22s;
}
.mega-item::after {
  content:'';
  position:absolute;bottom:0;left:0;right:0;height:2.5px;
  background:linear-gradient(90deg,var(--teal),var(--lime));
  border-radius:2px;
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.28s ease;
  box-shadow:0 0 6px rgba(158,220,57,0.45);
}
.mega-item:hover { background:rgba(26,135,156,0.08);border-color:rgba(26,135,156,0.18);transform:translateY(-2px);box-shadow:0 4px 12px rgba(26,135,156,0.1); }
.mega-item:hover::after { transform:scaleX(1); }
.mega-item-icon { font-size:0.88rem;flex-shrink:0;width:20px;text-align:center;margin-top:2px; }
.mega-item-title { font-size:0.78rem;font-weight:600;color:var(--ink);margin-bottom:1px;line-height:1.2; }
.mega-item-desc { font-size:0.67rem;color:var(--ink-light);line-height:1.3; }
.mega-item:hover .mega-item-title { color:var(--teal); }

.mega-col-cta { width:186px;flex-shrink:0;padding:18px 14px;background:#e8f6fb;border-left:1px solid rgba(26,135,156,0.1);display:flex;flex-direction:column;gap:12px; }
.mega-cta-card {
  background:rgba(255,255,255,0.88);border:1px solid rgba(255,255,255,0.97);
  border-radius:14px;padding:14px;backdrop-filter:blur(10px);
  position:relative;overflow:hidden;
  transition:transform 0.18s,box-shadow 0.18s,border-color 0.18s;
}
.mega-cta-card::after {
  content:'';position:absolute;bottom:0;left:0;right:0;height:2.5px;
  background:linear-gradient(90deg,var(--teal),var(--lime));border-radius:2px;
  transform:scaleX(0);transform-origin:left;transition:transform 0.3s ease;
  box-shadow:0 0 6px rgba(158,220,57,0.45);
}
.mega-cta-card:hover { transform:translateY(-2px);box-shadow:0 8px 20px rgba(26,135,156,0.12);border-color:rgba(26,135,156,0.2); }
.mega-cta-card:hover::after { transform:scaleX(1); }
.mega-cta-icon { font-size:1.1rem;margin-bottom:6px;display:block; }
.mega-cta-title { font-size:0.79rem;font-weight:700;color:var(--ink);margin-bottom:4px;line-height:1.3; }
.mega-cta-text { font-size:0.67rem;color:var(--ink-light);line-height:1.5;margin-bottom:9px; }
.mega-cta-btn {
  display:inline-block;background:linear-gradient(145deg,var(--teal),var(--teal-dark));
  color:#fff;padding:5px 11px;border-radius:8px;
  font-size:0.72rem;font-weight:600;text-decoration:none;
  box-shadow:0 2px 8px rgba(26,135,156,0.28);
}
.mega-cta-btn:hover { filter:brightness(1.06); }
.mega-all-link { font-size:0.73rem;font-weight:600;color:var(--teal);text-decoration:none;transition:opacity 0.15s; }
.mega-all-link:hover { opacity:0.7; }


/* ═══════════════════════════════════════════════════════════════════
   7. TYPOGRAPHY
═══════════════════════════════════════════════════════════════════ */
h1,h2,h3,h4,h5,h6 { font-family:var(--fh);color:var(--ink);line-height:1.12; }
h2 { font-size:clamp(1.8rem,2.6vw,2.5rem);font-weight:800;letter-spacing:-0.025em;margin-bottom:12px; }

/* Section tag — small uppercase label above headings */
.stag {
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--fh);font-size:0.68rem;font-weight:700;
  letter-spacing:0.12em;text-transform:uppercase;
  color:var(--teal);margin-bottom:14px;
}
.stag::before { content:'';width:16px;height:2px;background:linear-gradient(90deg,var(--teal),var(--lime));border-radius:1px; }

/* Lead paragraph under headings */
.lead { font-size:1rem;color:var(--ink-mid);line-height:1.8;margin-bottom:44px;max-width:540px; }

/* Pulsing glow dot — for live status indicators */
.pulse-dot { width:6px;height:6px;border-radius:50%;background:var(--teal);box-shadow:0 0 8px rgba(26,135,156,0.8);animation:pulseGlow 2s ease-in-out infinite;display:inline-block; }
.pulse-dot-lime { background:var(--lime-dark);box-shadow:0 0 8px rgba(122,184,44,0.8); }
@keyframes pulseGlow {
  0%,100% { box-shadow:0 0 4px rgba(26,135,156,0.6);opacity:1; }
  50%      { box-shadow:0 0 12px rgba(26,135,156,1);opacity:0.6; }
}


/* ═══════════════════════════════════════════════════════════════════
   8. BUTTONS
═══════════════════════════════════════════════════════════════════ */

/* Primary — teal gradient */
.btn-primary {
  background:linear-gradient(145deg,var(--teal),var(--teal-dark));
  color:#fff;padding:13px 26px;border-radius:var(--r-md);
  text-decoration:none;font-weight:600;font-size:0.9rem;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:var(--sh-btn);
  transition:transform 0.15s,box-shadow 0.2s,filter 0.2s;
  position:relative;overflow:hidden;
}
.btn-primary::before { content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,0.15),transparent);border-radius:inherit; }
.btn-primary:hover { transform:translateY(-2px);box-shadow:0 8px 28px rgba(26,135,156,0.45);filter:brightness(1.05); }

/* Glass outline — light backgrounds (page sections) */
.btn-outline {
  background:rgba(255,255,255,0.82);color:var(--ink);
  padding:13px 26px;border-radius:var(--r-md);
  text-decoration:none;font-weight:600;font-size:0.9rem;
  border:1px solid rgba(255,255,255,0.94);
  backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm);
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 2px 8px rgba(13,31,46,0.05),inset 0 1px 0 rgba(255,255,255,0.95);
  transition:all 0.2s;
}
.btn-outline:hover { background:rgba(255,255,255,0.95);border-color:rgba(26,135,156,0.25);color:var(--teal);box-shadow:0 4px 16px rgba(26,135,156,0.12),inset 0 1px 0 rgba(255,255,255,0.98); }

/* Glass outline — dark hero backgrounds only */
.btn-outline-hero {
  background:rgba(255,255,255,0.09);color:rgba(255,255,255,0.88);
  padding:13px 26px;border-radius:var(--r-md);
  text-decoration:none;font-weight:600;font-size:0.9rem;
  border:1px solid rgba(255,255,255,0.18);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  display:inline-flex;align-items:center;gap:8px;
  transition:all 0.2s;
}
.btn-outline-hero:hover { border-color:rgba(255,255,255,0.38);background:rgba(255,255,255,0.14);color:#fff; }

/* Lime CTA */
.btn-lime {
  background:linear-gradient(145deg,var(--lime),var(--lime-dark));
  color:var(--ink);padding:13px 28px;border-radius:var(--r-md);
  text-decoration:none;font-family:var(--fh);font-weight:700;font-size:0.9rem;
  display:inline-flex;align-items:center;gap:8px;
  box-shadow:0 4px 20px rgba(158,220,57,0.4),inset 0 1px 0 rgba(255,255,255,0.2);
  transition:transform 0.15s,box-shadow 0.2s,filter 0.2s;
  position:relative;overflow:hidden;
}
.btn-lime::before { content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(255,255,255,0.15),transparent);border-radius:inherit; }
.btn-lime:hover { transform:translateY(-2px);box-shadow:0 8px 30px rgba(158,220,57,0.5);filter:brightness(1.05); }

/* White outline — for dark backgrounds */
.btn-outline-w {
  background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.8);
  padding:13px 28px;border-radius:var(--r-md);
  text-decoration:none;font-weight:600;font-size:0.9rem;
  border:1px solid rgba(255,255,255,0.2);
  backdrop-filter:blur(12px);
  display:inline-flex;align-items:center;gap:8px;
  transition:all 0.2s;
}
.btn-outline-w:hover { border-color:rgba(255,255,255,0.45);background:rgba(255,255,255,0.15);color:#fff; }


/* ═══════════════════════════════════════════════════════════════════
   9. LAYOUT UTILITIES
═══════════════════════════════════════════════════════════════════ */
.container { max-width:1200px;margin:0 auto;padding:0 48px; }
section { padding:96px 0;position:relative; }

/* Alternate section background — slightly tinted */
.s-tinted { position:relative; }
.s-tinted::before { content:'';position:absolute;inset:0;background:rgba(255,255,255,0.25);backdrop-filter:blur(2px);pointer-events:none; }
.s-tinted > .container { position:relative;z-index:1; }

/* Thin divider line between sections */
.section-rule { height:1px;background:linear-gradient(90deg,transparent,rgba(26,135,156,0.2),transparent);margin:0 48px; }

/* Scroll-in reveal animation — triggered by JS IntersectionObserver */
.reveal { opacity:1;transform:none;transition:opacity 0.65s ease,transform 0.65s ease; }
.reveal.js-ready { opacity:0;transform:translateY(24px); }
.reveal.visible { opacity:1;transform:none; }
.r1 { transition-delay:100ms; }
.r2 { transition-delay:200ms; }
.r3 { transition-delay:300ms; }


/* ═══════════════════════════════════════════════════════════════════
   10. TRUST BAR
═══════════════════════════════════════════════════════════════════ */
.trust-bar { padding:0 48px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap; }
.trust-bar-inner {
  max-width:1100px;width:100%;
  background:rgba(13,25,41,0.82);
  backdrop-filter:var(--blur-lg);-webkit-backdrop-filter:var(--blur-lg);
  border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--r-lg);
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  margin:0 auto;box-shadow:0 4px 24px rgba(13,31,46,0.18);
}
.trust-item { display:flex;align-items:center;gap:8px;font-size:0.74rem;color:rgba(255,255,255,0.55);font-weight:500;padding:13px 22px;border-right:1px solid rgba(255,255,255,0.07); }
.trust-item:last-child { border-right:none; }
.trust-dot { width:5px;height:5px;border-radius:50%;background:var(--lime);box-shadow:0 0 6px rgba(158,220,57,0.7);flex-shrink:0; }


/* ═══════════════════════════════════════════════════════════════════
   11. BADGES & PILLS
═══════════════════════════════════════════════════════════════════ */
.hero-pill {
  display:inline-flex;align-items:center;gap:7px;
  background:rgba(26,135,156,0.1);border:1px solid rgba(26,135,156,0.28);
  backdrop-filter:blur(12px);color:var(--teal);
  font-size:0.68rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  padding:5px 14px;border-radius:30px;margin-bottom:22px;
}
.badge-lime { background:linear-gradient(135deg,var(--lime),#b5e84d);color:var(--ink);font-size:0.64rem;font-weight:800;letter-spacing:0.06em;padding:3px 10px;border-radius:20px;box-shadow:0 2px 8px rgba(158,220,57,0.35);display:inline-flex;align-items:center; }
.badge-teal { background:rgba(26,135,156,0.1);color:var(--teal);font-size:0.64rem;font-weight:700;border:1px solid rgba(26,135,156,0.22);padding:3px 10px;border-radius:20px; }
.badge-green { background:rgba(158,220,57,0.15);color:var(--lime-dark);font-size:0.59rem;font-weight:700;border:1px solid rgba(158,220,57,0.3);padding:2px 7px;border-radius:20px; }
.tag-chip { font-size:0.64rem;font-weight:600;padding:3px 8px;border-radius:20px;background:rgba(255,255,255,0.75);border:1px solid rgba(255,255,255,0.92);color:var(--ink-mid);backdrop-filter:blur(6px); }
.tag-chip-dark { background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.2);color:rgba(255,255,255,0.6); }


/* ═══════════════════════════════════════════════════════════════════
   12. FOOTER
═══════════════════════════════════════════════════════════════════ */
footer { background:rgba(8,18,30,0.92);backdrop-filter:var(--blur-xl);-webkit-backdrop-filter:var(--blur-xl);border-top:1px solid rgba(26,135,156,0.2);color:rgba(255,255,255,0.33);font-size:0.83rem; }
.footer-top { max-width:1200px;margin:0 auto;padding:52px 48px 40px;display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:44px; }
.footer-brand p { font-size:0.82rem;color:rgba(255,255,255,0.35);line-height:1.8;max-width:245px;margin:14px 0 16px; }
.footer-social { display:flex;gap:7px; }
.fsoc { width:30px;height:30px;border-radius:8px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;font-size:0.76rem;text-decoration:none;color:rgba(255,255,255,0.45);transition:all 0.2s; }
.fsoc:hover { background:rgba(26,135,156,0.2);color:var(--lime);border-color:rgba(26,135,156,0.35); }
.footer-col h5 { font-family:var(--fh);font-size:0.7rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-bottom:13px; }
.footer-col ul { list-style:none;display:flex;flex-direction:column;gap:8px; }
.footer-col ul li a { color:rgba(255,255,255,0.3);text-decoration:none;font-size:0.81rem;display:flex;align-items:center;gap:6px;transition:color 0.2s; }
.footer-col ul li a::before { content:'';width:3px;height:3px;border-radius:50%;background:rgba(255,255,255,0.15);flex-shrink:0;transition:background 0.2s; }
.footer-col ul li a:hover { color:var(--lime); }
.footer-col ul li a:hover::before { background:var(--lime); }
.footer-bottom { border-top:1px solid rgba(255,255,255,0.06);padding:17px 48px;max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:11px; }
.footer-bl { display:flex;align-items:center;gap:13px;flex-wrap:wrap; }
.footer-cert { display:inline-flex;align-items:center;gap:5px;background:rgba(158,220,57,0.08);border:1px solid rgba(158,220,57,0.2);color:var(--lime);font-size:0.65rem;font-weight:700;padding:3px 8px;border-radius:20px;letter-spacing:0.04em; }
.footer-br { display:flex;gap:17px; }
.footer-br a { color:rgba(255,255,255,0.2);text-decoration:none;font-size:0.74rem;transition:color 0.2s; }
.footer-br a:hover { color:rgba(255,255,255,0.5); }


/* ═══════════════════════════════════════════════════════════════════
   13. SUB-PAGE HERO SYSTEM  ✦ LOCKED DESIGN ✦
   Dark full-bleed glass hero with gradient headline + floating stat chips.
   Used on ALL sub-pages: About, Services, Security, Industries, Contact, etc.

   ─── REQUIRED HTML STRUCTURE ─────────────────────────────────────────
   Copy this block to every sub-page. Edit badge label, h1, lead text,
   and the .page-hero-stats chips to match the page. Keep all class names.

   <div class="page-hero">
     <div class="page-hero-orb"></div>
     <div class="page-hero-grid"></div>
     <div class="page-hero-inner">

       <div class="breadcrumb">
         <a href="index.html">Home</a>
         <span>›</span>
         <span>Page Name</span>
       </div>

       <div class="page-badge">
         <span class="page-badge-dot"></span>Section Label
       </div>

       <h1>First line of heading.<br><em>Gradient second line.</em></h1>

       <p class="lead">One or two sentences describing this page.</p>

       <div class="page-hero-stats">
         <div class="hero-chip">
           <span class="hero-chip-num">Stat</span>
           <span class="hero-chip-lbl">Label text</span>
         </div>
         <div class="hero-chip-divider"></div>
         <div class="hero-chip">
           <span class="hero-chip-num">Stat</span>
           <span class="hero-chip-lbl">Label text</span>
         </div>
         <!-- Add hero-chip-iso class for the ISO/cert chip -->
         <div class="hero-chip hero-chip-iso">
           <span class="hero-chip-num">🛡️ ISO 27001</span>
           <span class="hero-chip-lbl">Certified & audited annually</span>
         </div>
       </div>

     </div>
   </div>

   ─── REQUIRED DIVIDER (goes immediately after .page-hero closing tag) ──
   <div class="hero-divider"></div>

   ─── REQUIRED CSS in each sub-page <style> block (copy exactly) ─────
   (Full nav CSS — must be included on every sub-page for solid background)

   nav {
     position:fixed;top:12px;left:50%;transform:translateX(-50%);
     width:calc(100% - 48px);max-width:1240px;
     z-index:1000;height:60px;
     display:flex;align-items:center;
     padding:0 24px;justify-content:space-between;
     background: #edf8fc;
     backdrop-filter: blur(40px) saturate(200%);
     -webkit-backdrop-filter: blur(40px) saturate(200%);
     border: 1px solid rgba(26,135,156,0.14);
     border-radius: 18px;
     box-shadow: 0 4px 24px rgba(26,135,156,0.10), 0 1px 0 rgba(255,255,255,0.95) inset, 0 0 0 1px rgba(26,135,156,0.05);
     transition: box-shadow 0.3s, background 0.3s;
   }
   nav.scrolled {
     box-shadow: 0 8px 40px rgba(26,135,156,0.15), 0 1px 0 rgba(255,255,255,0.95) inset;
     background: #e8f6fb;
   }
═══════════════════════════════════════════════════════════════════ */

/* ─── Page Hero ─────────────────────────────────────────────────── */
.page-hero {
  padding-top: 72px;
  position: relative;
  overflow: hidden;
  height: 580px;
  min-height: 580px;
  display: flex;
  align-items: center;
}

/* Full dark glass backdrop */
.page-hero::before {
  content: '';
  position: absolute; inset: 0;
  background: linear-gradient(145deg, rgba(8,22,38,0.82) 0%, rgba(10,60,76,0.75) 100%);
  backdrop-filter: blur(2px);
  z-index: 0;
}

/* Teal orb — top right */
.page-hero::after {
  content: '';
  position: absolute;
  top: -120px; right: -80px;
  width: 560px; height: 560px;
  background: radial-gradient(circle, rgba(26,135,156,0.35) 0%, transparent 65%);
  pointer-events: none; z-index: 0;
}

/* Lime orb — bottom left (separate element) */
.page-hero-orb {
  position: absolute;
  bottom: -100px; left: -60px;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(158,220,57,0.18) 0%, transparent 65%);
  pointer-events: none; z-index: 0;
}

/* Subtle circuit grid texture */
.page-hero-grid {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background-image:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 48px 48px;
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 20%, transparent 100%);
}

/* Content wrapper */
.page-hero-inner {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  padding: 64px 48px 68px;
  position: relative; z-index: 2;
}

/* Breadcrumb */
.breadcrumb {
  font-size: 0.78rem; color: rgba(255,255,255,0.45);
  margin-bottom: 20px;
  display: flex; align-items: center; gap: 8px;
}
.breadcrumb a { color: rgba(255,255,255,0.65); text-decoration: none; transition: color 0.2s; }
.breadcrumb a:hover { color: var(--lime); }
.breadcrumb span:first-of-type { opacity: 0.35; }
.breadcrumb span:last-of-type { color: rgba(255,255,255,0.9); opacity: 1; font-weight: 500; }

/* Pulsing lime badge pill */
.page-badge {
  display: inline-flex; align-items: center; gap: 8px;
  background: rgba(158,220,57,0.12);
  border: 1px solid rgba(158,220,57,0.3);
  color: var(--lime);
  font-family: var(--fh); font-size: 0.67rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 5px 14px; border-radius: 30px;
  margin-bottom: 24px;
}
.page-badge-dot {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 8px rgba(158,220,57,0.9);
  animation: pulseGlow 2s ease-in-out infinite;
}

/* Giant heading — second line renders as lime-to-teal gradient text */
.page-hero h1 {
  font-family: var(--fh);
  font-size: clamp(3rem, 5.5vw, 5.2rem);
  font-weight: 800; color: #fff;
  letter-spacing: -0.04em; line-height: 0.98;
  margin-bottom: 28px;
  max-width: 780px;
}
.page-hero h1 em {
  font-style: normal;
  display: block;
  background: linear-gradient(90deg, var(--lime) 0%, var(--teal-mid) 60%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}

/* Lead paragraph */
.page-hero .lead {
  font-size: 1.05rem; color: rgba(255,255,255,0.62);
  line-height: 1.85; max-width: 560px;
  margin-bottom: 44px;
}

/* Floating stat chips */
.page-hero-stats {
  display: flex; align-items: center;
  gap: 12px; flex-wrap: wrap;
}
.hero-chip {
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(20px); -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: 50px; padding: 10px 18px;
  transition: background 0.2s, border-color 0.2s, transform 0.2s;
}
.hero-chip:hover {
  background: rgba(255,255,255,0.13);
  border-color: rgba(26,135,156,0.45);
  transform: translateY(-2px);
}
.hero-chip-num {
  font-family: var(--fh); font-size: 1.25rem; font-weight: 800;
  color: var(--lime); line-height: 1;
}
.hero-chip-lbl {
  font-size: 0.75rem; color: rgba(255,255,255,0.55);
  line-height: 1.3; max-width: 90px;
}
.hero-chip-divider {
  width: 1px; height: 32px;
  background: rgba(255,255,255,0.12); flex-shrink: 0;
}
/* ISO / certification chip variant */
.hero-chip-iso {
  background: rgba(26,135,156,0.15);
  border-color: rgba(26,135,156,0.3);
}
.hero-chip-iso .hero-chip-num {
  font-size: 0.82rem; color: rgba(255,255,255,0.9);
  display: flex; align-items: center; gap: 6px;
}

/* ─── Hero Divider (place immediately after .page-hero closing tag) ── */
.hero-divider {
  height: 3px;
  background: linear-gradient(90deg, transparent 0%, var(--teal) 20%, var(--lime) 55%, var(--teal) 80%, transparent 100%);
  box-shadow: 0 0 16px rgba(26,135,156,0.35), 0 0 32px rgba(158,220,57,0.2);
  position: relative;
  z-index: 10;
  display: block;
}

/* ─── Responsive ─────────────────────────────────────────────────── */
@media(max-width:1024px) {
  .page-hero-inner { padding: 52px 32px 56px; }
  .page-hero h1 { font-size: clamp(2.6rem, 5vw, 4rem); }
}
@media(max-width:768px) {
  .page-hero { height: auto; min-height: 480px; }
  .page-hero-inner { padding: 44px 20px 48px; }
  .page-hero h1 { font-size: clamp(2.2rem, 7vw, 3rem); }
  .page-hero-stats { gap: 8px; }
  .hero-chip-divider { display: none; }
}


/* ═══════════════════════════════════════════════════════════════════
   14. INDEX PAGE HERO — DARK GLASS VARIANT
   Applied to the main homepage hero only.
   Sub-pages use Section 13 (.page-hero).
   Index page uses .hero with the same dark glass language.

   KEY DIFFERENCES FROM LIGHT HERO:
   — Dark glass backdrop (rgba 8,22,38 → rgba 10,60,76)
   — Hero pill badge: lime instead of teal
   — h1 em line: lime-to-teal gradient text (background-clip)
   — hero-sub, proof-text: white/alpha instead of ink colours
   — btn-outline: dark glass instead of white frosted
   — Dashboard: dark glass cards instead of white frosted
   — hbadge: dark glass instead of white frosted
   — Scroll arrow: white stroke instead of ink
   — Three ambient orb elements added to HTML:
       <div class="hero-orb-lime"></div>
       <div class="hero-orb-mid"></div>
       <div class="hero-grid"></div>
═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════
   15. BACK TO TOP
═══════════════════════════════════════════════════════════════════ */
.back-top {
  position:fixed;bottom:24px;right:24px;z-index:900;
  width:40px;height:40px;border-radius:12px;
  background:rgba(255,255,255,0.7);backdrop-filter:var(--blur-sm);-webkit-backdrop-filter:var(--blur-sm);
  border:1px solid rgba(255,255,255,0.9);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;transform:translateY(10px);
  transition:opacity 0.3s,transform 0.3s,box-shadow 0.2s;
  box-shadow:0 4px 16px rgba(26,135,156,0.2),inset 0 1px 0 rgba(255,255,255,0.9);
  text-decoration:none;
}
.back-top.visible { opacity:1;transform:translateY(0); }
.back-top:hover { box-shadow:0 8px 24px rgba(26,135,156,0.3); }
.back-top svg { stroke:var(--teal); }


/* ═══════════════════════════════════════════════════════════════════
   14. RESPONSIVE
═══════════════════════════════════════════════════════════════════ */
@media(max-width:1024px) {
  nav { width:calc(100% - 32px); }
  .container { padding:0 32px; }
  .trust-bar { padding:0 32px; }
  .section-rule { margin:0 32px; }
  .footer-top { grid-template-columns:1fr 1fr;gap:28px; }
  .footer-brand { grid-column:span 2; }
}
@media(max-width:768px) {
  nav { width:calc(100% - 24px);top:8px;padding:0 16px; }
  .nav-links,.nav-phone { display:none; }
  .nav-hamburger { display:flex; }
  .nav-mobile-open .nav-links {
    display:flex;flex-direction:column;
    position:fixed;top:80px;left:12px;right:12px;
    background:rgba(242,252,255,0.97);
    backdrop-filter:blur(40px);-webkit-backdrop-filter:blur(40px);
    border:1px solid rgba(255,255,255,0.97);
    border-radius:var(--r-xl);padding:20px;gap:4px;
    box-shadow:var(--sh-float);z-index:999;
  }
  .nav-mobile-open .nav-links>li>a { font-size:1rem;padding:12px 14px;border-bottom:1px solid rgba(26,135,156,0.08); }
  section { padding:64px 0; }
  .container { padding:0 20px; }
  .trust-bar { padding:0 20px; }
  .trust-item { padding:9px 12px;font-size:0.7rem; }
  .section-rule { margin:0 20px; }
  .footer-top { grid-template-columns:1fr 1fr;gap:26px;padding:32px 20px 26px; }
  .footer-bottom { padding:13px 20px; }
  .cta-btns { flex-direction:column;align-items:center; }
  .btn-lime,.btn-outline-w { width:100%;max-width:300px;justify-content:center; }
}
@media(max-width:480px) {
  .footer-top { grid-template-columns:1fr;gap:22px; }
  .footer-brand { grid-column:span 1; }
}


/*
═══════════════════════════════════════════════════════════════════
  15. STANDARD PAGE JS
  Copy this <script> block into the bottom of every page <body>
═══════════════════════════════════════════════════════════════════

<script>
// Nav scroll shadow
const nav = document.getElementById('mainNav');
window.addEventListener('scroll',()=>{
  nav.classList.toggle('scrolled',window.scrollY>20);
},{passive:true});

// Scroll reveal — js-ready hides elements first so content shows if JS fails
document.querySelectorAll('.reveal').forEach(el=>el.classList.add('js-ready'));
const obs = new IntersectionObserver((entries)=>{
  entries.forEach(e=>{ if(e.isIntersecting) e.target.classList.add('visible'); });
},{threshold:0.07, rootMargin:'0px 0px -40px 0px'});
document.querySelectorAll('.reveal').forEach(el=>obs.observe(el));

// Mobile hamburger
const nt = document.getElementById('navToggle');
if(nt){
  nt.addEventListener('click',()=>{
    nav.classList.toggle('nav-mobile-open');
    const sp = nt.querySelectorAll('span');
    const op = nav.classList.contains('nav-mobile-open');
    sp[0].style.transform=op?'rotate(45deg) translate(5px,5px)':'';
    sp[1].style.opacity=op?'0':'';
    sp[2].style.transform=op?'rotate(-45deg) translate(5px,-5px)':'';
  });
  document.addEventListener('click',e=>{
    if(!e.target.closest('nav')){
      nav.classList.remove('nav-mobile-open');
      nt.querySelectorAll('span').forEach(s=>{s.style.transform='';s.style.opacity='';});
    }
  });
}

// Back to top
const bt = document.getElementById('backTop');
if(bt){
  window.addEventListener('scroll',()=>{
    bt.classList.toggle('visible',window.scrollY>400);
  },{passive:true});
  bt.addEventListener('click',e=>{ e.preventDefault(); window.scrollTo({top:0,behavior:'smooth'}); });
}
</script>

*/
