/* =========================================================
   Chibanis Algériens de France — refonte éditoriale
   ========================================================= */

:root{
  /* Palette — claire et joyeuse (par défaut) */
  --bg:        #fdf6e8;          /* crème solaire très clair */
  --bg-deep:   #f8edd2;          /* alt — pêche pâle */
  --ink:       #2e2418;          /* brun chaud, jamais noir */
  --ink-soft:  #6b5440;          /* corps texte secondaire */
  --muted:     #a09078;          /* meta */
  --rule:      #ead8b3;          /* hairlines */
  --paper:     #ffffff;          /* cartes blanches */

  --accent:    #d96d3a;          /* terracotta solaire */
  --accent-deep:#a84e1f;
  --accent-soft:#fde0c8;

  --tone-dz:   #5fa256;          /* vert pistache vif (DZ) */
  --tone-fr:   #4584b8;          /* bleu ciel (FR) */
  --tone-rouge:#e23a4a;          /* rouge — flag accent */

  /* Typo */
  --serif: "Cormorant Garamond", "EB Garamond", Georgia, serif;
  --sans:  "Public Sans", "Helvetica Neue", Arial, sans-serif;
  --arabic: "Amiri", "Cormorant Garamond", serif;

  --size-base: 18px;
  --lh: 1.65;

  --pad-section: 120px;
  --pad-block: 60px;
  --gutter: 32px;

  --maxw: 1240px;
  --maxw-text: 680px;
}

/* Tweaks: density */
[data-density="compact"]{
  --pad-section: 84px;
  --pad-block: 40px;
  --gutter: 24px;
}
[data-density="relaxed"]{
  --pad-section: 160px;
  --pad-block: 80px;
  --gutter: 40px;
}

/* Tweaks: senior mode */
[data-senior="true"]{
  --size-base: 21px;
  --lh: 1.75;
}

/* Tweaks: palette = forest */
[data-palette="forest"]{
  --accent:    #4a6b3e;
  --accent-deep:#2f4a26;
  --accent-soft:#dbe2cd;
}
/* Tweaks: palette = slate */
[data-palette="slate"]{
  --accent:    #2f4a5e;
  --accent-deep:#1d3041;
  --accent-soft:#d4dde4;
}
/* Tweaks: palette = ink */
[data-palette="ink"]{
  --accent:    #1a1612;
  --accent-deep:#000;
  --accent-soft:#e2dccf;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:var(--size-base);
  line-height:var(--lh);
  font-weight:400;
  font-feature-settings:"kern","liga","onum";
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;background:none;border:none;color:inherit}

::selection{background:var(--accent);color:var(--paper)}

/* ---------- typography ---------- */
.serif{font-family:var(--serif)}
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:600;
  display:inline-flex;align-items:center;gap:14px;
}
.eyebrow::before{
  content:""; width:32px; height:1px; background:currentColor; display:inline-block;
}
.eyebrow.center{justify-content:center}

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.08;
  letter-spacing:-.01em;
  color:var(--ink);
  text-wrap:balance;
}
h1{font-size:clamp(48px,7vw,108px); font-weight:500}
h2{font-size:clamp(36px,4.6vw,64px); font-weight:500; line-height:1.05}
h3{font-size:clamp(24px,2.6vw,34px); font-weight:500}
h4{font-size:22px; font-weight:600; line-height:1.25}

.lead{
  font-family:var(--serif);
  font-size:clamp(22px,2vw,28px);
  line-height:1.45;
  font-weight:400;
  color:var(--ink-soft);
  font-style:italic;
  text-wrap:pretty;
}
.kicker{
  font-family:var(--serif);
  font-style:italic;
  color:var(--accent);
  font-size:22px;
}

p{text-wrap:pretty}
p + p{margin-top:1em}

/* ---------- layout primitives ---------- */
.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding:0 40px;
}
@media (max-width:720px){ .wrap{padding:0 22px} }

