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

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --gold:#C49B39;
  --gold-bright:#D4AB49;
  --gold-dim:rgba(196,155,57,0.35);
  --gold-faint:rgba(196,155,57,0.08);
  --gold-ghost:rgba(196,155,57,0.04);
  --bg:#07050A;
  --bg-1:#0D0A12;
  --bg-2:#100C16;
  --bg-3:#151018;
  --text-100:#FFFFFF;
  --text-90:#F0E6D3;
  --text-70:rgba(240,230,211,0.7);
  --text-50:rgba(240,230,211,0.5);
  --text-30:rgba(240,230,211,0.3);
  --border-strong:rgba(196,155,57,0.3);
  --border-mid:rgba(196,155,57,0.15);
  --border-soft:rgba(196,155,57,0.07);
  --font-en:'Cormorant Garamond',Georgia,serif;
  --font-ar:'Noto Naskh Arabic',serif;
  --r:2px;
  --transition:all 0.25s cubic-bezier(0.4,0,0.2,1);
}

html{font-size:18px;scroll-behavior:smooth}
body{background:var(--bg);color:var(--text-90);line-height:1.75;min-height:100vh;font-family:var(--font-ar)}
html[lang="ar"] body{direction:rtl;text-align:right}
html[lang="en"] body{direction:ltr;text-align:left;font-family:var(--font-en)}
h1,h2,h3,h4{font-family:var(--font-ar);font-weight:700;line-height:1.2;color:var(--text-100)}
html[lang="en"] h1,html[lang="en"] h2,html[lang="en"] h3{font-family:var(--font-en)}
a{color:var(--gold);text-decoration:none;transition:var(--transition)}
a:hover{color:var(--gold-bright);opacity:1}

/* ── Ticker ── */
.ticker-bar{
  height:38px;
  background:rgba(196,155,57,0.06);
  border-bottom:1px solid var(--border-mid);
  overflow:hidden;
  white-space:nowrap;
  display:flex;
  align-items:center;
}
.ticker-track{
  display:inline-flex;
  gap:56px;
  animation:ticker-ltr 35s linear infinite;
}
@keyframes ticker-ltr{
  0%{transform:translateX(-50%)}
  100%{transform:translateX(0%)}
}
.ticker-item{
  font-size:13px;
  color:rgba(196,155,57,0.75);
  letter-spacing:2px;
  font-family:var(--font-ar);
  font-weight:700;
  padding:0 4px;
}
.ticker-sep{
  color:rgba(196,155,57,0.25);
  font-size:16px;
}

/* ── Nav ── */
.site-nav{
  height:70px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 48px;
  background:rgba(7,5,10,0.97);
  border-bottom:1px solid var(--border-mid);
  position:sticky;
  top:0;
  z-index:200;
  backdrop-filter:blur(12px);
}
.nav-logo{
  font-family:var(--font-en);
  font-size:28px;
  font-weight:700;
  color:var(--gold);
  letter-spacing:4px;
  font-style:italic;
  transition:var(--transition);
}
.nav-logo:hover{color:var(--gold-bright);opacity:1}
.nav-links{display:flex;gap:32px;align-items:center}
.nav-links a{
  color:var(--text-50);
  font-size:15px;
  letter-spacing:1px;
  font-family:var(--font-ar);
  font-weight:700;
  position:relative;
  transition:var(--transition);
}
.nav-links a::after{
  content:'';
  position:absolute;
  bottom:-4px;
  right:0;
  left:0;
  height:1px;
  background:var(--gold);
  transform:scaleX(0);
  transition:transform 0.25s cubic-bezier(0.4,0,0.2,1);
  transform-origin:right;
}
html[lang="en"] .nav-links a::after{transform-origin:left}
.nav-links a:hover{color:var(--text-90)}
.nav-links a:hover::after{transform:scaleX(1)}
.nav-add-btn{
  background:var(--gold);
  color:var(--bg);
  border:none;
  padding:10px 24px;
  font-family:var(--font-ar);
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  border-radius:var(--r);
  letter-spacing:1px;
  transition:var(--transition);
}
.nav-add-btn:hover{background:var(--gold-bright);transform:translateY(-1px)}
.nav-add-btn:active{transform:translateY(0)}

