/* ═══════════════════════════════════════════════════════════════
   Icon Egypt — Scroll Story Playground
═══════════════════════════════════════════════════════════════ */

:root {
  --cobalt:      #135bec;
  --cobalt-dark: #0d46c0;
  --cobalt-light:#3d78ff;
  --cobalt-dim:  rgba(19,91,236,0.12);
  --white:       #ffffff;
  --gray-100:    #F4F7FA;
  --charcoal:    #1A1A1A;
  --navy:        #0d1117;
  --card-bg:     #111827;
  --card-border: rgba(255,255,255,0.07);
  --radius-card: 18px;
  --radius-btn:  12px;
  --font:        'Inter', system-ui, sans-serif;
  --ease-spring: cubic-bezier(0.34,1.56,0.64,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--font);background:var(--navy);color:var(--white);overflow-x:hidden;-webkit-font-smoothing:antialiased;}
a{text-decoration:none;color:inherit;}
ul{list-style:none;}
input,textarea,select,button{font-family:var(--font);}

/* Dot grid backgrounds */
.hero-bg-grid,.contact-bg-grid{
  position:absolute;inset:0;
  background-image:radial-gradient(circle,rgba(19,91,236,0.18) 1.5px,transparent 1.5px);
  background-size:24px 24px;pointer-events:none;z-index:0;
}
.contact-bg-grid{background-image:radial-gradient(circle,rgba(255,255,255,0.04) 1.5px,transparent 1.5px);}

.txt-cobalt{color:var(--cobalt);}
.section-eyebrow{
  font-size:11px;font-weight:700;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--cobalt);margin-bottom:12px;display:flex;align-items:center;gap:8px;
}
.section-eyebrow::before{content:'';display:inline-block;width:24px;height:2px;background:var(--cobalt);border-radius:2px;}
.section-title{font-size:clamp(2rem,4vw,3.2rem);font-weight:900;line-height:1.12;letter-spacing:-0.02em;color:var(--white);}

/* Buttons */
.btn-primary{
  display:inline-flex;align-items:center;gap:8px;background:var(--cobalt);color:var(--white);
  font-size:15px;font-weight:700;padding:14px 28px;border-radius:var(--radius-btn);
  border:none;cursor:pointer;transition:background .2s,box-shadow .2s;
  box-shadow:0 8px 24px rgba(19,91,236,0.35);
}
.btn-primary:hover{background:var(--cobalt-light);box-shadow:0 12px 32px rgba(19,91,236,0.5);}
.btn-full{width:100%;justify-content:center;}
.btn-ghost{
  display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--white);
  font-size:15px;font-weight:600;padding:14px 24px;border-radius:var(--radius-btn);
  border:1.5px solid rgba(255,255,255,0.2);cursor:pointer;transition:border-color .2s,background .2s;
}
.btn-ghost:hover{border-color:var(--cobalt);background:var(--cobalt-dim);}
.magnetic{transition:transform .3s var(--ease-spring);will-change:transform;}

/* NAV */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 48px;transition:background .3s,backdrop-filter .3s,box-shadow .3s;
}
.nav.scrolled{
  background:rgba(13,17,23,0.88);backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 rgba(255,255,255,0.06);
}
.nav-logo{display:flex;align-items:center;gap:10px;}
.nav-links{display:flex;align-items:center;gap:36px;}
.nav-links a{font-size:14px;font-weight:500;color:rgba(255,255,255,0.7);transition:color .2s;letter-spacing:0.01em;}
.nav-links a:hover{color:var(--white);}
.nav-right{display:flex;align-items:center;gap:12px;}
/* Field/login/jobs nav (logo + .nav-right only): same physical layout in EN and Arabic —
   avoids [dir="rtl"] .nav row-reverse swapping controls to the opposite side. */
.nav.scrolled:not(:has(.nav-links)){
  direction:ltr;
}
.nav.scrolled:not(:has(.nav-links)) .nav-right{
  margin-inline-start:auto;
}
[dir="rtl"] .nav.scrolled:not(:has(.nav-links)){
  flex-direction:row;
}
[dir="rtl"] .nav.scrolled:not(:has(.nav-links)) .nav-right{
  flex-direction:row;
}
.nav-cta{
  background:var(--cobalt);color:var(--white);font-size:13px;font-weight:700;
  padding:10px 20px;border-radius:10px;letter-spacing:0.02em;
  transition:background .2s,box-shadow .2s;box-shadow:0 4px 16px rgba(19,91,236,0.3);
}
.nav-cta:hover{background:var(--cobalt-light);}

/* ICON Logo (official image) */
.nav-logo-img{
  height: 38px;
  width: auto;
  display: block;
  object-fit: contain;
  /* the source image has a dark bg — blend it seamlessly */
  border-radius: 8px;
  transition: opacity .2s;
}
.nav-logo:hover .nav-logo-img { opacity: .85; }
.footer-logo-img{
  height: 44px;
  width: auto;
  max-width: 100%;
  display: block;
  object-fit: contain;
  border-radius: 8px;
}

/* Lang Toggle */
.lang-toggle{
  display:flex;align-items:center;gap:4px;background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1);border-radius:8px;padding:6px 12px;
  cursor:pointer;transition:background .2s,border-color .2s;
}
.lang-toggle:hover{background:rgba(255,255,255,0.1);border-color:rgba(255,255,255,0.18);}
.lang-opt{font-size:12px;font-weight:700;color:rgba(255,255,255,0.4);letter-spacing:0.04em;transition:color .2s;}
.lang-opt.active{color:var(--cobalt-light);}
.lang-sep{font-size:11px;color:rgba(255,255,255,0.2);}

