/* ===================================================================
   AKABER — Design System
   كحلي عميق + ذهبي معدني هادئ | Quiet Modern Luxury
=================================================================== */

/* Google Fonts are loaded separately via wp_enqueue_style() in functions.php
   (NOT via @import here) — external @import breaks when combined/minified
   by caching plugins such as LiteSpeed Cache. */

:root{
  /* Colors — matched to reference akaber-v8.html exactly */
  --navy-deep:#0A1628;
  --navy:#0A1628;
  --navy-mid:#1B3A6B;
  --accent:#2563EB;
  --accent-light:#3B82F6;
  --gold:#C9A84C;
  --gold-light:#E0C06A;
  --gold-soft:#EDE0C0;
  --white:#FFFFFF;
  --cream:#F8FAFF;
  --gray-line:#EEF2F8;
  --gray-text:#52606D;
  --ink:#0A1628;
  --radius:16px;
  --shadow:0 4px 24px rgba(10,22,40,.10);
  --shadow-lg:0 8px 40px rgba(10,22,40,.15);

  /* Type — Cairo everywhere, matching reference */
  --f-display:'Cairo', sans-serif;
  --f-body:'Cairo', sans-serif;

  /* Rhythm */
  --section-pad: clamp(60px, 8vw, 100px);
  --container: 1280px;
  --ease: cubic-bezier(.22,.8,.28,1);
}

*{box-sizing:border-box; margin:0; padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--f-body);
  background:var(--white);
  color:var(--ink);
  line-height:1.75;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
html[dir="rtl"] body{ direction:rtl; }

img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
button{font-family:inherit; cursor:pointer; border:none; background:none;}
.container{max-width:var(--container); margin:0 auto; padding:0 28px;}

h1,h2,h3,h4{
  font-family:var(--f-display);
  font-weight:700;
  line-height:1.25;
  color:var(--navy);
  letter-spacing:-0.01em;
}

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

/* ===================================================================
   LOADER
=================================================================== */
#loader{
  position:fixed; inset:0; background:var(--navy-deep);
  display:flex; align-items:center; justify-content:center;
  z-index:9999; transition:opacity .8s var(--ease), visibility .8s var(--ease);
  animation: akaberForceHideLoader 0.01s 6s forwards;
}
@keyframes akaberForceHideLoader{
  to{ opacity:0; visibility:hidden; pointer-events:none; }
}
#loader.hide{opacity:0; visibility:hidden; pointer-events:none;}
.loader-inner{text-align:center;}
.loader-mark{
  font-family:var(--f-display); font-weight:700; font-size:15px;
  color:var(--gold-light); letter-spacing:.32em; text-transform:uppercase;
  margin-bottom:18px; opacity:0; animation:fadeUp 1s var(--ease) .2s forwards;
}
.loader-line{
  width:0; height:1px; background:linear-gradient(90deg,transparent,var(--gold),transparent);
  margin:0 auto; animation:loaderLine 1.6s var(--ease) .4s forwards;
}
@keyframes loaderLine{ to{ width:220px; } }
@keyframes fadeUp{ from{opacity:0; transform:translateY(8px);} to{opacity:1; transform:translateY(0);} }

/* ===================================================================
   HEADER
=================================================================== */
.site-header{
  position:fixed; top:0; inset-inline-start:0; width:100%; z-index:500;
  padding:18px 0; transition:background .4s var(--ease), padding .4s var(--ease), box-shadow .4s var(--ease);
  background:rgba(6,15,31,.55); backdrop-filter:blur(10px);
}
.site-header.scrolled{
  background:rgba(6,15,31,.92); backdrop-filter:blur(14px);
  padding:14px 0; box-shadow:0 8px 30px rgba(6,15,31,.18);
}
.header-row{display:flex; align-items:center; justify-content:space-between;}
/* Old .logo definition removed — see the current one further below (with logo-text strong/small) */
.logo span{color:var(--gold-light); font-size:11px; font-weight:500; letter-spacing:.28em; text-transform:uppercase; opacity:.85;}
.nav-links{display:flex; gap:34px; align-items:center;}
.nav-links a{
  font-size:14.5px; color:rgba(255,255,255,.82); position:relative; padding:6px 0;
  transition:color .3s;
}
.nav-links a::after{
  content:''; position:absolute; bottom:0; inset-inline-start:0; width:0; height:1px;
  background:var(--gold-light); transition:width .35s var(--ease);
}
.nav-links a:hover{color:var(--white);}
.nav-links a:hover::after{width:100%;}
.header-actions{display:flex; align-items:center; gap:18px;}
.lang-switch{
  font-size:13px; color:var(--white); border:1px solid rgba(255,255,255,.28);
  padding:7px 14px; border-radius:30px; transition:.3s;
}
.lang-switch:hover{border-color:var(--gold-light); color:var(--gold-light);}
.btn-header{
  font-size:14px; color:var(--navy-deep); background:var(--gold-light);
  padding:11px 24px; border-radius:30px; font-weight:600; transition:.3s;
}
.btn-header:hover{background:var(--white);}
.burger{display:none; flex-direction:column; gap:5px; width:26px;}
.burger span{height:1px; background:var(--white); width:100%;}

/* ===================================================================
   HERO
=================================================================== */
.hero{
  position:relative; min-height:100vh; display:flex; align-items:center;
  background:radial-gradient(ellipse 80% 60% at 50% 0%, #0E2240 0%, var(--navy-deep) 60%);
  overflow:hidden;
}
.hero::before{
  content:''; position:absolute; inset:0;
  background-image:url('data:image/svg+xml,%3Csvg xmlns="http://www.w3.org/2000/svg" width="100" height="100"%3E%3Cfilter id="n"%3E%3CfeTurbulence type="fractalNoise" baseFrequency="0.9" numOctaves="2" stitchTiles="stitch"/%3E%3C/filter%3E%3Crect width="100%25" height="100%25" filter="url(%23n)" opacity="0.025"/%3E%3C/svg%3E');
  pointer-events:none;
}
.hero-grid{
  position:absolute; inset:0; opacity:.5;
  background-image:linear-gradient(rgba(182,141,64,.07) 1px, transparent 1px);
  background-size:100% 90px;
}
.hero-content{position:relative; z-index:2; padding-top:110px; width:100%;}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:12px;
  font-size:12.5px; letter-spacing:.3em; text-transform:uppercase;
  color:var(--gold-light); margin-bottom:28px; opacity:0;
  animation:fadeUp 1s var(--ease) .3s forwards;
}
.hero-eyebrow .dash{width:32px; height:1px; background:var(--gold);}
.hero h1{
  color:var(--white); font-size:clamp(40px,6.2vw,78px); font-weight:700;
  max-width:920px; margin-bottom:30px; opacity:0;
  animation:fadeUp 1.1s var(--ease) .5s forwards;
}
.hero h1 em{
  font-style:normal; color:var(--gold-light); position:relative;
}
.hero-sub{
  color:rgba(255,255,255,.72); font-size:18px; max-width:620px; margin-bottom:48px;
  opacity:0; animation:fadeUp 1.1s var(--ease) .7s forwards;
}
.hero-cta{display:flex; gap:18px; flex-wrap:wrap; opacity:0; animation:fadeUp 1.1s var(--ease) .9s forwards;}
.btn-gold{
  background:linear-gradient(135deg,var(--gold-light),var(--gold));
  color:var(--navy-deep); padding:16px 34px; border-radius:10px; font-weight:600; font-size:15px;
  transition:transform .4s var(--ease), box-shadow .4s var(--ease); display:inline-flex; align-items:center; gap:10px;
}
.btn-gold:hover{transform:translateY(-3px); box-shadow:0 16px 36px rgba(182,141,64,.28);}
.btn-outline{
  border:1px solid rgba(255,255,255,.3); color:var(--white); padding:16px 34px; border-radius:10px;
  font-size:15px; transition:.4s var(--ease);
}
.btn-outline:hover{border-color:var(--gold-light); background:rgba(182,141,64,.08); color:var(--gold-light);}