.rule{
  height:1px;background:var(--rule);border:0;margin:0;
}

section{
  padding:var(--pad-section) 0;
}
section.alt{background:var(--bg-deep)}

.section-head{
  display:grid;
  grid-template-columns:200px 1fr;
  gap:48px;
  align-items:start;
  margin-bottom:var(--pad-block);
}
.section-head .num{
  font-family:var(--serif);
  font-size:54px;
  color:var(--accent);
  font-style:italic;
  line-height:1;
  font-weight:400;
}
.section-head h2{
  margin-bottom:18px;
}
.section-head .lead{
  max-width:720px;
}
@media (max-width:900px){
  .section-head{grid-template-columns:1fr;gap:18px}
  .section-head .num{font-size:42px}
}

/* ---------- top utility bar ---------- */
.utility{
  background:var(--ink);
  color:#d6c8ae;
  font-size:13px;
  letter-spacing:.04em;
}
.utility .wrap{
  display:flex;justify-content:space-between;align-items:center;
  padding-top:10px;padding-bottom:10px;flex-wrap:wrap;gap:10px;
}
.utility .nation-marks{display:inline-flex;align-items:center;gap:10px;color:#bba889}
.utility .dot{display:inline-block;width:7px;height:7px;border-radius:50%}
.utility .arabic{font-family:var(--arabic);font-size:15px;color:#e8d7c4}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(244,237,224,.92);
  backdrop-filter:saturate(140%) blur(8px);
  -webkit-backdrop-filter:saturate(140%) blur(8px);
  border-bottom:1px solid var(--rule);
}
.site-header .wrap{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:18px;padding-bottom:18px;gap:24px;
}
.brand{display:flex;align-items:center;gap:16px;text-decoration:none}
.brand .mark{
  width:48px;height:48px;border-radius:50%;
  background:var(--ink);
  display:grid;place-items:center;
  border:1px solid var(--ink);
  position:relative;
  flex:0 0 48px;
}
.brand .mark .ar{
  font-family:var(--arabic);
  color:var(--accent-soft);
  font-size:24px;
  line-height:1;
  margin-top:2px;
}
.brand .name{
  font-family:var(--serif);
  font-size:22px;
  line-height:1.1;
  font-weight:500;
  color:var(--ink);
}
.brand .name small{
  display:block;
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted);
  margin-top:4px;
  font-weight:500;
}
nav.primary{display:flex;gap:4px;align-items:center}
nav.primary a{
  font-size:14px;
  padding:8px 12px;
  color:var(--ink-soft);
  border-radius:4px;
  transition:color .2s;
  font-weight:500;
}
nav.primary a:hover{color:var(--accent)}
.cta-pill{
  border:1px solid var(--ink);
  padding:10px 18px !important;
  border-radius:999px;
  color:var(--ink) !important;
  font-size:13px !important;
  letter-spacing:.04em;
  transition:all .25s;
  font-weight:500;
}
.cta-pill:hover{background:var(--ink);color:var(--paper) !important}
.burger{display:none}

@media (max-width:1080px){
  nav.primary a:not(.cta-pill){display:none}
  .burger{display:inline-grid;place-items:center;width:42px;height:42px;border:1px solid var(--rule);border-radius:50%}
  .burger svg{width:18px;height:18px}
}

/* ---------- hero ---------- */
.hero{
  padding-top:80px;
  padding-bottom:var(--pad-section);
  position:relative;
}
.hero .wrap{
  display:grid;
  grid-template-columns:1fr;
  gap:40px;
  align-items:start;
}
.hero-left .eyebrow{margin-bottom:36px}
.hero h1{
  font-style:italic;
  font-weight:500;
}
.hero h1 .reg{font-style:normal}
.hero h1 em{
  font-style:italic;
  color:var(--accent);
  font-weight:500;
}
.hero h1 .ar{
  display:block;
  font-family:var(--arabic);
  font-style:normal;
  font-size:.5em;
  color:var(--ink-soft);
  letter-spacing:0;
  margin-top:24px;
  direction:rtl;
  line-height:1.2;
}
.hero-meta{
  margin-top:48px;
  display:flex;flex-wrap:wrap;gap:40px;
  border-top:1px solid var(--rule);
  padding-top:28px;
}
.hero-meta .item .k{
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;
}
.hero-meta .item .v{
  font-family:var(--serif);font-size:22px;color:var(--ink);margin-top:4px;
}

