/* ============================================================
   FAMILLE MOUSSAOUI — v2 — Professional Genealogy Site
   Palette : forest green · warm gold · warm cream · burgundy
   ============================================================ */

/* ── Design Tokens ── */
:root {
  /* Colors */
  --c-green-900: #0f1f18;
  --c-green-800: #162b21;
  --c-green-700: #1e3a2c;
  --c-green-600: #2a5240;
  --c-green-500: #3a6e55;
  --c-green-400: #4f9070;
  --c-gold-700: #8a6d2a;
  --c-gold-600: #a6862f;
  --c-gold-500: #b8953e;
  --c-gold-400: #c9a84c;
  --c-gold-300: #d4ba6e;
  --c-gold-200: #e3d3a0;
  --c-gold-100: #f0e8cc;
  --c-cream-100: #faf8f4;
  --c-cream-200: #f5f1ea;
  --c-cream-300: #ede7da;
  --c-cream-400: #ddd5c4;
  --c-red-600: #8b2e2e;
  --c-red-500: #a84040;
  --c-red-400: #c25555;
  --c-purple-500: #6b5b8a;
  --c-text: #1c1c1a;
  --c-text-secondary: #5c5a52;
  --c-text-muted: #9a9789;
  --c-border: #e2ddd3;
  --c-white: #ffffff;

  /* Shadows — layered for realism */
  --shadow-xs: 0 1px 2px rgba(28,28,26,.04);
  --shadow-sm: 0 1px 3px rgba(28,28,26,.06), 0 4px 8px rgba(28,28,26,.04);
  --shadow-md: 0 2px 4px rgba(28,28,26,.04), 0 8px 24px rgba(28,28,26,.08);
  --shadow-lg: 0 4px 8px rgba(28,28,26,.04), 0 12px 40px rgba(28,28,26,.12);
  --shadow-xl: 0 8px 16px rgba(28,28,26,.06), 0 24px 64px rgba(28,28,26,.14);
  --shadow-gold: 0 4px 16px rgba(184,149,62,.18);
  --shadow-up-sm: 0 -2px 8px rgba(28,28,26,.04);

  /* Radii */
  --r-sm: 8px;
  --r-md: 14px;
  --r-lg: 22px;
  --r-xl: 32px;
  --r-full: 9999px;

  /* Type */
  --f-display: 'Playfair Display', Georgia, serif;
  --f-body: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --f-arabic: 'Amiri', 'Traditional Arabic', serif;

  /* Timing */
  --ease: cubic-bezier(.25,.46,.45,.94);
  --ease-out: cubic-bezier(.16,1,.3,1);
  --ease-spring: cubic-bezier(.34,1.56,.64,1);
  --dur: .3s;
  --dur-slow: .5s;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;scroll-padding-top:80px}
body{font-family:var(--f-body);color:var(--c-text);background:var(--c-cream-200);line-height:1.75;overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
body.locked{overflow:hidden}
img{max-width:100%;display:block}
a{color:var(--c-gold-600);text-decoration:none;transition:color var(--dur) var(--ease)}
a:hover{color:var(--c-gold-500)}
button{cursor:pointer;font-family:inherit;border:none;background:none}
strong{font-weight:600}
::selection{background:var(--c-gold-200);color:var(--c-green-800)}

/* ── Scroll Progress Bar ── */
#scroll-progress{position:fixed;top:0;left:0;height:3px;background:linear-gradient(90deg,var(--c-gold-500),var(--c-gold-300));z-index:2000;width:0%;transition:none;pointer-events:none}

/* ── Geometric Background Pattern ── */
.geo-bg,.hero-bg-pattern,.login-pattern{
  position:absolute;inset:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100' height='100'%3E%3Cdefs%3E%3Cpattern id='p' width='100' height='100' patternUnits='userSpaceOnUse'%3E%3Cpath d='M50 5L95 50L50 95L5 50Z' fill='none' stroke='%23C9A84C' stroke-width='.4' opacity='.06'/%3E%3Ccircle cx='50' cy='50' r='18' fill='none' stroke='%23C9A84C' stroke-width='.3' opacity='.04'/%3E%3C/pattern%3E%3C/defs%3E%3Crect width='100' height='100' fill='url(%23p)'/%3E%3C/svg%3E");
}

/* ============================================================
   LOGIN OVERLAY
   ============================================================ */
#login-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:var(--c-green-800);transition:opacity .6s var(--ease),visibility .6s}
#login-overlay.hidden{opacity:0;visibility:hidden;pointer-events:none}

.login-card{
  position:relative;z-index:1;background:var(--c-white);border-radius:var(--r-xl);
  padding:3rem 2.5rem;width:90%;max-width:400px;text-align:center;
  box-shadow:var(--shadow-xl),0 0 80px rgba(184,149,62,.1);
  animation:loginIn .8s var(--ease-out) .15s both;
}
@keyframes loginIn{from{opacity:0;transform:translateY(24px) scale(.97)}to{opacity:1;transform:none}}

.login-ornament{width:48px;height:2px;background:linear-gradient(90deg,transparent,var(--c-gold-400),transparent);margin:0 auto 1.6rem;border-radius:1px}
.login-bismillah{font-family:var(--f-arabic);font-size:1.5rem;color:var(--c-gold-600);margin-bottom:.8rem;line-height:2}
.login-title{font-family:var(--f-display);font-size:1.7rem;color:var(--c-green-700);font-weight:700}
.login-title-ar{font-family:var(--f-arabic);font-size:1.3rem;color:var(--c-gold-600);margin-bottom:1rem}
.login-divider{width:100%;height:1px;background:linear-gradient(90deg,transparent,var(--c-cream-400),transparent);margin:1.2rem 0}

#login-form{display:flex;flex-direction:column;gap:.7rem}
.login-label{font-size:.8rem;font-weight:500;color:var(--c-text-secondary);text-align:left;letter-spacing:.02em}
#login-password{
  width:100%;padding:.9rem 1rem;border:1.5px solid var(--c-border);border-radius:var(--r-sm);
  font-size:.95rem;font-family:var(--f-body);background:var(--c-cream-100);
  transition:border-color var(--dur),box-shadow var(--dur);outline:none;
}
#login-password:focus{border-color:var(--c-gold-400);box-shadow:0 0 0 3px rgba(184,149,62,.12)}
#login-btn{
  width:100%;padding:.9rem;border-radius:var(--r-sm);
  background:var(--c-green-700);color:var(--c-white);font-size:.95rem;font-weight:600;
  letter-spacing:.02em;transition:all var(--dur) var(--ease);
}
#login-btn:hover{background:var(--c-green-600);box-shadow:var(--shadow-md);transform:translateY(-1px)}
#login-btn:active{transform:translateY(0)}
.login-error{color:var(--c-red-500);font-size:.85rem;font-weight:500}
.login-footer-text{font-size:.78rem;color:var(--c-text-muted)}

