/* ============================================================
   MEPA — Design Tokens
   Palette:
   --bg        #FFFFFF   white
   --bg-soft   #F7F4F2   warm off-white (alt sections)
   --panel     rgba(0,0,0,.03)  light card fill
   --line      rgba(0,0,0,.10)
   --text      #0F1117   near-black
   --text-dim  #6B7280   medium gray
   --accent    #E8491A   logo orange-red
   --accent-2  #C73A12   darker orange
   Type: Space Grotesk (display) / Inter (body) / JetBrains Mono (data)
   ============================================================ */

:root{
  --bg:#FFFFFF;
  --bg-soft:#F7F4F2;
  --panel:rgba(0,0,0,0.03);
  --panel-strong:rgba(0,0,0,0.055);
  --line:rgba(0,0,0,0.10);
  --line-soft:rgba(0,0,0,0.06);
  --text:#0F1117;
  --text-dim:#6B7280;
  --accent:#E8491A;
  --accent-2:#C73A12;
  --radius-lg:28px;
  --radius-md:18px;
  --radius-sm:12px;
}

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

html{scroll-behavior:smooth;}

body{
  font-family:'Inter',system-ui,sans-serif;
  background:var(--bg);
  color:var(--text);
  overflow-x:hidden;
  line-height:1.6;
}

.bg-mepa-bg{background:var(--bg);}
.text-mepa-text{color:var(--text);}

h1,h2,h3,.logo-text,.stat-num{
  font-family:'Space Grotesk', sans-serif;
}

a{color:inherit;text-decoration:none;}
ul{list-style:none;}
button{font-family:inherit;background:none;border:none;color:inherit;cursor:pointer;}

.container-x{
  max-width:1280px;
  margin:0 auto;
  padding:0 24px;
}

/* ============================================================
   BACKGROUND FX
   ============================================================ */
.bg-fx{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
.grid-overlay{
  position:absolute;
  inset:-2px;
  background-image:
    linear-gradient(rgba(0,0,0,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,0,0,0.04) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:radial-gradient(ellipse 80% 60% at 50% 0%, black 40%, transparent 100%);
}
.glow{
  position:absolute;
  border-radius:50%;
  filter:blur(140px);
  opacity:.10;
}
.glow-a{
  width:600px;height:600px;
  background:var(--accent);
  top:-200px; left:-150px;
}
.glow-b{
  width:700px;height:700px;
  background:var(--accent-2);
  top:200px; right:-250px;
  opacity:.07;
}
.glow-c{
  width:500px;height:500px;
  background:var(--accent);
  bottom:-200px; left:30%;
  opacity:.06;
}

/* ============================================================
   HEADER / MEGA MENU
   ============================================================ */
.site-header{
  position:sticky;
  top:0;
  z-index:100;
  padding:18px 20px 0;
}
.header-shell{
  max-width:1320px;
  margin:0 auto;
}
.nav-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:10px 12px 10px 22px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,0.08);
  background:rgba(255,255,255,0.10);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  box-shadow:0 8px 32px rgba(0,0,0,0.10), inset 0 1px 0 rgba(255,255,255,0.18);
  transition:background .3s ease, box-shadow .3s ease;
}
.site-header.scrolled .nav-inner{
  background:rgba(255,255,255,0.18);
  box-shadow:0 10px 40px rgba(0,0,0,0.12), inset 0 1px 0 rgba(255,255,255,0.22);
}

span.logo-mark img{
    width: 100%;
    max-width: 100px;
}

/* .logo{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.logo-text{
  font-weight:700;
  font-size:20px;
  letter-spacing:0.06em;
  background:linear-gradient(135deg,#fff 30%, var(--accent) 100%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
} */

/* Desktop nav */
.nav-menu{
  display:flex;
  align-items:center;
  gap:4px;
  flex:1;
  justify-content:space-between;
}
.nav-item{position:relative;}
.nav-link{
  display:flex;
  align-items:center;
  gap:6px;
  font-size:14px;
  font-weight:500;
  color:var(--text);
  padding:10px 13px;
  border-radius:999px;
  transition:color .2s ease, background .2s ease;
  white-space:nowrap;
}
.nav-link:hover, .nav-item:hover > .nav-link{
  color:var(--accent);
  background:var(--panel-strong);
  backdrop-filter:blur(24px) saturate(180%);
}
.chev{
  width:10px;height:7px;
  color:var(--text-dim);
  transition:transform .25s ease;
}
.nav-item:hover .chev{transform:rotate(180deg); color:var(--accent);}

.nav-actions{
  display:flex;
  align-items:center;
  gap:10px;
  flex-shrink:0;
}
.nav-cta{font-size:14px; padding:11px 22px;}

