/* ═══════════════════════════════════════════════════════════
   مؤسسة الآفاق الواسعة للمقاولات — ملف الأنماط المشترك
   هذا الملف يُستخدم في كل صفحات الموقع. عدّله مرة واحدة فقط.
   ═══════════════════════════════════════════════════════════ */

:root {
  --obsidian:   #08090d;
  --carbon:     #0f1117;
  --charcoal:   #161922;
  --slate:      #1e2230;
  --slate-mid:  #252a38;
  --slate-light:#2e3447;
  --gold:       #b8902a;
  --gold-mid:   #d4a843;
  --gold-light: #e8c76a;
  --gold-pale:  #f5e4a8;
  --gold-dim:   rgba(184,144,42,0.18);
  --gold-line:  rgba(212,168,67,0.30);
  --tx-1: rgba(255,255,255,0.95);
  --tx-2: rgba(255,255,255,0.65);
  --tx-3: rgba(255,255,255,0.35);
  --br-1: rgba(255,255,255,0.09);
  --br-2: rgba(255,255,255,0.05);
  --br-gold: rgba(212,168,67,0.25);
  --sh-card: 0 4px 32px rgba(0,0,0,0.6), 0 1px 0 rgba(255,255,255,0.04) inset;
  --sh-glow: 0 0 40px rgba(184,144,42,0.15);
  --sh-deep: 0 24px 80px rgba(0,0,0,0.8);
  --radius:  16px;
  --radius-sm: 10px;
  --tr: 0.28s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Cairo', system-ui, sans-serif;
  background: var(--carbon);
  color: var(--tx-1);
  direction: rtl;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
}
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.03'/%3E%3C/svg%3E");
  opacity: 0.4;
}

/* ── SOCIAL TOP BAR ── */
.social-top-bar {
  background: var(--obsidian);
  border-bottom: 1px solid var(--br-1);
  padding: 7px 0;
  position: relative; z-index: 1001;
}
.social-top-inner {
  max-width: 1240px; margin: 0 auto; padding: 0 28px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
}
.social-top-links { display: flex; align-items: center; gap: 6px; }
.social-top-btn {
  display: flex; align-items: center; justify-content: center;
  width: 30px; height: 30px;
  background: var(--charcoal); border: 1px solid var(--br-1);
  border-radius: 7px; color: var(--tx-2);
  text-decoration: none; font-size: 13px;
  transition: var(--tr); cursor: pointer;
}
.social-top-btn:hover { background: var(--gold-dim); border-color: var(--br-gold); color: var(--gold-light); transform: translateY(-1px); }
.social-top-label { font-size: 11px; color: var(--tx-3); letter-spacing: 0.5px; font-weight: 600; }
.social-top-contact { display: flex; align-items: center; gap: 10px; }
.social-top-contact a {
  color: var(--tx-3); font-size: 11px; text-decoration: none;
  display: flex; align-items: center; gap: 5px;
  transition: var(--tr);
}
.social-top-contact a:hover { color: var(--gold-light); }

/* ── NAVBAR ── */
nav {
  background: rgba(8,9,13,0.92);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border-bottom: 1px solid var(--br-1);
  position: sticky; top:0; z-index:1000;
}
.nav-inner {
  max-width:1240px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 28px; height:68px;
}
.nav-logo { display:flex; align-items:center; gap:12px; cursor:pointer; text-decoration:none; }
.nav-logo img { height:44px; width:auto; object-fit:contain; }
.nav-logo-fallback {
  width:44px; height:44px;
  background: linear-gradient(135deg, var(--gold), var(--gold-light));
  border-radius:10px;
  display:flex; align-items:center; justify-content:center;
  font-size:20px; font-weight:900; color:var(--obsidian);
}
.nav-logo-text .name { font-size:14px; font-weight:700; color:var(--tx-1); line-height:1.2; }
.nav-logo-text .tagline { font-size:11px; color:var(--gold-mid); }
.nav-links { display:flex; gap:4px; list-style:none; }
.nav-links a {
  color:var(--tx-2); text-decoration:none;
  font-size:13px; font-weight:600;
  padding:7px 13px; border-radius:8px;
  transition:var(--tr); cursor:pointer; letter-spacing:0.3px;
}
.nav-links a:hover { color:var(--tx-1); background:var(--br-1); }
.nav-links a.active { color:var(--gold-light); background:var(--gold-dim); }
.nav-cta {
  background: linear-gradient(135deg, var(--gold), var(--gold-mid)) !important;
  color: var(--obsidian) !important;
  padding:8px 18px !important; border-radius:8px !important;
  font-weight:800 !important; font-size:13px !important;
  box-shadow: 0 2px 16px rgba(184,144,42,0.35) !important;
}
.nav-cta:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(184,144,42,0.5) !important; }

.nav-toggle {
  display: none;
  background: var(--charcoal); border: 1px solid var(--br-1);
  width: 38px; height: 38px; border-radius: 8px;
  color: var(--tx-1); cursor: pointer; font-size: 18px;
}

/* ── PAGE WRAPPER ── */
.page-wrap { position:relative; z-index:1; }

