/* =========================================================
   Chibanis Algériens de France — VARIANTE "Journal de mémoire"
   Direction : presse d'archive, sépia, dense, asymétrique
   ========================================================= */

:root{
  /* Palette nocturne / journal de mémoire */
  --bg:        #1a1410;           /* encre profonde */
  --bg-deep:   #110c08;           /* alt encore plus sombre */
  --paper:     #fff8e8;           /* parchemin clair (cartes/inversion) */
  --paper-soft:#f0e5cc;
  --ink:       #fff8e8;           /* texte clair sur fond sombre */
  --ink-soft:  #e6d9b8;           /* secondaire */
  --muted:     #a89878;
  --rule:      #3a2e22;           /* hairlines marron foncé */
  --rule-soft: #2a2018;

  --accent:    #d99846;           /* or chaud */
  --accent-deep:#a8732f;
  --accent-soft:#3a2c1a;

  --tone-dz:   #7faa64;
  --tone-fr:   #6b9bbd;
  --tone-rouge:#d96058;

  /* Typo */
  --serif:    "Playfair Display", "Bodoni Moda", "EB Garamond", Georgia, serif;
  --serif-condensed: "Playfair Display", serif;
  --sans:     "Inter", "Helvetica Neue", Arial, sans-serif;
  --mono:     "JetBrains Mono", "Menlo", monospace;
  --arabic:   "Amiri", serif;

  --size-base:17px;
  --lh:1.65;
  --pad-section:96px;
  --pad-block:48px;
  --maxw:1320px;
}

[data-density="compact"]{--pad-section:64px;--pad-block:32px}
[data-density="relaxed"]{--pad-section:130px;--pad-block:64px}
[data-senior="true"]{--size-base:20px;--lh:1.75}

*,*::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";
}
.about-body p, .news article p, .shore li, .foyer-cell .body p, .eng-col li, .eng-col .e-lead, .tl-row .tl-body p{
  color:var(--ink-soft);
}
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(--bg)}

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

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:600;
  line-height:1.06;
  letter-spacing:-.01em;
  color:var(--paper);
  text-wrap:balance;
}
h1{font-size:clamp(56px,9vw,140px); font-weight:700; line-height:.96}
h2{font-size:clamp(38px,5.4vw,72px); font-weight:600; line-height:1.02}
h3{font-size:clamp(26px,3vw,38px); font-weight:600}
h4{font-size:22px; font-weight:600; line-height:1.22}

.lead{
  font-family:var(--serif);
  font-size:clamp(20px,1.7vw,24px);
  line-height:1.45;
  font-weight:400;
  color:var(--ink-soft);
  font-style:italic;
  text-wrap:pretty;
}

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

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

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

.section-head{
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
  margin-bottom:var(--pad-block);
  border-bottom:3px double var(--rule);
  padding-bottom:32px;
}
.section-head .topline{
  display:flex;align-items:baseline;gap:24px;flex-wrap:wrap;
}
.section-head .num{
  font-family:var(--mono);
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;
}
.section-head h2{margin-top:0}
.section-head .lead{max-width:760px;margin-top:8px}

/* ---------- top utility bar ---------- */
.utility{
  background:var(--bg-deep);
  color:var(--ink-soft);
  font-size:12px;
  font-family:var(--mono);
  letter-spacing:.06em;
  border-bottom:1px solid var(--rule);
}
.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:var(--accent)}
.utility .dot{display:inline-block;width:7px;height:7px;border-radius:50%}
.utility .arabic{font-family:var(--arabic);font-size:15px;color:var(--accent);font-weight:700}

/* ---------- header ---------- */
.site-header{
  position:sticky;top:0;z-index:50;
  background:rgba(26, 20, 16, .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}
.brand .mark{
  width:50px;height:50px;border-radius:0;
  background:var(--accent);
  display:grid;place-items:center;
  border:0;
  position:relative;
  flex:0 0 50px;
}
.brand .mark .ar{
  font-family:var(--arabic);
  color:var(--bg);
  font-size:28px;line-height:1;font-weight:700;
}
.brand .name{
  font-family:var(--serif);
  font-size:22px;
  line-height:1.05;
  font-weight:800;
  color:var(--paper);
  letter-spacing:-.01em;
}
.brand .name small{
  display:block;
  font-family:var(--mono);
  font-size:10px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--accent);
  margin-top:6px;
  font-weight:500;
}
nav.primary{display:flex;gap:0;align-items:center}
nav.primary a{
  font-family:var(--mono);
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  padding:10px 14px;
  color:var(--ink-soft);
  transition:color .2s;
  font-weight:500;
}
nav.primary a:hover{color:var(--accent)}
.cta-pill{
  border:1px solid var(--accent) !important;
  padding:10px 18px !important;
  color:var(--accent) !important;
  font-size:12px !important;
  letter-spacing:.1em;
  margin-left:8px;
  transition:all .25s;
}
.cta-pill:hover{background:var(--accent);color:var(--bg) !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);color:var(--accent)}
  .burger svg{width:18px;height:18px}
}