.hero-thread{
  position:absolute; bottom:0; inset-inline-start:0; width:100%; height:120px; z-index:1; overflow:hidden;
}
.hero-thread svg{position:absolute; bottom:-1px; width:100%; height:auto;}
.scroll-cue{
  position:absolute; bottom:36px; inset-inline-start:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px; z-index:3;
  opacity:0; animation:fadeUp 1s var(--ease) 1.3s forwards;
}
.scroll-cue span{font-size:11px; letter-spacing:.2em; color:rgba(255,255,255,.5); text-transform:uppercase;}
.scroll-cue .line{width:1px; height:34px; background:rgba(255,255,255,.25); position:relative; overflow:hidden;}
.scroll-cue .line::after{content:''; position:absolute; top:0; inset-inline-start:0; width:100%; height:10px; background:var(--gold-light); animation:scrollDrop 2s ease-in-out infinite;}
@keyframes scrollDrop{0%{top:-10px;} 100%{top:34px;}}

/* ===================================================================
   SECTION SHARED
=================================================================== */
section{padding:var(--section-pad) 0; position:relative;}
section + section{margin-top:calc(var(--section-pad) * -0.85);}
.section-dark + section, section + .section-dark, .section-cream + section, section + .section-cream, .hero + section{margin-top:0;}
/* Extra safety: sections that are conditionally rendered by PHP (e.g. map embed)
   should never leave an oversized visual gap if the previous section was skipped. */
section:empty, section:has(> :only-child > *:empty:only-child){display:none;}
.section-dark{background:var(--navy-deep); color:rgba(255,255,255,.85);}
.section-dark h2{color:var(--white);}
.section-cream{background:var(--cream);}
.eyebrow{
  display:flex; align-items:center; gap:14px; margin-bottom:20px;
  font-size:12.5px; letter-spacing:.26em; text-transform:uppercase; color:var(--accent);
  font-weight:700;
}
.eyebrow .rule{width:0; height:1px; background:var(--gold); animation: akaberRule .9s var(--ease) forwards; animation-delay:.5s;}
@keyframes akaberRule{ to{ width:46px; } }
.eyebrow.in-view .rule{width:46px;}
.section-dark .eyebrow{color:var(--gold-light);}
h2.title{font-size:clamp(30px,3.6vw,46px); max-width:680px; margin-bottom:0;}
.section-head{display:flex; justify-content:space-between; align-items:flex-end; gap:40px; margin-bottom:64px; flex-wrap:wrap;}
.section-lede{max-width:420px; color:var(--gray-text); font-size:16px; line-height:1.85;}
.section-dark .section-lede{color:rgba(255,255,255,.6);}

/* reveal — scroll-triggered entrance animation via IntersectionObserver (see main.js).
   A short CSS-only fallback animation still guarantees visibility if JS fails. */
.reveal{
  opacity:0; transform:translateY(34px);
  transition:opacity .9s cubic-bezier(.16,.84,.32,1), transform .9s cubic-bezier(.16,.84,.32,1);
}
.reveal.in-view{opacity:1; transform:translateY(0);}
.reveal-d1.in-view{transition-delay:.12s;}
.reveal-d2.in-view{transition-delay:.24s;}
.reveal-d3.in-view{transition-delay:.36s;}
.reveal-d4.in-view{transition-delay:.48s;}
/* Fallback: if JS never runs (rare), reveal after a short delay regardless */
@keyframes akaberRevealFallback{ to{ opacity:1; transform:translateY(0); } }
.no-js .reveal{ animation: akaberRevealFallback 1s var(--ease) forwards; animation-delay:.4s; }

/* ===================================================================
   ABOUT
=================================================================== */
.about{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center;}
.about-media{position:relative; aspect-ratio:4/5; border-radius:20px; overflow:hidden;}
.about-media img{width:100%; height:100%; object-fit:cover;}
.about-media::after{
  content:''; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%, rgba(6,15,31,.5));
}
.about-badge{
  position:absolute; bottom:24px; inset-inline-start:24px; z-index:2;
  background:var(--navy-deep); border:none;
  padding:18px 26px; border-radius:14px; color:var(--white); box-shadow:var(--shadow-lg);
}
.about-badge .num{font-family:var(--f-display); font-size:30px; color:var(--gold-light); font-weight:700;}
.about-badge .lbl{font-size:12.5px; opacity:.8; margin-top:2px;}
.about-text p{color:var(--gray-text); margin-bottom:22px; font-size:16.5px;}
.about-text .lead{font-size:20px; color:var(--navy); font-weight:500; margin-bottom:26px; line-height:1.6;}

/* ===================================================================
   TRUST / STATS BAR
=================================================================== */
.stats-band{background:var(--navy); position:relative;}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:0;}
.stat-item{
  text-align:center; padding:0 24px; position:relative;
}
.stat-item::before{
  content:''; position:absolute; inset-inline-start:0; top:10%; height:80%; width:1px;
  background:rgba(182,141,64,.25);
}
.stat-item:first-child::before{display:none;}
.stat-num{
  font-family:var(--f-display); font-weight:700; font-size:clamp(34px,4.6vw,52px);
  color:var(--gold-light); display:flex; align-items:baseline; justify-content:center; gap:4px;
}
.stat-lbl{color:rgba(255,255,255,.65); font-size:14px; margin-top:10px;}

/* ===================================================================
   SECTORS
=================================================================== */
.sectors-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--gray-line); margin-top:10px;}
.sector-card{
  background:var(--white); padding:46px 38px; transition:all .4s var(--ease);
  position:relative; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); margin:6px;
}
.sector-card:hover{background:var(--navy-deep); transform:scale(1.02); box-shadow:var(--shadow-lg);}
.sector-card:hover .sector-title, .sector-card:hover .sector-desc{color:var(--white);}
.sector-card:hover .sector-num{color:var(--gold-light);}
.sector-num{
  font-family:var(--f-display); font-size:14px; color:var(--gray-line); font-weight:700;
  display:block; margin-bottom:28px; transition:color .4s;
}
.sector-title{
  font-family:var(--f-display); font-size:21px; font-weight:700; color:var(--navy); margin-bottom:14px;
  transition:color .4s;
}
.sector-desc{color:#3D4759; font-size:16px; line-height:1.85; transition:color .4s; font-weight:500;}
.sector-arrow{
  position:absolute; inset-inline-end:30px; bottom:30px; width:34px; height:34px; border-radius:50%;
  border:1px solid var(--gray-line); display:flex; align-items:center; justify-content:center;
  opacity:0; transform:translateY(8px); transition:.4s var(--ease); color:var(--white);
}
.sector-card:hover .sector-arrow{opacity:1; transform:translateY(0); border-color:var(--gold-light); color:var(--gold-light);}

/* ===================================================================
   WHY AKABER
=================================================================== */
.why-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:46px; margin-top:60px;}
.why-item .icon{
  width:56px; height:56px; background:rgba(201,168,76,.12); border:none; border-radius:14px;
  display:flex; align-items:center; justify-content:center; margin-bottom:24px; color:var(--gold-light); font-size:22px;
}
.why-item h3{color:var(--white); font-size:18px; margin-bottom:10px;}
.why-item p{color:rgba(255,255,255,.6); font-size:14.5px; line-height:1.8;}

