/* =========================================================
   SYNAGOGA SLATINA – Modern CSS
   Design System: Warm Gold × Deep Navy × Cream
   ========================================================= */

/* ── Custom Properties ── */
:root {
  --color-navy:       #1a1f2e;
  --color-navy-light: #252b3d;
  --color-navy-mid:   #2e3450;
  --color-gold:       #c9a84c;
  --color-gold-light: #e2c97a;
  --color-gold-dark:  #a8883c;
  --color-brown:      #5c3d2e;
  --color-cream:      #f7f4ef;
  --color-cream-dark: #ede9e1;
  --color-white:      #ffffff;
  --color-text:       #2c2c2c;
  --color-text-muted: #6b6b6b;
  --color-border:     rgba(201,168,76,.2);

  --font-serif: 'Playfair Display', Georgia, serif;
  --font-sans:  'Inter', system-ui, sans-serif;

  --space-xs:  .25rem;
  --space-sm:  .5rem;
  --space-md:  1rem;
  --space-lg:  1.5rem;
  --space-xl:  2rem;
  --space-2xl: 3rem;
  --space-3xl: 4rem;
  --space-4xl: 6rem;
  --space-5xl: 8rem;

  --container-max: 1200px;
  --container-pad: clamp(1rem,5vw,2.5rem);

  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-full: 9999px;

  --shadow-sm: 0 1px 3px rgba(0,0,0,.08);
  --shadow-md: 0 4px 16px rgba(0,0,0,.12);
  --shadow-lg: 0 8px 32px rgba(0,0,0,.16);
  --shadow-xl: 0 16px 48px rgba(0,0,0,.2);

  --transition-fast: 150ms ease;
  --transition-base: 300ms ease;
  --nav-height: 72px;
}

/* ── Reset ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; scroll-padding-top:var(--nav-height); -webkit-text-size-adjust:100%; }
body { font-family:var(--font-sans); line-height:1.7; color:var(--color-text); background:var(--color-cream); overflow-x:hidden; }
img,svg { display:block; max-width:100%; }
a { color:inherit; text-decoration:none; }
ul { list-style:none; }
address { font-style:normal; }

/* ── Layout ── */
.container { max-width:var(--container-max); margin-inline:auto; padding-inline:var(--container-pad); }
.section { padding-block:var(--space-5xl); }
.section--dark  { background:var(--color-navy); color:var(--color-white); }
.section--warm  { background:var(--color-cream-dark); }

/* ── Typography helpers ── */
.section-eyebrow { display:inline-block; font-size:.75rem; font-weight:600; letter-spacing:.15em; text-transform:uppercase; color:var(--color-gold); margin-bottom:var(--space-sm); }
.section-eyebrow--light { color:var(--color-gold-light); }
.section-title { font-family:var(--font-serif); font-size:clamp(2rem,5vw,3rem); font-weight:700; line-height:1.15; color:var(--color-navy); margin-bottom:var(--space-lg); }
.section-title--light { color:var(--color-white); }
.section-title em { font-style:italic; color:var(--color-gold); }
.section-description { font-size:1.125rem; color:var(--color-text-muted); max-width:600px; line-height:1.8; }
.section-description--light { color:rgba(255,255,255,.7); }
.section-header { text-align:center; margin-bottom:var(--space-4xl); }
.section-header .section-description { margin-inline:auto; }
.section-cta { text-align:center; margin-top:var(--space-3xl); }
.lead { font-size:1.15rem; line-height:1.8; color:var(--color-navy); margin-bottom:var(--space-lg); }