/* Mega panels */
.mega-panel{
  position:absolute;
  top:calc(100% + 14px);
  left:50%;
  transform:translateX(-50%) translateY(8px);
  background:rgb(255, 255, 255);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-md);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  box-shadow:0 24px 60px rgba(0,0,0,0.10), inset 0 1px 0 rgba(255,255,255,0.18);
  padding:18px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transition:opacity .22s ease, transform .22s ease, visibility .22s ease;
  z-index:50;
}
.nav-item.has-mega:hover .mega-panel,
.nav-item.has-mega:focus-within .mega-panel{
  opacity:1;
  visibility:visible;
  transform:translateX(-50%) translateY(0);
  pointer-events:auto;
}

.mega-simple{
  min-width:280px;
  left:0;
  transform:translateX(0) translateY(8px);
}
.nav-item.has-mega:hover .mega-simple{
  transform:translateX(0) translateY(0);
}

.mega-wide{
  width:907px;
  left:100%;
}

.mega-grid{display:grid; gap:8px;}
.mega-grid-3{grid-template-columns:1fr 1fr 1.2fr;}

.mega-col{padding:6px 10px;}
.mega-col + .mega-col{border-left:1px solid var(--line-soft);}

.mega-heading{
  font-size:11px;
  font-weight:600;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:10px;
  padding:0 8px;
}

.mega-links{display:flex; flex-direction:column; gap:2px;}
.mega-links a{
  display:flex;
  align-items:center;
  gap:10px;
  font-size:14px;
  color:var(--text);
  padding:9px 10px;
  border-radius:10px;
  transition:background .18s ease, color .18s ease, padding-left .18s ease;
}
.mega-links a:hover{
  background:linear-gradient(90deg, rgba(232,73,26,0.10), rgba(199,58,18,0.06));
  color:var(--accent);
}
.mega-icon{
  font-size:11px;
  color:var(--accent-2);
  flex-shrink:0;
}

.mega-promo{
  margin-top:14px;
  padding:14px;
  border-radius:var(--radius-sm);
  background:linear-gradient(135deg, rgba(232,73,26,0.14), rgba(199,58,18,0.10));
  border:1px solid rgba(255,255,255,0.08);
}
.mega-promo-eyebrow{
  font-size:10px;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--accent);
  font-weight:600;
  margin-bottom:6px;
}
.mega-promo-title{
  font-family:'Space Grotesk', sans-serif;
  font-weight:600;
  font-size:15px;
  margin-bottom:6px;
}
.mega-promo-desc{
  font-size:12.5px;
  color:var(--text-dim);
  margin-bottom:10px;
}
.mega-promo-link{
  font-size:13px;
  font-weight:600;
  color:var(--accent);
}

/* Mobile menu */
.menu-toggle{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:42px; height:42px;
  border-radius:50%;
  border:1px solid var(--line);
  background:var(--panel);
  align-items:center;
}
.menu-toggle span{
  width:18px; height:1.5px;
  background:var(--accent);
  border-radius:2px;
  transition:transform .25s ease, opacity .25s ease;
}
.menu-toggle.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg);}
.menu-toggle.open span:nth-child(2){opacity:0;}
.menu-toggle.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg);}

.mobile-menu{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease;
}
.mobile-menu.open{max-height:90vh; overflow-y:auto;}
.mobile-menu-inner{
  margin:12px 8px 0;
  padding:16px;
  border-radius:var(--radius-md);
  background:#fff;
  border:1px solid rgba(255,255,255,0.08);
  backdrop-filter:blur(24px);
  display:flex;
  flex-direction:column;
  gap:4px;
}
.mobile-link{
  padding:12px 10px;
  font-size:15px;
  font-weight:500;
  border-radius:10px;
}
.mobile-link:hover{background:var(--panel-strong);}
.mobile-group summary{
  padding:12px 10px;
  font-size:15px;
  font-weight:500;
  border-radius:10px;
  cursor:pointer;
  list-style:none;
  display:flex;
  justify-content:space-between;
  align-items:center;
}
.mobile-group summary::after{
  content:'+';
  color:var(--accent);
  font-size:18px;
}
.mobile-group[open] summary::after{content:'–';}
.mobile-group a{
  display:block;
  padding:10px 22px;
  font-size:14px;
  color:var(--text-dim);
  border-radius:8px;
}
.mobile-group a:hover{color:var(--accent); background:var(--panel);}
.mobile-cta{
  margin:14px 4px 4px;
  text-align:center;
}

