/* ============================================================
   EMARAT CONTRACTING — Master Stylesheet
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=Inter:wght@300;400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Tajawal:wght@300;400;500;700;800;900&display=swap');

/* ---- Design Tokens ---- */
:root {
  --bg-primary:   #ffffff;
  --bg-secondary: #f5f6f6;
  --bg-card:      #ffffff;
  --bg-card-hover:#f0f1f3;

  --gold:         #E53E25;
  --gold-light:   #f05a3d;
  --gold-dark:    #c43318;
  --gold-subtle:  rgba(229,62,37,0.10);
  --gold-border:  rgba(229,62,37,0.25);

  --white:        #ffffff;
  --text:         #161929;
  --bg-dark:      #161929;
  --off-white:    #f5f6f6;
  --gray-200:     #e5e7eb;
  --gray-400:     #6b7280;
  --gray-500:     #4b5563;
  --gray-600:     #374151;

  --font-display: 'Playfair Display', Georgia, serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --max-w:        1280px;
  --sec-pad:      110px 0;
  --radius:       14px;

  --ease:         cubic-bezier(.4,0,.2,1);
  --t-fast:       0.22s var(--ease);
  --t-base:       0.42s var(--ease);
  --t-slow:       0.70s var(--ease);

  --shadow-card:  0 2px 16px rgba(0,0,0,.08);
  --shadow-hover: 0 8px 32px rgba(0,0,0,.14);
  --shadow-gold:  0 0 36px rgba(229,62,37,.18);
}

/* ---- Reset ---- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg-primary);color:var(--text);overflow-x:hidden;line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{text-decoration:none;color:inherit}
ul{list-style:none}
button{font-family:var(--font-body);cursor:pointer;border:none;background:none}

/* ============================================================
   PAGE LOADER
   ============================================================ */
.page-loader{
  position:fixed;inset:0;background:var(--bg-dark);
  z-index:9999;display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:2rem;
  transition:opacity .7s var(--ease),visibility .7s var(--ease);
}
.page-loader.loaded{opacity:0;visibility:hidden;pointer-events:none}

.loader-logo{
  height:60px;width:auto;
  filter:brightness(0) invert(1);
  animation:loaderPulse 1.6s ease-in-out infinite;
}
.loader-track{width:180px;height:2px;background:rgba(229,62,37,.12);border-radius:2px;overflow:hidden}
.loader-fill{height:100%;background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));animation:loaderFill 1.4s var(--ease) forwards}

@keyframes loaderPulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes loaderFill{0%{width:0}100%{width:100%}}

/* ============================================================
   TYPOGRAPHY
   ============================================================ */
h1,h2,h3,h4,h5,h6{font-family:var(--font-display);line-height:1.2;font-weight:700}

.eyebrow{
  font-family:var(--font-body);font-size:.75rem;font-weight:600;
  letter-spacing:.28em;text-transform:uppercase;color:var(--gold);
  display:inline-flex;align-items:center;gap:.8rem;margin-bottom:1rem;
}
.eyebrow::before{content:'';width:36px;height:1px;background:var(--gold)}
.eyebrow.center::before{display:none}
.eyebrow.center::after{content:'';width:36px;height:1px;background:var(--gold)}

.section-title{font-size:clamp(2rem,4vw,3.25rem);color:var(--text);margin-bottom:1.25rem;line-height:1.15}
.section-title .g{color:var(--gold)}
.section-sub{font-size:1.0625rem;color:var(--gray-400);line-height:1.8;max-width:620px}

/* ============================================================
   UTILITIES
   ============================================================ */
.container{max-width:var(--max-w);margin:0 auto;padding:0 2rem}
.text-center{text-align:center}
.text-center .section-sub{margin:0 auto}
.text-gold{color:var(--gold)}

/* Gold shimmer text */
.shimmer{
  background:linear-gradient(90deg,var(--gold),var(--gold-light),var(--gold),var(--gold-light));
  background-size:250% 100%;
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;animation:shimmer 5s linear infinite;
}
@keyframes shimmer{0%{background-position:-250% 0}100%{background-position:250% 0}}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.875rem 2rem;border-radius:5px;
  font-size:.875rem;font-weight:600;letter-spacing:.05em;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-base);
  position:relative;overflow:hidden;
}
.btn::after{
  content:'';position:absolute;top:50%;left:50%;
  width:0;height:0;background:rgba(255,255,255,.12);border-radius:50%;
  transform:translate(-50%,-50%);transition:width .6s,height .6s;
}
.btn:hover::after{width:350px;height:350px}

.btn-gold{
  background:linear-gradient(135deg,var(--gold-dark),var(--gold),var(--gold-light));
  background-size:200%;color:var(--bg-primary);
  box-shadow:0 4px 22px rgba(229,62,37,.30);
}
.btn-gold:hover{transform:translateY(-3px);box-shadow:0 10px 36px rgba(229,62,37,.45)}

.btn-outline{
  background:transparent;color:var(--gold);
  border:1.5px solid var(--gold);
}
.btn-outline:hover{background:var(--gold);color:var(--bg-primary);transform:translateY(-3px);box-shadow:0 10px 36px rgba(229,62,37,.30)}

.btn-ghost{
  display:inline-flex;align-items:center;gap:.5rem;
  color:var(--gold);font-size:.875rem;font-weight:600;
  transition:gap var(--t-fast),color var(--t-fast);
}
.btn-ghost:hover{gap:.875rem;color:var(--gold-light)}
.btn-ghost svg{transition:transform var(--t-fast)}
.btn-ghost:hover svg{transform:translateX(3px)}