/* ── Buttons ── */
.btn { display:inline-flex; align-items:center; gap:var(--space-sm); padding:.875rem 2rem; font-family:var(--font-sans); font-size:.9375rem; font-weight:500; border-radius:var(--radius-full); border:2px solid transparent; cursor:pointer; transition:all var(--transition-base); white-space:nowrap; }
.btn-primary { background:var(--color-gold); color:var(--color-navy); border-color:var(--color-gold); }
.btn-primary:hover { background:var(--color-gold-light); border-color:var(--color-gold-light); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-secondary { background:var(--color-navy); color:var(--color-white); border-color:var(--color-navy); }
.btn-secondary:hover { background:var(--color-navy-light); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-gold { background:var(--color-gold); color:var(--color-navy); border-color:var(--color-gold); font-weight:600; }
.btn-gold:hover { background:var(--color-gold-light); border-color:var(--color-gold-light); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-outline { background:transparent; color:var(--color-white); border-color:rgba(255,255,255,.5); }
.btn-outline:hover { background:rgba(255,255,255,.1); border-color:var(--color-white); transform:translateY(-2px); }
.btn-outline-dark { background:transparent; color:var(--color-navy); border-color:var(--color-navy); }
.btn-outline-dark:hover { background:var(--color-navy); color:var(--color-white); transform:translateY(-2px); }

/* ── Page Header (for subpages) ── */
.page-header { background:linear-gradient(135deg,var(--color-navy) 0%,var(--color-navy-mid) 100%); color:var(--color-white); padding:calc(var(--nav-height) + var(--space-4xl)) var(--container-pad) var(--space-4xl); text-align:center; position:relative; overflow:hidden; }
.page-header::before { content:''; position:absolute; inset:0; background:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); }
.page-header-inner { position:relative; z-index:1; max-width:700px; margin-inline:auto; }
.page-header .section-eyebrow { display:block; margin-bottom:var(--space-md); }
.page-header h1 { font-family:var(--font-serif); font-size:clamp(2.5rem,6vw,4rem); font-weight:700; line-height:1.1; margin-bottom:var(--space-lg); }
.page-header h1 em { font-style:italic; color:var(--color-gold); font-weight:400; }
.page-header p { font-size:1.125rem; color:rgba(255,255,255,.75); line-height:1.8; }
.breadcrumb { display:flex; align-items:center; gap:var(--space-sm); font-size:.875rem; color:rgba(255,255,255,.5); justify-content:center; margin-bottom:var(--space-xl); }
.breadcrumb a { color:rgba(255,255,255,.7); transition:color var(--transition-fast); }
.breadcrumb a:hover { color:var(--color-gold-light); }
.breadcrumb-sep { opacity:.4; }

/* ── Header / Navigation ── */
.site-header { position:fixed; top:0; left:0; right:0; z-index:1000; height:var(--nav-height); transition:background-color var(--transition-base),backdrop-filter var(--transition-base),box-shadow var(--transition-base); }
.site-header.scrolled { background:rgba(26,31,46,.97); backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); box-shadow:0 2px 20px rgba(0,0,0,.3); }
.site-header.header-solid { background:rgba(26,31,46,.97); }
.nav-container { max-width:var(--container-max); margin-inline:auto; padding-inline:var(--container-pad); height:100%; display:flex; align-items:center; gap:var(--space-xl); }
.nav-logo { display:flex; align-items:center; gap:var(--space-sm); flex-shrink:0; transition:opacity var(--transition-fast); }
.nav-logo:hover { opacity:.85; }
.logo-symbol { font-size:1.5rem; color:var(--color-gold); line-height:1; }
.logo-text { font-family:var(--font-serif); font-size:1.125rem; font-weight:600; color:var(--color-white); line-height:1.2; }
.logo-text em { font-style:italic; color:var(--color-gold); font-weight:400; }
.nav-menu { display:flex; align-items:center; gap:var(--space-xs); margin-left:auto; }
.nav-link { font-size:.9rem; font-weight:500; color:rgba(255,255,255,.8); padding:.5rem .875rem; border-radius:var(--radius-full); transition:color var(--transition-fast),background var(--transition-fast); }
.nav-link:hover,.nav-link.active { color:var(--color-white); background:rgba(255,255,255,.1); }
.nav-link.nav-cta { background:var(--color-gold); color:var(--color-navy); font-weight:600; }
.nav-link.nav-cta:hover { background:var(--color-gold-light); color:var(--color-navy); }
.lang-switcher { display:flex; align-items:center; gap:2px; border-left:1px solid rgba(255,255,255,.15); padding-left:var(--space-lg); flex-shrink:0; }
.lang-btn { font-size:.75rem; font-weight:600; letter-spacing:.05em; color:rgba(255,255,255,.5); padding:.25rem .5rem; border-radius:var(--radius-sm); transition:color var(--transition-fast),background var(--transition-fast); }
.lang-btn:hover { color:var(--color-white); background:rgba(255,255,255,.1); }
.lang-btn.active { color:var(--color-gold); }
.nav-toggle { display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; padding:4px; margin-left:auto; }
.nav-toggle span { display:block; width:24px; height:2px; background:var(--color-white); transition:all var(--transition-base); transform-origin:center; }
.nav-toggle.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-toggle.open span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-toggle.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

/* ── Hero ── */
.hero { position:relative; height:100vh; min-height:600px; display:flex; align-items:center; justify-content:center; overflow:hidden; }
.hero-bg { position:absolute; inset:0; }
.hero-overlay { position:absolute; inset:0; background:linear-gradient(135deg,rgba(26,31,46,.92) 0%,rgba(26,31,46,.75) 40%,rgba(92,61,46,.6) 100%); z-index:1; }
.hero-pattern { position:absolute; inset:0; background-color:var(--color-navy); background-image:radial-gradient(ellipse at 20% 50%,rgba(201,168,76,.15) 0%,transparent 60%),radial-gradient(ellipse at 80% 20%,rgba(201,168,76,.08) 0%,transparent 50%),url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23c9a84c' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/svg%3E"); }
.hero-content { position:relative; z-index:2; text-align:center; padding:var(--space-xl); max-width:800px; }
.hero-badge { display:inline-flex; align-items:center; gap:var(--space-sm); background:rgba(201,168,76,.15); border:1px solid rgba(201,168,76,.4); color:var(--color-gold-light); font-size:.8125rem; font-weight:500; letter-spacing:.08em; padding:.5rem 1.25rem; border-radius:var(--radius-full); margin-bottom:var(--space-xl); }
.hero-badge-symbol { font-size:1rem; }
.hero-title { font-family:var(--font-serif); font-size:clamp(3.5rem,10vw,7rem); font-weight:700; line-height:1.05; color:var(--color-white); letter-spacing:-.02em; margin-bottom:var(--space-xl); }
.hero-title em { display:block; color:var(--color-gold); font-style:italic; font-weight:400; }
.hero-subtitle { font-size:clamp(1rem,2.5vw,1.25rem); color:rgba(255,255,255,.75); line-height:1.6; margin-bottom:var(--space-2xl); }
.hero-actions { display:flex; gap:var(--space-md); justify-content:center; flex-wrap:wrap; }

/* Scroll indicator – pulsing arrow */
.hero-scroll { position:absolute; bottom:var(--space-2xl); left:50%; transform:translateX(-50%); z-index:2; display:flex; flex-direction:column; align-items:center; gap:var(--space-xs); color:rgba(255,255,255,.6); }
.scroll-label { font-size:.6875rem; letter-spacing:.15em; text-transform:uppercase; }
.scroll-arrow { display:flex; color:rgba(255,255,255,.75); animation:bounceDown 1.8s ease-in-out infinite; }
@keyframes bounceDown { 0%,100%{transform:translateY(0)} 50%{transform:translateY(9px)} }

/* ── Stats Bar ── */
.stats-bar { background:var(--color-navy); padding-block:var(--space-3xl); }
.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:var(--space-xl); text-align:center; }
.stat-item { display:flex; flex-direction:column; align-items:center; gap:var(--space-xs); }
.stat-item+.stat-item { border-left:1px solid rgba(255,255,255,.08); }
.stat-number { font-family:var(--font-serif); font-size:clamp(2rem,5vw,3rem); font-weight:700; color:var(--color-gold); line-height:1; }
.stat-label { font-size:.8125rem; color:rgba(255,255,255,.55); letter-spacing:.05em; }

/* ── Intro Section ── */
.intro-section { background:var(--color-cream); }
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-4xl); align-items:start; }
.intro-text p { color:var(--color-text-muted); margin-bottom:var(--space-lg); line-height:1.8; }
.intro-text .btn { margin-top:var(--space-md); }
.intro-visual { position:relative; height:380px; }
.visual-card { position:absolute; border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); }
.visual-card--main { top:0; right:0; width:75%; background:linear-gradient(135deg,var(--color-navy) 0%,var(--color-navy-mid) 100%); color:var(--color-white); padding:var(--space-2xl); display:flex; align-items:center; gap:var(--space-lg); }
.visual-icon { font-size:3rem; color:var(--color-gold); flex-shrink:0; line-height:1; }
.visual-text strong { display:block; font-family:var(--font-serif); font-size:1.5rem; font-weight:700; }
.visual-text span { font-size:.875rem; color:rgba(255,255,255,.6); }
.visual-card--secondary { bottom:20px; left:0; width:70%; background:var(--color-white); padding:var(--space-xl); }
.visual-card--secondary blockquote { font-family:var(--font-serif); font-size:1rem; font-style:italic; color:var(--color-navy); line-height:1.6; position:relative; padding-left:var(--space-lg); }
.visual-card--secondary blockquote::before { content:''; position:absolute; left:0; top:0; bottom:0; width:3px; background:var(--color-gold); border-radius:var(--radius-full); }
.visual-ornament { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:80px; height:80px; border:1px solid rgba(201,168,76,.3); border-radius:50%; pointer-events:none; }