/* ============================================================
   NAVIGATION
   ============================================================ */
#navbar{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  transition:all var(--dur) var(--ease);
}
#navbar.scrolled{
  background:rgba(15,31,24,.92);backdrop-filter:blur(16px) saturate(1.4);-webkit-backdrop-filter:blur(16px) saturate(1.4);
  box-shadow:0 1px 0 rgba(255,255,255,.04),var(--shadow-md);
}
.nav-inner{max-width:1200px;margin:0 auto;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between}
.nav-brand{font-family:var(--f-display);font-size:1.2rem;font-weight:700;color:var(--c-gold-400) !important;letter-spacing:.03em}
.nav-links{list-style:none;display:flex;gap:1.8rem}
.nav-links a{
  color:rgba(255,255,255,.7);font-size:.82rem;font-weight:500;letter-spacing:.03em;
  text-transform:uppercase;position:relative;padding:.25rem 0;transition:color var(--dur);
}
.nav-links a::after{content:'';position:absolute;bottom:-2px;left:0;width:0;height:1.5px;background:var(--c-gold-400);transition:width var(--dur) var(--ease)}
.nav-links a:hover,.nav-links a.active{color:var(--c-gold-300) !important}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}

.nav-toggle{display:none;flex-direction:column;gap:5px;padding:4px}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--c-gold-400);border-radius:1px;transition:all var(--dur)}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px)}

/* ============================================================
   HERO
   ============================================================ */
#hero{
  position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(175deg,var(--c-green-900) 0%,var(--c-green-800) 35%,var(--c-green-700) 100%);
  overflow:hidden;
}
.hero-bg-pattern{opacity:.6}
.hero-content{position:relative;z-index:1;text-align:center;padding:2rem;max-width:700px}

.hero-bismillah{font-family:var(--f-arabic);font-size:clamp(1.4rem,3.5vw,2.2rem);color:var(--c-gold-400);margin-bottom:2rem;line-height:2;opacity:0;animation:fadeDown .9s var(--ease) .3s forwards}
.hero-title{font-family:var(--f-display);font-size:clamp(2.6rem,7vw,4.5rem);color:var(--c-white);font-weight:700;letter-spacing:.01em;line-height:1.08;margin-bottom:.4rem;opacity:0;animation:fadeUp .9s var(--ease) .5s forwards}
.hero-title-ar{font-family:var(--f-arabic);font-size:clamp(1.6rem,4.5vw,2.6rem);color:var(--c-gold-300);margin-bottom:1.8rem;opacity:0;animation:fadeUp .9s var(--ease) .7s forwards}
.hero-divider{width:64px;height:1.5px;background:linear-gradient(90deg,transparent,var(--c-gold-400),transparent);margin:0 auto 1.6rem;opacity:0;animation:fadeIn .8s var(--ease) .9s forwards}
.hero-subtitle{font-family:var(--f-display);font-size:clamp(.95rem,2.2vw,1.3rem);color:rgba(255,255,255,.8);font-weight:400;font-style:italic;margin-bottom:.5rem;opacity:0;animation:fadeUp .8s var(--ease) 1s forwards}
.hero-date{font-size:.85rem;color:var(--c-gold-200);font-weight:300;letter-spacing:.06em;text-transform:uppercase;opacity:0;animation:fadeUp .8s var(--ease) 1.15s forwards}
.hero-gen{font-size:.78rem;color:rgba(255,255,255,.35);margin-top:.6rem;opacity:0;animation:fadeUp .8s var(--ease) 1.3s forwards}

