/* ============================================================
   NEXORWA — MAIN CSS
   ============================================================ */

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  /* ── NEXORWA ENERGIES BRAND COLORS ── */
  --primary: #0090C8;
  --primary-light: #00AADF;
  --primary-dark: #006E9B;
  --navy: #0A2D4A;
  --navy-mid: #0D3A5E;
  --navy-light: #1A5276;
  --teal-glow: #00C4F0;
  --dark: #07101A;
  --dark2: #0C1B28;
  --dark3: #112233;
  --white: #FFFFFF;
  --muted: #6A8FA8;
  --yellow: #00C4F0;
  --orange: #0090C8;
  --orange-light: #00AADF;
  --heading: 'Barlow Condensed', sans-serif;
  --body: 'Barlow', sans-serif;
  --radius: 12px;
  --transition: 0.25s ease;
}

html { scroll-behavior: smooth; }
body { font-family: var(--body); background: var(--dark); color: var(--white); overflow-x: hidden; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; text-decoration: none; }

/* ── TYPOGRAPHY ── */
h1,h2,h3,h4,h5 { font-family: var(--heading); font-weight: 900; text-transform: uppercase; line-height: 1.05; }
p { line-height: 1.75; }

.section-tag {
  display: inline-block; font-size: .75rem; font-weight: 600;
  letter-spacing: .12em; text-transform: uppercase; color: var(--orange); margin-bottom: .8rem;
}
.section-title { font-size: clamp(2rem, 4vw, 3.2rem); margin-bottom: 1rem; }
.section-title .accent { color: var(--orange); }
.section-title .outline { -webkit-text-stroke: 2px var(--white); color: transparent; }
.section-body { color: #8CB4CC; font-weight: 300; margin-bottom: 1.2rem; }

/* ── BUTTONS ── */
.btn-primary {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--orange); color: var(--white);
  font-family: var(--heading); font-size: 1rem; font-weight: 700;
  letter-spacing: .05em; text-transform: uppercase;
  padding: .85rem 2rem; border-radius: 6px; border: none; cursor: pointer;
  box-shadow: 0 4px 20px rgba(0,144,200,.35);
  transition: transform var(--transition), background var(--transition), box-shadow var(--transition);
}
.btn-primary:hover { background: var(--orange-light); transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,144,200,.45); }
.btn-outline {
  display: inline-flex; align-items: center; gap: .5rem;
  background: transparent; color: var(--white);
  font-family: var(--heading); font-size: 1rem; font-weight: 700;
  letter-spacing: .05em; text-transform: uppercase;
  padding: .85rem 2rem; border-radius: 6px; border: 2px solid rgba(255,255,255,.25); cursor: pointer;
  transition: border-color var(--transition), color var(--transition);
}
.btn-outline:hover { border-color: var(--orange); color: var(--orange); }
.btn-white {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--white); color: var(--navy);
  font-family: var(--heading); font-size: 1rem; font-weight: 800;
  letter-spacing: .05em; text-transform: uppercase;
  padding: .85rem 2.2rem; border-radius: 6px; border: none; cursor: pointer;
  box-shadow: 0 4px 20px rgba(0,0,0,.2);
  transition: transform var(--transition), box-shadow var(--transition);
}
.btn-white:hover { transform: translateY(-2px); box-shadow: 0 8px 30px rgba(0,0,0,.3); }

