/* =====================================================================
   LE GOÛT ROUGE — Krimidinner
   Aesthetic: film-noir crime dossier × candlelit fine dining
   ===================================================================== */

:root{
  /* palette */
  --ink:        #0b0908;   /* near-black, warm */
  --ink-2:      #120d0c;
  --ink-3:      #1a1311;
  --paper:      #f3ece0;   /* bone / cream */
  --paper-dim:  #cabfae;
  --blood:      #9b1b1b;
  --blood-deep: #5e0f10;
  --blood-bright:#c41e1e;
  --wine:       #3c0c0e;
  --gold:       #c9a24b;
  --gold-soft:  #e2c98a;
  --muted:      rgba(245,239,229,.82);
  --muted-2:    rgba(245,239,229,.56);
  --line:       rgba(201,162,75,.28);

  /* type */
  --f-display: "Playfair Display", "Times New Roman", Georgia, serif;
  --f-body:    "EB Garamond", Georgia, "Times New Roman", serif;
  --f-mono:    "Special Elite", "Courier New", ui-monospace, monospace;

  /* layout */
  --maxw: 1180px;
  --gutter: clamp(1.2rem, 4vw, 3rem);
  --section-y: clamp(4.5rem, 11vw, 9rem);
}

/* ---------- reset ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  background:var(--ink);
  color:var(--paper);
  font-family:var(--f-body);
  font-size:clamp(1.14rem,.72rem + .85vw,1.34rem);
  line-height:1.72;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
em{ font-style:italic; }
strong{ font-weight:600; color:var(--gold-soft); }

/* ---------- layout helpers ---------- */
.container{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gutter); }
.narrow{ max-width:780px; }
.center{ text-align:center; margin-inline:auto; }

.section{ position:relative; padding-block:var(--section-y); }
/* offset anchor jumps so headings clear the fixed nav */
.hero,.section{ scroll-margin-top:74px; }
.section--dark{ background:
   radial-gradient(120% 80% at 50% 0%, rgba(94,15,16,.18), transparent 60%),
   var(--ink-2); }
.section-head{ margin-bottom:clamp(2.5rem,5vw,4rem); }

/* ---------- typography blocks ---------- */
.kicker{
  font-family:var(--f-mono);
  font-size:.78rem;
  letter-spacing:.34em;
  text-transform:uppercase;
  color:var(--gold);
  display:inline-flex; align-items:center; gap:.7em;
}
.kicker::before{ content:"▪"; color:var(--blood-bright); font-size:.7em; }
.kicker--center{ justify-content:center; }

.h2{
  font-family:var(--f-display);
  font-weight:700;
  line-height:1.12;
  font-size:clamp(1.9rem,1rem + 3.4vw,3.4rem);
  letter-spacing:.005em;
  margin-top:.7rem;
}
.h2 em{ color:var(--gold-soft); font-weight:600; }

.rule{ width:64px; height:2px; background:linear-gradient(90deg,var(--blood-bright),var(--gold)); margin:1.5rem 0; border-radius:2px; }
.rule--center{ margin-inline:auto; }

.lede{ color:var(--muted); margin-top:1.3rem; max-width:60ch; font-weight:500;
  font-size:clamp(1.24rem,.9rem + 1vw,1.5rem); line-height:1.75; }
.lede--accent{ color:var(--paper); font-size:1.16em; }
.lede.center{ margin-inline:auto; }

/* ---------- buttons ---------- */
.btn{
  display:inline-block;
  margin-top:2rem;
  font-family:var(--f-mono);
  font-size:.82rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--paper);
  padding:.95em 2em;
  border:1px solid var(--gold);
  background:linear-gradient(180deg, rgba(155,27,27,.18), rgba(155,27,27,.05));
  position:relative;
  transition:color .3s, background .3s, box-shadow .3s, transform .3s;
}
.btn:hover,.btn:focus-visible{
  background:var(--blood);
  border-color:var(--blood-bright);
  box-shadow:0 0 0 1px var(--blood-bright), 0 12px 40px -12px rgba(196,30,30,.7);
  transform:translateY(-2px);
}

/* =====================================================================
   FX overlays — grain + vignette
   ===================================================================== */