/* ===================================================================
   FOUNDER QUOTE
=================================================================== */
.founder{
  background:var(--navy-deep); position:relative; padding:var(--section-pad) 0;
  background-image:radial-gradient(ellipse 70% 50% at 50% 100%, rgba(182,141,64,.07), transparent 70%);
}
.founder-inner{max-width:840px; margin:0 auto; text-align:center;}
.quote-mark{font-family:var(--f-display); font-size:64px; color:var(--gold); line-height:1; margin-bottom:10px; opacity:.7;}
.founder blockquote{
  font-family:var(--f-display); color:var(--white); font-size:clamp(22px,2.6vw,32px); font-weight:500;
  line-height:1.6; margin-bottom:42px;
}
.founder-name{color:var(--gold-light); font-weight:700; font-size:17px;}
.founder-role{color:rgba(255,255,255,.55); font-size:14px; margin-top:6px;}

/* ===================================================================
   VISION / MISSION / VALUES
=================================================================== */
.vmv-tabs{display:flex; gap:8px; margin-bottom:50px;}
.vmv-tab{
  padding:13px 28px; border:1px solid var(--gray-line); border-radius:30px; font-size:14.5px; color:var(--gray-text);
  transition:.3s;
}
.vmv-tab.active, .vmv-tab:hover{background:var(--navy); color:var(--white); border-color:var(--navy);}
.values-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:30px;}
.value-card{
  border:1px solid var(--gray-line); padding:34px; transition:.4s var(--ease); background:var(--white); border-radius:var(--radius); box-shadow:var(--shadow);
}
.value-card:hover{border-color:var(--accent); transform:translateY(-6px) scale(1.03); box-shadow:var(--shadow-lg); background:var(--white);}
.value-card:hover h3{color:var(--accent);}
.value-card h3{font-size:18px; margin-bottom:10px; color:var(--navy);}
.value-card p{font-size:14.5px; color:var(--gray-text);}

/* ===================================================================
   CTA
=================================================================== */
.cta{
  background:var(--navy); text-align:center; position:relative; overflow:hidden;
}
.cta::before{
  content:''; position:absolute; top:50%; inset-inline-start:50%; width:600px; height:600px;
  background:radial-gradient(circle, rgba(182,141,64,.12), transparent 70%);
  transform:translate(-50%,-50%);
}
.cta-inner{position:relative; z-index:2;}
.cta h2{color:var(--white); margin-bottom:24px;}
.cta p{color:rgba(255,255,255,.65); max-width:480px; margin:0 auto 40px; font-size:16.5px;}
.cta-actions{display:flex; gap:18px; justify-content:center; flex-wrap:wrap;}

/* ===================================================================
   FOOTER
=================================================================== */
footer{background:var(--navy-deep); color:rgba(255,255,255,.6); padding:90px 0 0;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:50px; padding-bottom:60px; border-bottom:1px solid rgba(255,255,255,.08);}
.footer-logo{font-family:var(--f-display); font-size:24px; color:var(--white); font-weight:800; margin-bottom:18px;}
.footer-about{font-size:14.5px; line-height:1.85; max-width:320px;}
.footer-col h5{color:var(--white); font-size:14px; letter-spacing:.08em; margin-bottom:22px; text-transform:uppercase;}
.footer-col ul{list-style:none;}
.footer-col li{margin-bottom:12px; font-size:14.5px;}
.footer-col a:hover{color:var(--gold-light);}
.footer-bottom{display:flex; justify-content:space-between; padding:26px 0; font-size:13px; flex-wrap:wrap; gap:10px;}

/* ===================================================================
   RESPONSIVE
=================================================================== */
@media (max-width:1024px){
  .about{grid-template-columns:1fr; gap:48px;}
  .sectors-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .stats-grid{grid-template-columns:repeat(2,1fr); row-gap:36px;}
  .stat-item:nth-child(3)::before{display:none;}
}
@media (max-width:760px){
  .nav-links, .header-actions .btn-header{display:none;}
  .burger{display:flex;}
  .sectors-grid, .why-grid{grid-template-columns:1fr;}
  .values-grid{grid-template-columns:1fr;}
  .section-head{margin-bottom:40px;}
  .footer-grid{grid-template-columns:1fr;}
}

/* ===================================================================
   PHASE 2 — Inner pages, Slider, Marquee, Timeline, Forms, FAQ
=================================================================== */