/* SIDEBAR */
.contact-sidebar{
  position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:90;
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.sidebar-link{
  width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;
  background:var(--card-bg);border:1px solid var(--card-border);color:var(--white);transition:background .2s,border-color .2s;
}
.sidebar-link svg{width:20px;height:20px;}
.sidebar-wa:hover{background:#25d366;border-color:#25d366;}
.sidebar-phone:hover{background:var(--cobalt);border-color:var(--cobalt);}
.sidebar-cta{
  writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);
  background:var(--cobalt);color:var(--white);font-size:10px;font-weight:800;
  letter-spacing:0.18em;text-transform:uppercase;padding:16px 10px;border-radius:12px;
  cursor:pointer;transition:background .2s;box-shadow:0 4px 20px rgba(19,91,236,0.35);margin-top:6px;
}
.sidebar-cta:hover{background:var(--cobalt-light);}

/* HERO */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;background:var(--navy);}
.hero-inner{
  position:relative;z-index:2;width:100%;max-width:1280px;margin:0 auto;
  padding:120px 64px 112px;display:grid;grid-template-columns:1fr 320px;gap:64px;align-items:center;
}
.hero-headline{
  font-size:clamp(2.8rem,5.5vw,5rem);font-weight:900;line-height:1.05;
  letter-spacing:-0.03em;color:var(--white);margin-bottom:24px;
}
.split-char{
  display:inline-block;opacity:0;transform:translateY(70px);
  animation:charReveal .6s cubic-bezier(0.25,0.46,0.45,0.94) forwards;
}
@keyframes charReveal{to{opacity:1;transform:translateY(0);}}
.hero-sub{
  font-size:18px;font-weight:400;color:rgba(255,255,255,0.6);line-height:1.65;
  max-width:520px;margin-bottom:40px;opacity:0;transform:translateY(20px);
  animation:fadeUp .7s ease forwards .6s;
}
.hero-actions{
  display:flex;gap:14px;flex-wrap:wrap;margin-bottom:56px;
  opacity:0;transform:translateY(20px);animation:fadeUp .7s ease forwards .75s;
}
.hero-stats{
  display:flex;align-items:center;gap:32px;
  opacity:0;transform:translateY(20px);animation:fadeUp .7s ease forwards .9s;
}
.stat{display:flex;flex-direction:column;gap:2px;}
.stat-num{font-size:28px;font-weight:900;letter-spacing:-0.02em;}
.stat-label{font-size:11px;font-weight:500;color:rgba(255,255,255,0.45);text-transform:uppercase;letter-spacing:0.08em;}
.stat-divider{width:1px;height:40px;background:rgba(255,255,255,0.12);}
.hero-character{
  position:relative;display:flex;flex-direction:column;align-items:center;
  opacity:0;transform:translateX(40px);animation:slideInRight .9s var(--ease-spring) forwards .3s;
}
.char-track{position:absolute;right:-24px;top:10px;bottom:10px;width:3px;background:rgba(255,255,255,0.06);border-radius:2px;}
.char-track-fill{width:100%;border-radius:2px;background:var(--cobalt);height:0%;transition:height .3s ease;}
.hero-scroll-hint{
  position:absolute;bottom:max(36px,env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%) translateY(10px);
  display:flex;flex-direction:column;align-items:center;gap:10px;z-index:3;
  opacity:0;animation:heroScrollHintIn .6s ease 1.2s both;
}
.hero-scroll-hint span{font-size:11px;font-weight:600;letter-spacing:0.14em;text-transform:uppercase;color:rgba(255,255,255,0.35);}
.scroll-arrow{width:18px;height:28px;border:2px solid rgba(255,255,255,0.2);border-radius:9px;position:relative;}
.scroll-arrow::after{
  content:'';position:absolute;top:5px;left:50%;transform:translateX(-50%);
  width:3px;height:7px;background:rgba(255,255,255,0.5);border-radius:2px;
  animation:scrollBounce 1.5s ease infinite;
}

