/*
Theme Name: Astrontech
Theme URI: https://astron.com.pk
Author: techpeer
Description: Custom WordPress theme for Astrontech Pvt. Ltd. — IT Solutions Pakistan
Version: 1.0.0
License: Private
Text Domain: astrontech
*/

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:     #C00000;
  --red-l:   #E8001A;
  --red-d:   #900000;
  --navy:    #034E97;
  --navy-l:  #0A6DC9;
  --dark:    #FFFFFF;
  --dark2:   #F4F5F8;
  --dark3:   #EAECF2;
  --dark4:   #E2E5ED;
  --dark5:   #F9FAFB;
  --card:    #FFFFFF;
  --gray:    #58595B;
  --border:  rgba(0,0,0,0.09);
  --border2: rgba(192,0,0,0.2);
  --white:   #FFFFFF;
  --offwhite:#D8DCE8;
  --muted:   #6B7280;
  --text:    #111827;
}
html{scroll-behavior:smooth}
body{font-family:'Inter',sans-serif;background:var(--dark);color:var(--text);overflow-x:hidden;line-height:1.6}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:#E8EAF0}
::-webkit-scrollbar-thumb{background:var(--red);border-radius:3px}

/* ─── NAVBAR ─── */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:999;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 5%;height:64px;
  background:rgba(255,255,255,.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(0,0,0,.08);
  box-shadow:0 4px 24px rgba(0,0,0,.08);
  transition:all .35s;
}
.nav-logo img{height:44px;width:auto}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none}
.nav-links li{display:flex;align-items:center}
.nav-links li>a{display:flex;align-items:center;gap:.3rem;line-height:1}
.nav-links a{color:var(--muted);font-size:.875rem;font-weight:500;transition:color .2s;letter-spacing:.01em}
.nav-links a:hover{color:var(--text)}
.nav-r{display:flex;align-items:center;gap:1.25rem}
.nav-call{font-size:.8rem;color:var(--muted);display:flex;align-items:center;gap:.4rem;transition:color .2s}
.nav-call:hover{color:var(--text)}
.nav-cta{background:var(--red);color:#fff;padding:.52rem 1.4rem;border-radius:7px;font-weight:700;font-size:.85rem;transition:all .2s;letter-spacing:.01em}
.nav-cta:hover{background:var(--red-l);transform:translateY(-1px);box-shadow:0 6px 20px rgba(192,0,0,.4)}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{width:22px;height:2px;background:var(--text);border-radius:2px}

/* ─── HERO SLIDER ─── */
#hero{position:relative;min-height:100vh;overflow:hidden;display:flex;align-items:center}
.hero-slides{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity .9s ease;pointer-events:none}
.hero-slide.active{opacity:1}
.hero-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;
  animation:hzoom 14s ease-in-out infinite alternate;
}
@keyframes hzoom{from{transform:scale(1)}to{transform:scale(1.07)}}
.hero-ov{
  position:absolute;inset:0;
  background:linear-gradient(110deg,rgba(10,12,16,.80) 0%,rgba(10,12,16,.55) 55%,rgba(3,78,151,.12) 100%);
}
.hero-scan{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(3,78,151,.03) 2px,rgba(3,78,151,.03) 4px);pointer-events:none}
.hero-glow{position:absolute;top:-200px;right:-100px;width:700px;height:700px;border-radius:50%;background:radial-gradient(circle,rgba(192,0,0,.12) 0%,transparent 65%);pointer-events:none}
.hero-inner{position:relative;z-index:2;padding:0 5%;padding-top:74px;padding-bottom:2.5rem;max-width:860px;width:100%;color:#fff}
/* Stacked text panels — grid trick keeps wrapper sized to tallest item */
.hero-texts{display:grid}
.hero-text{grid-row:1;grid-column:1;opacity:0;transition:opacity .9s ease;pointer-events:none}
.hero-text.active{opacity:1;pointer-events:auto}
.hero-eyebrow{display:inline-flex;align-items:center;gap:.6rem;border:1px solid rgba(192,0,0,.35);background:rgba(192,0,0,.08);border-radius:999px;padding:.38rem 1.1rem;font-size:.75rem;font-weight:700;color:var(--red-l);letter-spacing:.08em;text-transform:uppercase;margin-bottom:1.75rem}
.dot-live{width:7px;height:7px;background:var(--red-l);border-radius:50%;animation:blink 1.6s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.25}}
.hero-h{font-size:clamp(2.8rem,5.5vw,5rem);font-family:'Barlow Condensed',sans-serif;font-weight:300;line-height:1.05;letter-spacing:0px}
.hero-h .r{color:var(--red)}
.hero-p{margin-top:1.5rem;color:var(--offwhite);font-size:1.05rem;max-width:600px;line-height:1.8;opacity:.88}
.hero-btns{display:flex;gap:1rem;flex-wrap:wrap;margin-top:2.5rem}
.btn-red{background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff;padding:.85rem 2.25rem;border-radius:9px;font-weight:700;font-size:.98rem;box-shadow:0 6px 28px rgba(192,0,0,.45);transition:all .25s}
.btn-red:hover{transform:translateY(-3px);box-shadow:0 12px 38px rgba(192,0,0,.55)}
.btn-outline{border:1.5px solid rgba(255,255,255,.2);color:var(--white);padding:.85rem 2.25rem;border-radius:9px;font-weight:600;font-size:.98rem;backdrop-filter:blur(8px);background:rgba(255,255,255,.05);transition:all .25s}
.btn-outline:hover{border-color:rgba(192,0,0,.5);background:rgba(192,0,0,.08)}
.hero-stats{display:flex;margin-top:4rem;background:rgba(10,12,16,.75);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:14px;overflow:hidden;width:fit-content;max-width:100%;color:#fff}
.hs{padding:1.2rem 2rem;text-align:center;border-right:1px solid rgba(255,255,255,.1)}
.hs:last-child{border-right:none}
.hs-n{font-size:1.85rem;font-weight:900;letter-spacing:-1px;line-height:1}
.hs-n .sup{font-size:1rem;color:var(--red)}
.hs-l{font-size:.7rem;color:rgba(255,255,255,.55);text-transform:uppercase;letter-spacing:.1em;margin-top:.3rem}
/* Slider controls */
.hero-prev,.hero-next{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(10,12,16,.45);border:1px solid rgba(255,255,255,.15);color:#fff;width:48px;height:48px;border-radius:50%;font-size:1.6rem;cursor:pointer;transition:all .25s;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px)}
/* Dots — absolute bottom-center, never touches hero-inner layout */
.hero-dots{position:absolute;bottom:1.8rem;left:50%;transform:translateX(-50%);z-index:10;display:flex;gap:.55rem;align-items:center}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);border:1px solid rgba(255,255,255,.15);cursor:pointer;transition:all .35s;padding:0}
.hero-dot.active{width:26px;border-radius:4px;background:var(--red);border-color:var(--red)}
.hero-prev{left:2%}
.hero-next{right:2%}
.hero-prev:hover,.hero-next:hover{background:var(--red);border-color:var(--red)}
@keyframes fu{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}

