/*
Theme Name: Envicore Pro (ADE Look) Dynamic Hotfix
Theme URI: https://envicore.com.au
Author: Envicore
Author URI: https://envicore.com.au
Description: ADE-style theme for Envicore Consulting (blue/green). Includes Service CPT with admin-editable Expertise, Core Services, Support Services and Enquiries.
Version: 5.0.2
License: GPLv2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: envicore-pro-ade
Tested up to: 6.6
Requires PHP: 7.4
*/

:root {
  --blue:#1F5DAA;
  --green:#24B36B;
  --bg:#F7F9FB;
  --text:#000000;
  --muted:#4A5565;
  --card:#FFFFFF;
  --border:#E6ECF3;
  --shadow: 0 10px 24px rgba(10, 24, 54, 0.08);
  --radius: 16px;
  --max: 1200px;
}

/* ==========================================================
   ADE-style services pages (archive + single)
   ========================================================== */

.services-hero{padding:48px 0 10px;background:#fff;}
.services-hero__grid{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:end;}
.services-hero h1{margin:0;font-size:54px;line-height:1.05;letter-spacing:-0.02em;}
.services-hero__right p{margin:0;color:rgba(0,0,0,.65);font-size:16px;}

.services-index{padding:20px 0 70px;background:#fff;}
.services-index__grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;}
.service-tile{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:18px 18px;border-radius:12px;background:#0f6f80;color:#fff;text-decoration:none;}
.service-tile:hover{filter:brightness(1.05);}
.service-tile__num{font-weight:700;font-size:42px;opacity:.85;}
.service-tile__title{font-weight:700;font-size:16px;line-height:1.2;max-width:160px;text-align:left;}

@media (max-width: 1024px){
  .services-index__grid{grid-template-columns:repeat(2,minmax(0,1fr));}
  .services-hero__grid{grid-template-columns:1fr;}
  .services-hero h1{font-size:42px;}
}

@media (max-width: 520px){
  .services-index__grid{grid-template-columns:1fr;}
}

/* Single service page */
.service-hero{padding:48px 0;background:#fff;}
.service-hero__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:26px;align-items:center;}
.service-hero__kicker{color:rgba(0,0,0,.55);font-size:12px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px;}
.service-hero__title{margin:0 0 14px;font-size:44px;line-height:1.08;letter-spacing:-0.02em;}
.service-hero__blurb{margin:0;color:rgba(0,0,0,.65);max-width:520px;}
.service-hero__image{width:100%;height:320px;object-fit:cover;border-radius:14px;}

.service-expertise{padding:26px 0 10px;background:#fff;}
.service-expertise h2{text-align:center;margin:0 0 14px;font-size:26px;}
.service-expertise p{max-width:900px;margin:0 auto 10px;color:rgba(0,0,0,.65);}

.service-core{padding:26px 0 40px;background:#fff;}
.service-core h2{text-align:center;margin:0 0 18px;font-size:26px;}
.service-core__grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.core-box{border-radius:14px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#fff;}
.core-box__head{background:#0f6f80;color:#fff;font-weight:700;padding:14px 16px;}
.core-box__list{list-style:none;margin:0;padding:14px 18px;}
.core-box__list li{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.06);color:rgba(0,0,0,.75);}
.core-box__list li:last-child{border-bottom:none;}

.service-cards{margin-top:18px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;}
.service-card{border-radius:14px;overflow:hidden;border:1px solid rgba(0,0,0,.08);background:#fff;}
.service-card__head{background:#0f6f80;color:#fff;font-weight:700;padding:14px 16px;}
.service-card__list{list-style:none;margin:0;padding:14px 18px;}
.service-card__list li{padding:8px 0;border-bottom:1px solid rgba(0,0,0,.06);color:rgba(0,0,0,.75);}
.service-card__list li:last-child{border-bottom:none;}

.service-support{padding:30px 0 20px;background:#fff;}
.service-support h2{text-align:center;margin:0 0 12px;font-size:26px;}
.service-support p{max-width:900px;margin:0 auto 14px;color:rgba(0,0,0,.65);text-align:center;}
.support-box{max-width:900px;margin:0 auto;border-radius:14px;border:1px solid rgba(0,0,0,.08);padding:16px 18px;}
.support-box ul{margin:0;padding-left:18px;color:rgba(0,0,0,.75);}

.service-enquiries{padding:36px 0 70px;background:#fff;}
.enquiries-grid{display:grid;grid-template-columns:1fr 2fr;gap:18px;border-radius:14px;overflow:hidden;border:1px solid rgba(0,0,0,.08);}
.enquiries-left{background:#0f6f80;color:#fff;padding:22px;display:flex;align-items:center;}
.enquiries-title{font-size:28px;font-weight:700;}
.enquiries-right{padding:18px 22px;background:#fff;}
.enquiries-person{padding:10px 0;border-bottom:1px solid rgba(0,0,0,.06);}
.enquiries-person:last-child{border-bottom:none;}
.enquiries-person__name{font-weight:700;margin-bottom:2px;}
.enquiries-person__role{color:rgba(0,0,0,.65);font-size:13px;margin-bottom:8px;}
.enquiries-person__meta a{color:#0f6f80;text-decoration:none;}
.enquiries-person__meta a:hover{text-decoration:underline;}

@media (max-width: 1024px){
  .service-hero__grid{grid-template-columns:1fr;}
  .service-hero__image{height:260px;}
  .service-cards{grid-template-columns:1fr;}
  .service-core__grid{grid-template-columns:1fr;}
  .enquiries-grid{grid-template-columns:1fr;}
}

/* ==========================================================
   ADE-style footer
   ========================================================== */

.site-footer{background:#0b1220;color:#fff;}
.site-footer a{color:#fff;text-decoration:none;}
.site-footer a:hover{text-decoration:underline;}
.site-footer .footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:26px;padding:44px 0;align-items:start;}
.site-footer .footer-col h4{margin:0 0 12px;font-size:16px;}
.site-footer .footer-col ul{list-style:none;margin:0;padding:0;}
.site-footer .footer-col li{margin:0 0 10px;}
.footer-contact{margin:0 0 14px;color:rgba(255,255,255,.85);}
.footer-social{display:flex;gap:10px;}
.social-btn{width:40px;height:40px;border-radius:999px;border:1px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;}
.footer-brand{display:flex;justify-content:flex-end;}
.footer-logo img{max-width:170px;height:auto;}
.footer-logo-text{font-weight:800;font-size:20px;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:14px 0;color:rgba(255,255,255,.75);font-size:13px;}

@media (max-width: 1024px){
  .site-footer .footer-grid{grid-template-columns:1fr 1fr;}
  .footer-brand{justify-content:flex-start;}
}

@media (max-width: 520px){
  .site-footer .footer-grid{grid-template-columns:1fr;}
}

/* ==========================================================
   Mobile menu fixes
   ========================================================== */

.mobile-menu{z-index:9999;}
.mobile-menu.is-open{display:block;}
html.no-scroll, body.no-scroll{overflow:hidden;}

.mobile-nav li.menu-item-has-children ul{display:none;}
.mobile-nav li.menu-item-has-children.submenu-open ul{display:block;}
.mobile-nav .row{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.mobile-nav .submenu-toggle{width:36px;height:36px;border-radius:10px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.08);color:#fff;font-size:20px;line-height:1;}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Helvetica Neue", sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
a{color:inherit}
img{max-width:100%; height:auto}
.wrap{max-width:var(--max); margin:0 auto; padding:0 20px}
.topbar{
  position:sticky; top:0; z-index:999;
  background:rgba(247,249,251,.9);
  backdrop-filter: blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 0; gap:16px;
}
.brand{display:flex; align-items:center; gap:12px; text-decoration:none}
.logo-mark{
  width:40px; height:40px; border-radius:12px;
  background:linear-gradient(135deg,var(--blue),var(--green));
  box-shadow: var(--shadow);
  flex:0 0 auto;
}
.brand strong{font-size:16px; letter-spacing:.2px}
.brand small{display:block; color:var(--muted); font-size:12px; margin-top:-2px}

.menu .desktop-nav{list-style:none; margin:0; padding:0; display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.menu .desktop-nav a{
  text-decoration:none;
  padding:8px 10px;
  border-radius:12px;
  color:var(--muted);
  font-weight:600;
  font-size:14px;
  display:inline-block;
}
.menu .desktop-nav a:hover{background:#fff; color:var(--text); box-shadow:0 1px 0 rgba(0,0,0,.03)}
.menu .desktop-nav .current-menu-item > a, .menu .desktop-nav .current_page_item > a{background:#fff; color:var(--text)}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius:14px;
  font-weight:800;
  text-decoration:none;
  border:1px solid transparent;
  gap:8px;
  font-size:14px;
}
.btn.primary{background:var(--blue); color:#fff; box-shadow: var(--shadow)}
.btn.primary:hover{filter:brightness(.95)}
.btn.outline{background:transparent; border-color:rgba(31,93,170,.35); color:var(--blue)}
.btn.outline:hover{background:#fff}
.btn.green{background:var(--green); color:#0b2a1a}

.section{padding:80px 0}
.section.tight{padding:54px 0}
.grid{display:grid; gap:18px}
.cards-3{grid-template-columns: repeat(3, minmax(0,1fr))}
.cards-2{grid-template-columns: repeat(2, minmax(0,1fr))}
.cards-4{grid-template-columns: repeat(4, minmax(0,1fr))}

.kicker{
  display:flex; align-items:center; gap:10px;
  font-weight:900; color:var(--blue);
  letter-spacing:.3px;
  text-transform:uppercase;
  font-size:12px;
  margin-bottom:10px;
}
.kicker .line{flex:1;height:1px;background:var(--border)}
.dot{width:8px;height:8px;border-radius:999px;background:var(--green)}

.h1{
  font-size: clamp(32px, 4vw, 54px);
  line-height:1.06;
  margin:0 0 14px;
  letter-spacing:-.6px;
}
.h2{
  font-size: clamp(24px, 3vw, 38px);
  line-height:1.15;
  margin:0 0 12px;
  letter-spacing:-.4px;
}
.lead{color:var(--muted); font-size:18px; margin:0 0 18px; max-width:62ch}
.sub{color:var(--muted); font-weight:650; margin:0 0 18px; max-width:70ch}

.hero{display:grid; grid-template-columns: 1.2fr .8fr; align-items:center; gap:24px; padding:26px 0 8px}
.photo{
  background:#fff;
  border:1px solid var(--border);
  border-radius:22px;
  box-shadow: var(--shadow);
  overflow:hidden;
  min-height:320px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.photo .hint{padding:34px 24px 24px; text-align:center; color:var(--muted); max-width:42ch; font-weight:700}
.float-tags{position:absolute; bottom:16px; left:16px; display:flex; gap:10px; flex-wrap:wrap}

.tag{
  display:inline-flex; align-items:center; gap:8px;
  padding:7px 10px;
  border-radius:999px;
  background:#fff;
  border:1px solid var(--border);
  color:var(--muted);
  font-weight:700;
  font-size:12px;
}

.actions{display:flex; gap:12px; flex-wrap:wrap; margin:18px 0 10px}

.card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 1px 0 rgba(0,0,0,.03);
  padding:18px;
}
.card:hover{box-shadow: var(--shadow)}
.icon{
  width:44px;height:44px;border-radius:14px;
  background:rgba(31,93,170,.08);
  border:1px solid rgba(31,93,170,.18);
  display:flex; align-items:center; justify-content:center;
  font-weight:900; color:var(--blue);
  margin-bottom:12px;
}
.card h3{margin:0 0 6px; font-size:16px}
.card p{margin:0 0 10px; color:var(--muted); font-weight:600}

.link{color:var(--blue); font-weight:900; text-decoration:none}
.link:hover{text-decoration:underline}

.split{display:grid; grid-template-columns: 1fr 1fr; gap:18px; align-items:start}
.checklist{margin:0; padding-left:18px}
.checklist li{margin:8px 0; color:var(--muted); font-weight:650}

.band{
  background:linear-gradient(135deg, rgba(31,93,170,.12), rgba(36,179,107,.10));
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
}
.cta{display:grid; grid-template-columns: 1.2fr .8fr; gap:18px; align-items:center}
.enquiry{border-left:4px solid var(--green)}
.meta{color:var(--muted); font-weight:750}

.pillrow{display:flex; flex-wrap:wrap; gap:10px}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  background:#fff;
  border:1px solid var(--border);
  padding:10px 12px;
  border-radius:999px;
  font-weight:800;
  color:var(--muted);
}

.footer{
  background:#fff;
  border-top:1px solid var(--border);
  padding:46px 0;
}
.footgrid{display:grid; grid-template-columns: 1.1fr 1fr 1fr; gap:18px}
.footgrid h4{margin:0 0 12px}
.footgrid a{display:block; color:var(--muted); text-decoration:none; font-weight:650; margin:6px 0}
.footgrid a:hover{color:var(--text)}
.copyright{margin-top:18px; color:var(--muted); font-weight:650}

.breadcrumbs{font-size:12px; color:var(--muted); font-weight:750; margin:16px 0 10px}

.form{display:grid; gap:12px}
input, select, textarea{
  width:100%;
  padding:12px 12px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  font:inherit;
}
textarea{min-height:120px; resize:vertical}
.notice{font-size:12px; color:var(--muted); font-weight:650; margin-top:10px}

@media (max-width: 980px){
  .hero, .split, .cta{grid-template-columns:1fr}
  .cards-3{grid-template-columns:1fr}
  .cards-4{grid-template-columns:1fr 1fr}
  .footgrid{grid-template-columns:1fr}
  .photo{min-height:280px}
}
@media (max-width: 520px){
  .cards-4{grid-template-columns:1fr}
}

.photo img{width:100%;height:100%;object-fit:cover;display:block}

/* Mobile menu */
.hamburger{
  display:none;
  width:44px;height:44px;
  border-radius:14px;
  border:1px solid var(--border);
  background:#fff;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 1px 0 rgba(0,0,0,.03);
}
.hamburger span{
  width:18px;height:2px;background:#000;border-radius:4px;display:block;position:relative;
}
.hamburger span:before,.hamburger span:after{
  content:"";
  width:18px;height:2px;background:#000;border-radius:4px;display:block;position:absolute;left:0;
}
.hamburger span:before{top:-6px}
.hamburger span:after{top:6px}

.mobile-menu{
  display:none !important;
  background:#fff;
  border-bottom:1px solid var(--border);
}

/* Full-height scrollable mobile menu (so submenu doesn't get cut off) */
.mobile-menu.is-open{
  position:fixed;
  left:0;
  right:0;
  top:72px; /* header height */
  bottom:0;
  overflow-y:auto;
  -webkit-overflow-scrolling:touch;
  z-index:9998;
}

.mobile-menu .wrap{padding:0 20px}
.mobile-menu ul{list-style:none;margin:0;padding:10px 0;display:flex;flex-direction:column;gap:6px}
.mobile-menu a{padding:12px 10px;border-radius:12px;color:var(--muted);font-weight:800;text-decoration:none}
.mobile-menu a:hover{background:var(--bg);color:#000}
.mobile-menu .btn{width:100%}
.mobile-menu.is-open{display:block !important}

.footer-bottom small.footer-rights{display:block; text-align:center; font-weight:800; letter-spacing:.2px}
.footer-bottom small.footer-rights .sep{opacity:.7; padding:0 6px}

/* Responsive enhancements */
@media (max-width: 1024px){
  .cards-3{grid-template-columns: repeat(2, minmax(0,1fr))}
  .hero{grid-template-columns:1fr; padding-top:18px}
}
@media (max-width: 640px){
  .cards-2,.cards-3,.cards-4{grid-template-columns:1fr}
  .actions .btn{width:100%}
  .tag,.pill{width:fit-content}
  .photo{min-height:220px}
  .nav{padding:10px 0}
  .menu{display:none}
  .hamburger{display:inline-flex}
}

/* Mobile bottom action bar */
.mobile-bottom-bar{
  display:none;
  position:fixed;
  left:0; right:0; bottom:0;
  z-index:9999;
  padding:10px 12px calc(10px + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.94);
  backdrop-filter: blur(10px);
  border-top:1px solid var(--border);
}
.mobile-bottom-bar .bar{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:10px;
  max-width:var(--max);
  margin:0 auto;
}
.mobile-bottom-bar .btn{
  border-radius:14px;
  padding:12px 14px;
  font-size:14px;
}
body.has-mobile-bar{ padding-bottom: 78px; }

@media (max-width: 640px){
  .mobile-bottom-bar{display:block;}
}

/* Floating WhatsApp button */

.whatsapp-float:hover{ filter:brightness(.95); }
.whatsapp-float svg{ width:26px; height:26px; display:block; }



.whatsapp-float svg{ width:22px; height:22px; display:block; }
@media (max-width: 640px){
  .whatsapp-float{ bottom:92px; } /* keep above mobile bottom bar */
}

/* Desktop dropdown menus */
.menu .desktop-nav > li{position:relative}
.menu .desktop-nav ul{
  position:absolute;
  top:100%;
  right:0;
  min-width: 240px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:8px;
  box-shadow: var(--shadow);
  display:none;
}
.menu .desktop-nav ul li{width:100%}
.menu .desktop-nav ul a{display:block; padding:10px 10px; border-radius:12px; color:var(--muted)}
.menu .desktop-nav > li:hover > ul{display:block}
.menu .desktop-nav > li:focus-within > ul{display:block}

/* Mobile submenu toggle */
.mobile-menu .mobile-nav li{position:relative}
.mobile-menu .mobile-nav ul{
  display:none;
  padding-left:12px;
  border-left:2px solid var(--border);
  margin-left:6px;
}
.mobile-menu .mobile-nav li.is-open > ul{display:block}
.mobile-menu .submenu-toggle{
  width:40px;height:40px;
  border-radius:12px;
  border:1px solid var(--border);
  background:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.mobile-menu .row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.mobile-menu .row a{flex:1}

.mobile-menu .wrap{padding:0 20px}
.mobile-menu .mobile-nav{list-style:none;margin:0;padding:10px 0;display:flex;flex-direction:column;gap:6px}
.mobile-menu .mobile-nav a{padding:12px 10px;border-radius:12px;color:var(--muted);font-weight:800;text-decoration:none;display:block}
.mobile-menu .mobile-nav a:hover{background:var(--bg);color:#000}

/* --- NAV OVERRIDES (robust, prevents auto-open/unstyled lists) --- */
.menu ul, .menu .desktop-nav{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.menu ul a, .menu .desktop-nav a{
  display:inline-block;
  padding:10px 14px;
  border-radius:999px;
  font-weight:800;
  text-decoration:none;
  color:var(--muted);
}
.menu ul a:hover{background:var(--bg); color:#000}
.menu ul .current-menu-item > a, .menu ul .current_page_item > a{
  background:#fff;
  border:1px solid var(--border);
  color:#000;
  box-shadow:0 10px 24px rgba(17,24,39,.06);
}

/* Desktop dropdown */
.menu ul li{position:relative}
.menu ul ul{
  position:absolute;
  top:100%;
  right:0;
  min-width:240px;
  background:#fff;
  border:1px solid var(--border);
  border-radius:14px;
  padding:8px;
  box-shadow: var(--shadow);
  display:none;
}
.menu ul li:hover > ul,
.menu ul li:focus-within > ul{display:block}
.menu ul ul a{display:block; padding:10px 12px; border-radius:12px}

/* Hamburger only on mobile */
.hamburger{display:none}
@media (max-width: 640px){
  .menu{display:none !important;}
  .hamburger{display:inline-flex;}
}

/* Mobile menu hidden unless open */
.mobile-menu{display:none !important;}
.mobile-menu.is-open{display:block !important;}
.mobile-menu .mobile-nav, .mobile-menu ul{
  list-style:none;margin:0;padding:10px 0;
  display:flex;flex-direction:column;gap:6px;
}
.mobile-menu a{display:block;padding:12px 10px;border-radius:12px;color:var(--muted);font-weight:800;text-decoration:none}
.mobile-menu a:hover{background:var(--bg);color:#000}

/* Mobile submenus */
.mobile-menu ul ul{display:none;padding-left:12px;border-left:2px solid var(--border);margin-left:6px}
.mobile-menu li.is-open > ul{display:block}

/* --- MOBILE MENU OVERLAY FIX --- */
@media (max-width: 640px){
  .mobile-menu{
    position:fixed;
    top:0;
    left:0;
    right:0;
    bottom:0;
    background:#ffffff;
    z-index:99999;
    overflow-y:auto;
    padding-top:80px; /* space for header */
  }
  .mobile-menu .wrap{
    max-width:100%;
  }
  body.mobile-open{
    overflow:hidden;
  }
}

/* Header contact (desktop) */
.header-contact{
  display:none;
  gap:10px;
  align-items:center;
  font-size:13px;
  color:var(--muted);
  margin-right:auto;
}
.hc-link{color:var(--muted); text-decoration:none; font-weight:700}
.hc-link:hover{color:#000}
.hc-sep{opacity:.5}
@media (min-width: 900px){
  .header-contact{display:flex;}
}

/* WhatsApp floating button (compact) */
.whatsapp-float{
  position:fixed;
  right:14px;
  bottom:14px;
  z-index:99999;
  width:44px;
  height:44px;
  border-radius:14px;
  background: var(--green);
  color:#fff;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  box-shadow: var(--shadow);
}
.whatsapp-float svg{ width:22px; height:22px; display:block; }
@media (max-width: 640px){
  .whatsapp-float{ bottom:92px; } /* above mobile bottom bar */
}

/* ADE-like mobile menu */
@media (max-width: 640px){
  .mobile-menu{
    position:fixed;
    top:0; left:0; right:0; bottom:0;
    z-index:99999;
    display:none !important;
    background:#0b1220;
  }
  .mobile-menu.is-open{display:block !important;}
  .mm-top{position:relative; height:160px; overflow:hidden;}
  .mm-cover img{width:100%;height:100%;object-fit:cover; filter:saturate(1.1) contrast(1.05);}
  .mm-top:after{
    content:"";
    position:absolute; inset:0;
    background:linear-gradient(180deg, rgba(11,18,32,.25), rgba(11,18,32,.7));
  }
  .mm-brand{
    position:absolute; left:16px; bottom:14px; z-index:2;
    max-width:240px;
  }
  .mm-brand img{
    height:46px; width:auto; display:block;
    background:rgba(255,255,255,.06);
    border-radius:10px;
    padding:6px 8px;
    backdrop-filter: blur(8px);
  }
  .mm-close{
    position:absolute; right:16px; top:16px; z-index:2;
    width:44px; height:44px;
    border-radius:12px;
    border:0;
    background: rgba(62, 186, 255, .95);
    color:#fff;
    font-size:28px;
    line-height:44px;
    cursor:pointer;
  }
  .mm-panel{
    background:#eaf2f7;
    height:calc(100% - 160px);
    overflow:auto;
    border-top:3px solid rgba(62,186,255,.9);
  }
  .mm-panel .wrap{padding:12px 0;}
  .mobile-menu .mobile-nav{
    list-style:none;
    margin:0;
    padding:0;
    background:#eaf2f7;
  }
  .mobile-menu .mobile-nav > li{border-bottom:1px solid rgba(11,18,32,.08);}
  .mobile-menu .mobile-nav > li > a{
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:16px 18px;
    font-size:20px;
    font-weight:800;
    color:#0b1220;
    text-decoration:none;
  }
  .mobile-menu .mobile-nav > li > a:hover{background:rgba(255,255,255,.65)}
  .mobile-menu ul ul{
    display:none;
    padding:0;
    margin:0;
    background:#eaf2f7;
  }
  .mobile-menu li.is-open > ul{display:block;}
  .mobile-menu ul ul a{
    display:block;
    padding:14px 18px 14px 32px;
    font-size:18px;
    font-weight:700;
    color:#0b1220;
    text-decoration:none;
    border-top:1px solid rgba(11,18,32,.06);
  }
  .mobile-menu ul ul a:hover{background:rgba(255,255,255,.65)}
  .mobile-menu .submenu-toggle{
    width:44px;height:44px;
    border-radius:12px;
    border:0;
    background:transparent;
    color:#0b1220;
    font-size:18px;
    display:inline-flex;
    align-items:center;
    justify-content:center;
    cursor:pointer;
  }
  .mobile-menu .row{display:flex; align-items:center; justify-content:space-between;}
}
body.mobile-open{overflow:hidden;}

/* Force nav visibility by breakpoint */
@media (max-width: 640px){
  .menu{display:none !important;}
}
@media (min-width: 641px){
  .mobile-menu{display:none !important;}
}

/* Blog featured images */
.card-thumb{display:block; border-radius:16px; overflow:hidden; margin-bottom:12px; border:1px solid var(--border); background:#fff}
.card-thumb img{width:100%; height:180px; object-fit:cover; display:block}
.post-hero{margin:14px 0 18px; border-radius:18px; overflow:hidden; border:1px solid var(--border); background:#fff}
.post-hero img{width:100%; height:auto; display:block}

/* ADE-LIKE LAYOUT LAYER */
:root{
  --container: 1180px;
}

.container{
  width: min(var(--container), calc(100% - 40px));
  margin: 0 auto;
}

.section{
  padding: 86px 0;
}

.section-head{
  display:flex;
  align-items:flex-end;
  justify-content:space-between;
  gap:20px;
  margin-bottom: 28px;
}
.section-head h2{margin:0; font-size:48px; letter-spacing:-.02em}
.section-head p{margin:0; max-width:560px; color:var(--muted); font-weight:600}

@media (max-width: 900px){
  .section{padding:64px 0}
  .section-head{flex-direction:column; align-items:flex-start}
  .section-head h2{font-size:40px}
}
@media (max-width: 640px){
  .section{padding:54px 0}
  .section-head h2{font-size:34px}
}

/* HERO */
.hero--cover{
  position:relative;
  min-height: 560px;
  overflow:hidden;
  margin: 0;
}
.hero-bg img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.hero-overlay{position:absolute; inset:0; background: linear-gradient(90deg, rgba(6,20,30,.74) 0%, rgba(6,20,30,.35) 55%, rgba(6,20,30,.10) 100%);}
.hero-inner{
  position:relative;
  width: min(var(--container), calc(100% - 40px));
  margin: 0 auto;
  padding: 110px 0 90px;
  color:#fff;
}
.eyebrow{letter-spacing:.12em; font-weight:800; font-size:13px; opacity:.92}
.hero-title{margin:10px 0 12px; font-size:56px; letter-spacing:-.03em}
.hero-sub{margin:0 0 26px; max-width: 560px; font-size:18px; color: rgba(255,255,255,.88); font-weight:600}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap}

@media (max-width: 900px){
  .hero-inner{padding:92px 0 70px}
  .hero-title{font-size:46px}
}
@media (max-width: 640px){
  .hero--cover{min-height: 520px}
  .hero-inner{padding:88px 0 64px}
  .hero-title{font-size:38px}
  .hero-sub{font-size:16px}
}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; padding:12px 18px; border-radius:14px; font-weight:800; text-decoration:none}
.btn-primary{background: var(--blue); color:#fff}
.btn-primary:hover{filter:brightness(.96)}
.btn-ghost{background: rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.25); color:#fff}
.btn-ghost:hover{background: rgba(255,255,255,.18)}

/* Services grid */
.services-grid{
  display:grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}
.service-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:18px;
  padding:18px 16px;
  text-decoration:none;
  position:relative;
  min-height: 130px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  box-shadow:0 14px 30px rgba(17,24,39,.06);
}
.service-no{font-weight:900; color: rgba(11,18,32,.55)}
.service-card h3{margin:8px 0 0; font-size:18px; color:#000; letter-spacing:-.01em}
.service-card-arrow{position:absolute; right:16px; bottom:14px; color: rgba(11,18,32,.55); font-weight:900}
.service-card:hover{transform: translateY(-2px); box-shadow:0 18px 38px rgba(17,24,39,.10)}
@media (max-width: 1100px){ .services-grid{grid-template-columns: repeat(3, 1fr);} }
@media (max-width: 720px){ .services-grid{grid-template-columns: 1fr; } .service-card{min-height:auto;} }

/* Split section */
.split-grid{display:grid; grid-template-columns: 1.1fr .9fr; gap:28px; align-items:center}
.split-media img{width:100%; height:420px; object-fit:cover; border-radius:22px; border:1px solid var(--border); box-shadow: var(--shadow)}
.split-content h2{font-size:44px; margin:0 0 12px; letter-spacing:-.02em}
.split-content p{margin:0 0 18px; color:var(--muted); font-weight:600}
@media (max-width: 900px){
  .split-grid{grid-template-columns:1fr; }
  .split-media img{height:320px}
  .split-content h2{font-size:36px}
}

/* Cards */
.cards-3{display:grid; grid-template-columns: repeat(3, 1fr); gap:18px}
.card{background:#fff; border:1px solid var(--border); border-radius:22px; overflow:hidden; text-decoration:none; color:inherit; box-shadow:0 14px 30px rgba(17,24,39,.06)}
.card-media img{width:100%; height:220px; object-fit:cover; display:block}
.card-body{padding:18px}
.card-body h3{margin:0 0 8px; font-size:20px; letter-spacing:-.01em}
.card-body p{margin:0 0 10px; color:var(--muted); font-weight:600}
.card-link{font-weight:800; color:var(--blue)}
.card:hover{transform: translateY(-2px); box-shadow:0 18px 38px rgba(17,24,39,.10)}
@media (max-width: 980px){ .cards-3{grid-template-columns: 1fr;} .card-media img{height:240px} }

/* Accreditations */
.logo-strip{display:flex; flex-wrap:wrap; gap:12px}
.logo-pill{
  background:#fff;
  border:1px solid var(--border);
  border-radius:999px;
  padding:12px 16px;
  font-weight:800;
  color:#0b1220;
  box-shadow:0 12px 24px rgba(17,24,39,.06);
}


/* Desktop dropdown navigation (ADE-like) */
@media (min-width: 641px){
  .menu{position:relative;}
  .menu > li{position:relative;}
  .menu > li > a{padding:10px 12px; border-radius:12px;}
  .menu li.menu-item-has-children > a:after{
    content:"▾";
    font-size:12px;
    margin-left:6px;
    opacity:.7;
  }
  .menu li ul{
    position:absolute;
    top: calc(100% + 10px);
    left: 0;
    min-width: 260px;
    background:#ffffff;
    border:1px solid var(--border);
    border-radius:16px;
    box-shadow:0 18px 40px rgba(17,24,39,.14);
    padding:10px;
    display:none;
    z-index:9999;
  }
  .menu li ul li{margin:0;}
  .menu li ul a{
    display:block;
    padding:10px 12px;
    border-radius:12px;
    color:#0b1220;
    font-weight:800;
    text-decoration:none;
    white-space:nowrap;
  }
  .menu li ul a:hover{background: rgba(11,18,32,.06);}
  .menu li:hover > ul,
  .menu li:focus-within > ul{display:block;}
}


/* ADE-LIKE HEADER */
.topbar{
  position: absolute;
  top:0; left:0; right:0;
  z-index: 1000;
  background: rgba(8,18,28,.35);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.topbar .wrap{max-width: var(--container); margin:0 auto; padding: 14px 20px;}
.topbar .nav{display:flex; align-items:center; justify-content:space-between; gap:16px;}
.brand img{height:44px !important;}
.primary-nav{display:block;}
.primary-nav .menu-list{list-style:none; margin:0; padding:0; display:flex; gap:16px; align-items:center; flex-wrap:nowrap;}
.menu.mobile-nav-list{list-style:none; margin:0; padding:0;}

/* Desktop dropdown behaviour (ADE-like) */
@media (min-width: 901px){
  .primary-nav .menu-list li{position:relative;}
  .primary-nav .menu-list li > ul{
    display:none;
    position:absolute;
    left:0;
    top: calc(100% + 10px);
    min-width:260px;
    padding:10px 0;
    margin:0;
    list-style:none;
    border-radius:12px;
    background: rgba(255,255,255,.95);
    box-shadow: 0 18px 44px rgba(0,0,0,.25);
    border: 1px solid rgba(0,0,0,.06);
    z-index:9999;
  }
  .primary-nav .menu-list li:hover > ul{display:block;}
  .primary-nav .menu-list li > ul a{
    display:block;
    padding:10px 14px;
    text-decoration:none;
    color:#0b1220;
    font-weight:700;
    white-space:nowrap;
  }
  .primary-nav .menu-list li > ul a:hover{background: rgba(0, 188, 212, 0.12);}
}
.primary-nav .menu-list > li > a{
  color:#fff;
  font-weight:800;
  text-decoration:none;
  padding:10px 12px;
  border-radius:12px;
}
.primary-nav .menu-list > li > a:hover{background: rgba(255,255,255,.10);}

@media (max-width: 900px){
  .primary-nav{display:none;}
  .hamburger{display:inline-flex;}
  .topbar{position:sticky; background: rgba(255,255,255,.92); backdrop-filter: blur(10px);}
  .primary-nav .menu-list > li > a{color:#0b1220;}
}

/* Ensure desktop submenu opens cleanly */
@media (min-width: 901px){
  .menu-list li ul{
    top: calc(100% + 8px) !important;
  }
  .menu-list li ul a{color:#0b1220 !important;}
}


/* Services card layout closer to ADE */
.service-card{
  padding:0 !important;
  overflow:hidden;
}
.service-card .service-thumb{
  height:160px;
  background:#e7eef6;
}
.service-card .service-thumb img{
  width:100%; height:100%; object-fit:cover; display:block;
}
.service-card .service-meta{
  display:flex;
  align-items:center;
  gap:14px;
  padding:16px 16px 18px;
}
.service-no{
  font-size:44px;
  line-height:1;
  color: rgba(0,140,170,.95);
  font-weight:900;
}
.service-card h3{
  margin:0;
  font-size:18px;
}
.service-card-arrow{
  right:14px !important;
  bottom:18px !important;
  width:34px; height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  border:1px solid rgba(11,18,32,.12);
  background:#fff;
}
@media (max-width: 1100px){
  .service-card .service-thumb{height:150px;}
}


/* FIX: prevent menu wrapping/repeating and hide overlay on desktop */
.primary-nav .menu-list{flex-wrap:nowrap; white-space:nowrap;}
.primary-nav .menu-list > li{flex:0 0 auto;}
.primary-nav .menu-list > li > a{white-space:nowrap;}
.primary-nav{overflow:hidden;}

.mobile-overlay{display:none;}
.mobile-overlay.is-open{display:block;}
@media (min-width: 901px){
  .mobile-overlay{display:none !important;}
}
@media (max-width: 900px){
  .mobile-overlay{position:fixed; inset:0; z-index:2000; display:none; background:rgba(0,0,0,.55);}
  .mobile-overlay.is-open{display:block;}
  .mobile-overlay .panel{
    position:absolute; left:12px; right:12px; top:12px;
    background:#fff; border-radius:18px; overflow:hidden;
    box-shadow:0 24px 64px rgba(0,0,0,.22);
  }
  .mobile-overlay .panel .head{
    background:#0b1220; padding:14px 14px; display:flex; align-items:center; justify-content:space-between;
  }
  .mobile-overlay .panel .head .logo{height:36px;}
  .mobile-overlay .panel .close{
    width:40px; height:40px; border-radius:12px; border:0; background:#1b2a43; color:#fff; font-size:22px;
  }
  .mobile-overlay .panel .body{padding:10px 10px 14px; max-height: calc(100vh - 90px); overflow:auto;}
  .mobile-overlay .mobile-nav-list{list-style:none; margin:0; padding:0;}
  .mobile-overlay .mobile-nav-list > li > a{
    display:flex; align-items:center; justify-content:space-between;
    padding:14px 12px; border-radius:12px; font-weight:900; color:#0b1220; text-decoration:none;
  }
  .mobile-overlay .mobile-nav-list > li > a:hover{background:rgba(11,18,32,.06);}
  .mobile-overlay .mobile-nav-list li ul{display:none; padding:0 0 6px 10px; margin:0;}
  .mobile-overlay .mobile-nav-list li.is-open > ul{display:block;}
  .mobile-overlay .mobile-nav-list li ul a{
    display:block; padding:10px 12px; border-radius:12px; font-weight:800; color:#0b1220; text-decoration:none;
  }
}


/* Footer layout polish */
.site-footer{background:#f6f8fb; border-top:1px solid rgba(11,18,32,.08);}
.footer-grid{display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap:30px; padding:48px 0;}
.footer-grid h4{margin:0 0 12px; font-size:16px;}
.footer-grid a{text-decoration:none; color:#0b1220;}
.footer-grid a:hover{text-decoration:underline;}
.footer-bottom{background:#00a6c8; color:#fff; padding:14px 0; margin-top:10px;}
.footer-bottom .wrap{display:flex; justify-content:space-between; align-items:center; gap:12px;}
@media(max-width: 900px){
  .footer-grid{grid-template-columns:1fr; gap:18px;}
  .footer-bottom .wrap{flex-direction:column; align-items:flex-start;}
}


/* Service detail template */
.svc-hero{padding:110px 0 40px; background:#f6f8fb;}
.svc-hero-grid{display:grid; grid-template-columns: 1.2fr 1fr; gap:40px; align-items:center;}
.svc-hero h1{font-size:56px; line-height:1.05; margin:0;}
.svc-hero-media img{width:100%; height:auto; border-radius:18px; object-fit:cover; display:block;}
.svc-intro{padding:26px 0 20px;}
.svc-intro h2{font-size:40px; text-align:center; margin:0 0 14px;}
.svc-intro .lead{max-width:920px; margin:0 auto; text-align:center; color:rgba(11,18,32,.78); font-size:18px;}
.svc-core{padding:26px 0 46px;}
.svc-core h2{text-align:center; font-size:44px; margin:0 0 24px;}
.svc-core-grid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:24px;}
.svc-core-card{border:1px solid rgba(11,18,32,.10); border-radius:18px; overflow:hidden; background:#fff;}
.svc-core-head{background:#00a6c8; color:#fff; font-weight:900; padding:18px 18px; font-size:22px;}
.svc-list{list-style:none; margin:0; padding:0;}
.svc-list li{padding:14px 18px; border-top:1px solid rgba(11,18,32,.08); color:#0b1220;}
.svc-support{padding:18px 0 46px;}
.svc-support-grid{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:24px;}
.svc-support-card{border:1px solid rgba(11,18,32,.10); border-radius:18px; padding:22px; background:#fff;}
.svc-enquiries{padding:46px 0 70px; background:#f6f8fb;}
.enquiries-grid{display:grid; grid-template-columns: 1fr 1.3fr; gap:28px; align-items:stretch;}
.enquiries-box{background:#00a6c8; color:#fff; border-radius:18px; font-size:48px; font-weight:900; display:flex; align-items:center; justify-content:center; letter-spacing:1px;}
.contact-card{background:#fff; border:1px solid rgba(11,18,32,.10); border-radius:18px; padding:26px;}
.contact-card h3{margin:0 0 10px; font-size:24px;}
.contact-line{margin:10px 0; color:#0b1220;}
.contact-line span{display:inline-block; min-width:70px; color:rgba(11,18,32,.65); font-weight:800;}
@media(max-width: 980px){
  .svc-hero{padding:90px 0 28px;}
  .svc-hero-grid{grid-template-columns:1fr; gap:18px;}
  .svc-hero h1{font-size:40px;}
  .svc-core-grid, .svc-support-grid{grid-template-columns:1fr;}
  .enquiries-grid{grid-template-columns:1fr;}
  .enquiries-box{font-size:38px; padding:24px 10px;}
}

/* ==============================
   ADE.GROUP look fixes (v3.2.0)
   ============================== */

/* Desktop dropdown: ensure it is visible above hero and not clipped */
.desktop-nav li.has-submenu{position:relative;}
.desktop-nav li.has-submenu > ul{
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:260px;
  background:#ffffff;
  border:1px solid rgba(11,18,32,.10);
  border-radius:12px;
  padding:10px;
  box-shadow:0 18px 45px rgba(11,18,32,.12);
  z-index:10000;
}
.site-header{position:relative; z-index:1000;}

/* Mobile menu overlay (ADE-style) */
html.menu-open, html.menu-open body{overflow:hidden;}
.mobile-menu[data-mobile-menu]{
  display:none;
  position:fixed;
  inset:0;
  z-index:20000;
}
.mobile-menu[data-mobile-menu].is-open{display:block !important;}
.mobile-menu .mm-backdrop{
  position:absolute;
  inset:0;
  background:rgba(9,14,23,.55);
}
.mobile-menu .wrap{
  position:relative;
  z-index:1;
  max-width:520px;
  width:92vw;
  margin:70px auto 0;
  background:rgba(255,255,255,.92);
  backdrop-filter:saturate(140%) blur(10px);
  border:1px solid rgba(255,255,255,.55);
  border-radius:16px;
  overflow:hidden;
}
.mobile-menu .mm-header{
  display:flex;
  justify-content:flex-end;
  padding:10px;
}
.mobile-menu .mm-close{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(11,18,32,.12);
  background:#ffffff;
  font-size:22px;
  cursor:pointer;
}
.mobile-menu .mobile-nav > li{border-bottom:1px solid rgba(11,18,32,.08);}
.mobile-menu .mobile-nav > li:last-child{border-bottom:0;}
.mobile-menu .row{display:flex; align-items:center; justify-content:space-between;}
.mobile-menu .submenu-toggle{
  width:44px;
  height:44px;
  border-radius:12px;
  border:1px solid rgba(11,18,32,.12);
  background:#ffffff;
  font-weight:900;
}
.mobile-menu ul ul{padding-left:10px; margin:6px 0 12px 10px; border-left:2px solid rgba(11,18,32,.08);}

/* Footer (match ADE light footer + teal strip) */
.site-footer{
  background:#f4f6f9;
  color:#1b2233;
  border-top:1px solid rgba(11,18,32,.08);
}
.site-footer a{color:#1b2233;}
.site-footer a:hover{color:#0a6f87;}
.site-footer .footer-grid{gap:40px; align-items:flex-start;}
.site-footer h4{color:#1b2233; font-weight:900;}
.site-footer .social a{
  width:44px;
  height:44px;
  border-radius:10px;
  background:#e7ecf3;
  border:1px solid rgba(11,18,32,.10);
}
.site-footer .social a:hover{background:#dce6f2;}
.site-footer .footer-bottom{
  background:#0a6f87;
  color:#e9fbff;
}
.site-footer .footer-bottom .footer-wrap{padding:14px 20px;}

.footer-certbar{display:flex; gap:14px; flex-wrap:wrap; padding:28px 0 10px;}
.cert-pill{display:inline-flex; align-items:center; justify-content:center; padding:10px 16px; border-radius:999px; background:#ffffff; border:1px solid rgba(11,18,32,.10); font-weight:800; letter-spacing:.2px;}
.footer-logo{display:flex; justify-content:flex-end; align-items:flex-end;}
@media (max-width: 900px){
  .footer-logo{justify-content:flex-start;}
}
.service-item-link{display:block; color:inherit; text-decoration:none;}
.service-item-link:hover{text-decoration:underline; color:#0a6f87;}

/* ------------------------------------------------------------
   ADE-like subservice pages (virtual route: /services/<slug>/)
------------------------------------------------------------- */
.service-hero { padding: 48px 0; background: #f5f6f8; }
.service-hero__grid { display: grid; grid-template-columns: 1fr; gap: 20px; align-items: center; }
.service-hero__title { margin: 0; font-size: 34px; line-height: 1.1; }
.service-hero__image img { width: 100%; height: auto; border-radius: 6px; }

.section-title { margin: 0 0 18px; font-size: 26px; }

.service-benefits, .service-expertise, .service-core, .service-support, .service-enquiries { padding: 38px 0; }

.benefits-grid { display: grid; grid-template-columns: 1fr; gap: 18px; }
.benefit { background: #fff; border-radius: 10px; padding: 18px; box-shadow: 0 6px 20px rgba(0,0,0,.06); }
.benefit__icon { width: 44px; height: 44px; border-radius: 10px; background: rgba(0, 122, 204, .12); margin-bottom: 12px; }
.benefit__title { margin: 0 0 6px; font-size: 16px; }
.benefit__text { margin: 0; opacity: .85; }

.core-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.core-card { background: #fff; border-radius: 10px; overflow: hidden; box-shadow: 0 6px 20px rgba(0,0,0,.06); }
.core-card__header { background: #2f86c4; color: #fff; padding: 12px 14px; font-weight: 600; }
.core-card__body { padding: 10px 14px; }
.core-card__body ul { margin: 0; padding-left: 16px; }
.service-item-link { color: inherit; text-decoration: none; }
.service-item-link:hover { text-decoration: underline; }

.support-grid { display: grid; grid-template-columns: 1fr; gap: 16px; }
.support-card { background: #fff; border-radius: 10px; padding: 14px; box-shadow: 0 6px 20px rgba(0,0,0,.06); }
.support-card__title { margin: 0 0 10px; font-size: 16px; }
.support-card ul { margin: 0; padding-left: 16px; }

.enquiries-box { display: grid; grid-template-columns: 1fr; border-radius: 12px; overflow: hidden; box-shadow: 0 6px 20px rgba(0,0,0,.06); }
.enquiries-box__left { background: #2f86c4; color: #fff; padding: 18px; font-size: 22px; font-weight: 700; display:flex; align-items:center; justify-content:center; min-height: 120px; }
.enquiries-box__right { background: #fff; padding: 18px; }
.enquiries-contact + .enquiries-contact { margin-top: 14px; padding-top: 14px; border-top: 1px solid rgba(0,0,0,.08); }
.enquiries-contact__name { font-weight: 700; }
.enquiries-contact__role { opacity: .8; margin: 2px 0 8px; }
.enquiries-contact__row { opacity: .9; margin-top: 6px; }

@media (min-width: 768px) {
  .service-hero__grid { grid-template-columns: 1fr 1fr; }
  .benefits-grid { grid-template-columns: repeat(3, 1fr); }
  .core-grid { grid-template-columns: repeat(2, 1fr); }
  .support-grid { grid-template-columns: repeat(2, 1fr); }
  .enquiries-box { grid-template-columns: 280px 1fr; }
}

/* ==============================
   v3.2.3 fixes (desktop dropdown + footer copyright)
   ============================== */

/* Desktop dropdown (Services) */
@media (min-width: 992px){
  .main-nav ul{list-style:none;margin:0;padding:0}
  .main-nav li{position:relative}
  .main-nav .sub-menu{
    position:absolute;
    left:0;
    top:100%;
    min-width:240px;
    background:#fff;
    border:1px solid rgba(15,23,42,.08);
    border-radius:12px;
    box-shadow:0 18px 40px rgba(15,23,42,.12);
    padding:10px;
    opacity:0;
    visibility:hidden;
    transform:translateY(10px);
    transition:opacity .18s ease, transform .18s ease, visibility .18s ease;
    z-index:9999;
  }
  .main-nav .sub-menu a{
    display:block;
    padding:10px 12px;
    border-radius:10px;
    font-weight:600;
    color:#0f172a;
    text-decoration:none;
    white-space:nowrap;
  }
  .main-nav .sub-menu a:hover{background:rgba(0,166,200,.12)}
  .main-nav li:hover > .sub-menu,
  .main-nav li:focus-within > .sub-menu,
  .main-nav li.open > .sub-menu{opacity:1;visibility:visible;transform:translateY(0)}
}

/* Footer copyright: always centered + bold */
.site-footer .footer-bottom small,
.site-footer .footer-bottom .footer-wrap small{
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  font-weight:800;
  letter-spacing:.2px;
  width:100%;
}

/* ---- Overrides for production consistency ---- */
/* Footer rights: always bold + centered */
.site-footer .footer-bottom{font-weight:700 !important;}
.site-footer .footer-bottom .container{display:flex !important; justify-content:center !important; align-items:center !important; text-align:center !important;}

/* Ensure header dropdowns can overflow */
.site-header, .primary-nav, .header-inner{overflow:visible;}


/* v5.0.0 PRO STRUCTURE */
:root{--gutter:24px;}
.container{width:min(var(--container), calc(100% - (var(--gutter) * 2))); margin:0 auto;}
@media(max-width:640px){:root{--gutter:16px;}}

/* desktop dropdown - robust selectors */
@media (min-width: 901px){
  .primary-nav ul, .primary-nav .menu, .primary-nav .menu-list{list-style:none; margin:0; padding:0;}
  .primary-nav .menu-list, .primary-nav ul{display:flex; gap:16px; align-items:center;}
  .primary-nav li{position:relative;}
  .primary-nav .sub-menu{
    display:none;
    position:absolute;
    top: calc(100% + 10px);
    left:0;
    min-width: 280px;
    background:#fff;
    border:1px solid rgba(11,18,32,.10);
    border-radius:16px;
    padding:10px;
    box-shadow:0 18px 40px rgba(17,24,39,.16);
    z-index:9999;
  }
  .primary-nav .sub-menu a{
    display:block;
    padding:10px 12px;
    border-radius:12px;
    text-decoration:none;
    color:#0b1220;
    font-weight:800;
    white-space:nowrap;
  }
  .primary-nav .sub-menu a:hover{background: rgba(11,18,32,.06);}
  .primary-nav li.menu-item-has-children:hover > .sub-menu,
  .primary-nav li.menu-item-has-children:focus-within > .sub-menu{display:block;}
}

/* Mobile overlay scroll */
@media (max-width: 900px){
  .mobile-overlay .panel .body{max-height: calc(100vh - 84px); overflow:auto;}
}

/* Footer bottom bold and fixed */
.footer-bottom, .site-footer .footer-bottom{
  text-align:center;
  font-weight:800;
}

/* Service single page layout */
.svc-hero{padding:110px 0 40px; background:#f6f8fb;}
.svc-hero-grid{display:grid; grid-template-columns: 1.2fr 1fr; gap:40px; align-items:center;}
.svc-hero h1{font-size:56px; line-height:1.05; margin:0;}
.svc-hero-media img{width:100%; height:420px; object-fit:cover; border-radius:18px; border:1px solid rgba(11,18,32,.10); display:block;}
@media(max-width:980px){.svc-hero{padding:92px 0 28px}.svc-hero-grid{grid-template-columns:1fr; gap:18px}.svc-hero h1{font-size:40px}.svc-hero-media img{height:320px}}

.svc-intro{padding:26px 0 10px;}
.svc-intro h2{font-size:40px; text-align:center; margin:0 0 14px;}
.svc-intro .lead{max-width:920px; margin:0 auto; text-align:center; color:rgba(11,18,32,.78); font-size:18px; font-weight:600;}

.svc-grid2{display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:24px;}
@media(max-width:980px){.svc-grid2{grid-template-columns:1fr}}

.svc-card{border:1px solid rgba(11,18,32,.10); border-radius:18px; overflow:hidden; background:#fff;}
.svc-card-head{background:#00a6c8; color:#fff; font-weight:900; padding:18px; font-size:22px;}
.svc-list{list-style:none; margin:0; padding:0;}
.svc-list li{padding:14px 18px; border-top:1px solid rgba(11,18,32,.08); display:flex; justify-content:space-between; gap:12px;}
.svc-list a{color:#0b1220; text-decoration:none; font-weight:700;}
.svc-list a:hover{text-decoration:underline;}

.svc-section-title{font-size:44px; text-align:center; margin:0 0 24px;}
.svc-section{padding:26px 0 46px;}

.svc-enquiries{padding:46px 0 70px; background:#f6f8fb;}
.enquiries-grid{display:grid; grid-template-columns: 1fr 1.3fr; gap:28px; align-items:stretch;}
@media(max-width:980px){.enquiries-grid{grid-template-columns:1fr}}
.enquiries-box{background:#00a6c8; color:#fff; border-radius:18px; font-size:48px; font-weight:900; display:flex; align-items:center; justify-content:center; letter-spacing:1px;}
.contact-card{background:#fff; border:1px solid rgba(11,18,32,.10); border-radius:18px; padding:26px;}
.contact-card h3{margin:0 0 10px; font-size:24px;}
.contact-line{margin:10px 0; color:#0b1220;}
.contact-line span{display:inline-block; min-width:80px; color:rgba(11,18,32,.65); font-weight:800;}

/* -----------------------------
   Hotfixes: mobile nav + footer
   ----------------------------- */

/* Footer: labels/icons were too light on mobile */
.site-footer .footer-contact,
.site-footer .footer-contact a{color:#0b0f17; opacity:1;}
.site-footer .footer-contact .field-label{color:#0b0f17; opacity:1; font-weight:800;}
.site-footer .footer-social{display:flex; gap:10px; align-items:center;}
.site-footer .footer-social a{display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border-radius:10px; border:1px solid #dfe4ee; background:#fff;}
.site-footer .copyright{font-weight:900;}

/* Enquiries: force details readable */
.enquiries-card .details,
.enquiries-card .details a,
.enquiries-card .details strong{color:#0b0f17 !important; opacity:1 !important;}

/* -------------------------------------------------------------------------- */
/* v5.0.2 – Mobile menu + footer polish (ADE-like spacing)                     */
/* -------------------------------------------------------------------------- */

/* Mobile hamburger menu: ensure it appears above everything */
.mobile-menu {
  position: fixed;
  inset: 0;
  z-index: 99999;
  background: rgba(15, 111, 128, 0.96);
}
.mobile-menu a { color: #ffffff; }
.mobile-menu a:hover,
.mobile-menu a:focus { color: #ffffff; }

/* Footer: match ADE-style spacing & readability */
.site-footer {
  background: #eaf4f5;
  color: #0b1220;
}
.site-footer .footer-heading,
.site-footer a { color: #0b1220; }

.site-footer .footer-wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 40px 24px;
}

.site-footer .footer-bottom {
  background: #0f6a76;
  border-top: 0;
  padding: 16px 24px;
}
.site-footer .footer-rights {
  color: #ffffff;
  font-weight: 800;
  letter-spacing: 0.2px;
  text-align: center;
}

/* Contact labels (Email/Phone) – always visible */
.site-footer .footer-contact p,
.site-footer .footer-contact strong,
.site-footer .footer-contact a {
  color: #0b1220;
}

/* Social icons – consistent sizing */
.site-footer .footer-social a {
  width: 54px;
  height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
}

@media (max-width: 640px) {
  .site-footer .footer-wrap { padding: 32px 20px; }
  .site-footer .footer-grid {
    grid-template-columns: 1fr;
    gap: 22px;
    text-align: center;
    justify-items: center;
  }
  .site-footer .footer-links,
  .site-footer .footer-contact {
    text-align: center;
  }
  .site-footer .footer-social {
    justify-content: center;
  }
}