.hero-scroll-hint{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);opacity:0;animation:fadeIn 1s var(--ease) 1.6s forwards}
.scroll-arrow{display:block;width:20px;height:20px;border-right:1.5px solid var(--c-gold-400);border-bottom:1.5px solid var(--c-gold-400);transform:rotate(45deg);animation:scrollBounce 2.2s ease-in-out infinite}
@keyframes scrollBounce{0%,100%{transform:rotate(45deg) translateY(0);opacity:.4}50%{transform:rotate(45deg) translateY(8px);opacity:1}}

/* ============================================================
   SECTIONS — Common
   ============================================================ */
section{padding:5.5rem 0}
.section-container{max-width:1060px;margin:0 auto;padding:0 2rem}
.section-title{text-align:center;margin-bottom:1.2rem}
.section-title-text{display:block;font-family:var(--f-display);font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:700;color:var(--c-green-800);line-height:1.15}
.section-title-ar{display:block;font-family:var(--f-arabic);font-size:1.15rem;color:var(--c-gold-600);margin-top:.35rem}
.section-intro{text-align:center;color:var(--c-text-secondary);font-size:.95rem;max-width:560px;margin:0 auto 3.5rem;line-height:1.8}

/* Section backgrounds */
#arbre{background:var(--c-cream-100)}
#decouvertes{background:var(--c-cream-200)}
#archives{background:var(--c-cream-100)}
#hypotheses{background:var(--c-cream-200)}
#carte{background:var(--c-green-800);color:var(--c-white)}
#carte .section-title-text{color:var(--c-white)}
#carte .section-intro{color:rgba(255,255,255,.6)}
#actions{background:var(--c-cream-100)}
#contacts{background:var(--c-cream-200)}

/* ============================================================
   FAMILY TREE
   ============================================================ */
.family-alliances{
  text-align:center;margin-bottom:1.5rem;padding:.9rem 1.5rem;
  background:var(--c-white);border-radius:var(--r-md);border:1px solid var(--c-border);
  font-size:.88rem;box-shadow:var(--shadow-xs);
}
.alliance-detail{color:var(--c-text-muted);font-size:.8rem}
.alliance-tag.charabi{background:rgba(184,149,62,.1);padding:.15rem .5rem;border-radius:4px;font-weight:600;color:var(--c-gold-600)}

.charabi-alert{
  background:linear-gradient(135deg,rgba(184,149,62,.06),rgba(184,149,62,.02));
  border:1px solid var(--c-gold-300);border-radius:var(--r-md);padding:1.3rem 1.5rem 1.3rem 3rem;
  margin-bottom:2.5rem;font-size:.9rem;line-height:1.75;position:relative;box-shadow:var(--shadow-xs);
}
.charabi-alert::before{content:'!';position:absolute;top:50%;left:1rem;transform:translateY(-50%);width:26px;height:26px;background:var(--c-gold-500);color:var(--c-white);border-radius:var(--r-full);display:grid;place-items:center;font-weight:800;font-size:.75rem}
.highlight-charabi{color:var(--c-gold-600);background:rgba(184,149,62,.1);padding:.05rem .35rem;border-radius:3px;font-weight:600}

.tree{display:flex;flex-direction:column;align-items:center}
.tree-level{display:flex;flex-direction:column;align-items:center;width:100%}

.tree-connector{
  width:1.5px;height:36px;position:relative;
  background:linear-gradient(to bottom,var(--c-gold-400),var(--c-gold-300));
}
.tree-connector::after{content:'';position:absolute;bottom:-3px;left:50%;transform:translateX(-50%);width:7px;height:7px;border-radius:var(--r-full);background:var(--c-gold-400)}

/* Person card */
.person-card{
  background:var(--c-white);border-radius:var(--r-md);padding:1.6rem 2rem;
  text-align:center;max-width:460px;width:100%;
  box-shadow:var(--shadow-sm);border:1px solid var(--c-border);
  position:relative;transition:all var(--dur) var(--ease);
  border-top:3px solid var(--c-green-600);
}
.person-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.person-card.maire,.person-card.administrateur{border-top-color:var(--c-gold-500)}
.person-card.mobilise{border-top-color:var(--c-red-600)}
.person-card.ancestor{border-top-color:var(--c-text-muted);border-style:solid;border-top-style:dashed}
.person-card.yassine{border-top-color:var(--c-green-500)}
.person-card.spouse-card{border-top-color:var(--c-gold-300);background:linear-gradient(160deg,var(--c-white),rgba(184,149,62,.02))}

