/* =========================================================
   QAMAM AL-MOUJ CONTRACTING COMPANY
   Premium Corporate Style System
   ========================================================= */
:root{
  --navy:#0B1F3A;
  --navy-2:#0E2547;
  --navy-3:#0A1A30;
  --gold:#C9A227;
  --gold-2:#E5BE3F;
  --gold-soft:#F3E2A5;
  --white:#ffffff;
  --soft:#F6F7F9;
  --gray:#8A93A0;
  --line:#E5E8EE;
  --silver:#C7CCD4;
  --ink:#0B1220;
  --shadow-1:0 10px 30px rgba(11,31,58,.08);
  --shadow-2:0 24px 60px rgba(11,31,58,.18);
  --radius:6px;
  --container:1240px;
  --font-en:'Inter','Poppins','Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --font-ar:'Tajawal','Cairo','Noto Kufi Arabic',system-ui,sans-serif;
  --font-display:'Poppins','Inter',system-ui,sans-serif;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--font-en);
  color:var(--ink);
  background:var(--white);
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body.rtl{font-family:var(--font-ar); direction:rtl; text-align:right;}
img{max-width:100%; display:block}
a{color:var(--navy); text-decoration:none; transition:color .2s ease}
a:hover{color:var(--gold)}

h1,h2,h3,h4,h5{font-family:var(--font-display); color:var(--navy); margin:0 0 .6em; letter-spacing:-.01em; font-weight:700; line-height:1.2}
body.rtl h1,body.rtl h2,body.rtl h3,body.rtl h4,body.rtl h5{font-family:var(--font-ar); letter-spacing:0}
h1{font-size:clamp(2.2rem, 4.5vw, 3.6rem)}
h2{font-size:clamp(1.8rem, 3vw, 2.4rem)}
h3{font-size:1.35rem}
p{margin:0 0 1rem; color:#3a4250}

.container-x{max-width:var(--container); margin:0 auto; padding:0 28px}

/* ===== Top bar ===== */
.topbar{
  background:var(--navy-3); color:#cfd6e2; font-size:13px;
  padding:9px 0; border-bottom:1px solid rgba(255,255,255,.05);
}
.topbar a{color:#cfd6e2}
.topbar a:hover{color:var(--gold-2)}
.topbar .inner{display:flex; justify-content:space-between; align-items:center; gap:20px; flex-wrap:wrap}
.topbar .info span{margin-inline-end:22px}
.topbar .info i{color:var(--gold); margin-inline-end:6px}
.topbar .lang a{
  padding:3px 10px; border:1px solid rgba(255,255,255,.18); border-radius:3px;
  margin-inline-start:6px; font-weight:600; letter-spacing:.04em;
}
.topbar .lang a.active{background:var(--gold); color:var(--navy); border-color:var(--gold)}

/* ===== Navbar ===== */
.nav-wrap{
  position:sticky; top:0; z-index:1000; background:#fff;
  border-bottom:1px solid var(--line);
  transition:box-shadow .25s ease;
}
.nav-wrap.scrolled{box-shadow:var(--shadow-1)}
.nav-inner{display:flex; align-items:center; justify-content:space-between; padding:18px 0}
.brand{display:flex; align-items:center; gap:14px; text-decoration:none}
.brand-mark{
  width:54px; height:54px; border-radius:8px;
  background:linear-gradient(135deg,var(--navy) 0%, var(--navy-2) 60%, #16335c 100%);
  display:flex; align-items:center; justify-content:center;
  position:relative; box-shadow:0 6px 14px rgba(11,31,58,.25);
}
.brand-mark::after{
  content:""; position:absolute; inset:6px; border:1px solid var(--gold); border-radius:5px; opacity:.7;
}
.brand-mark span{color:var(--gold); font-weight:800; font-size:20px; font-family:var(--font-display); letter-spacing:.04em}
.brand-text .name{font-family:var(--font-display); font-weight:700; color:var(--navy); font-size:16px; line-height:1.15; letter-spacing:.02em}
.brand-text .sub{font-size:11px; color:var(--gray); letter-spacing:.18em; text-transform:uppercase; margin-top:3px}
body.rtl .brand-text .name{font-family:var(--font-ar); font-size:18px}
body.rtl .brand-text .sub{letter-spacing:.04em}

.nav-links{display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0}
.nav-links a{
  display:inline-flex; align-items:center; padding:10px 14px; font-weight:500; font-size:14.5px; color:#1a2233;
  letter-spacing:.01em; position:relative; border-radius:4px;
}
.nav-links a:hover{color:var(--navy); background:var(--soft)}
.nav-links a.active{color:var(--navy)}
.nav-links a.active::after{
  content:""; position:absolute; left:14px; right:14px; bottom:4px; height:2px; background:var(--gold);
}
.has-mega{position:relative}
.mega{
  position:absolute; top:calc(100% + 6px); left:0; min-width:640px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-2);
  padding:22px; display:none; grid-template-columns:repeat(2,1fr); gap:6px 28px; border-radius:6px;
  border-top:3px solid var(--gold);
}
body.rtl .mega{left:auto; right:0}
.has-mega:hover > .mega, .has-mega.open > .mega{display:grid}
.mega a{display:flex; align-items:flex-start; gap:12px; padding:10px; border-radius:4px}
.mega a:hover{background:var(--soft)}
.mega .ico{
  width:36px; height:36px; flex:none; background:var(--soft); color:var(--navy);
  display:flex; align-items:center; justify-content:center; border-radius:4px; font-size:16px;
}
.mega .t{font-weight:600; color:var(--navy); font-size:14px; line-height:1.3}
.mega .d{font-size:12.5px; color:var(--gray)}

.nav-cta{display:flex; align-items:center; gap:10px}
.btn{
  display:inline-flex; align-items:center; gap:10px; padding:13px 26px;
  font-weight:600; font-size:14px; letter-spacing:.04em; text-transform:uppercase;
  border:none; cursor:pointer; transition:all .25s ease; border-radius:3px;
  font-family:var(--font-display);
}
body.rtl .btn{font-family:var(--font-ar); letter-spacing:0; text-transform:none}
.btn-gold{background:var(--gold); color:var(--navy)}
.btn-gold:hover{background:var(--navy); color:var(--gold)}
.btn-navy{background:var(--navy); color:#fff}
.btn-navy:hover{background:var(--gold); color:var(--navy)}
.btn-ghost{background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,.55)}
.btn-ghost:hover{background:#fff; color:var(--navy); border-color:#fff}
.btn-outline{background:transparent; color:var(--navy); border:1.5px solid var(--navy)}
.btn-outline:hover{background:var(--navy); color:#fff}

.menu-toggle{display:none; background:transparent; border:0; color:var(--navy); font-size:24px; padding:8px}

/* ===== Hero ===== */
.hero{
  position:relative; min-height:88vh; display:flex; align-items:center; color:#fff;
  background:#091a31;
  overflow:hidden;
}
.hero::before{
  content:""; position:absolute; inset:0;
  background:linear-gradient(115deg, rgba(8,21,42,.92) 0%, rgba(8,21,42,.72) 45%, rgba(8,21,42,.4) 100%);
  z-index:2;
}
.hero-bg{position:absolute; inset:0; z-index:1}
.hero-bg img{width:100%; height:100%; object-fit:cover; opacity:.7}
.hero-inner{position:relative; z-index:3; padding:100px 0 120px; max-width:780px}
.hero .eyebrow{
  display:inline-flex; align-items:center; gap:10px; color:var(--gold-2);
  font-size:12.5px; letter-spacing:.32em; text-transform:uppercase; font-weight:600; margin-bottom:22px;
}
body.rtl .hero .eyebrow{letter-spacing:.05em; text-transform:none}
.hero .eyebrow::before{content:""; width:42px; height:1px; background:var(--gold)}
.hero h1{color:#fff; font-size:clamp(2.4rem, 5vw, 4rem); line-height:1.1; margin-bottom:24px}
.hero h1 .accent{color:var(--gold-2); display:block; font-style:italic; font-weight:600}
body.rtl .hero h1 .accent{font-style:normal}
.hero p.lead{font-size:18px; color:#dbe2ee; max-width:620px; margin-bottom:34px; line-height:1.7}
.hero-actions{display:flex; gap:14px; flex-wrap:wrap}
.hero-meta{
  position:absolute; bottom:0; left:0; right:0; z-index:3;
  background:rgba(255,255,255,.06); border-top:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(6px);
}
.hero-meta .grid{display:grid; grid-template-columns:repeat(4,1fr); }
.hero-meta .m{padding:22px 28px; color:#fff; border-inline-start:1px solid rgba(255,255,255,.1)}
.hero-meta .m:first-child{border-inline-start:0}
.hero-meta .num{font-family:var(--font-display); font-size:30px; font-weight:700; color:var(--gold-2)}
body.rtl .hero-meta .num{font-family:var(--font-ar)}
.hero-meta .lbl{font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:#b9c2d2}
body.rtl .hero-meta .lbl{letter-spacing:.02em; text-transform:none; font-size:13px}

/* ===== Inner page header ===== */
.page-head{
  position:relative; padding:130px 0 90px; color:#fff;
  background:linear-gradient(115deg,var(--navy) 0%, var(--navy-2) 100%);
  overflow:hidden;
}
.page-head::after{
  content:""; position:absolute; right:-150px; top:-80px; width:520px; height:520px;
  border:1px solid rgba(201,162,39,.18); border-radius:50%;
}
body.rtl .page-head::after{right:auto; left:-150px}
.page-head::before{
  content:""; position:absolute; right:80px; bottom:-160px; width:280px; height:280px;
  border:1px solid rgba(201,162,39,.14); border-radius:50%;
}
body.rtl .page-head::before{right:auto; left:80px}
.page-head .crumbs{font-size:12.5px; letter-spacing:.22em; text-transform:uppercase; color:var(--gold-2); margin-bottom:18px}
body.rtl .page-head .crumbs{letter-spacing:.04em; text-transform:none; font-size:14px}
.page-head h1{color:#fff; margin:0}
.page-head p{color:#cfd6e2; max-width:680px; margin-top:14px; font-size:17px}

/* ===== Sections ===== */
section{padding:100px 0}
.section-head{max-width:740px; margin:0 auto 60px; text-align:center}
.section-head .eyebrow{display:inline-block; color:var(--gold); font-size:12px; letter-spacing:.3em; text-transform:uppercase; font-weight:700; margin-bottom:14px}
body.rtl .section-head .eyebrow{letter-spacing:.04em; text-transform:none; font-size:14px}
.section-head h2{margin-bottom:16px}
.section-head p{color:#5b6577; font-size:16.5px}

/* ===== About preview ===== */
.about-grid{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center}
.about-grid .imgwrap{position:relative}
.about-grid .imgwrap img{width:100%; height:520px; object-fit:cover; border-radius:4px}
.about-grid .imgwrap .badge{
  position:absolute; bottom:-30px; inset-inline-start:-30px;
  background:var(--gold); color:var(--navy); padding:26px 32px; border-radius:4px;
  box-shadow:var(--shadow-2);
}
.about-grid .imgwrap .badge .n{font-family:var(--font-display); font-size:38px; font-weight:800; line-height:1}
.about-grid .imgwrap .badge .t{font-size:13px; font-weight:600; letter-spacing:.1em; text-transform:uppercase; margin-top:6px}
body.rtl .about-grid .imgwrap .badge .t{letter-spacing:.02em; text-transform:none}
.about-grid .eyebrow{color:var(--gold); font-size:12px; letter-spacing:.3em; text-transform:uppercase; font-weight:700; margin-bottom:14px; display:inline-block}
body.rtl .about-grid .eyebrow{letter-spacing:.04em; text-transform:none; font-size:14px}
.about-grid h2{margin-bottom:22px}
.about-grid .lead{font-size:17px; color:#3a4250; margin-bottom:26px}
.feat-list{list-style:none; padding:0; margin:0 0 30px}
.feat-list li{display:flex; gap:14px; padding:10px 0; align-items:flex-start}
.feat-list i{color:var(--gold); margin-top:4px}
.feat-list b{display:block; color:var(--navy); margin-bottom:2px}

/* ===== Services ===== */
.services-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:28px}
.svc-card{
  background:#fff; border:1px solid var(--line); padding:0;
  position:relative; transition:all .35s ease;
  display:flex; flex-direction:column; overflow:hidden;
}
.svc-card:hover{border-color:transparent; box-shadow:var(--shadow-2); transform:translateY(-6px)}
.svc-card .pic{height:220px; overflow:hidden; position:relative}
.svc-card .pic img{width:100%; height:100%; object-fit:cover; transition:transform .6s ease}
.svc-card:hover .pic img{transform:scale(1.06)}
.svc-card .pic::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(to top,rgba(11,31,58,.55),transparent 55%);
}
.svc-card .ico{
  position:absolute; bottom:-22px; inset-inline-start:24px;
  width:54px; height:54px; background:var(--gold); color:var(--navy);
  display:flex; align-items:center; justify-content:center; font-size:22px;
  border-radius:3px; z-index:2; box-shadow:0 8px 18px rgba(11,31,58,.2);
}
.svc-card .body{padding:38px 26px 26px}
.svc-card h3{font-size:1.2rem; margin-bottom:10px}
.svc-card p{color:#5b6577; font-size:14.5px; margin-bottom:18px}
.svc-card .more{
  display:inline-flex; align-items:center; gap:8px;
  color:var(--navy); font-weight:600; font-size:13px; letter-spacing:.1em; text-transform:uppercase;
  border-top:1px solid var(--line); padding-top:16px; width:100%;
}
body.rtl .svc-card .more{letter-spacing:.02em; text-transform:none; font-size:14px}
.svc-card:hover .more{color:var(--gold)}

/* ===== Why ===== */
.why{background:var(--navy); color:#fff; position:relative; overflow:hidden}
.why::before{
  content:""; position:absolute; right:-200px; top:-200px; width:600px; height:600px;
  background:radial-gradient(closest-side, rgba(201,162,39,.15), transparent 70%);
}
.why h2{color:#fff}
.why .section-head p{color:#b9c2d2}
.why-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:20px; position:relative; z-index:2}
.why-card{
  padding:36px 28px; background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08); border-radius:4px; transition:all .3s ease;
}
.why-card:hover{background:rgba(201,162,39,.08); border-color:var(--gold)}
.why-card .num{font-family:var(--font-display); font-size:14px; color:var(--gold); font-weight:700; letter-spacing:.18em; margin-bottom:14px}
body.rtl .why-card .num{font-family:var(--font-ar); letter-spacing:.02em}
.why-card h3{color:#fff; font-size:1.1rem; margin-bottom:10px}
.why-card p{color:#b9c2d2; font-size:14px; margin:0}

/* ===== Stats counter ===== */
.stats{background:var(--soft); padding:80px 0}
.stats-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:30px; text-align:center}
.stat .n{font-family:var(--font-display); font-size:54px; color:var(--navy); font-weight:800; line-height:1}
.stat .n .plus{color:var(--gold)}
body.rtl .stat .n{font-family:var(--font-ar)}
.stat .lbl{margin-top:10px; color:var(--gray); font-size:13.5px; letter-spacing:.16em; text-transform:uppercase; font-weight:600}
body.rtl .stat .lbl{letter-spacing:.02em; text-transform:none; font-size:15px}

/* ===== Clients ===== */
.clients-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:1px; background:var(--line); border:1px solid var(--line)}
.client{
  background:#fff; min-height:130px; display:flex; align-items:center; justify-content:center; padding:20px;
  font-weight:700; color:var(--gray); font-size:14.5px; text-align:center; letter-spacing:.04em;
  transition:all .3s ease;
}
.client:hover{background:var(--navy); color:var(--gold-2)}

/* ===== CTA strip ===== */
.cta-strip{
  background:linear-gradient(115deg,var(--navy) 0%, var(--navy-2) 100%);
  color:#fff; padding:70px 0; position:relative; overflow:hidden;
}
.cta-strip::after{
  content:""; position:absolute; right:-100px; top:-100px; width:400px; height:400px;
  border:1px solid rgba(201,162,39,.15); border-radius:50%;
}
.cta-strip .inner{display:flex; justify-content:space-between; align-items:center; gap:30px; flex-wrap:wrap; position:relative; z-index:2}
.cta-strip h2{color:#fff; margin:0; font-size:1.9rem; max-width:680px}
.cta-strip h2 span{color:var(--gold-2)}

/* ===== Footer ===== */
footer{background:#07152C; color:#a9b3c5; padding:80px 0 0; position:relative}
footer h4{color:#fff; font-size:14px; letter-spacing:.2em; text-transform:uppercase; margin-bottom:22px; position:relative; padding-bottom:14px}
body.rtl footer h4{letter-spacing:.02em; text-transform:none; font-size:16px}
footer h4::after{content:""; position:absolute; left:0; bottom:0; width:34px; height:2px; background:var(--gold)}
body.rtl footer h4::after{left:auto; right:0}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px; padding-bottom:60px}
footer p, footer a, footer li{color:#a9b3c5; font-size:14.5px; line-height:1.85}
footer a:hover{color:var(--gold-2)}
footer ul{list-style:none; padding:0; margin:0}
footer ul li{padding:5px 0}
.foot-brand .brand-mark{margin-bottom:18px}
.foot-info li{display:flex; gap:12px; align-items:flex-start}
.foot-info i{color:var(--gold); margin-top:6px; width:18px; text-align:center}
.foot-bottom{
  border-top:1px solid rgba(255,255,255,.08); padding:24px 0; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px;
  font-size:13.5px;
}
.foot-bottom .aramco{display:inline-flex; align-items:center; gap:10px; color:#cfd6e2}
.foot-bottom .aramco b{color:var(--gold-2)}

/* ===== Whatsapp + scroll top ===== */
.fab{
  position:fixed; bottom:24px; inset-inline-end:24px; width:56px; height:56px; border-radius:50%;
  display:flex; align-items:center; justify-content:center; color:#fff; font-size:24px;
  box-shadow:0 12px 28px rgba(0,0,0,.18); z-index:999; transition:transform .2s ease;
}
.fab:hover{transform:scale(1.08); color:#fff}
.fab.wa{background:#25D366}
.fab.top{background:var(--navy); bottom:92px; width:48px; height:48px; font-size:18px; opacity:0; pointer-events:none}
.fab.top.show{opacity:1; pointer-events:auto}

/* ===== Loader ===== */
.loader{
  position:fixed; inset:0; background:var(--navy); z-index:9999;
  display:flex; align-items:center; justify-content:center; transition:opacity .5s ease;
}
.loader .ring{width:54px; height:54px; border:3px solid rgba(255,255,255,.15); border-top-color:var(--gold); border-radius:50%; animation:spin 1s linear infinite}
.loader.done{opacity:0; pointer-events:none}
@keyframes spin{to{transform:rotate(360deg)}}

/* ===== Service detail ===== */
.svc-detail{display:grid; grid-template-columns:1.1fr 1fr; gap:60px; align-items:center}
.svc-detail .pic img{width:100%; height:520px; object-fit:cover; border-radius:4px}
.svc-detail h2{margin-bottom:22px}
.svc-detail ul{list-style:none; padding:0; margin:24px 0; display:grid; grid-template-columns:1fr 1fr; gap:12px}
.svc-detail ul li{display:flex; gap:10px; align-items:flex-start; color:#3a4250}
.svc-detail ul i{color:var(--gold); margin-top:5px}

.bullet-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; margin-top:40px}
.bullet{
  background:#fff; border:1px solid var(--line); padding:28px; border-radius:4px;
  display:flex; gap:16px; align-items:flex-start; transition:all .3s ease;
}
.bullet:hover{border-color:var(--gold); box-shadow:var(--shadow-1)}
.bullet i{
  width:44px; height:44px; flex:none; background:var(--soft); color:var(--navy);
  display:flex; align-items:center; justify-content:center; border-radius:4px; font-size:18px;
}
.bullet b{display:block; color:var(--navy); margin-bottom:4px; font-size:15.5px}
.bullet p{margin:0; color:#5b6577; font-size:14px}

/* ===== Gallery ===== */
.gallery-filter{display:flex; justify-content:center; gap:10px; margin-bottom:40px; flex-wrap:wrap}
.gallery-filter button{
  background:#fff; border:1px solid var(--line); padding:10px 22px; cursor:pointer;
  font-weight:600; font-size:13px; letter-spacing:.08em; color:#3a4250; transition:all .25s ease;
}
.gallery-filter button.active, .gallery-filter button:hover{background:var(--navy); color:#fff; border-color:var(--navy)}
.gallery-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:20px}
.gallery-grid .gitem{position:relative; overflow:hidden; cursor:pointer; aspect-ratio:4/3}
.gallery-grid .gitem img{width:100%; height:100%; object-fit:cover; transition:transform .5s ease}
.gallery-grid .gitem:hover img{transform:scale(1.08)}
.gallery-grid .gitem::after{
  content:"+"; position:absolute; inset:0; background:rgba(11,31,58,.5); color:var(--gold);
  display:flex; align-items:center; justify-content:center; font-size:42px; font-weight:300;
  opacity:0; transition:opacity .3s ease;
}
.gallery-grid .gitem:hover::after{opacity:1}
.lightbox{
  position:fixed; inset:0; background:rgba(7,21,44,.94); z-index:9998;
  display:none; align-items:center; justify-content:center; padding:30px;
}
.lightbox.show{display:flex}
.lightbox img{max-width:95%; max-height:92vh; object-fit:contain}
.lightbox .x{position:absolute; top:24px; right:30px; color:#fff; font-size:32px; cursor:pointer; background:transparent; border:0}

/* ===== Contact ===== */
.contact-grid{display:grid; grid-template-columns:1fr 1.2fr; gap:50px}
.contact-info{background:var(--navy); color:#fff; padding:50px 40px; border-radius:4px; position:relative; overflow:hidden}
.contact-info::after{content:""; position:absolute; right:-80px; bottom:-80px; width:260px; height:260px; border:1px solid rgba(201,162,39,.2); border-radius:50%}
.contact-info h3{color:#fff; margin-bottom:24px}
.contact-info ul{list-style:none; padding:0; margin:0; position:relative; z-index:2}
.contact-info li{display:flex; gap:18px; padding:18px 0; border-bottom:1px solid rgba(255,255,255,.08)}
.contact-info li:last-child{border:0}
.contact-info i{width:42px; height:42px; flex:none; background:var(--gold); color:var(--navy); display:flex; align-items:center; justify-content:center; border-radius:4px}
.contact-info .lbl{font-size:12px; color:var(--gold-2); letter-spacing:.18em; text-transform:uppercase; font-weight:600; margin-bottom:4px}
body.rtl .contact-info .lbl{letter-spacing:.02em; text-transform:none; font-size:13px}
.contact-info .val{color:#fff; font-size:15px}
.contact-form{background:#fff; border:1px solid var(--line); padding:40px}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:18px; margin-bottom:18px}
.form-row.full{grid-template-columns:1fr}
.form-row input, .form-row textarea, .form-row select{
  width:100%; padding:14px 16px; border:1px solid var(--line); background:#fff; font-family:inherit; font-size:14.5px; color:var(--ink);
  border-radius:3px; transition:border .2s ease;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus{outline:none; border-color:var(--gold)}
.form-row label{display:block; font-size:12px; color:var(--gray); letter-spacing:.12em; text-transform:uppercase; font-weight:600; margin-bottom:8px}
body.rtl .form-row label{letter-spacing:.02em; text-transform:none; font-size:13px}
.map-wrap{margin-top:60px; border:1px solid var(--line)}
.map-wrap iframe{width:100%; height:420px; border:0; display:block; filter:grayscale(.3) contrast(1.05)}

/* ===== Anim ===== */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1; transform:none}

/* ===== Mission / vision blocks ===== */
.mv-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:24px}
.mv{padding:42px 32px; background:#fff; border-top:3px solid var(--gold); border:1px solid var(--line); border-top:3px solid var(--gold); border-radius:4px}
.mv .ic{width:60px; height:60px; background:var(--soft); color:var(--navy); display:flex; align-items:center; justify-content:center; font-size:24px; border-radius:4px; margin-bottom:20px}
.mv h3{margin-bottom:12px}
.mv p{color:#5b6577; margin:0}

/* ===== President msg ===== */
.pres{display:grid; grid-template-columns:1fr 1.3fr; gap:60px; align-items:center; background:var(--soft); padding:70px; border-radius:4px}
.pres .ph{position:relative}
.pres .ph img{width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:4px}
.pres .ph::after{content:""; position:absolute; inset-inline-start:-22px; bottom:-22px; width:140px; height:140px; background:var(--gold); z-index:-1; border-radius:4px}
.pres blockquote{margin:0; font-size:19px; line-height:1.8; color:#2a3344; font-style:italic; padding-inline-start:30px; border-inline-start:3px solid var(--gold)}
body.rtl .pres blockquote{font-style:normal}
.pres .sig{margin-top:30px}
.pres .sig b{display:block; color:var(--navy); font-size:16px; font-family:var(--font-display)}
body.rtl .pres .sig b{font-family:var(--font-ar)}
.pres .sig span{color:var(--gray); font-size:13px; letter-spacing:.14em; text-transform:uppercase}
body.rtl .pres .sig span{letter-spacing:.02em; text-transform:none}