/* ─── TICKER ─── */
.ticker{background:var(--red);padding:.55rem 0;overflow:hidden}
.ticker-in{display:flex;gap:2.5rem;width:max-content;animation:tick 28s linear infinite}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.tick-item{font-size:.78rem;font-weight:700;color:#fff;white-space:nowrap;display:flex;align-items:center;gap:.6rem;letter-spacing:.04em}
.tick-item::before{content:'';width:4px;height:4px;background:#fff;border-radius:50%;opacity:.5;flex-shrink:0}

/* ─── SECTION COMMONS ─── */
section{padding:60px 5%}
.sl{font-size:1rem;font-weight:700;color:var(--red-l);text-transform:uppercase;letter-spacing:.1em;display:flex;align-items:center;gap:.5rem;margin-bottom:.65rem}
.sl::before{content:'';width:20px;height:2px;background:var(--red);border-radius:2px;flex-shrink:0}
.sh{font-size:clamp(2.2rem,4vw,3.4rem);font-family:'Barlow Condensed',sans-serif;font-weight:300;letter-spacing:0px;line-height:1.1;color:var(--text)}
.sh .a{color:var(--red)}
.sh .b{color:var(--navy)}
.sp{color:var(--muted);font-size:.95rem;line-height:1.75;max-width:540px;margin-top:.7rem}

/* ─── ABOUT ─── */
#about{background:var(--dark5)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.about-grid{grid-template-columns:1fr;gap:3rem}}
.about-img{position:relative;border-radius:18px;overflow:visible}
.about-img img{width:100%;height:470px;object-fit:cover;border-radius:18px}
.year-badge{position:absolute;top:-18px;right:-18px;width:108px;height:108px;border-radius:50%;background:linear-gradient(135deg,var(--red),var(--red-d));display:flex;flex-direction:column;align-items:center;justify-content:center;box-shadow:0 8px 32px rgba(192,0,0,.55);color:#fff;text-align:center}
.year-badge .yn{font-size:1.75rem;font-weight:900;line-height:1;letter-spacing:-1px}
.year-badge .yl{font-size:.6rem;text-transform:uppercase;letter-spacing:.06em;opacity:.85;margin-top:2px}
.about-card{position:absolute;bottom:-20px;left:1.5rem;right:1.5rem;background:rgba(10,12,16,.92);backdrop-filter:blur(16px);border:1px solid var(--border2);border-radius:14px;padding:1.15rem 1.5rem;display:flex;align-items:center;gap:1rem}
.about-card-icon{font-size:1.75rem;flex-shrink:0}
.about-card strong{font-size:.95rem;font-weight:700;display:block;margin-bottom:.15rem;color:#fff}
.about-card span{font-size:.8rem;color:rgba(255,255,255,.6)}
.about-pts{margin-top:2rem;display:flex;flex-direction:column;gap:1rem}
.apt{display:flex;align-items:flex-start;gap:1rem;padding:1rem 1.25rem;background:rgba(192,0,0,.04);border:1px solid rgba(192,0,0,.1);border-radius:12px;transition:all .25s}
.apt:hover{background:rgba(192,0,0,.08);transform:translateX(5px);border-color:rgba(192,0,0,.25)}
.apt-ic{width:38px;height:38px;flex-shrink:0;border-radius:9px;background:rgba(192,0,0,.08);border:1px solid rgba(192,0,0,.15);display:flex;align-items:center;justify-content:center;color:var(--red)}
.apt h4{font-size:.92rem;font-weight:700;margin-bottom:.2rem}
.apt p{font-size:.83rem;color:var(--muted);line-height:1.6}

/* ─── SERVICES ─── */
#services{background:var(--dark2)}
.svc-head{margin-bottom:3.5rem}
.svc-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}
.sc{border-radius:16px;border:1px solid var(--border);overflow:hidden;transition:all .35s;position:relative;background:var(--card);box-shadow:0 2px 12px rgba(0,0,0,.06)}
.sc::after{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--navy));opacity:0;transition:opacity .3s}
.sc:hover{border-color:rgba(192,0,0,.25);transform:translateY(-6px);box-shadow:0 20px 50px rgba(0,0,0,.12)}
.sc:hover::after{opacity:1}
.sc-img{height:190px;overflow:hidden}
.sc-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.sc:hover .sc-img img{transform:scale(1.06)}
.sc-body{padding:1.4rem}
.sc-ic{width:42px;height:42px;border-radius:10px;background:rgba(192,0,0,.1);border:1px solid rgba(192,0,0,.2);display:flex;align-items:center;justify-content:center;font-size:1.1rem;margin-bottom:1rem}
.sc h3{font-size:1.02rem;font-weight:700;margin-bottom:.45rem}
.sc p{font-size:.84rem;color:var(--muted);line-height:1.65}
.sc-tags{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:1rem}
.tag{font-size:.7rem;font-weight:600;color:var(--navy);background:rgba(3,78,151,.08);border:1px solid rgba(3,78,151,.18);border-radius:5px;padding:.18rem .55rem}

/* ─── WHY ─── */
#why{background:var(--dark3)}
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:5rem;align-items:center}
@media(max-width:900px){.why-grid{grid-template-columns:1fr;gap:3rem}}
.why-left{position:relative}
.why-left img{width:100%;height:500px;object-fit:cover;border-radius:18px}
.why-ov{position:absolute;inset:0;border-radius:18px;background:linear-gradient(180deg,transparent 40%,rgba(10,12,16,.92) 100%)}
.why-numbers{position:absolute;bottom:1.5rem;left:1.5rem;right:1.5rem;display:grid;grid-template-columns:1fr 1fr;gap:.75rem}
.wn{background:rgba(10,12,16,.9);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:1rem;text-align:center;color:#fff}
.wn-v{font-size:1.6rem;font-weight:900;color:var(--red);line-height:1}
.wn-l{font-size:.68rem;color:var(--muted);margin-top:.3rem;text-transform:uppercase;letter-spacing:.06em}
.why-pts{display:flex;flex-direction:column;gap:1.75rem}
.wp{display:flex;gap:1.25rem;align-items:flex-start}
.wp-num{width:44px;height:44px;flex-shrink:0;border-radius:11px;background:linear-gradient(135deg,var(--red),var(--red-d));display:flex;align-items:center;justify-content:center;font-weight:900;font-size:.95rem;color:#fff;box-shadow:0 4px 16px rgba(192,0,0,.4)}
.wp h4{font-size:.97rem;font-weight:700;margin-bottom:.35rem}
.wp p{font-size:.86rem;color:var(--muted);line-height:1.65}

/* ─── CLIENTS ─── */
#clients{background:var(--dark5);text-align:center}
.cl-head{margin-bottom:3rem}
.cl-mask{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,black 12%,black 88%,transparent);mask:linear-gradient(90deg,transparent,black 12%,black 88%,transparent)}
.cl-row{display:flex;gap:.85rem;width:max-content;animation:cl1 38s linear infinite}
.cl-row.r2{animation:cl2 38s linear infinite;margin-top:.85rem}
@keyframes cl1{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes cl2{from{transform:translateX(-50%)}to{transform:translateX(0)}}
.chip{background:var(--card);border:1px solid var(--border);border-radius:9px;padding:.55rem 1.3rem;font-size:.8rem;font-weight:600;color:var(--muted);white-space:nowrap;transition:all .2s;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.chip:hover{color:var(--red);border-color:rgba(192,0,0,.35);background:rgba(192,0,0,.04)}
.cl-row:hover{animation-play-state:paused}

/* ─── BRANDS ─── */
#brands{background:var(--dark4);text-align:center}
.br-head{margin-bottom:3rem}
.br-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;max-width:900px;margin:0 auto}
.bp{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:.65rem 1.6rem;font-size:.87rem;font-weight:700;color:var(--gray);transition:all .25s;letter-spacing:.03em;box-shadow:0 1px 4px rgba(0,0,0,.05)}
.bp:hover{color:var(--red);border-color:rgba(192,0,0,.3);background:rgba(192,0,0,.04)}

/* ─── GLOBAL PRESENCE ─── */
#global-presence{padding:60px 5%;background:var(--dark3);position:relative;overflow:hidden}
#global-presence::before{content:'';position:absolute;top:-200px;left:50%;transform:translateX(-50%);width:900px;height:500px;background:radial-gradient(ellipse,rgba(192,0,0,.05) 0%,transparent 70%);pointer-events:none}
.gp-inner{max-width:1280px;margin:0 auto}
.gp-header{text-align:center;margin-bottom:3.5rem}
.gp-header h2{font-size:clamp(2rem,3.5vw,2.8rem);font-weight:800;line-height:1.2;margin:.6rem 0 1rem}
.gp-header p{color:var(--muted);font-size:1.05rem;max-width:520px;margin:0 auto}
.gp-wrap{display:grid;grid-template-columns:1fr 300px;gap:2rem;align-items:stretch}
#worldMap{height:480px;border-radius:18px;overflow:hidden;border:1px solid var(--border);position:relative;box-shadow:0 0 60px rgba(192,0,0,.12),0 20px 60px rgba(0,0,0,.5)}
.leaflet-container{background:#e8ecf0!important}
.leaflet-control-zoom{display:none}
.leaflet-control-attribution{display:none}
.leaflet-layer{filter:none;transition:filter .4s}
#worldMap.map-dark .leaflet-layer{filter:invert(1) hue-rotate(180deg) brightness(.55) contrast(1.3) saturate(.4)}
#worldMap.map-dark{background:#0A0C10!important}
#mapThemeBtn{position:absolute;top:12px;right:12px;z-index:999;background:rgba(255,255,255,.92);border:1px solid rgba(0,0,0,.12);color:var(--text);padding:.38rem .85rem;border-radius:20px;font-family:'Inter',sans-serif;font-size:.75rem;font-weight:600;cursor:pointer;letter-spacing:.03em;backdrop-filter:blur(8px);transition:all .2s;display:flex;align-items:center;gap:.35rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}
#mapThemeBtn:hover{background:var(--red);color:#fff;border-color:var(--red)}
.gp-marker{width:18px;height:18px;background:var(--red);border:2px solid rgba(255,255,255,.25);border-radius:50%;box-shadow:0 0 0 4px rgba(192,0,0,.3),0 0 16px rgba(192,0,0,.6);animation:pulse-pin 2s ease-in-out infinite}
@keyframes pulse-pin{0%,100%{box-shadow:0 0 0 4px rgba(192,0,0,.3),0 0 16px rgba(192,0,0,.6)}50%{box-shadow:0 0 0 8px rgba(192,0,0,.15),0 0 28px rgba(192,0,0,.9)}}
.leaflet-popup-content-wrapper{background:rgba(26,32,46,.97)!important;border:1px solid var(--border2)!important;border-radius:10px!important;box-shadow:0 8px 30px rgba(0,0,0,.5)!important;color:var(--white)!important;backdrop-filter:blur(10px)}
.leaflet-popup-tip{background:rgba(26,32,46,.97)!important}
.leaflet-popup-content{margin:10px 14px!important;font-family:'Inter',sans-serif}
.leaflet-popup-content strong{display:block;font-size:.95rem;font-weight:700;color:var(--white);margin-bottom:2px}
.leaflet-popup-content small{color:var(--muted);font-size:.75rem}
.gp-legend{display:flex;flex-direction:column;gap:1rem;background:var(--card);border:1px solid var(--border);border-radius:18px;padding:1.5rem 1.25rem;align-self:start;position:sticky;top:90px;box-shadow:0 2px 16px rgba(0,0,0,.07)}
.gp-legend::before{content:'LOCATIONS';display:block;font-size:.65rem;font-weight:700;letter-spacing:.12em;color:var(--red);margin-bottom:.5rem}
.gp-pin{display:flex;align-items:center;gap:.85rem;padding:.6rem .8rem;border-radius:10px;cursor:pointer;transition:background .2s}
.gp-pin:hover{background:rgba(0,0,0,.04)}
.gp-pin.active{background:rgba(192,0,0,.08);border:1px solid rgba(192,0,0,.25)}
.pin-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0;background:var(--red);box-shadow:0 0 8px rgba(192,0,0,.7)}
.gp-pin strong{font-size:.88rem;font-weight:600;color:var(--text);display:block}
.gp-pin small{font-size:.72rem;color:var(--muted);line-height:1.3}
@media(max-width:900px){.gp-wrap{grid-template-columns:1fr}#worldMap{height:340px}.gp-legend{position:static}}

/* ─── OFFICES ─── */
#offices{background:var(--dark2)}
.of-head{margin-bottom:3.5rem}
.of-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:1.25rem}
.oc{background:var(--card);border:1px solid var(--border);border-radius:15px;padding:1.65rem;transition:all .3s;position:relative;overflow:hidden;box-shadow:0 2px 10px rgba(0,0,0,.06)}
.oc::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red),var(--navy));transform:scaleX(0);transform-origin:left;transition:transform .35s}
.oc:hover{border-color:rgba(192,0,0,.25);transform:translateY(-5px);box-shadow:0 16px 40px rgba(0,0,0,.12)}
.oc:hover::after,.oc.active::after{transform:scaleX(1)}
.oc.active{border-color:rgba(192,0,0,.5);background:rgba(192,0,0,.06)}
.oc-flag{margin-bottom:1rem;width:38px;height:38px;background:rgba(192,0,0,.08);border:1px solid rgba(192,0,0,.15);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--red)}
.oc-city{font-size:1.1rem;font-weight:800;margin-bottom:.25rem}
.oc-type{font-size:.68rem;font-weight:700;color:var(--red-l);text-transform:uppercase;letter-spacing:.1em;margin-bottom:.7rem}
.oc-addr{font-size:.81rem;color:var(--muted);line-height:1.6}
.map-wrap{margin-top:2.5rem;border-radius:18px;overflow:hidden;border:1px solid var(--border);position:relative;height:420px;background:var(--card)}
.map-wrap iframe{width:100%;height:100%;border:none;display:block;filter:grayscale(20%) contrast(1.05)}
.map-label{position:absolute;top:1rem;left:1rem;z-index:2;background:rgba(10,12,16,.92);backdrop-filter:blur(12px);border:1px solid rgba(192,0,0,.3);border-radius:10px;padding:.55rem 1.1rem;font-size:.8rem;font-weight:700;display:flex;align-items:center;gap:.5rem;color:var(--white)}
.map-label .dot{width:7px;height:7px;background:var(--red);border-radius:50%}