.fx-grain{
  position:fixed; inset:0; z-index:60; pointer-events:none;
  opacity:.05; mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.fx-vignette{
  position:fixed; inset:0; z-index:55; pointer-events:none;
  background:radial-gradient(130% 100% at 50% 42%, transparent 55%, rgba(0,0,0,.55) 100%);
}

/* =====================================================================
   NAV
   ===================================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  transition:background .4s, backdrop-filter .4s, border-color .4s, padding .4s;
  border-bottom:1px solid transparent;
}
.nav__inner{
  max-width:var(--maxw); margin-inline:auto; padding:1.1rem var(--gutter);
  display:flex; align-items:center; justify-content:space-between; gap:1rem;
}
.nav.scrolled{
  background:rgba(11,9,8,.82);
  backdrop-filter:blur(10px) saturate(1.1);
  border-bottom-color:var(--line);
}
.nav.scrolled .nav__inner{ padding-block:.7rem; }
.nav__brand{ display:flex; align-items:center; gap:.6rem; opacity:0; transform:translateY(-6px); transition:opacity .4s, transform .4s; pointer-events:none; }
.nav.scrolled .nav__brand{ opacity:1; transform:none; pointer-events:auto; }
.nav__brand-mark{ color:var(--blood-bright); font-size:.8rem; }
.nav__brand-text{ font-family:var(--f-display); font-weight:700; font-size:1.15rem; letter-spacing:.02em; }
.nav__links{ display:flex; gap:clamp(1rem,3vw,2.4rem); }
.nav__links a{
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.2em; text-transform:uppercase;
  color:var(--muted); position:relative; padding:.3em 0; transition:color .3s;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:1px; background:var(--gold); transition:width .3s; }
.nav__links a:hover,.nav__links a:focus-visible{ color:var(--paper); }
.nav__links a:hover::after,.nav__links a:focus-visible::after{ width:100%; }

/* mobile: hide wrapping links, keep a clean branded bar */
@media (max-width:600px){
  .nav{ background:rgba(11,9,8,.85); backdrop-filter:blur(8px) saturate(1.1); border-bottom-color:var(--line); }
  .nav__inner{ justify-content:center; padding-block:.7rem; }
  .nav__brand{ opacity:1; transform:none; pointer-events:auto; }
  .nav__links{ display:none; }
}

/* =====================================================================
   HERO
   ===================================================================== */
.hero{
  position:relative; min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:7rem var(--gutter) 5rem; overflow:hidden;
}
.hero__media{ position:absolute; inset:0; z-index:-2; }
.hero__img{
  position:absolute; inset:-1.5%; background-size:cover; background-position:center;
  transform:scale(1.01); animation:kenburns 32s ease-in-out infinite alternate;
}
/* minimal magnification so the 1080p-sourced frame stays as crisp as possible */
@keyframes kenburns{ from{ transform:scale(1.01) translate(0,0);} to{ transform:scale(1.05) translate(-1%,-1.2%);} }
.hero__scrim{
  position:absolute; inset:0;
  background:
    radial-gradient(100% 75% at 50% 35%, rgba(60,12,14,.35), transparent 70%),
    linear-gradient(180deg, rgba(11,9,8,.62) 0%, rgba(11,9,8,.42) 35%, rgba(11,9,8,.78) 78%, var(--ink) 100%);
}
.hero__content{ max-width:880px; position:relative; }
.hero__title{
  font-family:var(--f-display); font-weight:800;
  font-size:clamp(2.7rem,.5rem + 11vw,8.5rem);
  line-height:.98; letter-spacing:-.01em; margin:1rem 0 .2rem;
  text-shadow:0 18px 60px rgba(0,0,0,.6);
  overflow-wrap:break-word; text-wrap:balance;
}
.hero__type{
  font-family:var(--f-display); font-style:italic; font-weight:500;
  font-size:clamp(1.25rem,.6rem + 1.8vw,2rem); color:var(--gold-soft);
  letter-spacing:.02em;
}
.hero__tag{
  font-family:var(--f-display); font-weight:500;
  font-size:clamp(1.15rem,.7rem + 1.4vw,1.7rem); line-height:1.35;
  margin-top:1.8rem;
}
.hero__sub{ color:var(--muted); margin-top:1rem; font-size:1.05rem; }
.hero__scroll{ position:absolute; bottom:1.8rem; left:50%; transform:translateX(-50%); }
.hero__scroll-line{ display:block; width:1px; height:54px; background:linear-gradient(var(--gold),transparent); position:relative; overflow:hidden; }
.hero__scroll-line::after{ content:""; position:absolute; top:-50%; left:0; width:100%; height:50%; background:var(--paper); animation:scrolldot 2.2s ease-in-out infinite; }
@keyframes scrolldot{ 0%{ top:-50%;} 60%,100%{ top:120%;} }

/* =====================================================================
   DER FALL
   ===================================================================== */
.section--fall{
  background:
    radial-gradient(120% 90% at 50% -10%, rgba(94,15,16,.28), transparent 55%),
    var(--ink);
}
.section--fall .h2{ margin-top:1rem; }

/* =====================================================================
   ERMITTLUNG — cards
   ===================================================================== */
.cards{ display:grid; grid-template-columns:repeat(auto-fit,minmax(min(100%,290px),1fr)); gap:clamp(1.4rem,3vw,2.2rem); }
.card{
  background:linear-gradient(180deg, rgba(243,236,224,.04), rgba(243,236,224,.015));
  border:1px solid var(--line);
  position:relative; overflow:hidden;
  transition:transform .4s, border-color .4s, box-shadow .4s;
}
.card:hover{ transform:translateY(-6px); border-color:rgba(201,162,75,.55); box-shadow:0 24px 60px -28px rgba(0,0,0,.9); }
.card__media{ position:relative; aspect-ratio:16/10; overflow:hidden; }
.card__media img{ width:100%; height:100%; object-fit:cover; filter:saturate(.92) contrast(1.03); transition:transform .6s, filter .6s; }
.card:hover .card__media img{ transform:scale(1.06); filter:saturate(1.05); }
.card__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, transparent 45%, rgba(11,9,8,.7)); }
.tag{
  position:absolute; top:.9rem; left:.9rem; z-index:2;
  font-family:var(--f-mono); font-size:.66rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--ink); background:var(--gold); padding:.3em .7em;
  transform:rotate(-3deg); box-shadow:0 4px 14px rgba(0,0,0,.4);
}
.card__body{ padding:1.5rem 1.5rem 1.7rem; }
.card__title{ font-family:var(--f-display); font-weight:700; font-size:1.35rem; margin-bottom:.5rem; }
.card__body p{ color:var(--muted); font-size:1.08rem; line-height:1.6; }

