/* ═══════ BRAND FONTS ═══════ */
@font-face{
  font-family:"Zain";
  src:url("/assets/fonts/zain-regular.ttf") format("truetype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Faktum";
  src:url("/assets/fonts/faktum-regular.otf") format("opentype");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Faktum";
  src:url("/assets/fonts/faktum-bold.otf") format("opentype");
  font-weight:700;font-style:normal;font-display:swap;
}

:root{
  --red:#c94030;
  --red-dark:#a33328;
  --red-light:#e86050;
  --ink:#181818;
  --ink-2:#2b2b2b;
  --muted:#6b6b6b;
  --muted-2:#9a9a9a;
  --bg:#ffffff;
  --bg-2:#f6f5f3;
  --bg-3:#ececea;
  --line:#e8e8e6;
  --line-strong:#cfcfcd;
  --max:1440px;
  --gutter:48px;
  --ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;background:var(--bg)}
body{
  font-family:"Faktum","Inter","Cairo",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);
  font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
  /* Prevent ugly synthetic bold/italic — fall back to next family that has the weight */
  font-synthesis:none;
  -webkit-font-synthesis:none;
}
/* AR body: Zain for regular weight; for 500+ fall back to Cairo (which has those weights) */
html[lang="ar"] body, html[dir="rtl"] body{font-family:"Zain","Cairo","Faktum",sans-serif}
/* For any explicitly bold element in RTL → skip Zain, use Cairo directly */
html[dir="rtl"] h1, html[dir="rtl"] h2, html[dir="rtl"] h3, html[dir="rtl"] h4,
html[dir="rtl"] [class*="title"], html[dir="rtl"] .section-title,
html[dir="rtl"] .hero-title, html[dir="rtl"] strong, html[dir="rtl"] b{
  font-family:"Cairo","Zain",sans-serif;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer}
::selection{background:var(--ink);color:#fff}

.wrap{max-width:var(--max);margin:0 auto;padding:0 var(--gutter)}
.wrap-fluid{padding:0 var(--gutter)}

/* ═══════ NAV ═══════ */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:50;
  background:rgba(255,255,255,0);
  transition:background .35s var(--ease),box-shadow .35s,border-color .35s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:rgba(255,255,255,.95);
  backdrop-filter:saturate(180%) blur(16px);
  -webkit-backdrop-filter:saturate(180%) blur(16px);
  border-bottom-color:var(--line);
}
.nav-row{display:flex;align-items:center;justify-content:space-between;height:90px;gap:24px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:46px;width:auto;transition:transform .35s var(--ease)}
.brand:hover img{transform:scale(1.04)}
/* Logo defaults to dark — only flips on nav-light variant */
.nav-light:not(.scrolled) .brand img{filter:brightness(0) invert(1)}

.menu{display:flex;align-items:center;gap:42px}
.menu .link{
  font-family:"Faktum","Inter",sans-serif;font-weight:600;
  font-size:12.5px;letter-spacing:.18em;color:var(--ink);
  position:relative;padding:8px 0;text-transform:uppercase;
  transition:color .25s;
}
html[dir="rtl"] .menu .link{font-family:"Zain","Cairo",sans-serif;font-size:14px;text-transform:none;letter-spacing:.01em;font-weight:600}
.menu .link::after{content:"";position:absolute;inset:auto 0 0 0;height:1px;background:var(--red);transform:scaleX(0);transform-origin:right;transition:transform .35s var(--ease)}
.menu .link:hover::after,.menu .link.active::after{transform:scaleX(1);transform-origin:left}
.menu .link.active{color:var(--ink)}