.person-badges{display:flex;justify-content:center;gap:.4rem;margin-bottom:.7rem;flex-wrap:wrap}
.badge{
  display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .65rem;
  border-radius:var(--r-full);font-size:.65rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
}
.badge-maire,.badge-admin{background:linear-gradient(135deg,var(--c-gold-500),var(--c-gold-600));color:var(--c-white)}
.badge-mobilise{background:linear-gradient(135deg,var(--c-red-600),var(--c-red-500));color:var(--c-white)}
.badge-confirm{background:var(--c-cream-300);color:var(--c-text-secondary);border:1px dashed var(--c-text-muted)}
.badge-confirmed{background:var(--c-green-600);color:var(--c-white)}

.person-name{font-family:var(--f-display);font-size:1.2rem;font-weight:700;color:var(--c-green-800);margin-bottom:.25rem}
.person-gen{font-weight:400;font-size:.8rem;color:var(--c-text-muted)}
.person-name-hint{font-weight:400;color:var(--c-text-secondary);font-size:.95rem}
.person-dates{font-size:.9rem;color:var(--c-text-secondary)}
.person-places{font-size:.85rem;color:var(--c-text-muted)}
.detail-note{color:var(--c-text-secondary);font-size:.82rem}

.person-details{text-align:left;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--c-cream-300)}
.person-details[hidden]{display:none}
.person-detail-row{padding:.45rem 0;font-size:.88rem;line-height:1.65;border-bottom:1px solid var(--c-cream-200)}
.person-detail-row:last-child{border-bottom:none}

.person-toggle{
  margin-top:.8rem;border:1px solid var(--c-border);border-radius:var(--r-full);
  padding:.3rem 1.2rem;font-size:.78rem;font-weight:500;color:var(--c-gold-600);
  transition:all var(--dur) var(--ease);background:transparent;
}
.person-toggle:hover{border-color:var(--c-gold-400);background:var(--c-cream-100)}
.person-toggle.open{background:var(--c-cream-200);border-color:var(--c-gold-400)}

/* Spouse level */
.spouse-level{margin-top:-.3rem}
.spouse-connector{width:48px;height:1.5px;background:var(--c-gold-200);margin:0 auto .6rem}

/* Children grid */
.children-label{text-align:center;font-family:var(--f-display);font-size:1.05rem;color:var(--c-green-800);margin-bottom:1.3rem;font-weight:600}
.children-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.6rem;max-width:740px;margin:0 auto;padding:0 .5rem}
.small-grid{grid-template-columns:repeat(3,1fr);max-width:440px}

.child-card{
  background:var(--c-white);border-radius:var(--r-sm);padding:.85rem .6rem;text-align:center;
  border:1px solid var(--c-border);transition:all var(--dur) var(--ease);
}
.child-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px);border-color:var(--c-cream-400)}
.child-card.highlight{border-color:var(--c-gold-400);box-shadow:var(--shadow-gold);background:linear-gradient(160deg,var(--c-white),rgba(184,149,62,.04))}
.child-card.deceased{opacity:.65}
.child-number{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:var(--r-full);background:var(--c-green-700);color:var(--c-white);font-size:.65rem;font-weight:700;margin-bottom:.3rem}
.child-card h4{font-family:var(--f-display);font-size:.88rem;font-weight:600;color:var(--c-green-800)}
.child-note{font-size:.72rem;color:var(--c-text-muted);margin-top:.15rem;line-height:1.4}

.tree-note{margin-top:2rem;padding:.9rem 1.3rem;background:rgba(184,149,62,.06);border-left:2px solid var(--c-gold-400);border-radius:0 var(--r-sm) var(--r-sm) 0;font-size:.85rem;color:var(--c-text-secondary);max-width:580px}

/* ============================================================
   DISCOVERIES
   ============================================================ */
.discoveries-grid{display:grid;gap:1rem}

.discovery-card{
  background:var(--c-white);border-radius:var(--r-md);overflow:hidden;
  box-shadow:var(--shadow-xs);border:1px solid var(--c-border);
  transition:all var(--dur) var(--ease);
}
.discovery-card:hover{box-shadow:var(--shadow-sm)}

.discovery-header{
  display:flex;align-items:center;gap:1rem;padding:1.1rem 1.4rem;cursor:pointer;
  transition:background var(--dur);user-select:none;
}
.discovery-header:hover{background:var(--c-cream-100)}

.discovery-number{
  display:grid;place-items:center;width:36px;height:36px;min-width:36px;
  border-radius:var(--r-full);background:var(--c-green-700);
  color:var(--c-gold-400);font-family:var(--f-display);font-size:1rem;font-weight:700;
}
.discovery-title{font-family:var(--f-display);font-size:1.05rem;font-weight:600;color:var(--c-green-800);flex:1}