/* Mobile nav drawer */
.mobile-nav{
  position:fixed; top:0; inset-inline-end:-100%; width:78%; max-width:340px; height:100vh;
  background:var(--navy-deep); z-index:600; padding:100px 32px 40px; transition:inset-inline-end .5s var(--ease);
  display:flex; flex-direction:column; gap:22px;
}
body.nav-open .mobile-nav{inset-inline-end:0;}
.mobile-nav-links{list-style:none; display:flex; flex-direction:column; gap:20px;}
.mobile-nav-links a{color:#fff; font-size:17px;}
.burger.active span:nth-child(1){transform:translateY(6px) rotate(45deg);}
.burger.active span:nth-child(2){opacity:0;}
.burger.active span:nth-child(3){transform:translateY(-6px) rotate(-45deg);}
.burger span{transition:.3s;}

.logo{display:flex; align-items:center; gap:14px;}
.logo-text strong{display:block; font-family:var(--f-display); font-size:21px; font-weight:800; color:var(--white); line-height:1.15; letter-spacing:.01em;}
.logo-text small{display:block; font-size:10.5px; font-weight:500; color:var(--gold-light); letter-spacing:.04em; margin-top:2px; white-space:nowrap;}
.logo-mark{height:52px; width:auto;}
.loader-logo{width:64px; margin:0 auto 22px; display:block; opacity:0; animation:fadeUp 1s var(--ease) 0s forwards;}

.link-arrow{display:inline-flex; align-items:center; gap:8px; font-size:14.5px; font-weight:600; color:var(--gold); transition:.3s; }
.link-arrow:hover{gap:14px;}

/* Page Hero (inner pages) */
.page-hero{
  background:var(--navy-deep); padding:170px 0 80px; position:relative; overflow:hidden;
  background-image:radial-gradient(ellipse 70% 60% at 50% 0%, #0E2240 0%, var(--navy-deep) 65%);
}
.page-hero h1{color:#fff; font-size:clamp(32px,4.4vw,52px); max-width:760px;}
.page-hero-sub{color:rgba(255,255,255,.65); max-width:640px; margin-top:20px; font-size:16.5px; line-height:1.85;}

/* VMV grid */
.vmv-grid{display:grid; grid-template-columns:1fr 1fr; gap:30px; margin-bottom:60px;}
@media(max-width:760px){.vmv-grid{grid-template-columns:1fr;}}

/* Offer chips (About page) */
.offer-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-top:40px;}
.offer-chip{padding:16px 20px; border:1px solid var(--gray-line); border-radius:12px; font-size:15px; color:var(--navy); display:flex; gap:10px; transition:.3s;}
.offer-chip:hover{border-color:var(--gold); background:var(--cream);}
.offer-chip span{color:var(--gold);}
@media(max-width:760px){.offer-grid{grid-template-columns:1fr;}}

/* Sector detail rows */
.sector-detail-row{display:grid; grid-template-columns:120px 1fr; gap:30px; padding:42px 0; border-bottom:1px solid var(--gray-line);}
.sector-detail-row:first-child{border-top:1px solid var(--gray-line);}
.sector-detail-num{font-family:var(--f-display); font-size:38px; color:var(--gold); font-weight:700;}
.sector-detail-body h3{font-size:23px; margin-bottom:8px;}
.sector-detail-sub{display:block; color:var(--gold); font-size:13.5px; letter-spacing:.04em; margin-bottom:14px; font-weight:600;}
.sector-detail-body p{color:var(--gray-text); font-size:15.5px; max-width:680px;}
@media(max-width:760px){.sector-detail-row{grid-template-columns:1fr; gap:10px;}}

/* Leadership */
.leaders-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:36px;}
.leader-card{text-align:center;}
.leader-photo{aspect-ratio:1/1; border-radius:50%; overflow:hidden; margin-bottom:24px; background:var(--cream); max-width:160px; margin-inline:auto;}
.leader-photo img{width:100%; height:100%; object-fit:cover;}
.leader-photo-placeholder{width:100%; height:100%; background:linear-gradient(135deg,var(--navy),var(--navy-mid)); display:flex; align-items:center; justify-content:center;}
.leader-photo-placeholder::after{content:'A'; font-family:var(--f-display); font-size:54px; color:var(--gold-light); font-weight:700;}
.leader-card h3{font-size:19px; margin-bottom:6px;}
.leader-role{color:var(--gold); font-size:13.5px; font-weight:600; display:block; margin-bottom:14px;}
.leader-card p{color:var(--gray-text); font-size:14.5px; max-width:320px; margin:0 auto;}
@media(max-width:900px){.leaders-grid{grid-template-columns:1fr; gap:50px;}}

/* Homepage journey teaser */
.timeline-scroll{position:relative; overflow-x:auto; padding-bottom:10px;}
.timeline-track-line{position:absolute; top:11px; inset-inline-start:0; inset-inline-end:0; height:1px; background:var(--gray-line);}
.timeline-track{display:flex; gap:60px; position:relative; z-index:1; min-width:max-content; padding-bottom:10px;}
.timeline-chip{min-width:170px;}
.timeline-chip .dot{width:9px; height:9px; border-radius:50%; background:var(--gold); margin-bottom:18px;}
.timeline-chip strong{font-family:var(--f-display); color:var(--navy); font-size:16px;}
.timeline-chip p{color:var(--gray-text); font-size:14px; margin-top:8px;}

/* Full Timeline (Journey page) — single vertical column */
.full-timeline{position:relative; padding:20px 0; max-width:680px; margin:0 auto;}
.full-timeline-line{position:absolute; inset-inline-start:9px; top:6px; bottom:6px; width:1px; background:var(--gray-line);}
.timeline-row{display:grid; grid-template-columns:20px 1fr; grid-template-rows:auto auto; gap:4px 28px; margin-bottom:48px; position:relative;}
.timeline-node{grid-column:1; grid-row:1; width:13px; height:13px; border-radius:50%; background:var(--gold); border:3px solid var(--white); box-shadow:0 0 0 1px var(--gold); margin-top:6px; position:relative; z-index:2;}
.timeline-year{grid-column:2; grid-row:1; font-family:var(--f-display); font-size:24px; color:var(--navy); font-weight:700; margin-bottom:8px;}
.timeline-text{grid-column:2; grid-row:2;}
.timeline-text p{color:var(--gray-text); font-size:15.5px; max-width:520px;}
@media(max-width:600px){
  .timeline-year{font-size:20px;}
}

/* Old discrete-slider projects-slider definition removed — see the
   "continuous marquee" definition further below, which is the one in use. */
.project-slide img{width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease);}
.project-slide:hover img{transform:scale(1.06);}
.project-overlay{position:absolute; inset:0; background:linear-gradient(180deg,transparent 40%,rgba(6,15,31,.85)); display:flex; align-items:flex-end; padding:26px;}
.project-overlay span{color:#fff; font-family:var(--f-display); font-weight:600; font-size:17px;}
.slider-controls{display:flex; align-items:center; justify-content:center; gap:24px; margin-top:34px;}
.slider-btn{width:44px; height:44px; border-radius:50%; border:1px solid var(--gray-line); display:flex; align-items:center; justify-content:center; transition:.3s; color:var(--navy);}
.slider-btn:hover{background:var(--navy); color:#fff; border-color:var(--navy);}
.slider-dots{display:flex; gap:8px;}
.slider-dots .dot{width:7px; height:7px; border-radius:50%; background:var(--gray-line); transition:.3s; cursor:pointer;}
.slider-dots .dot.active{background:var(--gold); width:22px; border-radius:4px;}
@media(max-width:900px){.project-slide{flex:0 0 calc(50% - 12px);}}
@media(max-width:600px){.project-slide{flex:0 0 85%;}}

/* Partners marquee */
.marquee-wrap{overflow:hidden; position:relative; padding:30px 0; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
.marquee-track{display:flex; gap:70px; width:max-content; will-change:transform;}
.marquee-item{display:flex; align-items:center; justify-content:center; height:170px; min-width:280px; transition:transform .35s var(--ease); overflow:visible; flex-shrink:0;}
.marquee-item:hover{transform:scale(1.1); z-index:2;}
.marquee-item img{max-height:100%; max-width:280px; object-fit:contain; image-rendering:-webkit-optimize-contrast;}
.partner-placeholder{
  font-family:var(--f-display); color:var(--accent); font-size:14px; font-weight:700;
  border:1.5px dashed var(--accent); padding:16px 30px; border-radius:12px;
  display:flex; align-items:center; justify-content:center; gap:8px; background:rgba(37,99,235,.05);
  width:190px; height:130px; box-sizing:border-box; flex-shrink:0;
}

/* Forms */
.akaber-form{display:flex; flex-direction:column; gap:22px;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:22px;}
.form-group{display:flex; flex-direction:column; gap:8px;}
.form-group label{font-size:13.5px; color:var(--navy); font-weight:600;}
.form-group input, .form-group textarea{
  border:1.5px solid var(--gray-line); padding:14px 16px; font-family:inherit; font-size:15px; background:var(--cream);
  transition:border-color .3s; resize:vertical; border-radius:10px;
}
.form-group input:focus, .form-group textarea:focus{outline:none; border-color:var(--gold);}
.akaber-form .btn-gold{align-self:flex-start; border:none;}
.form-feedback{font-size:14.5px; margin-top:4px;}
.form-feedback.success{color:#2E7D32;}
.form-feedback.error{color:#C62828;}
@media(max-width:600px){.form-row{grid-template-columns:1fr;}}

/* Contact info cards */
.contact-info-card{padding:24px 0; border-bottom:1px solid var(--gray-line);}
.contact-info-card .ci-label{display:block; font-size:12.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:8px; font-weight:600;}
.contact-info-card a, .contact-info-card span{font-size:18px; color:var(--navy); font-family:var(--f-display);}
.map-frame{filter:grayscale(.15);}

/* FAQ accordion */
.faq-list{display:flex; flex-direction:column;}
.faq-item{border:1px solid var(--gray-line); border-radius:14px; margin-bottom:12px; box-shadow:var(--shadow); overflow:hidden;}
.faq-q{width:100%; display:flex; justify-content:space-between; align-items:center; padding:20px 24px; font-family:var(--f-display); font-size:17px; color:var(--navy); text-align:start;}
.faq-toggle{font-size:22px; color:var(--gold); transition:transform .4s var(--ease); flex-shrink:0; margin-inline-start:20px;}
.faq-item.open .faq-toggle{transform:rotate(45deg);}
.faq-a{max-height:0; overflow:hidden; transition:max-height .45s var(--ease);}
.faq-a p{color:var(--gray-text); padding:0 24px 22px; font-size:15.5px; max-width:680px;}

/* Header logo text */
.logo-text span{display:block; color:var(--gold-light); font-size:10px; font-weight:500; letter-spacing:.26em; text-transform:uppercase; opacity:.85;}

/* ===================================================================
   GALLERY — Auto-scrolling dual-row showcase
=================================================================== */
.gallery-section{padding-top:60px; padding-bottom:80px;}
.gallery-section > .container{margin-bottom:40px;}
.gallery-row{overflow:hidden; width:100%; margin-bottom:14px; -webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent); mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);}
.gallery-track{display:flex; gap:14px; width:max-content; will-change:transform;}
.gallery-item{flex:0 0 auto; width:260px; height:170px; border-radius:14px; overflow:hidden; box-shadow:var(--shadow);}
.gallery-item img{width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease);}
.gallery-item:hover img{transform:scale(1.08);}
@media(max-width:760px){ .gallery-item{width:180px; height:120px;} }

/* ===================================================================
   HERO PARTICLES
=================================================================== */
.hero-particles{position:absolute; inset:0; overflow:hidden; pointer-events:none; z-index:1;}
.particle{position:absolute; border-radius:50%; background:var(--gold-light); opacity:0; animation:akaberFloat linear infinite;}
@keyframes akaberFloat{
  0%{opacity:0; transform:translateY(0);}
  12%{opacity:.55;}
  88%{opacity:.3;}
  100%{opacity:0; transform:translateY(-380px);}
}

/* ===================================================================
   PROGRESS BAR
=================================================================== */
#progressBar{position:fixed; top:0; inset-inline-start:0; height:3px; width:0%; background:linear-gradient(90deg,var(--gold),var(--gold-light)); z-index:1000; transition:width .15s linear;}

/* ===================================================================
   WHATSAPP FLOAT
=================================================================== */
.whatsapp-float{
  position:fixed; bottom:26px; inset-inline-end:26px; z-index:900;
  width:56px; height:56px; border-radius:50%; background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.25); transition:transform .3s var(--ease);
}
.whatsapp-float:hover{transform:scale(1.08);}

/* ===================================================================
   TESTIMONIALS
=================================================================== */
.reviews-wrap{overflow-x:auto; padding-top:50px; padding-bottom:10px; scroll-snap-type:x proximity;}
.reviews-track{display:flex; gap:26px; width:max-content;}
.review-card{
  scroll-snap-align:start; width:340px; flex:0 0 auto; background:var(--white);
  padding:34px 30px; border:1px solid var(--gray-line); border-radius:var(--radius); box-shadow:var(--shadow);
}
.review-stars{color:var(--gold); font-size:15px; margin-bottom:16px; letter-spacing:2px;}
.review-text{color:var(--navy); font-size:15.5px; line-height:1.85; margin-bottom:22px; min-height:90px;}
.review-name{font-family:var(--f-display); font-weight:700; color:var(--navy); font-size:15px;}
.review-role{color:#8A6D2F; font-size:13px; margin-top:3px; font-weight:700;}

/* ===================================================================
   TRUSTED BAND
=================================================================== */
.trusted-band{background:var(--cream); padding:36px 0; border-top:1px solid var(--gray-line); border-bottom:1px solid var(--gray-line);}
.trusted-label{font-size:12.5px; font-weight:700; color:var(--gray-text); text-align:center; letter-spacing:.08em; margin-bottom:18px;}
.trusted-logos{display:flex; gap:16px; justify-content:center; flex-wrap:wrap;}
.trusted-chip{font-size:13.5px; font-weight:700; color:var(--gray-text); padding:8px 22px; border:1px solid var(--gray-line); border-radius:30px; background:var(--white);}

/* ===================================================================
   FOOTER SOCIAL ICONS
=================================================================== */
.footer-socials{display:flex; gap:12px; margin-top:20px;}
.social-icon{
  width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.08);
  display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.7);
  transition:.3s;
}
.social-icon:hover{background:var(--accent); color:#fff;}

/* ===================================================================
   BACK TO TOP
=================================================================== */
.back-to-top{
  position:fixed; bottom:26px; inset-inline-start:26px; z-index:900;
  width:48px; height:48px; border-radius:50%; background:var(--navy-deep); color:var(--gold-light);
  display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-lg);
  opacity:0; visibility:hidden; transform:translateY(10px); transition:.35s var(--ease);
}
.back-to-top.show{opacity:1; visibility:visible; transform:translateY(0);}
.back-to-top:hover{background:var(--accent);}