/* ── Hero (full-screen map) ── */
.wm-hero{
  position:relative;
  min-height:100vh;
  display:flex;
  flex-direction:column;
}
#home-map{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  z-index:0;
  filter:brightness(0.4) saturate(0.5) sepia(0.3);
}
.wm-shrine-bg{
  position:absolute;
  inset:0;
  z-index:0;
  background-image:url('/storage/site/shrine-hero.jpg');
  background-size:cover;
  background-position:center 25%;
  filter:brightness(0.28) saturate(0.55) sepia(0.25);
}
.wm-hero-overlay{
  position:absolute;
  inset:0;
  z-index:1;
  background:
    linear-gradient(180deg,rgba(7,5,10,0.85) 0%,rgba(7,5,10,0.15) 30%,rgba(7,5,10,0.15) 65%,rgba(7,5,10,0.98) 100%);
}
.wm-hero-content{
  position:relative;
  z-index:10;
  display:flex;
  flex-direction:column;
  min-height:100vh;
}
.wm-search-zone{
  flex:1;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  padding:6rem 2rem 2rem;
  text-align:center;
  min-height:60vh;
}
.wm-eyebrow{
  font-family:var(--font-en);
  font-size:12px;
  letter-spacing:6px;
  color:rgba(196,155,57,0.55);
  text-transform:uppercase;
  margin-bottom:20px;
  font-style:italic;
}
.wm-title{
  font-family:var(--font-ar);
  font-size:clamp(3rem,6.5vw,5.5rem);
  font-weight:700;
  color:var(--text-100);
  line-height:1.1;
  margin-bottom:12px;
  text-shadow:0 4px 60px rgba(0,0,0,1);
}
.wm-title em{color:var(--gold);font-style:normal}
.wm-subtitle{
  font-family:var(--font-en);
  font-style:italic;
  font-size:17px;
  color:var(--text-30);
  letter-spacing:4px;
  margin-bottom:44px;
}
.wm-search{
  display:flex;
  width:100%;
  max-width:580px;
  background:rgba(7,5,10,0.95);
  border:1px solid rgba(196,155,57,0.45);
  border-radius:var(--r);
  overflow:hidden;
  transition:border-color 0.25s ease;
  box-shadow:0 0 0 0 rgba(196,155,57,0);
}
.wm-search:focus-within{
  border-color:rgba(196,155,57,0.8);
  box-shadow:0 0 0 4px rgba(196,155,57,0.06);
}
.wm-search input{
  flex:1;
  background:transparent;
  border:none;
  padding:18px 24px;
  color:var(--text-100);
  font-size:17px;
  font-family:var(--font-ar);
  font-weight:600;
  outline:none;
}
.wm-search input::placeholder{color:rgba(196,155,57,0.3)}
.wm-search button{
  background:var(--gold);
  border:none;
  padding:18px 32px;
  color:var(--bg);
  font-family:var(--font-ar);
  font-size:15px;
  font-weight:700;
  cursor:pointer;
  letter-spacing:1px;
  transition:background 0.2s ease;
  white-space:nowrap;
}
html[lang="ar"] .wm-search button{order:-1}
.wm-search button:hover{background:var(--gold-bright)}
.wm-add-link{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:16px;
  padding:10px 24px;
  border:1px solid var(--border-mid);
  border-radius:var(--r);
  color:var(--text-50);
  font-size:14px;
  font-family:var(--font-ar);
  font-weight:700;
  letter-spacing:1px;
  transition:var(--transition);
}
.wm-add-link:hover{border-color:var(--border-strong);color:var(--gold)}