/* =====================================================================
   MENÜ
   ===================================================================== */
.section--menu{ background:
   linear-gradient(180deg, var(--ink) 0%, var(--wine) 120%),
   var(--ink); }
.menu-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width:860px){ .menu-grid{ grid-template-columns:1fr; } }

.menu-card{
  margin-top:2.2rem;
  background:
    repeating-linear-gradient(0deg, transparent, transparent 2.1rem, rgba(201,162,75,.07) 2.1rem, rgba(201,162,75,.07) calc(2.1rem + 1px)),
    rgba(11,9,8,.45);
  border:1px solid var(--line);
  padding:clamp(1.6rem,3vw,2.4rem);
  position:relative;
}
.menu-card::before,.menu-card::after{ content:""; position:absolute; width:14px; height:14px; border:1px solid var(--gold); }
.menu-card::before{ top:10px; left:10px; border-right:0; border-bottom:0; }
.menu-card::after{ bottom:10px; right:10px; border-left:0; border-top:0; }
.menu-card__head{ font-family:var(--f-display); font-style:italic; font-size:1.5rem; color:var(--gold-soft); text-align:center; margin-bottom:1.3rem; }
.menu-list{ list-style:none; display:flex; flex-direction:column; gap:1.15rem; }
.menu-list li{ display:flex; gap:1rem; align-items:baseline; }
.menu-list__no{ font-family:var(--f-display); font-style:italic; color:var(--blood-bright); font-size:1.2rem; min-width:1.6em; }
.menu-list__name{ display:block; font-family:var(--f-display); font-weight:600; font-size:1.2rem; }
.menu-list__desc{ display:block; color:var(--muted); font-size:1.06rem; }
.menu-card__foot{ margin-top:1.6rem; padding-top:1.2rem; border-top:1px solid var(--line); text-align:center; font-style:italic; color:var(--muted); font-size:.95rem; }