.discovery-header::after{
  content:'';width:8px;height:8px;border-right:1.5px solid var(--c-gold-500);border-bottom:1.5px solid var(--c-gold-500);
  transform:rotate(45deg);transition:transform var(--dur) var(--ease);flex-shrink:0;
}
.discovery-card.open .discovery-header::after{transform:rotate(-135deg)}

.discovery-body{
  max-height:0;overflow:hidden;transition:max-height var(--dur-slow) var(--ease);
  padding:0 1.4rem;font-size:.92rem;line-height:1.8;
}
.discovery-card.open .discovery-body{max-height:2000px;padding:0 1.4rem 1.4rem;padding-left:calc(1.4rem + 36px + 1rem)}

.discovery-body p{margin-bottom:.7rem}
.discovery-body ul{margin-bottom:.7rem;padding-left:1.2rem}
.discovery-body li{margin-bottom:.25rem}

.discovery-body blockquote{
  padding:.9rem 1.3rem;margin:.9rem 0;background:var(--c-cream-100);
  border-left:2px solid var(--c-gold-400);border-radius:0 var(--r-sm) var(--r-sm) 0;
  font-style:italic;color:var(--c-green-700);font-size:.9rem;
}
.discovery-clues{list-style:none !important;padding-left:0 !important}
.discovery-clues li::before{content:'\2192\00a0';color:var(--c-gold-500);font-weight:700}
.discovery-conclusion{color:var(--c-green-700);font-weight:500;padding:.55rem .9rem;background:rgba(184,149,62,.06);border-radius:var(--r-sm);margin-top:.5rem}
.discovery-warning{padding:.7rem .9rem;background:rgba(139,46,46,.04);border-left:2px solid var(--c-red-600);border-radius:0 var(--r-sm) var(--r-sm) 0;margin:.7rem 0;font-size:.88rem}
.discovery-source{font-size:.82rem;color:var(--c-text-muted)}
.discovery-note{font-size:.82rem;color:var(--c-text-secondary);font-style:italic}

/* Fraction grid */
.fraction-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.5rem;margin:1rem 0}
.fraction-item{padding:.75rem .9rem;background:var(--c-cream-100);border-radius:var(--r-sm);border:1px solid var(--c-cream-400);font-size:.88rem}
.fraction-item.highlight-fraction{background:rgba(184,149,62,.07);border-color:var(--c-gold-400)}
.fraction-item.chorfa-fraction{background:rgba(42,82,64,.04);border-color:var(--c-green-500)}
.fraction-tag{display:inline-block;font-size:.6rem;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:.12rem .45rem;border-radius:10px;background:var(--c-gold-500);color:var(--c-white);vertical-align:middle;margin-left:.2rem}
.fraction-tag.chorfa-tag{background:var(--c-green-600)}
.fraction-source{font-size:.78rem;color:var(--c-text-muted);display:block;margin-top:.15rem}

/* Lieu list */
.lieu-list{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}
.lieu-item{display:flex;gap:.7rem;padding:.75rem .9rem;background:var(--c-cream-100);border-radius:var(--r-sm);font-size:.88rem;line-height:1.6}
.lieu-number{display:grid;place-items:center;min-width:44px;height:26px;background:var(--c-green-700);color:var(--c-gold-400);border-radius:4px;font-size:.65rem;font-weight:700;letter-spacing:.02em;align-self:flex-start;margin-top:.15rem}

/* Acte list */
.acte-list{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}
.acte{display:flex;align-items:flex-start;gap:.7rem;padding:.65rem .9rem;border-radius:var(--r-sm);font-size:.88rem;line-height:1.6}
.acte.confirmed{background:rgba(42,82,64,.04)}
.acte.not-found{background:rgba(139,46,46,.03)}
.acte-status{font-size:1.1rem;line-height:1.4;flex-shrink:0}
.acte.confirmed .acte-status{color:var(--c-green-600)}
.acte.not-found .acte-status{color:var(--c-red-500)}

/* ============================================================
   ARCHIVES
   ============================================================ */
.subsection-title{
  font-family:var(--f-display);font-size:1.1rem;font-weight:700;color:var(--c-green-800);
  margin:2.5rem 0 1rem;padding-bottom:.4rem;border-bottom:1.5px solid var(--c-gold-200);
}
.subsection-title:first-of-type{margin-top:0}

.anom-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--c-border)}
.anom-table{width:100%;border-collapse:collapse;background:var(--c-white);font-size:.84rem}
.anom-table thead{background:var(--c-green-700);color:var(--c-white)}
.anom-table th{padding:.7rem .8rem;text-align:left;font-weight:600;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}
.anom-table td{padding:.7rem .8rem;border-bottom:1px solid var(--c-cream-200);vertical-align:top}
.anom-table tbody tr:last-child td{border-bottom:none}
.anom-table tbody tr:hover{background:var(--c-cream-100)}
.cote-ref{font-size:.72rem;color:var(--c-text-muted)}

