/* ============================================================
   RAYVEN AGENCY — style.css  v2.0
   Full responsive redesign + CMS-ready
   ============================================================ */

/* ---- CSS Custom Properties ---- */
:root {
  --accent: #e8a020;
  --accent-light: #f5c842;
  --accent-dark: #c47800;
  --accent-glow: rgba(232,160,32,0.25);
  --accent-rgb: 232,160,32;
  --bg:  #09090b;
  --bg2: #101014;
  --bg3: #17171c;
  --bg4: #1e1e24;
  --bg5: #25252d;
  --text: #f4f4f6;
  --text-muted: #8a909e;
  --text-dim: #484d5a;
  --border: rgba(255,255,255,0.07);
  --border-hover: rgba(255,255,255,0.14);
  --radius: 14px;
  --radius-lg: 22px;
  --radius-xl: 36px;
  --shadow: 0 24px 64px rgba(0,0,0,0.55);
  --shadow-sm: 0 4px 20px rgba(0,0,0,0.3);
  --shadow-accent: 0 8px 40px rgba(232,160,32,0.3);
  --shadow-card: 0 2px 24px rgba(0,0,0,0.4);
  --ease: cubic-bezier(0.4,0,0.2,1);
  --transition: all 0.3s cubic-bezier(0.4,0,0.2,1);
  --font-head: 'Kanit', sans-serif;
  --font-body: 'Plus Jakarta Sans', sans-serif;
  --container: 1280px;
  --header-h: 80px;
  --section-pad: clamp(60px, 8vw, 110px);
  
  /* Fluid Typography Scale */
  --fs-h1: clamp(2.8rem, 8vw, 4.8rem);
  --fs-h2: clamp(2.2rem, 5vw, 3.2rem);
  --fs-h3: clamp(1.6rem, 4vw, 2.4rem);
  --fs-body: clamp(1rem, 1.2vw, 1.15rem);
  --fs-small: 0.9rem;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px;-webkit-text-size-adjust:100%}
body{background:var(--bg);color:var(--text);font-family:var(--font-body);font-size:var(--fs-body);line-height:1.75;overflow-x:hidden;-webkit-font-smoothing:antialiased;position:relative;}

/* ---- Flicker-Free CMS Loading (Hide until CMS-ready) ---- */
[data-cms-key], [data-cms-section], [data-cms-text], [data-cms-nav], [data-cms-contact],
.page-bg-layer, .section-bg-layer, .page-banner-bg,
.hero-person-img, .service-img img, .project-img img, .team-img img, .industry-card-img img,
.testimonial-img img, .post-cover, .insight-img img, .footer-logo, .side-panel-logo,
.client-logo, #heroBg, #statsBg {
  opacity: 0;
  transition: opacity 0.6s var(--ease);
}
/* Overlay tint layers must never be hidden — their opacity IS their darkness level */
.page-bg-overlay, .section-bg-overlay { transition: background 0.4s ease, opacity 0.4s ease; }

/* Premium Shimmer/Skeleton State */
.cms-loading [data-cms-key], .cms-loading [data-cms-section] {
  position: relative;
  overflow: hidden;
  background: var(--bg2);
}
.cms-loading [data-cms-key]::after, .cms-loading [data-cms-section]::after {
  content: "";
  position: absolute;
  top: 0; right: 0; bottom: 0; left: 0;
  transform: translateX(-100%);
  background-image: linear-gradient(90deg, rgba(255,255,255,0) 0, rgba(255,255,255,0.03) 20%, rgba(255,255,255,0.06) 60%, rgba(255,255,255,0));
  animation: shimmer 2.5s infinite;
}
@keyframes shimmer {
  100% { transform: translateX(100%); }
}

body.cms-ready [data-cms-key],
body.cms-ready [data-cms-section],
body.cms-ready [data-cms-text],
body.cms-ready [data-cms-nav],
body.cms-ready [data-cms-contact],
body.cms-ready .page-bg-layer,
body.cms-ready .section-bg-layer,
body.cms-ready .page-banner-bg,
body.cms-ready .hero-person-img,
body.cms-ready .service-img img,
body.cms-ready .project-img img,
body.cms-ready .team-img img,
body.cms-ready .industry-card-img img,
body.cms-ready .testimonial-img img,
body.cms-ready .post-cover,
body.cms-ready .insight-img img,
body.cms-ready .footer-logo,
body.cms-ready .side-panel-logo,
body.cms-ready .client-logo,
body.cms-ready #heroBg,
body.cms-ready #statsBg {
  opacity: 1 !important;
}
/* Ensure the grid and loaders reveal too */
body.cms-ready #blogInsightsGrid, body.cms-ready #blogFilterTabs, body.cms-ready #singlePostContainer {
  opacity: 1 !important;
}

.page-bg-layer{position:fixed;inset:0;background-size:cover;background-position:center;z-index:-2;pointer-events:none;transition:background-image 0.6s ease-in-out;}
.page-bg-overlay{position:fixed;inset:0;z-index:-1;pointer-events:none;}
img{max-width:100%;display:block;object-fit:cover;image-rendering:high-quality;}
[data-cms-key] img, img[data-cms-key] { object-fit: cover; }
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{border:none;cursor:pointer;background:none;font-family:inherit}
input,textarea,select{font-family:inherit}
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg2)}
::-webkit-scrollbar-thumb{background:var(--accent-dark);border-radius:3px}

.container{max-width:var(--container);margin:0 auto;padding:0 clamp(20px, 5vw, 40px)}
.section-pad{padding:var(--section-pad) 0}
.centered{text-align:center}
.highlight{color:var(--accent)}
.star-icon{color:var(--accent);margin-right:6px}

.section-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--accent);margin-bottom:18px;
  padding:6px 16px;
  background:rgba(232,160,32,0.1);
  border:1px solid rgba(232,160,32,0.25);
  border-radius:50px;font-family:var(--font-body);
}
.section-title{
  font-family:var(--font-head);
  font-size:var(--fs-h2);
  font-weight:700;line-height:1.15;margin-bottom:20px;color:var(--text);
}
.section-title em{font-style:normal;color:var(--accent)}
.section-header p{color:var(--text-muted);max-width:540px;margin:0 auto;line-height:1.8}
.section-header.centered .section-label{display:flex;justify-content:center}
.section-header{margin-bottom:56px}

/* ---- Buttons ---- */
.btn-style1{
  display:inline-flex;align-items:center;gap:10px;
  font-family:var(--font-body);font-size:14px;font-weight:700;
  color:var(--text);padding:14px 30px;
  border:2px solid var(--accent);border-radius:50px;
  transition:var(--transition);position:relative;overflow:hidden;z-index:1;
  min-height:50px;touch-action:manipulation;
}
.btn-style1::before{content:'';position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform 0.35s var(--ease);z-index:-1}
.btn-style1:hover::before,.btn-style1:focus::before{transform:scaleX(1)}
.btn-style1:hover,.btn-style1:focus{color:#000;outline:none}
.btn-dot{width:8px;height:8px;border-radius:50%;background:var(--accent);transition:var(--transition)}
.btn-style1:hover .btn-dot,.btn-style1:focus .btn-dot{background:#000}
.btn-outline{
  display:inline-flex;align-items:center;gap:10px;
  font-size:14px;font-weight:700;color:var(--text-muted);padding:14px 30px;
  border:2px solid var(--border-hover);border-radius:50px;
  transition:var(--transition);min-height:50px;touch-action:manipulation;
}
.btn-outline:hover,.btn-outline:focus{border-color:var(--accent);color:var(--accent);outline:none}
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--accent);color:#000;font-weight:700;font-size:14px;
  padding:12px 26px;border-radius:50px;letter-spacing:0.3px;
  transition:var(--transition);min-height:44px;touch-action:manipulation;
}
.btn-primary:hover,.btn-primary:focus{background:var(--accent-light);transform:translateY(-2px);box-shadow:var(--shadow-accent);outline:none}
.btn-header-cta{
  background:var(--accent);color:#000;font-weight:700;font-size:13px;
  padding:10px 22px;border-radius:50px;transition:var(--transition);
  white-space:nowrap;min-height:40px;touch-action:manipulation;
  display:inline-flex;align-items:center;
}
.btn-header-cta:hover,.btn-header-cta:focus{background:var(--accent-light);outline:none}

/* ---- Animations ---- */
@keyframes fadeInUp{from{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeInLeft{from{opacity:0;transform:translateX(-50px)}to{opacity:1;transform:translateX(0)}}
@keyframes fadeInRight{from{opacity:0;transform:translateX(50px)}to{opacity:1;transform:translateX(0)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-18px)}}
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes slideFillIn{from{width:0}to{width:80%}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}
@keyframes scaleIn{from{opacity:0;transform:scale(0.88)}to{opacity:1;transform:scale(1)}}
@keyframes glowPulse{0%,100%{opacity:0.1}50%{opacity:0.22}}

[data-animate]{opacity:0}
[data-animate].animated[data-animate="fadeInUp"]{animation:fadeInUp 0.75s var(--ease) forwards}
[data-animate].animated[data-animate="fadeInLeft"]{animation:fadeInLeft 0.75s var(--ease) forwards}
[data-animate].animated[data-animate="fadeInRight"]{animation:fadeInRight 0.75s var(--ease) forwards}

/* ============================================================ PRELOADER */
#preloader{position:fixed;inset:0;background:#09090b;z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity 0.8s cubic-bezier(0.65, 0, 0.35, 1),visibility 0.8s cubic-bezier(0.65, 0, 0.35, 1)}
#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-inner{text-align:center}
.preloader-logo{font-family:var(--font-head);font-size:48px;font-weight:700;color:var(--accent);letter-spacing:12px;margin-bottom:24px;animation:pulse 2s ease infinite;text-transform:uppercase}
.preloader-logo--img{font-size:0;letter-spacing:0;margin-bottom:0}/* suppress text styles when showing image */
.preloader-logo--img img{display:block;max-height:80px;max-width:220px;width:auto;height:auto;margin:0 auto 28px;animation:pulse 2s ease infinite;object-fit:contain;filter:brightness(1)}
.preloader-bar{width:180px;height:1px;background:rgba(255,255,255,0.05);border-radius:2px;overflow:hidden;margin:0 auto;position:relative}
.preloader-bar span{display:block;height:100%;background:var(--accent);animation:slideFillIn 2s cubic-bezier(0.65, 0, 0.35, 1) infinite}

/* ============================================================
   LAZY LOAD — IMAGE SKELETON SHIMMER
   Auto-background: uses site CSS vars so it always matches the
   current theme palette. Removed once image finishes loading.
   ============================================================ */
img[loading="lazy"]:not(.img-loaded){
  background:linear-gradient(90deg,
    var(--bg3,#141417) 25%,
    var(--bg4,#1f1f23) 50%,
    var(--bg3,#141417) 75%);
  background-size:400% 100%;
  animation:img-shimmer 1.8s ease-in-out infinite;
}
img[loading="lazy"].img-loaded{
  background:none!important;
  animation:none!important;
}
@keyframes img-shimmer{
  0%  {background-position:100% 0}
  100%{background-position:-100% 0}
}

/* ============================================================ SIDE PANEL */
.side-panel-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:899;opacity:0;visibility:hidden;transition:var(--transition);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.side-panel-overlay.active{opacity:1;visibility:visible}
.side-panel{
  position:fixed;right:0;top:0;height:100%;width:420px;
  background:rgba(10,10,12,0.8);z-index:900;
  backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);
  transform:translateX(100%);transition:transform 0.6s cubic-bezier(0.65, 0, 0.35, 1);
  overflow-y:auto;padding:80px 48px 48px;
  border-left:1px solid rgba(255,255,255,0.05);
  display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(0,0,0,0.5);
}
.side-panel.active{transform:translateX(0)}
.side-panel-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:50%;background:var(--bg4);color:var(--text);font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition);touch-action:manipulation}
.side-panel-close:hover,.side-panel-close:focus{background:var(--accent);color:#000;outline:none}
.side-panel-logo{font-family:var(--font-head);font-size:28px;font-weight:700;color:var(--accent);letter-spacing:5px;margin-bottom:36px}
.side-panel-nav{margin-bottom:28px}
.side-panel-nav ul{display:flex;flex-direction:column;gap:4px}
.side-panel-nav ul li a{display:flex;align-items:center;gap:10px;font-size:15px;font-weight:600;color:var(--text-muted);padding:12px 14px;border-radius:var(--radius);transition:var(--transition);touch-action:manipulation}
.side-panel-nav ul li a:hover,.side-panel-nav ul li a:focus{background:rgba(232,160,32,0.1);color:var(--accent);outline:none;padding-left:18px}
.side-panel-nav ul li a i{width:18px;color:var(--accent);font-size:13px;flex-shrink:0}
.side-panel-divider{height:1px;background:var(--border);margin:20px 0}
.side-panel-section{margin-bottom:24px}
.side-panel-section h4{font-family:var(--font-head);font-size:17px;font-weight:600;margin-bottom:10px;color:var(--text)}
.side-panel-section p{color:var(--text-muted);font-size:14px;line-height:1.7;margin-bottom:14px}
.side-panel-cta{font-size:13px;padding:10px 20px}
.side-panel-contacts{display:flex;flex-direction:column;gap:12px}
.side-panel-contacts li{display:flex;align-items:center;gap:10px;color:var(--text-muted);font-size:14px}
.side-panel-contacts li i{color:var(--accent);width:14px;flex-shrink:0}
.side-panel-contacts a:hover{color:var(--accent)}
.side-panel-socials{display:flex;gap:10px;margin-top:8px}
.side-panel-socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text-muted);transition:var(--transition);touch-action:manipulation}
.side-panel-socials a:hover,.side-panel-socials a:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}

/* ============================================================ TOP BAR */
.top-bar{
  position:fixed;top:0;left:0;right:0;z-index:801;
  background:var(--bg2);border-bottom:1px solid rgba(255,255,255,0.06);
  height:38px;display:flex;align-items:center;
  transition:transform 0.4s ease, opacity 0.4s ease;
}
.top-bar.hidden{transform:translateY(-100%);opacity:0;pointer-events:none;}
.top-bar-inner{
  display:flex;align-items:center;justify-content:space-between;
  width:100%;max-width:1280px;margin:0 auto;padding:0 32px;
}
.top-bar-left{display:flex;align-items:center;gap:24px;}
.top-bar-left a{
  font-size:11.5px;color:var(--text-dim);text-decoration:none;
  display:flex;align-items:center;gap:6px;transition:color 0.2s;
  letter-spacing:0.02em;
}
.top-bar-left a:hover{color:var(--accent);}
.top-bar-left a i{color:var(--accent);font-size:10px;}
.top-bar-right{display:flex;align-items:center;gap:14px;}
.top-bar-social{
  width:26px;height:26px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:11px;color:var(--text-dim);
  transition:color 0.2s, background 0.2s;
}
.top-bar-social:hover{color:var(--accent);background:rgba(232,160,32,0.1);}
.top-bar-divider{width:1px;height:14px;background:rgba(255,255,255,0.08);}

/* ============================================================ HEADER */
.site-header{position:fixed;top:38px;left:0;right:0;z-index:800;height:var(--header-h);transition:all 0.5s cubic-bezier(0.65, 0, 0.35, 1)}
.site-header.top-bar-gone{top:0;}
.site-header.scrolled{
  height:70px;
  background:rgba(9,9,11,0.6);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(255,255,255,0.05);
  box-shadow:0 10px 40px rgba(0,0,0,0.3);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);gap:24px}
.site-logo{
  font-family:var(--font-head);
  font-size:26px;font-weight:700;color:var(--accent);
  letter-spacing:4px;flex-shrink:0;transition:var(--transition);
  display:inline-flex;align-items:center;padding-right:10px;
  opacity:1 !important; /* Always visible — text logo doesn't need FOUC hiding */
}
.site-logo:hover{opacity:0.85 !important}
.primary-nav ul{display:flex;gap:32px;align-items:center}
.primary-nav a{font-size:13px;font-weight:600;color:var(--text-muted);letter-spacing:0.5px;transition:var(--transition);position:relative;padding-bottom:4px}
.primary-nav a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--accent);transform:scaleX(0);transition:transform 0.3s var(--ease);border-radius:1px}
.primary-nav a:hover,.primary-nav a.active{color:var(--text)}
.primary-nav a:hover::after,.primary-nav a.active::after{transform:scaleX(1)}

/* ---- Dropdown nav items ---- */
.nav-item{position:relative;}
.nav-item>a .nav-arrow{
  font-size:9px;margin-left:4px;
  transition:transform 0.25s ease;display:inline-block;
}
.nav-item:hover>a .nav-arrow{transform:rotate(180deg);}

