/* =====================================================================
   Albert Agarunov — Memorial Site
   Solemn, premium, multilingual (RU / AZ / EN / HE)
   ===================================================================== */

:root{
  --ink:        #0c0e13;   /* deep obsidian background        */
  --ink-2:      #11141b;   /* raised surface                  */
  --ink-3:      #171b24;   /* cards                           */
  --line:       #262b36;   /* hairlines                       */
  --gold:       #c9a24b;   /* primary accent — medal gold     */
  --gold-soft:  #e2c781;
  --gold-deep:  #8a6d28;
  --red:        #d23b3b;   /* Azerbaijani flag red, sparing   */
  --teal:       #2f6f6b;   /* flag green/teal, sparing        */
  --paper:      #f3efe6;   /* warm off-white text             */
  --muted:      #9aa0ad;
  --muted-2:    #6c7280;
  --ring: rgba(201,162,75,.45);

  --serif: "Playfair Display", "Noto Serif", Georgia, serif;
  --serif-he: "Frank Ruhl Libre", "Noto Serif Hebrew", serif;
  --sans: "Inter", "Noto Sans Hebrew", system-ui, -apple-system, "Segoe UI", sans-serif;

  --maxw: 1180px;
  --ease: cubic-bezier(.22,.61,.36,1);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.72;
  font-weight:380;
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
body::before{ /* subtle vignette + grain feel */
  content:""; position:fixed; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(201,162,75,.06), transparent 55%),
    radial-gradient(80% 60% at 100% 100%, rgba(47,111,107,.05), transparent 60%);
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* Hebrew / RTL ------------------------------------------------------ */
html[dir="rtl"] body{ font-family:var(--sans); letter-spacing:0; }
html[lang="he"] h1,html[lang="he"] h2,html[lang="he"] h3,
html[lang="he"] .display,html[lang="he"] .eyebrow{ font-family:var(--serif-he); }
html[dir="rtl"] .timeline__item{ padding-left:0; padding-right:2.2rem; }
html[dir="rtl"] .timeline::before{ left:auto; right:7px; }
html[dir="rtl"] .timeline__dot{ left:auto; right:0; }
html[dir="rtl"] .quote--big{ border-left:0; border-right:3px solid var(--gold); padding-left:0; padding-right:1.6rem; }
html[dir="rtl"] .lead::first-letter{ float:right; margin:.02em 0 0 .12em; }

/* ===================== LAYOUT ===================== */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(1.1rem,4vw,2.4rem); position:relative; z-index:1; }
section{ position:relative; z-index:1; }
.eyebrow{
  font-family:var(--serif); font-style:italic; color:var(--gold-soft);
  font-size:1.05rem; letter-spacing:.04em; margin-bottom:.6rem;
}
.section-title{
  font-family:var(--serif); font-weight:700; line-height:1.08;
  font-size:clamp(1.9rem,4.2vw,3rem); margin-bottom:1.4rem;
}
.section-pad{ padding-block:clamp(3.6rem,9vw,7rem); }
.rule{ width:64px; height:2px; background:linear-gradient(90deg,var(--gold),transparent); margin:.2rem 0 1.6rem; }
html[dir="rtl"] .rule{ background:linear-gradient(270deg,var(--gold),transparent); }

/* ===================== TOP BAR ===================== */
.topbar{
  position:fixed; inset-block-start:0; inset-inline:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
  padding:.7rem clamp(1.1rem,4vw,2.4rem);
  background:rgba(12,14,19,0);
  transition:background .4s var(--ease), box-shadow .4s var(--ease), padding .4s var(--ease);
}
.topbar.scrolled{
  background:rgba(10,12,17,.86);
  backdrop-filter:blur(14px) saturate(140%);
  box-shadow:0 1px 0 var(--line);
  padding-block:.55rem;
}
.brand{ display:flex; align-items:center; gap:.6rem; font-family:var(--serif); font-weight:600; letter-spacing:.02em; }
.brand .star{ color:var(--gold); font-size:1.1rem; }
.brand b{ font-weight:700; }
.brand span{ color:var(--muted); font-weight:400; font-size:.85rem; }