/* ============================================================
   NAVIGATION
   ============================================================ */
.navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  padding:1.625rem 0;transition:padding var(--t-base),background var(--t-base),border-color var(--t-base),box-shadow var(--t-base);
}
.navbar.scrolled{
  padding:1rem 0;background:rgba(255,255,255,.97);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid var(--gold-border);
  box-shadow:0 4px 24px rgba(0,0,0,.08);
}
.navbar .container{display:flex;align-items:center;justify-content:space-between}

.nav-logo{display:flex;align-items:center;line-height:1}
.nav-logo img{height:42px;width:auto;filter:brightness(0) invert(1)}
.navbar.scrolled .nav-logo img{filter:brightness(0)}
.nav-logo-main{font-family:var(--font-display);font-size:1.3rem;font-weight:800;letter-spacing:.06em;color:var(--white)}
.nav-logo-sub{font-size:.55rem;font-weight:600;letter-spacing:.35em;text-transform:uppercase;color:var(--gold)}

.nav-menu{display:flex;align-items:center;gap:2.5rem}
.nav-link{
  font-size:.85rem;font-weight:500;color:rgba(255,255,255,.75);
  letter-spacing:.04em;position:relative;transition:color var(--t-fast);
}
.nav-link::after{
  content:'';position:absolute;bottom:-5px;left:0;width:0;height:1px;
  background:var(--gold);transition:width var(--t-base);
}
.nav-link:hover,.nav-link.active{color:#fff}
.navbar.scrolled .nav-link{color:rgba(22,25,41,.60)}
.navbar.scrolled .nav-link:hover,.navbar.scrolled .nav-link.active{color:var(--text)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-cta{padding:.6rem 1.4rem;font-size:.8rem}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:24px;height:2px;background:var(--white);border-radius:2px;transition:var(--t-base)}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0;transform:translateX(-8px)}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile overlay */
.mobile-overlay{
  display:none;position:fixed;inset:0;z-index:999;
  background:rgba(255,255,255,.98);backdrop-filter:blur(20px);
  flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;
  opacity:0;visibility:hidden;transition:opacity var(--t-base),visibility var(--t-base);
}
.mobile-overlay.open{opacity:1;visibility:visible}
.mobile-overlay a{
  font-family:var(--font-display);font-size:2.25rem;font-weight:800;
  color:var(--text);transition:color var(--t-fast);
}
.mobile-overlay a:hover{color:var(--gold)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100vh;display:flex;
  align-items:center;overflow:hidden;background:var(--bg-dark);
}

/* Canvas background */
.hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;
  opacity:1;pointer-events:none;
}

/* Radial glow */
.hero-glow{
  position:absolute;top:30%;right:15%;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle,rgba(229,62,37,.07) 0%,transparent 70%);
  pointer-events:none;animation:glowPulse 6s ease-in-out infinite;
}
@keyframes glowPulse{0%,100%{transform:scale(1);opacity:.7}50%{transform:scale(1.15);opacity:1}}

/* Rotating shapes */
.hero-shapes{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.h-shape{position:absolute;border:1px solid rgba(229,62,37,.08)}
.h-shape-1{width:320px;height:320px;top:12%;right:8%;animation:rotate 25s linear infinite}
.h-shape-2{width:160px;height:160px;bottom:18%;right:22%;animation:rotate 18s linear infinite reverse}
.h-shape-3{width:80px;height:80px;top:55%;right:40%;animation:rotate 12s linear infinite;border-color:rgba(229,62,37,.14)}
@keyframes rotate{from{transform:rotate(0)}to{transform:rotate(360deg)}}

.hero .container{position:relative;z-index:2}
.hero-content{max-width:820px}

/* Badge pill */
.hero-pill{
  display:inline-flex;align-items:center;gap:.75rem;
  background:var(--gold-subtle);border:1px solid var(--gold-border);
  border-radius:100px;padding:.45rem 1.25rem;margin-bottom:2.25rem;
  animation:fadeDown .8s var(--ease) forwards;
}
.hero-pill-dot{
  width:7px;height:7px;border-radius:50%;background:var(--gold);
  animation:dotBlink 2s ease-in-out infinite;
}
@keyframes dotBlink{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.6);opacity:.5}}
.hero-pill span{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}

/* Hero title */
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(3.5rem,8.5vw,8rem);
  font-weight:900;line-height:.98;letter-spacing:-.025em;
  margin-bottom:1.75rem;color:var(--white);
}
.hero-title .line{display:block;overflow:hidden}
.hero-title .line-inner{
  display:block;
  transform:translateY(115%);
  animation:lineUp 1s cubic-bezier(.76,0,.24,1) forwards;
  animation-delay:var(--d,0.2s);
}
.hero-title .gline{
  color:var(--gold);display:inline-block;position:relative;
}
.hero-title .gline::after{
  content:'';position:absolute;bottom:4px;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));
  transform:scaleX(0);transform-origin:left;
  animation:lineScale 1s var(--ease) forwards 1.3s;
}
@keyframes lineUp{to{transform:translateY(0)}}
@keyframes lineScale{to{transform:scaleX(1)}}