/* Standard dropdown */
.nav-dropdown{
  position:absolute;top:calc(100% + 16px);left:50%;
  transform:translateX(-50%) translateY(8px);
  min-width:220px;
  background:rgba(14,14,20,0.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:14px;
  padding:10px 0;
  opacity:0;pointer-events:none;
  transition:opacity 0.22s ease, transform 0.22s ease;
  box-shadow:0 20px 60px rgba(0,0,0,0.5);
  z-index:900;
}
.nav-dropdown::before{
  content:'';position:absolute;top:-6px;left:50%;
  transform:translateX(-50%);
  width:12px;height:12px;
  background:rgba(14,14,20,0.97);
  border-left:1px solid rgba(255,255,255,0.08);
  border-top:1px solid rgba(255,255,255,0.08);
  transform:translateX(-50%) rotate(45deg);
}
.nav-item:hover>.nav-dropdown,
.nav-item:focus-within>.nav-dropdown{
  opacity:1;pointer-events:auto;transform:translateX(-50%) translateY(0);
}
.nav-dropdown a{
  display:flex;align-items:center;gap:12px;
  padding:10px 18px;font-size:13px;font-weight:500;
  color:var(--text-muted);transition:all 0.18s ease;
  border-radius:0;white-space:nowrap;
}
.nav-dropdown a::after{display:none;}
.nav-dropdown a:hover{color:var(--text);background:rgba(255,255,255,0.04);padding-left:22px;}
.nav-dropdown a i{
  width:28px;height:28px;border-radius:8px;
  background:rgba(232,160,32,0.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-size:12px;flex-shrink:0;
}
.nav-dropdown .dropdown-divider{
  height:1px;background:rgba(255,255,255,0.06);margin:6px 0;
}
.nav-dropdown .dropdown-header{
  font-size:10px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.1em;color:var(--text-dim);padding:8px 18px 4px;
}

/* Mega-menu (Services) */
.nav-mega{
  position:absolute;top:calc(100% + 16px);left:50%;
  transform:translateX(-60%) translateY(8px);
  width:560px;
  background:rgba(14,14,20,0.97);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.08);
  border-radius:16px;padding:24px;
  opacity:0;pointer-events:none;
  transition:opacity 0.22s ease, transform 0.22s ease;
  box-shadow:0 24px 64px rgba(0,0,0,0.55);
  z-index:900;
}
.nav-item:hover>.nav-mega,
.nav-item:focus-within>.nav-mega{
  opacity:1;pointer-events:auto;transform:translateX(-60%) translateY(0);
}
.mega-header{
  font-size:11px;font-weight:700;text-transform:uppercase;
  letter-spacing:0.12em;color:var(--accent);
  margin-bottom:16px;padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,0.07);
}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px;}
.mega-item{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px;border-radius:10px;
  text-decoration:none;transition:background 0.18s ease;
}
.mega-item::after{display:none;}
.mega-item:hover{background:rgba(255,255,255,0.04);}
.mega-item-icon{
  width:36px;height:36px;border-radius:10px;flex-shrink:0;
  background:rgba(232,160,32,0.1);border:1px solid rgba(232,160,32,0.18);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-size:14px;
  transition:background 0.18s ease;
}
.mega-item:hover .mega-item-icon{background:rgba(232,160,32,0.18);}
.mega-item-text strong{
  display:block;font-size:13px;font-weight:700;
  color:var(--text);margin-bottom:2px;
}
.mega-item-text span{
  font-size:11.5px;color:var(--text-dim);line-height:1.4;
}
.mega-footer{
  margin-top:16px;padding-top:14px;
  border-top:1px solid rgba(255,255,255,0.07);
  display:flex;align-items:center;justify-content:space-between;
}
.mega-footer a{
  font-size:12px;font-weight:600;color:var(--accent);
  text-decoration:none;display:flex;align-items:center;gap:6px;
  transition:gap 0.2s;
}
.mega-footer a::after{display:none;}
.mega-footer a:hover{gap:10px;}

/* ---- Mobile side panel sub-nav ---- */
.side-nav-row{
  display:flex;align-items:center;gap:6px;
}
.side-nav-row>a{
  flex:1;
}
.side-nav-arrow{
  width:28px;height:28px;border-radius:6px;
  display:flex;align-items:center;justify-content:center;
  font-size:10px;color:var(--text-dim);
  background:rgba(255,255,255,0.05);
  transition:transform 0.25s ease, background 0.2s;
  cursor:pointer;flex-shrink:0;
}
.side-nav-parent.open .side-nav-arrow{transform:rotate(180deg);background:rgba(232,160,32,0.12);color:var(--accent);}
.side-nav-sub{
  max-height:0;overflow:hidden;
  transition:max-height 0.35s ease;
  padding-left:12px;
}
.side-nav-parent.open .side-nav-sub{max-height:400px;}
.side-nav-sub a{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;font-size:13px;color:var(--text-dim);
  border-radius:8px;transition:all 0.18s ease;
  margin-bottom:2px;
}
.side-nav-sub a:hover{color:var(--text);background:rgba(255,255,255,0.04);}
.side-nav-sub a i{
  width:24px;height:24px;border-radius:6px;
  background:rgba(232,160,32,0.1);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-size:10px;flex-shrink:0;
}

.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}
.header-search-btn{width:40px;height:40px;border-radius:50%;background:var(--bg4);color:var(--text-muted);font-size:14px;display:flex;align-items:center;justify-content:center;transition:var(--transition);touch-action:manipulation}
.header-search-btn:hover,.header-search-btn:focus{background:var(--accent);color:#000;outline:none}
.hamburger{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;border-radius:50%;background:var(--bg4);transition:var(--transition);touch-action:manipulation}
.hamburger span{display:block;width:20px;height:2px;background:var(--text-muted);transition:var(--transition);border-radius:1px}
.hamburger:hover,.hamburger:focus{background:rgba(232,160,32,0.15);outline:none}
.hamburger:hover span,.hamburger:focus span{background:var(--accent)}
.header-search-bar{position:absolute;top:100%;left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--border);padding:16px 0;display:none;box-shadow:var(--shadow-sm)}
.header-search-bar.active{display:block}
.header-search-bar .container{display:flex;gap:12px;align-items:center}
.header-search-bar input{flex:1;background:var(--bg4);border:1px solid var(--border);border-radius:10px;padding:12px 18px;color:var(--text);font-size:15px;outline:none;transition:var(--transition)}
.header-search-bar input:focus{border-color:var(--accent)}
#searchClose{color:var(--text-muted);font-size:18px;transition:var(--transition);width:44px;height:44px;display:flex;align-items:center;justify-content:center}
#searchClose:hover{color:var(--accent)}

/* ============================================================ HERO */
.hero-section{position:relative;min-height:100vh;display:flex;align-items:flex-start;padding-top:var(--header-h);overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center top;z-index:0;transition:background-image 0.6s ease}
.hero-overlay{position:absolute;inset:0;z-index:1;background:linear-gradient(110deg,rgba(9,9,11,0.97) 0%,rgba(9,9,11,0.82) 42%,rgba(9,9,11,0.45) 70%,rgba(9,9,11,0.75) 100%)}
.float-orb{position:absolute;border-radius:50%;z-index:1;pointer-events:none;filter:blur(80px)}
.orb1{width:600px;height:600px;background:rgba(232,160,32,0.04);top:-150px;right:-120px;animation:float 9s ease infinite}
.orb2{width:350px;height:350px;background:rgba(100,120,255,0.03);bottom:80px;left:-100px;animation:float 11s ease infinite 2s}
.orb3{width:220px;height:220px;background:rgba(232,160,32,0.03);top:45%;left:38%;animation:float 13s ease infinite 4s}
.hero-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px, 8vw, 80px);align-items:center;padding:clamp(20px, 6vw, 60px) clamp(20px, 5vw, 40px) clamp(60px, 10vw, 120px);width:100%;max-width:var(--container);margin:0 auto}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(232,160,32,0.1);border:1px solid rgba(232,160,32,0.3);padding:7px 18px;border-radius:50px;font-size:11px;font-weight:700;color:var(--accent);letter-spacing:2px;text-transform:uppercase;margin-bottom:24px;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.hero-title{font-family:var(--font-head);font-size:var(--fs-h1);font-weight:700;line-height:1.05;margin-bottom:24px;color:var(--text)}
.title-highlight{color:var(--accent);position:relative;display:inline-block}
.title-highlight::after{content:'';position:absolute;left:0;right:0;bottom:-6px;height:3px;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:2px}
.title-accent{color:var(--text-muted)}
.hero-desc{color:var(--text-muted);font-size:var(--fs-body);max-width:520px;margin-bottom:40px;line-height:1.8}
.hero-ctas{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:52px;align-items:center}
.hero-stats{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.hero-stat strong{font-family:var(--font-head);font-size:34px;font-weight:700;color:var(--accent)}
.hero-stat span{font-size:22px;color:var(--accent);font-weight:700}
.hero-stat small{display:block;font-size:12px;color:var(--text-muted);margin-top:4px;letter-spacing:0.5px}
.hero-stat-divider{width:1px;height:52px;background:var(--border)}
.hero-visual{position:relative;display:flex;justify-content:center}
.hero-img-wrap{
  position:relative;width:100%;max-width:480px;
  border-radius:var(--radius-xl);overflow:visible;
  min-height:500px;background:rgba(255,255,255,0.02);
}
@media (max-width: 768px) {
  .hero-img-wrap { min-height: 300px; }
  .about-page-img { min-height: 300px; }
}
.hero-person-img{width:100%;height:600px;object-fit:cover;object-position:top center;border-radius:var(--radius-xl);position:relative;z-index:2;box-shadow:var(--shadow)}
.hero-img-glow{
  position:absolute;inset:-20px;border-radius:50%;
  background:var(--accent);animation:glowPulse 6s ease infinite;
  filter:blur(100px);z-index:1;opacity:0.15;
}
.hero-badge-float{position:absolute;z-index:3;background:rgba(16,16,20,0.88);border:1px solid var(--border);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);padding:14px 20px;border-radius:16px;display:flex;align-items:center;gap:14px;box-shadow:0 2px 24px rgba(0,0,0,0.4)}
.hero-badge-float.badge-top{top:30px;left:-20px;animation:float 4s ease infinite;max-width:200px}
.hero-badge-float.badge-bottom{bottom:30px;right:-20px;animation:float 4s ease infinite 2s;max-width:200px}
.hero-badge-float i{font-size:22px;color:var(--accent)}
.hero-badge-float strong{display:block;font-size:13px;font-weight:700;white-space:nowrap}
.hero-badge-float small{font-size:11px;color:var(--text-muted)}
.hero-scroll-cue{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:2;width:28px;height:48px;border:2px solid rgba(255,255,255,0.15);border-radius:14px;display:flex;align-items:flex-start;justify-content:center;padding-top:7px;transition:var(--transition)}
.hero-scroll-cue:hover{border-color:var(--accent)}
.hero-scroll-cue span{width:4px;height:10px;background:var(--accent);border-radius:2px;animation:float 1.6s ease infinite}

/* ============================================================ MARQUEE */
/* ============================================================ LOGO STRIP (Partners / Clients) */
.logo-strip-section{padding:56px 0;position:relative;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.partners-section{background:var(--bg2)}
.clients-section{background:var(--bg)}
.logo-strip-label{text-align:center;font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--text-dim);margin-bottom:36px}
.logo-strip-track{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:32px 48px}
.logo-strip-item{display:flex;align-items:center;justify-content:center;opacity:0.5;transition:opacity 0.3s ease,filter 0.3s ease;filter:grayscale(1) brightness(1.2)}
.logo-strip-item:hover{opacity:0.9;filter:grayscale(0) brightness(1)}
.logo-strip-item img{max-height:44px;max-width:140px;width:auto;height:auto;object-fit:contain}

/* ---- CMS logo gallery (admin side) ---- */
.logo-gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;margin-bottom:20px}
.logo-gallery-slot{background:var(--bg4);border:2px dashed var(--border);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;align-items:center;gap:10px;position:relative;min-height:120px;transition:border-color 0.2s}
.logo-gallery-slot:has(img){border-style:solid;border-color:var(--border)}
.logo-gallery-slot img{max-height:60px;max-width:100%;object-fit:contain;border-radius:6px}
.logo-gallery-slot-placeholder{color:var(--text-dim);font-size:28px;margin-top:8px}
.logo-gallery-slot input[type=text]{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:8px;padding:6px 10px;font-size:12px;color:var(--text);text-align:center}
.logo-gallery-slot-actions{display:flex;gap:8px;width:100%}
.logo-gallery-slot-actions button{flex:1;padding:6px 8px;font-size:11px;border-radius:8px;border:1px solid var(--border);background:var(--bg3);color:var(--text-muted);cursor:pointer;transition:var(--transition)}
.logo-gallery-slot-actions .btn-remove{border-color:rgba(255,77,106,0.3);color:#ff4d6a}
.logo-gallery-slot-actions .btn-remove:hover{background:rgba(255,77,106,0.1)}
.logo-gallery-slot-actions .btn-upload:hover{background:rgba(232,160,32,0.1);border-color:var(--accent);color:var(--accent)}
.logo-gallery-slot .slot-upload-input{display:none}
.logo-section-toggle{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;padding:14px 18px;background:var(--bg3);border-radius:var(--radius);border:1px solid var(--border)}
.logo-section-toggle label{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer}

/* Mobile adjustments */
@media(max-width:768px){
  .logo-strip-track{gap:24px 32px}
  .logo-strip-item img{max-height:36px;max-width:110px}
  .logo-gallery-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:12px}
}
@media(max-width:480px){
  .logo-strip-section{padding:40px 0}
  .logo-strip-track{gap:20px 24px}
  .logo-strip-item img{max-height:30px;max-width:90px}
}

.marquee-section{background:var(--accent);overflow:hidden;padding:16px 0;position:relative}
.marquee-track{display:flex;width:max-content;animation:marquee 32s linear infinite}
.marquee-section:hover .marquee-track{animation-play-state:paused}
.marquee-group{display:flex;align-items:center;gap:32px;padding-right:32px;white-space:nowrap}
.marquee-group span{font-family:var(--font-head);font-size:14px;font-weight:700;color:#000;letter-spacing:2px;text-transform:uppercase}
.marquee-divider{font-size:18px !important;opacity:0.5}

/* ============================================================ ABOUT */
.about-section{background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px, 8vw, 100px);align-items:center}
.about-img-stack{position:relative}
.about-img-main{border-radius:var(--radius-xl);overflow:hidden;box-shadow:var(--shadow);position:relative}
.about-img-main img{height:580px;width:100%;transition:transform 0.6s var(--ease)}
.about-img-main:hover img{transform:scale(1.04)}
.about-exp-card{position:absolute;bottom:36px;right:-36px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#000;padding:28px 32px;border-radius:var(--radius-lg);text-align:center;z-index:2;box-shadow:var(--shadow-accent)}
.about-exp-card strong{font-family:var(--font-head);font-size:52px;font-weight:700;display:block;line-height:1}
.about-exp-card span{font-family:var(--font-head);font-size:38px;font-weight:700}
.about-exp-card p{font-size:13px;font-weight:700;margin-top:6px;letter-spacing:0.5px}
.about-shape-1{position:absolute;width:130px;height:130px;border-radius:50%;border:2px solid rgba(232,160,32,0.15);top:-24px;right:-24px;animation:spin 22s linear infinite}
.about-shape-2{position:absolute;width:70px;height:70px;border-radius:50%;background:rgba(232,160,32,0.08);bottom:80px;left:-28px;animation:float 7s ease infinite}
.about-desc{color:var(--text-muted);margin-bottom:36px;line-height:1.85;font-size:15px}
.about-features{display:flex;flex-direction:column;gap:16px;margin-bottom:40px}
.about-feature{display:flex;align-items:flex-start;gap:16px;background:var(--bg3);padding:20px;border-radius:var(--radius);border:1px solid var(--border);transition:var(--transition)}
.about-feature:hover{border-color:rgba(232,160,32,0.4);transform:translateX(6px);box-shadow:var(--shadow-card)}
.about-feature-icon{width:50px;height:50px;border-radius:14px;background:rgba(232,160,32,0.1);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:20px;flex-shrink:0;border:1px solid rgba(232,160,32,0.2)}
.about-feature strong{display:block;font-weight:700;margin-bottom:4px;font-size:15px}
.about-feature p{font-size:13px;color:var(--text-muted);margin:0}

/* ============================================================ SERVICES */
.services-section{background:var(--bg2)}
.services-carousel{position:relative;overflow:hidden}
.services-track{display:flex;gap:24px;transition:transform 0.55s var(--ease)}
.service-card{flex:0 0 calc(33.333% - 18px);background:var(--bg3);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:var(--transition);position:relative}
.service-card:hover{border-color:rgba(232,160,32,0.4);transform:translateY(-10px);box-shadow:var(--shadow)}
.service-img{height:230px;overflow:hidden;position:relative}
.service-img img{width:100%;height:100%;transition:transform 0.6s var(--ease)}
.service-card:hover .service-img img{transform:scale(1.07)}
.service-icon-badge{position:absolute;right:18px;top:200px;width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#000;font-size:20px;display:flex;align-items:center;justify-content:center;z-index:2;box-shadow:var(--shadow-accent)}
.service-body{padding:26px 22px 22px}
.service-body h4{margin-bottom:10px;font-size:18px;font-weight:700;line-height:1.3}
.service-body h4 a{color:var(--text);transition:var(--transition)}
.service-body h4 a:hover{color:var(--accent)}
.service-body p{font-size:14px;color:var(--text-muted);line-height:1.75}
.carousel-arrows{display:flex;gap:12px;justify-content:center;margin-top:40px}
.carousel-btn{width:52px;height:52px;border-radius:50%;border:1px solid var(--border);color:var(--text-muted);font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition);touch-action:manipulation}
.carousel-btn:hover,.carousel-btn:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}
.services-cta-bar{margin-top:48px;background:var(--bg4);border-radius:var(--radius-lg);padding:28px 36px;display:flex;align-items:center;gap:24px;border:1px solid var(--border)}
.services-cta-bar p{color:var(--text-muted);font-size:15px}
.services-cta-bar strong a{color:var(--accent);font-weight:700}
.services-cta-bar strong a:hover{text-decoration:underline}