/* Map bottom panel */
.wm-map-panel{
  padding:20px 48px;
  background:linear-gradient(0deg,rgba(7,5,10,1) 50%,transparent);
  display:flex;
  align-items:center;
  gap:16px;
  flex-wrap:wrap;
}
.wm-map-panel-wrap{position:relative;flex:1;min-width:220px;max-width:380px}
.wm-map-search-bar{
  display:flex;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--border-mid);
  border-radius:var(--r);
  overflow:hidden;
  transition:border-color 0.2s;
}
.wm-map-search-bar:focus-within{border-color:var(--border-strong)}
.wm-map-search-bar input{
  flex:1;
  background:transparent;
  border:none;
  padding:11px 16px;
  color:var(--text-90);
  font-size:15px;
  font-family:var(--font-ar);
  font-weight:600;
  outline:none;
  direction:rtl;
}
.wm-map-search-bar input::placeholder{color:rgba(196,155,57,0.3)}
.wm-map-results{
  position:absolute;
  bottom:calc(100% + 6px);
  right:0;left:0;
  background:rgba(13,10,18,0.99);
  border:1px solid var(--border-strong);
  border-radius:var(--r);
  max-height:220px;
  overflow-y:auto;
  z-index:100;
}
.wm-map-stats{font-size:13px;color:rgba(196,155,57,0.45);white-space:nowrap;font-family:var(--font-ar);font-weight:700;letter-spacing:1px}
.map-ri{
  padding:11px 16px;
  font-size:15px;
  color:var(--text-70);
  font-family:var(--font-ar);
  font-weight:600;
  cursor:pointer;
  display:flex;
  justify-content:space-between;
  border-bottom:1px solid var(--border-soft);
  transition:background 0.15s;
}
.map-ri:hover{background:rgba(196,155,57,0.07);color:var(--text-100)}
.map-ri-year{color:rgba(196,155,57,0.45);font-size:13px;font-family:var(--font-en);font-style:italic}

/* Leaflet */
.leaflet-tile{filter:brightness(0.5) saturate(0.4) hue-rotate(18deg)!important}
.leaflet-control-zoom a{
  background:rgba(7,5,10,0.95)!important;
  color:var(--gold)!important;
  border-color:var(--border-mid)!important;
  font-size:18px!important;
  font-weight:700!important;
}
.leaflet-control-zoom a:hover{background:rgba(196,155,57,0.1)!important}
.grave-popup{min-width:180px;font-family:var(--font-ar);direction:rtl;text-align:right}
.grave-popup h4{color:#1a1208;font-size:16px;margin-bottom:6px;font-weight:700}
.grave-popup a{display:inline-block;margin-top:8px;background:var(--gold);color:var(--bg);padding:6px 16px;border-radius:var(--r);font-size:13px;font-weight:700;transition:background 0.2s}
.grave-popup a:hover{background:var(--gold-bright)}

/* ── Ad strip ── */
.wm-ad-strip{
  height:68px;
  background:rgba(196,155,57,0.04);
  border-bottom:1px solid var(--border-soft);
  display:flex;
  align-items:center;
  padding:0 48px;
  gap:20px;
  transition:background 0.2s;
}
.wm-ad-strip:hover{background:rgba(196,155,57,0.07)}
.wm-ad-tag{
  font-family:var(--font-en);
  font-size:9px;
  letter-spacing:4px;
  color:rgba(196,155,57,0.4);
  text-transform:uppercase;
  border:1px solid rgba(196,155,57,0.15);
  padding:3px 10px;
  border-radius:1px;
  white-space:nowrap;
  font-style:italic;
}
.wm-ad-content{flex:1}
.wm-ad-item{display:flex;align-items:center;gap:16px;text-decoration:none}
.wm-ad-item img{height:44px;width:44px;object-fit:cover;border-radius:var(--r);border:1px solid var(--border-mid);filter:brightness(0.9)}
.wm-ad-text h4{font-size:16px;color:var(--text-90);font-family:var(--font-ar);font-weight:700;margin-bottom:2px}
.wm-ad-text p{font-size:13px;color:rgba(196,155,57,0.55);font-family:var(--font-ar);font-weight:600;letter-spacing:.5px}

/* ── Section divider ── */
.wm-section-label{
  display:flex;
  align-items:center;
  gap:20px;
  padding:36px 48px 16px;
}
.wm-section-label::before{
  content:'';
  flex:1;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(196,155,57,0.25));
}
.wm-section-label::after{
  content:'';
  flex:1;
  height:1px;
  background:linear-gradient(90deg,rgba(196,155,57,0.25),transparent);
}
html[lang="ar"] .wm-section-label::before{background:linear-gradient(90deg,rgba(196,155,57,0.25),transparent)}
html[lang="ar"] .wm-section-label::after{background:linear-gradient(90deg,transparent,rgba(196,155,57,0.25))}
.wm-section-label span{
  font-family:var(--font-en);
  font-size:10px;
  letter-spacing:5px;
  color:rgba(196,155,57,0.5);
  text-transform:uppercase;
  white-space:nowrap;
  font-style:italic;
}