/* ── Horizontal Timeline ── */
.timeline-horizontal { display:grid; grid-template-columns:auto 1fr auto; gap:var(--space-lg); align-items:center; }
.tl-viewport { overflow:hidden; }
.tl-track { display:flex; gap:var(--space-lg); transition:transform .45s cubic-bezier(.4,0,.2,1); will-change:transform; }
.tl-card { flex:0 0 calc(33.333% - var(--space-lg) * .667); background:rgba(255,255,255,.04); border:1px solid rgba(201,168,76,.2); border-radius:var(--radius-lg); padding:var(--space-xl); position:relative; }
.tl-card:hover { border-color:rgba(201,168,76,.45); background:rgba(255,255,255,.07); }
.tl-year { font-family:var(--font-serif); font-size:1.125rem; font-weight:700; color:var(--color-gold); margin-bottom:var(--space-md); }
.tl-dot { width:8px; height:8px; background:var(--color-gold); border-radius:50%; margin-bottom:var(--space-md); }
.tl-title { font-family:var(--font-serif); font-size:1rem; font-weight:600; color:var(--color-white); margin-bottom:var(--space-sm); }
.tl-card p { font-size:.875rem; color:rgba(255,255,255,.65); line-height:1.7; }
.tl-nav { width:44px; height:44px; flex-shrink:0; background:rgba(201,168,76,.1); border:1px solid rgba(201,168,76,.35); border-radius:50%; color:var(--color-gold); cursor:pointer; display:flex; align-items:center; justify-content:center; transition:all var(--transition-base); }
.tl-nav:hover:not(:disabled) { background:rgba(201,168,76,.25); border-color:var(--color-gold); }
.tl-nav:disabled { opacity:.3; cursor:not-allowed; }
.tl-progress { height:3px; background:rgba(255,255,255,.08); border-radius:var(--radius-full); margin-top:var(--space-xl); overflow:hidden; }
.tl-progress-bar { height:100%; background:var(--color-gold); border-radius:var(--radius-full); transition:width .45s ease; }

