/* ===== Tokens ===== */
:root{
  --bg:#0c0c0e;
  --bg-alt:#111114;
  --surface:#16161a;
  --line:rgba(255,255,255,.09);
  --text:#f3f1ec;
  --muted:#a7a39b;
  --accent:#e2552c;       /* flint ember */
  --accent-soft:#f08a4b;
  --maxw:1200px;
  --r:14px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --f-ar:"Tajawal",system-ui,sans-serif;
  --f-en:"Inter",system-ui,sans-serif;
  --f-display:"Cormorant Garamond",serif;
  --font:var(--f-ar);
}
html[lang="en"]{--font:var(--f-en);}

/* Arabic must never get letter-spacing (it breaks cursive joining) */
html[lang="ar"] .hero__eyebrow,
html[lang="ar"] .kicker,
html[lang="ar"] .card__cat,
html[lang="ar"] .stat__label,
html[lang="ar"] .nav__links,
html[lang="ar"] .lead,
html[lang="ar"] .hero__title,
html[lang="ar"] .section__title{letter-spacing:0}

/* Tajawal has no 600 weight — bump Arabic labels/buttons to 700
   so they render in Tajawal instead of falling back to a system font */
html[lang="ar"] .hero__eyebrow,
html[lang="ar"] .kicker,
html[lang="ar"] .card__cat,
html[lang="ar"] .card__t,
html[lang="ar"] .btn{font-weight:700}

*{box-sizing:border-box;margin:0;padding:0}
/* the hidden attribute must beat any author display rule (e.g. the admin
   editor overlay uses display:flex, which would otherwise override [hidden]) */
[hidden]{display:none !important}
html{scroll-behavior:smooth}
body{
  font-family:var(--font);
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
.container{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(20px,5vw,48px)}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/* ===== Navbar ===== */
.nav{position:fixed;inset-block-start:0;inset-inline:0;z-index:50;
  transition:background .4s var(--ease),border-color .4s,backdrop-filter .4s;
  border-block-end:1px solid transparent}
.nav.scrolled{background:rgba(12,12,14,.82);backdrop-filter:blur(14px);border-block-end-color:var(--line)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;height:74px}
.brand{display:flex;align-items:center;gap:12px}
.brand__word{height:19px;width:auto}
.nav__links{display:flex;gap:30px;font-size:.92rem}
.nav__links a{color:var(--muted);transition:color .25s;position:relative}
.nav__links a:hover{color:var(--text)}
.nav__links a::after{content:"";position:absolute;inset-block-end:-6px;inset-inline-start:0;width:0;height:1.5px;background:var(--accent);transition:width .3s var(--ease)}
.nav__links a:hover::after{width:100%}

.lang-toggle{
  font-family:"Inter","Tajawal",system-ui,sans-serif;font-size:.8rem;font-weight:600;letter-spacing:.05em;
  background:transparent;color:var(--text);border:1px solid var(--line);
  border-radius:999px;padding:8px 16px;cursor:pointer;
  transition:border-color .25s,color .25s,background .25s}
.lang-toggle:hover{border-color:var(--accent);color:var(--accent)}
/* show only the "other" language label */
html[lang="ar"] .lang-toggle [data-lang-label="ar"]{display:none}
html[lang="en"] .lang-toggle [data-lang-label="en"]{display:none}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  padding:14px 30px;border-radius:999px;font-size:.95rem;font-weight:600;
  cursor:pointer;transition:transform .25s var(--ease),background .25s,color .25s,border-color .25s}
.ig{width:18px;height:18px;fill:currentColor;flex:0 0 auto;display:inline-block}
.btn--primary{background:var(--accent);color:#fff}
.btn--primary:hover{background:var(--accent-soft);transform:translateY(-2px)}
.btn--ghost{border:1px solid var(--line);color:var(--text)}
.btn--ghost:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}