/* ── NAVBAR ── */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: rgba(15,15,15,.94); backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(0,144,200,.2);
  transition: border-color var(--transition);
}
#navbar.scrolled { border-bottom-color: rgba(0,144,200,.3); }
.nav-inner { display: flex; align-items: center; justify-content: space-between; padding: 0 5%; height: 72px; }
.nav-logo { font-family: var(--heading); font-size: 1.7rem; font-weight: 900; color: var(--white); }
.nav-logo span { color: var(--orange); }
.nav-logo img { height: 40px; width: auto; }
.nav-links { display: flex; gap: 1.8rem; list-style: none; align-items: center; }
.nav-links a { font-size: .85rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: #ccc; transition: color var(--transition); }
.nav-links a:hover, .nav-links a.active { color: var(--orange); }
.nav-cta { background: var(--orange) !important; color: var(--white) !important; padding: .5rem 1.2rem; border-radius: 4px; font-weight: 600 !important; transition: background var(--transition) !important; }
.nav-cta:hover { background: var(--orange-light) !important; color: var(--white) !important; }

.has-dropdown { position: relative; }
.dropdown {
  position: absolute; top: calc(100% + .5rem); left: 0; min-width: 220px;
  background: var(--dark2); border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px; padding: .5rem 0; list-style: none;
  opacity: 0; pointer-events: none; transform: translateY(8px);
  transition: opacity var(--transition), transform var(--transition);
}
.has-dropdown:hover .dropdown { opacity: 1; pointer-events: all; transform: translateY(0); }
.dropdown li a { display: block; padding: .6rem 1.2rem; font-size: .85rem; color: #ccc; transition: color var(--transition), background var(--transition); }
.dropdown li a:hover { color: var(--orange); background: rgba(0,144,200,.06); }

.nav-toggle { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: .5rem; }
.nav-toggle span { display: block; width: 24px; height: 2px; background: var(--white); transition: var(--transition); }

/* ── HERO ── */
/* #hero base — overridden by slideshow rules below */
#hero {
  height: 100vh; min-height: 600px;
  position: relative; overflow: hidden;
  display: block;
}
.hero-bg {
  position: absolute; inset: 0;
  background: radial-gradient(ellipse 70% 60% at 70% 50%, rgba(0,144,200,.2) 0%, transparent 65%),
              radial-gradient(ellipse 40% 50% at 20% 80%, rgba(10,45,74,.8) 0%, transparent 60%),
              var(--dark);
}
.hero-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(0,144,200,.05) 1px,transparent 1px), linear-gradient(90deg,rgba(0,144,200,.05) 1px,transparent 1px);
  background-size: 60px 60px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 80%);
}
.hero-content { position: relative; z-index: 2; max-width: 800px; }
.hero-badge {
  display: inline-flex; align-items: center; gap: .5rem;
  background: rgba(0,144,200,.12); border: 1px solid rgba(0,144,200,.3);
  border-radius: 999px; padding: .35rem 1rem;
  font-size: .78rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--orange-light); margin-bottom: 1.5rem;
  animation: fadeUp .6s ease both;
}
.hero-badge::before { content:''; width:6px; height:6px; border-radius:50%; background:var(--orange); animation: pulse 2s infinite; }
.hero-title {
  font-family: var(--heading); font-size: clamp(3.5rem,9vw,7.5rem); font-weight: 900;
  text-transform: uppercase; line-height: .95; margin-bottom: 1.5rem;
  animation: fadeUp .6s ease .1s both;
}
.hero-sub { font-size: 1.1rem; font-weight: 300; color: #bbb; max-width: 520px; line-height: 1.7; margin-bottom: 2.5rem; animation: fadeUp .6s ease .2s both; }
.hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeUp .6s ease .3s both; }
.hero-stats { display: flex; gap: 3rem; margin-top: 4rem; flex-wrap: wrap; animation: fadeUp .6s ease .4s both; }
.hero-stat-num { font-family: var(--heading); font-size: 2.6rem; font-weight: 900; color: var(--orange); line-height: 1; }
.hero-stat-label { font-size: .8rem; font-weight: 500; letter-spacing: .06em; text-transform: uppercase; color: var(--muted); margin-top: .2rem; }
.hero-scroll { position: absolute; bottom: 2rem; left: 5%; display: flex; align-items: center; gap: .75rem; font-size: .78rem; font-weight: 500; letter-spacing: .1em; text-transform: uppercase; color: var(--muted); animation: fadeUp .6s ease .5s both; }
.scroll-line { width:40px; height:1px; background:var(--orange); position:relative; overflow:hidden; }
.scroll-line::after { content:''; position:absolute; top:0; left:-40px; width:40px; height:1px; background:var(--white); animation: scrollAnim 1.8s ease infinite; }