/* ── Synagogue Section ── */
.synagogue-section { background:var(--color-white); }
.synagogue-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:var(--space-4xl); align-items:start; }
.synagogue-photo-wrap { position:relative; }
.synagogue-photo { width:100%; aspect-ratio:4/3; object-fit:cover; border-radius:var(--radius-xl); box-shadow:var(--shadow-xl); }
.synagogue-badge { position:absolute; bottom:var(--space-lg); left:var(--space-lg); right:var(--space-lg); background:rgba(26,31,46,.9); backdrop-filter:blur(8px); color:rgba(255,255,255,.9); font-size:.8125rem; padding:.625rem 1rem; border-radius:var(--radius-md); display:flex; align-items:center; gap:var(--space-sm); }
.synagogue-badge span { color:var(--color-gold); }
.info-block { margin-bottom:var(--space-2xl); }
.info-block h3 { font-family:var(--font-serif); font-size:1.25rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-md); }
.info-block p { color:var(--color-text-muted); line-height:1.8; }
.info-block--highlight { background:var(--color-cream); border-left:3px solid var(--color-gold); padding:var(--space-xl); border-radius:0 var(--radius-md) var(--radius-md) 0; }
.feature-list { display:flex; flex-direction:column; gap:var(--space-lg); margin-bottom:var(--space-2xl); }
.feature-item { display:flex; gap:var(--space-lg); align-items:flex-start; }
.feature-icon { flex-shrink:0; width:44px; height:44px; background:rgba(201,168,76,.1); border-radius:var(--radius-md); display:flex; align-items:center; justify-content:center; color:var(--color-gold-dark); }
.feature-item strong { display:block; font-weight:600; color:var(--color-navy); margin-bottom:2px; }
.feature-item p { font-size:.9rem; color:var(--color-text-muted); line-height:1.6; }

/* ── Cemetery Section ── */
.cemetery-section { background:var(--color-cream-dark); }
.cemetery-grid { display:grid; grid-template-columns:1.2fr 1fr; gap:var(--space-4xl); align-items:start; }
.cemetery-text p { color:var(--color-text-muted); line-height:1.8; margin-bottom:var(--space-lg); }
.cemetery-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-md); margin-block:var(--space-2xl); }
.cem-stat { text-align:center; background:var(--color-white); border-radius:var(--radius-lg); padding:var(--space-lg); box-shadow:var(--shadow-sm); }
.cem-stat strong { display:block; font-family:var(--font-serif); font-size:1.75rem; font-weight:700; color:var(--color-navy); }
.cem-stat span { font-size:.75rem; color:var(--color-text-muted); letter-spacing:.05em; }
.cemetery-photo-wrap { border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-xl); }
.cemetery-photo { width:100%; aspect-ratio:4/3; object-fit:cover; display:block; }
.cemetery-note { display:flex; align-items:flex-start; gap:var(--space-sm); font-size:.875rem; color:var(--color-text-muted); background:var(--color-white); padding:var(--space-md) var(--space-lg); border-radius:var(--radius-md); box-shadow:var(--shadow-sm); margin-top:var(--space-md); }
.cemetery-note svg { flex-shrink:0; margin-top:2px; }

/* ── Personalities Mini ── */
.personalities-section { background:var(--color-cream); }
.personality-mini { display:grid; grid-template-columns:280px 1fr; gap:var(--space-4xl); align-items:start; background:var(--color-white); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }
.pmi-photo-wrap { position:relative; }
.pmi-photo { width:100%; aspect-ratio:3/4; object-fit:cover; object-position:top; display:block; }
.pmi-dates { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(to top,rgba(26,31,46,.9),transparent); color:rgba(255,255,255,.9); text-align:center; padding:var(--space-xl) var(--space-md) var(--space-md); font-family:var(--font-serif); font-size:1rem; font-weight:600; }
.pmi-content { padding:var(--space-2xl) var(--space-2xl) var(--space-2xl) 0; }
.pmi-name { font-family:var(--font-serif); font-size:1.75rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-sm); }
.pmi-tags { display:flex; flex-wrap:wrap; gap:var(--space-sm); margin-bottom:var(--space-xl); }
.tag { font-size:.75rem; font-weight:500; background:rgba(201,168,76,.1); color:var(--color-gold-dark); border:1px solid rgba(201,168,76,.3); padding:.25rem .875rem; border-radius:var(--radius-full); }
.pmi-bio { color:var(--color-text-muted); line-height:1.8; margin-bottom:var(--space-xl); }
.pmi-quote { font-family:var(--font-serif); font-style:italic; font-size:1rem; color:var(--color-navy); line-height:1.7; border-left:3px solid var(--color-gold); padding-left:var(--space-lg); margin-bottom:var(--space-xl); }