/* ===================================================================
   BREADCRUMBS
=================================================================== */
.breadcrumbs{display:flex; gap:10px; align-items:center; font-size:13.5px; color:rgba(255,255,255,.55); margin-bottom:18px;}
.breadcrumbs a{color:rgba(255,255,255,.75);}
.breadcrumbs a:hover{color:var(--gold-light);}
.breadcrumbs .sep{opacity:.5;}

/* ===================================================================
   HERO — Cinematic upgrade (#10)
=================================================================== */
.hero-bg-video{
  position:absolute; inset:0; z-index:0; width:100%; height:100%; object-fit:cover;
}
.hero-video-overlay{
  position:absolute; inset:0; z-index:2;
  background:linear-gradient(180deg, rgba(6,15,31,.55) 0%, rgba(6,15,31,.78) 60%, rgba(6,15,31,.92) 100%);
}
.hero-bg-image{
  position:absolute; inset:0; z-index:0; display:none;
  background-image:linear-gradient(180deg, rgba(10,22,40,.75), rgba(10,22,40,.92)), url('https://images.unsplash.com/photo-1486406146926-c627a92ad1ab?w=1920&q=80&auto=format&fit=crop');
  background-size:cover; background-position:center;
  animation: akaberHeroZoom 22s ease-in-out infinite alternate;
}
@keyframes akaberHeroZoom{ from{ transform:scale(1); } to{ transform:scale(1.08); } }
.hero.video-fallback .hero-bg-video{ display:none; }
.hero.video-fallback .hero-bg-image{ display:block; }
@supports not (object-fit: cover){
  .hero-bg-video{ display:none; }
  .hero-bg-image{ display:block; }
}
.hero-mesh{
  position:absolute; inset:0; z-index:1; opacity:.6;
  background:
    radial-gradient(circle at 20% 20%, rgba(37,99,235,.25), transparent 40%),
    radial-gradient(circle at 80% 70%, rgba(201,168,76,.2), transparent 45%);
  animation: akaberMeshShift 16s ease-in-out infinite alternate;
}
@keyframes akaberMeshShift{
  from{ background-position:0% 0%, 100% 100%; }
  to{ background-position:15% 10%, 85% 90%; }
}
.hero-grid{ z-index:2; }
.hero-particles{ z-index:3; }
.hero-content{ z-index:4; }
.hero-thread{ z-index:3; }
.scroll-cue{ z-index:4; }

/* Scroll cue without text */
.scroll-cue .line{height:40px;}

/* ===================================================================
   PROJECTS — Continuous marquee instead of discrete slider (#1 #7)
=================================================================== */
.projects-slider{position:relative; overflow:hidden;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 4%,#000 96%,transparent);
}
.projects-track{display:flex; gap:24px; width:max-content; cursor:grab;}
.projects-track.dragging{cursor:grabbing;}
.project-slide{flex:0 0 340px; aspect-ratio:4/5; overflow:hidden; border-radius:var(--radius); box-shadow:var(--shadow); position:relative; transition:transform .4s var(--ease), box-shadow .4s var(--ease);}
.project-slide::before{
  content:''; position:absolute; top:0; bottom:0; inset-inline-start:0; width:0; background:var(--accent);
  z-index:3; transition:width .35s var(--ease);
}
.project-slide:hover{transform:scale(1.04); box-shadow:var(--shadow-lg); z-index:5;}
.project-slide:hover::before{width:5px;}

/* PARTNERS PLACEHOLDER — see main definition near .marquee-wrap above (#9) */