/* ============================================================
   BUTTONS / SHARED ELEMENTS
   ============================================================ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-size:15px;
  font-weight:600;
  padding:14px 28px;
  border-radius:999px;
  transition:transform .2s ease, box-shadow .2s ease, background .2s ease, border-color .2s ease;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  color:#FFFFFF;
  box-shadow:0 8px 24px rgba(232,73,26,0.28);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 12px 32px rgba(232,73,26,0.40);
}
.btn-ghost{
  color:var(--text);
  border:1px solid var(--line);
  background:var(--panel);
}
.btn-ghost:hover{
  border-color:var(--accent);
  color:var(--accent);
}
.btn-outline{
  border:1px solid var(--line);
  color:var(--text);
  background:transparent;
  font-size:14px;
  padding:12px 22px;
}
.btn-outline:hover{border-color:var(--accent); color:var(--accent);}

.glass-panel{
  background:#FFFFFF;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  box-shadow:0 2px 16px rgba(0,0,0,0.06);
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:18px;
}
.eyebrow-dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--accent);
  box-shadow:0 0 0 4px rgba(232,73,26,0.15);
}

.text-gradient{
  background:linear-gradient(135deg, var(--accent), var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

.section{padding:60px 0;}
.section-alt{background:linear-gradient(180deg, transparent, rgba(232,73,26,0.04), transparent);}

.section-title{
  font-size:clamp(28px, 4vw, 44px);
  font-weight:600;
  line-height:1.2;
  letter-spacing:-0.01em;
  margin-bottom:18px;
}
.section-text{
  color:var(--text-dim);
  font-size:16px;
  max-width:560px;
}
.section-head{margin-bottom:56px;}
.section-head-row{
  display:flex;
  justify-content:space-between;
  align-items:flex-end;
  gap:24px;
  flex-wrap:wrap;
}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;
  z-index:1;
  padding:90px 0 80px;
}
.hero-container{
  max-width:1280px;
  margin:0 auto;
  padding:0 24px;
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:60px;
  align-items:center;
}
.hero-title{
  font-size:clamp(38px, 5.5vw, 64px);
  font-weight:700;
  line-height:1.1;
  letter-spacing:-0.02em;
  margin-bottom:24px;
}
.hero-sub{
  color:var(--text-dim);
  font-size:18px;
  max-width:540px;
  margin-bottom:36px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
}
.hero-stats{
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  gap:24px;
  border-top:1px solid var(--line-soft);
  padding-top:32px;
}
.stat-num{
  font-size:28px;
  font-weight:700;
  margin-bottom:4px;
}
.stat-label{
  font-size:12.5px;
  color:var(--text-dim);
}

/* Hero visual — image frame */
.hero-visual{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-img-frame{
  position:relative;
  width:100%;
  max-width:460px;
  margin-left:auto;
}

/* Corner bracket accents */
.frame-corner{
  position:absolute;
  width:30px;
  height:30px;
  z-index:3;
  pointer-events:none;
}
.frame-corner--tl{
  top:-10px; left:-10px;
  border-top:2px solid var(--accent);
  border-left:2px solid var(--accent);
  border-radius:4px 0 0 0;
}
.frame-corner--br{
  bottom:-10px; 
  right:-10px;
  border-bottom:2px solid var(--accent-2);
  border-right:2px solid var(--accent-2);
  border-radius: 0 0 4px 0;
}

/* Image wrapper */
.hero-img-wrap{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  aspect-ratio:3/4;
  border:1px solid var(--line);
  background:linear-gradient(
    160deg,
    rgba(232,73,26,0.12) 0%,
    rgba(199,58,18,0.18) 45%,
    rgba(30,20,18,0.96) 100%
  );
}
.hero-img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  position:relative;
  z-index:1;
}
.hero-img-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(
    to top,
    rgba(20,12,10,0.85) 0%,
    rgba(20,12,10,0.18) 55%,
    transparent 100%
  );
}

/* Bottom label inside image */
.hero-img-label{
  position:absolute;
  bottom:26px; left:22px; right:22px;
  z-index:3;
  display:flex;
  flex-direction:column;
  gap:5px;
}
.him-tag{
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.18em;
  color:var(--accent);
}
.him-desc{
  font-size:13px;
  color:rgba(255,255,255,0.65);
  line-height:1.5;
}

/* Live network badge */
.hero-badge{
  position:absolute;
  top:22px; right:-18px;
  z-index:4;
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 16px;
  border-radius:100px;
  border:1px solid rgba(232,73,26,0.35);
  background:rgba(232,73,26,0.10);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  font-size:12px;
  font-weight:500;
  color: #fff;
  white-space:nowrap;
  box-shadow:0 4px 24px rgba(232,73,26,0.15);
}
.hero-badge-dot{
  width:7px; height:7px;
  border-radius:50%;
  background:#fff;
  flex-shrink:0;
  animation:pulse 2.4s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{opacity:1; transform:scale(1);}
  50%{opacity:.5; transform:scale(.75);}
}