/* ===== Hero ===== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;overflow:hidden}
.hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);animation:zoom 18s ease-in-out infinite alternate}
@keyframes zoom{to{transform:scale(1.18)}}
.hero__veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,12,14,.55) 0%,rgba(12,12,14,.7) 45%,var(--bg) 100%)}
.hero__content{position:relative;z-index:2;padding-block:120px;max-width:880px}
.hero__eyebrow{color:var(--accent-soft);font-size:.95rem;letter-spacing:.12em;
  text-transform:uppercase;margin-block-end:18px;font-weight:600}
.hero__title{font-size:clamp(2.6rem,7vw,5.6rem);line-height:1.08;font-weight:700;
  letter-spacing:-.01em;margin-block-end:26px}
.hero__title span{display:block}
.hero__title .accent{color:var(--accent)}
.hero__sub{font-size:clamp(1.05rem,2vw,1.3rem);color:var(--muted);max-width:680px;margin-block-end:38px}
.hero__sub strong{color:var(--text);font-family:var(--f-en);font-weight:600}
.hero__cta{display:flex;gap:16px;flex-wrap:wrap}
.hero__scroll{position:absolute;inset-block-end:28px;inset-inline-start:50%;transform:translateX(-50%);
  z-index:2;color:var(--muted);font-size:1.4rem;animation:bob 2s ease-in-out infinite}
@keyframes bob{50%{transform:translate(-50%,8px)}}

/* ===== Marquee ===== */
.marquee{overflow:hidden;border-block:1px solid var(--line);background:var(--bg-alt);padding-block:20px}
.marquee__track{display:flex;gap:32px;white-space:nowrap;width:max-content;
  animation:scroll 32s linear infinite;font-size:1.1rem;color:var(--muted);font-weight:500}
html[dir="rtl"] .marquee__track{animation-direction:reverse}
.marquee__track span:nth-child(even){color:var(--accent)}
@keyframes scroll{to{transform:translateX(-50%)}}

/* ===== Sections ===== */
.section{padding-block:clamp(72px,11vw,130px)}
.section--alt{background:var(--bg-alt)}
.kicker{display:inline-block;color:var(--accent);font-size:.85rem;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;margin-block-end:14px}
.section__title{font-size:clamp(1.9rem,4.2vw,3.1rem);font-weight:700;line-height:1.18;letter-spacing:-.01em}
.section__head{max-width:680px;margin-block-end:56px}
.lead{font-size:clamp(1.05rem,2vw,1.25rem);color:var(--muted)}
.lead strong{color:var(--text);font-family:var(--f-en);font-weight:600}

/* ===== About ===== */
.about__intro{max-width:760px;margin-block-end:64px}
.about__intro .section__title{margin-block:14px 22px}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-block-end:72px}
.pillar{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:34px 30px;
  transition:transform .35s var(--ease),border-color .35s}
.pillar:hover{transform:translateY(-5px);border-color:var(--accent)}
.pillar h3{font-size:1.35rem;margin-block-end:14px;color:var(--accent-soft)}
.pillar p{color:var(--muted)}
.values{list-style:none;display:flex;flex-wrap:wrap;gap:10px}
.values li{background:rgba(226,85,44,.1);color:var(--accent-soft);border:1px solid rgba(226,85,44,.25);
  padding:7px 16px;border-radius:999px;font-size:.92rem;font-weight:500}

.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
  border-block:1px solid var(--line);padding-block:46px}
.stat{text-align:center}
.stat__num{display:block;font-size:clamp(2.2rem,5vw,3.4rem);font-weight:700;color:var(--accent);font-family:var(--f-en);line-height:1}
.stat__label{display:block;margin-block-start:10px;color:var(--muted);font-size:.95rem}

/* ===== Services ===== */
.services{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.service{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);padding:38px 32px;
  position:relative;overflow:hidden;transition:transform .35s var(--ease),border-color .35s}
.service::before{content:"";position:absolute;inset-block-start:0;inset-inline-start:0;width:100%;height:3px;
  background:linear-gradient(90deg,var(--accent),var(--accent-soft));transform:scaleX(0);transform-origin:inline-start;transition:transform .4s var(--ease)}
.service:hover{transform:translateY(-6px);border-color:var(--accent)}
.service:hover::before{transform:scaleX(1)}
.service__num{font-family:var(--f-en);font-size:.9rem;font-weight:600;color:var(--accent);letter-spacing:.1em}
.service h3{font-size:1.5rem;margin-block:14px 12px}
.service>p{color:var(--muted);margin-block-end:22px}
.service ul{list-style:none;display:flex;flex-direction:column;gap:11px}
.service li{color:var(--text);font-size:.95rem;padding-inline-start:22px;position:relative}
.service li::before{content:"";position:absolute;inset-inline-start:0;inset-block-start:.62em;
  width:7px;height:7px;border-radius:50%;background:var(--accent)}

/* ===== Gallery ===== */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:240px;gap:18px}
.card{position:relative;border-radius:var(--r);overflow:hidden;background-size:cover;background-position:center;
  display:flex;align-items:flex-end;cursor:pointer}
.card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 35%,rgba(8,8,10,.9));
  transition:opacity .4s}