.hero-tagline{
  font-size:1.1875rem;color:var(--gray-400);
  max-width:500px;line-height:1.85;margin-bottom:3rem;
  opacity:0;animation:fadeUp .8s var(--ease) forwards .85s;
}
.hero-actions{
  display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s var(--ease) forwards 1.05s;
}

/* Scroll indicator */
.hero-scroll{
  position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
  opacity:0;animation:fadeIn 1s var(--ease) forwards 1.6s;
}
.hero-scroll-label{font-size:.65rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gray-500)}
.hero-scroll-bar{
  width:1px;height:52px;
  background:linear-gradient(to bottom,var(--gold),transparent);
  animation:scrollAnim 2.2s ease-in-out infinite;
}
@keyframes scrollAnim{
  0%{transform:scaleY(0);transform-origin:top;opacity:1}
  50%{transform:scaleY(1);transform-origin:top;opacity:1}
  100%{transform:scaleY(1);transform-origin:bottom;opacity:0}
}

/* ============================================================
   STATS BAND
   ============================================================ */
.stats-band{
  background:var(--bg-secondary);
  border-top:1px solid var(--gold-border);
  border-bottom:1px solid var(--gold-border);
  padding:72px 0;position:relative;overflow:hidden;
}
.stats-band::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 120% at 50% 50%,rgba(229,62,37,.04) 0%,transparent 70%);
}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);position:relative}
.stat-item{padding:2rem 2.5rem;text-align:center;position:relative}
.stat-item:not(:last-child)::after{
  content:'';position:absolute;right:0;top:15%;height:70%;
  width:1px;background:var(--gold-border);
}
.stat-number{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,4.5vw,4rem);
  font-weight:900;color:var(--gold);line-height:1;
  margin-bottom:.4rem;display:block;
}
.stat-label{font-size:.875rem;font-weight:600;color:var(--text);margin-bottom:.25rem}
.stat-desc{font-size:.75rem;color:var(--gray-500)}

/* ============================================================
   ABOUT
   ============================================================ */
.about-section{padding:var(--sec-pad);overflow:hidden}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}

.about-visual{position:relative}
.about-frame{
  aspect-ratio:4/5;background:var(--bg-card);
  border-radius:20px;overflow:hidden;
  border:1px solid rgba(0,0,0,.07);
  position:relative;
}
/* Blueprint pattern inside frame */
.about-frame::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(229,62,37,.06) 1px,transparent 1px),
    linear-gradient(90deg,rgba(229,62,37,.06) 1px,transparent 1px);
  background-size:48px 48px;
}
.about-frame::after{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 60% 40%,rgba(229,62,37,.07) 0%,transparent 60%);
}
/* Real project image inside frame */
.about-frame-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;object-position:center;
  transition:transform var(--t-slow);
}
.about-frame:hover .about-frame-img{transform:scale(1.04)}
/* Floating badge */
.about-badge{
  position:absolute;bottom:-1.5rem;right:-1.5rem;
  background:var(--gold);color:var(--bg-primary);
  padding:1.5rem 2rem;border-radius:14px;
  box-shadow:var(--shadow-gold);z-index:2;
}
.about-badge-num{font-family:var(--font-display);font-size:2.75rem;font-weight:900;line-height:1}
.about-badge-lbl{font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;opacity:.8;margin-top:.25rem}
/* Accent line left */
.about-accent-line{
  position:absolute;left:-2.5rem;top:10%;bottom:10%;
  width:2px;background:linear-gradient(to bottom,transparent,var(--gold),transparent);
}

.about-content{display:flex;flex-direction:column;gap:2rem}
.about-text{font-size:1.0625rem;color:var(--gray-400);line-height:1.85}

.values-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.value-card{
  padding:1.375rem;background:var(--bg-card);
  box-shadow:0 2px 12px rgba(0,0,0,.05);
  border-radius:var(--radius);border:1px solid var(--gold-border);
  display:flex;gap:.875rem;align-items:flex-start;
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.value-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);border-color:var(--gold)}
.value-icon{
  width:38px;height:38px;border-radius:9px;
  background:var(--gold-subtle);display:flex;align-items:center;justify-content:center;
  color:var(--gold);flex-shrink:0;font-size:1rem;
}
.value-name{font-size:.875rem;font-weight:700;color:var(--text);margin-bottom:.2rem}
.value-desc{font-size:.75rem;color:var(--gray-500);line-height:1.5}

/* ============================================================
   SERVICES
   ============================================================ */
.services-section{padding:var(--sec-pad);background:var(--bg-secondary);position:relative}
.services-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 70% 50% at 50% 0%,rgba(229,62,37,.03) 0%,transparent 60%);
}
.services-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:4rem}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

.svc-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:18px;padding:2.5rem;
  border:1px solid rgba(0,0,0,.07);
  position:relative;overflow:hidden;
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
}
.svc-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform var(--t-base);
}
.svc-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);border-color:var(--gold-border)}
.svc-card:hover::before{transform:scaleX(1)}

.svc-bg-num{
  position:absolute;bottom:-1.5rem;right:1rem;
  font-family:var(--font-display);font-size:7rem;font-weight:900;
  color:rgba(229,62,37,.04);line-height:1;user-select:none;
  transition:color var(--t-base);
}
.svc-card:hover .svc-bg-num{color:rgba(229,62,37,.08)}

