/@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;0,700;1,300;1,400;1,500;1,600;1,700&family=Jost:wght@300;400;500;600&family=JetBrains+Mono:wght@400;500&family=Noto+Naskh+Arabic:wght@400;500;600;700&family=Tajawal:wght@300;400;500;700&display=swap');

/* ——— Variables ——— */
:root {
  --ink: #0D0D0D;
  --ink-1: #111111;
  --ink-2: #161616;
  --ink-3: #1C1C1C;
  --ink-4: #242424;
  --paper: #F5F5F5;
  --paper-2: #EAE7E0;
  --paper-3: #C9C6BF;
  --mute: #8A8A88;
  --mute-2: #5C5C5A;
  --gold: #D4AF37;
  --gold-2: #B8962E;
  --gold-soft: #E7CC7B;
  --line: rgba(245,245,245,.10);
  --line-2: rgba(245,245,245,.18);
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: "Jost", "Helvetica Neue", Arial, sans-serif;
  --mono: "JetBrains Mono", ui-monospace, monospace;
  --maxw: 1320px;
  --gutter: clamp(20px, 4vw, 56px);
}

/* ——— Reset ——— */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--sans);
  background: var(--ink);
  color: var(--paper);
  font-weight: 300;
  font-size: 15px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

/* ——— Typographie ——— */
h1, h2, h3 {
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing: -0.01em;
  line-height: 1.02;
  margin: 0;
}
h1 { font-size: clamp(48px, 8vw, 120px); }
h2 { font-size: clamp(36px, 5vw, 72px); }
h3 { font-size: clamp(22px, 2vw, 30px); }

.eyebrow {
  font-family: var(--sans);
  font-size: 11px;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--gold);
  font-weight: 500;
  display: block;
}
.kicker {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mute);
}
.lede {
  font-family: var(--serif);
  font-weight: 300;
  font-style: italic;
  color: var(--paper-2);
  font-size: clamp(18px, 1.6vw, 22px);
  line-height: 1.4;
}
.muted { color: var(--mute); }
.gold { color: var(--gold); }
.center { text-align: center; }
.row { display: flex; gap: 18px; align-items: center; }
.between { display: flex; justify-content: space-between; align-items: center; gap: 18px; flex-wrap: wrap; }

/* ——— Layout ——— */
.wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 var(--gutter);
}
.section { padding: clamp(80px, 10vw, 140px) 0; }
.rule { height: 1px; background: var(--line); border: 0; margin: 0; }

/* ——— Buttons ——— */
.btn {
  display: inline-flex !important;
  align-items: center;
  gap: 12px;
  padding: 14px 26px !important;
  font-family: var(--sans) !important;
  font-size: 11px !important;
  letter-spacing: .26em !important;
  text-transform: uppercase !important;
  border: 1px solid var(--gold) !important;
  color: var(--gold) !important;
  background: transparent !important;
  transition: all .3s ease !important;
  cursor: pointer;
  border-radius: 0 !important;
}
.btn:hover { background: var(--gold) !important; color: var(--ink) !important; }
.btn.solid { background: var(--gold) !important; color: var(--ink) !important; }
.btn.solid:hover { background: var(--gold-2) !important; border-color: var(--gold-2) !important; }
.btn.ghost { border-color: var(--line-2) !important; color: var(--paper) !important; }
.btn.ghost:hover { border-color: var(--gold) !important; color: var(--gold) !important; background: transparent !important; }
.btn.sm { padding: 10px 18px !important; font-size: 10px !important; }
.btn .arrow { width: 14px; height: 1px; background: currentColor; position: relative; display: inline-block; }
.btn .arrow::after {
  content: "";
  position: absolute;
  right: 0; top: -3px;
  width: 7px; height: 7px;
  border-top: 1px solid currentColor;
  border-right: 1px solid currentColor;
  transform: rotate(45deg);
}