/* SERVICES */
.services-outer{position:relative;height:280vh;background:var(--navy);}
.services-sticky{
  position:sticky;top:0;height:100vh;max-height:100vh;
  overflow:hidden;
  display:grid;grid-template-rows:auto minmax(0,1fr);padding:0 64px;
}
.services-header{
  padding:60px 0 20px;
  display:flex;align-items:flex-end;gap:24px;
  flex-shrink: 0; /* never squish the header */
}
.services-header .section-title{margin:0;}
.services-header .section-sub{font-size:13px;color:rgba(255,255,255,0.4);font-weight:400;padding-bottom:4px;}
.services-body{
  display:grid;grid-template-columns:120px 1fr;gap:32px;
  overflow-x:hidden;
  overflow-y:auto;
  min-height:0;
  align-items:stretch;
  -webkit-overflow-scrolling:touch;
}
.character-column{
  position:relative;display:flex;flex-direction:column;align-items:stretch;justify-content:flex-start;
  min-height:0;align-self:stretch;
}
.char-path-track{
  position:absolute;left:50%;transform:translateX(-50%);width:2px;top:0;bottom:0;
  background:rgba(255,255,255,0.06);border-radius:2px;z-index:0;
}
.char-path-progress{width:100%;background:var(--cobalt);border-radius:2px;height:0%;transition:height .1s linear;}
.service-character-wrap{
  position:relative;z-index:1;flex:1 1 0;display:flex;flex-direction:column;align-items:center;
  justify-content:flex-start;min-height:0;width:100%;
}
.bento-grid{
  display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;
  gap:14px;
  height:auto;
  min-height:min-content;
  padding-bottom:24px;
  align-content:start;
}
.bento-card{
  background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:var(--radius-card);
  position:relative;overflow:visible;cursor:pointer;
  transition:transform .4s var(--ease-spring),border-color .4s ease,box-shadow .4s ease;
}
.bento-card:hover{transform:scale(1.02);box-shadow:0 8px 40px rgba(0,0,0,0.4);}
.bento-card.active{
  border-color:rgba(19,91,236,0.5);
  box-shadow:0 0 0 1px rgba(19,91,236,0.2),0 4px 32px rgba(19,91,236,0.15);
  background:linear-gradient(135deg,#111827 0%,#0d1628 100%);
}
.card-electrical{grid-column:1/3;}
.card-ups{grid-column:3/4;grid-row:1;}
.card-elv{grid-column:1/2;grid-row:2;}
.card-fire{grid-column:2/4;grid-row:2;}
.card-inner{position:relative;z-index:2;padding:28px 28px 32px;height:auto;min-height:0;display:flex;flex-direction:column;gap:10px;}
.card-icon{width:40px;height:40px;color:var(--cobalt);margin-bottom:4px;transition:color .3s;}
.bento-card.active .card-icon{color:var(--cobalt-light);}
.card-title{font-size:16px;font-weight:800;letter-spacing:-0.01em;color:var(--white);line-height:1.3;}
.card-electrical .card-title{font-size:20px;}
.card-desc{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.6;flex:1;max-width:380px;}
.card-desc-rich{max-width:100%;flex:0 0 auto;min-height:0;}
.card-desc-rich .card-lead{margin:0 0 8px;font-size:12px;color:rgba(255,255,255,0.55);line-height:1.5;}
.card-bullets{margin:0;padding-inline-start:18px;padding-inline-end:0;font-size:11px;color:rgba(255,255,255,0.45);line-height:1.45;}
.card-bullets li{margin:2px 0;}
.card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto;}
.tag{font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;background:rgba(255,255,255,0.06);color:rgba(255,255,255,0.5);letter-spacing:0.04em;transition:background .3s,color .3s;}
.bento-card.active .tag{background:rgba(19,91,236,0.15);color:var(--cobalt-light);}
.card-status,.fire-status{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:rgba(255,255,255,0.3);transition:color .3s;}
.bento-card.active .card-status{color:rgba(255,255,255,0.8);}
.bento-card.active .fire-status{color:#4caf50;}
.status-led{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.led-active{background:var(--cobalt);}
.bento-card.active .led-active{animation:pulseBlue 1.5s ease infinite;}
.led-safe{background:#4caf50;}
.bento-card.active .led-safe{animation:pulseGreen 1.8s ease infinite;}
.card-lens-flare{position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 75% 35%,rgba(19,91,236,0.15) 0%,transparent 55%);z-index:1;}
.animate-dash{animation:dashFlow 2s linear infinite;stroke-dasharray:4 3;}
.animate-dash-slow{animation:dashFlow 3s linear infinite reverse;stroke-dasharray:6 4;}
.animate-dash-rev{animation:dashFlow 2.5s linear infinite reverse;stroke-dasharray:3 5;}
.card-elv .data-lines{opacity:0.3;transition:opacity .4s;}
.card-elv.active .data-lines{opacity:1;}

@media (min-width:769px){
  :root{--specialties-bento-max-h:800px;}
  .bento-grid{
    max-height:var(--specialties-bento-max-h);
    min-height:0;
    grid-template-rows:minmax(0,1fr) minmax(0,1fr);
    align-content:stretch;
    padding:8px 10px 14px;
    box-sizing:border-box;
  }
  .bento-card{
    min-width:0;
    min-height:0;
    display:flex;
    flex-direction:column;
    height:100%;
  }
  .bento-card .card-inner{
    flex:1;
    min-height:0;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .bento-card .card-desc-rich{
    flex:1 1 auto;
    min-height:0;
  }
  .photo-frame-service{max-height:var(--specialties-bento-max-h);}
}

/* ABOUT */
.about-section{background:#0a0f1a;overflow:hidden;}
.about-inner{max-width:1280px;margin:0 auto;padding:120px 64px;display:grid;grid-template-columns:1fr 420px;gap:80px;align-items:center;}
.about-body{font-size:17px;color:rgba(255,255,255,0.6);line-height:1.75;margin-bottom:20px;}
.about-values{display:flex;flex-wrap:wrap;gap:12px;margin:32px 0;}
.value-item{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,0.04);border:1px solid rgba(255,255,255,0.07);border-radius:100px;padding:10px 18px;font-size:13px;font-weight:600;color:rgba(255,255,255,0.75);transition:border-color .2s,background .2s;}
.value-item:hover{border-color:rgba(19,91,236,0.4);background:rgba(19,91,236,0.08);}
.value-icon{font-size:16px;color:var(--cobalt);}
.about-character{position:relative;display:flex;align-items:center;justify-content:center;}
.about-char-bg{position:absolute;inset:-40px;background:radial-gradient(ellipse at 50% 60%,rgba(19,91,236,0.12) 0%,transparent 65%);border-radius:50%;}
.blueprint-overlay{
  position:absolute;inset:0;
  background-image:linear-gradient(rgba(19,91,236,0.04) 1px,transparent 1px),linear-gradient(90deg,rgba(19,91,236,0.04) 1px,transparent 1px);
  background-size:32px 32px;border-radius:24px;pointer-events:none;
}

/* PROJECTS */
.projects-section{background:#0a0f1a;overflow:hidden;}
.projects-header{max-width:1280px;margin:0 auto;padding:100px 64px 36px;}
.projects-strip{display:flex;gap:14px;padding:0 64px 80px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;}
.projects-strip::-webkit-scrollbar{display:none;}
.project-photo-card{
  position:relative;flex-shrink:0;width:340px;height:440px;border-radius:18px;overflow:hidden;
  scroll-snap-align:start;cursor:pointer;border:1px solid rgba(255,255,255,0.07);
  transition:transform .35s var(--ease-spring),border-color .3s;
}
.project-photo-card:hover{transform:scale(1.03) translateY(-4px);border-color:rgba(19,91,236,0.4);}
.project-photo-card img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(15%) brightness(.65) contrast(1.08) saturate(.75);transition:filter .4s ease,transform .5s ease;}
.project-photo-card:hover img{filter:grayscale(5%) brightness(.75) contrast(1.06) saturate(.9);transform:scale(1.04);}

.scroll-phase-sentinel{
  height:0;width:100%;margin:0;padding:0;border:0;
  pointer-events:none;visibility:hidden;overflow:hidden;
  position:relative;
}
/* Brands — aligned with index.html luxury treatment */
.brands-section.partners-section{
  padding-bottom:56px;position:relative;isolation:isolate;overflow:visible;
}
.brands-section::before{
  content:'';position:absolute;inset:-20% -10% auto -10%;height:70%;
  background:radial-gradient(ellipse 85% 65% at 50% 0%,rgba(19,91,236,0.14) 0%,rgba(10,15,26,0) 62%);
  pointer-events:none;z-index:0;
}
.brands-section .partners-header{position:relative;z-index:1;padding-bottom:32px;max-width:1280px;}
.brands-section .partners-header::after{
  content:'';display:block;width:min(100px,18vw);height:2px;margin-top:22px;border-radius:2px;
  background:linear-gradient(90deg,var(--cobalt),rgba(19,91,236,0.15),transparent);
}
[dir="rtl"] .brands-section .partners-header::after{
  margin-left:auto;margin-right:0;
  background:linear-gradient(270deg,var(--cobalt),rgba(19,91,236,0.15),transparent);
}
.brands-section .section-eyebrow{letter-spacing:0.16em;color:rgba(255,255,255,0.38);}
.brands-section .brands-sub{
  margin:14px 0 0;max-width:36rem;font-size:clamp(14px,1.35vw,16px);line-height:1.65;font-weight:400;color:rgba(255,255,255,0.48);
}
[dir="rtl"] .brands-section .brands-sub{margin-left:auto;margin-right:0;text-align:right;}
.brands-section .partners-grid{
  position:relative;z-index:1;
  padding:48px 0 52px;
  overflow-x:hidden;
  overflow-y:visible;
}
.brands-section .partners-grid::before,.brands-section .partners-grid::after{width:min(100px,12vw);opacity:0.95;}
.brands-section .partners-marquee{animation:brandsMarquee 52s linear infinite;}
.brands-section .partners-marquee-set{gap:36px;padding:28px 20px;}
.brands-section .partner-logo-wrap{
  min-width:232px;min-height:156px;padding:30px 26px;
  border:1px solid rgba(0,0,0,0.08);
  background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);
  backdrop-filter:none;-webkit-backdrop-filter:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,1),0 4px 24px rgba(0,0,0,0.08),0 1px 2px rgba(0,0,0,0.04);
}
.brands-section .partner-logo-wrap:hover{
  transform:scale(1.03);
  border:1px solid rgba(0,0,0,0.08);
  background:linear-gradient(180deg,#ffffff 0%,#fafafa 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,1),
    0 4px 24px rgba(0,0,0,0.08),
    0 1px 2px rgba(0,0,0,0.04),
    0 0 18px rgba(61,120,255,0.45),
    0 0 40px rgba(19,91,236,0.32),
    0 0 64px rgba(61,120,255,0.18);
}
.brands-section .partner-logo{
  height:92px;max-width:210px;
  filter:grayscale(0.25) brightness(0.97) opacity(0.92);
  transition:filter .45s ease,transform .45s var(--ease-spring);
}
.brands-section .partner-logo-wrap:hover .partner-logo{
  filter:grayscale(0.25) brightness(0.97) opacity(0.92);
  transform:none;
}
@keyframes brandsMarquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}

/* PARTNERS */
.partners-section{background:#0a0f1a;overflow:hidden;padding-bottom:80px;}
.partners-header{max-width:1280px;margin:0 auto;padding:80px 64px 36px;}
.partners-strip{overflow:hidden;position:relative;}
.partners-strip::before,.partners-strip::after{content:'';position:absolute;top:0;bottom:0;width:80px;z-index:2;pointer-events:none;}
.partners-strip::before{left:0;background:linear-gradient(to right,#0a0f1a,transparent);}
.partners-strip::after{right:0;left:auto;background:linear-gradient(to left,#0a0f1a,transparent);}
.partners-track{display:flex;gap:64px;animation:marquee 35s linear infinite;}
.partners-track:hover{animation-play-state:paused;}
.partner-logo{height:112px;width:auto;object-fit:contain;opacity:.4;filter:grayscale(100%) brightness(.6);transition:opacity .35s,filter .35s,transform .35s;flex-shrink:0;}
.partner-logo:hover{opacity:1;filter:grayscale(0%) brightness(1) drop-shadow(0 0 16px rgba(19,91,236,0.5)) drop-shadow(0 0 32px rgba(19,91,236,0.25));transform:scale(1.05);}
@keyframes marquee{0%{transform:translateX(0);}100%{transform:translateX(-50%);}}
@keyframes marquee-rtl{0%{transform:translateX(-50%);}100%{transform:translateX(0);}}
.project-card-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(6,11,20,.05) 0%,rgba(6,11,20,.78) 75%,rgba(6,11,20,.97) 100%);z-index:1;}
.project-photo-card::after{content:'';position:absolute;inset:0;background:rgba(19,91,236,0.08);mix-blend-mode:color;z-index:2;opacity:0;transition:opacity .35s;}
.project-photo-card:hover::after{opacity:1;}
.project-card-info{position:absolute;bottom:0;left:0;right:0;padding:24px;z-index:3;display:flex;flex-direction:column;gap:6px;}
.project-tag{display:inline-flex;align-self:flex-start;font-size:10px;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;padding:4px 10px;border-radius:5px;background:rgba(19,91,236,0.25);border:1px solid rgba(19,91,236,0.4);color:var(--cobalt-light);margin-bottom:4px;}
.project-title{font-size:17px;font-weight:800;letter-spacing:-0.01em;color:var(--white);line-height:1.25;}
.project-year{font-size:12px;color:rgba(255,255,255,0.45);font-weight:500;}

/* TEAM */
.team-section{background:var(--navy);overflow:hidden;}
.team-header{max-width:1280px;margin:0 auto;padding:100px 64px 40px;}
.team-track-wrapper{overflow:hidden;padding-bottom:80px;container-name:team;container-type:inline-size;}
.team-track{
  --team-gap:20px;--team-pad-inline:64px;--team-peek:0.2;
  display:flex;gap:var(--team-gap);padding:0 64px 40px;width:max-content;
}
.team-card{
  flex:0 0 clamp(300px,calc((100cqw - var(--team-pad-inline) - var(--team-gap)) / (1 + var(--team-peek))),550px);
  background:var(--card-bg);border:1.5px solid var(--card-border);
  border-radius:var(--radius-card);padding:32px;flex-shrink:0;position:relative;overflow:hidden;
  transition:transform .3s var(--ease-spring),border-color .3s;
}
.team-card:hover{transform:translateY(-6px);border-color:rgba(255,255,255,0.12);}
.team-card-accent{position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent,var(--cobalt));border-radius:var(--radius-card) var(--radius-card) 0 0;}
.team-name{font-size:18px;font-weight:800;letter-spacing:-0.01em;margin-bottom:4px;}
.team-role{font-size:12px;font-weight:600;color:var(--cobalt-light);letter-spacing:0.06em;text-transform:uppercase;margin-bottom:14px;}
.team-bio{font-size:14px;color:rgba(255,255,255,0.5);line-height:1.6;margin-bottom:20px;}
.team-expertise{display:flex;flex-wrap:wrap;gap:6px;}
.expertise-tag{font-size:11px;font-weight:600;padding:4px 10px;border-radius:6px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.55);}
.team-card-join{background:linear-gradient(135deg,rgba(19,91,236,0.1) 0%,rgba(13,17,23,0.8) 100%);border-color:rgba(19,91,236,0.25);display:flex;align-items:center;justify-content:center;}
.team-join-inner{text-align:center;display:flex;flex-direction:column;align-items:center;gap:14px;}
.join-icon{width:56px;height:56px;border-radius:16px;border:2px dashed rgba(19,91,236,0.4);display:flex;align-items:center;justify-content:center;font-size:28px;color:var(--cobalt);margin-bottom:8px;}
.team-join-inner h3{font-size:18px;font-weight:800;}
.team-join-inner p{font-size:13px;color:rgba(255,255,255,0.5);line-height:1.55;}

/* CONTACT */
.contact-section{position:relative;background:#060b14;overflow:hidden;}
.contact-inner{position:relative;z-index:1;max-width:1280px;margin:0 auto;padding:120px 64px;display:grid;grid-template-columns:1fr 480px;gap:80px;align-items:start;}
.contact-body{font-size:16px;color:rgba(255,255,255,0.55);line-height:1.7;margin:20px 0 36px;max-width:440px;}
.contact-details{display:flex;flex-direction:column;gap:14px;}
.contact-item{display:flex;align-items:center;gap:14px;font-size:15px;font-weight:500;color:rgba(255,255,255,0.6);padding:14px 18px;border-radius:12px;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.05);transition:background .2s,border-color .2s,color .2s;cursor:pointer;}
.contact-item:hover{background:rgba(255,255,255,0.06);border-color:rgba(255,255,255,0.1);color:var(--white);}
.contact-icon-mobile{width:20px;height:20px;flex-shrink:0;object-fit:contain;display:block;opacity:0.92;transition:opacity .2s,filter .2s;}
.contact-item:hover .contact-icon-mobile{opacity:1;filter:brightness(1.15);}
.contact-wa:hover{border-color:rgba(37,211,102,0.3);background:rgba(37,211,102,0.06);color:#4caf50;}
.contact-tel:hover{border-color:rgba(19,91,236,0.3);background:var(--cobalt-dim);color:var(--cobalt-light);}
.contact-social{flex-direction:column;align-items:flex-start;}
.contact-social-label{font-size:12px;font-weight:600;color:rgba(255,255,255,0.4);text-transform:uppercase;letter-spacing:.1em;margin-bottom:8px;}
.contact-social-links{display:flex;gap:10px;}
.contact-social .social-link{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:10px;background:rgba(255,255,255,0.05);color:rgba(255,255,255,0.5);transition:background .2s,color .2s;}
.contact-social .social-link:hover{background:var(--cobalt-dim);color:var(--cobalt-light);}
.contact-form-wrap{background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:24px;padding:40px;}
.contact-form{display:flex;flex-direction:column;gap:20px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:8px;}
.form-group label{font-size:12px;font-weight:700;letter-spacing:0.06em;text-transform:uppercase;color:rgba(255,255,255,0.45);}
.form-group input,.form-group select,.form-group textarea{
  background:rgba(255,255,255,0.04);border:1.5px solid rgba(255,255,255,0.08);
  border-radius:10px;padding:13px 16px;font-size:14px;color:var(--white);
  outline:none;transition:border-color .2s,background .2s;resize:none;appearance:none;
}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(255,255,255,0.2);}
.form-group select{color:rgba(255,255,255,0.7);cursor:pointer;}
.form-group select option{background:var(--card-bg);color:var(--white);}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--cobalt);background:rgba(19,91,236,0.05);}