.nav-light:not(.scrolled) .menu .link{color:rgba(255,255,255,.95)}
.nav-light:not(.scrolled) .menu .link::after{background:#fff}
.nav-light:not(.scrolled) .lang-switch{border-color:rgba(255,255,255,.35)}
.nav-light:not(.scrolled) .lang-switch a{color:rgba(255,255,255,.75)}
.nav-light:not(.scrolled) .lang-switch a.on{background:#fff;color:var(--ink)}
.nav-light:not(.scrolled) .nav-cta{background:#fff;color:var(--ink)}

.lang-switch{
  display:inline-flex;align-items:center;
  border:1px solid var(--line-strong);
  padding:3px;font-size:11.5px;font-weight:600;letter-spacing:.06em;
}
.lang-switch a{padding:6px 12px;color:var(--muted);transition:all .25s}
.lang-switch a.on{background:var(--ink);color:#fff}

.nav-cta{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--red);color:#fff;
  padding:14px 24px;font-size:11.5px;font-weight:700;
  letter-spacing:.18em;text-transform:uppercase;
  transition:background .25s,transform .25s var(--ease),color .25s;
}
html[dir="rtl"] .nav-cta{font-family:"Zain","Cairo",sans-serif;font-size:13.5px;letter-spacing:.02em;text-transform:none;font-weight:700}
.nav-cta:hover{background:var(--ink);color:#fff;transform:translateY(-1px)}

.burger{display:none;width:42px;height:42px;border:0;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.burger span{display:block;width:24px;height:1.5px;background:var(--ink);position:relative}
.burger span::before,.burger span::after{content:"";position:absolute;left:0;width:24px;height:1.5px;background:var(--ink);transition:transform .3s}
.burger span::before{top:-7px}.burger span::after{top:7px}
.nav-light:not(.scrolled) .burger span,
.nav-light:not(.scrolled) .burger span::before,
.nav-light:not(.scrolled) .burger span::after{background:#fff}

/* ═══════ BUTTONS ═══════ */
.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 32px;border-radius:0;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;
  transition:all .3s var(--ease);
  cursor:pointer;border:1px solid transparent;
}
html[dir="rtl"] .btn{font-family:"Zain","Cairo",sans-serif;font-size:14px;letter-spacing:.02em;text-transform:none;font-weight:700}
.btn-primary{background:var(--red);color:#fff}
.btn-primary:hover{background:var(--ink);transform:translateY(-2px)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:var(--red);transform:translateY(-2px)}
.btn-outline{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-outline-light{background:transparent;color:#fff;border-color:rgba(255,255,255,.65)}
.btn-outline-light:hover{background:#fff;color:var(--ink);border-color:#fff}
.btn .arrow{display:inline-flex;align-items:center;justify-content:center;width:14px;transition:transform .3s var(--ease)}
.btn:hover .arrow{transform:translateX(4px)}
html[dir="rtl"] .btn:hover .arrow{transform:translateX(-4px)}

/* ═══════ HERO ═══════ */
.hero{
  position:relative;height:100vh;min-height:680px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;background:var(--ink);color:#fff;
}
.hero-img{position:absolute;inset:0;z-index:0}
.hero-img img{width:100%;height:100%;object-fit:cover;animation:slowZoom 30s var(--ease) infinite alternate}
@keyframes slowZoom{ to{ transform:scale(1.1) } }
.hero-img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, rgba(24,24,24,.35) 0%, rgba(24,24,24,.15) 40%, rgba(24,24,24,.7) 100%);
}
.hero-content{position:relative;z-index:2;text-align:center;padding:0 var(--gutter);max-width:1200px}

.hero-eyebrow{
  display:inline-block;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.42em;text-transform:uppercase;
  color:rgba(255,255,255,.85);margin-bottom:36px;
  padding-bottom:18px;border-bottom:1px solid rgba(255,255,255,.35);
}
html[dir="rtl"] .hero-eyebrow{font-family:"Zain","Cairo",sans-serif;letter-spacing:.16em;font-size:13px;text-transform:none}

h1.hero-title{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(48px,7.2vw,116px);line-height:1.04;letter-spacing:-.035em;
  text-transform:uppercase;margin:0 0 28px;color:#fff;
}
html[dir="rtl"] h1.hero-title{
  font-family:"Zain","Cairo",sans-serif;font-weight:800;
  font-size:clamp(42px,6.5vw,104px);line-height:1.1;letter-spacing:-.02em;
  text-transform:none;
}
h1.hero-title .red{color:var(--red-light)}
h1.hero-title .thin{font-weight:300}

.hero-lede{
  font-size:17px;line-height:1.75;max-width:680px;
  color:rgba(255,255,255,.86);margin:0 auto 44px;
}
html[dir="rtl"] .hero-lede{font-size:17px;line-height:1.9}

.hero-actions{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}

.hero-scroll{
  position:absolute;bottom:36px;left:50%;transform:translateX(-50%);
  z-index:2;display:flex;flex-direction:column;align-items:center;gap:10px;
  color:rgba(255,255,255,.6);
  font-size:10px;letter-spacing:.36em;text-transform:uppercase;font-weight:700;
}
.hero-scroll::after{content:"";display:block;width:1px;height:36px;background:linear-gradient(180deg,rgba(255,255,255,.6),transparent);animation:scrollLine 2.4s var(--ease) infinite}
@keyframes scrollLine{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.01%{transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ═══════ MARQUEE TICKER ═══════ */
.ticker{
  background:var(--ink);color:#fff;padding:22px 0;overflow:hidden;
  position:relative;
}
.ticker-track{display:flex;gap:0;animation:tickerScroll 32s linear infinite;white-space:nowrap;width:max-content}
@keyframes tickerScroll{ to{ transform:translateX(-50%) } }
.ticker-item{
  display:inline-flex;align-items:center;gap:32px;padding:0 32px;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:18px;
  letter-spacing:.28em;text-transform:uppercase;
}
html[dir="rtl"] .ticker-item{font-family:"Zain","Cairo",sans-serif;letter-spacing:.06em;font-size:20px;text-transform:none;font-weight:700}
.ticker-item .dot{display:inline-block;width:6px;height:6px;background:var(--red);border-radius:50%}

/* ═══════ SECTION LABELS ═══════ */
.section-label{
  display:flex;align-items:center;gap:14px;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.4em;text-transform:uppercase;
  color:var(--red);margin-bottom:30px;
}
html[dir="rtl"] .section-label{font-family:"Zain","Cairo",sans-serif;letter-spacing:.18em;font-weight:700}
.section-label::before{content:"";display:block;width:48px;height:1px;background:var(--red)}
.section-label .num{color:var(--muted-2);letter-spacing:.18em;margin-inline-start:auto;font-weight:500}

.section-title{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(40px,5.4vw,84px);line-height:1.02;letter-spacing:-.035em;
  text-transform:uppercase;margin:0;color:var(--ink);
}
html[dir="rtl"] .section-title{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(36px,4.6vw,72px);line-height:1.1;letter-spacing:-.02em;text-transform:none}
.section-title .red{color:var(--red)}
.section-title .thin{font-weight:300;color:var(--muted)}

/* ═══════ ABOUT ═══════ */
.about-section{padding:140px 0;background:var(--bg)}
.about-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:90px;align-items:center}
.about-text .section-label{margin-bottom:38px}
.about-text h2{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(38px,4.6vw,68px);line-height:1.04;letter-spacing:-.035em;
  text-transform:uppercase;margin:0 0 32px;
}
html[dir="rtl"] .about-text h2{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(34px,4.2vw,60px);line-height:1.15;letter-spacing:-.02em;text-transform:none}
.about-text h2 .red{color:var(--red)}
.about-text h2 .thin{font-weight:300;color:var(--muted)}
.about-text p{font-size:16.5px;line-height:1.9;color:var(--ink-2);margin:0 0 22px;max-width:580px}
html[dir="rtl"] .about-text p{font-size:16px;line-height:2}
.about-text .actions{margin-top:30px;display:flex;gap:14px;flex-wrap:wrap}

.about-img{position:relative;aspect-ratio:4/5;overflow:hidden}
.about-img img{width:100%;height:100%;object-fit:cover;transition:transform 12s var(--ease)}
.about-img:hover img{transform:scale(1.05)}
.about-img-meta{
  position:absolute;left:0;right:0;bottom:0;z-index:2;
  padding:24px 28px;color:#fff;
  background:linear-gradient(transparent, rgba(0,0,0,.65));
  display:flex;justify-content:space-between;align-items:flex-end;gap:14px;
}
.about-img-meta b{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:12px;letter-spacing:.28em;text-transform:uppercase;
}
html[dir="rtl"] .about-img-meta b{font-family:"Zain","Cairo",sans-serif;letter-spacing:.1em;font-size:13px;text-transform:none}

/* ═══════ PROJECTS ═══════ */
.projects-section{padding:160px 0 140px;background:var(--bg-2);border-block:1px solid var(--line)}
.projects-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:80px}
.projects-head p{font-size:16px;line-height:1.85;color:var(--ink-2);max-width:480px;margin:0}

.projects-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.project-card{
  position:relative;overflow:hidden;background:var(--ink);
  aspect-ratio:5/4;cursor:pointer;
  display:flex;flex-direction:column;justify-content:flex-end;
  color:#fff;
}
.project-card.tall{aspect-ratio:5/6}
.project-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform 8s var(--ease);
}
.project-card:hover img{transform:scale(1.05)}
.project-card::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 30%, rgba(0,0,0,.65) 100%);
}
.project-card-content{position:relative;z-index:2;padding:38px 38px 36px;display:flex;flex-direction:column;gap:10px}
.project-card .status{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--red-light);margin-bottom:8px;
  display:inline-flex;align-items:center;gap:8px;
}
html[dir="rtl"] .project-card .status{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:13px;text-transform:none;font-weight:700}
.project-card .status::before{content:"";display:block;width:6px;height:6px;background:var(--red-light);border-radius:50%}
.project-card h3{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(28px,3vw,42px);line-height:1;letter-spacing:-.025em;
  text-transform:uppercase;margin:0;color:#fff;
}
html[dir="rtl"] .project-card h3{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(24px,2.6vw,36px);line-height:1.15;letter-spacing:-.01em;text-transform:none}
.project-card p{font-size:15px;line-height:1.6;color:rgba(255,255,255,.78);margin:6px 0 0;max-width:380px}
.project-card .more{
  margin-top:18px;
  display:inline-flex;align-items:center;gap:10px;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;
  color:#fff;align-self:flex-start;
}
html[dir="rtl"] .project-card .more{font-family:"Zain","Cairo",sans-serif;letter-spacing:.08em;font-size:13px;text-transform:none}
.project-card .more::after{content:"→";display:inline-block;transition:transform .3s}
html[dir="rtl"] .project-card .more::after{content:"←"}
.project-card:hover .more::after{transform:translateX(6px)}
html[dir="rtl"] .project-card:hover .more::after{transform:translateX(-6px)}

/* ═══════ SERVICES STRIP ═══════ */
.services-section{padding:160px 0;background:var(--bg)}
.services-head{margin-bottom:60px}
.services-head .top{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end}
.services-head p{font-size:16px;line-height:1.85;color:var(--ink-2);max-width:460px;margin:0}

.services-list{border-top:1px solid var(--ink)}
.svc-item{
  display:grid;grid-template-columns:90px 1.4fr 2fr 60px;gap:36px;align-items:center;
  padding:36px 0;border-bottom:1px solid var(--line);
  position:relative;cursor:pointer;
  transition:padding .35s var(--ease);
}
.svc-item:hover{padding-inline-start:18px;padding-inline-end:18px;background:var(--bg-2)}
.svc-item .nb{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:13px;letter-spacing:.22em;color:var(--red);
}
.svc-item h3{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:30px;line-height:1.05;letter-spacing:-.025em;
  text-transform:uppercase;margin:0;color:var(--ink);
  transition:color .35s,transform .35s var(--ease);
}
html[dir="rtl"] .svc-item h3{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:26px;text-transform:none}
.svc-item:hover h3{color:var(--red)}
.svc-item p{font-size:15px;line-height:1.7;color:var(--muted);margin:0}
.svc-item .arrow{
  width:50px;height:50px;border:1px solid var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:all .35s var(--ease);
}
.svc-item:hover .arrow{background:var(--red);border-color:var(--red);color:#fff;transform:rotate(-45deg)}
html[dir="rtl"] .svc-item .arrow svg{transform:scaleX(-1)}
html[dir="rtl"] .svc-item:hover .arrow svg{transform:scaleX(-1)}

/* ═══════ STATS ═══════ */
.stats-section{padding:140px 0;background:var(--ink);color:#fff;position:relative;overflow:hidden}
.stats-section::before{
  content:"";position:absolute;top:-150px;inset-inline-end:-150px;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(201,64,48,.18),transparent 60%);
}
.stats-section .section-label{color:var(--red-light)}
.stats-section .section-label::before{background:var(--red-light)}
.stats-section .section-title{color:#fff}
.stats-section .section-title .thin{color:rgba(255,255,255,.5)}

.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:80px;position:relative;z-index:2}
.stat-cell{
  padding:0 32px;border-inline-start:1px solid rgba(255,255,255,.14);
  display:flex;flex-direction:column;gap:14px;
}
.stat-cell:first-child{border-inline-start:0;padding-inline-start:0}
.stat-cell .k{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:rgba(255,255,255,.55);
}
html[dir="rtl"] .stat-cell .k{font-family:"Zain","Cairo",sans-serif;letter-spacing:.14em;font-size:12px;text-transform:none}
.stat-cell .v{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(56px,7vw,108px);line-height:.95;letter-spacing:-.04em;color:#fff;
}
html[dir="rtl"] .stat-cell .v{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(48px,6vw,92px)}
.stat-cell .v .red{color:var(--red-light)}
.stat-cell .d{font-size:13.5px;line-height:1.6;color:rgba(255,255,255,.62)}

/* ═══════ CTA ═══════ */
.cta-section{
  padding:0;background:var(--bg);position:relative;
}
.cta-inner{
  display:grid;grid-template-columns:1.1fr 1fr;min-height:560px;
}
.cta-image{position:relative;overflow:hidden;background:var(--ink)}
.cta-image img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 14s var(--ease)}
.cta-section:hover .cta-image img{transform:scale(1.04)}
.cta-content{
  padding:90px 80px;display:flex;flex-direction:column;justify-content:center;
  background:var(--ink);color:#fff;
}
.cta-content .section-label{color:var(--red-light)}
.cta-content .section-label::before{background:var(--red-light)}
.cta-content h2{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(38px,4.6vw,68px);line-height:1.04;letter-spacing:-.035em;
  text-transform:uppercase;margin:0 0 28px;color:#fff;
}
html[dir="rtl"] .cta-content h2{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(34px,4.2vw,60px);line-height:1.15;text-transform:none}
.cta-content h2 .red{color:var(--red-light)}
.cta-content p{font-size:17px;line-height:1.8;color:rgba(255,255,255,.78);margin:0 0 32px;max-width:480px}
.cta-content .actions{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:36px}
.cta-info{display:flex;flex-direction:column;gap:18px;padding-top:30px;border-top:1px solid rgba(255,255,255,.14)}
.cta-info .row{display:flex;flex-direction:column;gap:4px}
.cta-info .k{font-size:11px;letter-spacing:.28em;text-transform:uppercase;font-weight:700;color:rgba(255,255,255,.5)}
html[dir="rtl"] .cta-info .k{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:12px;text-transform:none}
.cta-info .v{font-size:16px;font-weight:500;color:#fff}

/* ═══════ FOOTER ═══════ */
.footer{background:#0a0a0a;color:#fff;padding:90px 0 36px}
.footer-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:60px;margin-bottom:70px}
.footer-brand img{height:54px;filter:brightness(0) invert(1);margin-bottom:26px}
.footer-brand p{font-size:14.5px;line-height:1.8;color:rgba(255,255,255,.6);max-width:360px;margin:0 0 22px}
.footer-brand .social{display:flex;gap:12px;margin-top:18px}
.footer-brand .social a{
  width:38px;height:38px;border:1px solid rgba(255,255,255,.18);
  display:flex;align-items:center;justify-content:center;
  transition:all .25s;
}
.footer-brand .social a:hover{background:var(--red);border-color:var(--red);transform:translateY(-2px)}
.footer-col h5{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:rgba(255,255,255,.5);margin:0 0 22px;
}
html[dir="rtl"] .footer-col h5{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:13px;text-transform:none}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:12px}
.footer-col a{font-size:15px;color:rgba(255,255,255,.85);transition:color .25s}
.footer-col a:hover{color:var(--red-light)}
.footer-bottom{
  padding-top:30px;border-top:1px solid rgba(255,255,255,.12);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
}
.footer-bottom .tagline{
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--red);
}
html[dir="rtl"] .footer-bottom .tagline{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:13px;text-transform:none}
.footer-bottom .copy{font-size:12.5px;color:rgba(255,255,255,.45)}

/* ═══════ PAGE HERO (subpages) ═══════ */
.page-hero{
  padding:200px 0 110px;background:var(--bg-2);position:relative;
  border-bottom:1px solid var(--line);
}
.page-hero .crumb{
  display:inline-flex;align-items:center;gap:14px;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.34em;text-transform:uppercase;
  color:var(--red);margin-bottom:32px;
}
html[dir="rtl"] .page-hero .crumb{font-family:"Zain","Cairo",sans-serif;letter-spacing:.14em;font-size:13px;text-transform:none}
.page-hero .crumb::before{content:"";display:block;width:42px;height:1px;background:var(--red)}
.page-hero h1{
  font-family:"Faktum","Inter",sans-serif;font-weight:800;
  font-size:clamp(50px,7vw,116px);line-height:1.02;letter-spacing:-.04em;
  text-transform:uppercase;margin:0 0 28px;color:var(--ink);max-width:16ch;
}
html[dir="rtl"] .page-hero h1{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(44px,6vw,100px);line-height:1.1;letter-spacing:-.02em;text-transform:none}
.page-hero h1 .red{color:var(--red)}
.page-hero h1 .thin{font-weight:300;color:var(--muted)}
.page-hero .lede{font-size:18px;color:var(--ink-2);max-width:720px;margin:0;line-height:1.8}

/* ═══════ VM / TIMELINE / SERVICES DETAIL (subpages) ═══════ */
.vm-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:60px}
.vm-card{
  background:var(--bg);border:1px solid var(--line);padding:54px 44px;
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s;
}
.vm-card:hover{transform:translateY(-4px);border-color:var(--red);box-shadow:0 30px 60px -30px rgba(0,0,0,.12)}
.vm-card .icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(201,64,48,.10);color:var(--red);margin-bottom:28px}
.vm-card .icon svg{width:24px;height:24px}
.vm-card h3{font-family:"Faktum","Inter",sans-serif;font-weight:800;font-size:30px;margin:0 0 6px;color:var(--ink);text-transform:uppercase;letter-spacing:-.02em}
html[dir="rtl"] .vm-card h3{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:26px;text-transform:none}
.vm-card .en{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--red);margin-bottom:24px}
html[dir="rtl"] .vm-card .en{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:12px}
.vm-card p{font-size:16px;line-height:1.9;color:var(--ink-2);margin:0}