/* ── Visit Section ── */
.visit-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3xl); align-items:start; margin-bottom:var(--space-4xl); }
.directions-title { font-family:var(--font-serif); font-size:1.25rem; font-weight:600; color:var(--color-white); display:flex; align-items:center; gap:var(--space-sm); margin-bottom:var(--space-xl); }
.direction-cards { display:flex; flex-direction:column; gap:var(--space-lg); }
.direction-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:var(--space-xl); }
.direction-from { font-weight:600; color:var(--color-gold); margin-bottom:var(--space-md); font-size:.875rem; letter-spacing:.05em; text-transform:uppercase; }
.direction-route { display:flex; flex-wrap:wrap; align-items:center; gap:var(--space-sm); }
.route-step { font-size:.875rem; color:rgba(255,255,255,.8); background:rgba(255,255,255,.07); padding:.25rem .75rem; border-radius:var(--radius-full); }
.route-step.highlight { background:var(--color-gold); color:var(--color-navy); font-weight:600; }
.route-arrow { color:rgba(255,255,255,.3); font-size:.875rem; }
.visit-cards-grid { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-md); }
.visit-info-card { background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.08); border-radius:var(--radius-lg); padding:var(--space-xl); transition:background var(--transition-fast); }
.visit-info-card:hover { background:rgba(255,255,255,.08); }
.visit-info-card--wide { grid-column:1/-1; }
.vic-icon { color:var(--color-gold); margin-bottom:var(--space-md); }
.visit-info-card h4 { font-family:var(--font-serif); font-size:1rem; font-weight:600; color:var(--color-white); margin-bottom:var(--space-sm); }
.visit-info-card p { font-size:.85rem; color:rgba(255,255,255,.6); line-height:1.6; }
/* Nearby */
.visit-nearby { border-top:1px solid rgba(255,255,255,.08); padding-top:var(--space-3xl); }
.nearby-inner { display:flex; align-items:center; justify-content:space-between; gap:var(--space-xl); margin-bottom:var(--space-xl); flex-wrap:wrap; }
.nearby-text h3 { font-family:var(--font-serif); font-size:1.375rem; font-weight:600; color:var(--color-white); margin-bottom:var(--space-sm); }
.nearby-text p { color:rgba(255,255,255,.6); font-size:.9375rem; max-width:480px; }
.nearby-tags { display:flex; flex-wrap:wrap; gap:var(--space-sm); }
.nearby-tag { background:rgba(201,168,76,.1); border:1px solid rgba(201,168,76,.3); color:var(--color-gold-light); font-size:.875rem; font-weight:500; padding:.5rem 1.25rem; border-radius:var(--radius-full); cursor:default; }

/* ── Support Section ── */
.support-section { background:var(--color-white); }
.support-inner { max-width:800px; margin-inline:auto; text-align:center; }
.support-symbol { font-size:3rem; color:var(--color-gold); margin-bottom:var(--space-lg); display:block; }
.support-text { font-size:1.0625rem; color:var(--color-text-muted); line-height:1.8; margin-bottom:var(--space-3xl); max-width:640px; margin-inline:auto; }
.support-ways { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-xl); margin-bottom:var(--space-3xl); }
.support-way { padding:var(--space-xl); background:var(--color-cream); border-radius:var(--radius-lg); transition:transform var(--transition-base),box-shadow var(--transition-base); }
.support-way:hover { transform:translateY(-4px); box-shadow:var(--shadow-md); }
.sw-icon { color:var(--color-gold-dark); margin-bottom:var(--space-lg); display:flex; justify-content:center; }
.support-way h4 { font-family:var(--font-serif); font-size:1.0625rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-sm); }
.support-way p { font-size:.875rem; color:var(--color-text-muted); line-height:1.65; }
.support-actions { display:flex; gap:var(--space-md); justify-content:center; flex-wrap:wrap; }