/* ── PARTNERS ── */
#partners { background: var(--dark2); border-top:1px solid rgba(255,255,255,.05); border-bottom:1px solid rgba(255,255,255,.05); padding:2rem 5%; display:flex; align-items:center; gap:3rem; flex-wrap:wrap; }
.partners-label { font-size:.75rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); white-space:nowrap; }
.partners-logos { display:flex; gap:2.5rem; flex-wrap:wrap; align-items:center; flex:1; }
.partner-name { font-family:var(--heading); font-size:1.1rem; font-weight:700; letter-spacing:.05em; color:rgba(255,255,255,.25); text-transform:uppercase; transition:color var(--transition); }
.partner-name:hover { color:rgba(255,255,255,.6); }

/* ── SECTIONS ── */
.section { padding: 100px 5%; }
.section-dark { background: var(--dark); }
.section-dark2 { background: var(--dark2); }

.section-header { display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:3rem; flex-wrap:wrap; gap:1rem; }

/* ── ABOUT ── */
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.about-img-wrap { position:relative; }
.about-img { width:100%; aspect-ratio:4/3; background:var(--dark3); border-radius:var(--radius); overflow:hidden; }
.about-img img { width:100%; height:100%; object-fit:cover; }
.about-img-placeholder { width:100%; height:100%; background:linear-gradient(135deg,var(--dark3),#2a1a0e); display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.1); font-family:var(--heading); font-size:1.2rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; }
.about-badge { position:absolute; bottom:-1.5rem; right:-1.5rem; background:var(--orange); border-radius:10px; padding:1.2rem 1.5rem; text-align:center; }
.about-badge .num { font-family:var(--heading); font-size:2.5rem; font-weight:900; line-height:1; color:var(--white); }
.about-badge .lbl { font-size:.7rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.8); }
.check-list { list-style:none; margin-bottom:2rem; }
.check-list li { display:flex; align-items:flex-start; gap:.75rem; font-size:.95rem; color:#ccc; margin-bottom:.75rem; }
.check-list li::before { content:'✓'; flex-shrink:0; width:22px; height:22px; background:rgba(0,144,200,.15); border-radius:50%; display:flex; align-items:center; justify-content:center; color:var(--orange); font-size:.75rem; font-weight:700; }

/* ── CARDS ── */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5rem; }
.grid-4 { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }

.card {
  background:var(--dark3); border:1px solid rgba(0,144,200,.12);
  border-radius:var(--radius); overflow:hidden;
  transition:transform .3s, border-color .3s, box-shadow .3s;
}
.card:hover { transform:translateY(-6px); border-color:rgba(0,144,200,.3); box-shadow:0 20px 40px rgba(0,0,0,.4); }
.card-img { width:100%; aspect-ratio:16/9; background:linear-gradient(135deg,#1e1e1e,#2a1a0e); overflow:hidden; position:relative; }
.card-img img { width:100%; height:100%; object-fit:cover; }
.card-img-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:3rem; color:rgba(255,255,255,.1); }
.card-img-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,.6),transparent 60%); }
.card-body { padding:1.4rem; }
.card-cat { font-size:.7rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--orange); margin-bottom:.5rem; }
.card-title { font-family:var(--heading); font-size:1.3rem; font-weight:800; text-transform:uppercase; margin-bottom:.5rem; }
.card-desc { font-size:.88rem; color:#6A8FA8; line-height:1.6; }
.card-link { display:inline-flex; align-items:center; gap:.4rem; margin-top:1rem; font-size:.8rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--orange); transition:gap .2s; }
.card-link:hover { gap:.7rem; }