/* ——— WhatsApp ——— */
.wa {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: #25D366;
  color: #0a2e16 !important;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 500;
}
.wa:hover { background: #1ebd5b; }
.wa-float {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 9999;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  background: #25D366;
  color: #0a2e16 !important;
  font-size: 11px;
  letter-spacing: .2em;
  text-transform: uppercase;
  font-weight: 500;
}
.wa-float:hover { background: #1ebd5b; }

/* ——— Placeholders ——— */
.ph {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(120% 80% at 70% 0%, rgba(212,175,55,.18) 0%, rgba(212,175,55,0) 50%),
    radial-gradient(80% 60% at 20% 100%, rgba(70,40,20,.45) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(135deg, #2a201a 0%, #161312 45%, #0a0a0a 100%);
}
.ph::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image: repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 1px, transparent 1px 6px);
}
.ph::after {
  content: attr(data-label);
  position: absolute;
  left: 14px; bottom: 12px;
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .14em;
  color: rgba(245,245,245,.45);
  text-transform: uppercase;
  border: 1px solid rgba(245,245,245,.18);
  padding: 4px 8px;
  background: rgba(13,13,13,.4);
}
.ph.cool {
  background:
    radial-gradient(100% 70% at 30% 10%, rgba(180,200,220,.18) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(160deg, #1c2733 0%, #131820 50%, #0a0a0a 100%);
}
.ph.warm {
  background:
    radial-gradient(120% 80% at 80% 20%, rgba(212,175,55,.28) 0%, rgba(212,175,55,0) 55%),
    linear-gradient(150deg, #3a2a1d 0%, #1a140f 50%, #0a0a0a 100%);
}
.ph.deep {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(60,55,45,.45) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(180deg, #161514 0%, #0a0a0a 100%);
}
.ph.sun {
  background:
    radial-gradient(80% 50% at 60% 80%, rgba(232,180,80,.35) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(160deg, #1f1a14 0%, #100d0a 60%, #060606 100%);
}
.ph.mar {
  background:
    radial-gradient(70% 60% at 30% 30%, rgba(120,100,70,.30) 0%, rgba(13,13,13,0) 60%),
    linear-gradient(140deg, #251c14 0%, #14100c 50%, #080807 100%);
}
.ph.horizon {
  background:
    radial-gradient(120% 80% at 70% 0%, rgba(212,175,55,.18) 0%, rgba(212,175,55,0) 50%),
    linear-gradient(135deg, #2a201a 0%, #161312 45%, #0a0a0a 100%);
}

/* ——— Hero ——— */
.hero {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: flex-end;
  padding-top: 140px;
  padding-bottom: 60px;
  overflow: hidden;
}
.hero-media {
  position: absolute;
  inset: 0;
  z-index: 0;
  background: var(--ink-2);
}
.hero-media::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(13,13,13,.35) 0%, rgba(13,13,13,.15) 35%, rgba(13,13,13,.85) 100%),
    linear-gradient(90deg, rgba(13,13,13,.6) 0%, rgba(13,13,13,0) 50%);
}
.hero-inner {
  position: relative;
  z-index: 2;
  width: 100%;
  display: grid;
  gap: 56px;
}
.hero-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  gap: 32px;
  flex-wrap: wrap;
}
.hero-title h1 { color: var(--paper); font-weight: 300; }
.hero-title h1 em { font-style: italic; color: var(--gold); font-weight: 400; }
.hero-meta { text-align: right; display: flex; flex-direction: column; gap: 10px; }
.hero-slogan {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-top: 22px;
  color: var(--paper-2);
  font-family: var(--serif);
  font-style: italic;
  font-size: clamp(18px, 1.6vw, 22px);
}
.hero-slogan .dot { width: 6px; height: 6px; background: var(--gold); border-radius: 50%; }
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  border-top: 1px solid var(--line);
}
.hero-stats .stat { padding: 24px 0; border-right: 1px solid var(--line); }
.hero-stats .stat:last-child { border-right: 0; }
.hero-stats .num { font-family: var(--serif); font-size: 40px; color: var(--paper); line-height: 1; }
.hero-stats .num em { color: var(--gold); font-style: normal; }
.hero-stats .lbl { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--mute); margin-top: 10px; }

/* ——— Search ——— */
.search {
  background: rgba(13,13,13,.78);
  backdrop-filter: blur(18px);
  border: 1px solid var(--line-2);
  display: grid;
  grid-template-columns: repeat(6, 1fr) auto;
}
.search .tabs { grid-column: 1 / -1; display: flex; border-bottom: 1px solid var(--line); }
.search .tab {
  padding: 16px 28px;
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  color: var(--mute);
  cursor: pointer;
  border-right: 1px solid var(--line);
  background: transparent;
  border-top: 0; border-bottom: 0; border-left: 0;
  font-family: var(--sans);
}
.search .tab.on { color: var(--gold); background: rgba(212,175,55,.06); }
.search .field {
  padding: 18px 22px;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.search .field label { font-size: 10px; letter-spacing: .24em; text-transform: uppercase; color: var(--mute); }
.search .field select,
.search .field input {
  background: transparent;
  border: 0;
  color: var(--paper);
  font-family: var(--sans);
  font-size: 14px;
  padding: 0;
  outline: none;
  appearance: none;
}
.search .submit {
  background: var(--gold);
  color: var(--ink);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 32px;
  font-size: 11px;
  letter-spacing: .26em;
  text-transform: uppercase;
  border: 0;
  min-width: 180px;
}
.search .submit:hover { background: var(--gold-2); }

/* ——— Cards ——— */
.card {
  background: var(--ink-1);
  border: 1px solid var(--line);
  display: flex;
  flex-direction: column;
  transition: border-color .3s ease;
}
.card:hover { border-color: var(--gold); }
.card:hover .card-img { transform: scale(1.04); }
.card-media { position: relative; overflow: hidden; aspect-ratio: 4/3; }
.card-img { position: absolute; inset: 0; transition: transform .8s ease; }
.card-badge {
  position: absolute; top: 14px; left: 14px;
  font-family: var(--sans); font-size: 10px;
  letter-spacing: .22em; text-transform: uppercase;
  padding: 6px 10px;
  background: rgba(13,13,13,.7); color: var(--gold);
  border: 1px solid var(--gold);
}
.card-body { padding: 22px; display: flex; flex-direction: column; gap: 14px; }
.card-loc {
  font-family: var(--sans); font-size: 11px;
  letter-spacing: .22em; text-transform: uppercase;
  color: var(--mute); display: flex; align-items: center; gap: 8px;
}
.card-loc::before { content: ""; width: 4px; height: 4px; background: var(--gold); border-radius: 50%; }
.card-title { font-family: var(--serif); font-size: 26px; line-height: 1.1; color: var(--paper); font-weight: 400; }
.card-meta { display: flex; gap: 18px; padding-top: 14px; border-top: 1px solid var(--line); font-size: 12px; color: var(--mute-2); }
.card-meta b { color: var(--paper-2); font-weight: 500; }
.card-foot { display: flex; justify-content: space-between; align-items: flex-end; padding-top: 14px; border-top: 1px solid var(--line); }
.card-price { font-family: var(--serif); font-size: 26px; color: var(--gold); line-height: 1; }
.card-price small { font-family: var(--sans); font-size: 11px; color: var(--mute); letter-spacing: .2em; }
.card-cta { font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--paper-2); display: flex; align-items: center; gap: 8px; }
.card-cta:hover { color: var(--gold); }

/* ——— Section header ——— */
.s-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; margin-bottom: 56px; flex-wrap: wrap; }
.s-head .left { max-width: 720px; }
.s-head h2 em { font-style: italic; color: var(--gold); font-weight: 400; }

/* ——— Chips ——— */
.chips { display: flex; gap: 10px; flex-wrap: wrap; margin-bottom: 36px; }
.chip {
  padding: 10px 18px; border: 1px solid var(--line-2);
  font-size: 11px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--paper-2); background: transparent; cursor: pointer;
}
.chip:hover { color: var(--gold); border-color: var(--gold); }
.chip.on { color: var(--ink); background: var(--gold); border-color: var(--gold); }

/* ——— Grids ——— */
.grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; }
.grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px; }
.grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px; }