/* FOOTER */
.footer{background:#050810;border-top:1px solid rgba(255,255,255,0.05);}
.footer-inner{max-width:1280px;margin:0 auto;padding:32px 64px;display:flex;align-items:center;justify-content:space-between;gap:24px;}
.footer-logo{display:flex;align-items:center;gap:10px;}
.footer-copy{font-size:12px;color:rgba(255,255,255,0.3);text-align:center;}
.footer-links{display:flex;gap:28px;}
.footer-links a{font-size:13px;color:rgba(255,255,255,0.35);transition:color .2s;}
.footer-links a:hover{color:rgba(255,255,255,0.8);}
.footer-social{display:flex;gap:12px;}
.footer-social-link{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;color:rgba(255,255,255,0.35);transition:color .2s,background .2s;}
.footer-social-link:hover{color:var(--cobalt-light);background:rgba(19,91,236,0.15);}

/* Keyframes */
@keyframes fadeUp{to{opacity:1;transform:translateY(0);}}
@keyframes heroScrollHintIn{
  from{opacity:0;transform:translateX(-50%) translateY(10px);}
  to{opacity:1;transform:translateX(-50%) translateY(0);}
}
@keyframes slideInRight{to{opacity:1;transform:translateX(0);}}
@keyframes pulseBlue{0%,100%{box-shadow:0 0 0 0 rgba(19,91,236,0.7);}50%{box-shadow:0 0 0 6px rgba(19,91,236,0);}}
@keyframes pulseGreen{0%,100%{box-shadow:0 0 0 0 rgba(76,175,80,0.7);}50%{box-shadow:0 0 0 6px rgba(76,175,80,0);}}
@keyframes dashFlow{from{stroke-dashoffset:0;}to{stroke-dashoffset:-50;}}
@keyframes scrollBounce{0%,100%{opacity:.5;transform:translateX(-50%) translateY(0);}50%{opacity:1;transform:translateX(-50%) translateY(5px);}}

/* ═══════════════════════════════════════════════════════════════
   PHOTO TREATMENTS
═══════════════════════════════════════════════════════════════ */
.photo-cobalt-tint{position:absolute;inset:0;background:rgba(19,91,236,0.10);mix-blend-mode:color;z-index:2;pointer-events:none;}
.photo-fade{position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(to bottom,rgba(13,17,23,0.08) 0%,rgba(13,17,23,0.0) 30%,rgba(13,17,23,0.55) 72%,rgba(13,17,23,0.98) 100%),linear-gradient(to right,rgba(13,17,23,0.35) 0%,transparent 18%,transparent 82%,rgba(13,17,23,0.35) 100%);}
.photo-fade-all{background:linear-gradient(to bottom,rgba(13,17,23,0.85) 0%,transparent 18%,transparent 70%,rgba(13,17,23,0.92) 100%),linear-gradient(to right,rgba(13,17,23,0.7) 0%,transparent 22%,transparent 78%,rgba(13,17,23,0.7) 100%);}
.photo-fade-about{background:linear-gradient(to bottom,rgba(13,17,23,0.05) 0%,rgba(13,17,23,0.0) 25%,rgba(13,17,23,0.45) 70%,rgba(13,17,23,0.97) 100%),linear-gradient(to right,transparent 50%,rgba(10,15,26,0.7) 100%);}

.photo-frame-hero{position:relative;width:290px;height:430px;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,0.07);box-shadow:0 0 0 1px rgba(19,91,236,0.12),0 32px 80px rgba(0,0,0,0.6);flex-shrink:0;}
.photo-frame-hero img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(8%) brightness(.78) contrast(1.06) saturate(.88);display:block;}
.photo-frame-service{
  position:relative;flex:1 1 0;width:108px;min-height:0;border-radius:14px;overflow:hidden;
  border:1px solid rgba(19,91,236,0.18);
}
.photo-frame-service img{
  width:100%;height:100%;min-height:0;object-fit:cover;object-position:center 20%;
  filter:grayscale(12%) brightness(.6) contrast(1.1) saturate(.75);display:block;
}
.photo-frame-about{position:relative;width:340px;height:480px;border-radius:20px;overflow:hidden;border:1px solid rgba(255,255,255,0.06);box-shadow:0 0 0 1px rgba(19,91,236,0.1),0 40px 100px rgba(0,0,0,0.5);flex-shrink:0;}
.photo-frame-about img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(10%) brightness(.72) contrast(1.08) saturate(.8);display:block;}