/* Floating metric chips */
.hero-chip{
  position:absolute;
  z-index:4;
  background:rgba(20, 15, 13, 0) !important;
  border-color:rgba(255,255,255,0.12) !important;
  box-shadow:0 4px 20px rgba(0,0,0,0.20) !important;
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  padding:14px 20px;
  border-radius:var(--radius-sm);
  text-align:center;
  min-width:88px;
}
.hero-chip--left{
  bottom:26%; left:-32px;
  animation:float 5.5s ease-in-out infinite;
}
.hero-chip--right{
  top:26%; right:-20px;
  animation:float 5.5s ease-in-out infinite 1.6s;
}
.chip-val{
  font-family:'Space Grotesk', sans-serif;
  font-size:22px;
  font-weight:700;
  line-height:1;
  margin-bottom:4px;
  background:linear-gradient(135deg, var(--accent) 30%, var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
}
.chip-lbl{
  font-size:11px;
  color:#ffff;
  white-space:nowrap;
}
@keyframes float{
  0%,100%{transform:translateY(0);}
  50%{transform:translateY(-10px);}
}

/* ============================================================
   LOGO STRIP
   ============================================================ */
.logo-strip{
  padding:36px 0;
  border-top:1px solid var(--line-soft);
  border-bottom:1px solid var(--line-soft);
  position:relative;
  z-index:1;
}
.logo-strip-label{
  text-align:center;
  font-size:13px;
  color:var(--text-dim);
  margin-bottom:24px;
  letter-spacing:.02em;
}
.logo-marquee{overflow:hidden; mask-image:linear-gradient(90deg, transparent, black 10%, black 90%, transparent);}
.logo-track{
  display:flex;
  gap:64px;
  width:max-content;
  animation:marquee 28s linear infinite;
}
.logo-item{
  font-family:'Space Grotesk', sans-serif;
  font-weight:600;
  font-size:18px;
  letter-spacing:.06em;
  color:var(--text-dim);
  opacity:.6;
  white-space:nowrap;
}
@keyframes marquee{
  from{transform:translateX(0);}
  to{transform:translateX(-50%);}
}

/* ============================================================
   ABOUT (redesign)
   ============================================================ */
.about-section{ overflow:hidden; }

/* Identity header */
.about-identity{ margin-bottom:56px; }
.about-identity-line{
  display:flex;
  align-items:center;
  gap:20px;
  margin-bottom:24px;
}
.about-identity-rule{
  flex:1;
  height:1px;
  background:var(--line);
}
.about-identity-year{
  font-family:'JetBrains Mono', monospace;
  font-size:12px;
  color:var(--text-dim);
  letter-spacing:.14em;
  text-transform:uppercase;
}
.about-headline{
  font-family:'Space Grotesk', sans-serif;
  font-size:clamp(26px,3.6vw,46px);
  font-weight:700;
  line-height:1.18;
  max-width:680px;
}

/* Body grid */
.about-body{
  display:grid;
  grid-template-columns:1fr 1.7fr;
  gap:40px;
  align-items:start;
  margin-bottom:40px;
}

/* Stat tower */
.about-stats-tower{
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  overflow:hidden;
}
.about-stat-block{
  position:relative;
  padding:28px 28px 28px 36px;
  border-bottom:1px solid var(--line);
  background:transparent;
  transition:background .25s ease;
}
.about-stat-block:last-child{ border-bottom:none; }
.about-stat-block:hover{ background:var(--panel-strong); }
.about-stat-block--accent{ background:rgba(232,73,26,.05); }
.about-stat-block--violet{ background:rgba(199,58,18,.04); }
.about-stat-bar{
  position:absolute;
  left:0; top:0; bottom:0;
  width:3px;
  background:linear-gradient(to bottom, var(--accent), var(--accent-2));
}
.about-stat-big{
  font-family:'Space Grotesk', sans-serif;
  font-size:46px;
  font-weight:700;
  line-height:1;
  background:linear-gradient(135deg, var(--accent) 30%, var(--accent-2));
  -webkit-background-clip:text;
  background-clip:text;
  -webkit-text-fill-color:transparent;
  margin-bottom:6px;
}
.about-stat-lbl{
  font-size:13px;
  color:var(--text-dim);
  letter-spacing:.03em;
}

/* Content panel */
.about-content-panel{
  display:flex;
  flex-direction:column;
  gap:36px;
}
.about-desc{
  font-size:17px;
  line-height:1.78;
  color:var(--text-dim);
}
.about-pillars{
  display:flex;
  flex-direction:column;
  gap:14px;
}
.about-pillar{
  display:flex;
  gap:20px;
  align-items:flex-start;
  padding:20px 22px;
  border-radius:var(--radius-sm);
  border:1px solid var(--line-soft);
  background:var(--panel);
  transition:border-color .22s ease, background .22s ease;
}
.about-pillar:hover{
  border-color:rgba(232,73,26,.4);
  background:var(--panel-strong);
}
.pillar-index{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  font-weight:500;
  color:var(--accent);
  letter-spacing:.1em;
  padding-top:3px;
  flex-shrink:0;
}
.pillar-title{
  font-size:15px;
  font-weight:600;
  color:var(--text);
  margin-bottom:4px;
}
.pillar-desc{
  font-size:13.5px;
  color:var(--text-dim);
  line-height:1.65;
}

/* Locations strip */
.about-locations{
  display:flex;
  align-items:center;
  gap:20px;
  padding:18px 24px;
  border-radius:var(--radius-sm);
  border:1px solid var(--line-soft);
  background:var(--panel);
  flex-wrap:wrap;
}
.about-loc-label{
  font-family:'JetBrains Mono', monospace;
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.14em;
  color:var(--accent);
  white-space:nowrap;
}
.about-loc-list{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}
.about-loc{ font-size:14px; color:var(--text); }
.about-loc-sep{ font-size:12px; color:var(--text-dim); }

/* ============================================================
   CARD GRIDS
   ============================================================ */
.grid-cards{display:grid; gap:20px;}
.grid-cards-3{grid-template-columns:repeat(3,1fr);}
.grid-cards-4{grid-template-columns:repeat(4,1fr);}
.grid-cards-5{grid-template-columns:repeat(5,1fr);}

.feature-card{
  padding:28px 24px;
  transition:transform .25s ease, border-color .25s ease, background .25s ease;
}
.feature-card:hover{
  transform:translateY(-6px);
  border-color:rgba(232,73,26,0.35);
  background:rgba(232,73,26,0.03);
}
.feature-icon{
  width:46px;height:46px;
  display:flex;align-items:center;justify-content:center;
  border-radius:14px;
  color:var(--accent);
  font-size:20px;
  margin-bottom:18px;
}
.feature-card h3{
  font-size:16px;
  font-weight:600;
  margin-bottom:8px;
  letter-spacing:-0.01em;
}
.feature-card p{
  font-size:14px;
  color:var(--text-dim);
}

.industries-grid .industry-card{
  padding:28px 22px;
  transition:transform .25s ease, border-color .25s ease;
}
.industry-card:hover{
  transform:translateY(-6px);
  border-color:rgba(232,73,26,0.35);
}
.industry-card h3{
  font-size:17px;
  font-weight:600;
  margin-bottom:8px;
}
.industry-card p{
  font-size:13.5px;
  color:var(--text-dim);
}

/* ============================================================
   CASE STUDIES — Horizontal Split Cards
   ============================================================ */
.cs-grid{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.cs-card{
  display:grid;
  grid-template-columns:380px 1fr;
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--line);
  min-height:270px;
  transition:transform .35s cubic-bezier(.4,0,.2,1),
             box-shadow .35s ease,
             border-color .35s ease;
}
.cs-card:hover{
  transform:translateY(-4px);
  box-shadow:0 20px 56px rgba(0,0,0,.1), 0 4px 16px rgba(232,73,26,.06);
  border-color:rgba(232,73,26,.2);
}

/* Dark visual panel */
.cs-visual{
  position:relative;
  overflow:hidden;
  display:flex;
  flex-direction:column;
  justify-content:flex-end;
  /* padding:24px 26px; */
  border-right:1px solid rgba(232,73,26,.1);
  transition:border-color .35s ease;
}
.cs-card:hover .cs-visual{ border-right-color:rgba(232,73,26,.32); }

/* Gradient + embedded texture per industry */
/* .cs-visual--logistics{
  background:
    radial-gradient(circle, rgba(255,255,255,.11) 1px, transparent 1px),
    linear-gradient(148deg, #061220 0%, #0c2442 52%, #0d3262 100%);
  background-size:26px 26px, 100% 100%;
} */
.cs-visual--realestate{
  background:
    linear-gradient(rgba(255,135,35,.07) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,135,35,.07) 1px, transparent 1px),
    linear-gradient(148deg, #130800 0%, #2f1100 52%, #4a1b00 100%);
  background-size:26px 26px, 26px 26px, 100% 100%;
}
.cs-visual--construction{
  background:
    repeating-linear-gradient(-45deg, transparent, transparent 13px, rgba(255,255,255,.04) 13px, rgba(255,255,255,.04) 14px),
    linear-gradient(148deg, #070c18 0%, #0e1927 52%, #0a1a2e 100%);
}

/* Orange glow blob */
.cs-glow{
  position:absolute;
  top:-48px;
  right:-48px;
  width:200px;
  height:200px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(232,73,26,.58) 0%, transparent 65%);
  pointer-events:none;
  z-index:0;
  transition:transform .4s ease;
}
.cs-card:hover .cs-glow{ transform:scale(1.2); }

/* Geometric decoration per industry */
.cs-deco{
  position:absolute;
  pointer-events:none;
  z-index:0;
}
.cs-visual--logistics .cs-deco{
  width:280px; height:280px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.06);
  top:50%; left:48%;
  transform:translate(-50%,-50%);
}
.cs-visual--realestate .cs-deco{
  width:140px; height:100px;
  border:1px solid rgba(255,135,35,.15);
  border-radius:8px;
  bottom:36px; right:22px;
  transform:rotate(7deg);
}
.cs-visual--construction .cs-deco{
  width:100px; height:100px;
  border:1.5px solid rgba(255,255,255,.08);
  border-radius:6px;
  top:28px; right:28px;
}