/* Equipment card (square) */
.equip-card .card-img { aspect-ratio:1; }
.equip-card-type { font-size:.75rem; color:var(--orange); font-weight:600; letter-spacing:.06em; text-transform:uppercase; }

/* Training card */
.training-card { padding:2rem; }
.training-icon { width:52px; height:52px; background:rgba(0,144,200,.12); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.5rem; margin-bottom:1.2rem; }
.training-tag { display:inline-block; margin-top:1.2rem; background:rgba(0,196,240,.1); color:var(--teal-glow); font-size:.72rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; padding:.3rem .8rem; border-radius:999px; border:1px solid rgba(0,196,240,.2); }
.training-meta { display:flex; gap:1rem; flex-wrap:wrap; margin-top:.75rem; }
.training-meta span { font-size:.78rem; color:var(--muted); }

/* Blog card */
.blog-card .card-img { aspect-ratio:16/9; }
.blog-date { font-size:.75rem; color:var(--muted); margin-bottom:.4rem; }

/* ── EQUIPMENT FEATURE ── */
.equip-feature { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:center; }
.equip-feature-visual { aspect-ratio:1; background:var(--dark3); border-radius:50%; border:3px solid rgba(0,144,200,.2); box-shadow:0 0 80px rgba(0,144,200,.1); display:flex; align-items:center; justify-content:center; font-size:5rem; color:rgba(255,255,255,.08); font-family:var(--heading); font-weight:900; text-transform:uppercase; overflow:hidden; }
.equip-feature-visual img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.equip-specs { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin:2rem 0; }
.equip-spec { background:var(--dark3); border:1px solid rgba(0,144,200,.12); border-radius:8px; padding:1rem; }
.equip-spec-val { font-family:var(--heading); font-size:1.6rem; font-weight:900; color:var(--yellow); }
.equip-spec-key { font-size:.75rem; font-weight:500; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); margin-top:.2rem; }