/* ── Cemetery grid ── */
.wm-cem-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:1px;
  background:var(--border-soft);
}
.wm-cem-card{
  background:var(--bg-1);
  text-decoration:none;
  color:inherit;
  display:flex;
  align-items:center;
  gap:18px;
  padding:24px 32px;
  transition:background 0.2s ease;
  position:relative;
  overflow:hidden;
}
.wm-cem-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(196,155,57,0.05),transparent);
  opacity:0;
  transition:opacity 0.25s ease;
}
.wm-cem-card:hover{background:var(--bg-2)}
.wm-cem-card:hover::before{opacity:1}
.wm-cem-icon{
  width:48px;height:48px;
  border:1px solid var(--border-mid);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
  background:rgba(196,155,57,0.05);
  transition:border-color 0.25s,background 0.25s;
}
.wm-cem-card:hover .wm-cem-icon{border-color:var(--border-strong);background:rgba(196,155,57,0.1)}
.wm-cem-icon svg{width:20px;height:20px;fill:rgba(196,155,57,0.6);transition:fill 0.25s}
.wm-cem-card:hover .wm-cem-icon svg{fill:var(--gold)}
.wm-cem-info h3{font-size:18px;color:var(--text-90);font-weight:700;margin-bottom:4px;transition:color 0.2s}
.wm-cem-card:hover .wm-cem-info h3{color:var(--text-100)}
.wm-cem-info p{font-size:13px;color:rgba(196,155,57,0.5);font-weight:600;letter-spacing:.5px;transition:color 0.2s}
.wm-cem-card:hover .wm-cem-info p{color:rgba(196,155,57,0.75)}
.wm-cem-arrow{margin-right:auto;color:var(--text-30);font-size:22px;transition:color 0.2s,transform 0.2s}
html[lang="ar"] .wm-cem-arrow{margin-right:0;margin-left:auto}
.wm-cem-card:hover .wm-cem-arrow{color:var(--gold);transform:translateX(-4px)}
html[lang="ar"] .wm-cem-card:hover .wm-cem-arrow{transform:translateX(4px)}

/* ── Recent graves ── */
.wm-recent{background:var(--bg-1);padding-bottom:40px}
.wm-recent-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(240px,1fr));
  gap:1px;
  background:var(--border-soft);
}
.wm-grave-card{
  background:var(--bg-1);
  padding:20px 32px;
  text-decoration:none;
  display:block;
  transition:background 0.2s;
  border-left:2px solid transparent;
  transition:background 0.2s,border-color 0.2s;
}
html[lang="ar"] .wm-grave-card{border-left:none;border-right:2px solid transparent}
.wm-grave-card:hover{background:var(--bg-2);border-color:var(--gold)}
.wm-grave-name{font-size:17px;color:var(--text-90);font-weight:700;margin-bottom:6px;display:block;transition:color 0.2s}
.wm-grave-card:hover .wm-grave-name{color:var(--text-100)}
.wm-grave-date{font-family:var(--font-en);font-size:13px;color:rgba(196,155,57,0.5);font-style:italic;transition:color 0.2s}
.wm-grave-card:hover .wm-grave-date{color:rgba(196,155,57,0.75)}
.wm-grave-fatiha{font-size:13px;color:rgba(196,155,57,0.4);font-weight:700;margin-top:6px;display:block;letter-spacing:.5px;transition:color 0.2s}
.wm-grave-card:hover .wm-grave-fatiha{color:rgba(196,155,57,0.65)}