/* Case number top-left */
.cs-num{
  position:absolute;
  top:20px;
  left:24px;
  font-family:'JetBrains Mono', monospace;
  font-size:10px;
  font-weight:600;
  letter-spacing:.22em;
  color:rgba(255,255,255,.26);
  z-index:2;
}

/* Bottom gradient fade */
.cs-vfade{
  position:absolute;
  inset:0;
  background:linear-gradient(to bottom, transparent 28%, rgba(0,0,0,.65) 100%);
  pointer-events:none;
  z-index:1;
}

/* Metrics */
.cs-metrics{
  position:relative;
  z-index:2;
  display:flex;
  gap:22px;
  align-items:flex-end;
}
.cs-stat{ display:flex; flex-direction:column; gap:4px; }
.cs-stat-val{
  font-family:'Space Grotesk', sans-serif;
  font-size:38px;
  font-weight:700;
  line-height:1;
  color:#fff;
  letter-spacing:-.03em;
}
.cs-stat-val small{
  font-size:.42em;
  font-weight:700;
  letter-spacing:0;
  vertical-align:middle;
}
.cs-stat-lbl{
  font-size:9px;
  font-weight:600;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(255,255,255,.44);
}

/* Light content panel */
.cs-body{
  position:relative;
  overflow:hidden;
  padding:36px 44px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:11px;
  background:var(--bg);
}