/* ============================================================ STATS */
.stats-section{position:relative;padding:90px 0;overflow:hidden}
.stats-bg{position:absolute;inset:0;background-size:cover;background-position:center}
.stats-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(9,9,11,0.92) 0%,rgba(9,9,11,0.82) 100%)}
.stats-grid{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(20px, 4vw, 40px);text-align:center}
.stat-item{padding:32px 20px;border-radius:var(--radius-lg);background:rgba(232,160,32,0.05);border:1px solid rgba(232,160,32,0.12);transition:var(--transition)}
.stat-item:hover{background:rgba(232,160,32,0.1);border-color:rgba(232,160,32,0.3);transform:translateY(-4px)}
.stat-item strong{font-family:var(--font-head);font-size:var(--fs-h1);font-weight:700;color:var(--accent);display:block;line-height:1}
.stat-item span{font-size:var(--fs-h2);color:var(--accent);font-weight:700}
.stat-item p{color:var(--text-muted);font-size:var(--fs-small);margin-top:10px;letter-spacing:0.5px}

/* ============================================================ PROJECTS */
.projects-section{background:var(--bg)}
.projects-header{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:end;margin-bottom:52px}
.projects-header p{color:var(--text-muted);line-height:1.8}
.projects-grid{display:grid;grid-template-columns:repeat(auto-fit, minmax(280px, 1fr)); gap:14px}
.project-card{position:relative;overflow:hidden;border-radius:var(--radius-lg);cursor:pointer;min-height:300px;}
.project-card.large{grid-column:span 2; grid-row:span 2}
.project-img{width:100%;height:100%}
.project-img img{width:100%;height:100%;transition:transform 0.7s var(--ease)}
.project-card:hover .project-img img{transform:scale(1.1)}
.project-card::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(9,9,11,0.92) 0%,transparent 55%);transition:var(--transition)}
.project-card:hover::after{background:linear-gradient(to top,rgba(9,9,11,0.96) 0%,rgba(9,9,11,0.25) 100%)}
.project-arrow{position:absolute;top:18px;right:18px;z-index:3;width:48px;height:48px;border-radius:50%;background:var(--accent);color:#000;font-size:16px;display:flex;align-items:center;justify-content:center;transform:scale(0) rotate(-45deg);transition:var(--transition);touch-action:manipulation}
.project-card:hover .project-arrow{transform:scale(1) rotate(0deg)}
.project-info{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:3}
.project-cats{display:flex;gap:8px;margin-bottom:8px}
.project-cats li{font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--accent);background:rgba(232,160,32,0.15);padding:4px 12px;border-radius:20px;border:1px solid rgba(232,160,32,0.25)}
.project-info h4{font-size:18px;font-weight:700}
.project-info h4 a{color:var(--text);transition:var(--transition)}
.project-info h4 a:hover{color:var(--accent)}
.projects-view-all{text-align:center;margin-top:52px}
.btn-view-all{display:inline-flex;align-items:center;gap:12px;font-weight:700;font-size:14px;color:var(--text);border:2px solid var(--border-hover);padding:14px 40px;border-radius:50px;transition:var(--transition);touch-action:manipulation}
.btn-view-all:hover,.btn-view-all:focus{border-color:var(--accent);color:var(--accent);outline:none;background:rgba(232,160,32,0.05)}

/* ============================================================ TEAM */
.team-section{background:var(--bg2)}
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:56px}
.team-card{background:var(--bg3);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border);transition:var(--transition);text-align:center}
.team-card:hover{border-color:rgba(232,160,32,0.4);transform:translateY(-10px);box-shadow:var(--shadow)}
.team-img{height:290px;overflow:hidden;position:relative}
.team-img img{width:100%;height:100%;transition:transform 0.6s var(--ease)}
.team-card:hover .team-img img{transform:scale(1.06)}
.team-info{padding:22px}
.team-info h4{font-size:17px;font-weight:700;margin-bottom:4px}
.team-info span{font-size:13px;color:var(--text-muted);display:block;margin-bottom:16px}
.team-socials{display:flex;justify-content:center;gap:10px}
.team-socials a{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:12px;color:var(--text-muted);transition:var(--transition);touch-action:manipulation}
.team-socials a:hover,.team-socials a:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}

/* ============================================================ TESTIMONIALS */
.testimonials-section{background:var(--bg)}
.testimonials-wrap{margin-top:56px}
.testimonials-slider{position:relative;min-height:280px}
.testimonial-card{display:none;background:var(--bg3);border-radius:var(--radius-lg);padding:52px;border:1px solid var(--border);position:relative;max-width:820px;margin:0 auto}
.testimonial-card.active{display:block;animation:scaleIn 0.5s var(--ease)}
.testimonial-quote{position:absolute;top:36px;right:44px;font-size:52px;color:var(--accent);opacity:0.2}
.testimonial-text{font-size:17px;line-height:1.85;color:var(--text-muted);margin-bottom:28px;font-style:italic}
.testimonial-rating{color:var(--accent);font-size:15px;margin-bottom:28px;display:flex;gap:4px}
.testimonial-author{display:flex;align-items:center;gap:18px;padding-top:28px;border-top:1px solid var(--border)}
.testimonial-author img{width:60px;height:60px;border-radius:50%;border:3px solid var(--accent);object-fit:cover;flex-shrink:0}
.testimonial-author strong{display:block;font-size:16px;font-weight:700}
.testimonial-author span{font-size:13px;color:var(--text-muted)}
.testimonials-nav{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:36px}
.testi-btn{width:48px;height:48px;border-radius:50%;border:1px solid var(--border);color:var(--text-muted);font-size:15px;display:flex;align-items:center;justify-content:center;transition:var(--transition);touch-action:manipulation}
.testi-btn:hover,.testi-btn:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}
.testi-dots{display:flex;gap:8px}
.testi-dots .dot{width:10px;height:10px;border-radius:50%;background:var(--border);cursor:pointer;transition:var(--transition);}
.testi-dots .dot.active{background:var(--accent);transform:scale(1.3);}
.dot{width:8px;height:8px;border-radius:50%;background:var(--bg5);border:1px solid var(--border);cursor:pointer;transition:var(--transition);touch-action:manipulation}
.dot.active{background:var(--accent);border-color:var(--accent);width:26px;border-radius:4px}

/* ============================================================ CONTACT */
.contact-section{background:var(--bg2)}
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:start}

/* ---- Homepage contact CTA (simplified — no form) ---- */
.home-contact-cta{display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center}
.home-contact-details{margin-top:8px}
.home-contact-right{}
.home-contact-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px;position:relative;overflow:hidden}
.home-contact-card::before{content:'';position:absolute;top:-60px;right:-60px;width:180px;height:180px;border-radius:50%;background:rgba(232,160,32,0.07);pointer-events:none}
.home-contact-card-icon{width:52px;height:52px;border-radius:14px;background:rgba(232,160,32,0.12);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:20px;margin-bottom:20px}
.home-contact-card h3{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:12px}
.home-contact-card p{color:var(--text-muted);font-size:14px;line-height:1.8;margin-bottom:20px}
.home-contact-perks{list-style:none;display:flex;flex-direction:column;gap:10px}
.home-contact-perks li{font-size:14px;color:var(--text-muted);display:flex;align-items:center;gap:10px}
.home-contact-perks li i{color:var(--accent);font-size:13px;flex-shrink:0}
@media(max-width:900px){.home-contact-cta{grid-template-columns:1fr;gap:48px}}
@media(max-width:600px){.home-contact-card{padding:28px 22px}}
.contact-detail{margin-bottom:28px}
.contact-detail small{font-size:11px;text-transform:uppercase;letter-spacing:2.5px;color:var(--text-dim);display:block;margin-bottom:8px}
.contact-divider{width:40px;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent-light));border-radius:1px;margin:8px 0 10px}
.contact-detail h4{font-size:18px;font-weight:700}
.contact-socials{display:flex;gap:12px;margin-top:8px}
.contact-socials a{width:44px;height:44px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-muted);transition:var(--transition);touch-action:manipulation}
.contact-socials a:hover,.contact-socials a:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}
.contact-form-wrap{background:var(--bg3);border-radius:var(--radius-lg);padding:52px;border:1px solid var(--border);box-shadow:var(--shadow-card)}
.contact-form-header{margin-bottom:36px}
.contact-form-header h3{font-size:28px;font-weight:700;margin-bottom:10px}
.contact-form-header p{color:var(--text-muted);font-size:14px;line-height:1.7}
.form-group{margin-bottom:16px}
.form-group input,.form-group textarea{width:100%;background:var(--bg4);border:1px solid var(--border);border-radius:12px;padding:15px 20px;color:var(--text);font-size:15px;outline:none;transition:var(--transition);resize:none;-webkit-appearance:none;appearance:none}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent);background:var(--bg5);box-shadow:0 0 0 3px rgba(232,160,32,0.1)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-dim)}
.btn-submit{width:100%;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#000;font-weight:700;font-size:15px;padding:18px;border-radius:12px;display:flex;align-items:center;justify-content:center;gap:10px;transition:var(--transition);cursor:pointer;touch-action:manipulation;border:none;letter-spacing:0.3px}
.btn-submit:hover,.btn-submit:focus{transform:translateY(-2px);box-shadow:var(--shadow-accent);outline:none}
.btn-submit:disabled{opacity:.6;cursor:not-allowed;transform:none;box-shadow:none}

/* ---- Form validation states ---- */
.form-group.has-error input,.form-group.has-error textarea{border-color:#ff4d6a!important;background:rgba(255,77,106,0.06)!important}
.form-error-msg{display:none;font-size:12px;color:#ff4d6a;margin-top:5px;padding-left:4px}
.form-group.has-error .form-error-msg{display:block}

/* ---- Form success / error banners ---- */
.form-success,.form-error-banner{
  display:none;margin-top:16px;padding:14px 18px;border-radius:12px;
  font-size:14px;font-weight:600;align-items:center;gap:10px
}
.form-success{background:rgba(0,200,100,0.1);border:1px solid rgba(0,200,100,0.3);color:#00c864}
.form-error-banner{background:rgba(255,77,106,0.1);border:1px solid rgba(255,77,106,0.3);color:#ff4d6a}
.form-success.show,.form-error-banner.show{display:flex}

/* ---- Search results dropdown ---- */
.search-results-dropdown{
  position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg3);
  border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow);z-index:200;max-height:360px;overflow-y:auto;display:none
}
.search-results-dropdown.open{display:block}
.search-result-item{display:flex;align-items:flex-start;gap:14px;padding:14px 20px;
  border-bottom:1px solid var(--border);transition:var(--transition);text-decoration:none;cursor:pointer}
.search-result-item:last-child{border-bottom:none}
.search-result-item:hover{background:var(--bg4)}
.search-result-icon{width:36px;height:36px;border-radius:10px;background:rgba(232,160,32,0.1);
  color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;margin-top:1px}
.search-result-text strong{display:block;font-size:14px;font-weight:600;color:var(--text);margin-bottom:2px}
.search-result-text span{font-size:12px;color:var(--text-muted)}
.search-no-results{padding:20px;text-align:center;color:var(--text-dim);font-size:14px}
.header-search-bar .container{position:relative}

/* ---- Hamburger: desktop hidden, mobile only ---- */
@media(min-width:1151px){.hamburger{display:none}}

/* ============================================================ FAQ */
.faq-section{background:var(--bg)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:56px}
.faq-item{background:var(--bg3);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;transition:var(--transition)}
.faq-item.open{border-color:rgba(232,160,32,0.4);box-shadow:var(--shadow-card)}
.faq-question{width:100%;text-align:left;padding:22px 26px;font-size:15px;font-weight:600;color:var(--text);display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer;transition:var(--transition);touch-action:manipulation;min-height:66px}
.faq-question:hover{color:var(--accent)}
.faq-item.open .faq-question{color:var(--accent)}
.faq-icon{flex-shrink:0;color:var(--accent);transition:transform 0.3s var(--ease);font-size:14px}
.faq-item.open .faq-icon{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s var(--ease),padding 0.3s ease;padding:0 26px}
.faq-item.open .faq-answer{max-height:240px;padding:0 26px 24px}
.faq-answer p{color:var(--text-muted);font-size:14px;line-height:1.8}

/* ============================================================ CLIENTS */
.clients-section{padding:60px 0;background:var(--bg2);border-top:1px solid var(--border)}
.clients-label{text-align:center;font-size:12px;text-transform:uppercase;letter-spacing:3px;color:var(--text-dim);margin-bottom:36px}
.clients-marquee-track{display:flex;width:max-content;animation:marquee 22s linear infinite}
.clients-group{display:flex;gap:64px;padding-right:64px;align-items:center}
.client-logo{font-family:var(--font-head);font-size:18px;font-weight:700;color:var(--text-dim);letter-spacing:2px;text-transform:uppercase;transition:var(--transition);white-space:nowrap;cursor:default}
.client-logo:hover{color:var(--accent)}

/* ============================================================ FOOTER */
.site-footer{background:var(--bg2);border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1.8fr 1fr 1fr 1.4fr;gap:56px;padding:80px 40px 60px}
.footer-logo{font-family:var(--font-head);font-size:30px;font-weight:700;color:var(--accent);letter-spacing:5px;margin-bottom:18px}
.footer-brand p,.footer-tagline{color:var(--text-muted);font-size:14px;line-height:1.85;margin-bottom:28px}
.footer-socials{display:flex;gap:16px}
.footer-socials a{width:40px;height:40px;border-radius:50%;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--text-muted);transition:var(--transition);touch-action:manipulation}
.footer-socials a:hover,.footer-socials a:focus{background:var(--accent);border-color:var(--accent);color:#000;outline:none}
.footer-col h5{font-size:15px;font-weight:700;margin-bottom:22px;color:var(--text);position:relative}
.footer-col h5::after{content:'';display:block;width:32px;height:2px;background:var(--accent);border-radius:1px;margin-top:8px}
.footer-col ul{display:flex;flex-direction:column;gap:12px}
.footer-col ul li a{font-size:14px;color:var(--text-muted);transition:var(--transition);display:flex;align-items:center;gap:8px;touch-action:manipulation}
.footer-col ul li a:hover,.footer-col ul li a:focus{color:var(--accent);padding-left:5px;outline:none}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-muted);line-height:1.65;margin-bottom:12px}
.footer-contact li:last-child{margin-bottom:0}
.footer-contact li i{color:var(--accent);margin-top:3px;flex-shrink:0}
.footer-bottom{border-top:1px solid var(--border);padding:24px 0}
.footer-bottom .container{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}
.footer-bottom p{font-size:13px;color:var(--text-dim)}
.footer-bottom-links{display:flex;gap:24px}
.footer-bottom-links a{font-size:13px;color:var(--text-dim);transition:var(--transition)}
.footer-bottom-links a:hover{color:var(--accent)}

/* ============================================================ BACK TO TOP */
.back-to-top{position:fixed;bottom:36px;right:36px;z-index:700;width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-light));color:#000;font-size:16px;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transform:translateY(24px);transition:var(--transition);box-shadow:var(--shadow-accent);touch-action:manipulation}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{transform:translateY(-4px);box-shadow:0 12px 50px rgba(232,160,32,0.4)}