/* ——— Services ——— */
.services { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; border-top: 1px solid var(--line); }
.service {
  padding: 40px 32px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 14px;
  transition: background .3s ease;
}
.service:hover { background: rgba(212,175,55,.04); }
.service:last-child { border-right: 0; }
.service-num { font-family: var(--mono); font-size: 11px; color: var(--mute); letter-spacing: .18em; }
.service h3 { color: var(--paper); font-size: 28px; }
.service p { color: var(--mute); margin: 0; }
.service .more { margin-top: auto; font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--gold); }

/* ——— About ——— */
.about-strip { display: grid; grid-template-columns: 1.1fr .9fr; gap: 80px; align-items: center; }
.about-strip .media { aspect-ratio: 4/5; }

/* ——— CTA wide ——— */
.cta-wide {
  position: relative; padding: clamp(80px, 10vw, 140px) 0;
  text-align: center; overflow: hidden;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.cta-wide .bg { position: absolute; inset: 0; opacity: .6; }
.cta-wide .bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(13,13,13,.55) 0%, rgba(13,13,13,.92) 100%);
}
.cta-wide .inner { position: relative; z-index: 1; }
.cta-wide h2 { max-width: 900px; margin: 18px auto 28px; }
.cta-wide .ctas { margin-top: 40px; display: inline-flex; gap: 14px; flex-wrap: wrap; justify-content: center; }