/* ─── CONTACT ─── */
#contact{background:var(--dark5);display:grid;grid-template-columns:1fr 1.15fr;gap:5rem;align-items:start;padding:60px 5%}
@media(max-width:900px){#contact{grid-template-columns:1fr;gap:3rem}.pg-section[style*="grid-template-columns"]{grid-template-columns:1fr!important}}
.ct-info p{color:var(--muted);line-height:1.8;margin:1rem 0 2rem}
.ci{display:flex;align-items:flex-start;gap:1rem;margin-bottom:1.15rem}
.ci-ic{width:42px;height:42px;border-radius:10px;flex-shrink:0;background:rgba(192,0,0,.1);border:1px solid rgba(192,0,0,.2);display:flex;align-items:center;justify-content:center;font-size:.95rem}
.ci strong{display:block;font-size:.88rem;font-weight:700;margin-bottom:.1rem}
.ci span{font-size:.82rem;color:var(--muted);line-height:1.5}
.ct-form{background:var(--card);border:1px solid var(--border);border-radius:18px;padding:2.25rem;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.ft{font-size:1.05rem;font-weight:700;margin-bottom:1.75rem;display:flex;align-items:center;gap:.65rem}
.ft-ic{width:30px;height:30px;background:var(--red);border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.8rem;box-shadow:0 4px 12px rgba(192,0,0,.4)}
.fr{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
@media(max-width:500px){.fr{grid-template-columns:1fr}}
.fg{margin-bottom:1rem}
label{display:block;font-size:.75rem;font-weight:600;color:var(--gray);margin-bottom:.4rem;text-transform:uppercase;letter-spacing:.06em}
input,textarea,select{width:100%;background:#F8F9FC;border:1px solid rgba(0,0,0,.12);border-radius:9px;padding:.72rem 1rem;color:var(--text);font-size:.9rem;font-family:inherit;outline:none;transition:border .2s,background .2s}
input:focus,textarea:focus,select:focus{border-color:var(--red);background:#fff;box-shadow:0 0 0 3px rgba(192,0,0,.08)}
textarea{height:108px;resize:vertical}
select option{background:#fff;color:var(--text)}
.fb{width:100%;padding:.9rem;border:none;border-radius:9px;background:linear-gradient(135deg,var(--red),var(--red-d));color:#fff;font-size:.98rem;font-weight:700;cursor:pointer;font-family:inherit;transition:all .25s;box-shadow:0 6px 24px rgba(192,0,0,.4)}
.fb:hover{transform:translateY(-2px);box-shadow:0 10px 32px rgba(192,0,0,.55)}

/* ─── FOOTER ─── */
footer{background:#05070D;border-top:1px solid var(--border);padding:3.5rem 5% 2rem}
.ft-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:2.5rem}
@media(max-width:900px){.ft-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.ft-grid{grid-template-columns:1fr}}
.ft-brand img{height:40px;width:auto;margin-bottom:1rem}
.ft-brand p{font-size:.82rem;color:var(--muted);line-height:1.75;max-width:270px;margin-top:.5rem}
.ft-col h5{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.12em;color:var(--red-l);margin-bottom:1rem}
.ft-col ul{list-style:none}
.ft-col li{margin-bottom:.5rem}
.ft-col a{font-size:.83rem;color:var(--muted);transition:color .2s}
.ft-col a:hover{color:var(--white)}
.ft-bot{border-top:1px solid var(--border);padding-top:1.5rem;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.ft-bot p{font-size:.78rem;color:var(--muted)}
.socials{display:flex;gap:.6rem}
.sb{width:34px;height:34px;border-radius:8px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;color:var(--muted);transition:all .2s}
.sb:hover{background:var(--red);border-color:var(--red);color:#fff}

/* ─── REVEAL ─── */
.rv{opacity:0;transform:translateY(26px);transition:opacity .65s,transform .65s}
.rv.on{opacity:1;transform:translateY(0)}
.rv-l{opacity:0;transform:translateX(-30px);transition:opacity .65s,transform .65s}
.rv-l.on{opacity:1;transform:translateX(0)}
.rv-r{opacity:0;transform:translateX(30px);transition:opacity .65s,transform .65s}
.rv-r.on{opacity:1;transform:translateX(0)}

/* ─── MOBILE MENU ─── */
#mobileMenu{display:none;position:fixed;top:64px;left:0;right:0;z-index:998;background:rgba(255,255,255,.98);backdrop-filter:blur(20px);border-bottom:1px solid rgba(0,0,0,.08);box-shadow:0 8px 24px rgba(0,0,0,.08);padding:1.2rem 5% 1.5rem;flex-direction:column;gap:.25rem}
#mobileMenu.open{display:flex}
#mobileMenu a{color:var(--muted);font-size:1rem;font-weight:500;padding:.75rem 0;border-bottom:1px solid rgba(0,0,0,.07);transition:color .2s}
#mobileMenu a:last-child{border-bottom:none}
#mobileMenu a:hover{color:var(--text)}
#mobileMenu .mob-cta{margin-top:.75rem;background:var(--red);color:#fff;padding:.75rem;border-radius:8px;text-align:center;font-weight:700;border-bottom:none}
#mobileMenu .mob-cta:hover{background:var(--red-l)}
.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)}
.hamburger span{transition:transform .25s,opacity .2s}

/* ─── NAV DROPDOWN ─── */
.has-drop{position:relative}
.has-drop>a{display:flex;align-items:center;gap:.3rem}
/* invisible bridge fills the gap so mouse travel doesn't close the menu */
.has-drop::after{
  content:'';position:absolute;top:100%;left:0;right:0;height:12px;
}
.has-drop>.drop{
  visibility:hidden;opacity:0;pointer-events:none;
  position:absolute;top:calc(100% + 12px);left:0;
  background:#fff;border:1px solid var(--border);border-radius:10px;
  box-shadow:0 12px 40px rgba(0,0,0,.12);min-width:220px;
  padding:.5rem 0;list-style:none;z-index:1000;
  transform:translateY(-6px);
  transition:opacity .18s ease,transform .18s ease,visibility .18s;
}
.has-drop:hover>.drop{
  visibility:visible;opacity:1;pointer-events:auto;transform:translateY(0);
}
.drop li a{display:flex;align-items:center;gap:.65rem;padding:.6rem 1.2rem;font-size:.85rem;color:var(--muted);transition:color .18s,background .18s}
.drop li a:hover{color:var(--red);background:rgba(192,0,0,.05)}
.drop-arrow{font-size:.8rem;opacity:.5;display:inline-block;transition:transform .2s}
.has-drop:hover .drop-arrow{transform:rotate(180deg)}
.drop-ic{display:flex;align-items:center;color:var(--red);opacity:.75;flex-shrink:0}
.nav-contact-btn{
  background:var(--red);color:#fff !important;
  display:inline-flex;align-items:center;line-height:1;
  padding:.45rem 1.2rem;border-radius:7px;font-weight:700;font-size:.875rem;
  transition:background .2s,box-shadow .2s !important;
}
.nav-contact-btn:hover{background:var(--red-l) !important;box-shadow:0 4px 14px rgba(192,0,0,.35)}

/* ─── MOBILE DROPDOWN ─── */
.mob-drop-wrap{border-bottom:1px solid rgba(0,0,0,.07)}
.mob-drop-btn{
  width:100%;background:none;border:none;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;
  padding:.75rem 0;font-size:1rem;color:var(--muted);font-family:inherit;
  font-weight:500;transition:color .2s;
}
.mob-drop-btn:hover{color:var(--text)}
.mob-drop{display:none;padding-left:1rem;padding-bottom:.5rem}
.mob-drop.open{display:flex;flex-direction:column}
.mob-drop a{padding:.5rem 0;font-size:.9rem;color:var(--muted);border:none;transition:color .2s}
.mob-drop a:hover{color:var(--red)}

/* ─── SERVICE CARD ADDITIONS ─── */
.sc-sub{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--red-l);margin-bottom:.4rem}
.sc-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:1.1rem;font-size:.82rem;font-weight:700;color:var(--red);transition:gap .2s}
.sc-link:hover{gap:.65rem}
.sc h3{font-size:1rem;font-weight:700;margin-bottom:.5rem;color:var(--text)}

/* ─── SUCCESS STORIES PREVIEW ─── */
#stories-preview{background:var(--dark2);padding:80px 5%}
.sp-head{text-align:center;margin-bottom:3rem}
.sp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:900px){.sp-grid{grid-template-columns:1fr}}
.sp-card{
  background:var(--card);border-radius:14px;padding:2rem;
  border:1px solid var(--border);
  box-shadow:0 2px 12px rgba(0,0,0,.04);
  transition:transform .3s,box-shadow .3s;
}
.sp-card:hover{transform:translateY(-4px);box-shadow:0 12px 30px rgba(0,0,0,.09)}
.sp-tag{display:inline-block;background:rgba(192,0,0,.1);color:var(--red);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.3rem .8rem;border-radius:999px;margin-bottom:1rem}
.sp-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.75rem;color:var(--text)}
.sp-card p{font-size:.85rem;color:var(--muted);line-height:1.7}
.sp-link{display:inline-flex;align-items:center;gap:.35rem;margin-top:1rem;font-size:.82rem;font-weight:700;color:var(--red);transition:gap .2s}
.sp-link:hover{gap:.65rem}

/* ─── FOOTER ADDITIONS ─── */
.ft-social{display:flex;gap:.6rem;margin-top:1rem}
.ft-dev{font-size:.78rem;color:var(--muted)}
.ft-dev a{color:var(--muted);text-decoration:underline}
.ft-contact-list{list-style:none}
.ft-contact-list li{font-size:.82rem;color:var(--muted);line-height:1.6;margin-bottom:.6rem}
.ft-contact-list a{color:var(--muted);transition:color .2s}
.ft-contact-list a:hover{color:var(--red)}

/* ─── INNER PAGES ─── */
.inner-banner{
  position:relative;min-height:280px;display:flex;align-items:flex-end;
  background:linear-gradient(135deg,#060d1f 0%,#0a2a5c 60%,#1a0505 100%);
  padding:0 5% 3rem;overflow:hidden;
}
.inner-banner::before{content:'';position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(3,78,151,.04) 2px,rgba(3,78,151,.04) 4px)}
.ib-ov{position:absolute;top:-160px;right:-80px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(192,0,0,.15) 0%,transparent 65%)}
.ib-inner{position:relative;z-index:2;color:#fff}
.ib-title{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2.2rem,5vw,3.8rem);font-weight:300;line-height:1.1;margin-top:.5rem}
.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.78rem;color:rgba(255,255,255,.55);margin-bottom:.75rem}
.breadcrumb a{color:rgba(255,255,255,.55);transition:color .2s}
.breadcrumb a:hover{color:#fff}
.bc-sep{opacity:.4}

.pg-section{padding:55px 5%}
.pg-section.bg-alt{background:var(--dark2)}
.pg-head{margin-bottom:3rem}

.pg-stats{display:flex;gap:2.5rem;flex-wrap:wrap;margin-top:2rem}
.pg-stat{text-align:center}
.pg-stat-n{font-family:'Barlow Condensed',sans-serif;font-size:2.4rem;font-weight:700;color:var(--red);line-height:1}
.pg-stat-n span{font-size:1.4rem}
.pg-stat-l{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;margin-top:.3rem}

/* VMV cards */
.vmv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:900px){.vmv-grid{grid-template-columns:1fr}}
.vmv-card{background:var(--card);border-radius:14px;padding:2rem;border:1px solid var(--border);box-shadow:0 2px 12px rgba(0,0,0,.04)}
.vmv-ic{width:54px;height:54px;background:rgba(192,0,0,.08);border:1px solid rgba(192,0,0,.15);border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:1.25rem}
.vmv-card h3{font-size:1.05rem;font-weight:700;margin-bottom:.75rem}
.vmv-card p{font-size:.85rem;color:var(--muted);line-height:1.75}

/* Values grid */
.vals-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
@media(max-width:900px){.vals-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.vals-grid{grid-template-columns:1fr}}
.val-card{background:var(--card);border-radius:14px;padding:1.75rem;border:1px solid var(--border)}
.val-ic{width:44px;height:44px;background:rgba(192,0,0,.08);border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--red);margin-bottom:1rem}
.val-card h4{font-size:.95rem;font-weight:700;margin-bottom:.6rem}
.val-card p{font-size:.83rem;color:var(--muted);line-height:1.7}