/* Ghost watermark number */
.cs-wmk{
  position:absolute;
  right:-6px;
  bottom:-30px;
  font-family:'Space Grotesk', sans-serif;
  font-size:190px;
  font-weight:800;
  line-height:1;
  color:var(--text);
  opacity:.033;
  user-select:none;
  pointer-events:none;
  letter-spacing:-.04em;
}

.cs-tag{
  font-size:10px;
  font-weight:700;
  letter-spacing:.15em;
  text-transform:uppercase;
  color:var(--accent);
}
.cs-body h3{
  font-family:'Space Grotesk', sans-serif;
  font-size:20px;
  font-weight:600;
  line-height:1.3;
  color:var(--text);
  max-width:38ch;
}
.cs-body p{
  font-size:14px;
  color:var(--text-dim);
  line-height:1.65;
  max-width:50ch;
}
.cs-link{
  margin-top:8px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  font-size:13px;
  font-weight:600;
  color:var(--accent);
  transition:gap .22s ease;
}
.cs-link:hover{ gap:13px; }

/* Insights */
.insight-card{
  padding:28px;
  display:flex;
  flex-direction:column;
  gap:12px;
  transition:transform .25s ease, border-color .25s ease;
}
.insight-card:hover{
  transform:translateY(-6px);
  border-color:rgba(232,73,26,0.35);
}
.insight-meta{
  display:flex;
  justify-content:space-between;
  font-size:12px;
  color:var(--text-dim);
}
.insight-meta span:first-child{color:var(--accent);}
.insight-card h3{
  font-size:18px;
  font-weight:600;
  line-height:1.35;
}
.insight-card p{
  font-size:14px;
  color:var(--text-dim);
}

/* ============================================================
   PARTNERSHIPS
   ============================================================ */
.partnerships-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:48px;
  align-items:center;
}

.partner-badge.glass-panel img {
    width: 70px;
    margin-left: auto;
    margin-right: auto;
    height: 70px;
    object-fit: contain;
}

.partner-badges{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
}
.partner-badge{
  padding:24px 12px;
  text-align:center;
  font-family:'Space Grotesk', sans-serif;
  font-weight:600;
  font-size:15px;
  color:var(--text-dim);
  transition:color .2s ease, border-color .2s ease, transform .2s ease;
}
.partner-badge:hover{
  color:var(--accent);
  border-color:rgba(232,73,26,0.40);
  transform:translateY(-3px);
}

/* ============================================================
   CTA / CONTACT
   ============================================================ */