.hero-image{
  position:relative;
  width:100%;
  aspect-ratio:1408/745;
  background:#f5e9ce;
  overflow:hidden;
  border-radius:2px;
}
.hero-image img{
  width:100%;height:100%;object-fit:cover;
  filter:saturate(.95) contrast(1.02);
}
.hero-image .stamp{
  position:absolute;top:24px;left:24px;
  font-family:var(--serif);font-style:italic;color:var(--paper);
  letter-spacing:.04em;
  text-shadow:0 1px 12px rgba(0,0,0,.6);
}
.hero-image .stamp small{
  display:block;font-family:var(--sans);font-style:normal;
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  margin-top:4px;opacity:.85;
}
.hero-image .corner{
  position:absolute;bottom:24px;right:24px;
  background:var(--bg);color:var(--ink);
  padding:14px 18px;
  border-radius:2px;
  font-family:var(--serif);
  text-align:center;
}
.hero-image .corner .y{font-size:32px;line-height:1;display:block}
.hero-image .corner .l{font-family:var(--sans);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:4px;display:block}

@media (max-width:900px){
  .hero .wrap{grid-template-columns:1fr;gap:40px}
}

/* ---------- marquee strip ---------- */
.tagline-strip{
  background:var(--ink);
  color:var(--bg);
  padding:34px 0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.tagline-strip .wrap{
  display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;
}
.tagline-strip .big{
  font-family:var(--serif);font-style:italic;font-size:clamp(20px,2.2vw,30px);
  font-weight:400;color:var(--accent-soft);
}
.tagline-strip .meta{display:flex;gap:32px;align-items:center;color:#bba889;font-size:13px;letter-spacing:.04em}
.tagline-strip .meta strong{display:block;font-family:var(--serif);color:var(--paper);font-size:24px;font-weight:500;font-style:normal}

/* ---------- about / presentation ---------- */
.about-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:80px;
  align-items:start;
}
.about-body p{margin-bottom:18px;color:var(--ink-soft);font-size:17px}
.about-body p.first::first-letter{
  font-family:var(--serif);
  font-size:74px;
  float:left;
  line-height:.85;
  padding:8px 12px 0 0;
  color:var(--accent);
  font-style:italic;
}
.about-body strong{color:var(--ink);font-weight:600}
.about-photo{
  position:relative;
  aspect-ratio:4/5;
  background:var(--ink);
  overflow:hidden;
}
.about-photo img{width:100%;height:100%;object-fit:cover;filter:saturate(.95)}
.about-photo .cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.7));color:var(--paper);
  font-family:var(--serif);font-style:italic;font-size:17px;
}
.missions{
  margin-top:36px;
  border-top:1px solid var(--rule);
  padding-top:36px;
}
.missions h4{
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:18px;
}
.missions ol{list-style:none;counter-reset:m}
.missions li{
  counter-increment:m;
  padding:14px 0 14px 50px;
  border-bottom:1px solid var(--rule);
  position:relative;
  font-size:16px;
  color:var(--ink-soft);
}
.missions li::before{
  content:counter(m,decimal-leading-zero);
  position:absolute;left:0;top:14px;
  font-family:var(--serif);font-style:italic;color:var(--accent);font-size:18px;
}
.missions li:last-child{border-bottom:0}

@media (max-width:900px){
  .about-grid{grid-template-columns:1fr;gap:50px}
}