/* ── Footer ── */
.site-footer{
  padding:32px 48px;
  border-top:1px solid var(--border-soft);
  background:var(--bg);
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.site-footer-logo{font-family:var(--font-en);font-size:22px;font-weight:700;color:rgba(196,155,57,0.4);font-style:italic;letter-spacing:3px}
.site-footer-copy{font-family:var(--font-en);font-size:11px;color:var(--text-30);letter-spacing:2px}
.site-footer a{color:rgba(196,155,57,0.5);transition:color 0.2s}
.site-footer a:hover{color:var(--gold)}

/* ── Grave page ── */
.grave-page{max-width:760px;margin:0 auto;padding:48px 24px}
.grave-hero{display:flex;align-items:flex-start;gap:24px;padding-bottom:28px;border-bottom:1px solid var(--border-soft)}
.grave-photo{width:100px;height:100px;border-radius:50%;object-fit:cover;border:1px solid var(--border-strong);flex-shrink:0;filter:brightness(0.9)}
.grave-photo--placeholder{width:100px;height:100px;border-radius:50%;background:var(--bg-2);border:1px solid var(--border-mid);flex-shrink:0}
.grave-identity h1{font-size:2.2rem;font-weight:700;color:var(--text-100);line-height:1.15;margin-bottom:6px}
.grave-name-alt{font-family:var(--font-en);font-style:italic;font-size:16px;color:var(--text-30);margin-bottom:6px}
.grave-dates{font-family:var(--font-en);font-size:15px;color:var(--gold);font-weight:700;letter-spacing:1px;margin-bottom:6px}
.grave-cemetery-link{font-size:15px;color:var(--text-50);font-weight:600;transition:color 0.2s}
.grave-cemetery-link:hover{color:var(--gold)}

.fatiha-section{text-align:center;padding:36px 0;border-bottom:1px solid var(--border-soft)}
.fatiha-num{font-family:var(--font-en);font-size:4rem;font-weight:700;color:var(--gold);display:block;line-height:1;margin-bottom:8px}
.fatiha-label{font-size:14px;color:var(--text-30);letter-spacing:3px;font-weight:700;text-transform:uppercase}
.btn-fatiha{
  margin-top:20px;
  background:transparent;
  color:var(--gold);
  border:1px solid var(--border-mid);
  border-radius:var(--r);
  padding:14px 48px;
  font-size:16px;
  font-family:var(--font-ar);
  font-weight:700;
  cursor:pointer;
  letter-spacing:1px;
  transition:var(--transition);
  max-width:320px;
  width:100%;
}
.btn-fatiha:hover{background:rgba(196,155,57,0.08);border-color:var(--border-strong);transform:translateY(-1px)}
.btn-fatiha:active{transform:translateY(0)}
.btn-fatiha:disabled{opacity:.35;cursor:default;transform:none}

.grave-map-section,.memorial-section,.photos-section,.share-section{padding:24px 0;border-bottom:1px solid var(--border-soft)}
.grave-map-section h2,.memorial-section h2,.photos-section h2,.share-section h2{
  font-family:var(--font-en);font-size:11px;letter-spacing:5px;color:rgba(196,155,57,0.45);
  text-transform:uppercase;font-style:italic;margin-bottom:16px;font-weight:400
}
.grave-map{height:260px;border-radius:var(--r);border:1px solid var(--border-mid);filter:brightness(0.65) saturate(0.45) hue-rotate(18deg)}
.grave-location-text{font-size:14px;color:var(--text-50);margin-top:10px;font-weight:600}
.memorial-bio{font-size:17px;line-height:2.1;color:var(--text-70)}
.photo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:6px}
.photo-thumb{width:100%;height:100px;object-fit:cover;border-radius:var(--r);border:1px solid var(--border-mid);filter:brightness(0.85);transition:filter 0.2s,transform 0.2s}
.photo-thumb:hover{filter:brightness(1);transform:scale(1.02)}
.share-block{display:flex;gap:12px;flex-wrap:wrap}
.btn-whatsapp{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#128C7E;color:#fff;padding:14px 24px;border-radius:var(--r);
  font-size:16px;font-weight:700;flex:1;min-width:160px;
  transition:var(--transition);
}
.btn-whatsapp:hover{background:#0ea58e;transform:translateY(-1px);opacity:1}
.btn-copy{
  background:transparent;border:1px solid var(--border-mid);border-radius:var(--r);
  padding:14px 24px;font-family:var(--font-ar);font-size:16px;font-weight:700;
  color:var(--text-50);cursor:pointer;flex:1;min-width:130px;
  transition:var(--transition);
}
.btn-copy:hover{border-color:var(--border-strong);color:var(--text-90);transform:translateY(-1px)}

/* ── Forms ── */
.form-page{max-width:500px;margin:48px auto;padding:0 20px}
.form-card{background:var(--bg-1);border:1px solid var(--border-mid);border-radius:4px;padding:40px 36px 48px}
.form-card h1{font-size:1.6rem;font-weight:700;color:var(--gold);letter-spacing:1px;margin-bottom:28px;text-align:center}
.field-label{display:block;font-size:13px;color:var(--text-50);margin-bottom:6px;margin-top:16px;font-weight:700;letter-spacing:1px}
.field-input{
  width:100%;padding:14px 16px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-mid);
  border-radius:var(--r);
  color:var(--text-100);
  font-family:var(--font-ar);
  font-size:16px;font-weight:600;
  outline:none;
  transition:border-color 0.2s,box-shadow 0.2s;
}
.field-input:focus{border-color:var(--border-strong);box-shadow:0 0 0 3px rgba(196,155,57,0.08)}
.field-input::placeholder{color:var(--text-30)}
select.field-input option{background:var(--bg-2);color:var(--text-100)}
textarea.field-input{resize:vertical;min-height:100px}
.btn-primary-form{
  width:100%;padding:16px;
  background:var(--gold);color:var(--bg);
  border:none;border-radius:var(--r);
  font-size:17px;font-family:var(--font-ar);font-weight:700;
  cursor:pointer;margin-top:24px;letter-spacing:1px;
  transition:var(--transition);
}
.btn-primary-form:hover{background:var(--gold-bright);transform:translateY(-1px)}
.btn-primary-form:active{transform:translateY(0)}
.btn-primary-form:disabled{opacity:.45;cursor:default;transform:none}
.form-link{text-align:center;margin-top:16px;font-size:15px;color:var(--text-30);font-weight:600}
.form-link a{color:var(--gold);font-weight:700;transition:color 0.2s}
.form-link a:hover{color:var(--gold-bright)}
.alert{padding:14px 18px;border-radius:var(--r);margin-bottom:16px;font-size:15px;font-weight:600}
.alert-err{color:#ffbbbb;background:rgba(220,50,50,0.1);border:1px solid rgba(220,50,50,0.2)}
.alert-ok{color:#bbffcc;background:rgba(50,200,100,0.08);border:1px solid rgba(50,200,100,0.2)}
.alert-warn{color:#ffd88a;background:rgba(196,155,57,0.08);border:1px solid var(--border-mid)}

/* ── Submit grave ── */
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:480px){.grid2{grid-template-columns:1fr}}
.btn-gps{
  padding:10px 18px;background:transparent;
  border:1px solid var(--border-mid);border-radius:var(--r);
  color:var(--text-50);font-family:var(--font-ar);font-size:14px;font-weight:700;
  cursor:pointer;display:inline-flex;align-items:center;gap:6px;
  transition:var(--transition);letter-spacing:.5px;
}
.btn-gps:hover{border-color:var(--border-strong);color:var(--gold);transform:translateY(-1px)}
#pick-map{height:260px;border-radius:var(--r);border:1px solid var(--border-mid);display:none;margin-top:10px}
#pick-map.show{display:block}
.photo-preview{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.photo-preview img{width:80px;height:80px;object-fit:cover;border-radius:var(--r);border:1px solid var(--border-mid);transition:transform 0.2s}
.photo-preview img:hover{transform:scale(1.05)}

/* ── Search / Cemetery pages ── */
.search-page,.cemetery-page{max-width:760px;margin:0 auto;padding:40px 24px}
.search-page h1,.cemetery-page h1{font-size:2rem;font-weight:700;color:var(--text-100);margin-bottom:24px}
.cemetery-cover{width:100%;height:240px;object-fit:cover;border-radius:var(--r);display:block;margin-bottom:24px;filter:brightness(0.55) saturate(0.5);border:1px solid var(--border-mid)}
.cemetery-search input{
  width:100%;padding:14px 20px;
  background:var(--bg-1);border:1px solid var(--border-mid);
  border-radius:var(--r);color:var(--text-100);
  font-size:16px;font-family:var(--font-ar);font-weight:600;
  outline:none;transition:border-color 0.2s;
}
.cemetery-search input:focus{border-color:var(--border-strong)}
.grave-list{list-style:none}
.grave-list-item{border-bottom:1px solid var(--border-soft);transition:background 0.15s}
.grave-list-item:hover{background:rgba(196,155,57,0.03)}
.grave-list-link{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 8px;text-decoration:none;color:var(--text-70);
  font-weight:600;transition:color 0.15s;
}
.grave-list-link:hover{color:var(--text-100)}
.grave-list-name{flex:1;font-size:17px;font-weight:700}
.grave-list-date{font-family:var(--font-en);font-size:13px;color:rgba(196,155,57,0.5);white-space:nowrap;font-style:italic;margin:0 12px}
.grave-list-fatiha{font-size:13px;color:var(--gold);opacity:.7;white-space:nowrap;font-weight:700;letter-spacing:.5px}
.search-result-item{
  display:flex;justify-content:space-between;align-items:center;
  padding:16px 8px;border-bottom:1px solid var(--border-soft);
  text-decoration:none;color:var(--text-70);transition:color 0.15s,background 0.15s;
}
.search-result-item:hover{color:var(--text-100);background:rgba(196,155,57,0.03)}
.sr-name{font-size:17px;font-weight:700}
.sr-date{font-family:var(--font-en);font-size:13px;color:rgba(196,155,57,0.5);font-style:italic}
.no-results{color:var(--text-30);font-size:16px;padding:24px 0;font-weight:600}

/* ── Responsive ── */
@media(max-width:768px){
  .site-nav{padding:0 20px;height:60px}
  .nav-logo{font-size:22px;letter-spacing:3px}
  .nav-links{gap:20px}
  .nav-links a{font-size:14px}
  .wm-search-zone{padding:5rem 1.25rem 1.5rem}
  .wm-title{font-size:2.5rem}
  .wm-map-panel{padding:16px 20px}
  .wm-section-label{padding:28px 20px 12px}
  .wm-cem-grid,.wm-recent-grid{grid-template-columns:1fr}
  .wm-cem-card,.wm-grave-card{padding:18px 20px}
  .wm-ad-strip{padding:0 20px}
  .site-footer{padding:24px 20px;flex-direction:column;gap:12px;text-align:center}
  .grave-hero{flex-direction:column;align-items:center;text-align:center}
  .share-block{flex-direction:column}
  .form-card{padding:28px 20px 36px}
}