/* ---------- hero ---------- */
.hero{
  padding:60px 0 var(--pad-section);
  position:relative;
}
.hero .wrap{
  display:grid;
  grid-template-columns:1fr;
  gap:48px;
}
.hero-left .eyebrow{margin-bottom:32px}
.hero h1{
  font-style:normal;
  letter-spacing:-.025em;
  text-transform:none;
}
.hero h1 .reg{font-weight:300}
.hero h1 em{
  font-style:italic;
  color:var(--accent);
  font-weight:900;
}
.hero h1 .ar{
  display:block;
  font-family:var(--arabic);
  font-style:normal;
  font-size:.42em;
  color:var(--accent);
  letter-spacing:0;
  margin-top:24px;
  direction:rtl;
  line-height:1.2;
  font-weight:700;
}
.hero-meta{
  margin-top:36px;
  display:flex;flex-wrap:wrap;gap:0;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:24px 0;
}
.hero-meta .item{
  flex:1;min-width:140px;
  padding:0 28px;
  border-right:1px solid var(--rule);
}
.hero-meta .item:last-child{border-right:0}
.hero-meta .item:first-child{padding-left:0}
.hero-meta .item .k{
  font-family:var(--mono);
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:500;
}
.hero-meta .item .v{
  font-family:var(--serif);font-size:34px;color:var(--accent);margin-top:6px;font-weight:800;
}

.hero-image{
  position:relative;
  width:100%;
  aspect-ratio:1408/745;
  background:var(--bg-deep);
  overflow:hidden;
  margin-top:16px;
}
.hero-photo{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  object-position:center center;
  filter:sepia(.35) saturate(.8) contrast(1.05) brightness(.92);
}
.hero-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(26,20,16,.6));
  pointer-events:none;z-index:1;
}
.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,.7);
  z-index:2;font-size:20px;font-weight:600;
}
.hero-image .stamp small{
  display:block;font-family:var(--mono);font-style:normal;
  font-size:10px;letter-spacing:.22em;text-transform:uppercase;
  margin-top:4px;color:var(--accent);font-weight:500;
}
.hero-image .corner{
  position:absolute;bottom:24px;right:24px;
  background:var(--accent);color:var(--bg);
  padding:14px 18px;
  font-family:var(--serif);
  text-align:center;
  z-index:2;
  border-radius:0;
}
.hero-image .corner .y{font-size:30px;line-height:1;display:block;font-weight:900}
.hero-image .corner .l{font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;margin-top:4px;display:block;font-weight:500}

@media (max-width:900px){
  .hero{padding-top:40px}
  .hero-meta .item{padding:0 16px}
}

/* ---------- marquee strip ---------- */
.tagline-strip{
  background:var(--accent);
  color:var(--bg);
  padding:38px 0;
  border-top:1px solid var(--accent-deep);
  border-bottom:1px solid var(--accent-deep);
}
.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(22px,2.2vw,32px);
  font-weight:600;color:var(--bg);max-width:760px;
}
.tagline-strip .meta{display:flex;gap:36px;align-items:center;color:var(--accent-deep);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.tagline-strip .meta strong{display:block;font-family:var(--serif);color:var(--bg);font-size:26px;font-weight:900;font-style:normal;text-transform:none;letter-spacing:-.01em}

/* ---------- about ---------- */
.about-grid{
  display:grid;
  grid-template-columns:1.4fr 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:88px;
  float:left;
  line-height:.85;
  padding:8px 14px 0 0;
  color:var(--accent);
  font-weight:900;
}
.about-body strong{color:var(--paper);font-weight:700}
.about-photo{
  position:relative;
  aspect-ratio:4/5;
  background:var(--bg-deep);
  overflow:hidden;
}
.about-photo-img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  filter:sepia(.4) saturate(.75) contrast(1.05) brightness(.9);
}
.about-photo .cap{
  position:absolute;bottom:0;left:0;right:0;
  padding:24px;background:linear-gradient(transparent,rgba(0,0,0,.85));color:var(--paper);
  font-family:var(--serif);font-style:italic;font-size:17px;z-index:1;
  border-bottom:3px solid var(--accent);
}
.missions{
  margin-top:36px;
  border-top:1px solid var(--rule);
  padding-top:36px;
}
.missions h4{
  font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:500;margin-bottom:18px;
}
.missions ol{list-style:none;counter-reset:m}
.missions li{
  counter-increment:m;
  padding:16px 0 16px 60px;
  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-weight:900;color:var(--accent);font-size:22px;
}
.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:sepia(.32) saturate(.82) contrast(1.05) brightness(.92);
  box-shadow:0 8px 24px rgba(0, 0, 0, .35);
}
.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-weight:900;color:var(--accent);font-style:normal;flex:0 0 auto;
}
.two-rives-feature .trf-cap{
  margin-top:28px;
  font-family:var(--serif);font-style:italic;font-size:18px;color:var(--ink-soft);
  display:flex;align-items:baseline;gap:18px;flex-wrap:wrap;border-top:1px solid var(--rule);padding-top:20px;
}
.two-rives-feature .trf-cap .ar{font-family:var(--arabic);font-style:normal;color:var(--accent);font-size:24px;font-weight:700}
[data-motifs="off"] .two-rives-feature .trf-cap .ar{display:none}