/* ---------- two shores ---------- */
.two-rives-feature{
  margin: 0 0 64px;
  position:relative;
}
.two-rives-feature .trf-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:24px;
}
.two-rives-feature .trf-fig{
  margin:0;
  display:flex;flex-direction:column;gap:14px;
}
.two-rives-feature .trf-fig img{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  display:block;
  filter:saturate(1.02);
  box-shadow:0 8px 24px rgba(40, 25, 10, .12);
}
.two-rives-feature .trf-fig figcaption{
  font-family:var(--serif);font-style:italic;
  font-size:17px;color:var(--ink-soft);
  display:flex;gap:10px;align-items:baseline;
}
.two-rives-feature .trf-fig .trf-num{
  font-family:var(--serif);font-style:italic;color:var(--accent);font-weight:500;flex:0 0 auto;
}

/* legacy (kept for safety) */
.two-rives-feature img.trf-img{
  width:100%;
  aspect-ratio: 21/9;
  object-fit: cover;
  display:block;
  filter: saturate(.98);
}

@media (max-width:760px){
  .two-rives-feature .trf-grid{grid-template-columns:1fr;gap:32px}
}
.two-rives-feature .trf-cap{
  margin-top:16px;
  display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;
  font-family:var(--serif);font-style:italic;
  font-size:18px;color:var(--ink-soft);
}
.two-rives-feature .trf-cap .ar{
  font-family:var(--arabic);font-style:normal;color:var(--accent);font-size:22px;
}
[data-motifs="off"] .two-rives-feature .trf-cap .ar{display:none}

/* ---------- inline illustration scenes ---------- */
.illust{
  width:100%;height:100%;display:block;
}
.hero-image .illust{position:absolute;inset:0;z-index:0}
.about-photo .illust{position:absolute;inset:0;z-index:0}
.foyer-cell .img .illust{position:absolute;inset:0;z-index:0}
.two-rives-feature .illust{aspect-ratio:21/9}

/* ---------- real photographs ---------- */
.hero-photo{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  object-position:center center;
  filter:saturate(1.05) contrast(1.02);
}
.about-photo.emblem{
  background:linear-gradient(135deg, #fdf6e8, #f5ead4);
  border:1px solid var(--rule);
}
.about-photo-img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  object-position:center 50%;
  filter:saturate(1.04) contrast(1.02);
}
.trf-img{
  width:100%;
  aspect-ratio:21/9;
  object-fit:cover;
  object-position:center 40%;
  display:block;
  filter:saturate(1.02);
}
.foyer-cell .img{position:relative}
.foyer-cell .foyer-img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  filter:saturate(1.03);
}
.foyer-cell .img .ix{z-index:2;text-shadow:0 1px 8px rgba(0,0,0,.55)}
/* mute the watermark sparkle in bottom-right corner of generated images */
.foyer-cell .img::after{
  content:"";position:absolute;
  right:0;bottom:0;width:60px;height:60px;
  background:linear-gradient(315deg, rgba(0,0,0,.18), transparent 60%);
  z-index:1;pointer-events:none;
}
.hero-image::after{
  content:"";position:absolute;right:0;bottom:0;width:80px;height:80px;
  background:linear-gradient(315deg, rgba(0,0,0,.18), transparent 60%);
  z-index:1;pointer-events:none;
}
.two-rives-feature{position:relative}
.two-rives-feature::after{
  content:"";position:absolute;right:0;bottom:50px;width:70px;height:70px;
  background:linear-gradient(315deg, rgba(0,0,0,.18), transparent 60%);
  z-index:1;pointer-events:none;
}

/* ---------- big flag pair (now: real crossed-flags photo, bg removed) ---------- */
.flags-pair{
  display:block;
  margin:0 0 28px;
  width:220px;
  position:relative;
}
.flags-pair img{
  width:100%;
  height:auto;
  display:block;
  filter:drop-shadow(0 6px 14px rgba(40, 25, 10, .18));
}