.card-photo-bg{position:absolute;inset:0;z-index:0;overflow:hidden;border-radius:var(--radius-card);}
.card-photo-bg img{width:100%;height:100%;object-fit:cover;display:block;filter:grayscale(25%) brightness(.28) contrast(1.12) saturate(.5);transition:filter .6s ease;}
.bento-card.active .card-photo-bg img{filter:grayscale(10%) brightness(.42) contrast(1.1) saturate(.65);}
.card-photo-bg::after{content:'';position:absolute;inset:0;background:linear-gradient(145deg,rgba(13,17,23,0.5) 0%,rgba(13,17,23,0.15) 50%,rgba(13,17,23,0.6) 100%);z-index:1;}

.team-avatar-photo{position:relative;width:176px;height:176px;border-radius:50%;overflow:hidden;margin-bottom:22px;flex-shrink:0;border:3px solid var(--border-color,var(--cobalt));box-shadow:0 0 0 6px rgba(255,255,255,0.045);}
.team-avatar-photo img{width:100%;height:100%;object-fit:cover;object-position:top center;filter:grayscale(12%) brightness(.85) contrast(1.05) saturate(.9);display:block;}
.team-avatar-photo .photo-cobalt-tint{opacity:.6;}
.team-avatar-photo .team-avatar-badge{position:absolute;bottom:-4px;right:-4px;width:40px;height:40px;border-radius:12px;display:flex;align-items:center;justify-content:center;border:2px solid var(--card-bg);z-index:4;}
.team-avatar-photo .team-avatar-badge svg{width:20px;height:20px;}