/* ============================================================ CMS ADMIN BUTTON */
.cms-admin-btn{position:fixed;bottom:36px;left:36px;z-index:700;background:var(--bg3);border:1px solid var(--border);color:var(--text-muted);font-size:12px;font-weight:700;letter-spacing:1px;padding:12px 20px;border-radius:50px;display:none;align-items:center;gap:8px;transition:var(--transition);box-shadow:var(--shadow-sm);text-decoration:none;touch-action:manipulation}
.cms-admin-btn.show{display:flex}
.cms-admin-btn:hover{background:var(--accent);color:#000;border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-accent)}
.cms-admin-btn i{font-size:14px}

/* ============================================================ RESPONSIVE 1200px */
@media(max-width:1150px){
  .primary-nav, .btn-header-cta { display:none }
  .top-bar { display:none; }
  .site-header { top:0; }
}
@media(max-width:1200px){
  :root{--section-pad:90px}
  .container{padding:0 32px}
  .hero-inner{gap:40px}
  .hero-badge-float.badge-top{left:-20px}
  .hero-badge-float.badge-bottom{right:-20px}
  .about-grid{gap:60px}
  .footer-grid{grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:40px}
}

/* ============================================================ RESPONSIVE 1024px */
@media(max-width:1024px){
  :root{--header-h:72px;--section-pad:80px}
  .primary-nav ul{gap:22px}
  .hero-inner{grid-template-columns:1fr 1fr;gap:32px;padding:60px 32px}
  .hero-title{font-size:clamp(2.4rem,4vw,3.6rem)}
  .hero-person-img{height:500px}
  .hero-badge-float.badge-top{left:-10px;top:30px}
  .hero-badge-float.badge-bottom{right:-10px;bottom:30px}
  .about-grid{gap:40px}
  .about-img-main img{height:500px}
  .about-exp-card{right:-16px;padding:20px 24px}
  .about-exp-card strong{font-size:42px}
  .stats-grid{grid-template-columns:repeat(4,1fr);gap:20px}
  .projects-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;gap:12px}
  .project-card.large{grid-row:span 1}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:20px}
  .contact-grid{gap:48px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;padding:60px 32px 40px}
  .service-card{flex:0 0 calc(50% - 14px)}
}

/* ============================================================ RESPONSIVE 768px */
@media(max-width:768px){
  :root{--header-h:64px;--section-pad:70px}
  .container{padding:0 24px}
  .primary-nav{display:none}
  .btn-header-cta{display:none}
  .hero-section{min-height:auto; padding-bottom:60px;}
  .hero-inner{grid-template-columns:1fr;text-align:center;padding:120px 24px 60px;gap:35px}
  .hero-scroll-cue{position:static; margin:40px auto 0; transform:none;}
  /* Show by default if image exists, hidden via JS/logic if empty */
  .hero-visual{display:flex; margin-top: 20px;}
  .hero-visual.hero-hide-mobile{display:none;}
  .hero-inner{grid-template-columns:1fr}
  .hero-badge-float.badge-top{left:0;top:20px;padding:10px 14px}
  .hero-badge-float.badge-bottom{right:0;bottom:20px;padding:10px 14px}
  .hero-badge-float strong{font-size:12px}
  .hero-badge-float small{font-size:10px}
  .hero-badge-float i{font-size:18px}
  .hero-desc{margin:0 auto 36px;font-size:15px}
  .hero-ctas{justify-content:center}
  .hero-stats{justify-content:center;gap:20px}
  .about-grid{grid-template-columns:1fr;gap:48px}
  .about-img-main img{height:420px}
  .about-exp-card{right:0;padding:20px 24px}
  .services-cta-bar{flex-direction:column;align-items:center;text-align:center;padding:24px;gap:16px}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .stat-item{padding:24px 16px}
  .projects-header{grid-template-columns:1fr;gap:16px}
  .projects-grid{grid-template-columns:1fr;gap:12px}
  .project-card,.project-card.large,.project-card.tall{grid-row:span 1;height:260px}
  .faq-grid{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr;gap:40px}
  .contact-form-wrap{padding:36px 28px}
  .footer-grid{grid-template-columns:1fr 1fr;gap:32px;padding:50px 24px 36px}
  .footer-bottom{padding:20px 0}
  .section-title{font-size:clamp(1.7rem,5vw,2.4rem)}
  .team-grid{grid-template-columns:repeat(2,1fr);gap:16px}
  .service-card{flex:0 0 100%}
  .testimonial-card{padding:36px 28px}
}

/* ---- Read More Link (Homepage Services) ---- */
.read-more {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-top: 18px;
  font-size: 13px;
  font-weight: 800;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 1px;
  text-decoration: none;
  transition: var(--transition);
}
.read-more i {
  font-size: 11px;
  transition: transform 0.3s ease;
}
.read-more:hover {
  color: var(--accent-light);
}
.read-more:hover i {
  transform: translateX(4px);
}

/* ============================================================ RESPONSIVE 480px */
@media(max-width:480px){
  :root{--header-h:60px;--section-pad:60px}
  .container{padding:0 18px}
  .site-logo{font-size:22px;letter-spacing:3px}
  .hero-title{font-size:clamp(2rem,8vw,2.8rem)}
  .hero-person-img{height:320px}
  .hero-img-wrap{max-width:280px}
  .hero-stats{gap:12px}
  .hero-stat strong{font-size:28px}
  .hero-badge-float{display:none}
  .stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .stat-item strong{font-size:36px}
  .team-grid{grid-template-columns:1fr 1fr;gap:12px}
  .team-img{height:220px}
  .testimonial-card{padding:28px 20px}
  .contact-form-wrap{padding:28px 20px}
  .side-panel{width:100vw;border-left:none}
  .footer-grid{grid-template-columns:1fr;gap:28px}
  .footer-bottom .container{flex-direction:column;align-items:center;text-align:center;gap:8px}
  .back-to-top{bottom:24px;right:20px;width:44px;height:44px}
  .cms-admin-btn{bottom:24px;left:20px;font-size:11px;padding:10px 16px}
  .btn-style1,.btn-outline{padding:13px 24px;font-size:13px}
  .project-card,.project-card.large{height:220px}
  .hero-ctas{flex-direction:column;align-items:center;width:100%}
  .hero-ctas .btn-style1,.hero-ctas .btn-outline{width:100%;justify-content:center;max-width:280px}
  .faq-question{padding:18px 20px;font-size:14px;min-height:60px}
}

@media(max-width:360px){
  .container{padding:0 14px}
  .hero-title{font-size:1.9rem}
  .section-title{font-size:1.7rem}
  .team-grid{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stat-item{padding:18px 12px}
}

@media(hover:none) and (pointer:coarse){
  .service-card:hover{transform:none}
  .team-card:hover{transform:none}
  .project-arrow{transform:scale(0.85) rotate(0deg);opacity:0.9}
}

/* ============================================================ RAVEN HERO ENHANCEMENTS */
.hero-section::after{content:'';position:absolute;bottom:0;left:0;right:0;height:160px;background:linear-gradient(to top,var(--bg) 0%,transparent 100%);z-index:2;pointer-events:none}
.hero-bg::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 30%,rgba(232,160,32,0.06) 0%,transparent 60%)}

/* Floating orbs — raven edition: warmer, more dramatic */
.orb1{background:rgba(232,140,20,0.09)}
.orb2{background:rgba(180,80,0,0.06)}
.orb3{background:rgba(232,160,32,0.06)}

/* ============================================================ SCROLL ANIMATIONS — staggered children */
[data-animate].animated{animation-fill-mode:both}
.about-feature:nth-child(2){transition-delay:0.1s}
.about-feature:nth-child(3){transition-delay:0.2s}

/* ============================================================ SELECTION COLOR */
::selection{background:var(--accent);color:#000}
::-moz-selection{background:var(--accent);color:#000}

/* ============================================================ FOCUS VISIBLE (accessibility) */
:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:4px}

/* ============================================================ PRINT */

/* ============================================================
   PAGE BACKGROUND LAYER (full-page, behind everything)
   ============================================================ */
.page-bg-layer{
  position:fixed;inset:0;z-index:-2;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  transition:background-image 0.6s ease, opacity 0.6s ease;
}
.page-bg-overlay{
  position:fixed;inset:0;z-index:-1;
  background:rgba(9,9,11,0.7);
  transition:background 0.4s ease;
}

/* ============================================================
   SECTION BACKGROUND LAYER (per-section)
   The .section-bg-layer and .section-bg-overlay are absolutely
   positioned inside sections. To keep text above them we only
   elevate .container children — NOT every child — so we never
   accidentally override hero-bg, hero-overlay, page-banner-bg
   etc. which must stay absolutely positioned.
   ============================================================ */
section{position:relative;}
/* Layered background architecture: sections are transparent so page bg shows through */
section[data-cms-section]{background:transparent !important;}
.section-bg-layer{
  position:absolute;inset:0;z-index:1;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  transition:background-image 0.6s ease;
  pointer-events:none;
}
.section-bg-overlay{
  position:absolute;inset:0;z-index:2;
  background:transparent;
  transition:background 0.4s ease;
  pointer-events:none;
}
/* Only elevate the content wrapper, not every child */
section>.container{position:relative;z-index:3;}

/* ============================================================
   PAGE BANNER (subpage hero strip)
   ============================================================ */
.page-banner{
  padding: clamp(120px, 12vh, 160px) 0 clamp(60px, 8vh, 100px);
  background: linear-gradient(135deg, var(--bg) 0%, var(--bg3) 100%);
  position: relative; overflow: hidden;
}
.page-banner-bg{
  position:absolute;inset:0;
  background-size:cover;background-position:center;background-repeat:no-repeat;
  z-index:0;
}
.page-banner-overlay{
  position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(135deg, rgba(9,9,11,0.92) 0%, rgba(9,9,11,0.65) 100%);
  pointer-events: none;
}
.page-banner-inner {
  position: relative; z-index: 2;
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(40px, 6vw, 80px);
  align-items: center;
}
.page-banner::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at 30% 50%,rgba(232,160,32,0.08) 0%,transparent 60%);
  pointer-events:none;
}
.page-banner .container{position:relative;z-index:2;}
.page-banner-label{
  display:inline-flex;align-items:center;gap:8px;
  font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;
  color:var(--accent);margin-bottom:14px;
  padding:6px 16px;
  background:rgba(232,160,32,0.1);
  border:1px solid rgba(232,160,32,0.25);
  border-radius:50px;
}
.page-banner-title{
  font-family:var(--font-head);
  font-size:clamp(2.2rem,5vw,4rem);
  font-weight:800;line-height:1.1;color:var(--text);
  margin-bottom:20px;
}
.page-banner-title em{font-style:normal;color:var(--accent);}
.breadcrumb-current{color:var(--accent);}

/* --- Split Hero Visual --- */
.page-banner-visual {
  position: relative;
  display: flex;
  justify-content: center;
  perspective: 1000px;
}
.page-banner-img-wrap {
  position: relative;
  width: 100%;
  max-width: 480px;
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
  transform: rotateY(-5deg);
  transition: var(--transition);
}
.page-banner-img-wrap:hover {
  transform: rotateY(0deg) translateY(-5px);
  box-shadow: var(--shadow-accent);
}
.page-banner-img-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.page-banner-visual::after {
  content: ''; position: absolute;
  width: 150%; height: 150%;
  top: -25%; left: -25%;
  background: radial-gradient(circle, rgba(232,160,32,0.1) 0%, transparent 70%);
  z-index: -1;
  pointer-events: none;
}

@media(max-width:992px){
  .page-banner-inner { grid-template-columns: 1fr; gap: 0; text-align: center; }
  .page-banner-label { justify-content: center; }
  .breadcrumb { justify-content: center; }
  .page-banner-visual { display: none !important; height: 0; min-height: 0; overflow: hidden; } /* Hide foreground on small tablets/mobile — no residual space */
}
  .page-banner{padding:120px 0 60px;}
  .page-banner-title{font-size:clamp(1.8rem,6vw,2.6rem);}
}
@media(max-width:480px){
  .page-banner{padding:100px 0 48px;}
  .page-banner-title{font-size:1.8rem;}
}

/* ============================================================
   ABOUT PAGE
   ============================================================ */
.about-content-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;}
.about-image-block{position:relative;}
.about-page-img-main{width:100%;border-radius:var(--radius-lg);object-fit:cover;height:520px;}
.about-img-badge{
  position:absolute;bottom:-24px;right:-24px;
  background:var(--accent);color:#000;padding:20px 24px;border-radius:var(--radius);
  font-family:var(--font-head);font-weight:800;text-align:center;
}
.about-img-badge strong{display:block;font-size:2rem;line-height:1;}
.about-img-badge span{font-size:11px;text-transform:uppercase;letter-spacing:2px;}
.about-text-block{padding-left:16px;}
.about-highlights{display:flex;flex-direction:column;gap:20px;margin-top:36px;}
.about-highlight-item{
  display:flex;align-items:flex-start;gap:16px;
  padding:20px 24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
}
.about-highlight-item .icon{
  width:44px;height:44px;border-radius:10px;background:rgba(232,160,32,0.12);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--accent);font-size:18px;
}
.about-highlight-item h4{font-family:var(--font-head);font-size:16px;margin-bottom:4px;}
.about-highlight-item p{font-size:13px;color:var(--text-muted);line-height:1.6;}

.mission-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center;}
.mission-text p{color:var(--text-muted);line-height:1.9;margin-bottom:20px;}
.mission-image img{width:100%;border-radius:var(--radius-lg);height:400px;object-fit:cover;}

/* ---- About page image block ---- */
.about-page-img{
  position:relative;
  border-radius:var(--radius-xl);
  overflow:visible;
}
.about-page-img>img{
  width:100%;height:520px;object-fit:cover;object-position:top center;
  border-radius:var(--radius-xl);display:block;box-shadow:var(--shadow);
}
.about-exp-badge{
  position:absolute;bottom:32px;right:-28px;
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:#000;padding:24px 28px;border-radius:var(--radius-lg);
  text-align:center;z-index:2;box-shadow:var(--shadow-accent);
}
.about-exp-badge strong{font-family:var(--font-head);font-size:48px;font-weight:700;display:block;line-height:1;}
.about-exp-badge span{font-family:var(--font-head);font-size:34px;font-weight:700;}
.about-exp-badge p{font-size:12px;font-weight:700;margin-top:6px;letter-spacing:0.5px;}
.about-ring{
  position:absolute;width:130px;height:130px;border-radius:50%;
  border:2px solid rgba(232,160,32,0.2);top:-20px;right:-20px;
  animation:spin 22s linear infinite;pointer-events:none;
}
.about-orb{
  position:absolute;width:64px;height:64px;border-radius:50%;
  background:rgba(232,160,32,0.08);bottom:90px;left:-24px;
  animation:float 7s ease infinite;pointer-events:none;
}

/* ---- Mission & Vision cards ---- */
.mv-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:28px;margin-top:48px;
}
.mv-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);
  padding:48px 40px;text-align:center;transition:var(--transition);
}
.mv-card:hover{border-color:var(--accent);transform:translateY(-6px);box-shadow:0 16px 48px rgba(201,168,76,0.12);}
.mv-icon{
  width:72px;height:72px;border-radius:20px;
  background:rgba(232,160,32,0.1);border:1px solid rgba(232,160,32,0.25);
  display:flex;align-items:center;justify-content:center;
  color:var(--accent);font-size:28px;margin:0 auto 24px;
}
.mv-card h3{font-family:var(--font-head);font-size:22px;font-weight:700;margin-bottom:16px;}
.mv-card p{font-size:15px;color:var(--text-muted);line-height:1.8;}
@media(max-width:768px){
  .mv-grid{grid-template-columns:1fr;gap:20px;}
  .mv-card{padding:36px 28px;}
  .about-page-img>img{height:380px;}
  .about-exp-badge{right:0;bottom:-16px;padding:18px 22px;}
  .about-exp-badge strong{font-size:36px;}
  .about-exp-badge span{font-size:26px;}
}

.values-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:20px;}
.value-card{
  padding:32px 24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  text-align:center;transition:var(--transition);
}
.value-card:hover{border-color:var(--accent);transform:translateY(-4px);}
.value-icon{width:56px;height:56px;margin:0 auto 16px;border-radius:14px;background:rgba(232,160,32,0.12);display:flex;align-items:center;justify-content:center;color:var(--accent);font-size:22px;}
.value-card h3,.value-card h4{font-family:var(--font-head);font-size:17px;margin-bottom:10px;font-weight:700;}
.value-card p{font-size:13px;color:var(--text-muted);line-height:1.6;}

.approach-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.approach-step{
  padding:32px 24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  position:relative;
}
.approach-step-num{
  font-family:var(--font-head);font-size:48px;font-weight:800;
  color:rgba(232,160,32,0.12);line-height:1;margin-bottom:16px;
}
.approach-step h3{font-family:var(--font-head);font-size:18px;margin-bottom:10px;}
.approach-step p{font-size:13px;color:var(--text-muted);line-height:1.7;}

.about-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;}

@media(max-width:1024px){
  .about-content-grid{grid-template-columns:1fr;gap:48px;}
  .about-text-block{padding-left:0;}
  .about-img-badge{right:0;bottom:-16px;}
  .mission-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:repeat(3,1fr);}
  .approach-grid{grid-template-columns:repeat(2,1fr);}
  .about-stats-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:600px){
  .values-grid{grid-template-columns:1fr 1fr;}
  .approach-grid{grid-template-columns:1fr;}
  .about-stats-grid{grid-template-columns:1fr 1fr;}
}

/* ============================================================
   SERVICES PAGE — Detail Cards
   ============================================================ */