.card>figcaption{position:relative;z-index:2;padding:22px;transform:translateY(8px);opacity:.92;transition:transform .4s var(--ease)}
.card:hover>figcaption{transform:translateY(0)}
.card img,.card{transition:transform .6s var(--ease)}
.card:hover{transform:scale(.99)}
.card__cat{display:block;color:var(--accent-soft);font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-block-end:5px}
.card__t{display:block;font-size:1.08rem;font-weight:600;line-height:1.3}
.card--wide{grid-column:span 2}
.card--tall{grid-row:span 2}

/* ===== Why ===== */
.why{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line);border-radius:var(--r);overflow:hidden}
.why__item{background:var(--bg-alt);padding:38px 32px;transition:background .3s}
.why__item:hover{background:var(--surface)}
.why__item h3{font-size:1.25rem;margin-block-end:12px;color:var(--accent-soft)}
.why__item p{color:var(--muted);font-size:.97rem}

/* ===== Contact ===== */
.contact{text-align:center;background:
  radial-gradient(900px 400px at 50% 0%,rgba(226,85,44,.12),transparent 70%),var(--bg)}
.contact__inner{max-width:680px;margin-inline:auto}
.contact .section__title{margin-block:14px 18px}
.contact__actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-block-start:34px}
.contact__actions .btn{font-family:var(--f-en)}

/* ===== Footer ===== */
.footer{border-block-start:1px solid var(--line);padding-block:48px;background:var(--bg-alt)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.footer__brand{display:flex;align-items:center;gap:12px}
.footer__word{height:62px;width:auto}
.footer__contact{display:flex;gap:26px;flex-wrap:wrap;font-family:var(--f-en);font-size:.92rem}
.footer__contact a{color:var(--muted);transition:color .25s;display:inline-flex;align-items:center;gap:8px}
.footer__contact a:hover{color:var(--accent)}
.footer__copy{color:var(--muted);font-size:.88rem;width:100%;border-block-start:1px solid var(--line);padding-block-start:24px;margin-block-start:8px}

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

/* ===== Responsive ===== */
@media(max-width:960px){
  .nav__links{display:none}
  .pillars,.services,.why{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2,1fr);gap:36px 24px}
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:200px}
  .card--wide,.card--tall{grid-column:auto;grid-row:auto}
}
@media(max-width:540px){
  .gallery{grid-template-columns:1fr;grid-auto-rows:220px}
  .hero__cta{flex-direction:column;align-items:stretch}
  .footer__inner{flex-direction:column;text-align:center;align-items:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
  .reveal{opacity:1;transform:none}
}

/* ===== Nav actions + Profile button ===== */
.nav__actions{display:flex;align-items:center;gap:12px}
.btn-profile{font-family:var(--font);font-size:.85rem;font-weight:700;
  border:1px solid var(--accent);color:var(--accent);border-radius:999px;
  padding:8px 18px;white-space:nowrap;transition:background .25s,color .25s}
.btn-profile:hover{background:var(--accent);color:#fff}
@media(max-width:600px){.btn-profile{display:none}}

/* ===== Project detail page ===== */
.detail-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden}
.detail-hero__bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.detail-hero__veil{position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(12,12,14,.55) 0%,rgba(12,12,14,.55) 40%,var(--bg) 100%)}
.detail-hero__content{position:relative;z-index:2;padding-block:120px 56px;max-width:900px}
.detail-back{display:inline-block;color:var(--muted);font-size:.95rem;margin-block-end:18px;transition:color .25s}
.detail-back:hover{color:var(--accent)}
.detail-hero__title{font-size:clamp(2rem,5vw,3.6rem);font-weight:700;line-height:1.15;margin-block:10px 22px}
.detail-meta{list-style:none;display:flex;flex-wrap:wrap;gap:14px 40px}
.detail-meta li{display:flex;flex-direction:column;gap:3px}
.detail-meta__k{color:var(--accent-soft);font-size:.8rem;font-weight:600}
.detail-meta__v{font-size:1.05rem}
.detail-body .lead{max-width:760px;margin-block-end:24px}
.detail-text{max-width:760px;color:var(--muted);font-size:1.05rem}
.detail-text p{margin-block-end:14px}
.detail-block{margin-block-start:56px}
.detail-h2{font-size:clamp(1.4rem,3vw,2rem);font-weight:700;margin-block-end:24px}
.detail-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.detail-gallery__item{display:block;border-radius:var(--r);overflow:hidden;background:var(--surface);aspect-ratio:4/3}
.detail-gallery__item img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.detail-gallery__item:hover img{transform:scale(1.05)}
.detail-videos{display:grid;grid-template-columns:repeat(auto-fit,minmax(420px,1fr));gap:20px}
.detail-video{position:relative;aspect-ratio:16/9;border-radius:var(--r);overflow:hidden;background:#000}
.detail-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
@media(max-width:520px){.detail-videos{grid-template-columns:1fr}}

/* ===== Admin ===== */
/* Admin uses IBM Plex throughout (IBM Plex Sans Arabic in AR, IBM Plex Sans in EN) */
.admin-body{
  --f-ar:"IBM Plex Sans Arabic",system-ui,sans-serif;
  --f-en:"IBM Plex Sans","IBM Plex Sans Arabic",system-ui,sans-serif;
  font-family:var(--font);
}
.admin-body .lang-toggle,
.admin-body .admin-who,
.admin-body .admin-tag,
.admin-body input,
.admin-body select,
.admin-body textarea,
.admin-body .btn{font-family:var(--font)}
.admin-body{background:var(--bg);min-height:100vh}
.admin-top{display:flex;align-items:center;gap:14px;padding:16px clamp(20px,5vw,48px);
  border-block-end:1px solid var(--line);background:var(--bg-alt)}
.admin-top .brand__word{height:18px}
.admin-tag{font-family:var(--f-en);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--accent);border:1px solid var(--accent);border-radius:999px;padding:3px 10px}
.admin-top__right{margin-inline-start:auto;display:flex;align-items:center;gap:14px}
.admin-who{color:var(--muted);font-size:.9rem;font-family:var(--f-en)}
.admin-main{padding-block:40px;font-family:var(--font)}
.admin-card{max-width:520px;margin:40px auto;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:34px}
.admin-card h1{font-size:1.5rem;margin-block-end:14px}
.muted{color:var(--muted)}
.admin-card code{background:var(--bg-alt);padding:2px 6px;border-radius:5px;color:var(--accent-soft);font-size:.88em}
.admin-login form{display:flex;flex-direction:column;gap:16px;margin-block-start:8px}
label{display:flex;flex-direction:column;gap:6px;font-size:.9rem;color:var(--muted)}
input,select,textarea{font-family:inherit;font-size:.95rem;background:var(--bg-alt);color:var(--text);
  border:1px solid var(--line);border-radius:9px;padding:11px 13px;width:100%}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent)}