.timeline{display:grid;grid-template-columns:1fr;gap:0;border-inline-start:1px solid var(--line);margin-inline-start:14px;margin-top:60px}
.tl-item{padding-inline-start:48px;padding-bottom:50px;position:relative}
.tl-item::before{content:"";position:absolute;inset-inline-start:-7px;top:6px;width:13px;height:13px;background:var(--red);box-shadow:0 0 0 4px var(--bg)}
.tl-item .date{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--red);margin-bottom:12px;display:block}
html[dir="rtl"] .tl-item .date{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:12px;text-transform:none}
.tl-item h4{font-family:"Faktum","Inter",sans-serif;font-weight:800;font-size:24px;margin:0 0 10px;color:var(--ink);text-transform:uppercase;letter-spacing:-.015em}
html[dir="rtl"] .tl-item h4{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:22px;text-transform:none}
.tl-item p{margin:0;color:var(--ink-2);font-size:15.5px;line-height:1.85;max-width:680px}

.svc-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:60px}
.svc-card{background:var(--bg-2);border:1px solid var(--line);padding:48px 40px;transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.svc-card:hover{transform:translateY(-4px);border-color:var(--red);box-shadow:0 30px 60px -30px rgba(0,0,0,.1)}
.svc-card .num{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:13px;letter-spacing:.22em;color:var(--red);margin-bottom:18px}
.svc-card .icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(201,64,48,.10);color:var(--red);margin-bottom:28px}
.svc-card h3{font-family:"Faktum","Inter",sans-serif;font-weight:800;font-size:28px;margin:0 0 14px;line-height:1.1;color:var(--ink);text-transform:uppercase;letter-spacing:-.02em}
html[dir="rtl"] .svc-card h3{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:26px;text-transform:none}
.svc-card p{margin:0;color:var(--ink-2);line-height:1.85;font-size:15.5px}
.svc-card ul{margin:18px 0 0;padding:0;list-style:none}
.svc-card li{font-size:14.5px;color:var(--ink-2);padding:7px 0;display:flex;gap:12px;align-items:flex-start}
.svc-card li::before{content:"";width:6px;height:6px;background:var(--red);margin-top:9px;flex-shrink:0}