/* ===================================================================
   AI FAQ ASSISTANT
=================================================================== */
.ai-faq-box{background:var(--white); border:1px solid var(--gray-line); border-radius:var(--radius); box-shadow:var(--shadow); padding:26px;}
.ai-faq-thread{max-height:340px; overflow-y:auto; display:flex; flex-direction:column; gap:14px; margin-bottom:20px; padding-inline-end:4px;}
.ai-msg{max-width:85%; padding:13px 18px; border-radius:14px; font-size:15px; line-height:1.75;}
.ai-msg-bot{background:var(--cream); color:var(--ink); align-self:flex-start; border:1px solid var(--gray-line);}
.ai-msg-user{background:var(--accent); color:#fff; align-self:flex-end;}
.ai-msg-typing{display:flex; gap:5px; align-self:flex-start; padding:14px 18px; background:var(--cream); border-radius:14px; border:1px solid var(--gray-line);}
.ai-msg-typing span{width:7px; height:7px; border-radius:50%; background:var(--gray-text); animation:akaberTypingDot 1.2s ease-in-out infinite;}
.ai-msg-typing span:nth-child(2){animation-delay:.2s;}
.ai-msg-typing span:nth-child(3){animation-delay:.4s;}
@keyframes akaberTypingDot{ 0%,60%,100%{opacity:.3; transform:translateY(0);} 30%{opacity:1; transform:translateY(-3px);} }
.ai-faq-suggestions{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:18px;}
.ai-chip{font-size:13.5px; padding:9px 16px; border:1px solid var(--gray-line); border-radius:30px; color:var(--navy); background:var(--cream); transition:.3s;}
.ai-chip:hover{background:var(--accent); color:#fff; border-color:var(--accent);}
.ai-faq-form{display:flex; gap:10px;}
.ai-faq-form input{flex:1; border:1.5px solid var(--gray-line); border-radius:10px; padding:13px 16px; font-family:inherit; font-size:15px; background:var(--cream);}
.ai-faq-form input:focus{outline:none; border-color:var(--accent);}
.ai-faq-form button{background:var(--accent); color:#fff; border-radius:10px; padding:13px 26px; font-weight:700; font-size:14.5px; transition:.3s;}
.ai-faq-form button:hover{background:var(--accent-light);}
.ai-faq-form button:disabled{opacity:.6;}

/* ===================================================================
   FIX: Arabic letter-spacing — disconnects letters, must reset for RTL
=================================================================== */
html[dir="rtl"] .eyebrow,
html[dir="rtl"] .trusted-label,
html[dir="rtl"] .contact-info-card .ci-label,
html[dir="rtl"] .nav-links a,
html[dir="rtl"] .footer-col h5 {
  letter-spacing: 0 !important;
}

/* ===================================================================
   FIX: Remove gap between stacked moving gallery rows
=================================================================== */
.gallery-row{ margin-bottom: 0 !important; }
.gallery-section .gallery-row:first-of-type{ margin-bottom: 2px !important; }

/* ===================================================================
   REGION MAP (countries presence)
=================================================================== */
.region-map{display:flex; gap:50px; justify-content:center; flex-wrap:wrap;}
.region-pin{display:flex; flex-direction:column; align-items:center; gap:10px; position:relative;}
.region-dot{
  width:14px; height:14px; border-radius:50%; background:var(--accent);
  box-shadow:0 0 0 0 rgba(37,99,235,.5); animation:akaberPulse 2.4s ease-out infinite;
}
.region-pin.is-hq .region-dot{background:var(--gold);}
@keyframes akaberPulse{
  0%{box-shadow:0 0 0 0 rgba(37,99,235,.45);}
  70%{box-shadow:0 0 0 14px rgba(37,99,235,0);}
  100%{box-shadow:0 0 0 0 rgba(37,99,235,0);}
}
.region-pin.is-hq .region-dot{animation-name:akaberPulseGold;}
@keyframes akaberPulseGold{
  0%{box-shadow:0 0 0 0 rgba(201,168,76,.5);}
  70%{box-shadow:0 0 0 14px rgba(201,168,76,0);}
  100%{box-shadow:0 0 0 0 rgba(201,168,76,0);}
}
.region-name{font-size:14.5px; font-weight:700; color:var(--navy);}
.region-hq-tag{position:absolute; top:-14px; font-size:10px; background:var(--gold); color:var(--navy-deep); padding:2px 8px; border-radius:10px; font-weight:800;}

/* ===================================================================
   PROJECT SINGLE PAGE
=================================================================== */
.project-hero-media{aspect-ratio:16/8; border-radius:var(--radius); overflow:hidden; margin-bottom:40px;}
.project-hero-media img{width:100%; height:100%; object-fit:cover;}
.project-meta-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--gray-line); margin-bottom:50px; border-radius:var(--radius); overflow:hidden;}
.project-meta-item{background:var(--white); padding:24px; text-align:center;}
.pmi-label{display:block; font-size:12px; color:var(--gray-text); margin-bottom:8px; text-transform:uppercase; letter-spacing:.05em;}
.pmi-value{display:block; font-family:var(--f-display); font-size:18px; font-weight:700; color:var(--navy);}
.project-content{font-size:16.5px; line-height:1.9; color:var(--ink); max-width:760px;}
@media(max-width:760px){ .project-meta-grid{grid-template-columns:repeat(2,1fr);} }

/* ===================================================================
   NEWS & INSIGHTS
=================================================================== */
.news-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:30px;}
.news-card{background:var(--white); border:1px solid var(--gray-line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); transition:.4s var(--ease); display:block; position:relative;}
.news-card::before{content:''; position:absolute; top:0; bottom:0; inset-inline-start:0; width:0; background:var(--accent); z-index:3; transition:width .35s var(--ease);}
.news-card:hover::before{width:5px;}
.news-card:hover{transform:translateY(-6px); box-shadow:var(--shadow-lg);}
.news-card-media{aspect-ratio:4/3; overflow:hidden;}
.news-card-media img{width:100%; height:100%; object-fit:cover;}
.news-card-body{padding:24px;}
.news-card-date{font-size:12.5px; color:var(--accent); font-weight:700;}
.news-card-body h3{font-size:18px; margin:10px 0; color:var(--navy);}
.news-card-body p{font-size:14.5px; color:var(--gray-text); line-height:1.75;}
.news-empty{grid-column:1/-1; text-align:center; padding:60px 0; color:var(--gray-text);}
@media(max-width:900px){ .news-grid{grid-template-columns:1fr 1fr;} }
@media(max-width:600px){ .news-grid{grid-template-columns:1fr;} }

/* ===================================================================
   HERO MOUSE GLOW
=================================================================== */
.hero-glow{
  position:absolute; inset:0; z-index:3; pointer-events:none; opacity:0; transition:opacity .4s;
  background:radial-gradient(circle 280px at var(--gx,50%) var(--gy,50%), rgba(201,168,76,.18), transparent 70%);
}
.hero:hover .hero-glow{opacity:1;}

/* ===================================================================
   COOKIE CONSENT BANNER
=================================================================== */
#cookieBanner{
  position:fixed; bottom:0; inset-inline-start:0; inset-inline-end:0; z-index:950;
  background:var(--navy-deep); color:rgba(255,255,255,.85); padding:20px 26px;
  display:flex; align-items:center; justify-content:center; gap:24px; flex-wrap:wrap;
  transform:translateY(100%); transition:transform .5s var(--ease); box-shadow:0 -10px 30px rgba(0,0,0,.15);
}
#cookieBanner.show{transform:translateY(0);}
#cookieBanner p{font-size:14px; margin:0; max-width:600px;}
#cookieBanner a{color:var(--gold-light); text-decoration:underline;}
#cookieAccept{background:var(--gold); color:var(--navy-deep); padding:10px 26px; border-radius:30px; font-weight:700; font-size:14px; flex-shrink:0;}

/* ===================================================================
   PAGE TRANSITION FADE
=================================================================== */
body{ opacity:1; transition:opacity .25s ease; }
body.akaber-fading{ opacity:0; }

/* ===================================================================
   COMPANY PROFILE PDF BUTTON
=================================================================== */
.profile-pdf-btn{display:inline-flex; align-items:center; gap:10px;}