.menu-grid__media{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.menu-photo{ position:relative; overflow:hidden; border:1px solid var(--line); }
.menu-photo--tall{ grid-column:1 / -1; aspect-ratio:16/9; }
.menu-photo{ aspect-ratio:4/3; }
.menu-photo img{ width:100%; height:100%; object-fit:cover; transition:transform .7s; }
.menu-photo:hover img{ transform:scale(1.05); }
.menu-photo figcaption{
  position:absolute; left:0; bottom:0; right:0; padding:1rem .9rem .7rem;
  font-family:var(--f-mono); font-size:.68rem; letter-spacing:.14em; text-transform:uppercase; color:var(--paper);
  background:linear-gradient(transparent, rgba(11,9,8,.85));
}

/* ---------- featured film ---------- */
.film{
  position:relative; margin:0 0 clamp(2rem,4vw,3rem); overflow:hidden;
  border:1px solid var(--line); aspect-ratio:16/9; background:#000;
  box-shadow:0 30px 80px -40px rgba(0,0,0,.9);
}
.film__video{ width:100%; height:100%; object-fit:cover; display:block; filter:saturate(1.02) contrast(1.03); }
.film::after{ content:""; position:absolute; inset:0; pointer-events:none; box-shadow:inset 0 0 120px rgba(11,9,8,.55); }
.film__rec{
  position:absolute; top:1rem; left:1rem; z-index:2;
  font-family:var(--f-mono); font-size:.72rem; letter-spacing:.2em; color:var(--paper);
  display:inline-flex; align-items:center; gap:.5em;
  background:rgba(11,9,8,.5); padding:.35em .7em; border:1px solid var(--line);
}
.film__rec::before{ content:""; width:.6em; height:.6em; border-radius:50%; background:var(--blood-bright); animation:blink 1.4s steps(1) infinite; }
@keyframes blink{ 50%{ opacity:.2; } }
.film__cap{
  position:absolute; left:0; right:0; bottom:0; z-index:2; padding:1.4rem 1.1rem .9rem;
  font-family:var(--f-mono); font-size:.7rem; letter-spacing:.18em; text-transform:uppercase; color:var(--paper);
  background:linear-gradient(transparent, rgba(11,9,8,.85));
}

/* =====================================================================
   GALERIE — masonry via columns + lightbox
   ===================================================================== */
.gallery{ column-count:3; column-gap:1rem; }
@media (max-width:820px){ .gallery{ column-count:2; } }
@media (max-width:480px){ .gallery{ column-count:1; } }
.gallery__item{
  break-inside:avoid; margin-bottom:1rem; position:relative; overflow:hidden;
  cursor:pointer; border:1px solid transparent; transition:border-color .3s;
}
.gallery__item img{ width:100%; filter:saturate(.9) brightness(.94) contrast(1.03); transition:transform .6s, filter .6s; }
.gallery__item::after{
  content:"＋"; position:absolute; inset:0; display:flex; align-items:center; justify-content:center;
  font-family:var(--f-body); font-size:2rem; color:var(--paper);
  background:linear-gradient(0deg, rgba(94,15,16,.55), rgba(11,9,8,.25));
  opacity:0; transition:opacity .35s;
}
.gallery__item:hover img,.gallery__item:focus-visible img{ transform:scale(1.05); filter:saturate(1.05) brightness(1); }
.gallery__item:hover::after,.gallery__item:focus-visible::after{ opacity:1; }
.gallery__item:focus-visible{ outline:2px solid var(--gold); outline-offset:2px; }

/* =====================================================================
   CREW
   ===================================================================== */
.section--crew{ background:var(--ink); }
.crew-grid{ display:grid; grid-template-columns:.95fr 1.05fr; gap:clamp(2rem,5vw,4.5rem); align-items:center; }
@media (max-width:860px){ .crew-grid{ grid-template-columns:1fr; } }
.crew-photo{ position:relative; overflow:hidden; border:1px solid var(--line); }
.crew-photo::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 90px rgba(11,9,8,.6); }
.crew-photo img{ width:100%; filter:saturate(.95) contrast(1.03); }
.credit-list{ list-style:none; margin-top:1.8rem; display:flex; flex-direction:column; gap:.7rem; }
.credit-list li{ display:flex; gap:1rem; align-items:baseline; color:var(--muted); border-bottom:1px dashed var(--line); padding-bottom:.7rem; }
.credit-list span{ font-family:var(--f-mono); font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--gold); min-width:8.5em; }