/* ── CTA BAND ── */
.cta-band { padding:80px 5%; background:linear-gradient(135deg, #0A2D4A 0%, #0090C8 100%); text-align:center; position:relative; overflow:hidden; }
.cta-band-bg { position:absolute; inset:0; background:radial-gradient(ellipse at 20% 50%,rgba(255,255,255,.08),transparent 40%),radial-gradient(ellipse at 80% 50%,rgba(0,0,0,.15),transparent 40%); }
.cta-band-inner { position:relative; z-index:2; }
.cta-band-title { font-family:var(--heading); font-size:clamp(2rem,5vw,4rem); font-weight:900; text-transform:uppercase; color:var(--white); margin-bottom:1rem; line-height:1; }
.cta-band-sub { font-size:1rem; color:rgba(255,255,255,.8); margin-bottom:2.5rem; max-width:500px; margin-left:auto; margin-right:auto; }
.cta-stats { display:flex; justify-content:center; gap:4rem; flex-wrap:wrap; margin-top:3rem; padding-top:3rem; border-top:1px solid rgba(255,255,255,.2); }
.cta-stat-num { font-family:var(--heading); font-size:3rem; font-weight:900; color:var(--white); line-height:1; }
.cta-stat-label { font-size:.78rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:rgba(255,255,255,.7); margin-top:.3rem; }

/* ── CONTACT ── */
.contact-grid { display:grid; grid-template-columns:1fr 1fr; gap:5rem; align-items:start; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; margin-bottom:1.5rem; }
.contact-icon { width:44px; height:44px; flex-shrink:0; background:rgba(0,144,200,.12); border:1px solid rgba(0,144,200,.2); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; }
.contact-item-label { font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--muted); margin-bottom:.2rem; }
.contact-item-val { font-size:.95rem; color:var(--white); font-weight:500; }
.contact-form { background:var(--dark2); border:1px solid rgba(255,255,255,.07); border-radius:16px; padding:2.5rem; }
.form-title { font-family:var(--heading); font-size:1.6rem; font-weight:900; text-transform:uppercase; margin-bottom:.3rem; }
.form-sub { font-size:.88rem; color:#6A8FA8; margin-bottom:2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1.2rem; }
.form-group label { display:block; font-size:.75rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:#8CB4CC; margin-bottom:.4rem; }
.form-group input, .form-group select, .form-group textarea {
  width:100%; background:var(--dark3); border:1px solid rgba(255,255,255,.1);
  border-radius:8px; padding:.8rem 1rem; color:var(--white);
  font-family:var(--body); font-size:.92rem;
  transition:border-color var(--transition), box-shadow var(--transition); outline:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color:var(--orange); box-shadow:0 0 0 3px rgba(0,144,200,.12);
}
.form-group textarea { resize:vertical; min-height:100px; }
.form-group select option { background:var(--dark3); }
.form-success { display:none; background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.3); border-radius:8px; padding:1rem; color:#4ade80; font-size:.9rem; margin-bottom:1rem; text-align:center; }

/* ── PAGE HERO (inner pages) ── */
.page-hero { padding:140px 5% 80px; background:var(--dark2); position:relative; overflow:hidden; border-bottom:1px solid rgba(255,255,255,.06); }
.page-hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(0,144,200,.1),transparent 70%); }
.page-hero-inner { position:relative; z-index:2; max-width:700px; }
.breadcrumb { display:flex; align-items:center; gap:.5rem; font-size:.8rem; color:var(--muted); margin-bottom:1rem; }
.breadcrumb a { color:var(--muted); transition:color var(--transition); }
.breadcrumb a:hover { color:var(--orange); }
.breadcrumb span { color:var(--orange); }

/* ── FOOTER ── */
#footer { background:#050D14; border-top:1px solid rgba(0,144,200,.15); border-top:1px solid rgba(255,255,255,.06); padding:60px 5% 30px; }
.footer-top { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; padding-bottom:3rem; border-bottom:1px solid rgba(255,255,255,.06); margin-bottom:2rem; }
.footer-logo { font-family:var(--heading); font-size:1.8rem; font-weight:900; margin-bottom:.75rem; }
.footer-logo span { color:var(--orange); }
.footer-desc { font-size:.88rem; color:#777; line-height:1.7; margin-bottom:1.5rem; max-width:280px; }
.socials { display:flex; gap:.75rem; }
.social-btn { width:38px; height:38px; background:var(--dark3); border:1px solid rgba(255,255,255,.08); border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.85rem; color:#777; transition:background var(--transition),color var(--transition),border-color var(--transition); }
.social-btn:hover { background:var(--primary); color:var(--white); border-color:var(--primary); }
.footer-col-title { font-family:var(--heading); font-size:.9rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; margin-bottom:1.2rem; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:.65rem; }
.footer-links a { font-size:.88rem; color:#777; transition:color var(--transition); }
.footer-links a:hover { color:var(--orange); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:1rem; }
.footer-copy { font-size:.8rem; color:#555; }
.footer-copy a { color:var(--orange); }
.footer-legal { display:flex; gap:1.5rem; }
.footer-legal a { font-size:.8rem; color:#555; transition:color var(--transition); }
.footer-legal a:hover { color:#8CB4CC; }

/* ── GALLERY ── */
.gallery-grid { columns:4; gap:1rem; }
.gallery-item { break-inside:avoid; margin-bottom:1rem; border-radius:8px; overflow:hidden; cursor:pointer; transition:transform .3s; }
.gallery-item:hover { transform:scale(1.02); }
.gallery-item img { width:100%; display:block; }

/* ── PAGINATION ── */
.pagination { display:flex; justify-content:center; gap:.5rem; margin-top:3rem; }
.pagination a, .pagination span { width:40px; height:40px; display:flex; align-items:center; justify-content:center; border-radius:8px; background:var(--dark3); border:1px solid rgba(255,255,255,.08); font-size:.9rem; transition:background var(--transition),border-color var(--transition),color var(--transition); }
.pagination a:hover { background:rgba(0,144,200,.2); border-color:var(--orange); color:var(--orange); }
.pagination .current { background:var(--orange); border-color:var(--orange); color:var(--white); }

/* ── PAYMENT MODAL ── */
.modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.8); z-index:9999; align-items:center; justify-content:center; }
.modal-overlay.open { display:flex; }
.modal { background:var(--dark2); border:1px solid rgba(255,255,255,.08); border-radius:16px; padding:2.5rem; width:90%; max-width:500px; position:relative; }
.modal-close { position:absolute; top:1rem; right:1rem; background:none; border:none; color:var(--muted); font-size:1.5rem; cursor:pointer; transition:color var(--transition); }
.modal-close:hover { color:var(--white); }
.modal-title { font-family:var(--heading); font-size:1.6rem; font-weight:900; text-transform:uppercase; margin-bottom:.3rem; }
.modal-price { font-size:1.8rem; font-weight:700; color:var(--orange); margin-bottom:1.5rem; }

/* ── ADMIN NOTICE ── */
.notice { padding:.8rem 1.2rem; border-radius:8px; font-size:.9rem; margin-bottom:1.5rem; }
.notice-success { background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.3); color:#4ade80; }
.notice-error { background:rgba(239,68,68,.1); border:1px solid rgba(239,68,68,.3); color:#f87171; }

/* ── REVEAL ANIMATION ── */
.reveal { opacity:0; transform:translateY(30px); transition:opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.5;transform:scale(1.4)} }
@keyframes scrollAnim { to{left:40px} }

/* ── RESPONSIVE ── */
@media (max-width:1024px) {
  .about-grid { grid-template-columns:1fr; gap:3rem; }
  .equip-feature { grid-template-columns:1fr; gap:3rem; }
  .contact-grid { grid-template-columns:1fr; gap:3rem; }
  .footer-top { grid-template-columns:1fr 1fr; }
  .grid-3 { grid-template-columns:1fr 1fr; }
  .grid-4 { grid-template-columns:repeat(3,1fr); }
  .gallery-grid { columns:3; }
}
@media (max-width:768px) {
  .nav-links { display:none; flex-direction:column; position:fixed; top:72px; left:0; right:0; background:var(--dark2); border-bottom:1px solid rgba(255,255,255,.06); padding:1.5rem 5% 2rem; gap:1rem; }
  .nav-links.open { display:flex; }
  .nav-toggle { display:flex; }
  .grid-3 { grid-template-columns:1fr; }
  .grid-4 { grid-template-columns:1fr 1fr; }
  .footer-top { grid-template-columns:1fr; }
  .gallery-grid { columns:2; }
  .form-row { grid-template-columns:1fr; }
  .cta-stats { gap:2rem; }
  .hero-stats { gap:2rem; }
  .equip-feature { grid-template-columns:1fr; }
}
@media (max-width:480px) {
  .grid-4 { grid-template-columns:1fr; }
  .gallery-grid { columns:1; }
}

/* ══════════════════════════════════════════
   HERO SLIDESHOW — FIXED
══════════════════════════════════════════ */
#hero {
  height: 100vh; min-height: 600px;
  position: relative; overflow: hidden;
  display: block;
}

.hero-slider {
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  width: 100%; height: 100%;
}

.hero-slide {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  display: flex; flex-direction: column; justify-content: center;
  padding: 140px 5% 200px;
  opacity: 0; visibility: hidden;
  transition: opacity .9s ease, visibility .9s ease;
  z-index: 1;
}
.hero-slide.active { opacity:1; visibility:visible; z-index:2; }

/* Slide background image */
.slide-bg {
  position:absolute; inset:0;
  background-size:cover; background-position:center;
  transform:scale(1.04);
  transition:transform 7s ease;
}
.hero-slide.active .slide-bg { transform:scale(1); }
.slide-bg-gradient {
  background: radial-gradient(ellipse 70% 60% at 70% 50%, rgba(0,144,200,.22) 0%, transparent 70%),
              radial-gradient(ellipse 40% 50% at 20% 80%, rgba(0,196,240,.1) 0%, transparent 60%),
              #07101A;
}

/* Dark overlay on real images */
.slide-overlay {
  position:absolute; inset:0;
  background:linear-gradient(105deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.35) 60%, rgba(0,0,0,.15) 100%);
  z-index:1;
}

/* Slide content */
.slide-content {
  position:relative; z-index:3; max-width:800px;
  transform:translateY(20px);
  transition:transform .9s ease .2s, opacity .9s ease .2s;
  opacity:0;
}
.hero-slide.active .slide-content { transform:translateY(0); opacity:1; }

/* Stats bar */
.hero-stats-bar {
  position:absolute; bottom:0; left:0; right:0; z-index:10;
  display:flex; align-items:stretch;
  background:rgba(15,15,15,.88); backdrop-filter:blur(12px);
  border-top:1px solid rgba(0,144,200,.2);
}
.hero-stat { flex:1; padding:1.4rem 2rem; text-align:center; }
.hero-stat-num { font-family:var(--heading); font-size:2rem; font-weight:900; color:var(--orange); line-height:1; }
.hero-stat-label { font-size:.72rem; font-weight:600; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); margin-top:.3rem; }
.hero-stat-divider { width:1px; background:rgba(255,255,255,.08); margin:1rem 0; }

/* Slider controls */
.slider-controls {
  position:absolute; bottom:100px; right:5%; z-index:10;
  display:flex; align-items:center; gap:1rem;
}
.slider-arrow {
  width:42px; height:42px; border-radius:50%;
  background:rgba(255,255,255,.1); border:1px solid rgba(255,255,255,.2);
  color:var(--white); font-size:1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:background .2s, border-color .2s;
}
.slider-arrow:hover { background:var(--orange); border-color:var(--orange); }
.slider-dots { display:flex; gap:.5rem; align-items:center; }
.slider-dot {
  width:8px; height:8px; border-radius:50%;
  background:rgba(255,255,255,.3); border:none; cursor:pointer;
  transition:background .3s, transform .3s, width .3s;
  padding:0;
}
.slider-dot.active { background:var(--orange); width:24px; border-radius:4px; }

/* Scroll indicator */
.hero-scroll {
  position:absolute; bottom:90px; left:5%; z-index:10;
  display:flex; align-items:center; gap:.75rem;
  font-size:.78rem; font-weight:500; letter-spacing:.1em;
  text-transform:uppercase; color:rgba(255,255,255,.5);
}
.scroll-line { width:40px; height:1px; background:var(--orange); position:relative; overflow:hidden; }
.scroll-line::after { content:''; position:absolute; top:0; left:-40px; width:40px; height:1px; background:var(--white); animation:scrollAnim 1.8s ease infinite; }

/* ══════════════════════════════════════════
   PARTNERS TICKER
══════════════════════════════════════════ */
#partners {
  background:var(--dark2);
  border-top:1px solid rgba(255,255,255,.05);
  border-bottom:1px solid rgba(255,255,255,.05);
  padding:1.5rem 5%;
  display:flex; align-items:center; gap:2rem; overflow:hidden;
}
.partners-track-wrap { flex:1; overflow:hidden; position:relative; }
.partners-track { display:flex; gap:3rem; align-items:center; white-space:nowrap; will-change:transform; }
.partner-name {
  font-family:var(--heading); font-size:1.1rem; font-weight:700;
  letter-spacing:.06em; text-transform:uppercase;
  color:rgba(255,255,255,.22); flex-shrink:0;
  transition:color .2s; cursor:default;
}
.partner-name:hover { color:var(--primary); }

/* ══════════════════════════════════════════
   ABOUT — ACCENT CARD
══════════════════════════════════════════ */
.about-accent-card {
  position:absolute; top:2rem; left:-1.5rem;
  background:var(--dark3);
  border:1px solid rgba(0,144,200,.25);
  border-radius:12px; padding:1rem 1.2rem;
  text-align:center;
  box-shadow:0 8px 32px rgba(0,0,0,.4);
}

/* ══════════════════════════════════════════
   CARD CATEGORY OVERLAY
══════════════════════════════════════════ */
.card-cat-overlay {
  position:absolute; top:.75rem; left:.75rem;
  background:rgba(0,144,200,.9);
  color:var(--white);
  font-size:.68rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:.25rem .7rem; border-radius:4px;
  z-index:2;
}

/* ══════════════════════════════════════════
   RESPONSIVE ADJUSTMENTS
══════════════════════════════════════════ */
@media(max-width:768px){
  .hero-stats-bar { display:grid; grid-template-columns:1fr 1fr; }
  .hero-stat-divider { display:none; }
  .slider-controls { right:50%; transform:translateX(50%); bottom:130px; }
  .hero-scroll { display:none; }
  .about-accent-card { display:none; }
  .hero-slide { padding:120px 5% 220px; }
}
@media(max-width:480px){
  .hero-stats-bar { grid-template-columns:1fr 1fr; }
  .hero-stat { padding:1rem; }
  .hero-stat-num { font-size:1.6rem; }
}

/* ══════════════════════════════════════════
   ANNOUNCEMENT BAR
══════════════════════════════════════════ */
#announcement-bar {
  background: linear-gradient(90deg, var(--navy), var(--primary-dark)); color: var(--white);
  padding: .6rem 5%; display: flex; align-items: center; justify-content: center;
  gap: 1.5rem; font-size: .82rem; font-weight: 500;
  position: relative; z-index: 1001;
}
#announcement-bar a { color: var(--white); font-weight: 700; text-decoration: underline; }
#announcement-bar button { background: none; border: none; color: var(--white); font-size: 1.2rem; cursor: pointer; margin-left: auto; opacity: .8; line-height: 1; padding: 0; }