.svc-icon{
  width:52px;height:52px;border-radius:12px;
  background:var(--gold-subtle);display:flex;align-items:center;justify-content:center;
  color:var(--gold);margin-bottom:1.5rem;font-size:1.4rem;
  transition:background var(--t-fast),color var(--t-fast);
}
.svc-card:hover .svc-icon{background:var(--gold);color:var(--bg-primary)}
.svc-title{font-size:1.2rem;font-weight:700;color:var(--text);margin-bottom:.875rem}
.svc-desc{font-size:.9rem;color:var(--gray-400);line-height:1.75}

/* ============================================================
   ADVANTAGE
   ============================================================ */
.advantage-section{padding:var(--sec-pad);overflow:hidden}
.advantage-intro{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:end;margin-bottom:4rem}

.advantage-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border:1px solid var(--gold-border);border-radius:18px;overflow:hidden;
}
.adv-item{
  padding:2.5rem;background:#fafafa;
  border-right:1px solid var(--gold-border);
  border-bottom:1px solid var(--gold-border);
  transition:background var(--t-fast);position:relative;overflow:hidden;
}
.adv-item:nth-child(3n){border-right:none}
.adv-item:nth-child(n+4){border-bottom:none}
.adv-item:hover{background:#f0f1f3}

.adv-num{
  font-family:var(--font-display);font-size:2.75rem;font-weight:900;
  color:rgba(229,62,37,.18);line-height:1;margin-bottom:1rem;
}
.adv-title{font-size:1.0625rem;font-weight:700;color:var(--text);margin-bottom:.625rem}
.adv-desc{font-size:.85rem;color:var(--gray-500);line-height:1.7}

/* ============================================================
   PROJECTS PREVIEW
   ============================================================ */
.projects-section{padding:var(--sec-pad);background:var(--bg-secondary);position:relative}
.projects-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 50% at 50% 100%,rgba(229,62,37,.03) 0%,transparent 70%);
}
.projects-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem}
.projects-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* PROJECT CARD */
.proj-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:18px;overflow:hidden;
  border:1px solid rgba(0,0,0,.07);
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
  display:flex;flex-direction:column;
}
.proj-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);border-color:var(--gold-border)}

.proj-visual{aspect-ratio:16/10;position:relative;overflow:hidden;flex-shrink:0;background:#161929}
.proj-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;transition:transform var(--t-slow);
}
.proj-card:hover .proj-img{transform:scale(1.06)}
.proj-visual-bg{
  position:absolute;inset:0;
  transition:transform var(--t-slow);
}
.proj-card:hover .proj-visual-bg{transform:scale(1.06)}
/* unique gradient per project */
.alpin       .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.kitchen-off .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.snc         .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.kingdom     .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.wiyyana     .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.kitchen-fac .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.noon        .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}
.amazon      .proj-visual-bg{background:linear-gradient(135deg,#080808 0%,#141414 60%,#080808 100%)}

/* blueprint grid overlay */
.proj-visual-grid{
  position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(229,62,37,.15) 1px,transparent 1px),
    linear-gradient(90deg,rgba(229,62,37,.15) 1px,transparent 1px);
  background-size:36px 36px;
  opacity:.5;
}
.proj-visual-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top,rgba(7,12,24,.95) 0%,rgba(7,12,24,.2) 70%,transparent 100%);
}
/* category badge on top */
.proj-cat{
  position:absolute;top:1.25rem;left:1.25rem;
  font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;
  color:var(--gold);background:rgba(255,255,255,.92);
  border:1px solid var(--gold-border);border-radius:4px;
  padding:.3rem .7rem;backdrop-filter:blur(8px);
}
/* value tag bottom */
.proj-val{
  position:absolute;bottom:1.25rem;right:1.25rem;
  font-size:.75rem;font-weight:700;color:var(--white);
  background:rgba(229,62,37,.2);border:1px solid var(--gold-border);
  border-radius:4px;padding:.3rem .7rem;backdrop-filter:blur(8px);
}

.proj-body{padding:1.75rem;flex:1;display:flex;flex-direction:column}
.proj-meta{display:flex;align-items:center;gap:.5rem;margin-bottom:.625rem}
.proj-location{
  font-size:.72rem;font-weight:600;color:var(--gold);
  display:flex;align-items:center;gap:.3rem;
}
.proj-dot{width:3px;height:3px;border-radius:50%;background:var(--gray-600)}
.proj-area{font-size:.72rem;color:var(--gray-500)}
.proj-title{
  font-family:var(--font-display);font-size:1.1875rem;
  font-weight:700;color:var(--text);line-height:1.3;margin-bottom:auto;
}
.proj-footer{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:1.25rem;margin-top:1.25rem;
  border-top:1px solid rgba(0,0,0,.07);
}
.proj-stat-label{font-size:.65rem;color:var(--gray-500);text-transform:uppercase;letter-spacing:.06em}
.proj-stat-val{font-size:.85rem;font-weight:600;color:var(--text)}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials-section{padding:var(--sec-pad);overflow:hidden}
.testimonials-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(ellipse 50% 60% at 50% 50%,rgba(229,62,37,.04) 0%,transparent 70%);
}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}

.testi-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:18px;padding:2.5rem;
  border:1px solid rgba(0,0,0,.07);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
  position:relative;
}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:var(--gold-border)}
.testi-quote{
  font-family:var(--font-display);font-size:5rem;color:var(--gold);
  opacity:.15;line-height:1;margin-bottom:-.75rem;
}
.testi-text{font-size:.9375rem;color:var(--gray-400);line-height:1.85;margin-bottom:2rem;font-style:italic}
.testi-author{display:flex;align-items:center;gap:1rem}
.testi-avatar{
  width:48px;height:48px;border-radius:50%;
  background:var(--gold-subtle);border:2px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.1rem;font-weight:700;color:var(--gold);
  flex-shrink:0;
}
.testi-name{font-size:.9375rem;font-weight:700;color:var(--text)}
.testi-role{font-size:.75rem;color:var(--gray-500);margin-top:.2rem}