.status-badge{display:inline-block;padding:.15rem .5rem;border-radius:10px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.status-done{background:rgba(42,82,64,.1);color:var(--c-green-600)}
.status-partial{background:rgba(184,149,62,.12);color:var(--c-gold-700)}
.status-pending{background:rgba(139,46,46,.06);color:var(--c-red-500)}

.cartes-list{display:flex;flex-direction:column;gap:.4rem}
.carte-item{padding:.7rem .9rem;background:var(--c-white);border-radius:var(--r-sm);border-left:2px solid var(--c-gold-400);font-size:.88rem;box-shadow:var(--shadow-xs)}
.carte-item code{background:var(--c-cream-200);padding:.1rem .35rem;border-radius:3px;font-size:.78rem;color:var(--c-green-700)}

.non-numerise{background:var(--c-white);border-radius:var(--r-md);padding:1.1rem 1.4rem;border:1px dashed var(--c-gold-400);box-shadow:var(--shadow-xs)}
.non-numerise ul{padding-left:1.1rem}
.non-numerise li{margin-bottom:.5rem;font-size:.88rem}

/* ============================================================
   HYPOTHESES
   ============================================================ */
.hypotheses-grid{display:grid;gap:1.2rem}

.hypothesis-card{
  background:var(--c-white);border-radius:var(--r-md);padding:1.8rem;
  box-shadow:var(--shadow-sm);border:1px solid var(--c-border);
  border-left:4px solid var(--c-text-muted);transition:all var(--dur) var(--ease);
}
.hypothesis-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.hypothesis-card.h-strong{border-left-color:var(--c-green-500)}
.hypothesis-card.h-possible{border-left-color:var(--c-gold-500)}
.hypothesis-card.h-weak{border-left-color:var(--c-cream-400)}

.hypothesis-header{display:flex;align-items:center;gap:.8rem;margin-bottom:.9rem;flex-wrap:wrap}
.hypothesis-strength{
  display:inline-block;padding:.25rem .7rem;border-radius:var(--r-full);
  font-size:.65rem;font-weight:800;letter-spacing:.07em;text-transform:uppercase;
}
.h-strong .hypothesis-strength{background:var(--c-green-600);color:var(--c-white)}
.h-possible .hypothesis-strength{background:var(--c-gold-500);color:var(--c-white)}
.h-weak .hypothesis-strength{background:var(--c-cream-300);color:var(--c-text-secondary)}
.hypothesis-header h3{font-family:var(--f-display);font-size:1.1rem;font-weight:700;color:var(--c-green-800)}
.hypothesis-summary{font-size:.92rem;line-height:1.75;color:var(--c-text)}

.hypothesis-indices{margin-top:1.1rem;padding-top:.9rem;border-top:1px solid var(--c-cream-300)}
.hypothesis-indices h4{font-size:.8rem;font-weight:700;color:var(--c-gold-600);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}
.hypothesis-indices ol{padding-left:1.3rem;font-size:.88rem;line-height:1.7;columns:2;column-gap:2rem}
.hypothesis-indices li{margin-bottom:.25rem;break-inside:avoid}

/* ============================================================
   MAP
   ============================================================ */
#map-container{max-width:1060px;margin:0 auto;padding:0 2rem}
#map{width:100%;height:480px;border-radius:var(--r-md);border:1.5px solid rgba(184,149,62,.25);box-shadow:var(--shadow-lg);z-index:1}

.map-legend{display:flex;justify-content:center;gap:2rem;margin-top:1.3rem;flex-wrap:wrap}
.legend-item{display:flex;align-items:center;gap:.45rem;font-size:.82rem;color:rgba(255,255,255,.7)}
.legend-dot{width:10px;height:10px;border-radius:var(--r-full);border:1.5px solid rgba(255,255,255,.2)}
.legend-algeria{background:var(--c-gold-400)}
.legend-france{background:var(--c-green-400)}
.legend-property{background:var(--c-red-500)}
.legend-transit{background:var(--c-purple-500)}

.leaflet-popup-content-wrapper{border-radius:var(--r-sm) !important;font-family:var(--f-body) !important;box-shadow:var(--shadow-md) !important}
.leaflet-popup-content{margin:10px 14px !important;font-size:.85rem !important;line-height:1.55 !important}
.leaflet-popup-content strong{color:var(--c-green-800);font-family:var(--f-display)}

/* ============================================================
   TIMELINE
   ============================================================ */
.timeline-group{margin-bottom:2.5rem}
.timeline-group:last-child{margin-bottom:0}
.timeline-group-title{
  font-family:var(--f-display);font-size:1.1rem;font-weight:700;margin-bottom:1rem;
  display:flex;align-items:center;gap:.5rem;
}
.timeline-group-title::before{content:'';display:inline-block;width:10px;height:10px;border-radius:var(--r-full)}
.timeline-group-title.done{color:var(--c-green-600)}
.timeline-group-title.done::before{background:var(--c-green-600)}
.timeline-group-title.waiting{color:var(--c-gold-600)}
.timeline-group-title.waiting::before{background:var(--c-gold-500)}
.timeline-group-title.todo{color:var(--c-green-800)}
.timeline-group-title.todo::before{background:var(--c-green-800)}

.timeline{position:relative;padding-left:1.8rem}
.timeline::before{content:'';position:absolute;left:4px;top:0;bottom:0;width:1.5px;background:var(--c-cream-400)}

.timeline-item{position:relative;padding-bottom:1rem}
.timeline-item:last-child{padding-bottom:0}

.timeline-dot{
  position:absolute;left:-1.8rem;top:.4rem;width:10px;height:10px;border-radius:var(--r-full);
  border:2px solid var(--c-white);z-index:1;
}
.timeline-item.done .timeline-dot{background:var(--c-green-600);box-shadow:0 0 0 2px rgba(42,82,64,.12)}
.timeline-item.waiting .timeline-dot{background:var(--c-gold-500);box-shadow:0 0 0 2px rgba(184,149,62,.12)}
.timeline-item.todo .timeline-dot{background:var(--c-green-800);box-shadow:0 0 0 2px rgba(30,58,44,.12)}

.timeline-content{
  background:var(--c-white);padding:.85rem 1.1rem;border-radius:var(--r-sm);
  border:1px solid var(--c-border);font-size:.9rem;line-height:1.6;box-shadow:var(--shadow-xs);
}
.timeline-content p{margin:0}
.timeline-delay{color:var(--c-text-muted);font-size:.8rem;font-style:italic}

/* ============================================================
   QUESTIONS
   ============================================================ */
#actions .questions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.8rem;margin-top:1.2rem}
#actions .question-card{
  background:var(--c-white);border:1px solid var(--c-border);border-radius:var(--r-md);
  padding:1.1rem;display:flex;align-items:flex-start;gap:.7rem;transition:all var(--dur) var(--ease);
}
#actions .question-card:hover{box-shadow:var(--shadow-sm);border-color:var(--c-gold-400);transform:translateY(-2px)}
#actions .question-icon{
  display:grid;place-items:center;width:30px;height:30px;min-width:30px;
  border-radius:var(--r-full);border:1.5px solid var(--c-gold-400);color:var(--c-gold-500);
  font-family:var(--f-display);font-size:1rem;font-weight:700;
}
#actions .question-card p{color:var(--c-text);font-size:.88rem;line-height:1.55}