.cta-section{
  padding-bottom: 60px;
}
.cta-panel{
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:48px;
  padding:48px;
  position:relative;
  overflow:hidden;
}
.cta-panel::before{
  content:'';
  position:absolute;
  width:400px;height:400px;
  background:var(--accent);
  opacity:.12;
  filter:blur(120px);
  top:-150px; right:-100px;
  border-radius:50%;
}
.contact-points{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:28px;
}
.contact-points div{
  display:flex;
  gap:14px;
  font-size:15px;
}
.contact-label{
  color:var(--text-dim);
  min-width:60px;
}
.cta-form{
  display:flex;
  flex-direction:column;
  gap:14px;
  position:relative;
  z-index:1;
}
.form-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px;
}
.cta-form input,
.cta-form select,
.cta-form textarea{
  width:100%;
  padding:14px 16px;
  border-radius:var(--radius-sm);
  border:1px solid var(--line);
  background:rgba(0,0,0,0.03);
  color:var(--text);
  font-family:inherit;
  font-size:14px;
  resize:vertical;
}
.cta-form input::placeholder,
.cta-form textarea::placeholder{color:var(--text-dim);}
.cta-form input:focus,
.cta-form select:focus,
.cta-form textarea:focus{
  outline:none;
  border-color:var(--accent);
}
.cta-form select{color:var(--text-dim);}
.cta-submit{margin-top:4px;}
.form-success{
  display:none;
  font-size:13.5px;
  color:var(--accent);
  text-align:center;
}
.form-success.show{display:block;}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{
  padding:40px 0 40px;
  position:relative;
  z-index:1;
}
.footer-box{
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(0,0,0,0.08);
  border-radius:var(--radius-lg);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  box-shadow:0 8px 32px rgba(0,0,0,0.10), inset 0 1px 0 rgba(255,255,255,0.18);
  padding:48px;
}

span.logo-mark-footer img{
  width:100%;
  max-width:130px;
  display:block;
}
.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr 1fr;
  gap:40px;
  margin-bottom:40px;
}
.footer-tagline{
  color:var(--text-dim);
  font-size:14px;
  margin-top:14px;
  max-width:220px;
}
.footer-heading{
  font-size:11px;
  font-weight:700;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--text-dim);
  margin-bottom:16px;
}
.footer-col{display:flex; flex-direction:column; gap:10px;}
.footer-col a{
  font-size:14px;
  color:var(--text-dim);
  transition:color .2s ease;
}
.footer-col a:hover{color:var(--accent);}
.footer-bottom{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding-top:28px;
  border-top:1px solid rgba(0,0,0,0.08);
  font-size:13px;
  color:var(--text-dim);
}
.footer-socials{display:flex; gap:10px;}
.footer-socials a{
  width:34px;height:34px;
  border-radius:50%;
  border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;
  color:var(--text-dim);
  transition:border-color .2s ease, color .2s ease, background .2s ease;
}
.footer-socials a:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:rgba(232,73,26,0.06);
}

/* ============================================================
   PORTFOLIO
   ============================================================ */