@media (max-width:760px){
  .two-rives-feature .trf-grid{grid-template-columns:1fr;gap:32px}
}

.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-family:var(--mono);
  font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  color:var(--accent);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(--accent);font-size:.6em;margin-bottom:6px;font-weight:700;
}
.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;
  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:920px;margin:80px auto 0;
  padding:48px 60px;
  background:var(--bg-deep);
  border-left:4px solid var(--accent);
  position:relative;
}
.pull-quote::before{
  content:"\201C";
  position:absolute;left:-20px;top:-30px;
  font-family:var(--serif);font-size:200px;line-height:1;color:var(--accent);
  font-weight:900;
}
.pull-quote .pq{
  font-family:var(--serif);
  font-style:italic;
  font-size:clamp(24px,2.4vw,34px);
  line-height:1.4;
  color:var(--paper);font-weight:500;
}
.pull-quote .pq-author{
  margin-top:28px;
  font-family:var(--mono);
  font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);
}

/* ---------- 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-weight:900;color:var(--accent);font-size:48px;line-height:1;
}
.values .val h4{font-family:var(--serif);font-size:28px;font-weight:800;margin:18px 0 12px;color:var(--paper)}
.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 (newspaper-style columns) ---------- */
.timeline-ed{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  border-top:2px solid var(--rule);
}
.tl-row{
  padding:36px 28px;
  border-right:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  position:relative;
}
.tl-row:nth-child(3n){border-right:0}
.tl-row .tl-year{
  font-family:var(--mono);color:var(--accent);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  margin-bottom:8px;font-weight:500;
}
.tl-row .tl-year small{display:none}
.tl-row .tl-body h4{
  font-family:var(--serif);font-size:26px;font-weight:800;margin-bottom:12px;color:var(--paper);line-height:1.1;
}
.tl-row .tl-body p{color:var(--ink-soft);font-size:15px;line-height:1.55}
.tl-row.highlight{background:var(--accent-soft)}
.tl-row.highlight .tl-year{color:var(--accent)}
.tl-row.highlight::before{
  content:"\2605"; position:absolute;top:18px;right:18px;color:var(--accent);font-size:18px;
}

@media (max-width:900px){
  .timeline-ed{grid-template-columns:1fr}
  .tl-row{border-right:0}
}

/* ---------- foyer ---------- */
.foyer-list{
  display:grid;grid-template-columns:repeat(2,1fr);gap:48px 32px;
}
.foyer-cell{
  display:grid;grid-template-rows:auto auto;gap:0;
  background:transparent;
}
.foyer-cell .img{
  position:relative;background:var(--bg-deep);overflow:hidden;
  aspect-ratio:4/3;
}
.foyer-cell .foyer-img{
  position:absolute;inset:0;z-index:0;
  width:100%;height:100%;object-fit:cover;
  filter:sepia(.3) saturate(.85) contrast(1.05) brightness(.93);
}
.foyer-cell .img .ix{
  position:absolute;top:14px;left:18px;z-index:2;
  font-family:var(--serif);font-weight:900;color:var(--accent);font-size:38px;
  text-shadow:0 2px 12px rgba(0,0,0,.6);
}
.foyer-cell .body{padding:26px 0 0}
.foyer-cell .body h4{
  font-family:var(--serif);font-size:30px;font-weight:800;margin-bottom:12px;color:var(--paper);
}
.foyer-cell .body p{color:var(--ink-soft);font-size:16px;margin-bottom:18px}
.foyer-cell .body .when{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--muted);font-weight:500;
  border-top:1px solid var(--rule);padding-top:14px;
  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:17px;font-weight:600}

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