.service-label-tag{
  display:inline-flex;align-items:center;gap:8px;
  font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);margin-bottom:14px;
}
.service-detail-card{
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
.service-detail-card.reverse{direction:rtl;}
.service-detail-card.reverse>*{direction:ltr;}
.service-detail-visual{position:relative;border-radius:var(--radius-lg);overflow:hidden;}
.service-detail-visual img{width:100%;height:460px;object-fit:cover;display:block;border-radius:var(--radius-lg);transition:transform 0.7s var(--ease);}
.service-detail-visual:hover img{transform:scale(1.04);}
.service-badge{
  position:absolute;bottom:24px;right:24px;
  width:60px;height:60px;border-radius:18px;
  background:linear-gradient(135deg,var(--accent),var(--accent-light));
  color:#000;font-size:24px;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(232,160,32,0.4);
}
.service-detail-body .service-number{
  font-family:var(--font-head);font-size:80px;font-weight:900;
  color:rgba(232,160,32,0.1);line-height:1;margin-bottom:-20px;
}
.service-detail-body h3{
  font-family:var(--font-head);font-size:clamp(1.6rem,2.5vw,2.4rem);
  font-weight:800;line-height:1.2;margin-bottom:18px;
}
.service-detail-body>p{
  color:var(--text-muted);font-size:15px;line-height:1.8;margin-bottom:28px;
}
.service-bullets{display:flex;flex-direction:column;gap:12px;margin-bottom:32px;}
.service-bullet{
  display:flex;align-items:center;gap:12px;
  font-size:14px;color:var(--text-muted);
}
.service-bullet i{color:var(--accent);font-size:15px;flex-shrink:0;}
.service-bullet span{line-height:1.5;}

/* Services CTA section */
.services-cta-inner{
  display:grid;grid-template-columns:1fr auto;gap:64px;align-items:center;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xl);
  padding:64px;
}
.services-cta-text h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.6rem);margin-bottom:14px;}
.services-cta-text p{color:var(--text-muted);font-size:15px;margin-bottom:28px;}
.cta-buttons{display:flex;gap:14px;flex-wrap:wrap;}
.services-cta-img img{width:220px;height:280px;object-fit:cover;border-radius:var(--radius-lg);}

@media(max-width:1024px){
  .service-detail-card{grid-template-columns:1fr;gap:40px;}
  .service-detail-card.reverse{direction:ltr;}
  .service-detail-visual img{height:320px;}
  .services-cta-inner{grid-template-columns:1fr;gap:40px;padding:48px 36px;}
  .services-cta-img{text-align:center;}
  .services-cta-img img{width:180px;height:230px;}
}
@media(max-width:768px){
  .service-detail-body .service-number{font-size:56px;}
  .services-cta-inner{padding:36px 28px;}
}

/* ============================================================
   SERVICES PAGE — Legacy List
   ============================================================ */
.services-list-grid{display:grid;grid-template-columns:1fr;gap:0;}
.service-list-item{
  display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:40px;
  padding:40px 0;border-bottom:1px solid var(--border);
  transition:var(--transition);
}
.service-list-item:first-child{border-top:1px solid var(--border);}
.service-list-item:hover .service-list-num{color:var(--accent);}
.service-list-num{font-family:var(--font-head);font-size:48px;font-weight:800;color:var(--bg5);line-height:1;transition:color 0.3s;}
.service-list-body h3{font-family:var(--font-head);font-size:22px;margin-bottom:8px;}
.service-list-body p{font-size:14px;color:var(--text-muted);line-height:1.7;max-width:560px;}
.service-list-img{width:140px;height:100px;border-radius:var(--radius);overflow:hidden;flex-shrink:0;}
.service-list-img img{width:100%;height:100%;object-fit:cover;}

.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.process-step{
  padding:32px 24px;text-align:center;
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  position:relative;
}
.process-step-num{
  width:56px;height:56px;margin:0 auto 20px;border-radius:50%;
  background:rgba(232,160,32,0.12);border:1px solid rgba(232,160,32,0.3);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-head);font-weight:700;font-size:18px;color:var(--accent);
}
.process-step h3{font-family:var(--font-head);font-size:18px;margin-bottom:10px;}
.process-step p{font-size:13px;color:var(--text-muted);line-height:1.7;}

.services-cta-box{
  padding:80px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xl);
  text-align:center;
}
.services-cta-box h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.8rem);margin-bottom:16px;}
.services-cta-box p{color:var(--text-muted);max-width:500px;margin:0 auto 36px;}
.cta-btns{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}

@media(max-width:1024px){
  .process-grid{grid-template-columns:repeat(2,1fr);}
  .services-cta-box{padding:48px 32px;}
}
@media(max-width:768px){
  .service-list-item{grid-template-columns:60px 1fr;gap:20px;}
  .service-list-img{display:none;}
  .service-list-num{font-size:36px;}
  .process-grid{grid-template-columns:repeat(2,1fr);gap:16px;}
}
@media(max-width:480px){
  .service-list-item{grid-template-columns:1fr;gap:12px;}
  .service-list-num{font-size:28px;}
  .process-grid{grid-template-columns:1fr;}
}

/* ============================================================
   WORK PAGE
   ============================================================ */
.work-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;}
.work-filter-btn{
  padding:10px 22px;border-radius:50px;border:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--text-muted);background:transparent;
  transition:var(--transition);cursor:pointer;
}
.work-filter-btn.active,.work-filter-btn:hover{
  background:var(--accent);color:#000;border-color:var(--accent);
}
.work-grid-full{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;}
.work-card{
  border-radius:var(--radius-lg);overflow:hidden;position:relative;
  height:360px;cursor:pointer;display:block;text-decoration:none;color:var(--text);
}
.work-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease);}
.work-card:hover img{transform:scale(1.06);}
.work-card-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(9,9,11,0.97) 0%,rgba(9,9,11,0.5) 50%,transparent 80%);
  display:flex;flex-direction:column;justify-content:flex-end;padding:24px 28px;
  transition:var(--transition);
}
.work-card:hover .work-card-overlay{background:linear-gradient(to top,rgba(9,9,11,0.99) 0%,rgba(9,9,11,0.65) 55%,rgba(9,9,11,0.15) 100%);}
.work-card-tag{
  display:inline-block;padding:4px 12px;border-radius:50px;
  background:rgba(232,160,32,0.2);border:1px solid rgba(232,160,32,0.4);
  font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;
  color:var(--accent);margin-bottom:10px;align-self:flex-start;
}
.work-card-title{
  font-family:var(--font-head);font-size:17px;margin-bottom:6px;line-height:1.3;
  letter-spacing:-0.01em;font-weight:700;
  display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.work-card-sub{
  font-size:12px;color:rgba(244,244,246,0.7);line-height:1.5;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
  max-height:0;opacity:0;transition:max-height 0.3s ease,opacity 0.3s ease;
}
.work-card:hover .work-card-sub{max-height:48px;opacity:1;}
.work-card .project-arrow{position:absolute;top:16px;right:16px;z-index:3;width:42px;height:42px;border-radius:50%;background:var(--accent);color:#000;font-size:15px;display:flex;align-items:center;justify-content:center;transform:scale(0) rotate(-45deg);transition:var(--transition);}
.work-card:hover .project-arrow{transform:scale(1) rotate(0deg);}
.work-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px;}
.work-stat-box{text-align:center;padding:40px 24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);}
.work-stat-box strong{display:block;font-family:var(--font-head);font-size:clamp(2.4rem,4vw,3.6rem);font-weight:800;color:var(--accent);}
.work-stat-box span{font-size:14px;color:var(--text-muted);}
.work-cta-box{
  padding:80px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xl);
  text-align:center;
}
.work-cta-box h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.8rem);margin-bottom:16px;}
.work-cta-box p{color:var(--text-muted);max-width:500px;margin:0 auto 36px;}

@media(max-width:1024px){.work-grid-full{gap:16px;}.work-cta-box{padding:48px 32px;}}
@media(max-width:768px){.work-grid-full{grid-template-columns:1fr;}.work-stats-grid{grid-template-columns:1fr;}}
@media(max-width:480px){.work-card{height:260px;}}

/* ---- CLASS ALIASES: bridge HTML names ↔ CSS names ---- */
/* Work page uses .work-grid — alias to .work-grid-full */
.work-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
@media(max-width:768px){ .work-grid { grid-template-columns: 1fr; } }

/* Work page uses .filter-tabs / .filter-btn — alias to .work-filter / .work-filter-btn */
.filter-tabs {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}
.filter-btn {
  padding: 10px 22px;
  border-radius: 50px;
  border: 1px solid var(--border);
  font-size: 13px;
  font-weight: 600;
  color: var(--text-muted);
  background: transparent;
  transition: var(--transition);
  cursor: pointer;
  touch-action: manipulation;
}
.filter-btn.active, .filter-btn:hover {
  background: var(--accent);
  color: #000;
  border-color: var(--accent);
}

/* Insight page uses .insights-filter / .insights-filter-btn */
.insights-filter {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 40px;
}

/* Static HTML may still use .insight-img / .insight-body — alias to CSS names */
.insight-img { height: 220px; overflow: hidden; }
.insight-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.insight-card:hover .insight-img img { transform: scale(1.05); }
.insight-body { padding: 28px; }
.insight-body h3 { font-family: var(--font-head); font-size: 19px; margin-bottom: 10px; line-height: 1.3; }
.insight-body p { font-size: 13px; color: var(--text-muted); line-height: 1.7; margin-bottom: 20px; }

/* insight-link alias for insight-read-more */
.insight-link {
  font-size: 13px;
  font-weight: 700;
  color: var(--accent);
  display: flex;
  align-items: center;
  gap: 6px;
}
.insight-link:hover { gap: 10px; }

/* ============================================================
   SINGLE POST / INSIGHT READER
   ============================================================ */

.single-post-view { display: none; max-width: 800px; margin: 0 auto; }
.back-to-insights {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--text-muted); font-size: 13px; font-weight: 600;
  text-decoration: none; margin-bottom: 32px;
  transition: color 0.2s, gap 0.2s;
}
.back-to-insights:hover { color: var(--accent); gap: 12px; }
.back-to-insights i { font-size: 11px; }

.post-meta {
  display: flex; align-items: center; gap: 20px;
  font-size: 13px; color: var(--text-dim);
  margin-bottom: 20px; flex-wrap: wrap;
}
.post-meta span { display: flex; align-items: center; gap: 6px; }
.post-meta i { color: var(--accent); font-size: 11px; }

.single-post-view h1 {
  font-family: var(--font-head); font-size: clamp(28px, 4vw, 44px);
  font-weight: 800; line-height: 1.2; margin-bottom: 32px;
  color: var(--text);
}

.post-cover {
  width: 100%; max-height: 500px; object-fit: cover;
  border-radius: var(--radius-lg); margin-bottom: 48px;
  border: 1px solid var(--border);
}

.post-video-container {
  position: relative; padding-bottom: 56.25%; height: 0;
  overflow: hidden; border-radius: var(--radius-lg);
  margin-bottom: 48px; border: 1px solid var(--border);
}
.post-video-container iframe {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%; border: none;
}

.post-media-link-box {
  background: var(--bg3); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 20px 24px;
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 32px; font-size: 14px; color: var(--text-muted);
}
.btn-media-action {
  margin-left: auto; background: var(--accent); color: #000;
  padding: 8px 16px; border-radius: 6px; font-size: 12px;
  font-weight: 700; text-decoration: none; display: flex;
  align-items: center; gap: 6px; transition: opacity 0.2s;
}
.btn-media-action:hover { opacity: 0.85; }

/* Rich text body — mirrors Quill output formatting */
.post-content {
  font-size: 16px; line-height: 1.8; color: var(--text-muted);
}
.post-content h1,
.post-content h2,
.post-content h3,
.post-content h4 {
  font-family: var(--font-head); color: var(--text);
  font-weight: 700; line-height: 1.25; margin: 1.5em 0 0.5em;
}
.post-content h1 { font-size: 2.75rem; border-bottom: 2px solid var(--accent); padding-bottom: 10px; }
.post-content h2 { font-size: 2rem; margin-top: 2em; }
.post-content h3 { font-size: 1.5rem; }
.post-content h4 { font-size: 1.25rem; }
.post-content p  { margin-bottom: 1.5em; font-size: 1.1rem; line-height: 1.9; color: var(--text-muted); }
.post-content a  { color: var(--accent); text-decoration: underline; text-underline-offset: 3px; }
.post-content a:hover { color: var(--accent-light); }
.post-content strong, .post-content b { color: var(--text); font-weight: 700; }
.post-content em, .post-content i { font-style: italic; }
.post-content u  { text-decoration: underline; }
.post-content s  { text-decoration: line-through; opacity: 0.6; }

.post-content ul,
.post-content ol {
  margin: 1.5em 0; padding-left: 1.5em;
}
.post-content ul { list-style: disc; }
.post-content ol { list-style: decimal; }
.post-content li { margin-bottom: 0.5em; }

.post-content blockquote {
  border-left: 4px solid var(--accent); margin: 2rem 0;
  padding: 1.5rem 2rem; background: var(--bg3);
  border-radius: 0 12px 12px 0;
  font-style: italic; font-size: 1.1rem; color: var(--text);
}

.post-content pre,
.post-content code {
  font-family: 'Courier New', Courier, monospace;
  background: var(--bg2); border: 1px solid var(--border);
  border-radius: 6px; font-size: 0.88em;
}
.post-content pre  { padding: 20px 24px; overflow-x: auto; margin-bottom: 1.5em; }
.post-content code { padding: 2px 6px; color: var(--accent); }

.post-content img {
  max-width: 100%; height: auto; border-radius: var(--radius-lg);
  margin: 2rem 0; border: 1px solid var(--border);
}
.post-content hr {
  border: none; border-top: 1px solid var(--border); margin: 3em 0;
}
.post-content table { border-collapse: collapse; width: 100%; border: 1px solid var(--border); margin: 20px 0; }
.post-content td, .post-content th { border: 1px solid var(--border); padding: 12px; text-align: left; }
.post-content th { background: var(--bg2); color: var(--text); }
.post-content iframe { width: 100%; aspect-ratio: 16/9; border-radius: 12px; margin: 20px 0; }
.post-content .ql-editor { padding: 0; }
.post-content .ql-align-center { text-align: center; }
.post-content .ql-align-right  { text-align: right;  }
.post-content .ql-align-justify { text-align: justify; }

/* ============================================================
   CONTACT PAGE
   ============================================================ */

/* --- 3-card info row at top of contact page --- */
.contact-info-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:64px;
}
.contact-info-card{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  padding:32px 24px;text-align:center;transition:var(--transition);
}
.contact-info-card:hover{border-color:var(--accent);transform:translateY(-4px);box-shadow:var(--shadow-card);}
.contact-info-card .contact-info-icon{
  margin:0 auto 16px;
}
.contact-info-card h4{font-size:16px;font-weight:700;margin-bottom:8px;}
.contact-info-card p{font-size:14px;color:var(--text-muted);margin:0;}
.contact-info-card a{color:var(--text-muted);text-decoration:none;transition:color 0.2s;}
.contact-info-card a:hover{color:var(--accent);}

/* --- 2-col grid: info left, form right --- */
.contact-main-grid{
  display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start;
}
.contact-info-col h2{
  font-size:clamp(22px,3vw,36px);font-weight:800;margin-bottom:16px;
}
.contact-info-col>p{
  font-size:15px;color:var(--text-muted);line-height:1.8;margin-bottom:40px;
}
.contact-hours{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:28px;
}
.contact-hours h5{
  font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;
  color:var(--accent);margin-bottom:16px;
}
.contact-hours ul{list-style:none;padding:0;margin:0;}
.contact-hours ul li{
  display:flex;justify-content:space-between;align-items:center;
  font-size:14px;color:var(--text-muted);
  padding:10px 0;border-bottom:1px solid var(--border);
}
.contact-hours ul li:last-child{border-bottom:none;}
@media(max-width:960px){
  .contact-info-cards{grid-template-columns:1fr;}
  .contact-main-grid{grid-template-columns:1fr;gap:40px;}
}
@media(max-width:480px){
  .contact-info-cards{grid-template-columns:1fr;}
}