/* ── Footer ── */
.site-footer { background:var(--color-navy); color:rgba(255,255,255,.7); padding-top:var(--space-4xl); padding-bottom:var(--space-2xl); }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1.5fr; gap:var(--space-3xl); margin-bottom:var(--space-3xl); }
.footer-logo { display:flex; align-items:center; gap:var(--space-sm); margin-bottom:var(--space-lg); }
.footer-logo .logo-symbol { font-size:1.25rem; }
.footer-logo span { font-family:var(--font-serif); font-size:1rem; font-weight:600; color:var(--color-white); }
.footer-logo em { font-style:italic; color:var(--color-gold); }
.footer-brand p { font-size:.875rem; line-height:1.7; max-width:240px; margin-bottom:var(--space-lg); }
.footer-social { display:flex; gap:var(--space-sm); }
.social-link { width:36px; height:36px; background:rgba(255,255,255,.07); border-radius:50%; display:flex; align-items:center; justify-content:center; color:rgba(255,255,255,.6); transition:background var(--transition-fast),color var(--transition-fast); }
.social-link:hover { background:var(--color-gold); color:var(--color-navy); }
.footer-nav h3,.footer-info h3 { font-family:var(--font-serif); font-size:.9375rem; font-weight:600; color:var(--color-white); margin-bottom:var(--space-lg); }
.footer-nav ul { display:flex; flex-direction:column; gap:var(--space-sm); }
.footer-nav a { font-size:.875rem; color:rgba(255,255,255,.6); transition:color var(--transition-fast); }
.footer-nav a:hover { color:var(--color-gold-light); }
.footer-info address { margin-bottom:var(--space-lg); }
.footer-info p { font-size:.875rem; line-height:1.7; margin-bottom:var(--space-md); }
.footer-info a { color:var(--color-gold-light); transition:opacity var(--transition-fast); }
.footer-info a:hover { opacity:.8; }
.footer-langs { display:flex; gap:var(--space-md); }
.footer-langs a { font-size:.8125rem; font-weight:600; color:rgba(255,255,255,.5); letter-spacing:.05em; transition:color var(--transition-fast); }
.footer-langs a:hover { color:var(--color-gold-light); }
.footer-bottom { border-top:1px solid rgba(255,255,255,.08); padding-top:var(--space-xl); display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:var(--space-md); }
.footer-bottom p { font-size:.8125rem; color:rgba(255,255,255,.4); }
.footer-credits strong { color:rgba(255,255,255,.6); }

/* ── Back to Top ── */
.back-to-top { position:fixed; bottom:var(--space-xl); right:var(--space-xl); z-index:900; width:44px; height:44px; background:var(--color-gold); color:var(--color-navy); border:none; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; box-shadow:var(--shadow-md); opacity:0; transform:translateY(10px); transition:opacity var(--transition-base),transform var(--transition-base),background var(--transition-fast); }
.back-to-top.visible { opacity:1; transform:translateY(0); }
.back-to-top:hover { background:var(--color-gold-light); transform:translateY(-2px); box-shadow:var(--shadow-lg); }

/* ── Gallery Grid (for subpages) ── */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:var(--space-md); }
.gallery-item { border-radius:var(--radius-lg); overflow:hidden; cursor:pointer; position:relative; aspect-ratio:4/3; }
.gallery-item img { width:100%; height:100%; object-fit:cover; transition:transform var(--transition-base); display:block; }
.gallery-item:hover img { transform:scale(1.04); }
.gallery-item-overlay { position:absolute; inset:0; background:rgba(26,31,46,.5); opacity:0; transition:opacity var(--transition-base); display:flex; align-items:center; justify-content:center; color:var(--color-white); }
.gallery-item:hover .gallery-item-overlay { opacity:1; }

/* ── Lightbox ── */
.lightbox { position:fixed; inset:0; z-index:9999; background:rgba(0,0,0,.92); display:none; align-items:center; justify-content:center; padding:var(--space-lg); }
.lightbox.open { display:flex; }
.lightbox-inner { position:relative; max-width:90vw; max-height:90vh; }
.lightbox-img { max-width:100%; max-height:85vh; object-fit:contain; border-radius:var(--radius-md); box-shadow:var(--shadow-xl); }
.lightbox-close { position:absolute; top:-16px; right:-16px; width:40px; height:40px; background:var(--color-gold); color:var(--color-navy); border:none; border-radius:50%; cursor:pointer; font-size:1.25rem; display:flex; align-items:center; justify-content:center; }
.lightbox-caption { text-align:center; color:rgba(255,255,255,.7); font-size:.875rem; margin-top:var(--space-md); }
.lightbox-nav { position:absolute; top:50%; transform:translateY(-50%); background:rgba(255,255,255,.1); border:none; border-radius:50%; width:44px; height:44px; cursor:pointer; color:var(--color-white); display:flex; align-items:center; justify-content:center; transition:background var(--transition-fast); }
.lightbox-nav:hover { background:rgba(255,255,255,.25); }
.lightbox-prev { left:-60px; }
.lightbox-next { right:-60px; }

/* ── Cemetery Plan (planhrbitova) ── */
.cemetery-map-wrap { background:var(--color-cream-dark); border-radius:var(--radius-xl); padding:var(--space-2xl); }
.cemetery-map-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(100px,1fr)); gap:var(--space-sm); }
.grave-item { background:var(--color-white); border:1px solid var(--color-border); border-radius:var(--radius-md); cursor:pointer; overflow:hidden; transition:transform var(--transition-fast),box-shadow var(--transition-fast),border-color var(--transition-fast); }
.grave-item:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--color-gold); }
.grave-item img { width:100%; aspect-ratio:1; object-fit:cover; display:block; }
.grave-item-label { padding:.375rem .5rem; font-size:.6875rem; text-align:center; color:var(--color-text-muted); font-weight:500; }