.nav{ display:flex; align-items:center; gap:.2rem; }
.nav a{
  font-size:.83rem; letter-spacing:.06em; text-transform:uppercase; color:var(--muted);
  padding:.5rem .7rem; border-radius:8px; transition:color .25s, background .25s;
}
.nav a:hover{ color:var(--paper); background:rgba(255,255,255,.04); }

.langs{ display:flex; gap:.15rem; background:rgba(255,255,255,.04); padding:.25rem; border-radius:10px; border:1px solid var(--line); }
.langs button,.langs a{
  font:inherit; font-size:.78rem; font-weight:600; letter-spacing:.04em;
  color:var(--muted); background:transparent; border:0; cursor:pointer;
  padding:.32rem .58rem; border-radius:7px; transition:.22s;
  text-decoration:none; display:inline-block; line-height:1;
}
.langs button:hover,.langs a:hover{ color:var(--paper); }
.langs button.active,.langs a.active{ color:var(--ink); background:var(--gold); }

.burger{ display:none; background:transparent; border:0; color:var(--paper); cursor:pointer; padding:.4rem; }
.burger svg{ width:26px; height:26px; }

/* ===================== HERO ===================== */
.hero{
  min-height:100svh; display:grid; align-items:center;
  padding-block:clamp(6rem,12vw,8rem) clamp(2.5rem,6vw,4rem);
  position:relative; overflow:hidden;
}
.hero__bg{
  position:absolute; inset:0; z-index:0;
  background:
    linear-gradient(180deg, rgba(12,14,19,.62), rgba(12,14,19,.86) 60%, var(--ink) 100%),
    radial-gradient(60% 80% at 78% 30%, rgba(201,162,75,.10), transparent 60%);
}
.hero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.15fr .85fr; gap:clamp(1.5rem,5vw,4rem); align-items:center; }
.hero__text .kicker{
  display:inline-flex; align-items:center; gap:.5rem; font-size:.78rem; letter-spacing:.22em;
  text-transform:uppercase; color:var(--gold-soft); margin-bottom:1.3rem;
  border:1px solid var(--gold-deep); border-radius:999px; padding:.4rem .9rem;
}
.hero__text h1{
  font-family:var(--serif); font-weight:800; line-height:.98;
  font-size:clamp(2.7rem,7.4vw,5.4rem); letter-spacing:-.01em; margin-bottom:.5rem;
}
.hero__text h1 .sub{ display:block; font-size:.4em; font-weight:600; font-style:italic; color:var(--gold-soft); margin-top:.5rem; letter-spacing:.01em; }
.hero__dates{
  font-family:var(--serif); font-size:clamp(1.05rem,2.4vw,1.35rem); color:var(--paper);
  display:flex; align-items:center; gap:.8rem; margin:.4rem 0 1.5rem; opacity:.9;
}
.hero__dates .sep{ flex:0 0 36px; height:1px; background:var(--gold); }
.hero__quote{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.15rem,2.4vw,1.5rem);
  line-height:1.5; color:var(--paper); max-width:34ch; border-inline-start:3px solid var(--gold);
  padding-inline-start:1.1rem;
}
.hero__cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:2rem; }

.btn{
  display:inline-flex; align-items:center; gap:.5rem; font:inherit; font-size:.92rem; font-weight:600;
  padding:.8rem 1.3rem; border-radius:10px; cursor:pointer; transition:.25s var(--ease); border:1px solid transparent;
}
.btn--gold{ background:var(--gold); color:#1a1407; }
.btn--gold:hover{ background:var(--gold-soft); transform:translateY(-2px); }
.btn--ghost{ border-color:var(--line); color:var(--paper); }
.btn--ghost:hover{ border-color:var(--gold); color:var(--gold-soft); }

.hero__portrait{ position:relative; }
.portrait-frame{
  position:relative; border-radius:14px; overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.6), 0 0 0 1px var(--line);
  aspect-ratio:4/5;
}
.portrait-frame img{
  width:100%; height:100%; object-fit:cover; object-position:50% 18%;
  filter:grayscale(.25) contrast(1.04);
}
.portrait-frame::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, transparent 55%, rgba(12,14,19,.7));
  mix-blend-mode:multiply;
}
.portrait-cap{
  position:absolute; inset-block-end:0; inset-inline:0; z-index:2; padding:1rem 1.2rem;
  font-size:.82rem; color:var(--paper); letter-spacing:.01em;
}
.portrait-cap b{ color:var(--gold-soft); font-weight:600; }