.hero-bg-photo{position:absolute;inset:0;z-index:0;overflow:hidden;}
.hero-bg-photo img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;filter:grayscale(30%) brightness(.18) contrast(1.1) saturate(.4);}
.hero-bg-photo::after{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 50% 50%,transparent 20%,rgba(6,11,20,0.7) 100%),linear-gradient(to bottom,rgba(6,11,20,0.4) 0%,rgba(6,11,20,0.15) 40%,rgba(6,11,20,0.6) 100%);}
.hero-bg-grid{z-index:1;}
.hero-inner{position:relative;z-index:2;}
.hero-scroll-hint{z-index:3;}

.contact-bg-photo{position:absolute;inset:0;z-index:0;overflow:hidden;}
.contact-bg-photo img{width:100%;height:100%;object-fit:cover;object-position:center 40%;display:block;filter:grayscale(35%) brightness(.14) contrast(1.1) saturate(.3);}
.contact-bg-photo::after{content:'';position:absolute;inset:0;background:linear-gradient(to right,rgba(6,11,20,0.85) 0%,rgba(6,11,20,0.2) 30%,rgba(6,11,20,0.2) 70%,rgba(6,11,20,0.85) 100%);}
.contact-bg-grid{z-index:1;}
.contact-inner{position:relative;z-index:2;}