/* ── Personality subpage ── */
.person-grid { display:grid; grid-template-columns:340px 1fr; gap:var(--space-4xl); align-items:start; }
.person-photo-wrap { position:sticky; top:calc(var(--nav-height) + 2rem); border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-xl); }
.person-photo { width:100%; display:block; }
.person-photo-caption { background:var(--color-navy); color:rgba(255,255,255,.7); font-size:.8125rem; padding:var(--space-md) var(--space-lg); text-align:center; }
.person-content h2 { font-family:var(--font-serif); font-size:2rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-md); }
.person-content h3 { font-family:var(--font-serif); font-size:1.25rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-md); margin-top:var(--space-2xl); }
.person-content p { color:var(--color-text-muted); line-height:1.85; margin-bottom:var(--space-lg); }
.person-content strong { color:var(--color-navy); }
.person-quote { background:var(--color-cream); border-left:4px solid var(--color-gold); padding:var(--space-xl); border-radius:0 var(--radius-lg) var(--radius-lg) 0; margin-block:var(--space-2xl); font-family:var(--font-serif); font-style:italic; font-size:1.0625rem; color:var(--color-navy); line-height:1.75; }

/* ── Localities table layout ── */
.localities-table { width:100%; border-collapse:collapse; font-size:.875rem; }
.localities-table thead th { font-family:var(--font-serif); font-size:.8125rem; font-weight:700; color:var(--color-navy); text-align:left; padding:.625rem var(--space-md); border-bottom:2px solid var(--color-gold); letter-spacing:.04em; text-transform:uppercase; white-space:nowrap; }
.localities-table tbody tr { border-bottom:1px solid var(--color-cream-dark); transition:background var(--transition-fast); }
.localities-table tbody tr:hover { background:var(--color-cream); }
.localities-table td { padding:.75rem var(--space-md); vertical-align:top; }
.lt-name { display:flex; align-items:center; gap:var(--space-sm); font-family:var(--font-serif); font-weight:700; color:var(--color-navy); font-size:.9375rem; }
.lt-desc { font-size:.8125rem; color:var(--color-text-muted); line-height:1.55; margin-top:.25rem; padding-left:2.25rem; }
.lt-badges { display:flex; flex-wrap:wrap; gap:4px; padding-top:.25rem; }
@media (max-width:768px) {
  .localities-table thead { display:none; }
  .localities-table tr { display:block; padding:var(--space-md) 0; border-bottom:1px solid var(--color-cream-dark); }
  .localities-table td { display:block; padding:.25rem var(--space-md); }
  .lt-desc { padding-left:0; }
}