.scroll-hint{ position:absolute; inset-block-end:1.4rem; inset-inline-start:50%; transform:translateX(-50%); z-index:3; color:var(--muted); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:.5rem; }
.scroll-hint .line{ width:1px; height:34px; background:linear-gradient(var(--gold),transparent); animation:pulse 2.2s var(--ease) infinite; }
@keyframes pulse{ 0%,100%{opacity:.3; transform:scaleY(.7)} 50%{opacity:1; transform:scaleY(1)} }

/* ===================== LEAD / INTRO ===================== */
.lead{ font-size:clamp(1.2rem,2.5vw,1.6rem); line-height:1.6; font-weight:380; color:var(--paper); max-width:40ch; font-family:var(--serif); }
.lead strong{ color:var(--gold-soft); font-weight:600; }

.facts{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:14px; overflow:hidden; margin-top:2.4rem; }
.fact{ background:var(--ink-2); padding:1.4rem 1.2rem; }
.fact .num{ font-family:var(--serif); font-size:clamp(1.7rem,4vw,2.4rem); font-weight:800; color:var(--gold); line-height:1; }
.fact .lab{ font-size:.82rem; color:var(--muted); margin-top:.5rem; }

/* ===================== STORY (prose) ===================== */
.prose{ max-width:62ch; }
.prose p{ margin-bottom:1.15rem; color:#d8d4c8; }
.prose p:first-of-type::first-letter,.lead.dropcap::first-letter{
  font-family:var(--serif); font-weight:800; float:inline-start; font-size:3.6rem; line-height:.78;
  color:var(--gold); margin:.06em .12em 0 0;
}
.story-grid{ display:grid; grid-template-columns:1fr .8fr; gap:clamp(1.6rem,5vw,3.5rem); align-items:start; }
.story-media{ position:sticky; top:90px; }
.story-media figure{ border-radius:12px; overflow:hidden; border:1px solid var(--line); box-shadow:0 20px 50px rgba(0,0,0,.5); }
.story-media img{ width:100%; height:auto; filter:grayscale(.15); }
.story-media figcaption{ font-size:.8rem; color:var(--muted); padding:.7rem .9rem; background:var(--ink-3); }

/* ===================== BATTLE (feature band) ===================== */
.band{ position:relative; overflow:hidden; }
.band__bg{ position:absolute; inset:0; z-index:0; }
.band__bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.6) brightness(.42) contrast(1.05); }
.band__bg::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, var(--ink), rgba(12,14,19,.5) 45%, var(--ink)); }
.band .wrap{ position:relative; z-index:2; }
.band .section-title{ max-width:18ch; }
.battle-flow{ display:grid; gap:1.1rem; max-width:60ch; }
.battle-step{ display:grid; grid-template-columns:auto 1fr; gap:1rem; align-items:start; }
.battle-step .tick{ font-family:var(--serif); color:var(--gold); font-weight:800; font-size:1.1rem; line-height:1.5; min-width:2.2rem; }
.battle-step p{ color:#dcd8cc; }
.battle-step b{ color:var(--paper); }

/* ===================== QUOTES ===================== */
.quote--big{
  font-family:var(--serif); font-style:italic; font-size:clamp(1.6rem,4.4vw,2.8rem); line-height:1.32;
  border-inline-start:3px solid var(--gold); padding-inline-start:1.6rem; max-width:24ch; color:var(--paper);
}
.quote--big::before{ content:"“"; color:var(--gold); font-size:1.2em; line-height:0; vertical-align:-.35em; margin-inline-end:.05em; }
.quote-attrib{ margin-top:1.4rem; color:var(--muted); font-size:.92rem; letter-spacing:.02em; }
.quote-attrib b{ color:var(--gold-soft); font-weight:600; }

.bounty{ display:flex; align-items:center; gap:1.2rem; margin-top:2.6rem; padding:1.2rem 1.4rem; background:var(--ink-3); border:1px solid var(--line); border-radius:12px; max-width:50ch; }
.bounty .big{ font-family:var(--serif); font-weight:800; color:var(--red); font-size:clamp(1.4rem,3vw,2rem); line-height:1; white-space:nowrap; }
.bounty p{ font-size:.95rem; color:var(--muted); }

/* ===================== VIDEO FACADE ===================== */
.video-facade{
  position:relative; aspect-ratio:16/9; border-radius:14px; overflow:hidden; cursor:pointer;
  border:1px solid var(--line); box-shadow:0 24px 60px rgba(0,0,0,.55); background:#000;
}
.video-facade img{ width:100%; height:100%; object-fit:cover; object-position:50% 14%; filter:grayscale(.35) brightness(.62) contrast(1.05); transition:.5s var(--ease); }
.video-facade:hover img{ filter:grayscale(.1) brightness(.72); transform:scale(1.03); }
.video-facade::after{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 50% 45%, transparent 30%, rgba(8,9,13,.55)); }
.video-play{
  position:absolute; inset-block-start:50%; inset-inline-start:50%; transform:translate(-50%,-50%); z-index:2;
  width:84px; height:84px; border-radius:50%; border:2px solid var(--gold);
  background:rgba(201,162,75,.18); backdrop-filter:blur(4px); cursor:pointer;
  display:grid; place-items:center; transition:.3s var(--ease);
}
html[dir="rtl"] .video-play{ transform:translate(50%,-50%); }
.video-facade:hover .video-play{ background:var(--gold); transform:translate(-50%,-50%) scale(1.08); }
html[dir="rtl"] .video-facade:hover .video-play{ transform:translate(50%,-50%) scale(1.08); }
.video-play .tri{ width:0; height:0; border-style:solid; border-width:13px 0 13px 22px; border-color:transparent transparent transparent var(--gold); margin-inline-start:6px; transition:border-color .3s; }
.video-facade:hover .video-play .tri{ border-left-color:#1a1407; }
html[dir="rtl"] .video-play .tri{ transform:scaleX(-1); }
.video-cta{ position:absolute; inset-block-end:1.1rem; inset-inline-start:1.3rem; z-index:2; font-weight:600; letter-spacing:.04em; color:var(--paper); font-size:.95rem; }
.video-facade iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }
.video-fallback{ margin-top:1rem; font-size:.88rem; }
.video-fallback a{ color:var(--muted); border-bottom:1px solid var(--line); }
.video-fallback a:hover{ color:var(--gold-soft); }