/* ---------- news ---------- */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--rule)}
.news article{
  padding:32px 24px;border-right:1px solid var(--rule);border-bottom:1px solid var(--rule);
}
.news article:nth-child(3n){border-right:0}
.news article .ncat{
  font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;
  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:800;line-height:1.15;margin-bottom:14px;
  color:var(--paper);text-wrap:balance;
}
.news article .ndate{
  font-family:var(--mono);color:var(--muted);font-size:11px;margin-bottom:8px;letter-spacing:.1em;text-transform:uppercase;
}
.news article p{color:var(--ink-soft);font-size:15px;line-height:1.55;margin-bottom:14px}
.news article a.more{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);
  border-bottom:1px solid var(--accent);padding-bottom:2px;font-weight:500;
}
.news article a.more:hover{color:var(--paper);border-color:var(--paper)}

@media (max-width:980px){.news{grid-template-columns:1fr 1fr}.news article:nth-child(2n){border-right:0}.news article:nth-child(3n){border-right:1px solid var(--rule)}}
@media (max-width:640px){.news{grid-template-columns:1fr}.news article{border-right:0 !important}}

/* ---------- 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-weight:900;color:var(--accent);font-size:42px;line-height:1}
.eng-col h3{font-family:var(--serif);font-size:38px;font-weight:800;margin:14px 0 14px;color:var(--paper)}
.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(--mono);color:var(--accent);font-size:11px;font-weight:500;flex:0 0 24px;letter-spacing:.1em}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 26px;
  background:var(--accent);color:var(--bg);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  border:0;transition:all .25s ease;
}
.btn:hover{background:var(--paper);color:var(--bg);transform:translateY(-1px)}
.btn.ghost{background:transparent;color:var(--accent);border:1px solid var(--accent)}
.btn.ghost:hover{background:var(--accent);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(--bg-deep)}
.contact-info{padding:48px 44px;background:var(--accent);color:var(--bg)}
.contact-info h3{color:var(--bg);font-family:var(--serif);font-size:32px;margin-bottom:30px;font-weight:900}
.contact-info .ci{padding:18px 0;border-bottom:1px solid rgba(0,0,0,.15);display:grid;grid-template-columns:120px 1fr;gap:20px}
.contact-info .ci:last-child{border-bottom:0}
.contact-info .ci .ck{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:rgba(0,0,0,.6);font-weight:500;padding-top:4px}
.contact-info .ci .cv{font-family:var(--serif);font-size:18px;color:var(--bg);line-height:1.45;font-weight:600}
.contact-info .ci .cv a{border-bottom:1px solid rgba(0,0,0,.3)}
.contact-info .ci .cv a:hover{color:var(--paper);border-color:var(--paper)}

.contact-form{padding:48px 44px}
.contact-form h3{font-family:var(--serif);font-size:32px;margin-bottom:30px;font-weight:800;color:var(--paper)}
.field{margin-bottom:22px}
.field label{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);font-weight:500;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(--paper);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(--bg-deep);color:var(--ink-soft);padding:80px 0 30px;border-top:1px solid var(--rule)}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1.4fr;gap:48px}
.foot h5{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:500;margin-bottom:18px}
.foot p,.foot li{font-size:15px;line-height:1.65;color:var(--ink-soft)}
.foot ul{list-style:none}
.foot ul li{padding:5px 0}
.foot a:hover{color:var(--accent)}
.foot .brand-foot{
  font-family:var(--serif);font-size:30px;color:var(--paper);
  margin-bottom:14px;line-height:1.1;font-weight:900;
}
.foot .brand-foot small{display:block;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-top:6px;font-weight:500}
.foot .nl input{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--rule);
  padding:8px 0;color:var(--paper);font-family:var(--sans);font-size:16px;margin-bottom:14px;
}
.foot .nl input::placeholder{color:var(--muted)}
.foot .nl input:focus{outline:0;border-color:var(--accent)}
.foot .nl button{
  background:var(--accent);color:var(--bg);padding:11px 22px;
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
}
.foot .nl button:hover{background:var(--paper);color:var(--bg)}

.foot-bottom{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:60px;padding-top:24px;border-top:1px solid var(--rule);
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;flex-wrap:wrap;gap:14px;text-transform:uppercase;
}
.foot-bottom .ar{font-family:var(--arabic);color:var(--accent);font-size:18px;text-transform:none;letter-spacing:0;font-weight:700}

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

/* ---------- arabic motif visibility ---------- */
[data-motifs="off"] .ar,
[data-motifs="off"] .arabic{display:none !important}

/* hide unused flag/symbol residues from refonte */
.flags-pair, .trf-flags { display:none !important }
.ph { display:none !important }
.illust { display:none !important }

/* tweaks panel */
.kicker{display:none}