/* Arabic questions */
.mouloud-questions{margin-top:3rem;padding:1.8rem;background:var(--c-white);border-radius:var(--r-md);border:1px solid var(--c-border);box-shadow:var(--shadow-sm)}
.arabic-questions{display:flex;flex-direction:column;gap:.6rem;margin-top:.8rem}
.arabic-q{padding:.7rem .9rem;background:var(--c-cream-100);border-radius:var(--r-sm);border-right:2px solid var(--c-gold-400)}
.arabic-text{font-family:var(--f-arabic);font-size:1.1rem;color:var(--c-green-800);line-height:2;margin-bottom:.1rem}
.french-text{font-size:.82rem;color:var(--c-text-muted);font-style:italic}

/* ============================================================
   CONTACTS TABLE
   ============================================================ */
.contacts-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--r-md);box-shadow:var(--shadow-sm);border:1px solid var(--c-border)}
.contacts-table{width:100%;border-collapse:collapse;background:var(--c-white);font-size:.88rem}
.contacts-table thead{background:var(--c-green-700);color:var(--c-white)}
.contacts-table th{padding:.8rem 1rem;text-align:left;font-weight:600;font-size:.72rem;letter-spacing:.04em;text-transform:uppercase}
.contacts-table td{padding:.8rem 1rem;border-bottom:1px solid var(--c-cream-200);vertical-align:top}
.contacts-table tbody tr:last-child td{border-bottom:none}
.contacts-table tbody tr:hover{background:var(--c-cream-100)}
.contact-detail{font-size:.78rem;color:var(--c-text-secondary)}
.contact-hours{font-size:.78rem;color:var(--c-text-muted)}

/* ============================================================
   FOOTER
   ============================================================ */
#footer{background:var(--c-green-900);color:rgba(255,255,255,.6);text-align:center;padding:3rem 2rem}
.footer-ornament{width:48px;height:1.5px;background:linear-gradient(90deg,transparent,var(--c-gold-400),transparent);margin:0 auto 1.4rem}
.footer-author{font-size:.9rem;margin-bottom:.25rem}
.footer-author strong{color:var(--c-gold-400)}
.footer-private{font-size:.78rem;color:rgba(255,255,255,.3);margin-bottom:.3rem}
.footer-update{font-size:.72rem;color:rgba(255,255,255,.2);margin-bottom:1.2rem}
.footer-bismillah{font-family:var(--f-arabic);font-size:1rem;color:var(--c-gold-600);opacity:.5}