/* ===================================================================
   PYRAMID TIMELINE (Homepage) — stacked, no horizontal cut-off (#1)
=================================================================== */
.pyramid-timeline{display:flex; flex-direction:column; gap:0; max-width:640px; margin:0; position:relative; padding-inline-start:8px;}
.pyramid-line{
  position:absolute; top:30px; bottom:50px; inset-inline-start:31px; width:2px;
  background:linear-gradient(to bottom, var(--gold) 0%, var(--gray-line) 100%);
  transform-origin:top; transform:scaleY(0); transition:transform 1.4s cubic-bezier(.16,.84,.32,1);
}
.pyramid-line.in-view{transform:scaleY(1);}
.pyramid-step{
  display:flex; align-items:flex-start; gap:26px; padding:20px 14px;
  margin-inline-start:calc(var(--step, 0) * 26px);
  border-radius:14px;
  transition:margin .4s var(--ease), background .35s var(--ease), transform .35s var(--ease);
  position:relative; z-index:2;
}
.pyramid-step:hover{background:var(--white); box-shadow:var(--shadow); transform:translateX(0) scale(1.02);}
.pyramid-icon{
  flex-shrink:0; width:48px; height:48px; border-radius:50%; background:var(--navy-deep);
  color:var(--gold-light); display:flex; align-items:center; justify-content:center;
  font-family:var(--f-display); font-weight:700; font-size:15px; box-shadow:0 6px 16px rgba(10,22,40,.25);
  border:3px solid var(--cream); transition:transform .4s var(--ease), background .4s var(--ease);
}
.pyramid-step:hover .pyramid-icon{transform:scale(1.15); background:var(--accent);}
.pyramid-body{padding-top:4px;}
.pyramid-body strong{display:block; font-family:var(--f-display); font-size:19px; color:var(--navy); margin-bottom:5px; transition:color .3s;}
.pyramid-step:hover .pyramid-body strong{color:var(--accent);}
.pyramid-body p{color:var(--gray-text); font-size:14.5px; margin:0; line-height:1.7;}
@media(max-width:760px){
  .pyramid-step{margin-inline-start:0 !important; padding:16px 10px;}
  .pyramid-line{inset-inline-start:31px;}
}