/* ── HERO ── */
.hero {
  min-height:92vh;
  background:
    radial-gradient(ellipse 80% 60% at 70% -10%, rgba(184,144,42,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 10% 80%, rgba(184,144,42,0.07) 0%, transparent 55%),
    linear-gradient(170deg, var(--obsidian) 0%, var(--carbon) 40%, #10131c 100%);
  display:flex; align-items:center;
  position:relative; overflow:hidden;
}
.hero::before {
  content:'';
  position:absolute; top:0; right:0;
  width:1px; height:100%;
  background: linear-gradient(180deg, transparent 0%, var(--gold-mid) 40%, var(--gold) 60%, transparent 100%);
  opacity:0.4;
}
.hero-bg-lines {
  position:absolute; inset:0; pointer-events:none; overflow:hidden;
  background-image: repeating-linear-gradient(-55deg, transparent, transparent 40px, rgba(255,255,255,0.012) 40px, rgba(255,255,255,0.012) 41px);
}
.hero-inner {
  max-width:1240px; margin:0 auto; padding:100px 28px 80px;
  display:grid; grid-template-columns:1.1fr 0.9fr;
  gap:70px; align-items:center; position:relative; z-index:1;
}
.hero-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  border:1px solid var(--gold-line);
  background: var(--gold-dim);
  color:var(--gold-light);
  padding:5px 14px; border-radius:30px;
  font-size:12px; font-weight:700; letter-spacing:0.8px;
  margin-bottom:22px; text-transform:uppercase;
  animation: fadeUp 0.5s ease both;
}
.hero-eyebrow::before {
  content:''; width:6px; height:6px; border-radius:50%;
  background:var(--gold-light); flex-shrink:0;
  box-shadow:0 0 6px var(--gold-light);
  animation: pulse-dot 2s infinite;
}
@keyframes pulse-dot { 0%,100%{opacity:1;} 50%{opacity:0.3;} }
.hero-title {
  font-family:'Playfair Display', 'Amiri', serif;
  font-size:clamp(30px,4.2vw,58px); font-weight:900;
  color:var(--tx-1); line-height:1.3; margin-bottom:22px;
  animation: fadeUp 0.6s 0.1s ease both;
}
.hero-title .gold-text {
  background: linear-gradient(135deg, var(--gold-light), var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.hero-desc {
  font-size:15px; color:var(--tx-2); line-height:2;
  margin-bottom:36px; max-width:520px;
  animation: fadeUp 0.6s 0.2s ease both;
}
.hero-btns { display:flex; gap:14px; flex-wrap:wrap; animation: fadeUp 0.6s 0.3s ease both; }

/* ── HERO CTA BANNER ── */
.hero-cta-banner {
  margin-top: 32px;
  position: relative; overflow: hidden;
  border-radius: var(--radius);
  background: linear-gradient(135deg, rgba(184,144,42,0.15), rgba(184,144,42,0.05));
  border: 1px solid var(--gold-line);
  padding: 0;
  cursor: pointer;
  transition: var(--tr);
  text-decoration: none;
  display: block;
  animation: fadeUp 0.6s 0.4s ease both;
}
.hero-cta-banner:hover { transform: translateY(-3px); box-shadow: var(--sh-glow); border-color: var(--gold-mid); }
.hero-cta-banner-inner {
  display: flex; align-items: center; gap: 0;
  overflow: hidden; border-radius: var(--radius);
}
.hero-cta-img {
  width: 140px; height: 90px; flex-shrink: 0;
  background: linear-gradient(135deg, #0d1a2e, #1a2f4a);
  display: flex; align-items: center; justify-content: center;
  position: relative; overflow: hidden;
}
.hero-cta-img::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(135deg, rgba(184,144,42,0.3), transparent);
}
.hero-cta-img-icon { font-size: 42px; position: relative; z-index: 1; }
.hero-cta-img::after {
  content: ''; position: absolute; inset: 0;
  background-image:
    repeating-linear-gradient(0deg, rgba(0,0,0,0.15) 0px, rgba(0,0,0,0.15) 1px, transparent 1px, transparent 4px),
    repeating-linear-gradient(90deg, rgba(0,0,0,0.15) 0px, rgba(0,0,0,0.15) 1px, transparent 1px, transparent 4px);
  z-index: 2;
}
.hero-cta-text { flex: 1; padding: 18px 20px; display: flex; flex-direction: column; gap: 4px; }
.hero-cta-text strong { font-size: 15px; font-weight: 900; color: var(--tx-1); line-height: 1.3; }
.hero-cta-text span { font-size: 12px; color: var(--gold-light); font-weight: 600; }
.hero-cta-arrow {
  width: 50px; height: 90px;
  background: linear-gradient(135deg, var(--gold), var(--gold-mid));
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; color: var(--obsidian); font-weight: 900;
  flex-shrink: 0;
}

/* ── BUTTONS ── */
.btn-primary {
  background: linear-gradient(135deg, var(--gold), var(--gold-mid));
  color:var(--obsidian); border:none;
  padding:14px 30px; border-radius:var(--radius-sm);
  font-family:'Cairo',sans-serif; font-size:14px; font-weight:800;
  cursor:pointer; transition:var(--tr);
  box-shadow:0 4px 24px rgba(184,144,42,0.4), 0 1px 0 rgba(255,255,255,0.15) inset;
  text-decoration:none; display:inline-block; letter-spacing:0.3px;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(184,144,42,0.55); }
.btn-outline {
  background:transparent; color:var(--tx-1);
  border:1px solid var(--br-1);
  padding:13px 28px; border-radius:var(--radius-sm);
  font-family:'Cairo',sans-serif; font-size:14px; font-weight:600;
  cursor:pointer; transition:var(--tr);
  text-decoration:none; display:inline-block;
}
.btn-outline:hover { border-color:var(--gold-line); color:var(--gold-light); transform:translateY(-2px); background:var(--gold-dim); }

/* ── HERO STATS ── */
.hero-visual { display:flex; flex-direction:column; gap:14px; animation: fadeLeft 0.7s 0.2s ease both; }
.hero-stats { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.stat-card {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:24px 20px; text-align:center;
  transition:var(--tr); position:relative; overflow:hidden;
}
.stat-card::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity:0; transition:var(--tr);
}
.stat-card:hover { border-color:var(--br-gold); transform:translateY(-3px); box-shadow:var(--sh-glow); }
.stat-card:hover::before { opacity:1; }
.stat-number {
  font-family:'Playfair Display',serif;
  font-size:38px; font-weight:900; line-height:1;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:12px; color:var(--tx-3); margin-top:7px; letter-spacing:0.5px; }
.hero-partner {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:18px 22px;
  display:flex; align-items:center; gap:16px; transition:var(--tr);
}
.hero-partner:hover { border-color:var(--br-gold); }
.hero-partner-label { font-size:11px; color:var(--tx-3); letter-spacing:0.5px; }
.hero-partner-name { font-size:16px; font-weight:800; color:var(--gold-light); margin-top:2px; }

/* ── SECTIONS ── */
.section { padding:90px 0; }
.section-inner { max-width:1240px; margin:0 auto; padding:0 28px; }
.section-header { margin-bottom:56px; }
.section-eyebrow {
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; letter-spacing:1.2px;
  text-transform:uppercase; color:var(--gold-mid); margin-bottom:14px;
}
.section-eyebrow::before { content:''; display:inline-block; width:28px; height:1px; background:var(--gold-mid); }
.section-title {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(26px,3.2vw,42px); font-weight:900;
  color:var(--tx-1); line-height:1.35; margin-bottom:14px;
}
.section-title .gold-text {
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.section-desc { font-size:15px; color:var(--tx-2); line-height:1.95; max-width:640px; }

/* ── SERVICES CARDS ── */
.services-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:20px; }
.service-card {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:34px 26px;
  transition:var(--tr); cursor:pointer; position:relative; overflow:hidden;
  text-decoration:none; display:block;
}
.service-card:hover { transform:translateY(-6px); border-color:var(--br-gold); box-shadow:var(--sh-glow); }
.service-icon {
  width:58px; height:58px; background:var(--slate); border:1px solid var(--br-1);
  border-radius:14px; display:flex; align-items:center; justify-content:center;
  font-size:26px; margin-bottom:20px;
}
.service-card h3 { font-size:17px; font-weight:700; color:var(--tx-1); margin-bottom:10px; }
.service-card p { font-size:13.5px; color:var(--tx-2); line-height:1.85; margin-bottom:22px; }
.btn-link {
  color:var(--gold-mid); font-size:13px; font-weight:700;
  cursor:pointer; display:inline-flex; align-items:center; gap:6px;
  text-decoration:none; transition:var(--tr);
}
.btn-link:hover { color:var(--gold-light); gap:10px; }

/* ── WHY US ── */
.why-section {
  background: radial-gradient(ellipse 70% 50% at 50% 50%, rgba(184,144,42,0.06) 0%, transparent 65%), var(--obsidian);
  border-top:1px solid var(--br-1); border-bottom:1px solid var(--br-1);
}
.why-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:50px; }
.why-card {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:30px 24px; transition:var(--tr);
}
.why-card:hover { transform:translateY(-4px); border-color:var(--br-gold); box-shadow:var(--sh-glow); }
.why-icon { font-size:30px; margin-bottom:16px; display:block; }
.why-card h4 { color:var(--gold-light); font-size:16px; font-weight:700; margin-bottom:8px; }
.why-card p { color:var(--tx-2); font-size:13.5px; line-height:1.85; }

/* ── PARTNERS (DYNAMIC FROM images.js) ── */
.partners-strip {
  background:var(--charcoal); border-top:1px solid var(--br-1); border-bottom:1px solid var(--br-1); padding:50px 0;
}
.partners-inner { max-width:1240px; margin:0 auto; padding:0 28px; }
.partners-label { text-align:center; font-size:11px; letter-spacing:1.5px; color:var(--tx-3); margin-bottom:32px; font-weight:700; text-transform:uppercase; }
.partners-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 24px;
  align-items: center;
  justify-items: center;
}
.partner-item {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: 18px 14px;
  background: var(--obsidian);
  border: 1px solid var(--br-1);
  border-radius: 12px;
  width: 100%; min-height: 130px;
  transition: var(--tr);
}
.partner-item:hover {
  border-color: var(--br-gold);
  transform: translateY(-3px);
  box-shadow: var(--sh-glow);
}
.partner-logo-img {
  max-width: 100%; max-height: 70px;
  width: auto; height: auto;
  object-fit: contain;
  filter: grayscale(0.2) brightness(1.05);
  transition: var(--tr);
}
.partner-item:hover .partner-logo-img { filter: grayscale(0) brightness(1.1); }
.partner-item-name {
  font-size: 12px; color: var(--tx-2); font-weight: 600; text-align: center;
}
.partners-empty {
  grid-column: 1 / -1;
  text-align: center; padding: 30px 20px;
  color: var(--tx-3); font-size: 13px; font-style: italic;
}

/* ── CTA STRIP ── */
.cta-strip {
  background: radial-gradient(ellipse 80% 80% at 50% 50%, rgba(184,144,42,0.14) 0%, transparent 65%), var(--obsidian);
  border-top:1px solid var(--br-gold); border-bottom:1px solid var(--br-gold);
  padding:70px 0; text-align:center;
}
.cta-strip h2 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(22px,3vw,38px); font-weight:900; color:var(--tx-1); margin-bottom:14px;
}
.cta-strip h2 span {
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.cta-strip p { color:var(--tx-2); font-size:15px; margin-bottom:32px; }
.btn-blue {
  background:linear-gradient(135deg,var(--gold),var(--gold-mid));
  color:var(--obsidian); border:none;
  padding:15px 36px; border-radius:var(--radius-sm);
  font-family:'Cairo',sans-serif; font-size:15px; font-weight:800;
  cursor:pointer; transition:var(--tr); text-decoration:none; display:inline-block;
  box-shadow:0 4px 24px rgba(184,144,42,0.4);
}
.btn-blue:hover { transform:translateY(-2px); box-shadow:0 8px 32px rgba(184,144,42,0.55); }

/* ── PAGE HEROES ── */
.services-page-hero, .about-hero {
  background:
    radial-gradient(ellipse 70% 60% at 50% -20%, rgba(184,144,42,0.14) 0%, transparent 55%),
    linear-gradient(170deg, var(--obsidian) 0%, var(--carbon) 100%);
  border-bottom:1px solid var(--br-1);
  padding:90px 0 70px; text-align:center; position:relative; overflow:hidden;
}
.services-page-hero::before, .about-hero::before {
  content:''; position:absolute; bottom:0; right:0; left:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.services-page-hero h1, .about-hero h1 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(28px,4vw,50px); font-weight:900; color:var(--tx-1); margin-bottom:16px;
}
.services-page-hero h1 .gold, .about-hero h1 .gold {
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.services-page-hero p, .about-hero p { color:var(--tx-2); font-size:15px; max-width:660px; margin:0 auto; line-height:2; }

/* ── SERVICE DETAIL GRID ── */
.services-detail-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; margin-top:50px; }
.service-detail-card {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); overflow:hidden; transition:var(--tr); cursor:pointer;
  text-decoration:none; display:block;
}
.service-detail-card:hover { transform:translateY(-5px); border-color:var(--br-gold); box-shadow:var(--sh-glow); }
.service-detail-img {
  height:190px; display:flex; align-items:center; justify-content:center;
  font-size:60px; position:relative; overflow:hidden;
}
.sdi-construction { background:linear-gradient(135deg,#080f1a,#0d1f3c); }
.sdi-renovation   { background:linear-gradient(135deg,#071409,#0d2e13); }
.sdi-interior     { background:linear-gradient(135deg,#130a12,#2a1025); }
.sdi-external     { background:linear-gradient(135deg,#130c03,#2e1e07); }
.service-detail-img::after {
  content:''; position:absolute; inset:0;
  background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,0.5));
}
.service-detail-body { padding:26px; }
.service-detail-body h3 { font-size:18px; font-weight:700; color:var(--tx-1); margin-bottom:10px; }
.service-detail-body p { font-size:13.5px; color:var(--tx-2); line-height:1.85; margin-bottom:20px; }

/* ── SUB HERO ── */
.sub-hero { padding:80px 0 60px; position:relative; overflow:hidden; border-bottom:1px solid var(--br-1); }
.sub-hero-construction { background:radial-gradient(ellipse 70% 60% at 50% -20%,rgba(42,82,152,0.25) 0%,transparent 65%),var(--obsidian); }
.sub-hero-renovation   { background:radial-gradient(ellipse 70% 60% at 50% -20%,rgba(45,106,79,0.25) 0%,transparent 65%),var(--obsidian); }
.sub-hero-interior     { background:radial-gradient(ellipse 70% 60% at 50% -20%,rgba(107,45,94,0.25) 0%,transparent 65%),var(--obsidian); }
.sub-hero-external     { background:radial-gradient(ellipse 70% 60% at 50% -20%,rgba(184,144,42,0.2)  0%,transparent 65%),var(--obsidian); }
.sub-hero::before {
  content:''; position:absolute; bottom:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
}
.sub-hero-inner { max-width:1240px; margin:0 auto; padding:0 28px; position:relative; z-index:1; }
.back-btn {
  display:inline-flex; align-items:center; gap:8px;
  color:var(--tx-3); font-size:13px; font-weight:600;
  cursor:pointer; margin-bottom:28px; transition:var(--tr);
  background:none; border:none; font-family:'Cairo',sans-serif;
  text-decoration:none;
}
.back-btn:hover { color:var(--gold-light); }
.sub-hero h1 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(26px,4vw,48px); font-weight:900; color:var(--tx-1); margin-bottom:16px; line-height:1.35;
}
.sub-hero p { color:var(--tx-2); font-size:15px; line-height:2; max-width:680px; }
.sub-hero .gold {
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

/* ── WORKS GALLERY (DYNAMIC FROM images.js) ── */
.works-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 18px;
  margin: 40px 0;
}
.work-card {
  background: var(--charcoal); border: 1px solid var(--br-1);
  border-radius: var(--radius); overflow: hidden;
  transition: var(--tr); cursor: pointer; position: relative;
}
.work-card:hover { transform: translateY(-4px); border-color: var(--br-gold); box-shadow: var(--sh-glow); }
.work-card-img {
  width: 100%; height: 220px; object-fit: cover; display: block;
  background: var(--slate);
}
.work-card-body { padding: 16px 18px; }
.work-card-title { font-size: 14px; font-weight: 700; color: var(--tx-1); margin-bottom: 4px; }
.work-card-cat { font-size: 11px; color: var(--gold-mid); font-weight: 600; letter-spacing: 0.4px; }
.works-empty {
  grid-column: 1 / -1; text-align: center;
  padding: 50px 20px;
  background: var(--charcoal); border: 1px dashed var(--br-1); border-radius: var(--radius);
  color: var(--tx-3); font-size: 13px; font-style: italic;
}
.works-empty strong { color: var(--gold-mid); display: block; margin-bottom: 6px; font-style: normal; font-size: 14px; font-weight: 700; }

/* ── LIGHTBOX ── */
.lightbox {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.92);
  display: none; align-items: center; justify-content: center;
  z-index: 9999; padding: 20px;
  backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px);
}
.lightbox.active { display: flex; }
.lightbox-content { max-width: 90vw; max-height: 90vh; position: relative; }
.lightbox-img {
  max-width: 90vw; max-height: 85vh;
  border-radius: 8px; display: block;
  box-shadow: 0 20px 80px rgba(0,0,0,0.8);
}
.lightbox-caption {
  text-align: center; color: var(--tx-1); font-weight: 700;
  margin-top: 14px; font-size: 14px;
}
.lightbox-close {
  position: absolute; top: 20px; left: 20px;
  width: 42px; height: 42px; border-radius: 50%;
  background: var(--charcoal); border: 1px solid var(--br-gold);
  color: var(--tx-1); font-size: 18px; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 10000;
}
.lightbox-close:hover { background: var(--gold-dim); }

/* ── FEATURE ITEMS ── */
.features-list { margin-top:50px; }
.feature-item {
  display:flex; gap:22px; padding:26px 28px;
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); margin-bottom:14px;
  transition:var(--tr); border-right:2px solid transparent;
}
.feature-item:hover { border-right-color:var(--gold); border-color:var(--br-gold); transform:translateX(-3px); }
.feature-icon-wrap {
  width:50px; height:50px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:22px; flex-shrink:0; background:var(--slate); border:1px solid var(--br-1);
}
.feature-text h4 { font-size:16px; font-weight:700; color:var(--tx-1); margin-bottom:6px; }
.feature-text p { font-size:13.5px; color:var(--tx-2); line-height:1.85; }

/* ── STRENGTH BOX ── */
.strength-section {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:44px; margin-top:50px;
}
.strength-section h2 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:26px; color:var(--tx-1); font-weight:900;
  margin-bottom:30px; padding-bottom:18px; border-bottom:1px solid var(--br-1);
}
.strength-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(200px,1fr)); gap:24px; }
.strength-item { display:flex; gap:14px; align-items:flex-start; }
.strength-bullet {
  width:30px; height:30px; flex-shrink:0; margin-top:2px;
  background:linear-gradient(135deg,var(--gold),var(--gold-mid));
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:13px; color:var(--obsidian); font-weight:900;
}
.strength-text h5 { font-size:14px; font-weight:700; color:var(--tx-1); margin-bottom:5px; }
.strength-text p { font-size:13px; color:var(--tx-2); line-height:1.75; }