.contact-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:60px;align-items:start;}
.contact-info-block{display:flex;flex-direction:column;gap:24px;}
.contact-info-item{
  display:flex;align-items:flex-start;gap:18px;
  padding:24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
}
.contact-info-icon{
  width:48px;height:48px;border-radius:12px;background:rgba(232,160,32,0.12);
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
  color:var(--accent);font-size:20px;
}
.contact-info-text h4{font-family:var(--font-head);font-size:15px;margin-bottom:4px;}
.contact-info-text a,.contact-info-text p{font-size:14px;color:var(--text-muted);transition:color 0.2s;}
.contact-info-text a:hover{color:var(--accent);}
.contact-social-row{display:flex;gap:12px;margin-top:8px;}
.contact-social-row a{
  width:44px;height:44px;border-radius:10px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--text-muted);
  font-size:18px;transition:var(--transition);
}
.contact-social-row a:hover{border-color:var(--accent);color:var(--accent);}
.contact-form-box{
  padding:48px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);
}
.contact-form-box h3{font-family:var(--font-head);font-size:22px;margin-bottom:24px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.form-group label{font-size:13px;font-weight:600;color:var(--text-muted);}
.form-group input,.form-group textarea,.form-group select{
  padding:14px 18px;background:var(--bg4);border:1px solid var(--border);
  border-radius:var(--radius);color:var(--text);font-size:14px;transition:border-color 0.2s;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  outline:none;border-color:var(--accent);
}
.form-group textarea{resize:vertical;min-height:120px;}
.form-submit{margin-top:8px;}
.contact-map-embed{
  width:100%;height:300px;background:var(--bg3);border-radius:var(--radius-lg);
  overflow:hidden;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--text-muted);
}

/* ---- Contact Map (new) ---- */
.contact-map-wrap{border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border)}
.contact-map-header{padding:20px 28px;background:var(--bg3);display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.contact-map-label{font-size:13px;font-weight:700;color:var(--accent);display:flex;align-items:center;gap:8px;letter-spacing:.5px}
.contact-map-addr{font-size:14px;color:var(--text-muted);margin:0}
.contact-map-frame{position:relative;background:var(--bg4)}
.contact-map-frame iframe{filter:grayscale(20%) invert(8%) sepia(5%) saturate(200%);border:none}
.contact-map-ext{position:absolute;bottom:12px;right:12px;background:var(--bg2);color:var(--text-muted);font-size:12px;font-weight:600;padding:7px 14px;border-radius:8px;border:1px solid var(--border);display:flex;align-items:center;gap:6px;text-decoration:none;transition:var(--transition)}
.contact-map-ext:hover{color:var(--accent);border-color:var(--accent)}

@media(max-width:1024px){.contact-grid{grid-template-columns:1fr;}
.contact-form-box{padding:32px 24px;}}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}

/* ============================================================
   TEAM PAGE
   ============================================================ */
.team-grid-full{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.team-card-full{
  background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;transition:var(--transition);
}
.team-card-full:hover{transform:translateY(-6px);border-color:rgba(232,160,32,0.25);}
.team-card-img{height:280px;overflow:hidden;}
.team-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.team-card-full:hover .team-card-img img{transform:scale(1.05);}
.team-card-info{padding:24px;}
.team-card-info h3{font-family:var(--font-head);font-size:18px;margin-bottom:4px;}
.team-card-info .role{font-size:13px;color:var(--accent);font-weight:600;margin-bottom:10px;display:block;}
.team-card-info .bio{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:16px;}
.team-card-social{display:flex;gap:10px;}
.team-card-social a{
  width:36px;height:36px;border-radius:8px;border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:15px;
  color:var(--text-muted);transition:var(--transition);
}
.team-card-social a:hover{color:var(--accent);border-color:var(--accent);}

.team-culture-grid{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.team-culture-text p{color:var(--text-muted);line-height:1.9;margin-bottom:16px;}
.team-culture-features{display:flex;flex-direction:column;gap:16px;margin-top:28px;}
.team-culture-feature{
  display:flex;align-items:center;gap:14px;padding:18px 20px;
  background:var(--bg4);border:1px solid var(--border);border-radius:var(--radius);
}
.team-culture-feature .icon{color:var(--accent);font-size:18px;flex-shrink:0;}
.team-culture-image img{width:100%;border-radius:var(--radius-lg);height:420px;object-fit:cover;}
.team-roles-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;}
.team-role-card{
  padding:28px 24px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
  transition:var(--transition);
}
.team-role-card:hover{border-color:rgba(232,160,32,0.3);}
.team-role-card .tag{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--accent);margin-bottom:10px;display:block;}
.team-role-card h4{font-family:var(--font-head);font-size:17px;margin-bottom:8px;}
.team-role-card p{font-size:13px;color:var(--text-muted);margin-bottom:16px;}
.team-cta-box{padding:80px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;}
.team-cta-box h2{font-family:var(--font-head);font-size:clamp(1.8rem,3vw,2.8rem);margin-bottom:16px;}
.team-cta-box p{color:var(--text-muted);max-width:500px;margin:0 auto 36px;}

@media(max-width:1024px){
  .team-grid-full{grid-template-columns:repeat(2,1fr);}
  .team-culture-grid{grid-template-columns:1fr;}
  .team-roles-grid{grid-template-columns:repeat(2,1fr);}
  .team-cta-box{padding:48px 32px;}
}
@media(max-width:600px){
  .team-grid-full{grid-template-columns:1fr 1fr;}
  .team-roles-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .team-grid-full{grid-template-columns:1fr;}
}

/* ============================================================
   INDUSTRIES PAGE
   ============================================================ */
.industries-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.industry-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);}
.industry-card:hover{transform:translateY(-6px);border-color:rgba(232,160,32,0.25);}
.industry-card-img{height:200px;overflow:hidden;}
.industry-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.industry-card:hover .industry-card-img img{transform:scale(1.05);}
.industry-card-body{padding:28px;}
.industry-icon{
  width:44px;height:44px;border-radius:50%;background:rgba(232,160,32,0.12);
  display:flex;align-items:center;justify-content:center;margin-bottom:14px;
  color:var(--accent);font-size:18px;
}
.industry-card-body h3{font-size:18px;font-weight:700;color:var(--text);margin-bottom:10px;}
.industry-card-body p{font-size:14px;color:var(--text-muted);line-height:1.7;margin-bottom:18px;}
.industry-card-link{
  display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:600;
  color:var(--accent);text-decoration:none;transition:var(--transition);
}
.industry-card-link:hover{gap:12px;}
.industry-card-link i{font-size:12px;}

/* ============================================================
   INSIGHTS PAGE
   ============================================================ */