/* Vision/Values block */
.vv-block{display:grid;grid-template-columns:80px 1fr;gap:2rem;align-items:flex-start;max-width:800px}
@media(max-width:600px){.vv-block{grid-template-columns:1fr}}
.vv-icon{width:70px;height:70px;background:rgba(192,0,0,.08);border:1px solid rgba(192,0,0,.15);border-radius:14px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:.4rem}

/* Timeline */
.timeline{max-width:800px;margin:0 auto;position:relative}
.timeline::before{content:'';position:absolute;left:90px;top:0;bottom:0;width:2px;background:var(--border2)}
@media(max-width:600px){.timeline::before{left:0}}
.tl-item{display:grid;grid-template-columns:90px 1fr;gap:2rem;margin-bottom:3rem;position:relative}
@media(max-width:600px){.tl-item{grid-template-columns:1fr}}
.tl-year{font-family:'Barlow Condensed',sans-serif;font-size:1.3rem;font-weight:700;color:var(--red);text-align:right;padding-top:.2rem;position:relative}
.tl-year::after{content:'';position:absolute;right:-2.4rem;top:.6rem;width:14px;height:14px;border-radius:50%;background:var(--red);border:3px solid var(--dark);box-shadow:0 0 0 2px var(--red)}
@media(max-width:600px){.tl-year::after{display:none}.tl-year{text-align:left}}
.tl-body{background:var(--card);border-radius:12px;padding:1.5rem;border:1px solid var(--border)}
.tl-body h3{font-size:1rem;font-weight:700;margin-bottom:.6rem}
.tl-body p{font-size:.85rem;color:var(--muted);line-height:1.75}