/* contact form */
.form-wrap{background:var(--bg-2);border:1px solid var(--line);padding:48px 40px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-bottom:22px}
.field{display:flex;flex-direction:column;gap:10px}
.field label{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted)}
html[dir="rtl"] .field label{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:12px;text-transform:none}
.field input,.field textarea,.field select{
  background:transparent;border:0;border-bottom:1px solid var(--line-strong);
  color:var(--ink);font:inherit;padding:12px 0 14px;outline:none;font-family:inherit;
  transition:border-color .25s;
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field textarea:focus,.field select:focus{border-bottom-color:var(--red)}
.field textarea{resize:vertical;min-height:120px}

/* ═══════ REVEAL — visible by default, JS opts in to animation ═══════ */
.reveal{opacity:1;transform:none;transition:opacity .9s var(--ease),transform .9s var(--ease)}
html.js-reveal .reveal{opacity:0;transform:translateY(28px)}
html.js-reveal .reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}

/* ═══════ RESPONSIVE ═══════ */
@media (max-width:1100px){
  :root{--gutter:32px}
  .about-grid,.projects-head,.services-head .top,.cta-inner,.projects-grid{grid-template-columns:1fr;gap:40px}
  .cta-content{padding:70px 50px}
  .cta-image{min-height:380px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:40px 0}
  .stat-cell:nth-child(3){border-inline-start:0;padding-inline-start:0}
  .vm-grid,.svc-detail-grid{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr 1fr;gap:40px}
}
@media (max-width:760px){
  :root{--gutter:22px}
  .menu .link,.menu .lang-switch,.menu .nav-cta{display:none}
  .burger{display:flex}
  body.menu-open .menu{display:flex !important;position:fixed;inset:90px 0 auto 0;flex-direction:column;background:rgba(255,255,255,.98);padding:32px;gap:22px;border-bottom:1px solid var(--line);align-items:flex-start}
  body.menu-open .menu .link,body.menu-open .menu .lang-switch,body.menu-open .menu .nav-cta{display:block}
  body.menu-open .menu .link{font-size:24px}
  .stats-grid{grid-template-columns:1fr 1fr;gap:40px 20px}
  .stat-cell .v{font-size:56px}
  .svc-item{grid-template-columns:auto 1fr auto;gap:16px;padding:28px 0}
  .svc-item p{grid-column:1 / -1}
  .svc-item h3{font-size:21px}
  .about-section,.projects-section,.services-section,.stats-section,.cta-inner{padding:90px 0}
  .cta-content{padding:60px 30px}
  .footer-top{grid-template-columns:1fr;gap:40px}
  .form-row{grid-template-columns:1fr}
  .page-hero{padding:160px 0 80px}
  .project-card,.project-card.tall{aspect-ratio:5/4}
  .project-card-content{padding:30px 26px}
  h1.hero-title{font-size:46px}
  .hero{min-height:600px}
}
@media (max-width:520px){
  .brand img{height:38px}
  .vm-card,.svc-card{padding:38px 28px}
  .form-wrap{padding:32px 24px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  html{scroll-behavior:auto}
}

/* ═══════ LEGACY SUBPAGE COMPAT ═══════ */
/* page-hero-bg image styling (subpage hero background) */
.page-hero{overflow:hidden}
.page-hero-bg{position:absolute;inset:0;z-index:0;opacity:.18}
.page-hero-bg img{width:100%;height:100%;object-fit:cover}
.page-hero-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 0%, var(--bg-2) 100%)}
.page-hero .wrap{position:relative;z-index:2}