/* ——— Testimonials ——— */
.quote { padding: 48px; border: 1px solid var(--line); display: flex; flex-direction: column; gap: 28px; background: var(--ink-1); }
.quote p { font-family: var(--serif); font-style: italic; font-size: 22px; line-height: 1.45; color: var(--paper); margin: 0; }
.quote .who { display: flex; align-items: center; gap: 14px; padding-top: 24px; border-top: 1px solid var(--line); }
.quote .avatar { width: 48px; height: 48px; }
.quote .nm { font-family: var(--sans); font-size: 14px; color: var(--paper); }
.quote .role { font-size: 11px; letter-spacing: .22em; text-transform: uppercase; color: var(--mute); margin-top: 4px; }

/* ——— Newsletter ——— */
.news { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; align-items: center; }
.news input {
  background: transparent; border: 0; border-bottom: 1px solid var(--line-2);
  padding: 16px 0; color: var(--paper); font-family: var(--sans); font-size: 15px;
  width: 100%; outline: none;
}
.news input:focus { border-color: var(--gold); }
.news form { display: flex; gap: 14px; align-items: flex-end; }

/* ——— Marquee ——— */
.marquee { overflow: hidden; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 22px 0; background: var(--ink-1); }
.marquee-track {
  display: flex; gap: 60px; white-space: nowrap;
  animation: auraya-scroll 38s linear infinite;
  font-family: var(--serif); font-size: 28px; color: var(--paper-2);
}
.marquee-track span { display: flex; align-items: center; gap: 60px; }
.marquee-track i { color: var(--gold); font-style: normal; }
@keyframes auraya-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ——— Footer ——— */
.foot { background: var(--ink); border-top: 1px solid var(--line); padding: 80px 0 32px; }
.foot-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: 56px; }
.foot h4 { font-family: var(--sans); font-size: 11px; letter-spacing: .26em; text-transform: uppercase; color: var(--gold); margin: 0 0 22px; }
.foot a { color: var(--paper-2); display: block; padding: 6px 0; font-size: 14px; }
.foot a:hover { color: var(--gold); }
.foot p { color: var(--mute); font-size: 14px; line-height: 1.7; }
.foot-bot {
  margin-top: 60px; padding-top: 24px; border-top: 1px solid var(--line);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 12px;
  font-size: 12px; color: var(--mute);
}