/* Our Businesses alternating rows */
.biz-row{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-bottom:5rem}
.biz-row:last-child{margin-bottom:0}
.biz-flip .biz-img{order:2}
.biz-flip .biz-content{order:1}
@media(max-width:900px){.biz-row,.biz-flip{grid-template-columns:1fr}.biz-flip .biz-img,.biz-flip .biz-content{order:unset}}
.biz-img{position:relative;border-radius:16px;overflow:hidden}
.biz-img img{width:100%;height:340px;object-fit:cover}
.biz-num{position:absolute;top:1rem;left:1rem;font-family:'Barlow Condensed',sans-serif;font-size:4rem;font-weight:700;color:rgba(255,255,255,.15);line-height:1;pointer-events:none}

/* Success Stories cards */
.story-card{background:var(--card);border-radius:14px;padding:2.5rem;border:1px solid var(--border);margin-bottom:2rem;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.story-tag{display:inline-block;background:rgba(192,0,0,.1);color:var(--red);font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;padding:.3rem .8rem;border-radius:999px;margin-bottom:.75rem}
.story-card h3{font-size:1.15rem;font-weight:700;color:var(--text);margin-bottom:.4rem}
.story-card h4{font-size:.9rem;font-weight:600;color:var(--navy);margin-bottom:.9rem}
.story-card p{font-size:.87rem;color:var(--muted);line-height:1.8;margin-bottom:1.25rem}
.story-results{display:flex;flex-wrap:wrap;gap:.6rem}
.story-result{display:flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:600;color:var(--text);background:var(--dark2);padding:.35rem .8rem;border-radius:6px}

/* Contact page */
.ct-wrap{display:grid;grid-template-columns:1fr 1.2fr;gap:5rem;align-items:flex-start}
@media(max-width:900px){.ct-wrap{grid-template-columns:1fr;gap:3rem}}

/* CTA banner */
.pg-cta{background:linear-gradient(135deg,#060d1f 0%,#0a2a5c 100%);padding:80px 5%;text-align:center;color:#fff}
.pg-cta h2{font-family:'Barlow Condensed',sans-serif;font-size:clamp(2rem,4vw,3rem);font-weight:300;margin-bottom:1rem}
.pg-cta p{color:rgba(255,255,255,.65);margin-bottom:2rem;font-size:1rem}

/* THEME HEADER UPDATE */
/* Theme Name: Astron Group */

/* ─── RESPONSIVE ─── */
@media(max-width:768px){
  .nav-links,.nav-call,.nav-cta,.nav-contact-btn{display:none}
  .hamburger{display:flex}
  section{padding:70px 5%}
  .hero-stats{flex-wrap:wrap;width:100%}
  .hs{flex:1;min-width:120px;border-bottom:1px solid var(--border)}
  .hs:nth-child(odd){border-right:1px solid var(--border)}
  .hs:nth-child(3),.hs:nth-child(4){border-bottom:none}
}