/* ===================== TIMELINE ===================== */
.timeline{ position:relative; max-width:54ch; margin-top:.5rem; }
.timeline::before{ content:""; position:absolute; inset-block:6px; inset-inline-start:7px; width:2px; background:linear-gradient(var(--gold-deep),var(--line)); }
.timeline__item{ position:relative; padding-inline-start:2.2rem; padding-bottom:1.7rem; }
.timeline__dot{ position:absolute; inset-inline-start:0; top:6px; width:16px; height:16px; border-radius:50%; background:var(--ink); border:2px solid var(--gold); }
.timeline__item.is-end .timeline__dot{ background:var(--red); border-color:var(--red); }
.timeline__date{ font-family:var(--serif); color:var(--gold-soft); font-weight:700; font-size:1.05rem; }
.timeline__item p{ color:#cfcbbf; font-size:.98rem; margin-top:.15rem; }

/* ===================== GALLERY ===================== */
.gallery{ columns:3; column-gap:14px; }
.gallery figure{ break-inside:avoid; margin-bottom:14px; border-radius:12px; overflow:hidden; border:1px solid var(--line); position:relative; cursor:zoom-in; background:var(--ink-3); }
.gallery img{ width:100%; height:auto; transition:transform .6s var(--ease), filter .4s; filter:grayscale(.15); }
.gallery figure:hover img{ transform:scale(1.045); filter:grayscale(0); }
.gallery figcaption{
  position:absolute; inset-block-end:0; inset-inline:0; padding:1.4rem .9rem .7rem;
  font-size:.78rem; color:var(--paper); line-height:1.4;
  background:linear-gradient(transparent, rgba(8,9,13,.92)); opacity:0; transform:translateY(6px); transition:.35s var(--ease);
}
.gallery figure:hover figcaption{ opacity:1; transform:translateY(0); }
.gallery .badge{ position:absolute; inset-block-start:.6rem; inset-inline-start:.6rem; z-index:2; font-size:.66rem; letter-spacing:.1em; text-transform:uppercase; background:var(--gold); color:#1a1407; padding:.2rem .5rem; border-radius:6px; font-weight:700; }

/* lightbox */
.lb{ position:fixed; inset:0; z-index:100; background:rgba(6,7,10,.94); display:none; align-items:center; justify-content:center; padding:2rem; cursor:zoom-out; backdrop-filter:blur(6px); }
.lb.open{ display:flex; }
.lb img{ max-width:92vw; max-height:82vh; border-radius:8px; box-shadow:0 30px 90px rgba(0,0,0,.7); }
.lb__cap{ position:absolute; inset-block-end:1.4rem; inset-inline:0; text-align:center; color:var(--muted); font-size:.9rem; padding-inline:1rem; }
.lb__close{ position:absolute; inset-block-start:1.2rem; inset-inline-end:1.4rem; color:var(--paper); background:transparent; border:1px solid var(--line); border-radius:8px; padding:.4rem .7rem; cursor:pointer; font-size:1.1rem; }

/* ===================== MEMORY (cards) ===================== */
.cards{ display:grid; grid-template-columns:repeat(3,1fr); gap:1.1rem; }
.card{ background:var(--ink-3); border:1px solid var(--line); border-radius:14px; padding:1.6rem 1.4rem; transition:.3s var(--ease); }
.card:hover{ border-color:var(--gold-deep); transform:translateY(-4px); }
.card .ico{ font-size:1.6rem; margin-bottom:.7rem; }
.card h3{ font-family:var(--serif); font-size:1.25rem; font-weight:700; margin-bottom:.5rem; }
.card p{ font-size:.95rem; color:var(--muted); }

/* faith / interfaith band */
.faith{ text-align:center; }
.faith__symbols{ display:flex; align-items:center; justify-content:center; gap:1.6rem; font-size:2.4rem; color:var(--gold); margin-bottom:1.4rem; }
.faith__symbols span:nth-child(2){ color:var(--muted-2); font-size:1.4rem; }
.faith blockquote{ font-family:var(--serif); font-style:italic; font-size:clamp(1.3rem,3vw,1.9rem); line-height:1.45; max-width:30ch; margin-inline:auto; }

/* ===================== FOOTER ===================== */
.footer{ border-top:1px solid var(--line); background:var(--ink-2); padding-block:clamp(2.6rem,6vw,4rem); }
.footer__top{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:2rem; align-items:start; }
.footer__brand{ font-family:var(--serif); font-size:1.5rem; font-weight:700; }
.footer__brand .star{ color:var(--gold); }
.footer p.small{ color:var(--muted); font-size:.9rem; max-width:46ch; margin-top:.6rem; }
.footer__sources{ font-size:.82rem; color:var(--muted-2); }
.footer__sources a{ color:var(--muted); border-bottom:1px solid var(--line); }
.footer__sources a:hover{ color:var(--gold-soft); }
.footer__bottom{ margin-top:2.4rem; padding-top:1.4rem; border-top:1px solid var(--line); display:flex; flex-wrap:wrap; justify-content:space-between; gap:1rem; color:var(--muted-2); font-size:.82rem; }
.footer__bottom .nev{ font-family:var(--serif); font-style:italic; color:var(--gold-soft); }

/* ===================== REVEAL ANIM ===================== */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .8s var(--ease), transform .8s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none;} .scroll-hint .line{animation:none;} html{scroll-behavior:auto;} }

/* ===================== RESPONSIVE ===================== */
@media (max-width:960px){
  .hero__grid{ grid-template-columns:1fr; gap:2.4rem; }
  .hero__portrait{ max-width:380px; }
  .story-grid{ grid-template-columns:1fr; }
  .story-media{ position:static; }
  .cards{ grid-template-columns:1fr 1fr; }
  .gallery{ columns:2; }
  .facts{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .nav{ display:none; }
  .burger{ display:inline-flex; }
  .nav.open{
    display:flex; flex-direction:column; position:absolute; inset-block-start:100%; inset-inline:0;
    background:rgba(10,12,17,.98); padding:1rem; gap:.2rem; border-block:1px solid var(--line);
  }
  .nav.open a{ padding:.8rem; }
  .cards{ grid-template-columns:1fr; }
  .gallery{ columns:1; }
  .facts{ grid-template-columns:1fr 1fr; }
  .brand span{ display:none; }
  .battle-step{ grid-template-columns:1fr; gap:.2rem; }
}