/* ── PROFILE DOWNLOAD CARD ── */
.profile-card {
  margin-top: 40px;
  background: linear-gradient(135deg, var(--charcoal), var(--slate));
  border: 1px solid var(--br-gold);
  border-radius: var(--radius);
  padding: 28px;
  display: flex; align-items: center; gap: 22px;
  flex-wrap: wrap;
  text-decoration:none;
}
.profile-card-icon {
  width: 64px; height: 64px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--gold), var(--gold-mid));
  border-radius: 14px;
  display: flex; align-items: center; justify-content: center;
  font-size: 28px;
}
.profile-card-text { flex: 1; min-width: 200px; }
.profile-card-text strong { display: block; font-size: 16px; color: var(--tx-1); margin-bottom: 4px; }
.profile-card-text span { font-size: 13px; color: var(--tx-2); }

/* ── ABOUT ── */
.about-story { display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center; padding:80px 0; }
.about-story-visual {
  background: radial-gradient(ellipse 80% 80% at 50% 50%, rgba(184,144,42,0.08) 0%, transparent 65%), var(--charcoal);
  border:1px solid var(--br-gold); border-radius:20px; padding:48px;
  display:flex; flex-direction:column; gap:20px; align-items:center; justify-content:center; min-height:360px;
}
.about-big-icon { font-size:72px; }
.tagline-big {
  font-family:'Playfair Display','Amiri',serif; font-size:20px;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  font-weight:900; text-align:center;
}
.about-story-text h2 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(22px,3vw,34px); color:var(--tx-1); font-weight:900; margin-bottom:20px; line-height:1.4;
}
.about-story-text p { font-size:14.5px; color:var(--tx-2); line-height:2; margin-bottom:16px; }

