/* =========================================================
   AXIS — Architecture & Engineering Office
   Design System / Global Styles
   Author: Senior Front-end (30+ yrs) build for Axis
   ========================================================= */

/* ---------- Design Tokens ---------- */
:root{
  /* Palette — refined luxury: espresso near-black + champagne gold + warm ivory */
  --bg:          #F7F4ED;   /* warm ivory page */
  --surface:     #FFFFFF;
  --surface-2:   #EDE8DC;   /* warm sand */
  --ink:         #16130E;   /* espresso near-black text */
  --ink-2:       #453F37;   /* secondary text */
  --ink-3:       #857F72;   /* muted */
  --line:        #E4DDCE;   /* hairline borders */
  --dark:        #0F0D09;   /* deep espresso-black (footer/hero) */
  --dark-2:      #1B1710;
  --accent:      #BE9A54;   /* champagne / antique gold */
  --accent-2:    #A37E3A;   /* deeper gold (hover) */
  --accent-soft: #F2E9D4;
  --gold-line:   linear-gradient(90deg, transparent, #BE9A54, transparent);

  /* Typography — bold modern grotesque display + clean sans body */
  --f-sans:    "Manrope", "Tajawal", system-ui, sans-serif;   /* body (EN) */
  --f-serif:   "Space Grotesk", "Cairo", sans-serif;          /* display (EN) — strong grotesque */
  --f-ar:      "Tajawal", "Manrope", sans-serif;              /* body (AR) */
  --f-ar-head: "Cairo", "Tajawal", sans-serif;                /* display (AR) — heavy geometric */

  /* Header background (theme-aware) */
  --header-bg: rgba(247,244,237,.9);

  /* Metrics */
  --container: 1240px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 4px;
  --radius-lg: 10px;
  --header-h: 82px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --dur: .6s;

  --shadow-sm: 0 2px 10px rgba(28,26,23,.06);
  --shadow-md: 0 18px 50px -20px rgba(28,26,23,.28);
}

/* ---------- Dark theme ---------- */
html[data-theme="dark"]{
  --bg:          #100D08;   /* deep espresso page */
  --surface:     #191510;   /* card surface */
  --surface-2:   #15110B;   /* alt surface */
  --ink:         #F4EFE3;   /* light text */
  --ink-2:       #C4BCAB;
  --ink-3:       #8C8574;
  --line:        #2B251B;
  --dark:        #080604;   /* darkest blocks / footer */
  --dark-2:      #12100A;
  --accent:      #CBA968;   /* brighter gold for dark bg */
  --accent-2:    #E2C382;
  --accent-soft: #241D11;
  --header-bg:   rgba(16,13,8,.92);
  --shadow-md:   0 20px 55px -22px rgba(0,0,0,.65);
  --shadow-sm:   0 2px 12px rgba(0,0,0,.35);
}
html[data-theme="dark"] .btn--ghost{ border-color:var(--line); }
html[data-theme="dark"] .btn--ghost:hover{ border-color:var(--accent); color:var(--accent); }
/* smooth theme transition */
body, .site-header, .card, .quote, .post, .field input, .field select, .field textarea, .pd-meta, form.axis-form, .filters button{
  transition: background-color .4s var(--ease), border-color .4s var(--ease), color .3s var(--ease);
}

/* ---------- Reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family: var(--f-sans);
  background: var(--bg);
  color: var(--ink);
  line-height: 1.75;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
html[lang="ar"] body,
html[lang="ar"]{ font-family: var(--f-ar); }
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font-family:inherit; cursor:pointer; border:none; background:none; color:inherit; }
h1,h2,h3,h4{ line-height:1.15; font-weight:600; color:var(--ink); }

/* Headings: strong grotesque in EN, heavy Cairo in AR */
html[lang="en"] h1,
html[lang="en"] h2,
html[lang="en"] .display{ font-family: var(--f-serif); font-weight:700; letter-spacing:-.015em; }
html[lang="ar"] h1,
html[lang="ar"] h2,
html[lang="ar"] .display{ font-family: var(--f-ar-head); font-weight:800; letter-spacing:0; }

/* ---------- Layout helpers ---------- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--gutter); }
.section{ padding-block: clamp(64px, 9vw, 130px); }
.section--tight{ padding-block: clamp(48px, 6vw, 90px); }
.bg-sand{ background:var(--surface-2); }
.bg-dark{ background:var(--dark); color:#EDE9E0; }
.center{ text-align:center; }
.mt-s{ margin-top:14px; } .mt-m{ margin-top:26px; } .mt-l{ margin-top:44px; }

/* Eyebrow / kicker */
.kicker{
  display:inline-flex; align-items:center; gap:10px;
  font-family:var(--f-sans); font-size:.78rem; font-weight:700;
  letter-spacing:.22em; text-transform:uppercase; color:var(--accent);
}
html[lang="ar"] .kicker{ letter-spacing:.06em; font-family:var(--f-ar); }
.kicker::before{ content:""; width:30px; height:1.5px; background:var(--accent); display:inline-block; }

.h-section{ font-size: clamp(1.9rem, 4vw, 3rem); margin-top:16px; }
.lead{ color:var(--ink-2); font-size:1.06rem; max-width:60ch; }
.bg-dark .lead{ color:#C9C3B6; }
.bg-dark .h-section, .bg-dark h1,.bg-dark h2,.bg-dark h3{ color:#F5F1E8; }

/* ---------- Buttons ---------- */
.btn{
  --pad-y:15px; --pad-x:30px;
  display:inline-flex; align-items:center; gap:12px;
  padding: var(--pad-y) var(--pad-x);
  font-family:var(--f-sans); font-weight:700; font-size:.9rem;
  letter-spacing:.04em; border-radius:var(--radius);
  transition: all .35s var(--ease); position:relative;
}
html[lang="ar"] .btn{ font-family:var(--f-ar); }
.btn .arw{ transition: transform .35s var(--ease); }
html[dir="rtl"] .btn .arw{ transform: scaleX(-1); }
.btn:hover .arw{ transform: translateX(4px); }
html[dir="rtl"] .btn:hover .arw{ transform: scaleX(-1) translateX(4px); }
.btn--primary{ background:linear-gradient(135deg, #C7A45E, #A98039); color:#fff; box-shadow:0 8px 22px -14px rgba(120,90,40,.9); }
.btn--primary:hover{ background:linear-gradient(135deg, #A98039, #8F6A2E); transform: translateY(-2px); box-shadow:0 14px 30px -12px rgba(150,112,52,.8); }
.btn--ghost{ border:1.5px solid var(--line); color:var(--ink); }
.btn--ghost:hover{ border-color:var(--ink); }
.btn--light{ border:1.5px solid rgba(255,255,255,.35); color:#fff; }
.btn--light:hover{ background:#fff; color:var(--ink); border-color:#fff; }
.btn--wa{ background:#25D366; color:#fff; box-shadow:0 8px 22px -14px rgba(37,211,102,.9); }
.btn--wa:hover{ background:#1EBE5A; transform:translateY(-2px); box-shadow:0 14px 30px -12px rgba(37,211,102,.7); }

/* Text link with underline motion */
.link-arrow{ display:inline-flex; align-items:center; gap:8px; font-weight:700; color:var(--accent); font-family:var(--f-sans); }
html[lang="ar"] .link-arrow{ font-family:var(--f-ar); }
.link-arrow .arw{ transition:transform .3s var(--ease); }
.link-arrow:hover .arw{ transform:translateX(4px); }
html[dir="rtl"] .link-arrow .arw{ transform:scaleX(-1); }
html[dir="rtl"] .link-arrow:hover .arw{ transform:scaleX(-1) translateX(4px); }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; inset-block-start:0; inset-inline:0; z-index:100;
  height:var(--header-h);
  display:flex; align-items:center;
  transition: background .4s var(--ease), box-shadow .4s var(--ease), height .4s var(--ease);
}
.site-header .container{ display:flex; align-items:center; justify-content:space-between; gap:24px; }
.site-header.scrolled{ background:var(--header-bg); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line); height:70px; }

.brand{ display:flex; align-items:center; gap:12px; font-family:var(--f-serif); font-weight:700; font-size:1.5rem; letter-spacing:.14em; color:#fff; }
.brand .mark{ width:34px; height:34px; flex:0 0 auto; }
.brand-studio{ font-weight:400; font-size:.56em; letter-spacing:.26em; opacity:.82; margin-inline-start:.4em; }
.site-header.scrolled .brand{ color:var(--ink); }
html[lang="ar"] .brand .brand-txt{ font-family:var(--f-serif); font-weight:700; letter-spacing:.04em; }

.nav{ display:flex; align-items:center; gap:6px; }
.nav a{
  padding:10px 16px; font-size:.9rem; font-weight:600; color:rgba(255,255,255,.9);
  border-radius:var(--radius); transition:color .25s, background .25s; position:relative;
}
.site-header.scrolled .nav a{ color:var(--ink-2); }
.nav a:hover{ color:#fff; }
.site-header.scrolled .nav a:hover{ color:var(--accent); }
.nav a.active{ color:var(--accent); }
.site-header.scrolled .nav a.active{ color:var(--accent); }
.nav a.active::after{
  content:""; position:absolute; inset-block-end:2px; inset-inline:16px; height:2px; background:var(--accent);
}

.header-actions{ display:flex; align-items:center; gap:14px; }
.lang-toggle{
  display:inline-flex; align-items:center; gap:6px; padding:8px 14px;
  border:1px solid rgba(255,255,255,.35); border-radius:100px; font-weight:700; font-size:.82rem;
  color:#fff; transition:all .3s;
}
.lang-toggle:hover{ background:#fff; color:var(--ink); }
.site-header.scrolled .lang-toggle{ border-color:var(--line); color:var(--ink); }
.site-header.scrolled .lang-toggle:hover{ background:var(--ink); color:#fff; }

.theme-toggle{ display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border:1px solid rgba(255,255,255,.35); border-radius:50%; color:#fff; transition:all .3s; }
.theme-toggle:hover{ background:#fff; color:var(--ink); }
.site-header.scrolled .theme-toggle{ border-color:var(--line); color:var(--ink); }
.site-header.scrolled .theme-toggle:hover{ background:var(--ink); color:var(--bg); }
.theme-toggle svg{ width:18px; height:18px; }
.theme-toggle .icon-sun{ display:none; }
html[data-theme="dark"] .theme-toggle .icon-sun{ display:block; }
html[data-theme="dark"] .theme-toggle .icon-moon{ display:none; }

.menu-btn{ display:none; width:44px; height:44px; align-items:center; justify-content:center; color:#fff; }
.site-header.scrolled .menu-btn{ color:var(--ink); }
.menu-btn svg{ width:26px; height:26px; }

/* Mobile drawer */
.drawer{
  position:fixed; inset:0; z-index:200; background:var(--dark);
  display:flex; flex-direction:column; padding: 30px var(--gutter);
  transform: translateX(-100%); visibility:hidden; transition: transform .45s var(--ease), visibility .45s;
}
html[dir="rtl"] .drawer{ transform: translateX(100%); }
.drawer.open{ transform:translateX(0); visibility:visible; }
.drawer-top{ display:flex; align-items:center; justify-content:space-between; }
.drawer .brand{ color:#fff; }
.drawer-close{ color:#fff; width:44px; height:44px; }
.drawer-close svg{ width:26px; height:26px; }
.drawer nav{ margin-top:40px; display:flex; flex-direction:column; gap:4px; }
.drawer nav a{ font-family:var(--f-serif); font-size:1.9rem; color:#EDE9E0; padding:12px 0; border-bottom:1px solid rgba(255,255,255,.08); }
html[lang="ar"] .drawer nav a{ font-family:var(--f-ar); font-weight:700; }
.drawer nav a.active{ color:var(--accent); }
.drawer-foot{ margin-top:auto; color:#B8B2A5; font-size:.9rem; }
.drawer-foot a{ color:#EDE9E0; }

/* =========================================================
   HERO
   ========================================================= */
.hero{ position:relative; min-height:100vh; display:flex; align-items:center; color:#fff; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:-2; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; }
.hero__bg::after{
  content:""; position:absolute; inset:0;
  background: linear-gradient(180deg, rgba(10,8,5,.62) 0%, rgba(10,8,5,.4) 42%, rgba(10,8,5,.88) 100%);
}
.hero__inner{ position:relative; z-index:2; padding-block: 140px 90px; max-width:820px; }
.hero h1{ font-size: clamp(2.6rem, 6.4vw, 5.4rem); color:#fff; line-height:1.05; }
.hero .lead{ color:rgba(255,255,255,.88); font-size:1.15rem; max-width:56ch; margin-top:22px; }
.hero .kicker{ color:#E9CFA6; }
.hero .kicker::before{ background:#E9CFA6; }
.hero-cta{ display:flex; flex-wrap:wrap; gap:16px; margin-top:36px; }
.hero-scroll{
  position:absolute; inset-block-end:26px; inset-inline-start:50%; transform:translateX(-50%);
  z-index:2; color:rgba(255,255,255,.7); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
  display:flex; flex-direction:column; align-items:center; gap:10px;
}
.hero-scroll .line{ width:1px; height:46px; background:rgba(255,255,255,.5); animation: scrollLine 2s var(--ease) infinite; transform-origin:top; }
@keyframes scrollLine{ 0%{transform:scaleY(0)} 40%{transform:scaleY(1)} 100%{transform:scaleY(0); transform-origin:bottom} }

/* Small page hero (inner pages) */
.page-hero{ position:relative; min-height:56vh; display:flex; align-items:flex-end; color:#fff; overflow:hidden; }
.page-hero__bg{ position:absolute; inset:0; z-index:-2; }
.page-hero__bg img{ width:100%; height:100%; object-fit:cover; }
.page-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,13,9,.4), rgba(15,13,9,.82)); }
.page-hero__inner{ padding-block: 0 60px; position:relative; z-index:2; }
.page-hero h1{ font-size:clamp(2.2rem,5vw,4rem); color:#fff; }
.breadcrumbs{ display:flex; gap:10px; align-items:center; color:rgba(255,255,255,.75); font-size:.85rem; margin-bottom:18px; }
.breadcrumbs a:hover{ color:#fff; }
.breadcrumbs .sep{ opacity:.5; }

/* =========================================================
   STATS
   ========================================================= */
.stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:30px; }
.stat{ text-align:center; }
.stat .num{ font-family:var(--f-serif); font-size:clamp(2.4rem,5vw,3.6rem); font-weight:600; color:var(--accent); line-height:1; }
html[lang="ar"] .stat .num{ font-family:var(--f-ar-head); font-weight:800; }
.stat .label{ margin-top:10px; color:var(--ink-2); font-weight:600; font-size:.92rem; }
.bg-dark .stat .label{ color:#C9C3B6; }

/* =========================================================
   SECTION HEADER (shared)
   ========================================================= */
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:30px; flex-wrap:wrap; margin-bottom:52px; }
.sec-head .txt{ max-width:640px; }

/* =========================================================
   ABOUT / SPLIT
   ========================================================= */
.split{ display:grid; grid-template-columns:1.05fr 1fr; gap:clamp(30px,5vw,70px); align-items:center; }
.split__media{ position:relative; }
.split__media img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-md); width:100%; }
.split__media .badge{
  position:absolute; inset-block-end:-26px; inset-inline-end:-14px;
  background:var(--accent); color:#fff; padding:22px 26px; border-radius:var(--radius-lg);
  box-shadow:var(--shadow-md); max-width:220px;
}
.split__media .badge b{ font-family:var(--f-serif); font-size:2.2rem; display:block; line-height:1; }
html[lang="ar"] .split__media .badge b{ font-family:var(--f-ar-head); }
.feature-list{ display:grid; gap:18px; margin-top:26px; }
.feature-list li{ display:flex; gap:14px; align-items:flex-start; }
.feature-list .ic{ flex:0 0 auto; width:34px; height:34px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; }
.feature-list .ic svg{ width:18px; height:18px; }
.feature-list b{ display:block; color:var(--ink); }
.feature-list span{ color:var(--ink-2); font-size:.95rem; }

/* =========================================================
   SERVICES
   ========================================================= */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:38px 32px; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  position:relative; overflow:hidden;
}
.card::before{ content:""; position:absolute; inset-block-start:0; inset-inline-start:0; width:100%; height:3px; background:var(--accent); transform:scaleX(0); transform-origin:inline-start; transition:transform .4s var(--ease); }
.card:hover{ transform:translateY(-6px); box-shadow:var(--shadow-md); border-color:transparent; }
.card:hover::before{ transform:scaleX(1); }
.card .ic{ width:58px; height:58px; border-radius:12px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; margin-bottom:22px; }
.card .ic svg{ width:28px; height:28px; }
.card h3{ font-size:1.28rem; margin-bottom:12px; }
.card p{ color:var(--ink-2); font-size:.96rem; }
.card .num-ghost{ position:absolute; inset-block-start:22px; inset-inline-end:26px; font-family:var(--f-serif); font-size:2.2rem; color:var(--line); font-weight:600; }

/* =========================================================
   PROJECTS
   ========================================================= */
.filters{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin-bottom:44px; }
.filters button{
  padding:10px 22px; border-radius:100px; border:1px solid var(--line); font-weight:600; font-size:.9rem;
  color:var(--ink-2); transition:all .3s;
}
.filters button:hover{ border-color:var(--ink); }
.filters button.active{ background:var(--ink); color:#fff; border-color:var(--ink); }

.grid-projects{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.grid-projects.two{ grid-template-columns:repeat(2,1fr); }
.p-card{ position:relative; border-radius:var(--radius-lg); overflow:hidden; display:block; aspect-ratio:4/3; background:var(--surface-2); }
.p-card img{ width:100%; height:100%; object-fit:cover; transition:transform .8s var(--ease); }
.p-card:hover img{ transform:scale(1.06); }
.p-card__overlay{
  position:absolute; inset:0; display:flex; flex-direction:column; justify-content:flex-end;
  padding:26px; color:#fff;
  background:linear-gradient(180deg, rgba(15,13,9,0) 35%, rgba(15,13,9,.85) 100%);
}
.p-card__tag{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:#E9CFA6; font-weight:700; margin-bottom:8px; opacity:0; transform:translateY(10px); transition:.45s var(--ease); }
.p-card__title{ font-family:var(--f-serif); font-size:1.4rem; color:#fff; }
html[lang="ar"] .p-card__title{ font-family:var(--f-ar-head); font-weight:700; }
.p-card__meta{ font-size:.86rem; color:rgba(255,255,255,.8); margin-top:4px; opacity:0; max-height:0; transition:.45s var(--ease); }
.p-card:hover .p-card__tag{ opacity:1; transform:translateY(0); }
.p-card:hover .p-card__meta{ opacity:1; max-height:40px; }
.p-card__plus{ position:absolute; inset-block-start:20px; inset-inline-end:20px; width:44px; height:44px; border-radius:50%; background:rgba(255,255,255,.15); backdrop-filter:blur(4px); display:grid; place-items:center; color:#fff; opacity:0; transform:scale(.8); transition:.4s var(--ease); }
.p-card:hover .p-card__plus{ opacity:1; transform:scale(1); }

/* =========================================================
   PROCESS
   ========================================================= */
.process{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; counter-reset:step; }
.step{ position:relative; padding-top:30px; }
.step__n{ font-family:var(--f-serif); font-size:1.1rem; font-weight:700; color:var(--accent); border:1.5px solid var(--accent); width:52px; height:52px; border-radius:50%; display:grid; place-items:center; margin-bottom:20px; }
html[lang="ar"] .step__n{ font-family:var(--f-ar-head); }
.step h3{ font-size:1.16rem; margin-bottom:10px; }
.step p{ color:var(--ink-2); font-size:.94rem; }
.bg-dark .step p{ color:#C9C3B6; }
.step::before{ content:""; position:absolute; inset-block-start:56px; inset-inline-start:52px; width:calc(100% - 40px); height:1px; background:var(--line); }
.bg-dark .step::before{ background:rgba(255,255,255,.14); }
.process .step:last-child::before{ display:none; }

/* =========================================================
   CTA BANNER
   ========================================================= */
.cta-band{ position:relative; overflow:hidden; color:#fff; }
.cta-band__bg{ position:absolute; inset:0; z-index:-2; }
.cta-band__bg img{ width:100%; height:100%; object-fit:cover; }
.cta-band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(120deg, rgba(23,21,15,.92), rgba(23,21,15,.6)); }
.cta-band h2{ color:#fff; font-size:clamp(2rem,4vw,3.2rem); max-width:18ch; }
.cta-band p{ color:rgba(255,255,255,.85); max-width:52ch; margin-top:16px; }

/* =========================================================
   TESTIMONIALS
   ========================================================= */
.quote{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:38px 34px; }
.quote .mark{ font-family:var(--f-serif); font-size:4rem; line-height:.6; color:var(--accent); height:34px; }
.quote p{ font-size:1.08rem; color:var(--ink); line-height:1.7; }
html[lang="en"] .quote p{ font-family:var(--f-sans); font-size:1.12rem; font-weight:500; }
.quote .who{ margin-top:22px; display:flex; align-items:center; gap:12px; }
.quote .who .av{ width:46px; height:46px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-weight:800; }
.quote .who b{ display:block; }
.quote .who span{ color:var(--ink-3); font-size:.85rem; }

/* =========================================================
   CONTACT
   ========================================================= */
.contact-grid{ display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(30px,5vw,64px); }
.info-item{ display:flex; gap:16px; padding:22px 0; border-bottom:1px solid var(--line); }
.info-item:last-child{ border-bottom:none; }
.info-item .ic{ flex:0 0 auto; width:48px; height:48px; border-radius:12px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; }
.info-item .ic svg{ width:22px; height:22px; }
.info-item b{ display:block; margin-bottom:2px; }
.info-item span,.info-item a{ color:var(--ink-2); }
.info-item a:hover{ color:var(--accent); }

form.axis-form{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(26px,4vw,42px); box-shadow:var(--shadow-sm); }
.field{ margin-bottom:20px; }
.field label{ display:block; font-weight:600; font-size:.88rem; margin-bottom:8px; color:var(--ink); }
.field input,.field select,.field textarea{
  width:100%; padding:14px 16px; border:1px solid var(--line); border-radius:var(--radius);
  font-family:inherit; font-size:.96rem; color:var(--ink); background:var(--bg); transition:border-color .25s, box-shadow .25s;
}
.field textarea{ resize:vertical; min-height:130px; }
.field input:focus,.field select:focus,.field textarea:focus{ outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(176,122,60,.15); }
.field-row{ display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-note{ font-size:.85rem; color:var(--ink-3); margin-top:6px; }
.form-status{ margin-top:16px; font-weight:600; display:none; }
.form-status.ok{ display:block; color:#2E7D4F; }

.map-embed{ border-radius:var(--radius-lg); overflow:hidden; border:1px solid var(--line); height:340px; }
.map-embed iframe{ width:100%; height:100%; border:0; filter:grayscale(.3) contrast(1.05); }

/* =========================================================
   BLOG
   ========================================================= */
.grid-blog{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.post{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s; display:flex; flex-direction:column; }
.post:hover{ transform:translateY(-5px); box-shadow:var(--shadow-md); }
.post .thumb{ aspect-ratio:16/10; overflow:hidden; }
.post .thumb img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.post:hover .thumb img{ transform:scale(1.05); }
.post .body{ padding:26px 24px 28px; flex:1; display:flex; flex-direction:column; }
.post .cat{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); font-weight:700; }
.post h3{ font-size:1.24rem; margin:10px 0 12px; }
.post p{ color:var(--ink-2); font-size:.94rem; flex:1; }
.post .foot{ margin-top:18px; display:flex; align-items:center; justify-content:space-between; color:var(--ink-3); font-size:.84rem; }

/* =========================================================
   PROJECT DETAIL
   ========================================================= */
.pd-hero{ position:relative; min-height:70vh; display:flex; align-items:flex-end; color:#fff; }
.pd-hero__bg{ position:absolute; inset:0; z-index:-2; }
.pd-hero__bg img{ width:100%; height:100%; object-fit:cover; }
.pd-hero__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,13,9,.2), rgba(15,13,9,.82)); }
.pd-hero__inner{ position:relative; z-index:2; padding-block:0 54px; }
.pd-meta{ display:grid; grid-template-columns:repeat(4,1fr); gap:24px; border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px; background:var(--surface); }
.pd-meta .k{ font-size:.76rem; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-3); font-weight:700; }
.pd-meta .v{ font-weight:600; margin-top:6px; color:var(--ink); }
.pd-gallery{ display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.pd-gallery a{ border-radius:var(--radius-lg); overflow:hidden; aspect-ratio:16/10; }
.pd-gallery a.wide{ grid-column:1 / -1; aspect-ratio:16/7; }
.pd-gallery img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease); }
.pd-gallery a:hover img{ transform:scale(1.04); }

/* =========================================================
   LIGHTBOX
   ========================================================= */
.lightbox{ position:fixed; inset:0; z-index:300; background:rgba(15,13,9,.94); display:none; align-items:center; justify-content:center; padding:30px; }
.lightbox.open{ display:flex; }
.lightbox img{ max-width:92vw; max-height:88vh; border-radius:6px; box-shadow:0 30px 80px rgba(0,0,0,.6); }
.lightbox .close{ position:absolute; inset-block-start:24px; inset-inline-end:30px; color:#fff; width:48px; height:48px; }
.lightbox .close svg{ width:30px; height:30px; }
.lightbox .nav-btn{ position:absolute; inset-block-start:50%; transform:translateY(-50%); color:#fff; width:56px; height:56px; display:grid; place-items:center; background:rgba(255,255,255,.1); border-radius:50%; }
.lightbox .prev{ inset-inline-start:24px; } .lightbox .next{ inset-inline-end:24px; }
html[dir="rtl"] .lightbox .nav-btn svg{ transform:scaleX(-1); }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ background:var(--dark); color:#C9C3B6; padding-block:72px 0; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.4fr; gap:40px; }
.footer-grid .brand{ color:#fff; margin-bottom:18px; }
.footer-about p{ color:#A8A296; font-size:.95rem; max-width:34ch; }
.footer-col h4{ color:#fff; font-size:1rem; margin-bottom:20px; font-family:var(--f-sans); letter-spacing:.02em; }
html[lang="ar"] .footer-col h4{ font-family:var(--f-ar); }
.footer-col a{ display:block; padding:7px 0; color:#A8A296; transition:color .25s, padding .25s; font-size:.94rem; }
.footer-col a:hover{ color:#fff; padding-inline-start:6px; }
.socials{ display:flex; gap:12px; margin-top:20px; }
.socials a{ width:42px; height:42px; border-radius:50%; border:1px solid rgba(255,255,255,.16); display:grid; place-items:center; color:#EDE9E0; transition:all .3s; }
.socials a:hover{ background:var(--accent); border-color:var(--accent); color:#fff; }
.socials svg{ width:18px; height:18px; }
.footer-bottom{ margin-top:60px; border-top:1px solid rgba(255,255,255,.1); padding-block:26px; display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; color:#8E887C; font-size:.86rem; }
.footer-bottom a:hover{ color:#fff; }

/* Newsletter */
.newsletter{ display:flex; gap:10px; margin-top:16px; }
.newsletter input{ flex:1; padding:13px 16px; border-radius:var(--radius); border:1px solid rgba(255,255,255,.16); background:rgba(255,255,255,.05); color:#fff; font-family:inherit; }
.newsletter input::placeholder{ color:#8E887C; }
.newsletter input:focus{ outline:none; border-color:var(--accent); }
.newsletter button{ background:var(--accent); color:#fff; padding:0 18px; border-radius:var(--radius); display:grid; place-items:center; transition:background .3s; }
.newsletter button:hover{ background:var(--accent-2); }
html[dir="rtl"] .newsletter button svg{ transform:scaleX(-1); }

/* =========================================================
   FLOATING WHATSAPP
   ========================================================= */
.wa-float{
  position:fixed; inset-block-end:26px; inset-inline-end:26px; z-index:150;
  width:58px; height:58px; border-radius:50%; background:#25D366; color:#fff;
  display:grid; place-items:center; box-shadow:0 12px 30px -8px rgba(37,211,102,.65);
  transition:transform .3s var(--ease), box-shadow .3s;
}
.wa-float:hover{ transform:scale(1.09); box-shadow:0 16px 36px -8px rgba(37,211,102,.75); }
.wa-float svg{ width:31px; height:31px; }
.wa-float::after{ content:""; position:absolute; inset:0; border-radius:50%; border:2px solid #25D366; animation:waPulse 2.2s ease-out infinite; }
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.6 } 100%{ transform:scale(1.6); opacity:0 } }
@media (max-width:560px){ .wa-float{ width:52px; height:52px; inset-block-end:20px; inset-inline-end:20px; } .wa-float svg{ width:27px; height:27px; } }

/* =========================================================
   REVEAL ANIMATIONS
   ========================================================= */
.reveal{ opacity:0; transform:translateY(28px); transition: opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s } .reveal.d2{ transition-delay:.16s } .reveal.d3{ transition-delay:.24s } .reveal.d4{ transition-delay:.32s }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } .hero-scroll .line{ animation:none; } html{ scroll-behavior:auto; } }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width: 1024px){
  .cards, .grid-projects, .grid-blog{ grid-template-columns:repeat(2,1fr); }
  .process{ grid-template-columns:repeat(2,1fr); }
  .step::before{ display:none; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:34px; }
  .pd-meta{ grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 860px){
  .nav{ display:none; }
  .hide-mobile-cta{ display:none; }
  .menu-btn{ display:flex; }
  .split{ grid-template-columns:1fr; }
  .split__media{ order:-1; }
  .split__media .badge{ inset-inline-end:16px; }
  .stats{ grid-template-columns:repeat(2,1fr); gap:34px 20px; }
  .contact-grid{ grid-template-columns:1fr; }
  .sec-head{ margin-bottom:38px; }
}
@media (max-width: 560px){
  .cards, .grid-projects, .grid-projects.two, .grid-blog, .process{ grid-template-columns:1fr; }
  .field-row{ grid-template-columns:1fr; }
  .pd-meta{ grid-template-columns:1fr; }
  .pd-gallery{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ justify-content:center; }
}