/* =====================================================================
   FINALE
   ===================================================================== */
.section--finale{ position:relative; overflow:hidden; text-align:center; padding-block:clamp(6rem,14vw,11rem); }
.finale__bg{ position:absolute; inset:-2%; background-size:cover; background-position:center; filter:grayscale(.3) saturate(.8) brightness(.5); z-index:-2; }
.finale__scrim{ position:absolute; inset:0; z-index:-1; background:radial-gradient(100% 90% at 50% 50%, rgba(60,12,14,.55), rgba(11,9,8,.92) 75%); }
.finale__title{ margin-top:1rem; }
.finale__content .lede{ margin-inline:auto; }
.stamp{
  display:inline-block; margin-top:2.6rem;
  font-family:var(--f-mono); font-size:clamp(1rem,.5rem + 1.4vw,1.5rem); letter-spacing:.2em; text-transform:uppercase;
  color:var(--blood-bright); border:3px double var(--blood-bright); padding:.55em 1.1em;
  transform:rotate(-7deg); opacity:.92;
  box-shadow:inset 0 0 18px rgba(196,30,30,.25);
}

/* =====================================================================
   FOOTER
   ===================================================================== */
.footer{ background:var(--ink-2); border-top:1px solid var(--line); padding-block:clamp(2.6rem,6vw,4rem); }
.footer__brand{ font-family:var(--f-display); font-weight:700; font-size:clamp(1.6rem,1rem + 2vw,2.4rem); }
.footer__sub{ font-family:var(--f-mono); font-size:.74rem; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); margin-top:.6rem; }
.footer__fine{ color:var(--muted-2); margin-top:1rem; font-size:.95rem; }

/* =====================================================================
   LIGHTBOX
   ===================================================================== */
.lightbox{
  position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center;
  background:rgba(7,5,5,.94); backdrop-filter:blur(6px);
  opacity:0; transition:opacity .3s; padding:clamp(1rem,4vw,3rem);
}
.lightbox[hidden]{ display:none; }
.lightbox.open{ opacity:1; }
.lightbox__figure{ max-width:min(1100px,92vw); max-height:86vh; }
.lightbox__img{ max-width:100%; max-height:86vh; margin:auto; box-shadow:0 30px 80px -20px rgba(0,0,0,.9); border:1px solid var(--line); }
.lightbox__close,.lightbox__nav{
  position:absolute; background:transparent; border:1px solid var(--line); color:var(--paper);
  cursor:pointer; font-family:var(--f-body); line-height:1; transition:background .25s, border-color .25s, transform .25s;
}
.lightbox__close{ top:1.2rem; right:1.2rem; width:2.8rem; height:2.8rem; font-size:1.8rem; border-radius:50%; }
.lightbox__nav{ top:50%; transform:translateY(-50%); width:3.2rem; height:3.2rem; font-size:2rem; border-radius:50%; }
.lightbox__nav--prev{ left:clamp(.6rem,3vw,2rem); }
.lightbox__nav--next{ right:clamp(.6rem,3vw,2rem); }
.lightbox__close:hover,.lightbox__nav:hover{ background:var(--blood); border-color:var(--blood-bright); }
.lightbox__nav:hover{ transform:translateY(-50%) scale(1.06); }
.lightbox__count{ position:absolute; bottom:1.3rem; left:50%; transform:translateX(-50%); font-family:var(--f-mono); font-size:.74rem; letter-spacing:.22em; color:var(--muted); }

/* =====================================================================
   REVEAL animations
   ===================================================================== */
.reveal{ opacity:0; transform:translateY(26px); transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1); will-change:opacity,transform; }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion: reduce){
  .hero__img{ animation:none; transform:scale(1.01); }
  .hero__scroll-line::after{ animation:none; }
  .film__rec::before{ animation:none; }
  .reveal{ opacity:1; transform:none; transition:none; }
}