/* ── MISSION BLOCK ── */
.mission-block {
  background:var(--charcoal); border:1px solid var(--br-gold);
  border-radius:var(--radius); padding:40px; margin-top:50px; text-align:center;
}
.mission-block .section-eyebrow { justify-content:center; }
.mission-block h3 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:22px; color:var(--tx-1); font-weight:900; margin-bottom:14px;
}
.mission-block p { font-size:15px; color:var(--tx-2); line-height:2; max-width:720px; margin:0 auto; }

/* ── VALUES ── */
.values-section { background:var(--obsidian); border-top:1px solid var(--br-1); border-bottom:1px solid var(--br-1); padding:80px 0; }
.values-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:18px; margin-top:50px; }
.value-card {
  background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:var(--radius); padding:32px 24px; text-align:center; transition:var(--tr);
}
.value-card:hover { transform:translateY(-5px); border-color:var(--br-gold); box-shadow:var(--sh-glow); }
.value-icon { font-size:36px; margin-bottom:16px; display:block; }
.value-card h4 { font-size:17px; font-weight:700; color:var(--tx-1); margin-bottom:10px; }
.value-card p { font-size:13.5px; color:var(--tx-2); line-height:1.85; }

/* ── MAP ── */
.map-section { padding:70px 0; background:var(--obsidian); border-top:1px solid var(--br-1); }
.map-box { border:1px solid var(--br-1); border-radius:var(--radius); overflow:hidden; height:380px; box-shadow:var(--sh-deep); }
.map-box iframe { width:100%; height:100%; border:none; }