.shores{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.shore{
  padding:48px;
  position:relative;
}
.shore + .shore{border-left:1px solid var(--rule)}
.shore .tag{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--muted);margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.shore .tag .dot{width:8px;height:8px;border-radius:50%}
.shore.dz .tag .dot{background:var(--tone-dz)}
.shore.fr .tag .dot{background:var(--tone-fr)}

.shore h3 .ar{
  display:block;font-family:var(--arabic);color:var(--ink-soft);font-size:.6em;margin-bottom:6px;
}
.shore .sub{font-family:var(--serif);font-style:italic;color:var(--muted);margin:8px 0 30px;font-size:19px}
.shore ul{list-style:none}
.shore li{
  padding:14px 0;border-bottom:1px solid var(--rule);font-size:16px;color:var(--ink-soft);
  display:flex;gap:14px;align-items:baseline;
}
.shore li:last-child{border-bottom:0}
.shore li::before{
  content:"";flex:0 0 6px;width:6px;height:6px;border-radius:50%;
  background:var(--accent);margin-top:8px;
}
.shore.fr li::before{background:var(--tone-fr)}
.shore.dz li::before{background:var(--tone-dz)}

@media (max-width:900px){
  .shores{grid-template-columns:1fr}
  .shore + .shore{border-left:0;border-top:1px solid var(--rule)}
  .shore{padding:36px 24px}
}

/* ---------- quote ---------- */
.pull-quote{
  max-width:880px;margin:80px auto 0;
  padding:0 40px;
  text-align:left;
  position:relative;
}
.pull-quote::before{
  content:"";
  position:absolute;left:0;top:8px;
  font-family:var(--serif);font-size:140px;line-height:1;color:var(--accent);
  font-style:italic;
}
.pull-quote .pq{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(22px,2.3vw,32px);
  line-height:1.45;
  color:var(--ink);
  font-weight:400;
}
.pull-quote .pq-author{
  display:flex;align-items:center;gap:14px;
  margin-top:28px;
  font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);font-weight:600;
}
.pull-quote .pq-author::before{
  content:"";width:36px;height:1px;background:var(--muted);
}