/* ═══════════════════════════════════════════════════════════════
   ARABIC FONT + RTL
═══════════════════════════════════════════════════════════════ */
[lang|="ar"],[lang|="ar"] body{font-family:'Noto Sans Arabic',var(--font);}
[lang|="ar"] .hero-headline{
  line-height: 1.35;
  letter-spacing: 0 !important;   /* override -0.03em base rule */
  word-spacing: 0.05em;
}
[lang|="ar"] .hero-headline .split-char {
  letter-spacing: 0 !important;   /* prevent per-span tracking from breaking glyphs */
  display: inline;                 /* word spans must stay inline so Arabic words wrap naturally */
}
[lang|="ar"] .section-title{letter-spacing:0;line-height:1.3;}
[lang|="ar"] .icon-wordmark-name,[lang|="ar"] .icon-wordmark-sub,[lang|="ar"] .footer-logo-brand,[lang|="ar"] .footer-logo-tagline,[lang|="ar"] .tag,[lang|="ar"] .expertise-tag,[lang|="ar"] .project-tag,[lang|="ar"] .section-eyebrow,[lang|="ar"] .stat-label,[lang|="ar"] .nav-cta,[lang|="ar"] .lang-toggle{letter-spacing:0;}

[dir="rtl"] .nav{flex-direction:row-reverse;}
[dir="rtl"] .nav-right{flex-direction:row-reverse;}
[dir="rtl"] .nav-links{flex-direction:row-reverse;}
[dir="rtl"] .nav-logo{flex-direction:row-reverse;}
[dir="rtl"] .contact-sidebar{right:auto;left:24px;}
[dir="rtl"] .hero-inner{
  direction: rtl;
  padding-bottom: 172px; /* extra clearance so Arabic stats don't collide with scroll hint */
}
[dir="rtl"] .hero-actions{flex-direction:row-reverse;}
[dir="rtl"] .hero-stats{flex-direction:row-reverse;}
[dir="rtl"] .hero-scroll-hint { bottom: max(16px, env(safe-area-inset-bottom, 0px)); }
/* Section eyebrow: use direction:rtl so ::before line sits on the right
   and the whole group naturally aligns to the right edge — no flex-reverse
   needed (parent direction:rtl already handles the flow direction).        */
[dir="rtl"] .section-eyebrow {
  direction: rtl;          /* items flow right → left; flex-start = right edge */
  flex-direction: row;     /* keep DOM order; direction:rtl handles visual order */
}
[dir="rtl"] .section-eyebrow::before {
  order: 0;                /* reset any previous order override */
  margin: 0;
}
[dir="rtl"] .services-sticky{direction:rtl;}
[dir="rtl"] .services-header{flex-direction:column;align-items:flex-start;}
[dir="rtl"] .services-header .section-eyebrow,
[dir="rtl"] .services-header .section-title,
[dir="rtl"] .services-header .section-sub{text-align:right;width:100%;}
[dir="rtl"] .bento-grid{direction:rtl;}
[dir="rtl"] .about-inner{direction:rtl;}
[dir="rtl"] .about-text{text-align:right;}
/* about-values: no flex-direction reversal — direction:rtl from .about-inner
   already makes flex-start = right, so items align right naturally.         */