/* ============================================================
   HSE SECTION
   ============================================================ */
.hse-section{padding:var(--sec-pad);background:var(--bg-secondary);position:relative;overflow:hidden}
.hse-section::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 80% 50%,rgba(229,62,37,.04) 0%,transparent 60%);
}
.hse-grid{display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}

.hse-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin:2rem 0}
.hse-stat{
  background:var(--bg-card);border-radius:var(--radius);padding:1.75rem;
  border:1px solid var(--gold-border);text-align:center;
}
.hse-stat-val{
  font-family:var(--font-display);font-size:2rem;
  font-weight:900;color:var(--gold);line-height:1;margin-bottom:.4rem;
}
.hse-stat-lbl{font-size:.75rem;font-weight:600;color:var(--gray-400);letter-spacing:.06em}

.proc-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;margin-top:1.5rem}
.proc-item{
  display:flex;align-items:center;gap:.625rem;
  font-size:.85rem;color:var(--gray-400);
}
.proc-item::before{
  content:'';width:7px;height:7px;border-radius:50%;
  background:var(--gold);flex-shrink:0;
}

/* HSE visual — shield */
.hse-visual{position:relative}
.hse-frame{
  background:var(--bg-card);border-radius:20px;
  aspect-ratio:4/3;border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;position:relative;
}
.hse-frame::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(229,62,37,.05) 1px,transparent 1px),
    linear-gradient(90deg,rgba(229,62,37,.05) 1px,transparent 1px);
  background-size:40px 40px;
}
.shield-wrap{position:relative;z-index:1;text-align:center}
.shield-hex{
  width:140px;height:160px;margin:0 auto 1rem;
  background:var(--gold-subtle);border:2px solid var(--gold);
  clip-path:polygon(50% 0%,100% 25%,100% 75%,50% 100%,0% 75%,0% 25%);
  display:flex;align-items:center;justify-content:center;flex-direction:column;
  animation:shieldPulse 3.5s ease-in-out infinite;
}
@keyframes shieldPulse{0%,100%{transform:scale(1)}50%{transform:scale(1.06)}}
.shield-num{font-family:var(--font-display);font-size:3rem;font-weight:900;color:var(--gold);line-height:1}
.shield-sub{font-size:.5rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);opacity:.8}
.shield-label{font-size:.8rem;font-weight:600;color:var(--gray-400);letter-spacing:.08em}

/* ============================================================
   TEAM
   ============================================================ */
.team-section{padding:var(--sec-pad)}

.founders-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:3.5rem 0}
.founder-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:18px;padding:2.5rem;
  border:1px solid var(--gold-border);display:flex;gap:2rem;align-items:flex-start;
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.founder-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:var(--gold)}
.founder-ava{
  width:80px;height:80px;border-radius:16px;
  background:var(--gold-subtle);border:2px solid var(--gold);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.6rem;font-weight:700;color:var(--gold);
  flex-shrink:0;
}
.founder-badge{
  display:inline-block;font-size:.65rem;font-weight:700;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);background:var(--gold-subtle);
  border:1px solid var(--gold-border);border-radius:4px;padding:.2rem .55rem;margin-bottom:.5rem;
}
.founder-name{font-family:var(--font-display);font-size:1.375rem;font-weight:800;color:var(--text);margin-bottom:.2rem}
.founder-title{font-size:.8rem;color:var(--gray-500);margin-bottom:.875rem}
.founder-desc{font-size:.875rem;color:var(--gray-400);line-height:1.75;margin-bottom:1rem}
.creds{display:flex;gap:.4rem;flex-wrap:wrap}
.cred{
  font-size:.68rem;font-weight:700;letter-spacing:.04em;
  padding:.2rem .55rem;border-radius:4px;
  background:rgba(0,0,0,.04);color:var(--gray-500);
  border:1px solid rgba(0,0,0,.08);
}

.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem}
.team-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:14px;padding:1.875rem;
  text-align:center;border:1px solid rgba(0,0,0,.07);
  transition:transform var(--t-fast),box-shadow var(--t-fast),border-color var(--t-fast);
}
.team-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-card);border-color:var(--gold-border)}
.team-ava{
  width:62px;height:62px;border-radius:50%;
  background:var(--gold-subtle);border:2px solid var(--gold-border);
  margin:0 auto 1.25rem;display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:1.2rem;font-weight:700;color:var(--gold);
}
.team-name{font-size:1rem;font-weight:700;color:var(--text);margin-bottom:.25rem}
.team-role{font-size:.75rem;font-weight:600;color:var(--gold);margin-bottom:.625rem}
.team-desc{font-size:.78rem;color:var(--gray-500);line-height:1.6;margin-bottom:.875rem}

/* ============================================================
   SECTORS
   ============================================================ */