/* vm-section, history-section (about page) */
.vm-section{padding:140px 0;background:var(--bg-2);border-block:1px solid var(--line)}
.history-section{padding:140px 0;background:var(--bg)}
.vm-section .section-title,.history-section .section-title{margin-top:0}

/* about-text signature */
.about-text .signature{margin-top:30px;padding-top:30px;border-top:1px solid var(--line);display:flex;align-items:center;gap:18px}
.about-text .signature img{height:30px;width:auto}
.about-text .signature span{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted)}
html[dir="rtl"] .about-text .signature span{font-family:"Zain","Cairo",sans-serif;letter-spacing:.12em;font-size:12px;text-transform:none}

/* Legacy .cta (subpage CTA section — full-width red block) */
.cta{padding:130px 0;background:var(--red);color:#fff;position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;top:50%;inset-inline-end:-150px;transform:translateY(-50%);width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(0,0,0,.18),transparent 60%);pointer-events:none}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:80px;align-items:end;position:relative;z-index:2}
.cta h2{font-family:"Faktum","Inter",sans-serif;font-weight:800;font-size:clamp(40px,5.4vw,80px);line-height:1.02;letter-spacing:-.035em;text-transform:uppercase;margin:0 0 28px;color:#fff}
html[dir="rtl"] .cta h2{font-family:"Zain","Cairo",sans-serif;font-weight:800;font-size:clamp(36px,4.6vw,68px);line-height:1.15;text-transform:none}
.cta h2 .thin{font-weight:300;color:rgba(255,255,255,.7)}
.cta p{font-size:17px;line-height:1.8;color:rgba(255,255,255,.92);max-width:540px;margin:0 0 32px}
.cta-actions{display:flex;gap:14px;flex-wrap:wrap}
.cta .btn-primary{background:#0a0a0a;color:#fff}
.cta .btn-primary:hover{background:#fff;color:var(--red)}
.cta .btn-outline{border-color:rgba(255,255,255,.55);color:#fff}
.cta .btn-outline:hover{background:#fff;color:var(--red);border-color:#fff}
.cta-info{display:flex;flex-direction:column;gap:22px;padding-top:30px;border-top:1px solid rgba(255,255,255,.3)}
.cta-info .row{display:flex;flex-direction:column;gap:6px}
.cta-info .k{font-family:"Faktum","Inter",sans-serif;font-weight:700;font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.65)}
html[dir="rtl"] .cta-info .k{font-family:"Zain","Cairo",sans-serif;letter-spacing:.14em;font-size:12px;text-transform:none}
.cta-info .v{font-size:17px;font-weight:500;color:#fff}
html[dir="rtl"] .cta-info .v{font-family:"Zain","Cairo",sans-serif}
.cta-info .v a:hover{color:rgba(255,255,255,.7)}

@media (max-width:1100px){
  .cta-grid{grid-template-columns:1fr;gap:40px}
  .vm-section,.history-section{padding:90px 0}
}

/* ═══════ FLOATING ACTIONS (WhatsApp + Back to top) ═══════ */
.fab-stack{
  position:fixed;bottom:24px;right:24px;left:auto;
  z-index:60;display:flex;flex-direction:column-reverse;gap:12px;
}
.fab{
  width:52px;height:52px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 24px rgba(0,0,0,.22);
  transition:transform .25s var(--ease),box-shadow .25s,background .25s;
  cursor:pointer;border:0;
}
.fab:hover{transform:translateY(-3px);box-shadow:0 14px 32px rgba(0,0,0,.28)}
.fab svg{width:24px;height:24px}
.fab-whatsapp{background:#25D366;color:#fff}
.fab-whatsapp:hover{background:#1ebe57}
.fab-top{
  background:var(--ink);color:#fff;
  opacity:0;pointer-events:none;transform:translateY(20px);
  transition:opacity .35s var(--ease),transform .35s var(--ease),background .25s;
}
.fab-top.show{opacity:1;pointer-events:auto;transform:translateY(0)}
.fab-top:hover{background:var(--red)}
.fab-top svg{transform:rotate(-90deg)}

/* tooltip on hover */
.fab[data-tip]{position:relative}
.fab[data-tip]::before{
  content:attr(data-tip);position:absolute;
  right:62px;top:50%;transform:translateY(-50%);
  background:var(--ink);color:#fff;
  font-family:"Faktum","Inter",sans-serif;font-weight:600;
  font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:8px 14px;white-space:nowrap;
  opacity:0;pointer-events:none;transition:opacity .25s var(--ease);
}
html[dir="rtl"] .fab[data-tip]::before{font-family:"Zain","Cairo",sans-serif;letter-spacing:.04em;text-transform:none;font-size:13px}
.fab:hover[data-tip]::before{opacity:1}

@media (max-width:520px){
  .fab-stack{bottom:18px;right:18px}
  .fab{width:48px;height:48px}
  .fab[data-tip]::before{display:none}
}

/* ═══════ CHIC IMAGE FRAME OVERLAY ═══════ */
/* applied to about-img, hero-img wrapper, page-hero-bg, gallery items, project images */
.about-img{padding:14px;position:relative;background:transparent}
.about-img::before{
  content:"";position:absolute;inset:0;
  border:1px solid var(--line-strong);
  pointer-events:none;z-index:3;
}
.about-img::after{
  content:"";position:absolute;
  top:0;inset-inline-start:0;
  width:80px;height:80px;
  border-top:2px solid var(--red);
  border-inline-start:2px solid var(--red);
  pointer-events:none;z-index:4;
}
.about-img .corner-br{
  position:absolute;bottom:0;inset-inline-end:0;
  width:80px;height:80px;
  border-bottom:2px solid var(--red);
  border-inline-end:2px solid var(--red);
  pointer-events:none;z-index:4;
}
.about-img img{position:relative;z-index:1}
.about-img .about-img-meta{z-index:2}

/* Hero — top corner accent overlay */
.hero::before{
  content:"";position:absolute;
  top:96px;inset-inline-start:32px;
  width:120px;height:120px;
  border-top:2px solid var(--red);
  border-inline-start:2px solid var(--red);
  z-index:3;pointer-events:none;opacity:.85;
}
.hero::after{
  content:"";position:absolute;
  bottom:32px;inset-inline-end:32px;
  width:120px;height:120px;
  border-bottom:2px solid var(--red);
  border-inline-end:2px solid var(--red);
  z-index:3;pointer-events:none;opacity:.85;
}

/* Page hero — soft frame */
.page-hero{position:relative}
.page-hero::before{
  content:"";position:absolute;
  top:110px;inset-inline-start:24px;
  width:90px;height:90px;
  border-top:2px solid var(--red);
  border-inline-start:2px solid var(--red);
  z-index:3;pointer-events:none;opacity:.7;
}

/* darken page-hero bg image consistently */
.page-hero-bg{opacity:.32}
.page-hero-bg img{filter:grayscale(.2) contrast(1.05)}

/* gallery items — corner red marks */
.gallery-item{position:relative}
.gallery-item::after{
  content:"";position:absolute;
  top:14px;inset-inline-start:14px;
  width:36px;height:36px;
  border-top:2px solid var(--red);
  border-inline-start:2px solid var(--red);
  z-index:3;pointer-events:none;
}

/* project-card already has overlay — add corner marker */
.project-card::before{
  content:"";position:absolute;
  top:16px;inset-inline-start:16px;
  width:46px;height:46px;
  border-top:2px solid var(--red-light);
  border-inline-start:2px solid var(--red-light);
  z-index:3;pointer-events:none;
}

@media (max-width:760px){
  .hero::before,.hero::after{display:none}
  .about-img::after,.about-img .corner-br{width:48px;height:48px}
}

/* ═══════ GALLERY SECTION (masonry) ═══════ */
.gallery-section{padding:140px 0;background:var(--bg-2);border-block:1px solid var(--line)}
.gallery-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:64px}
.gallery-head p{font-size:16px;line-height:1.85;color:var(--ink-2);max-width:480px;margin:0}

/* horizontal manual scroller — light, scrollable by drag/wheel/touch */
.gallery-scroll{
  position:relative;
  margin-inline:calc(var(--gutter) * -1);
  overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;-ms-overflow-style:none;
  scroll-snap-type:x mandatory;
  scroll-padding-inline:var(--gutter);
  padding:6px var(--gutter);
}
.gallery-scroll::-webkit-scrollbar{display:none}
.gallery-masonry{
  display:flex;gap:18px;
}
.g-item{
  position:relative;overflow:hidden;background:var(--ink);
  flex:0 0 340px;height:240px;
  scroll-snap-align:start;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.g-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 8s var(--ease),filter .5s;
}
.g-item:hover{transform:translateY(-3px);box-shadow:0 30px 60px -20px rgba(0,0,0,.35)}
.g-item:hover img{transform:scale(1.05)}
.g-item::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg, transparent 50%, rgba(0,0,0,.7) 100%);
  opacity:.55;transition:opacity .4s;
}
.g-item:hover::after{opacity:.85}
.g-item .g-lbl{
  position:absolute;left:18px;right:18px;bottom:16px;z-index:2;
  display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  font-family:"Faktum","Inter",sans-serif;font-weight:700;
  font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:#fff;
  transform:translateY(8px);opacity:.85;transition:transform .4s var(--ease),opacity .4s;
}
html[dir="rtl"] .g-item .g-lbl{font-family:"Zain","Cairo",sans-serif;letter-spacing:.1em;font-size:13px;text-transform:none;font-weight:600}
.g-item:hover .g-lbl{transform:translateY(0);opacity:1}
.g-item .g-lbl .nb{color:var(--red-light)}

/* red corner accent — overrides the simpler .gallery-item rule */
.g-item .corner{
  position:absolute;top:14px;inset-inline-start:14px;
  width:34px;height:34px;
  border-top:2px solid var(--red);
  border-inline-start:2px solid var(--red);
  z-index:3;pointer-events:none;
  transition:width .35s var(--ease),height .35s var(--ease),border-color .35s;
}
.g-item:hover .corner{width:44px;height:44px;border-color:var(--red-light)}

/* legacy modifiers no longer apply in flex row — kept harmless */
.g-item.tall, .g-item.wide, .g-item.big{ /* unused in scroller */ }

@media (max-width:1100px){
  .gallery-head{grid-template-columns:1fr;gap:30px}
  .g-item{flex:0 0 320px;height:230px}
}
@media (max-width:760px){
  /* On mobile: switch to vertical scrollable column with proper spacing */
  .gallery-scroll{
    overflow:visible;
    margin-inline:0;padding:0;
    scroll-snap-type:none;
    -webkit-mask-image:none;mask-image:none;
  }
  .gallery-masonry{
    display:grid;grid-template-columns:1fr;
    gap:18px;width:auto;
    animation:none;
  }
  .g-item{
    flex:0 1 auto;width:100%;height:auto;aspect-ratio:4/3;
  }
  .gallery-section{padding:80px 0}
}