/* ---------- values ---------- */
.values{
  display:grid;grid-template-columns:repeat(4,1fr);gap:0;
  border-top:1px solid var(--rule);
}
.values .val{
  padding:40px 28px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.values .val:last-child{border-right:0}
.values .val .v-num{
  font-family:var(--serif);font-style:italic;color:var(--accent);font-size:22px;
}
.values .val h4{
  font-family:var(--serif);font-size:28px;font-weight:500;margin:20px 0 12px;
}
.values .val p{color:var(--ink-soft);font-size:15px;line-height:1.6}

@media (max-width:900px){
  .values{grid-template-columns:1fr 1fr}
  .values .val:nth-child(even){border-right:0}
}
@media (max-width:560px){
  .values{grid-template-columns:1fr}
  .values .val{border-right:0}
}

/* ---------- timeline ---------- */
.timeline-ed{
  position:relative;
  max-width:920px;
  margin:0 auto;
}
.timeline-ed::before{
  content:"";position:absolute;left:170px;top:0;bottom:0;width:1px;background:var(--rule);
}
.tl-row{
  display:grid;grid-template-columns:170px 1fr;
  gap:60px;padding:32px 0;
  border-bottom:1px solid var(--rule);
  position:relative;
}
.tl-row:last-child{border-bottom:0}
.tl-row .tl-year{
  font-family:var(--serif);font-style:italic;color:var(--accent);font-size:28px;
  line-height:1.1;
}
.tl-row .tl-year small{display:block;font-family:var(--sans);font-style:normal;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-top:6px}
.tl-row::before{
  content:"";position:absolute;left:163px;top:42px;
  width:15px;height:15px;border-radius:50%;
  background:var(--bg);border:2px solid var(--accent);
}
.tl-row.highlight::before{background:var(--accent)}
.tl-row .tl-body h4{
  font-family:var(--serif);font-size:26px;font-weight:500;margin-bottom:10px;
}
.tl-row .tl-body p{color:var(--ink-soft);font-size:16px;max-width:560px}

@media (max-width:720px){
  .timeline-ed::before{left:0}
  .tl-row{grid-template-columns:1fr;gap:12px;padding-left:28px}
  .tl-row::before{left:-7px;top:36px}
}

/* ---------- foyer ---------- */
.foyer-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:1px;
  background:var(--rule);
  border:1px solid var(--rule);
}
.foyer-cell{
  background:var(--paper);
  padding:0;
  display:grid;grid-template-rows:280px 1fr;
}
.foyer-cell .img{
  position:relative;background:var(--ink) center/cover;
  overflow:hidden;
}
.foyer-cell .img img{width:100%;height:100%;object-fit:cover;filter:saturate(.95)}
.foyer-cell .img .ix{
  position:absolute;top:18px;left:20px;
  font-family:var(--serif);font-style:italic;color:var(--paper);font-size:20px;
}
.foyer-cell .body{padding:32px 28px 36px}
.foyer-cell .body h4{
  font-family:var(--serif);font-size:28px;font-weight:500;margin-bottom:10px;
}
.foyer-cell .body p{color:var(--ink-soft);font-size:16px;margin-bottom:20px}
.foyer-cell .body .when{
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:600;
  border-top:1px solid var(--rule);padding-top:16px;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.foyer-cell .body .when .day{color:var(--accent);font-family:var(--serif);font-style:italic;text-transform:none;letter-spacing:0;font-size:16px;font-weight:400}

@media (max-width:900px){
  .foyer-list{grid-template-columns:1fr}
}

/* ---------- news / actu ---------- */
.news{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:48px 40px;
}
.news article{
  border-top:1px solid var(--ink);
  padding-top:22px;
}
.news article .ncat{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:600;
  color:var(--accent);margin-bottom:14px;display:flex;align-items:center;gap:10px;
}
.news article .ncat .dot{width:6px;height:6px;border-radius:50%;background:currentColor}
.news article h4{
  font-family:var(--serif);font-size:24px;font-weight:500;line-height:1.2;margin-bottom:14px;
  text-wrap:balance;
}
.news article .ndate{
  font-family:var(--serif);font-style:italic;color:var(--muted);font-size:15px;margin-bottom:6px;
}
.news article p{color:var(--ink-soft);font-size:15px;line-height:1.55;margin-bottom:14px}
.news article a.more{
  font-size:13px;letter-spacing:.05em;color:var(--ink);
  border-bottom:1px solid var(--ink);padding-bottom:2px;font-weight:500;
}
.news article a.more:hover{color:var(--accent);border-color:var(--accent)}

@media (max-width:980px){.news{grid-template-columns:1fr 1fr;gap:40px 32px}}
@media (max-width:640px){.news{grid-template-columns:1fr}}

/* ---------- gallery ---------- */
.gal{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;grid-auto-rows:160px;
}
.gal .g{
  background:var(--ink) center/cover;position:relative;overflow:hidden;
}
.gal .g img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease;filter:saturate(.95)}
.gal .g:hover img{transform:scale(1.05)}
.gal .g .cap{
  position:absolute;left:0;right:0;bottom:0;padding:18px;
  font-family:var(--serif);font-style:italic;color:var(--paper);font-size:15px;
  background:linear-gradient(transparent,rgba(0,0,0,.7));
}

/* asymmetric editorial grid */
.gal .g:nth-child(1){grid-column:span 6;grid-row:span 2}
.gal .g:nth-child(2){grid-column:span 3;grid-row:span 1}
.gal .g:nth-child(3){grid-column:span 3;grid-row:span 1}
.gal .g:nth-child(4){grid-column:span 4;grid-row:span 1}
.gal .g:nth-child(5){grid-column:span 4;grid-row:span 2}
.gal .g:nth-child(6){grid-column:span 4;grid-row:span 1}
.gal .g:nth-child(7){grid-column:span 4;grid-row:span 1}
.gal .g:nth-child(8){grid-column:span 4;grid-row:span 1}