.sectors-section{padding:var(--sec-pad);background:var(--bg-secondary)}
.sectors-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:4rem}
.sector-card{
  background:var(--bg-card);
  box-shadow:0 1px 12px rgba(0,0,0,.06);border-radius:18px;padding:2.5rem;
  border:1px solid rgba(0,0,0,.07);
  position:relative;overflow:hidden;
  transition:transform var(--t-base),box-shadow var(--t-base),border-color var(--t-base);
}
.sector-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--gold-dark),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform var(--t-base);
}
.sector-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-hover);border-color:var(--gold-border)}
.sector-card:hover::after{transform:scaleX(1)}
.sector-bg-num{
  position:absolute;top:.5rem;right:1.25rem;
  font-family:var(--font-display);font-size:5rem;font-weight:900;
  color:rgba(229,62,37,.05);line-height:1;user-select:none;
}
.sector-icon{
  width:56px;height:56px;border-radius:14px;font-size:1.6rem;
  background:var(--gold-subtle);display:flex;align-items:center;justify-content:center;
  color:var(--gold);margin-bottom:1.5rem;
  transition:background var(--t-fast),color var(--t-fast);
}
.sector-card:hover .sector-icon{background:var(--gold);color:var(--bg-primary)}
.sector-title{font-family:var(--font-display);font-size:1.1875rem;font-weight:700;color:var(--text);margin-bottom:.625rem}
.sector-desc{font-size:.875rem;color:var(--gray-500);line-height:1.75}

/* ============================================================
   CTA SECTION
   ============================================================ */
.cta-section{padding:130px 0;position:relative;overflow:hidden;background:var(--bg-dark)}
.cta-bg{
  position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 50% 50%,rgba(229,62,37,.18) 0%,transparent 65%);
}
.cta-lines{position:absolute;inset:0;pointer-events:none}
.cta-vl{position:absolute;width:1px;height:100%;background:rgba(229,62,37,.05)}
.cta-vl:nth-child(1){left:25%}
.cta-vl:nth-child(2){right:25%}

.cta-content{position:relative;z-index:1;text-align:center}
.cta-title{
  font-family:var(--font-display);
  font-size:clamp(2.5rem,5.5vw,5rem);
  font-weight:900;color:var(--white);line-height:1.1;margin-bottom:1.5rem;
}
.cta-sub{font-size:1.125rem;color:var(--gray-400);max-width:540px;margin:0 auto 3rem;line-height:1.8}
.cta-btns{display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}

.cta-contacts{
  display:flex;align-items:center;justify-content:center;gap:4rem;
  margin-top:3.5rem;padding-top:3rem;border-top:1px solid var(--gold-border);flex-wrap:wrap;
}
.ctc-item{display:flex;flex-direction:column;align-items:center;gap:.2rem}
.ctc-lbl{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gray-600)}
.ctc-val{font-size:.95rem;font-weight:600;color:var(--text);transition:color var(--t-fast)}
.ctc-val:hover{color:var(--gold)}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--bg-dark);border-top:1px solid var(--gold-border);padding:5.5rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.2fr;gap:4rem;margin-bottom:4rem}