.insights-filter{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:40px;}
.insights-filter-btn{
  padding:10px 22px;border-radius:50px;border:1px solid var(--border);
  font-size:13px;font-weight:600;color:var(--text-muted);background:transparent;
  transition:var(--transition);cursor:pointer;
}
.insights-filter-btn.active,.insights-filter-btn:hover{background:var(--accent);color:#000;border-color:var(--accent);}
.insights-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px;}
.insight-card{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);}
.insight-card:hover{transform:translateY(-6px);border-color:rgba(232,160,32,0.25);}
.insight-card-img{height:220px;overflow:hidden;}
.insight-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s;}
.insight-card:hover .insight-card-img img{transform:scale(1.05);}
.insight-card-body{padding:28px;}
.insight-meta{display:flex;gap:16px;font-size:12px;color:var(--text-muted);margin-bottom:12px;align-items:center;}
.insight-tag{padding:3px 10px;border-radius:50px;background:rgba(232,160,32,0.12);color:var(--accent);font-weight:700;letter-spacing:1px;text-transform:uppercase;font-size:10px;}
.insight-card-body h3{font-family:var(--font-head);font-size:19px;margin-bottom:10px;line-height:1.3;}
.insight-card-body p{font-size:13px;color:var(--text-muted);line-height:1.7;margin-bottom:20px;}
.insight-read-more{font-size:13px;font-weight:700;color:var(--accent);display:flex;align-items:center;gap:6px;}
  /* DYNAMIC HUB ENHANCEMENTS */
  .services-dynamic-hub {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 30px;
    margin-top: 40px;
  }
  .service-brand-card {
    background: var(--bg3);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 36px;
    transition: var(--transition);
    height: 100%;
    display: flex;
    flex-direction: column;
  }
  .service-brand-card:hover {
    border-color: var(--accent);
    transform: translateY(-8px);
    box-shadow: var(--shadow);
  }
  .service-brand-card h3 {
    font-family: var(--font-head);
    font-size: 20px;
    margin-bottom: 12px;
    color: var(--text);
  }
  .service-brand-card p {
    font-size: 14px;
    color: var(--text-muted);
    line-height: 1.7;
    margin-bottom: 24px;
    flex: 1;
  }
  .btn-text {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    font-weight: 700;
    color: var(--accent);
    text-transform: uppercase;
    letter-spacing: 1px;
    transition: var(--transition);
  }
  .btn-text:hover {
    gap: 12px;
    opacity: 0.8;
  }

  .insight-cat-badge {
    position: absolute;
    top: 20px;
    left: 20px;
    z-index: 5;
    background: var(--accent);
    color: #000;
    font-size: 10px;
    font-weight: 800;
    padding: 4px 12px;
    border-radius: 50px;
    text-transform: uppercase;
    letter-spacing: 1px;
  }

  /* CMS Dashboard UI Refinement */
  .mini-badge {
    display: inline-block;
    padding: 2px 8px;
    font-size: 9px;
    font-weight: 800;
    text-transform: uppercase;
    border-radius: 4px;
    margin-right: 4px;
  }
  .mini-badge.work-bg { background: #e8a020; color: #000; }
  .mini-badge.blog-bg { background: #3b82f6; color: #fff; }
  .mini-badge.service-bg { background: #10b981; color: #fff; }
  .mini-badge.home-p { border: 1px solid #e8a020; color: #e8a020; }
  .mini-badge.work-p { border: 1px solid #3b82f6; color: #3b82f6; }
  .mini-badge.service-p { border: 1px solid #10b981; color: #10b981; }
  .mini-badge.blog-p { border: 1px solid #f43f5e; color: #f43f5e; }

/* ============================================================
   GLOBAL RESPONSIVENESS OVERHAUL
   ============================================================ */

/* LAPTOP / TABLET (Lrg) */
@media(max-width:1024px){
  :root { --section-pad: 80px; }
  .hero-inner { grid-template-columns: 1fr; text-align: center; justify-items: center; padding: 60px clamp(20px, 5vw, 40px); }
  .hero-desc { margin-left: auto; margin-right: auto; }
  .hero-ctas { justify-content: center; }
  .hero-stats { justify-content: center; }
  .hero-visual { display: none; } /* Hide heavy visuals on mobile-ish tablets for core focus */
  
  .about-grid { grid-template-columns: 1fr; gap: 40px; }
  .about-img-main img { height: 400px; }
  .about-exp-card { right: 0; bottom: -20px; padding: 20px; }
  
  .stats-grid { grid-template-columns: 1fr 1fr; }
  .projects-header { grid-template-columns: 1fr; text-align: center; }
  .projects-header p { margin: 0 auto; }
  .projects-grid { grid-template-columns: 1fr 1fr; }
  .project-card.large { grid-column: span 2; }
  
  .team-grid { grid-template-columns: 1fr 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .contact-form-wrap { padding: 30px; }
  
  .faq-grid { grid-template-columns: 1fr; }
}

/* TABLET (Sml) / MOBILE */
@media(max-width:768px){
  :root { --section-pad: 60px; }
  .header-inner { padding: 0 10px; }
  .primary-nav { display: none; } /* Focus on the hamburger for mobile */
  .header-actions .btn-header-cta { display: none; } 
  
  .hero-title { font-size: calc(var(--fs-h1) * 0.9); }
  .section-title { font-size: calc(var(--fs-h2) * 0.95); }
  
  .service-card { flex: 0 0 100%; } /* Carousel items go full width */
  .stats-grid { grid-template-columns: 1fr; }
  .projects-grid { grid-template-columns: 1fr; }
  .project-card.large { grid-column: auto; grid-row: auto; }
  
  .testimonial-card { padding: 30px; }
  .testimonial-text { font-size: 15px; }
  
  .footer-grid { grid-template-columns: 1fr; text-align: center; gap: 40px; }
  .footer-logo { margin: 0 auto 20px; }
  .footer-socials { justify-content: center; }
}

/* PHONES */
@media(max-width:480px){
  .hero-ctas .btn-style1, .hero-ctas .btn-style2 { width: 100%; justify-content: center; }
  .hero-stats { flex-direction: column; gap: 20px; }
  .hero-stat-divider { display: none; }
  
  .about-exp-card strong { font-size: 40px; }
  .about-exp-card span { font-size: 28px; }
  
  .side-panel { width: 100%; }
}

@media print{.site-header,.side-panel,.back-to-top,.cms-admin-btn,.hero-scroll-cue{display:none}}

/* ============================================================
   DEFINITIVE RESPONSIVE OVERHAUL v3.0
   Placed last — wins every cascade conflict.
   Fixes: duplicate rules, missing breakpoints, iOS zoom,
   hero visibility, touch targets, overlapping fixed els.
   ============================================================ */

/* ---- Universal Touch & Form Fixes (all sizes) ---- */
input, textarea, select {
  font-size: 16px !important; /* Prevent iOS auto-zoom on focus */
}
button, a, [role="button"] {
  -webkit-tap-highlight-color: transparent;
}

/* ---- 1200px ---- */
@media (max-width: 1200px) {
  .footer-grid { grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 40px; padding: 72px 32px 48px; }
  .services-dynamic-hub { grid-template-columns: repeat(3, 1fr); gap: 24px; }
}

/* ---- 1024px: Tablet Landscape ---- */
@media (max-width: 1024px) {
  :root { --header-h: 70px; --section-pad: 80px; }

  /* Hero — show visual but shrink it, don't hide */
  .hero-inner {
    grid-template-columns: 1fr 1fr;
    text-align: left;
    gap: 36px;
    padding: 56px 0;
    justify-items: start;
  }
  .hero-visual { display: flex !important; justify-content: center; }
  .hero-person-img { height: 460px; }
  .hero-ctas { justify-content: flex-start; }
  .hero-stats { justify-content: flex-start; }
  .hero-desc { margin-left: 0; margin-right: 0; }

  /* Grids */
  .about-grid { grid-template-columns: 1fr; gap: 48px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .projects-grid { grid-template-columns: 1fr 1fr; }
  .project-card.large { grid-column: span 2; grid-row: span 1; }
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .faq-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 40px; }
  .contact-form-wrap { padding: 36px 28px; }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 40px; padding: 60px 0 40px; }

  /* Page-specific */
  .services-dynamic-hub { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .insights-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .team-grid-full { grid-template-columns: repeat(2, 1fr); }
  .work-grid-full { grid-template-columns: 1fr 1fr; gap: 16px; }
  .work-stats-grid { grid-template-columns: repeat(3, 1fr); }
  .work-cta-box, .services-cta-box, .team-cta-box { padding: 52px 36px; }
  .values-grid { grid-template-columns: repeat(3, 1fr); }
  .approach-grid { grid-template-columns: repeat(2, 1fr); }
  .about-stats-grid { grid-template-columns: repeat(2, 1fr); }
  .process-grid { grid-template-columns: repeat(2, 1fr); }
  .about-content-grid { grid-template-columns: 1fr; gap: 48px; }
  .about-text-block { padding-left: 0; }
  .mission-grid { grid-template-columns: 1fr; }
  .team-culture-grid { grid-template-columns: 1fr; }
  .team-roles-grid { grid-template-columns: repeat(2, 1fr); }
  .contact-form-box { padding: 36px 28px; }
  .newsletter-form { flex-direction: column; gap: 12px; }
  .newsletter-form input, .newsletter-form button { width: 100%; }

  /* Service list */
  .service-list-item { grid-template-columns: 60px 1fr auto; gap: 24px; }
}

/* ---- 768px: Tablet Portrait & Mobile ---- */
@media (max-width: 768px) {
  :root { --header-h: 64px; --section-pad: 64px; }
  .container { padding: 0 20px; }
  
  /* Nav */
  .primary-nav { display: none !important; }
  .btn-header-cta { display: none !important; }
  .header-inner { padding: 0; }

  /* Hero — single column, centered */
  .hero-inner {
    grid-template-columns: 1fr;
    text-align: center;
    gap: 36px;
    padding: 48px 20px 56px;
    justify-items: center;
  }
  .hero-visual { display: flex; justify-content: center; }
  .hero-person-img { height: 340px; max-width: 300px; margin: 0 auto; }
  .hero-img-wrap { max-width: 300px; }
  .hero-badge-float { padding: 10px 14px; }
  .hero-badge-float.badge-top { left: 0; top: 16px; }
  .hero-badge-float.badge-bottom { right: 0; bottom: 16px; }
  .hero-badge-float strong { font-size: 12px; }
  .hero-badge-float small { font-size: 10px; }
  .hero-ctas { justify-content: center; }
  .hero-stats { justify-content: center; gap: 20px; }
  .hero-desc { margin: 0 auto 32px; }

  /* Grids */
  .about-grid { grid-template-columns: 1fr; }
  .about-img-main img { height: 380px; }
  .stats-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .projects-header { grid-template-columns: 1fr; gap: 16px; text-align: center; }
  .projects-grid { grid-template-columns: 1fr; gap: 12px; }
  .project-card, .project-card.large, .project-card.tall { grid-column: auto; grid-row: auto; height: 260px; }
  .team-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .faq-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; gap: 36px; }
  .footer-grid { grid-template-columns: 1fr; text-align: center; gap: 36px; padding: 52px 0 36px; }
  .footer-logo { margin: 0 auto 16px; }
  .footer-socials { justify-content: center; }
  .footer-col ul li a:hover { padding-left: 0; }

  /* Testimonial */
  .testimonial-card { padding: 32px 24px; }
  .testimonial-text { font-size: 15px; }

  /* Services carousel */
  .service-card { flex: 0 0 100%; }
  .services-cta-bar { flex-direction: column; text-align: center; padding: 24px 20px; }

  /* Page-specific */
  .services-dynamic-hub { grid-template-columns: 1fr; gap: 16px; }
  .insights-grid { grid-template-columns: 1fr; gap: 20px; }
  .blog-grid { grid-template-columns: 1fr; gap: 20px; }
  .work-grid-full { grid-template-columns: 1fr; }
  .work-stats-grid { grid-template-columns: 1fr; gap: 16px; }
  .work-cta-box, .services-cta-box, .team-cta-box { padding: 40px 24px; }
  .work-cta-box p, .services-cta-box p, .team-cta-box p { max-width: 100%; }
  .cta-btns { flex-direction: column; align-items: center; }
  .values-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .approach-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .about-stats-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .about-page-img-main { height: 380px; }
  .about-img-badge { right: 0; bottom: -12px; }
  .process-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .service-list-item { grid-template-columns: 48px 1fr; gap: 16px; padding: 28px 0; }
  .service-list-img { display: none; }
  .service-list-num { font-size: 34px; }
  .team-grid-full { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .team-culture-grid { grid-template-columns: 1fr; gap: 36px; }
  .team-roles-grid { grid-template-columns: 1fr 1fr; gap: 14px; }
  .contact-form-box { padding: 28px 20px; }
  .form-row { grid-template-columns: 1fr !important; gap: 0; }

  /* Fixed element positioning — prevent overlap */
  .back-to-top { bottom: 24px; right: 20px; width: 44px; height: 44px; font-size: 14px; }
  .cms-admin-btn { bottom: 80px; left: 20px; font-size: 11px; padding: 10px 16px; }

  /* Section title scaling */
  .section-title { font-size: clamp(1.7rem, 5vw, 2.2rem) !important; }
  .page-banner-title { font-size: clamp(1.8rem, 6vw, 2.6rem) !important; }
  .page-banner { padding: 110px 0 60px; }

  /* Industries/other grids */
  .industries-grid, .industry-grid { grid-template-columns: repeat(2, 1fr) !important; }
}

/* ---- 480px: Small Phones ---- */
@media (max-width: 480px) {
  :root { --header-h: 60px; --section-pad: 56px; }
  .container { padding: 0 16px; }
  .site-logo { font-size: 21px; letter-spacing: 3px; }

  /* Hero */
  .hero-inner { padding: 40px 16px 48px; }
  .hero-title { font-size: clamp(1.9rem, 8vw, 2.6rem) !important; }
  .hero-person-img { height: 290px; }
  .hero-img-wrap { max-width: 260px; }
  .hero-badge-float { display: none; }
  .hero-stats { flex-direction: column; align-items: center; gap: 16px; }
  .hero-stat-divider { display: none; }
  .hero-ctas { flex-direction: column; align-items: center; width: 100%; gap: 12px; }
  .hero-ctas .btn-style1, .hero-ctas .btn-outline, .hero-ctas a { width: 100%; justify-content: center; max-width: 300px; }

  /* Stats & grids */
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .stat-item { padding: 20px 12px; }
  .stat-item strong { font-size: 2.2rem !important; }
  .team-grid { grid-template-columns: 1fr 1fr; gap: 10px; }
  .team-img { height: 210px; }
  .team-card-img { height: 220px; }

  /* Side panel */
  .side-panel { width: 100vw; border-left: none; padding: 48px 24px 32px; }

  /* Footer */
  .footer-grid { grid-template-columns: 1fr; gap: 28px; padding: 40px 0 28px; }
  .footer-bottom .container { flex-direction: column; align-items: center; text-align: center; gap: 8px; }

  /* Fixed buttons — stack vertically, avoid overlap */
  .back-to-top { bottom: 20px; right: 16px; width: 42px; height: 42px; }
  .cms-admin-btn { bottom: 72px; left: 16px; }

  /* Page-specific */
  .values-grid { grid-template-columns: 1fr !important; }
  .approach-grid { grid-template-columns: 1fr !important; }
  .process-grid { grid-template-columns: 1fr !important; }
  .team-roles-grid { grid-template-columns: 1fr !important; }
  .team-grid-full { grid-template-columns: 1fr 1fr; }
  .industries-grid, .industry-grid { grid-template-columns: 1fr !important; }
  .work-card { height: 240px; }
  .work-stat-box { padding: 28px 16px; }
  .contact-form-wrap, .contact-form-box { padding: 24px 16px; }
  .testimonial-card { padding: 24px 18px; }
  .faq-question { padding: 18px 18px; font-size: 14px; min-height: 58px; }

  /* Buttons */
  .btn-style1, .btn-outline { padding: 13px 22px; font-size: 13px; }
  .services-cta-box, .work-cta-box, .team-cta-box { padding: 36px 20px; }
}

/* ---- 360px: Very Small Phones ---- */
@media (max-width: 360px) {
  .container { padding: 0 12px; }
  .hero-title { font-size: 1.85rem !important; }
  .section-title { font-size: 1.65rem !important; }
  .team-grid, .team-grid-full { grid-template-columns: 1fr; }
  .stats-grid { grid-template-columns: 1fr 1fr; gap: 8px; }
  .hero-person-img { height: 260px; }
  .side-panel { padding: 44px 18px 28px; }
}

/* ---- Touch Devices (no hover) ---- */
@media (hover: none) and (pointer: coarse) {
  .service-card:hover { transform: none; }
  .team-card:hover, .team-card-full:hover { transform: none; }
  .insight-card:hover { transform: none; }
  .about-feature:hover { transform: none; }
  .value-card:hover { transform: none; }
  .project-arrow { transform: scale(0.9) rotate(0deg) !important; opacity: 1 !important; }
  .work-card:hover img { transform: none; }
  
  /* Always show nav arrows on touch (can't hover) */
  .carousel-btn { opacity: 1; }
}

/* ---- Landscape Phone (max-height guard) ---- */
@media (max-height: 500px) and (orientation: landscape) {
  .hero-section { min-height: auto; padding: 96px 0 40px; }
  .hero-person-img { height: 240px; }
  .hero-inner { padding: 20px 16px; gap: 24px; }
  #preloader .preloader-logo { font-size: 36px; }
}

/* ============================================================
   TEXT & ALIGNMENT FIXES
   ============================================================ */

/* ---- CRITICAL: btn-style2 missing definition ---- */
/* ---- Improved: btn-style2 as an elegant outline/ghost button ---- */
.btn-style2 {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-body);
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  background: transparent;
  padding: 14px 30px;
  border-radius: 50px;
  border: 2px solid rgba(232, 160, 32, 0.5);
  transition: var(--transition);
  min-height: 50px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  touch-action: manipulation;
}
.btn-style2:hover, .btn-style2:focus {
  background: var(--accent);
  border-color: var(--accent);
  color: #000;
  transform: translateY(-2px);
  box-shadow: var(--shadow-accent);
  outline: none;
}

/* ---- CRITICAL: hero-actions alias (HTML uses hero-actions, not hero-ctas) ---- */
.hero-actions {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 48px;
  align-items: center;
}

/* ---- Section Header — aligned content ---- */
/* Non-centered headers: p stays left, no forced auto margin */
.section-header p {
  color: var(--text-muted);
  max-width: 560px;
  margin: 0;
  line-height: 1.85;
}
/* Centered headers: everything centered */
.section-header.centered {
  text-align: center;
}
.section-header.centered p {
  margin: 0 auto;
  text-align: center;
}
.section-header.centered .section-title {
  text-align: center;
}
.section-header.centered .section-label {
  display: inline-flex;
  margin: 0 auto 18px;
}

/* ---- Section titles — consistent left alignment by default ---- */
.section-title {
  text-align: left;
}
.centered .section-title {
  text-align: center;
}

/* ---- Page Banner — always left-aligned, clean and authoritative ---- */
.page-banner .container,
.page-banner-inner {
  text-align: left;
}
.page-banner-title {
  text-align: left;
}
.page-banner-sub {
  text-align: left;
  max-width: 540px;
  margin: 0 0 28px;
}
.breadcrumb {
  justify-content: flex-start;
  text-align: left;
}

/* ---- Hero text alignment on desktop ---- */
.hero-content {
  text-align: left;
}
.hero-desc {
  text-align: left;
}
.hero-stats {
  text-align: left;
}
.hero-stat {
  text-align: left;
}

/* ---- Card body prose — always left-aligned ---- */
.service-body p,
.project-info p,
.team-info p,
.about-feature p,
.insight-card-body p,
.teammate-bio,
.work-card-sub,
.contact-info-text p,
.contact-info-text a {
  text-align: left;
}

/* ---- Section description paragraphs ---- */
.about-desc,
.section-desc,
.about-text-block p,
.mv-card p,
.value-card p,
.approach-step p,
.process-step p,
.service-brand-card p,
.team-culture-text p,
.mission-text p,
.team-role-card p {
  text-align: left;
  line-height: 1.85;
}

/* ---- Stat boxes and counters — centered ---- */
.stat-item,
.work-stat-box,
.hero-stat strong,
.hero-stat span,
.hero-stat small {
  text-align: center;
}

/* ---- Footer alignment (desktop = left, mobile = center) ---- */
.footer-col,
.footer-brand,
.footer-contact {
  text-align: left;
}
.footer-contact li {
  text-align: left;
  justify-content: flex-start;
}

/* ---- CTA boxes — centered ---- */
.services-cta-box,
.work-cta-box,
.team-cta-box {
  text-align: center;
}
.services-cta-box p,
.work-cta-box p,
.team-cta-box p {
  text-align: center;
  margin: 0 auto 36px;
}

/* ---- Testimonial text ---- */
.testimonial-text {
  text-align: left;
}

/* ---- Contact form header ---- */
.contact-form-header,
.contact-form-box h3 {
  text-align: left;
}

/* ============================================================
   MOBILE TEXT ALIGNMENT OVERRIDES
   ============================================================ */
@media (max-width: 768px) {

  /* Hero — fully centered on mobile */
  .hero-content {
    text-align: center;
    width: 100%;
  }
  .hero-desc { text-align: center; }
  .hero-stats { justify-content: center; text-align: center; }
  .hero-stat { text-align: center; }
  .hero-actions { justify-content: center; }

  /* Section headers — center on mobile for visual balance */
  .section-header {
    text-align: center;
  }
  .section-header p {
    margin: 0 auto;
    text-align: center;
  }
  .section-header .section-label {
    display: inline-flex;
    margin: 0 auto 18px;
  }
  .section-title {
    text-align: center !important;
  }

  /* Page banners — keep left on mobile (breadcrumb looks better left) */
  .page-banner .container,
  .page-banner-title,
  .page-banner-sub,
  .page-banner-inner {
    text-align: left !important;
  }
  /* Breadcrumb always left */
  .breadcrumb {
    justify-content: flex-start !important;
    text-align: left !important;
  }

  /* Cards stay left-aligned for readability */
  .service-body,
  .project-info,
  .insight-card-body,
  .about-feature,
  .contact-info-text,
  .team-card-info {
    text-align: left;
  }

  /* About text area — left for readability when stacked */
  .about-desc,
  .about-text-block p,
  .mv-card p,
  .mission-text p,
  .team-culture-text p {
    text-align: left;
  }

  /* Projects header centered */
  .projects-header .section-header {
    text-align: center;
  }

  /* Footer — center everything on mobile */
  .footer-col,
  .footer-brand,
  .footer-col ul li a,
  .footer-contact li {
    text-align: center;
    justify-content: center;
  }
  .footer-contact li i {
    display: none; /* icon clutters centered layout on mobile */
  }
  .footer-contact li {
    justify-content: center;
  }

  /* CTA buttons centered */
  .hero-actions {
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: 12px;
  }
  .hero-actions .btn-style1,
  .hero-actions .btn-style2,
  .hero-actions a {
    width: 100%;
    max-width: 300px;
    justify-content: center;
  }
}

@media (max-width: 480px) {
  .page-banner-sub { font-size: 15px; }
  .hero-actions { flex-direction: column; align-items: center; width: 100%; }
  .about-exp-card strong, .about-exp-badge strong { font-size: 38px; }
  .about-exp-card span, .about-exp-badge span { font-size: 26px; }
}




/* ============================================================
   PROFESSIONAL POLISH — FINAL RESPONSIVE TWEAKS 
   Ensures total alignment harmony and touch-friendly UI.
   ============================================================ */

/* ---- Center all standalone section headers on mobile ---- */
@media (max-width: 768px) {
  .section-header, 
  .section-header.centered,
  .projects-header,
  .about-content-grid .section-header,
  .services-header,
  .team-header,
  .insight-header {
    text-align: center !important;
    width: 100% !important;
    max-width: 600px !important;
    margin: 0 auto 40px !important;
  }
  .section-header p,
  .section-title {
    text-align: center !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }
  .section-label {
    margin: 0 auto 16px !important;
    display: inline-flex !important;
  }
}

/* ---- Footer & Brand centering ---- */
@media (max-width: 768px) {
  .footer-grid {
    text-align: center !important;
  }
  .footer-col, .footer-brand, .footer-logo-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center !important;
  }
  .footer-logo {
    margin-bottom: 20px !important;
  }
  .footer-socials, .contact-social-row {
    justify-content: center !important;
    margin: 0 auto !important;
  }
  .footer-col ul li {
    text-align: center !important;
  }
}

/* ---- Contact Form & Elements ---- */
@media (max-width: 480px) {
  .contact-form-box, .contact-form-wrap {
    padding: 28px 16px !important;
  }
  .form-group label {
    text-align: left;
    width: 100%;
  }
  .form-submit button {
    width: 100% !important;
  }
}

/* ---- Global Button Stacking ---- */
@media (max-width: 480px) {
  .hero-actions, .cta-btns, .btn-row {
    flex-direction: column !important;
    gap: 12px !important;
    width: 100% !important;
  }
  .btn-style1, .btn-style2, .btn-outline {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
  }
}

/* ---- Better Image Scaling ---- */
@media (max-width: 768px) {
  .about-img-main img {
    height: 340px !important;
  }
}

/* ---- Grid Alignment Fixes ---- */
@media (max-width: 768px) {
  .stats-grid, .stats-row, .work-stats-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 12px !important;
  }
}
@media (max-width: 360px) {
  .stats-grid, .stats-row, .work-stats-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ---- Final Alignment Guard ---- */
.centered-on-mobile {
  text-align: inherit;
}
@media (max-width: 768px) {
  .centered-on-mobile {
    text-align: center !important;
  }
}

/* ============================================================
   ACCESSIBILITY — Skip Link
   ============================================================ */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--accent);
  color: #000;
  padding: 10px 20px;
  font-weight: 700;
  font-size: 14px;
  z-index: 9999;
  text-decoration: none;
  border-radius: 0 0 6px 0;
  transition: top 0.2s;
}
.skip-link:focus { top: 0; }

/* ============================================================
   COOKIE CONSENT BANNER
   ============================================================ */
.cookie-banner {
  position: fixed;
  bottom: -120px;
  left: 0;
  right: 0;
  z-index: 9998;
  padding: 0 24px 24px;
  pointer-events: none;
  transition: bottom 0.4s cubic-bezier(0.34, 1.56, 0.64, 1);
}
.cookie-banner.visible {
  bottom: 0;
  pointer-events: auto;
}
.cookie-banner-inner {
  max-width: 780px;
  margin: 0 auto;
  background: var(--bg2);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 18px 24px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  box-shadow: 0 8px 40px rgba(0,0,0,0.5);
}
.cookie-text {
  flex: 1;
  font-size: 14px;
  color: var(--text-muted);
  line-height: 1.6;
  min-width: 200px;
}
.cookie-text strong { color: var(--text); }
.cookie-text a { color: var(--accent); text-decoration: none; }
.cookie-text a:hover { text-decoration: underline; }
.cookie-actions { display: flex; gap: 10px; flex-shrink: 0; }
.cookie-btn-accept {
  background: var(--accent);
  color: #000;
  border: none;
  border-radius: 8px;
  padding: 9px 22px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
}
.cookie-btn-accept:hover { opacity: 0.85; }
.cookie-btn-decline {
  background: transparent;
  color: var(--text-muted);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 9px 22px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: color 0.2s, border-color 0.2s;
}
.cookie-btn-decline:hover { color: var(--text); border-color: var(--text-muted); }

/* ============================================================
   LEGAL CONTENT PAGES (Privacy, Terms)
   ============================================================ */
.legal-content {
  max-width: 760px;
  margin: 0 auto;
  line-height: 1.85;
  color: var(--text-muted);
}
.legal-content p { margin-bottom: 16px; }
.legal-content h2 {
  font-size: clamp(18px, 2.5vw, 22px);
  color: var(--text);
  font-weight: 700;
  margin: 48px 0 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--border);
}
.legal-content h2:first-of-type { margin-top: 32px; }
.legal-content ul {
  padding-left: 24px;
  margin-bottom: 16px;
}
.legal-content ul li {
  margin-bottom: 8px;
}
.legal-content strong { color: var(--text); }
.legal-content a { color: var(--accent); text-decoration: none; }
.legal-content a:hover { text-decoration: underline; }

/* CMS DASHBOARD HELPERS — Feature Toggles */
.cms-switch { position: relative; display: inline-block; width: 44px; height: 24px; }
.cms-switch input { opacity: 0; width: 0; height: 0; }
.cms-slider { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: var(--bg2); border: 1px solid var(--border); transition: .4s; border-radius: 24px; }
.cms-slider:before { position: absolute; content: ""; height: 18px; width: 18px; left: 2px; bottom: 2px; background-color: var(--text-muted); transition: .4s; border-radius: 50%; }
.cms-switch input:checked + .cms-slider { background-color: var(--accent); border-color: var(--accent); }
.cms-switch input:checked + .cms-slider:before { transform: translateX(20px); background-color: #fff; }

/* Dashboard choice cards */
.choice-card input:checked + .choice-box { border-color: var(--accent); background: rgba(232,160,32,0.05); }
.choice-box { border: 1px solid var(--border); padding: 15px; border-radius: 12px; text-align: center; transition: 0.3s; }
.choice-box i { font-size: 20px; color: var(--text-dim); margin-bottom: 8px; display: block; }
.choice-card input:checked + .choice-box i { color: var(--accent); }
.choice-box h4 { font-size: 13px; margin: 0; color: var(--text); }
.choice-box p { font-size: 10px; margin: 2px 0 0; color: var(--text-dim); }



/* ============================================================
   WORDPRESS CLASSIC EDITOR AESTHETIC — CMS EXTENSION
   ============================================================ */
.wp-editor-header {
  border-bottom: 1px solid #dcdcde;
  border-top-left-radius: 12px;
  border-top-right-radius: 12px;
}
.wp-editor-main {
  min-height: 800px;
}
.wp-editor-sidebar {
  border-left: 1px solid #dcdcde;
}
.wp-metabox {
  border: 1px solid #dcdcde;
  background: #fff;
  border-radius: 0;
  margin-bottom: 20px;
  box-shadow: 0 1px 1px rgba(0,0,0,0.04);
}
.wp-metabox-header {
  border-bottom: 1px solid #dcdcde;
  padding: 10px 15px;
  font-family: var(--font-head);
  font-size: 14px;
  font-weight: 600;
  color: #1d2327;
  background: #fff;
}
.wp-metabox-body {
  padding: 15px;
  background: #fff;
}
.wp-metabox-footer {
  background: #f6f7f7;
  border-top: 1px solid #dcdcde;
  padding: 10px 15px;
}

/* Specific WP-style buttons */
.btn-wp-publish {
  background: #2271b1 !important;
  border-color: #2271b1 !important;
  color: #fff !important;
  text-shadow: 0 -1px 1px #135e96, 1px 0 1px #135e96, 0 1px 1px #135e96, -1px 0 1px #135e96 !important;
  box-shadow: 0 1px 0 #135e96 !important;
  border-radius: 3px !important;
}
.btn-wp-publish:hover {
  background: #135e96 !important;
  border-color: #135e96 !important;
}

/* Handle TinyMCE override theme conflict */
.tox-tinymce {
  border: none !important;
  border-top: 1px solid #dcdcde !important;
}
.tox .tox-toolbar, .tox .tox-toolbar-overlord {
  background-color: #f0f0f1 !important;
  border-bottom: 1px solid #dcdcde !important;
}

#slug-preview {
  color: #50575e;
  border: 1px solid #dcdcde;
  padding: 0 4px;
  background: #fff;
  font-size: 13px;
}


/* ============================================================
   MOBILE — CONSOLIDATED RESPONSIVE FIXES
   These rules sit last in the cascade to cleanly override all
   earlier conflicting blocks.
   ============================================================ */

/* ---- NAV / HEADER ---- */
@media (max-width: 1150px) {
  .primary-nav,
  .btn-header-cta { display: none !important; }
  .top-bar         { display: none !important; }
  .site-header     { top: 0 !important; }
  .hamburger       { display: flex !important; }
}
@media (min-width: 1151px) {
  .hamburger { display: none !important; }
}

/* ============================================================
   TABLET LANDSCAPE  ≤ 1024px
   ============================================================ */
@media (max-width: 1024px) {
  :root { --header-h: 68px; --section-pad: 80px; }

  .header-inner { gap: 16px; }

  .hero-inner {
    grid-template-columns: 1fr 1fr;
    text-align: left;
    gap: 32px;
    padding: 56px 0 48px;
    justify-items: start;
    align-items: center;
  }
  .hero-visual  { display: flex !important; justify-content: center; }
  .hero-ctas    { justify-content: flex-start; }
  .hero-stats   { justify-content: flex-start; }
  .hero-desc    { margin-left: 0; margin-right: 0; }
  .hero-person-img { height: 460px; }

  .about-grid          { grid-template-columns: 1fr; gap: 48px; }
  .stats-grid          { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .projects-header     { grid-template-columns: 1fr; }
  .projects-grid       { grid-template-columns: 1fr 1fr; }
  .project-card.large  { grid-column: span 2; grid-row: span 1; }
  .team-grid           { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .faq-grid            { grid-template-columns: 1fr; }
  .contact-grid        { grid-template-columns: 1fr; gap: 40px; }
  .contact-form-wrap   { padding: 36px 28px; }
  .footer-grid         { grid-template-columns: 1fr 1fr; gap: 40px; padding: 60px 0 40px; }

  /* inner pages */
  .services-dynamic-hub  { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .insights-grid         { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .team-grid-full        { grid-template-columns: repeat(2, 1fr); }
  .work-grid-full        { grid-template-columns: 1fr 1fr; gap: 16px; }
  .work-stats-grid       { grid-template-columns: repeat(3, 1fr); }
  .values-grid           { grid-template-columns: repeat(3, 1fr); }
  .approach-grid         { grid-template-columns: repeat(2, 1fr); }
  .process-grid          { grid-template-columns: repeat(2, 1fr); }
  .about-stats-grid      { grid-template-columns: repeat(2, 1fr); }
  .team-roles-grid       { grid-template-columns: repeat(2, 1fr); }
  .newsletter-form       { flex-direction: column; gap: 12px; }
  .newsletter-form input,
  .newsletter-form button { width: 100%; }
  .service-list-item     { grid-template-columns: 60px 1fr auto; gap: 24px; }
}

/* ============================================================
   TABLET PORTRAIT / LARGE MOBILE  ≤ 768px
   ============================================================ */
@media (max-width: 768px) {
  :root { --header-h: 64px; --section-pad: 64px; }
  .container { padding: 0 20px; }

  /* Header */
  .header-inner { padding: 0; gap: 12px; }
  .primary-nav,
  .btn-header-cta { display: none !important; }
  .site-logo span { font-size: 22px !important; letter-spacing: 2px; }

  /* Section headings */
  .section-title    { font-size: clamp(1.7rem, 5.5vw, 2.2rem) !important; }
  .page-banner-title { font-size: clamp(1.8rem, 6vw, 2.6rem) !important; }
  .page-banner      { padding: 112px 0 64px; }

  /* Hero — single column, centred */
  .hero-inner {
    grid-template-columns: 1fr !important;
    text-align: center !important;
    justify-items: center !important;
    align-items: center;
    gap: 32px;
    padding: 48px 0 56px;
  }
  .hero-visual   { display: flex !important; justify-content: center; }
  .hero-person-img { height: 320px; max-width: 100%; }
  .hero-img-wrap   { max-width: 300px; margin: 0 auto; }
  .hero-ctas       { justify-content: center; }
  .hero-stats      { justify-content: center; gap: 20px; }
  .hero-desc       { margin: 0 auto 32px; }
  .hero-badge-float.badge-top    { left: 0;  top: 16px; }
  .hero-badge-float.badge-bottom { right: 0; bottom: 16px; }
  .hero-badge-float strong { font-size: 11px; }
  .hero-badge-float small  { font-size: 10px; }
  .hero-scroll-cue { position: static; transform: none; margin: 32px auto 0; }

  /* Grids */
  .about-grid          { grid-template-columns: 1fr; }
  .about-img-main img  { height: 360px; }
  .stats-grid          { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .projects-header     { grid-template-columns: 1fr; text-align: center; gap: 16px; }
  .projects-grid       { grid-template-columns: 1fr; gap: 12px; }
  .project-card,
  .project-card.large,
  .project-card.tall   { grid-column: auto !important; grid-row: auto !important; height: 260px; }
  .team-grid           { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .faq-grid            { grid-template-columns: 1fr; }
  .contact-grid        { grid-template-columns: 1fr; gap: 36px; }
  .form-row            { grid-template-columns: 1fr !important; }

  /* Services carousel */
  .service-card        { flex: 0 0 100% !important; }
  .services-cta-bar    { flex-direction: column; text-align: center; padding: 24px 20px; gap: 14px; }

  /* Testimonial */
  .testimonial-card { padding: 32px 24px; }
  .testimonial-text { font-size: 15px; }

  /* Footer */
  .footer-grid {
    grid-template-columns: 1fr !important;
    text-align: center;
    gap: 36px;
    padding: 52px 0 36px;
  }
  .footer-logo                { margin: 0 auto 16px; }
  .footer-tagline             { max-width: 340px; margin: 0 auto 24px; }
  .footer-socials             { justify-content: center; }
  .footer-col h5::after       { margin: 8px auto 0; }
  .footer-col ul              { align-items: center; }
  .footer-col ul li a         { justify-content: center; padding-left: 0 !important; }
  .footer-col ul li a:hover   { padding-left: 0 !important; }
  .footer-contact li          { justify-content: center; }
  .footer-about               { align-items: center; display: flex; flex-direction: column; }
  .footer-bottom              { padding: 20px 0; }
  .footer-bottom .container   { flex-direction: column; align-items: center; text-align: center; gap: 10px; }

  /* Inner pages */
  .services-dynamic-hub  { grid-template-columns: 1fr; gap: 16px; }
  .insights-grid         { grid-template-columns: 1fr; gap: 20px; }
  .blog-grid             { grid-template-columns: 1fr; gap: 20px; }
  .work-grid-full        { grid-template-columns: 1fr; }
  .work-stats-grid       { grid-template-columns: 1fr; gap: 16px; }
  .work-cta-box, .services-cta-box, .team-cta-box { padding: 40px 24px; }
  .cta-btns              { flex-direction: column; align-items: center; }
  .values-grid           { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .approach-grid         { grid-template-columns: 1fr 1fr; gap: 14px; }
  .about-stats-grid      { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .process-grid          { grid-template-columns: 1fr 1fr; gap: 14px; }
  .service-list-item     { grid-template-columns: 48px 1fr; gap: 16px; padding: 28px 0; }
  .service-list-img      { display: none; }
  .team-grid-full        { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .team-culture-grid     { grid-template-columns: 1fr; gap: 36px; }
  .team-roles-grid       { grid-template-columns: 1fr 1fr; gap: 14px; }
  .contact-form-box      { padding: 28px 20px; }
  .industries-grid,
  .industry-grid         { grid-template-columns: repeat(2, 1fr) !important; }

  /* Fixed UI buttons — prevent overlap */
  .back-to-top   { bottom: 24px; right: 20px; width: 44px; height: 44px; font-size: 14px; }
  .cms-admin-btn { bottom: 80px; left: 20px; font-size: 11px; padding: 10px 16px; }
}

/* ============================================================
   SMALL PHONES  ≤ 480px
   ============================================================ */
@media (max-width: 480px) {
  :root { --header-h: 60px; --section-pad: 56px; }
  .container    { padding: 0 16px; }
  .site-logo span { font-size: 20px !important; letter-spacing: 2px; }

  /* Hero */
  .hero-inner      { padding: 40px 0 48px; gap: 28px; }
  .hero-title      { font-size: clamp(1.9rem, 8vw, 2.6rem) !important; }
  .hero-person-img { height: 280px; }
  .hero-img-wrap   { max-width: 260px; }
  .hero-badge-float { display: none !important; }
  .hero-stats      { flex-direction: column; align-items: center; gap: 14px; }
  .hero-stat-divider { display: none; }
  .hero-ctas       { flex-direction: column; align-items: center; width: 100%; gap: 12px; }
  .hero-ctas .btn-style1,
  .hero-ctas .btn-outline,
  .hero-ctas .btn-style2,
  .hero-ctas a     { width: 100%; justify-content: center; max-width: 300px; }

  /* Buttons */
  .btn-style1, .btn-outline, .btn-style2 { padding: 13px 22px; font-size: 13px; }
  .services-cta-box, .work-cta-box, .team-cta-box { padding: 36px 20px; }

  /* Stats */
  .stats-grid   { grid-template-columns: 1fr 1fr; gap: 10px; }
  .stat-item    { padding: 20px 12px; }
  .stat-item strong { font-size: 2.1rem !important; }

  /* Team */
  .team-grid  { grid-template-columns: 1fr 1fr; gap: 10px; }
  .team-img   { height: 200px; }
  .team-card-img { height: 210px; }

  /* Testimonial */
  .testimonial-card { padding: 24px 16px; }
  .testimonial-text { font-size: 14px; }
  .testimonial-author { gap: 12px; }
  .testimonial-author img { width: 48px; height: 48px; }

  /* FAQ */
  .faq-question { padding: 18px 18px; font-size: 14px; min-height: 56px; }

  /* Contact */
  .contact-form-wrap, .contact-form-box { padding: 24px 16px; }

  /* Side panel */
  .side-panel { width: 100vw; border-left: none; padding: 48px 20px 32px; }

  /* Footer */
  .footer-grid   { gap: 28px; padding: 40px 0 28px; }
  .footer-logo   { font-size: 26px; letter-spacing: 4px; }
  .footer-tagline { font-size: 13px; }

  /* Fixed buttons */
  .back-to-top   { bottom: 20px; right: 14px; width: 42px; height: 42px; }
  .cms-admin-btn { bottom: 72px; left: 14px; }

  /* Page grids */
  .values-grid   { grid-template-columns: 1fr !important; }
  .approach-grid { grid-template-columns: 1fr !important; }
  .process-grid  { grid-template-columns: 1fr !important; }
  .team-roles-grid { grid-template-columns: 1fr !important; }
  .team-grid-full  { grid-template-columns: 1fr 1fr; }
  .industries-grid,
  .industry-grid   { grid-template-columns: 1fr !important; }
  .work-card     { height: 260px; }
  /* Always show arrow + excerpt on touch devices */
  .work-card .project-arrow { transform: scale(1) rotate(0deg) !important; }
  .work-card .work-card-sub { max-height: 48px !important; opacity: 1 !important; }
  .work-stat-box { padding: 28px 16px; }

  /* Page banner */
  .page-banner      { padding: 96px 0 52px; }
  .page-banner-title { font-size: clamp(1.7rem, 7.5vw, 2.2rem) !important; }
}

/* ============================================================
   VERY SMALL PHONES  ≤ 360px
   ============================================================ */
@media (max-width: 360px) {
  .container    { padding: 0 12px; }
  .hero-title   { font-size: 1.8rem !important; }
  .section-title { font-size: 1.6rem !important; }
  .team-grid, .team-grid-full { grid-template-columns: 1fr; }
  .stats-grid   { gap: 8px; }
  .hero-person-img { height: 250px; }
  .side-panel   { padding: 44px 16px 28px; }
  .footer-grid  { gap: 24px; }
}

/* ============================================================
   LANDSCAPE PHONE  (max-height guard)
   ============================================================ */
@media (max-height: 500px) and (orientation: landscape) {
  .hero-section { min-height: auto; padding: 90px 0 36px; }
  .hero-person-img { height: 220px; }
  .hero-inner   { padding: 16px 0; gap: 20px; }
  #preloader .preloader-logo { font-size: 36px; }
}

/* ============================================================
   TOUCH DEVICES (no hover states)
   ============================================================ */
@media (hover: none) and (pointer: coarse) {
  .service-card:hover    { transform: none; }
  .team-card:hover,
  .team-card-full:hover  { transform: none; }
  .insight-card:hover    { transform: none; }
  .about-feature:hover   { transform: none; }
  .value-card:hover      { transform: none; }
  .project-arrow         { transform: scale(0.9) rotate(0deg) !important; opacity: 1 !important; }
  .work-card:hover img   { transform: none; }
  .work-card .project-arrow { transform: scale(1) rotate(0deg) !important; opacity: 1 !important; }
  .work-card .work-card-sub { max-height: 48px !important; opacity: 1 !important; }
  .carousel-btn          { opacity: 1 !important; }
  .footer-col ul li a:hover { padding-left: 0 !important; }
}