/* ── Nearby monuments list ── */
.nearby-legend { display:flex; flex-wrap:wrap; gap:var(--space-md) var(--space-xl); margin-bottom:var(--space-3xl); }
.legend-item { display:flex; align-items:center; gap:var(--space-sm); font-size:.875rem; color:var(--color-text-muted); }
.legend-dot { width:12px; height:12px; border-radius:2px; flex-shrink:0; }
.legend-dot--nacista  { background:#c0392b; }
.legend-dot--komunist { background:#e67e22; }
.legend-dot--other    { background:#95a5a6; }
.legend-dot--rebulit  { background:#3498db; }
.legend-dot--cemetery { background:var(--color-gold); }
.localities-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(300px,1fr)); gap:var(--space-lg); }
.locality-card { background:var(--color-white); border-radius:var(--radius-lg); padding:var(--space-xl); box-shadow:var(--shadow-sm); border-left:3px solid var(--color-border); transition:box-shadow var(--transition-base),border-color var(--transition-base); }
.locality-card:hover { box-shadow:var(--shadow-md); border-color:var(--color-gold); }
.locality-name { font-family:var(--font-serif); font-size:1.0625rem; font-weight:700; color:var(--color-navy); margin-bottom:var(--space-sm); }
.locality-desc { font-size:.875rem; color:var(--color-text-muted); line-height:1.65; }
.locality-badges { display:flex; flex-wrap:wrap; gap:var(--space-xs); margin-top:var(--space-sm); }
.badge { font-size:.6875rem; font-weight:600; padding:.2rem .6rem; border-radius:var(--radius-full); }
.badge--syn { background:rgba(52,152,219,.12); color:#2980b9; }
.badge--cem { background:rgba(201,168,76,.12); color:var(--color-gold-dark); }

/* ── AOS ── */
[data-aos] { opacity:0; transform:translateY(20px); transition:opacity .6s ease,transform .6s ease; }
[data-aos="fade-left"]  { transform:translateX(30px); }
[data-aos="fade-right"] { transform:translateX(-30px); }
[data-aos="zoom-in"]    { transform:scale(.9); opacity:0; }
[data-aos="fade-down"]  { transform:translateY(-20px); }
[data-aos].aos-animate  { opacity:1; transform:translate(0) scale(1); }

/* ── Responsive ── */
@media (max-width:1100px) {
  .person-grid { grid-template-columns:280px 1fr; }
  .person-photo-wrap { position:static; }
}
@media (max-width:1024px) {
  .intro-grid { grid-template-columns:1fr; }
  .intro-visual { display:none; }
  .intro-section [style*="grid-template-columns:1fr 1fr"] { grid-template-columns:1fr !important; }
  .synagogue-grid { grid-template-columns:1fr; }
  .cemetery-grid { grid-template-columns:1fr; }
  .cemetery-visual { order:-1; }
  .personality-mini { grid-template-columns:220px 1fr; }
  .pmi-content { padding:var(--space-xl) var(--space-xl) var(--space-xl) 0; }
  .visit-grid { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .footer-brand { grid-column:1/-1; }
  .tl-card { flex-basis:calc(50% - var(--space-lg) * .5); }
  .person-grid { grid-template-columns:1fr; }
}
@media (max-width:768px) {
  :root { --nav-height:64px; }
  .nav-menu { position:fixed; top:var(--nav-height); left:0; right:0; flex-direction:column; align-items:stretch; background:rgba(26,31,46,.98); backdrop-filter:blur(16px); padding:var(--space-lg); gap:var(--space-xs); transform:translateY(-100%); opacity:0; transition:transform var(--transition-base),opacity var(--transition-base); pointer-events:none; }
  .nav-menu.open { transform:translateY(0); opacity:1; pointer-events:all; }
  .nav-link { padding:var(--space-md); border-radius:var(--radius-md); }
  .lang-switcher { display:none; }
  .nav-toggle { display:flex; }
  .stats-grid { grid-template-columns:1fr 1fr; }
  .stat-item+.stat-item { border-left:none; }
  .stat-item:nth-child(odd) { border-right:1px solid rgba(255,255,255,.08); }
  .tl-card { flex-basis:calc(100% - 0px); }
  .synagogue-photo-wrap { margin-bottom:var(--space-xl); }
  .personality-mini { grid-template-columns:1fr; }
  .pmi-photo-wrap { max-width:240px; margin-inline:auto; }
  .pmi-content { padding:0 var(--space-xl) var(--space-xl); }
  .support-ways { grid-template-columns:1fr; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom { flex-direction:column; text-align:center; }
  .cemetery-stats { grid-template-columns:1fr; gap:var(--space-sm); }
  .visit-cards-grid { grid-template-columns:1fr; }
  .visit-info-card--wide { grid-column:1; }
  .nearby-inner { flex-direction:column; align-items:flex-start; }
  .gallery-grid { grid-template-columns:repeat(auto-fill,minmax(160px,1fr)); }
  .lightbox-prev { left:-16px; }
  .lightbox-next { right:-16px; }
  .timeline-horizontal { gap:var(--space-sm); }
  .tl-nav { width:36px; height:36px; }
}
@media (max-width:480px) {
  .hero-scroll { display:none; }
  .hero-actions { flex-direction:column; align-items:center; }
  .hero-actions .btn { width:100%; justify-content:center; }
  .stats-grid { grid-template-columns:1fr; }
  .stat-item+.stat-item { border-left:none; border-top:1px solid rgba(255,255,255,.08); }
  .stat-item:nth-child(odd) { border-right:none; }
  .direction-route { gap:var(--space-xs); }
  .back-to-top { bottom:var(--space-lg); right:var(--space-lg); }
  .cemetery-map-grid { grid-template-columns:repeat(auto-fill,minmax(80px,1fr)); }
}

/* ── Print ── */
@media print {
  .site-header,.hero-scroll,.back-to-top,.support-section,.tl-nav { display:none; }
  body { font-size:12pt; }
  .section { padding-block:2cm; }
}

/* ── Locality pictograms (nearby monuments) ── */
.locality-card { position:relative; }
.locality-picto { position:absolute; top:var(--space-md); right:var(--space-md); width:28px; height:28px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.locality-picto--syn-preserved { background:rgba(39,174,96,.15);  color:#219653; }
.locality-picto--syn-nazi      { background:rgba(192,57,43,.12);  color:#c0392b; }
.locality-picto--syn-postwar   { background:rgba(230,126,34,.12); color:#e67e22; }
.locality-picto--syn-converted { background:rgba(52,152,219,.12); color:#2980b9; }
.locality-picto--syn-gone      { background:rgba(149,165,166,.15);color:#7f8c8d; }
.locality-picto--cemetery      { background:rgba(201,168,76,.12); color:var(--color-gold-dark); }
/* Legend pictograms */
.legend-picto { width:24px; height:24px; border-radius:50%; display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.legend-picto--syn-preserved { background:rgba(39,174,96,.15);  color:#219653; }
.legend-picto--syn-nazi      { background:rgba(192,57,43,.12);  color:#c0392b; }
.legend-picto--syn-postwar   { background:rgba(230,126,34,.12); color:#e67e22; }
.legend-picto--syn-converted { background:rgba(52,152,219,.12); color:#2980b9; }
.legend-picto--syn-gone      { background:rgba(149,165,166,.15);color:#7f8c8d; }
.legend-picto--cemetery      { background:rgba(201,168,76,.12); color:var(--color-gold-dark); }

/* ── Focus & Selection ── */
:focus-visible { outline:2px solid var(--color-gold); outline-offset:3px; border-radius:var(--radius-sm); }
::selection { background:rgba(201,168,76,.3); color:var(--color-navy); }