/* ===================================================================
   STORYTELLING JOURNEY PAGE (#1)
=================================================================== */
.story-hero{position:relative; min-height:70vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; background:var(--navy-deep); overflow:hidden; padding:140px 0 80px;}
.story-hero-bg{position:absolute; inset:0; background:radial-gradient(ellipse 70% 60% at 50% 0%, #0E2240 0%, var(--navy-deep) 65%); opacity:.9;}
.story-hero-content{position:relative; z-index:2; max-width:760px;}
.story-hero-content h1{color:#fff; font-size:clamp(32px,4.4vw,52px);}
.story-hero-content .breadcrumbs{justify-content:center;}
.story-hero-content .eyebrow{justify-content:center;}
.story-scroll-hint{position:relative; z-index:2; margin-top:50px; display:flex; flex-direction:column; align-items:center; gap:10px;}
.story-scroll-hint span{color:rgba(255,255,255,.5); font-size:12px; letter-spacing:.15em; text-transform:uppercase;}
.story-scroll-line{width:1px; height:40px; background:rgba(255,255,255,.25); position:relative; overflow:hidden;}
.story-scroll-line::after{content:''; position:absolute; top:0; inset-inline-start:0; width:100%; height:12px; background:var(--gold-light); animation:scrollDrop 2s ease-in-out infinite;}

.story-rail{position:sticky; top:0; height:3px; background:var(--gray-line); z-index:90;}
.story-rail-fill{height:100%; width:0%; background:linear-gradient(90deg,var(--gold),var(--gold-light)); transition:width .1s linear;}

.story-chapters{padding:40px 0 20px; max-width:1100px; margin:0 auto;}
.story-chapter{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:70px 28px;}
.story-end{direction:ltr;}
html[dir="rtl"] .story-end{direction:rtl;}
.story-end .story-chapter-media{order:2;}
.story-end .story-chapter-text{order:1;}
.story-chapter-media{position:relative; aspect-ratio:4/3; border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg);}
.story-chapter-media img{width:100%; height:100%; object-fit:cover; transform:scale(1.15); transition:transform 1.4s cubic-bezier(.16,.84,.32,1);}
.story-chapter.in-view .story-chapter-media img{transform:scale(1);}
.story-chapter-media:hover img{transform:scale(1.06) !important;}
.story-year-badge{
  position:absolute; bottom:20px; inset-inline-start:20px; background:var(--navy-deep); color:var(--gold-light);
  font-family:var(--f-display); font-weight:700; font-size:22px; padding:10px 22px; border-radius:10px;
}
.story-chapter-num{font-family:var(--f-display); font-size:46px; font-weight:700; color:var(--gray-line); margin-bottom:14px;}
.story-chapter-text h2{font-size:clamp(22px,2.4vw,30px); margin-bottom:18px;}
.story-chapter-text p{color:var(--gray-text); font-size:16px; line-height:1.9;}
@media(max-width:860px){
  .story-chapter{grid-template-columns:1fr; gap:30px; padding:40px 20px;}
  .story-end .story-chapter-media, .story-end .story-chapter-text{order:initial;}
}

/* ===================================================================
   BRAND MARK SECTION — large centered logo moment (#4)
=================================================================== */
.brand-mark-section{position:relative; padding:90px 0; text-align:center; background:var(--cream); overflow:hidden;}
.brand-mark-glow{position:absolute; top:50%; inset-inline-start:50%; width:500px; height:500px; background:radial-gradient(circle, rgba(201,168,76,.12), transparent 70%); transform:translate(-50%,-50%);}
.brand-mark-img{position:relative; z-index:2; width:110px; height:auto; margin:0 auto 26px; opacity:0; animation:akaberReveal 1.2s var(--ease) forwards; animation-delay:.1s;}
.brand-mark-tagline{position:relative; z-index:2; font-family:var(--f-display); font-size:clamp(18px,2.2vw,24px); color:var(--navy); font-weight:600; max-width:600px; margin:0 auto;}

/* ===================================================================
   PROJECT ZOOM ICON (#6)
=================================================================== */
.project-zoom-icon{
  position:absolute; top:18px; inset-inline-end:18px; width:38px; height:38px; border-radius:50%;
  background:rgba(255,255,255,.18); backdrop-filter:blur(8px); color:#fff;
  display:flex; align-items:center; justify-content:center; opacity:0; transform:scale(.8);
  transition:.35s var(--ease); z-index:2;
}
.project-slide{ position:relative; }
.project-slide:hover .project-zoom-icon{opacity:1; transform:scale(1);}
.project-zoom-icon:hover{background:var(--gold-light); color:var(--navy-deep);}

/* TRUST STRIP removed entirely per client request. */
.page-hero{ padding-top:80px; }

/* ===================================================================
   INTERACTIVE SECTORS (#10)
=================================================================== */
.sectors-interactive{margin-top:50px; display:grid; grid-template-columns:340px 1fr; gap:0; border:1px solid var(--gray-line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);}
.sectors-tabs{background:var(--cream); border-inline-end:1px solid var(--gray-line); display:flex; flex-direction:column;}
.sector-tab{
  display:flex; align-items:center; gap:14px; padding:20px 24px; text-align:start; border-bottom:1px solid var(--gray-line);
  transition:.3s; position:relative;
}
.sector-tab:last-child{border-bottom:none;}
.sector-tab-icon{font-size:20px;}
.sector-tab-title{flex:1; font-size:14.5px; font-weight:700; color:var(--navy);}
.sector-tab-num{font-family:var(--f-display); font-size:12px; color:var(--gray-line); font-weight:700;}
.sector-tab:hover{background:var(--white);}
.sector-tab.active{background:var(--navy-deep);}
.sector-tab.active .sector-tab-title{color:#fff;}
.sector-tab.active .sector-tab-num{color:var(--gold-light);}
.sector-tab.active::after{content:''; position:absolute; top:0; bottom:0; inset-inline-start:0; width:3px; background:var(--gold);}

.sectors-display{position:relative; min-height:420px; background:var(--white);}
.sector-panel{position:absolute; inset:0; display:grid; grid-template-columns:1fr 1fr; opacity:0; pointer-events:none; transition:opacity .5s var(--ease);}
.sector-panel.active{opacity:1; pointer-events:auto;}
.sector-panel-media{overflow:hidden;}
.sector-panel-media img{width:100%; height:100%; object-fit:cover; transform:scale(1.05); transition:transform 8s ease-out;}
.sector-panel.active .sector-panel-media img{transform:scale(1);}
.sector-panel-text{padding:50px 44px; display:flex; flex-direction:column; justify-content:center;}
.sector-panel-num{font-family:var(--f-display); font-size:42px; color:var(--gray-line); font-weight:700; margin-bottom:16px;}
.sector-panel-text h3{font-size:24px; margin-bottom:16px; color:var(--navy);}
.sector-panel-text p{color:var(--gray-text); font-size:15.5px; line-height:1.85;}
@media(max-width:900px){
  .sectors-interactive{grid-template-columns:1fr;}
  .sectors-tabs{flex-direction:column; overflow-x:visible; border-inline-end:none; border-bottom:1px solid var(--gray-line);}
  .sector-tab{flex-direction:row; gap:14px; min-width:0; text-align:start; border-bottom:1px solid var(--gray-line); border-inline-end:none;}
  .sector-tab:last-child{border-bottom:none;}
  .sector-tab.active::after{top:0; bottom:0; inset-inline-start:0; width:3px; height:auto;}
  .sectors-display{min-height:auto;}
  .sector-panel{position:relative; display:none; grid-template-columns:1fr;}
  .sector-panel.active{display:grid;}
  .sector-panel-media{aspect-ratio:16/9;}
  .sector-panel-text{padding:30px 24px;}
}

/* ===================================================================
   AI FAQ — action buttons when assistant is not configured
=================================================================== */
.ai-msg-actions{display:flex; gap:10px; margin-top:-4px;}
.ai-action-btn{
  font-size:13px; font-weight:700; padding:9px 18px; border-radius:20px;
  background:var(--accent); color:#fff; transition:.3s;
}
.ai-action-btn:hover{background:var(--accent-light);}
.ai-action-btn-wa{background:#25D366;}
.ai-action-btn-wa:hover{background:#1ebe57;}

/* ===================================================================
   FAQ GROUPS
=================================================================== */
.faq-group{margin-bottom:44px;}
.faq-group-title{font-family:var(--f-display); font-size:15px; color:var(--accent); font-weight:800; text-transform:uppercase; letter-spacing:.04em; margin-bottom:16px; padding-bottom:10px; border-bottom:2px solid var(--gray-line);}

/* ===================================================================
   LEGACY NUMBER SECTION — professional animated ring counter
=================================================================== */
.legacy-number-section{
  position:relative; background:var(--navy-deep); padding:110px 0; overflow:hidden;
}
.legacy-number-glow{
  position:absolute; top:50%; inset-inline-start:50%; width:900px; height:900px;
  background:radial-gradient(circle, rgba(201,168,76,.10), transparent 65%);
  transform:translate(-50%,-50%); pointer-events:none;
}
.legacy-number-inner{
  position:relative; z-index:2; display:grid; grid-template-columns:auto 1fr; gap:80px; align-items:center;
}
.legacy-ring-wrap{position:relative; width:240px; height:240px; flex-shrink:0; margin:0 auto;}
.legacy-ring{width:100%; height:100%; transform:rotate(-90deg);}
.legacy-ring-track{fill:none; stroke:rgba(255,255,255,.08); stroke-width:6;}
.legacy-ring-fill{
  fill:none; stroke:url(#akaberGoldGradient); stroke-width:6; stroke-linecap:round;
  stroke-dasharray:678.6; stroke-dashoffset:678.6;
  transition:stroke-dashoffset 2.2s cubic-bezier(.16,.84,.32,1);
}
.legacy-ring-content{
  position:absolute; inset:0; display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.legacy-num{font-family:var(--f-display); font-size:56px; font-weight:800; color:var(--white); line-height:1; display:flex; align-items:baseline; gap:2px;}
.legacy-num .num-val{color:var(--gold-light);}
.legacy-num-label{color:rgba(255,255,255,.55); font-size:14px; letter-spacing:.08em; text-transform:uppercase; margin-top:10px;}
.legacy-number-text .eyebrow{color:var(--gold-light);}
.legacy-number-text h2{color:#fff; font-size:clamp(24px,3vw,36px); margin-bottom:18px;}
.legacy-number-text p{color:rgba(255,255,255,.7); font-size:16px; line-height:1.9; max-width:520px;}
@media(max-width:760px){
  .legacy-number-inner{grid-template-columns:1fr; text-align:center; gap:44px;}
  .legacy-number-text p{margin-inline:auto;}
}

/* Old legacy-timeline-layout (ring-based) definition removed — replaced below
   with the new left-aligned, non-circular professional legacy card design. */

/* Old navy card design fully removed — see LEGACY SECTION at end of file for the new design. */

/* ===================================================================
   LEGACY SECTION — Editorial-style "70+ years" (no circle, no card box)
=================================================================== */
.legacy-section{padding:var(--section-pad) 0; background:var(--cream); position:relative;}
.legacy-timeline-layout{
  display:grid; grid-template-columns:290px 1fr; gap:80px; align-items:start; margin-top:54px;
  direction:ltr;
}
.legacy-timeline-layout .legacy-hero-num{direction:ltr; text-align:start;}
.legacy-timeline-layout .pyramid-timeline{direction:inherit;}
html[dir="rtl"] .legacy-timeline-layout .pyramid-timeline{direction:rtl;}
.legacy-hero-num{position:sticky; top:130px;}
.legacy-hero-num-figure{
  display:flex; align-items:flex-start; line-height:.85; margin-bottom:18px;
}
.legacy-hero-num-figure .legacy-num{
  font-family:var(--f-display); font-weight:800; font-size:clamp(90px,9vw,128px);
  background:linear-gradient(160deg, var(--navy) 20%, var(--accent) 100%);
  -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent;
  letter-spacing:-.03em;
}
.legacy-hero-num-figure .legacy-num-plus{
  font-family:var(--f-display); font-weight:800; font-size:clamp(38px,4vw,52px);
  color:var(--gold); margin-top:8px; margin-inline-start:2px;
}
.legacy-hero-num-label{
  font-family:var(--f-display); font-size:16px; font-weight:700; color:var(--navy);
  line-height:1.4; text-transform:uppercase; letter-spacing:.02em;
}
.legacy-hero-num-line{width:52px; height:3px; background:linear-gradient(90deg,var(--gold),var(--gold-light)); margin:26px 0;}
.legacy-hero-num-meta{display:flex; gap:34px;}
.legacy-meta-item{display:flex; flex-direction:column; gap:4px;}
.legacy-meta-item strong{font-family:var(--f-display); font-size:22px; color:var(--accent); font-weight:700;}
.legacy-meta-item span{font-size:12.5px; color:var(--gray-text);}
@media(max-width:900px){
  .legacy-timeline-layout{grid-template-columns:1fr; gap:40px;}
  .legacy-hero-num{position:static;}
  .pyramid-timeline{padding-inline-start:0;}
}

/* ===================================================================
   PROJECTS GRID — standalone projects page layout
=================================================================== */
.projects-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;}
@media(max-width:900px){.projects-grid{grid-template-columns:repeat(2, 1fr);}}
@media(max-width:600px){.projects-grid{grid-template-columns:1fr;}}