.footer-brand-desc{font-size:.875rem;color:var(--gray-500);line-height:1.8;max-width:280px;margin:1.25rem 0 1.5rem}
.footer-socials{display:flex;gap:.625rem}
.soc-link{
  width:42px;height:42px;border-radius:10px;
  background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  color:rgba(255,255,255,.6);
  transition:background var(--t-fast),color var(--t-fast),transform var(--t-fast),border-color var(--t-fast);
}
.soc-link:hover{transform:translateY(-3px)}
.soc-instagram:hover{background:radial-gradient(circle at 30% 107%,#fdf497 0%,#fd5949 45%,#d6249f 60%,#000 90%);color:#fff;border-color:transparent}
.soc-linkedin:hover{background:#000;color:#fff;border-color:transparent}
.soc-x:hover{background:#000;color:#fff;border-color:transparent}
.soc-whatsapp:hover{background:#25d366;color:#fff;border-color:transparent}

.footer-head{font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:1.5rem}
.footer-links{display:flex;flex-direction:column;gap:.875rem}
.footer-link{font-size:.875rem;color:var(--gray-500);transition:color var(--t-fast)}
.footer-link:hover{color:var(--off-white)}

.fct-item{margin-bottom:1.125rem}
.fct-label{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--gray-600);margin-bottom:.25rem}
.fct-val{font-size:.875rem;color:var(--gray-400);transition:color var(--t-fast)}
.fct-val:hover{color:var(--off-white)}

.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:2rem;border-top:1px solid rgba(255,255,255,.08);
}
.footer-copy{font-size:.78rem;color:var(--gray-600)}
.footer-copy span{color:var(--gold)}
.footer-procode{
  color:var(--gold);font-weight:700;
  transition:color var(--t-fast),opacity var(--t-fast);
}
.footer-procode:hover{color:var(--gold-light);opacity:.85}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal{
  opacity:0;transform:translateY(42px);
  transition:opacity .8s var(--ease),transform .8s var(--ease);
}
.reveal.from-left{transform:translateX(-42px)}
.reveal.from-right{transform:translateX(42px)}
.reveal.scale{transform:scale(.93)}
.reveal.visible{opacity:1;transform:none}
.d1{transition-delay:.10s}.d2{transition-delay:.20s}.d3{transition-delay:.30s}
.d4{transition-delay:.40s}.d5{transition-delay:.50s}.d6{transition-delay:.60s}

/* ============================================================
   PAGE HEADER (inner pages)
   ============================================================ */
.page-header{
  padding:160px 0 90px;background:var(--bg-dark);
  position:relative;overflow:hidden;
}
.page-header::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 60% 80% at 70% 40%,rgba(229,62,37,.06) 0%,transparent 60%),
             linear-gradient(135deg,#080808 0%,#111111 60%,#161616 100%);
}
.page-header::after{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(229,62,37,.04) 1px,transparent 1px),
    linear-gradient(90deg,rgba(229,62,37,.04) 1px,transparent 1px);
  background-size:52px 52px;
}
.page-header .container{position:relative;z-index:1}
.page-header-title{font-size:clamp(2.5rem,5vw,4.5rem);font-weight:900;color:#ffffff;line-height:1.1;margin-bottom:1.5rem}
.page-header-sub{font-size:1.0625rem;color:var(--gray-400);max-width:600px;line-height:1.8}

.breadcrumb{display:flex;align-items:center;gap:.5rem;margin-bottom:1.5rem}
.bc{font-size:.78rem;color:var(--gray-500);transition:color var(--t-fast)}
.bc:hover{color:var(--gold)}
.bc-sep{color:var(--gray-600);font-size:.7rem}
.bc.current{color:var(--gold)}

/* ============================================================
   PROJECTS PAGE
   ============================================================ */
.projects-page-section{padding:80px 0 110px}
.filter-bar{display:flex;gap:.75rem;flex-wrap:wrap;margin-bottom:2.5rem}
.filter-btn{
  padding:.5rem 1.375rem;border-radius:100px;
  border:1px solid rgba(0,0,0,.10);
  background:transparent;color:var(--gray-400);font-size:.875rem;font-weight:500;
  transition:background var(--t-fast),border-color var(--t-fast),color var(--t-fast);
}
.filter-btn:hover,.filter-btn.active{background:var(--gold);border-color:var(--gold);color:var(--bg-primary)}
.proj-full-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}

/* ============================================================
   PROJECT DETAIL
   ============================================================ */
.proj-detail-section{padding:80px 0 0px}
.proj-detail-grid{display:grid;grid-template-columns:2fr 1fr;gap:4rem;margin-bottom:5rem}
.proj-detail-body{font-size:1.0625rem;color:var(--gray-400);line-height:1.85;margin-bottom:2.5rem}

.highlights-title{
  font-family:var(--font-display);font-size:1.375rem;font-weight:700;color:var(--text);
  margin-bottom:1.5rem;display:flex;align-items:center;gap:1rem;
}
.highlights-title::after{content:'';flex:1;height:1px;background:var(--gold-border)}
.hl-item{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1rem 0;border-bottom:1px solid rgba(0,0,0,.06);
}
.hl-item:last-child{border-bottom:none}
.hl-icon{
  width:24px;height:24px;border-radius:50%;flex-shrink:0;margin-top:.1rem;
  background:var(--gold-subtle);border:1px solid var(--gold-border);
  display:flex;align-items:center;justify-content:center;color:var(--gold);font-size:.65rem;
}
.hl-text{font-size:.9375rem;color:var(--gray-300);line-height:1.65}

/* Info Panel */
.info-panel{position:sticky;top:110px}
.info-card{
  background:var(--bg-card);border:1px solid var(--gold-border);
  border-radius:18px;overflow:hidden;
}
.info-card-head{
  padding:1.875rem;
  background:linear-gradient(135deg,rgba(229,62,37,.14),rgba(229,62,37,.04));
  border-bottom:1px solid var(--gold-border);
}
.info-card-head h3{font-family:var(--font-display);font-size:1.25rem;font-weight:800;color:var(--text);margin-bottom:.25rem}
.info-card-head p{font-size:.75rem;font-weight:600;letter-spacing:.08em;color:var(--gold)}
.info-card-body{padding:1.875rem}
.info-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:.875rem 0;border-bottom:1px solid rgba(0,0,0,.06);
}
.info-row:last-child{border-bottom:none}
.info-lbl{font-size:.72rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--gray-500)}
.info-val{font-size:.9rem;font-weight:700;color:var(--text);text-align:right}
.info-val.g{color:var(--gold)}
.info-card-foot{
  padding:1.875rem;border-top:1px solid var(--gold-border);
  background:rgba(0,0,0,.2);
}

/* Related projects */
.related-section{padding:60px 0 100px;background:var(--bg-secondary)}
.related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;margin-top:2.5rem}

/* ============================================================
   COMMON ANIMATIONS
   ============================================================ */
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:translateY(0)}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1100px){
  .about-grid,.hse-grid{grid-template-columns:1fr;gap:4rem}
  .advantage-intro,.services-intro{grid-template-columns:1fr}
  .projects-grid,.services-grid,.testi-grid,.sectors-grid,.advantage-grid{grid-template-columns:repeat(2,1fr)}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .stat-item:nth-child(2)::after{display:none}
  .footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .proj-detail-grid{grid-template-columns:1fr}
  .info-panel{position:static}
  .proj-full-grid,.related-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .nav-menu{display:none}
  .hamburger{display:flex}
  .mobile-overlay{display:flex}
  :root{--sec-pad:80px 0}
  .hero-title{font-size:clamp(2.8rem,12vw,4.5rem)}
  .projects-grid,.services-grid,.testi-grid,.sectors-grid,.founders-grid{grid-template-columns:1fr}
  .advantage-grid{grid-template-columns:1fr;border:none;background:transparent}
  .adv-item{border-radius:var(--radius);border:1px solid var(--gold-border);border-bottom:1px solid var(--gold-border)!important;border-right:1px solid var(--gold-border)!important}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .team-grid{grid-template-columns:repeat(2,1fr)}
  .proj-full-grid,.related-grid{grid-template-columns:1fr}
  .projects-header{flex-direction:column;gap:1.5rem;align-items:flex-start}
  .hero-actions{flex-direction:column;align-items:flex-start}
  .cta-contacts{gap:2rem}
}
@media(max-width:480px){
  .container{padding:0 1.25rem}
  .stats-grid{grid-template-columns:1fr 1fr}
  .stat-item::after{display:none}
  .hse-stats-grid,.proc-grid{grid-template-columns:1fr}
  .values-grid{grid-template-columns:1fr}
  .team-grid{grid-template-columns:1fr}
  .cta-contacts{flex-direction:column;gap:1.5rem}
}