/* ── CONTACT PAGE ── */
.contact-page {
  background:
    radial-gradient(ellipse 90% 70% at 80% 0%, rgba(184,144,42,0.10) 0%, transparent 50%),
    radial-gradient(ellipse 60% 50% at 10% 90%, rgba(184,144,42,0.06) 0%, transparent 55%),
    var(--obsidian);
  min-height:100vh;
}
.glass {
  background:rgba(22,25,34,0.85); border:1px solid var(--br-1);
  border-radius:18px; box-shadow:var(--sh-card);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
}
.contact-container { width:min(1100px,92vw); margin:0 auto; padding:32px 0 180px; }
.contact-header-bar {
  display:flex; align-items:center; justify-content:space-between;
  gap:18px; padding:16px 20px; flex-wrap:nowrap; margin-bottom:28px;
}
.contact-logo-block { display:flex; align-items:center; justify-content:flex-start; min-width:140px; flex:0 0 auto; }
.contact-logo-block img { width:min(200px,60vw); height:auto; object-fit:contain; }
.contact-logo-fallback {
  font-family:'Playfair Display','Amiri',serif; font-size:18px; font-weight:900;
  background:linear-gradient(135deg,var(--gold-light),var(--gold-pale));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.location-btn {
  display:inline-flex; flex-direction:column; gap:5px;
  padding:12px 16px; border-radius:14px;
  border:1px solid var(--br-1); background:rgba(22,25,34,0.6);
  transition:all .2s ease; max-width:540px;
  margin-inline-start:auto; line-height:1.6;
  text-decoration:none; color:var(--tx-1);
}
.location-btn:hover { background:rgba(184,144,42,0.07); border-color:var(--br-gold); }
.location-title { display:flex; align-items:center; gap:9px; font-weight:800; font-size:14px; }
.location-btn > span { color:var(--tx-3); font-size:12px; }
.contact-hero-section { width:min(860px,100%); padding:28px 24px; text-align:center; margin:0 auto; }
.contact-hero-section h1 {
  font-family:'Playfair Display','Amiri',serif;
  font-size:clamp(24px,3vw,36px); font-weight:900; color:var(--tx-1); margin-bottom:8px;
}
.contact-hero-section p { color:var(--tx-2); font-size:14px; font-weight:600; line-height:1.9; margin-bottom:26px; }
.contact-grid { display:grid; gap:14px; grid-template-columns:1fr; text-align:right; }
.c-card { padding:18px; border-radius:16px; }
.c-card-title { font-size:11px; color:var(--tx-3); margin:0 0 12px; font-weight:700; letter-spacing:0.8px; text-transform:uppercase; }
.social-grid { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
.btn-like {
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:12px; border-radius:12px;
  border:1px solid var(--br-1); background:rgba(255,255,255,.04);
  transition:all .2s ease; font-weight:700; color:var(--tx-1);
  text-decoration:none; cursor:pointer; font-size:14px;
}
.btn-like:hover { background:rgba(184,144,42,0.09); border-color:var(--br-gold); transform:translateY(-1px); }
.email-cta { justify-content:space-between; padding-inline:16px; }
.email-left { display:flex; align-items:center; gap:12px; }
.email-meta { display:flex; flex-direction:column; gap:2px; text-align:right; direction:rtl; }
.email-meta small { color:var(--tx-3); font-size:11px; font-weight:700; letter-spacing:0.5px; }
.email-meta strong { direction:ltr; text-align:left; font-weight:900; color:var(--tx-1); }
.email-right {
  display:flex; align-items:center; gap:8px; font-weight:800; font-size:12px; padding:9px 14px;
  border-radius:10px; border:1px solid var(--br-gold); background:var(--gold-dim); color:var(--gold-light);
  transition:all .2s ease; white-space:nowrap;
}
.cr-box {
  display:flex; align-items:center; justify-content:space-between; gap:10px;
  padding:16px; border-radius:12px; border:1px solid var(--br-1); background:rgba(255,255,255,.03);
}
.cr-left { display:flex; align-items:center; gap:12px; }
.cr-meta { display:flex; flex-direction:column; gap:2px; text-align:right; }
.cr-meta small { color:var(--tx-3); font-size:11px; font-weight:700; letter-spacing:0.5px; }
.cr-meta strong { font-weight:900; letter-spacing:.4px; color:var(--tx-1); }
.copy-btn {
  padding:9px 14px; border-radius:10px; border:1px solid var(--br-gold); background:var(--gold-dim);
  color:var(--gold-light); cursor:pointer; transition:all .2s ease;
  font-weight:800; font-size:12px; white-space:nowrap; font-family:'Cairo',sans-serif;
}
.copy-btn:hover { background:rgba(184,144,42,0.25); }

/* ── FIXED CONTACT BAR (CONTACT PAGE) ── */
.contact-bar-fixed {
  position:fixed; inset-inline:0; bottom:0;
  padding:14px 0 calc(14px + env(safe-area-inset-bottom));
  background:linear-gradient(180deg,rgba(8,9,13,0) 0%,rgba(8,9,13,.85) 30%,rgba(8,9,13,.97) 100%);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-top:1px solid var(--br-gold); z-index:500;
}
.contact-card-bar { width:min(1100px,92vw); margin:0 auto; padding:16px 18px; border-radius:18px; display:flex; flex-direction:column; gap:12px; }
.contact-copy { display:flex; flex-direction:column; gap:4px; text-align:right; line-height:1.8; }
.contact-copy strong { font-weight:900; color:var(--tx-1); }
.contact-copy span { color:var(--tx-2); font-size:13px; }
.contact-actions { display:flex; gap:10px; flex-wrap:wrap; }
.cta-btn {
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  padding:12px 18px; border-radius:999px; border:1px solid var(--br-1); background:rgba(255,255,255,.05);
  font-weight:800; transition:all .2s ease; min-width:150px; white-space:nowrap; flex:1 1 180px;
  text-decoration:none; color:var(--tx-1); font-family:'Cairo',sans-serif; font-size:14px;
}
.cta-btn:hover { background:rgba(255,255,255,.09); transform:translateY(-1px); }
.cta-btn.whatsapp { border-color:rgba(37,211,102,.35); background:rgba(37,211,102,.07); }
.cta-btn.whatsapp:hover { background:rgba(37,211,102,.14); }
.cta-btn.call { border-color:rgba(74,163,255,.35); background:rgba(74,163,255,.07); }

/* ── FOOTER ── */
footer { background:var(--obsidian); border-top:1px solid var(--br-1); color:var(--tx-2); padding:64px 0 0; position:relative; z-index:1; }
.footer-inner {
  max-width:1240px; margin:0 auto; padding:0 28px 52px;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:48px;
}
.footer-brand .logo { display:flex; align-items:center; gap:12px; margin-bottom:18px; }
.footer-brand .logo img { height:48px; width:auto; object-fit:contain; }
.footer-brand .logo-icon {
  width:46px; height:46px; background:linear-gradient(135deg,var(--gold),var(--gold-mid));
  border-radius:10px; display:flex; align-items:center; justify-content:center;
  font-size:20px; font-weight:900; color:var(--obsidian);
}
.footer-brand .brand-name { font-size:15px; font-weight:700; color:var(--tx-1); line-height:1.3; }
.footer-brand p { font-size:13.5px; line-height:1.95; margin-bottom:18px; }
.legal-info { background:var(--charcoal); border:1px solid var(--br-1); border-radius:10px; padding:14px 16px; }
.legal-row { display:flex; justify-content:space-between; font-size:12px; margin-bottom:6px; gap:8px; }
.legal-row:last-child { margin-bottom:0; }
.legal-label { color:var(--gold-mid); font-weight:700; flex-shrink:0; }
.legal-val { color:var(--tx-3); text-align:left; direction:ltr; }
.footer-col h4 {
  color:var(--tx-1); font-size:13px; font-weight:700; margin-bottom:18px; padding-bottom:10px;
  border-bottom:1px solid var(--br-1); letter-spacing:0.5px; text-transform:uppercase;
}
.footer-col ul { list-style:none; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul li a { color:var(--tx-2); text-decoration:none; font-size:13.5px; transition:var(--tr); cursor:pointer; }
.footer-col ul li a:hover { color:var(--gold-light); }
.footer-bottom {
  border-top:1px solid var(--br-1); padding:20px 28px;
  max-width:1240px; margin:0 auto;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px;
}
.footer-bottom p { font-size:12px; color:var(--tx-3); }
.social-links-footer { display:flex; gap:10px; }
.social-btn-footer {
  width:34px; height:34px; background:var(--charcoal); border:1px solid var(--br-1);
  border-radius:8px; display:flex; align-items:center; justify-content:center;
  font-size:14px; cursor:pointer; transition:var(--tr); text-decoration:none; color:var(--tx-2);
}
.social-btn-footer:hover { background:var(--gold-dim); border-color:var(--br-gold); color:var(--gold-light); transform:translateY(-2px); }

/* ── FLOAT BTN ── */
.float-btn { position:fixed; bottom:28px; left:24px; z-index:9998; }
.float-toggle {
  width:54px; height:54px; background:linear-gradient(135deg,#25d366,#128c7e);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:24px; cursor:pointer; box-shadow:0 4px 20px rgba(37,211,102,0.4);
  transition:var(--tr); border:none;
}
.float-toggle:hover { transform:scale(1.1); }
.float-menu {
  position:absolute; bottom:65px; left:0;
  display:flex; flex-direction:column; gap:9px;
  opacity:0; pointer-events:none; transform:translateY(10px); transition:var(--tr);
}
.float-btn.open .float-menu { opacity:1; pointer-events:all; transform:translateY(0); }
.float-item {
  display:flex; align-items:center; gap:10px;
  background:var(--charcoal); border:1px solid var(--br-gold);
  border-radius:28px; padding:9px 16px 9px 12px;
  box-shadow:0 4px 20px rgba(0,0,0,0.5);
  cursor:pointer; text-decoration:none; transition:var(--tr);
  white-space:nowrap; color:var(--tx-1); font-family:'Cairo',sans-serif;
}
.float-item:hover { transform:translateX(-4px); background:rgba(184,144,42,0.12); }
.fi-icon { font-size:18px; }
.fi-label { font-size:13px; font-weight:700; }

/* ── ANIMATIONS ── */
@keyframes fadeUp   { from{opacity:0;transform:translateY(22px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeLeft { from{opacity:0;transform:translateX(28px)} to{opacity:1;transform:translateX(0)} }

/* ── RESPONSIVE ── */
@media (max-width:1050px) {
  .contact-header-bar { flex-wrap:wrap; }
  .location-btn { margin-inline-start:0; width:100%; max-width:none; }
}
@media (max-width:900px) {
  .nav-links { display:none; flex-direction: column; position: absolute; top: 68px; right: 0; left: 0; background: var(--obsidian); border-bottom: 1px solid var(--br-1); padding: 12px 18px; gap: 4px; }
  .nav-links.mobile-open { display: flex; }
  .nav-toggle { display: flex; align-items: center; justify-content: center; }
  .hero-inner { grid-template-columns:1fr; gap:40px; padding:70px 20px 60px; }
  .services-detail-grid { grid-template-columns:1fr; }
  .about-story { grid-template-columns:1fr; gap:40px; }
  .footer-inner { grid-template-columns:1fr 1fr; }
  .services-grid { grid-template-columns:1fr; }
  .strength-grid { grid-template-columns:1fr; }
  .strength-section { padding:28px; }
  .section { padding:60px 0; }
  .section-inner { padding:0 20px; }
  .social-top-bar { display: none; }
  .partners-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width:480px) {
  .footer-inner { grid-template-columns:1fr; }
  .hero-stats { grid-template-columns:1fr 1fr; }
  .hero-cta-banner-inner { flex-direction: column; }
  .hero-cta-img { width:100%; height:120px; }
  .hero-cta-arrow { width:100%; height:46px; }
  .partners-grid { grid-template-columns: 1fr 1fr; gap: 12px; }
}