/* Back to top */
#back-to-top{
  position:fixed;bottom:2rem;right:2rem;width:42px;height:42px;
  border-radius:var(--r-full);background:var(--c-green-700);color:var(--c-gold-400);
  display:grid;place-items:center;font-size:1.2rem;z-index:800;
  box-shadow:var(--shadow-md);opacity:0;transform:translateY(12px);
  transition:all var(--dur) var(--ease);pointer-events:none;
}
#back-to-top.visible{opacity:1;transform:translateY(0);pointer-events:auto}
#back-to-top:hover{background:var(--c-green-600);transform:translateY(-2px);box-shadow:var(--shadow-lg)}

/* ============================================================
   MODAL
   ============================================================ */
.modal[hidden]{display:none}
.modal{position:fixed;inset:0;z-index:9000;display:flex;align-items:center;justify-content:center;padding:2rem}
.modal-backdrop{position:absolute;inset:0;background:rgba(15,31,24,.5);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.modal-content{
  position:relative;background:var(--c-white);border-radius:var(--r-lg);padding:2rem;
  max-width:480px;width:100%;max-height:80vh;overflow-y:auto;
  box-shadow:var(--shadow-xl);animation:modalIn .3s var(--ease-out);
}
@keyframes modalIn{from{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:none}}
.modal-close{position:absolute;top:.8rem;right:1rem;font-size:1.6rem;color:var(--c-text-muted);transition:color var(--dur)}
.modal-close:hover{color:var(--c-text)}

/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */
.animate-on-scroll{opacity:0;transform:translateY(20px);transition:opacity .65s var(--ease),transform .65s var(--ease)}
.animate-on-scroll.visible{opacity:1;transform:none}
.animate-on-scroll:nth-child(2){transition-delay:.06s}
.animate-on-scroll:nth-child(3){transition-delay:.12s}
.animate-on-scroll:nth-child(4){transition-delay:.18s}
.animate-on-scroll:nth-child(5){transition-delay:.24s}
.animate-on-scroll:nth-child(6){transition-delay:.3s}

@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@keyframes fadeDown{from{opacity:0;transform:translateY(-18px)}to{opacity:1;transform:none}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:900px){
  .nav-toggle{display:flex}
  .nav-links{
    display:none;position:absolute;top:100%;left:0;right:0;
    background:rgba(15,31,24,.96);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
    flex-direction:column;padding:.8rem 2rem 1.2rem;gap:0;
  }
  .nav-links.open{display:flex}
  .nav-links li{padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}
  .nav-links li:last-child{border-bottom:none}
  .children-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.5rem}
  .small-grid{grid-template-columns:repeat(3,1fr)}
  .discovery-card.open .discovery-body{padding-left:1.4rem}
  .fraction-grid{grid-template-columns:1fr}
  .hypothesis-indices ol{columns:1}
  .lieu-item{flex-direction:column;gap:.25rem}
  #map{height:340px}
}

@media(max-width:600px){
  section{padding:4rem 0}
  .section-container{padding:0 1.2rem}
  .nav-inner{padding:.7rem 1.2rem}
  .person-card{padding:1.2rem .9rem}
  .person-name{font-size:1.05rem}
  .children-grid{grid-template-columns:repeat(3,1fr);gap:.4rem}
  .child-card{padding:.6rem .4rem}
  .child-card h4{font-size:.78rem}
  .discovery-header{padding:.9rem 1rem}
  .discovery-card.open .discovery-body{padding:0 1rem 1rem}
  .discovery-number{width:30px;height:30px;min-width:30px;font-size:.85rem}
  .timeline{padding-left:1.4rem}
  .timeline-dot{left:-1.4rem;width:8px;height:8px}
  #actions .questions-grid{grid-template-columns:1fr}
  .arabic-text{font-size:1rem}
  .mouloud-questions{padding:1.1rem}
  .hypothesis-header{flex-direction:column;gap:.4rem;align-items:flex-start}
  .hypothesis-card{padding:1.3rem}

  /* Stack tables */
  .contacts-table thead,.anom-table thead{display:none}
  .contacts-table,.contacts-table tbody,.contacts-table tr,.contacts-table td,
  .anom-table,.anom-table tbody,.anom-table tr,.anom-table td{display:block;width:100%}
  .contacts-table tr,.anom-table tr{margin-bottom:.7rem;padding:.4rem;border:1px solid var(--c-border);border-radius:var(--r-sm)}
  .contacts-table td,.anom-table td{padding:.35rem .7rem;border-bottom:1px solid var(--c-cream-200)}
  .contacts-table td::before,.anom-table td::before{content:attr(data-label);display:block;font-weight:700;font-size:.68rem;text-transform:uppercase;color:var(--c-green-700);letter-spacing:.03em;margin-bottom:.1rem}
  .login-card{padding:2rem 1.5rem}

  #back-to-top{bottom:1.2rem;right:1.2rem;width:38px;height:38px;font-size:1rem}
}