/* ============================================================
   LIGHT THEME OVERRIDES
   ============================================================ */
.about-text{color:var(--gray-400)}
.hero-title{color:#ffffff}
.hero-tagline{color:rgba(255,255,255,.7)}
.navbar.scrolled .nav-link{color:rgba(22,25,41,.6)}
.navbar.scrolled .hamburger span{background:var(--text)}
[style*="color:var(--white)"]{color:var(--text) !important}
[style*="color:var(--gray-400)"] a{color:var(--text)}
.hse-section [style*="color:var(--gray-400)"]{color:var(--gray-500)}
.vision-mission-section p{color:var(--gray-500)}

/* ============================================================
   PROJECT GALLERY
   ============================================================ */
.proj-hero-img{width:100%;height:480px;object-fit:cover;display:block;border-bottom:1px solid var(--gold-border)}
@media(max-width:768px){.proj-hero-img{height:260px}}

.gallery-section{padding:0px 0 60px}
.gallery-section .section-title{margin-bottom:2.5rem}
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1rem;
}
.gallery-item{
  border-radius:12px;overflow:hidden;
  aspect-ratio:4/3;position:relative;
  box-shadow:0 2px 12px rgba(0,0,0,.08);
  cursor:pointer;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .4s ease;display:block;
}
.gallery-item:hover img{transform:scale(1.06)}

/* Lightbox */
.lightbox{
  display:none;position:fixed;inset:0;
  background:rgba(0,0,0,.92);z-index:9999;
  align-items:center;justify-content:center;
}
.lightbox.open{display:flex}
.lightbox img{max-width:90vw;max-height:88vh;border-radius:8px;object-fit:contain}
.lb-close{
  position:fixed;top:1.25rem;right:1.5rem;
  font-size:2rem;color:#fff;cursor:pointer;
  line-height:1;background:none;border:none;padding:.25rem .5rem;
}
.lb-prev,.lb-next{
  position:fixed;top:50%;transform:translateY(-50%);
  font-size:2.5rem;color:#fff;cursor:pointer;
  background:none;border:none;padding:.5rem 1rem;opacity:.7;
  transition:opacity .2s;
}
.lb-prev:hover,.lb-next:hover{opacity:1}
.lb-prev{left:.5rem}.lb-next{right:.5rem}

/* ============================================================
   LANGUAGE TOGGLE
   ============================================================ */
.lang-toggle{
  display:inline-flex;align-items:center;
  padding:.375rem .85rem;
  border:1.5px solid rgba(255,255,255,.22);
  border-radius:6px;
  font-size:.78rem;font-weight:700;
  color:rgba(255,255,255,.75);
  letter-spacing:.08em;
  transition:all var(--t-fast);
  text-decoration:none;
  margin-left:.5rem;
}
.lang-toggle:hover{border-color:var(--gold);color:var(--gold)}
.navbar.scrolled .lang-toggle{border-color:rgba(22,25,41,.25);color:rgba(22,25,41,.55)}
.navbar.scrolled .lang-toggle:hover{border-color:var(--gold);color:var(--gold)}
[dir=rtl] .lang-toggle{margin-left:0;margin-right:.5rem}

/* ============================================================
   RTL OVERRIDES
   ============================================================ */
[dir=rtl]{font-family:'Tajawal',sans-serif}
[dir=rtl] h1,[dir=rtl] h2,[dir=rtl] h3,[dir=rtl] h4,[dir=rtl] .section-title,[dir=rtl] .eyebrow{font-family:'Tajawal',sans-serif}
[dir=rtl] .eyebrow::before{margin-right:0;margin-left:.75rem}
[dir=rtl] .hl-item{flex-direction:row-reverse; direction: ltr;}
[dir=rtl] .info-val{text-align:left}
[dir=rtl] .soc-links{direction:ltr}
[dir=rtl] .footer-bottom{flex-direction:column;align-items:center;text-align:center}
[dir=rtl] .fct-item{text-align:right}
[dir=rtl] .breadcrumb{flex-direction:row-reverse}
[dir=rtl] .cta-btns{flex-direction:row-reverse}
[dir=rtl] .filter-bar{flex-direction:row-reverse;flex-wrap:wrap}
[dir=rtl] .team-cred{direction:ltr;text-align:left}
[dir=rtl] .footer-grid{text-align:right}
[dir=rtl] .footer-links{text-align:right}
[dir=rtl] .page-header-sub{text-align:right}
[dir=rtl] a[href^="tel"],[dir=rtl] a[href^="mailto"],[dir=rtl] .fct-val{direction:ltr;unicode-bidi:embed}
[dir=rtl] .highlights-title{text-align:right}