@media (max-width:900px){
  .gal{grid-template-columns:repeat(6,1fr)}
  .gal .g:nth-child(n){grid-column:span 3;grid-row:span 1}
  .gal .g:nth-child(1){grid-column:span 6;grid-row:span 2}
}
@media (max-width:560px){
  .gal{grid-template-columns:1fr;grid-auto-rows:200px}
  .gal .g:nth-child(n){grid-column:span 1}
}

/* ---------- engagement ---------- */
.engage{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1px solid var(--rule);
}
.eng-col{
  padding:54px 48px;
  border-bottom:1px solid var(--rule);
}
.eng-col + .eng-col{border-left:1px solid var(--rule)}
.eng-col .e-no{
  font-family:var(--serif);font-style:italic;color:var(--accent);font-size:22px;
}
.eng-col h3{
  font-family:var(--serif);font-size:38px;font-weight:500;margin:18px 0 14px;
}
.eng-col .e-lead{color:var(--ink-soft);max-width:480px;margin-bottom:28px;font-size:16px}
.eng-col ul{list-style:none;margin-bottom:32px}
.eng-col li{
  padding:14px 0;border-bottom:1px solid var(--rule);font-size:16px;color:var(--ink-soft);
  display:flex;gap:18px;align-items:baseline;
}
.eng-col li:last-child{border-bottom:0}
.eng-col li .n{
  font-family:var(--serif);font-style:italic;color:var(--accent);font-size:15px;flex:0 0 24px;
}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;border-radius:999px;
  background:var(--ink);color:var(--bg);
  font-size:13px;letter-spacing:.06em;
  border:1px solid var(--ink);
  transition:all .25s ease;
  font-weight:500;
  text-transform:uppercase;
}
.btn:hover{background:var(--accent);border-color:var(--accent);color:var(--paper);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--bg)}
.btn .arr{display:inline-block;transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}

@media (max-width:900px){
  .engage{grid-template-columns:1fr}
  .eng-col + .eng-col{border-left:0;border-top:1px solid var(--rule)}
  .eng-col{padding:40px 24px}
}

/* ---------- contact ---------- */
.contact{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border:1px solid var(--rule);
  background:var(--paper);
}
.contact-info{
  padding:48px 44px;
  background:var(--ink);
  color:var(--bg);
}
.contact-info h3{color:var(--paper);font-family:var(--serif);font-size:30px;margin-bottom:30px;font-weight:500}
.contact-info .ci{
  padding:18px 0;border-bottom:1px solid #2a241d;
  display:grid;grid-template-columns:120px 1fr;gap:20px;
}
.contact-info .ci:last-child{border-bottom:0}
.contact-info .ci .ck{
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:#b9a98b;font-weight:600;
  padding-top:4px;
}
.contact-info .ci .cv{font-family:var(--serif);font-size:18px;color:var(--bg);line-height:1.45}
.contact-info .ci .cv a{border-bottom:1px solid rgba(214,200,174,.4)}
.contact-info .ci .cv a:hover{color:var(--accent-soft)}

.contact-form{padding:48px 44px}
.contact-form h3{font-family:var(--serif);font-size:30px;margin-bottom:30px;font-weight:500}
.field{margin-bottom:22px}
.field label{
  display:block;font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);font-weight:600;margin-bottom:8px;
}
.field input,.field textarea,.field select{
  width:100%;background:transparent;border:0;
  border-bottom:1px solid var(--rule);
  padding:8px 0;font-family:var(--sans);font-size:17px;color:var(--ink);
  transition:border-color .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--accent)}
.field textarea{resize:vertical;min-height:90px}

@media (max-width:900px){
  .contact{grid-template-columns:1fr}
  .contact-info,.contact-form{padding:36px 28px}
}