/* ——— Page header ——— */
.page-head { position: relative; padding: 200px 0 80px; border-bottom: 1px solid var(--line); overflow: hidden; }
.page-head .bg { position: absolute; inset: 0; z-index: 0; opacity: .5; }
.page-head .bg::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(13,13,13,.7) 0%, rgba(13,13,13,1) 100%);
}
.page-head .inner { position: relative; z-index: 1; }
.crumb { font-size: 11px; letter-spacing: .24em; text-transform: uppercase; color: var(--mute); margin-bottom: 20px; display: flex; gap: 12px; }
.crumb span { color: var(--gold); }

/* ——— Forms ——— */
.field { display: flex; flex-direction: column; gap: 8px; }
.field label { font-size: 10px; letter-spacing: .24em; text-transform: uppercase; color: var(--mute); }
.field input, .field select, .field textarea {
  background: var(--ink-2) !important; border: 1px solid var(--line) !important;
  color: var(--paper) !important; font-family: var(--sans) !important;
  font-size: 14px !important; padding: 14px 16px !important;
  outline: none !important; border-radius: 0 !important;
}
.field input:focus, .field select:focus, .field textarea:focus { border-color: var(--gold) !important; }
.field textarea { min-height: 120px; resize: vertical; }

/* ——— Pager ——— */
.pager { display: flex; gap: 8px; justify-content: center; margin-top: 60px; }
.pager a { width: 44px; height: 44px; display: grid; place-items: center; border: 1px solid var(--line); font-size: 13px; color: var(--paper-2); }
.pager a.on { background: var(--gold); color: var(--ink); border-color: var(--gold); }
.pager a:hover { border-color: var(--gold); color: var(--gold); }

/* ——— Nav Elementor ——— */
.elementor-nav-menu--main .elementor-item {
  padding-left: 14px !important;
  padding-right: 14px !important;
  letter-spacing: .18em !important;
  font-size: 12px !important;
  text-transform: uppercase !important;
  color: var(--paper-2) !important;
}
.elementor-nav-menu--main .elementor-item:hover,
.elementor-nav-menu--main .elementor-item.elementor-item-active {
  color: var(--gold) !important;
}

/* ——— Header ——— */
.elementor-location-header {
  background: transparent !important;
  transition: background .35s ease !important;
}

/* ——— Cacher titres WordPress ——— */
.entry-title, .page-title, .site-title,
.site-header, .site-branding,
#colophon, .site-footer, .site-info {
  display: none !important;
}

/* ——— Arabe RTL ——— */
[dir="rtl"] { font-family: 'Noto Naskh Arabic', 'Tajawal', serif !important; }
[dir="rtl"] h1, [dir="rtl"] h2, [dir="rtl"] h3 {
  font-family: 'Noto Naskh Arabic', serif !important;
  line-height: 1.4 !important;
}

/* ——— Responsive ——— */
@media (max-width: 1100px) {
  .grid-4 { grid-template-columns: repeat(2, 1fr); }
  .services { grid-template-columns: repeat(2, 1fr); }
  .foot-grid { grid-template-columns: 1fr 1fr; gap: 40px; }
}
@media (max-width: 1024px) {
  .grid-3 { grid-template-columns: repeat(2, 1fr); }
  .elementor-nav-menu--main { display: none !important; }
}
@media (max-width: 900px) {
  .grid-2 { grid-template-columns: 1fr; }
  .about-strip { grid-template-columns: 1fr; gap: 40px; }
  .news { grid-template-columns: 1fr; gap: 30px; }
  .search { grid-template-columns: 1fr 1fr; }
  .search .submit { grid-column: 1 / -1; padding: 18px; min-width: 0; }
}
@media (max-width: 640px) {
  .grid-3, .grid-4 { grid-template-columns: 1fr; }
  .hero-stats { grid-template-columns: repeat(2, 1fr); }
  .services { grid-template-columns: 1fr; }
  .foot-grid { grid-template-columns: 1fr; }
  .cta-wide .ctas { flex-direction: column; width: 100%; }
  .cta-wide .btn { width: 100%; justify-content: center !important; }
}