[dir="rtl"] .about-values{
  flex-direction: row;
  direction: rtl;
  justify-content: flex-start; /* flex-start in direction:rtl = right edge */
}
[dir="rtl"] .value-item{
  flex-direction: row;
  direction: rtl;
}
[dir="rtl"] .team-header{direction:rtl;text-align:right;}
/* RTL scroll direction is handled in JS (see initTeamScroll) — no flex reversal here */
[dir="rtl"] .team-track{flex-direction:row;}
[dir="rtl"] .team-card{direction:rtl;text-align:right;}
[dir="rtl"] .team-info{direction:rtl;text-align:right;}
[dir="rtl"] .team-expertise{direction:rtl;flex-direction:row;justify-content:flex-start;}
[dir="rtl"] .team-avatar-photo .team-avatar-badge{right:auto;left:-4px;}
[dir="rtl"] .partners-header{direction:rtl;text-align:right;}
[dir="rtl"] .partners-track{animation-name:marquee-rtl;}
[dir="rtl"] .partners-strip::before{left:auto;right:0;background:linear-gradient(to left,#0a0f1a,transparent);}
[dir="rtl"] .partners-strip::after{right:auto;left:0;background:linear-gradient(to right,#0a0f1a,transparent);}
[dir="rtl"] .projects-header{direction:rtl;text-align:right;}
/* direction:rtl on the scroll container makes overflow start from the right,
   placing the first card on the right edge — no flex reversal needed.       */
[dir="rtl"] .projects-strip{
  flex-direction: row;    /* keep DOM order */
  direction: rtl;         /* scroll origin = right; flex-start = right */
}
/* English project titles on Arabic page — isolate LTR; pairs with index horizontal RTL */
[dir="rtl"] .project-photo-card .project-card-info{direction:ltr;text-align:left;unicode-bidi:isolate;}
[dir="rtl"] .project-tag{align-self:flex-start;} /* flex-start = right in direction:rtl */
[dir="rtl"] .contact-inner{direction:rtl;}
[dir="rtl"] .contact-item{flex-direction:row-reverse;}
[dir="rtl"] .form-group{direction:rtl;}
[dir="rtl"] .form-group input,[dir="rtl"] .form-group select,[dir="rtl"] .form-group textarea{text-align:right;direction:rtl;}
[dir="rtl"] .form-row{direction:rtl;}
[dir="rtl"] .footer-inner{flex-direction:row-reverse;}
[dir="rtl"] .footer-links{flex-direction:row-reverse;}
[dir="rtl"] .footer-logo{flex-direction:row-reverse;}
[dir="rtl"] .footer-logo-text{direction:rtl;text-align:right;}
[dir="rtl"] .card-inner{direction:rtl;}
[dir="rtl"] .card-tags{flex-direction:row-reverse;}
[dir="rtl"] .card-status,[dir="rtl"] .fire-status{flex-direction:row-reverse;}
[dir="rtl"] .team-join-inner{
  direction: rtl;
  text-align: right;
  align-items: flex-end; /* right-align all children in the column */
}

/* Responsive */
@media(max-width:1024px){
  .nav{padding:16px 28px;}
  .hero-inner,.about-inner,.contact-inner{padding:100px 28px 60px;}
  .hero-inner{padding-bottom:92px;}
  .services-sticky{padding:0 28px;}
  .team-track,.projects-strip{padding:0 28px 40px;}
  .team-track{--team-pad-inline:28px;}
  .partners-header{padding:60px 28px 28px;}
  .footer-inner{padding:28px;}
  .projects-header,.team-header{padding:80px 28px 36px;}
}
@media(max-width:768px){
  .hero-inner{grid-template-columns:1fr;padding:100px 24px 92px;text-align:center;}
  .hero-character{display:none;}
  .hero-actions{justify-content:center;}
  .hero-stats{justify-content:center;}
  .about-inner{grid-template-columns:1fr;}
  .about-character{order:-1;}
  .team-avatar-photo{width:140px;height:140px;margin-bottom:18px;}
  .team-avatar-photo .team-avatar-badge{width:34px;height:34px;bottom:-3px;right:-3px;border-radius:10px;}
  .team-avatar-photo .team-avatar-badge svg{width:17px;height:17px;}
  [dir="rtl"] .team-avatar-photo .team-avatar-badge{right:auto;left:-3px;}
  .contact-inner{grid-template-columns:1fr;}
  .bento-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto;}
  .card-electrical{grid-column:1/-1;grid-row:auto;}
  .card-ups{grid-column:auto;grid-row:auto;}
  .card-elv{grid-column:auto;grid-row:auto;}
  .card-fire{grid-column:1/-1;grid-row:auto;}
  .services-outer{height:auto;}
  .services-sticky{position:relative;height:auto;min-height:100vh;max-height:none;overflow:visible;}
  .character-column{display:none;}
  .services-body{grid-template-columns:1fr;}
  .nav-links{display:none;}
  .contact-sidebar{display:none;}
  /* Stack footer; override RTL row-reverse (it beats plain .footer-inner specificity). */
  [dir="rtl"] .footer-inner{flex-direction:column;}
  .footer-inner{
    flex-direction:column;
    align-items:stretch;
    text-align:center;
    gap:20px;
  }
  .footer-logo{justify-content:center;order:1;}
  .footer-links{
    order:2;
    flex-wrap:wrap;
    gap:10px 16px;
    justify-content:center;
    max-width:100%;
  }
  .footer-copy{
    order:3;
    width:100%;
    max-width:100%;
    min-width:0;
    box-sizing:border-box;
    line-height:1.5;
    padding-inline:4px;
  }
  .footer-social{order:4;justify-content:center;}
  .form-row{grid-template-columns:1fr;}
  .project-photo-card{width:280px;height:360px;}
}