.portfolio-tabs{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:40px;
}
.portfolio-tab{
  padding:9px 22px;
  border-radius:100px;
  border:1px solid var(--line);
  font-size:14px;
  font-weight:500;
  color:var(--text-dim);
  cursor:pointer;
  transition:all .2s ease;
  background:transparent;
}
.portfolio-tab:hover{
  border-color:var(--accent);
  color:var(--accent);
}
.portfolio-tab.active{
  background:var(--accent);
  border-color:var(--accent);
  color:#FFFFFF;
  font-weight:600;
}
.portfolio-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:28px;
}
.portfolio-card{
  border-radius:var(--radius-md);
  overflow:hidden;
  transition:transform .3s ease, box-shadow .3s ease;
}
.portfolio-card:hover{
  transform:translateY(-5px);
  box-shadow:0 20px 60px rgba(232,73,26,.12);
}
.portfolio-card.hidden{
  display:none;
}
.portfolio-img{
  position:relative;
  width:100%;
  height:220px;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
}
.portfolio-img img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
  position:absolute;
  inset:0;
}
.portfolio-img-fallback{
  position:relative;
  z-index:1;
  font-family:'Space Grotesk',sans-serif;
  font-size:15px;
  font-weight:600;
  color:rgba(255,255,255,.9);
  text-align:center;
  padding:0 16px;
  pointer-events:none;
}
.portfolio-img--1{ background:linear-gradient(135deg,#0f2f3f 0%,#0d4a3a 50%,#1a2a4a 100%); }
.portfolio-img--2{ background:linear-gradient(135deg,#1a0f3f 0%,#2d1b6e 50%,#0f1a3f 100%); }
.portfolio-img--3{ background:linear-gradient(135deg,#1a2f0f 0%,#2a3f1a 50%,#0f2a1a 100%); }
.portfolio-img--4{ background:linear-gradient(135deg,#2f1a0f 0%,#3f2a0f 50%,#1a0f2f 100%); }
.portfolio-img--5{ background:linear-gradient(135deg,#0f1a3f 0%,#1a2a5a 50%,#0f2a3a 100%); }
.portfolio-img--6{ background:linear-gradient(135deg,#2a0f1a 0%,#3a1a2a 50%,#1a0f3a 100%); }
.portfolio-card-body{
  padding:24px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.portfolio-tag{
  font-size:12px;
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--accent);
}
.portfolio-card-body h3{
  font-size:17px;
  font-weight:600;
  color:var(--text);
  line-height:1.4;
}
.portfolio-card-body p{
  font-size:14px;
  color:var(--text-dim);
  line-height:1.65;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1100px){
  .nav-menu{display:none;}
  .menu-toggle{display:flex;}
  .nav-cta{display:none;}
  .hero-container{grid-template-columns:1fr; text-align:center;}
  .hero-actions{justify-content:center;}
  .hero-sub{margin-left:auto; margin-right:auto;}
  .hero-stats{grid-template-columns:repeat(2,1fr);}
  .hero-visual{margin-top:40px;}
  .about-body{grid-template-columns:1fr;}
  .about-stats-tower{display:grid; grid-template-columns:repeat(2,1fr); border-radius:var(--radius-md);}
  .about-stat-block{border-bottom:none; border-right:1px solid var(--line);}
  .about-stat-block:nth-child(even){border-right:none;}
  .about-stat-block:nth-child(n+3){border-top:1px solid var(--line);}
  .grid-cards-5, .grid-cards-4, .grid-cards-3{grid-template-columns:repeat(2,1fr);}
  .portfolio-grid{grid-template-columns:repeat(2,1fr);}
  .partnerships-grid{grid-template-columns:1fr; gap:32px;}
  .partner-badges{grid-template-columns:repeat(4,1fr);}
  .cta-panel{grid-template-columns:1fr; padding:32px;}
  .footer-box{padding:32px;}
  .footer-grid{grid-template-columns:1fr 1fr;}
  /* Case studies */
  .cs-card{grid-template-columns:300px 1fr;}
  .cs-wmk{font-size:140px;}
  .cs-body{padding:28px 32px;}
  .cs-stat-val{font-size:32px;}
}

@media (max-width: 640px){
  .container-x, .hero-container{padding:0 18px;}
  .site-header{padding:14px 12px 0;}
  .nav-inner{padding:8px 8px 8px 16px;}
  .hero{padding:50px 0 60px;}
  .hero-stats{grid-template-columns:repeat(2,1fr); gap:18px;}
  .grid-cards-5, .grid-cards-4, .grid-cards-3, .grid-cards-2{grid-template-columns:1fr;}
  .portfolio-grid{grid-template-columns:1fr;}
  .portfolio-tab{font-size:13px; padding:8px 18px;}
  .partner-badges{grid-template-columns:repeat(2,1fr);}
  .about-stats-tower{display:flex; flex-direction:column;}
  .about-stat-block{border-bottom:1px solid var(--line); border-right:none;}
  .about-stat-block:last-child{border-bottom:none;}
  .about-stat-block:nth-child(n+3){border-top:none;}
  .about-locations{flex-direction:column; align-items:flex-start; gap:12px;}
  .about-headline{font-size:clamp(22px,5vw,32px);}
  .about-desc{font-size:15px;}
  .form-row{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column; gap:16px; text-align:center;}
  .section{padding:64px 0;}
  .hero-chip{display:none;}
  .hero-badge{right:8px;}
  .hero-img-frame{max-width:380px; margin:0 auto;}
  /* Case studies */
  .cs-card{grid-template-columns:1fr; min-height:unset;}
  .cs-visual{min-height:200px; border-right:none; border-bottom:1px solid rgba(232,73,26,.1);}
  .cs-body{padding:22px 22px 26px;}
  .cs-stat-val{font-size:30px;}
  .cs-wmk{font-size:110px; bottom:-18px;}
  .cs-metrics{gap:18px;}
}

/* Case studies tablet stack */
@media (max-width: 780px){
  .cs-card{grid-template-columns:1fr; min-height:unset;}
  .cs-visual{min-height:210px; border-right:none; border-bottom:1px solid rgba(232,73,26,.1);}
  .cs-body{padding:26px 28px 30px;}
  .cs-wmk{font-size:130px; bottom:-22px;}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; animation-iteration-count:1 !important; transition-duration:0.01ms !important; scroll-behavior:auto !important;}
}

/* Focus visibility */
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:2px;
}