/* ---------- footer ---------- */
.foot{
  background:var(--ink);color:#bba889;padding:80px 0 30px;
}
.foot-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:48px;
}
.foot h5{
  font-family:var(--sans);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--paper);font-weight:600;margin-bottom:18px;
}
.foot p,.foot li{font-size:15px;line-height:1.65;color:#a89878}
.foot ul{list-style:none}
.foot ul li{padding:5px 0}
.foot a:hover{color:var(--paper)}
.foot .brand-foot{
  font-family:var(--serif);font-size:28px;color:var(--paper);
  margin-bottom:14px;line-height:1.2;font-weight:500;
}
.foot .brand-foot small{display:block;font-family:var(--sans);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-soft);margin-top:6px;font-weight:500}
.foot .nl input{
  width:100%;background:transparent;border:0;border-bottom:1px solid #4a3f33;
  padding:8px 0;color:var(--paper);font-family:var(--sans);font-size:16px;margin-bottom:14px;
}
.foot .nl input::placeholder{color:#7a6e5e}
.foot .nl input:focus{outline:0;border-color:var(--accent)}
.foot .nl button{
  background:var(--accent);color:var(--paper);padding:11px 22px;border-radius:999px;
  font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:500;
}
.foot .nl button:hover{background:var(--accent-deep)}

.foot-bottom{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:60px;padding-top:24px;border-top:1px solid #2a241d;
  font-size:12px;letter-spacing:.06em;flex-wrap:wrap;gap:14px;
}
.foot-bottom .ar{font-family:var(--arabic);color:var(--accent-soft);font-size:18px}

@media (max-width:980px){.foot-grid{grid-template-columns:1fr 1fr;gap:36px}}
@media (max-width:560px){.foot-grid{grid-template-columns:1fr}}

/* ---------- symbolic placeholders ---------- */
.ph{
  background:
    radial-gradient(ellipse at 30% 20%, rgba(200, 96, 44, .14), transparent 60%),
    radial-gradient(ellipse at 80% 90%, rgba(90, 133, 70, .10), transparent 55%),
    linear-gradient(135deg, #f3e3c5 0%, #e6d2a8 100%);
  position:relative;
  display:grid;place-items:center;
  overflow:hidden;
}
.ph::before{
  content:"";
  position:absolute;inset:0;
  background:
    repeating-linear-gradient(45deg, rgba(120, 80, 40, .04) 0 1px, transparent 1px 14px);
  pointer-events:none;
}
.ph .sym{
  width:42%;
  max-width:160px;
  aspect-ratio:1;
  color:var(--accent-deep);
  opacity:.7;
  display:block;
  z-index:1;
}
.ph .sym path,.ph .sym circle,.ph .sym line,.ph .sym rect,.ph .sym polyline,.ph .sym polygon{
  vector-effect:non-scaling-stroke;
}
.ph .ar-word{
  position:absolute;
  bottom:18px;left:0;right:0;text-align:center;
  font-family:var(--arabic);
  color:var(--accent-deep);
  font-size:20px;
  letter-spacing:0;
  z-index:1;
  opacity:.85;
}
.ph .ph-label{
  position:absolute;
  top:18px;left:18px;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(90, 70, 50, .65);
  font-weight:600;
  z-index:1;
}
[data-motifs="off"] .ph .ar-word{display:none}
/* hide ph-label/ar-word where the parent already has its own caption/stamp */
.hero-image .ph .ph-label,
.hero-image .ph .ar-word,
.about-photo .ph .ph-label,
.about-photo .ph .ar-word{display:none}
/* small placeholders (gallery) hide the arabic word and label */
.gal .ph .ar-word, .gal .ph .ph-label{display:none}
.gal .ph .sym{width:38%}

/* ---------- arabic motifs (subtle) ---------- */
[data-motifs="off"] .ar,
[data-motifs="off"] .ar-ornament{display:none !important}

.ar-ornament{
  text-align:center;font-family:var(--arabic);color:var(--accent);font-size:36px;
  margin:0 auto;letter-spacing:0;line-height:1;opacity:.7;
}