textarea{resize:vertical;line-height:1.6}
.admin-error{color:#ff7a6b;font-size:.9rem}
.admin-head{display:flex;align-items:center;justify-content:space-between;margin-block-end:24px;gap:16px}
.admin-head h1{font-size:1.6rem}
.admin-list{display:flex;flex-direction:column;gap:10px}
.al-row{display:flex;align-items:center;gap:16px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--r);padding:12px 14px}
.al-thumb{width:64px;height:48px;border-radius:8px;background:var(--bg-alt) center/cover no-repeat;flex:0 0 auto}
.al-meta{display:flex;flex-direction:column;gap:2px;min-width:0}
.al-meta strong{font-size:1rem}
.al-meta .muted{font-size:.82rem}
.al-actions{margin-inline-start:auto;display:flex;gap:8px}
.al-actions button{background:var(--bg-alt);border:1px solid var(--line);color:var(--text);
  border-radius:8px;padding:7px 14px;cursor:pointer;font-size:.85rem;transition:border-color .2s,color .2s}
.al-edit:hover{border-color:var(--accent);color:var(--accent)}
.al-del:hover{border-color:#ff7a6b;color:#ff7a6b}
.admin-editor{position:fixed;inset:0;z-index:100;background:rgba(8,8,10,.7);
  display:flex;justify-content:center;align-items:flex-start;overflow:auto;padding:30px 16px}
.admin-editor__panel{background:var(--bg-alt);border:1px solid var(--line);border-radius:16px;
  width:100%;max-width:760px;padding:28px}
.admin-editor__head{display:flex;align-items:center;justify-content:space-between;margin-block-end:20px}
.admin-editor__head h2{font-size:1.3rem}
.admin-form{display:flex;flex-direction:column;gap:16px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}
.upl{display:flex;gap:10px;align-items:center}
.upl input[type=file]{padding:7px;font-size:.82rem}
.cover-prev img{max-height:120px;border-radius:9px;border:1px solid var(--line)}
.check{flex-direction:row;align-items:center;gap:10px}
.check input{width:auto}
.admin-form__actions{display:flex;align-items:center;gap:16px;margin-block-start:6px}