/* ══════════════════════════════════════════
   MEGA DROPDOWN MENU
══════════════════════════════════════════ */
.dropdown-mega {
  display: flex !important; gap: 0;
  min-width: 480px !important;
  padding: 1.5rem !important;
  flex-direction: row !important;
  list-style: none;
}
.mega-col { flex: 1; padding: 0 1rem; border-right: 1px solid rgba(255,255,255,.06); }
.mega-col:last-child { border-right: none; }
.mega-col-title {
  font-size: .65rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase;
  color: var(--orange); margin-bottom: .75rem; padding-bottom: .5rem;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.mega-col a {
  display: block !important; padding: .45rem 0 !important;
  font-size: .85rem !important; color: #ccc !important;
  transition: color .2s !important;
  border-bottom: none !important;
}
.mega-col a:hover { color: var(--orange) !important; background: none !important; }
.mega-view-all {
  color: var(--orange) !important; font-weight: 600 !important;
  margin-top: .75rem !important; padding-top: .75rem !important;
  border-top: 1px solid rgba(255,255,255,.06) !important;
}

/* Override dropdown for mega */
.has-dropdown:hover .dropdown-mega {
  display: flex !important;
}

/* Nav logo - Energies in smaller font */
.nav-logo span { color: var(--orange); font-size: .9em; }

/* Footer - update privacy link */
.footer-links a[href="/pages/privacy-policy"],
.footer-links a[href="/pages/career"] { }

@media(max-width: 1200px) {
  .dropdown-mega { min-width: 380px !important; }
}
@media(max-width: 768px) {
  .dropdown-mega { flex-direction: column !important; min-width: 100% !important; }
  .mega-col { border-right: none; border-bottom: 1px solid rgba(255,255,255,.06); padding: .75rem 0; }
  #announcement-bar { font-size: .75rem; gap: .75rem; }
}
