/* ===========================================================
   PETROCELLI — minimal, elegant, classic with a modern twist
=========================================================== */

:root{
  --ink:        #1a1d24;
  --ink-soft:   #2b2f38;
  --muted:      #6b6f78;
  --muted-2:    #9aa0aa;
  --line:       #ececef;
  --paper:      #ffffff;
  --paper-2:    #fafafb;
  --soft:       #f4f4f6;
  --blue:       #1d3aa1;
  --blue-deep:  #142974;
  --terra:      #b8593c;     /* refined terracotta accent */
  --terra-soft: #c9684a;

  --grey-cool:  #f5f5f7;
  --grey-cool-2:#e8e8ed;
  --grey-text:  #6e6e73;
  --grey-ink:   #1d1d1f;

  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, sans-serif;

  --max: 1200px;
  --pad: clamp(1.25rem, 4vw, 2.5rem);
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.65;
  color:var(--ink);
  background:var(--paper);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }

.container{
  max-width:var(--max);
  margin:0 auto;
  padding-left:var(--pad);
  padding-right:var(--pad);
}

.eyebrow{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.3em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--blue);
}

.section-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(2.2rem, 5vw, 3.8rem);
  line-height:1.05;
  letter-spacing:-.015em;
  color:var(--ink);
  margin-top:1rem;
}
.section-title em{
  font-style:italic;
  color:var(--terra);
  font-weight:400;
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:.5rem;
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  padding:.95rem 1.8rem;
  border-radius:999px;
  transition:all .35s ease;
  white-space:nowrap;
}
.btn-solid{
  background:var(--blue);
  color:var(--paper);
}
.btn-solid:hover{ background:var(--blue-deep); transform:translateY(-1px); }
.btn-line{
  background:transparent;
  color:var(--paper);
  border:1px solid rgba(255,255,255,.6);
}
.btn-line:hover{ background:rgba(255,255,255,.12); border-color:#fff; }
.btn-ghost{
  background:transparent;
  color:var(--ink);
  border:1px solid var(--ink);
  padding:.7rem 1.3rem;
  font-size:.7rem;
}
.btn-ghost:hover{ background:var(--blue); color:var(--paper); border-color:var(--blue); }
.btn-large{ padding:1.15rem 2.2rem; }

.link-arrow{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-family:var(--sans);
  font-size:.74rem;
  letter-spacing:.22em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--blue);
  margin-top:1.8rem;
  position:relative;
  padding-bottom:.4rem;
}
.link-arrow::after{
  content:"→";
  font-size:1.1rem;
  transition:transform .3s ease;
}
.link-arrow:hover::after{ transform:translateX(6px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed;
  top:0; left:0; right:0;
  z-index:100;
  padding:1rem 0;
  transition:background .35s ease, padding .35s ease, border-color .35s ease;
  border-bottom:1px solid transparent;
}
.site-header.scrolled{
  background:rgba(255,255,255,.94);
  backdrop-filter:saturate(180%) blur(18px);
  -webkit-backdrop-filter:saturate(180%) blur(18px);
  border-bottom-color:var(--line);
  padding:.5rem 0;
}
.header-inner{
  max-width:var(--max);
  margin:0 auto;
  padding:0 var(--pad);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:2rem;
}

.brand{
  display:flex;
  align-items:center;
}
.brand-mark{
  width:90px;
  height:90px;
  object-fit:contain;
  flex-shrink:0;
  transition:width .35s ease, height .35s ease, filter .35s ease;
}
.site-header.scrolled .brand-mark{
  width:64px;
  height:64px;
}
.site-header:not(.scrolled) .brand-mark{
  filter:brightness(0) invert(1);
}

/* Desktop nav — visible only on desktop, hidden on mobile via media query */
.nav-desktop{
  display:flex;
  align-items:center;
  gap:2.4rem;
  flex:1;
  justify-content:center;
}
.nav-desktop-link{
  font-family:var(--sans);
  font-size:.78rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--ink);
  position:relative;
  padding:.4rem 0;
  transition:color .3s ease;
}
.nav-desktop-link::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-2px;
  height:1px;
  background:var(--terra);
  transform:scaleX(0);
  transform-origin:center;
  transition:transform .3s ease;
}
.nav-desktop-link:hover{
  color:var(--terra);
}
.nav-desktop-link:hover::after{
  transform:scaleX(1);
}
/* When hero is visible (header not scrolled), nav links are white over the image */
.site-header:not(.scrolled) .nav-desktop-link{
  color:var(--paper);
}
.site-header:not(.scrolled) .nav-desktop-link::after{
  background:var(--paper);
}
.site-header:not(.scrolled) .nav-desktop-link:hover{
  color:var(--paper);
  opacity:.85;
}

.header-actions{
  display:flex;
  align-items:center;
  gap:.9rem;
}
.header-actions .ig-btn{
  margin-left:.6rem;
}
.ig-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:42px;
  height:42px;
  border:1px solid var(--ink);
  border-radius:50%;
  color:var(--ink);
  transition:all .3s ease;
}
.ig-btn:hover{
  background:var(--blue);
  border-color:var(--blue);
  color:var(--paper);
  transform:translateY(-1px);
}
.site-header:not(.scrolled) .ig-btn{
  color:var(--paper);
  border-color:rgba(255,255,255,.6);
}
.site-header:not(.scrolled) .ig-btn:hover{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}
.ig-link{
  display:inline-flex;
  align-items:center;
  gap:.5rem;
}
.ig-link:hover{ color:var(--blue); }
.site-header:not(.scrolled) .btn-ghost{
  color:var(--paper);
  border-color:rgba(255,255,255,.6);
}
.site-header:not(.scrolled) .btn-ghost:hover{
  background:var(--paper);
  color:var(--ink);
  border-color:var(--paper);
}

.hamburger{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;
  gap:5px;
  width:42px;
  height:42px;
  border:1px solid var(--terra);
  border-radius:50%;
  margin-left:.4rem;
  position:relative;
  z-index:101;
  background:transparent;
  transition:all .3s ease;
}
.hamburger:hover{
  background:var(--terra);
  border-color:var(--terra);
  transform:translateY(-1px);
}
.hamburger span{
  display:block;
  width:16px;
  height:1.5px;
  background:var(--terra);
  transition:all .35s ease;
  transform-origin:center;
}
.hamburger:hover span{
  background:var(--paper);
}
.site-header:not(.scrolled) .hamburger{
  background:transparent;
  border-color:var(--terra-soft);
}
.site-header:not(.scrolled) .hamburger span{
  background:var(--terra-soft);
}
.site-header:not(.scrolled) .hamburger:hover{
  background:var(--terra);
  border-color:var(--terra);
}
.site-header:not(.scrolled) .hamburger:hover span{
  background:var(--paper);
}

/* Burger -> X when overlay open (always over white overlay bg) */
.hamburger.is-active,
.site-header:not(.scrolled) .hamburger.is-active{
  background:var(--terra);
  border-color:var(--terra);
}
.hamburger.is-active span,
.site-header:not(.scrolled) .hamburger.is-active span{
  background:var(--paper);
}
.hamburger.is-active span:nth-child(1){
  transform:translateY(6.5px) rotate(45deg);
}
.hamburger.is-active span:nth-child(2){
  opacity:0;
}
.hamburger.is-active span:nth-child(3){
  transform:translateY(-6.5px) rotate(-45deg);
}

/* Full-screen elegant overlay nav */
.nav-overlay{
  position:fixed;
  top:0; left:0; right:0; bottom:0;
  background:var(--paper);
  z-index:100;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  padding:7rem var(--pad) 2.5rem;
  opacity:0;
  pointer-events:none;
  transition:opacity .4s ease;
}
.nav-overlay.open{
  opacity:1;
  pointer-events:auto;
}
.nav-overlay-inner{
  flex:1;
  display:flex;
  flex-direction:column;
  justify-content:center;
  max-width:var(--max);
  margin:0 auto;
  width:100%;
  gap:.4rem;
}
.nav-link{
  display:flex;
  align-items:baseline;
  gap:1.5rem;
  font-family:var(--serif);
  font-size:clamp(2.2rem, 6vw, 4.5rem);
  font-weight:400;
  color:var(--ink);
  line-height:1.1;
  padding:.5rem 0;
  border-bottom:1px solid var(--line);
  transition:color .3s ease, padding-left .35s ease;
  opacity:0;
  transform:translateY(20px);
}
.nav-overlay.open .nav-link{
  opacity:1;
  transform:translateY(0);
  transition:opacity .6s ease, transform .6s cubic-bezier(.2,.7,.2,1), color .3s ease, padding-left .35s ease, border-color .3s ease;
}
.nav-overlay.open .nav-link:nth-child(1){ transition-delay:.1s, .1s, 0s, 0s, 0s; }
.nav-overlay.open .nav-link:nth-child(2){ transition-delay:.16s, .16s, 0s, 0s, 0s; }
.nav-overlay.open .nav-link:nth-child(3){ transition-delay:.22s, .22s, 0s, 0s, 0s; }
.nav-overlay.open .nav-link:nth-child(4){ transition-delay:.28s, .28s, 0s, 0s, 0s; }
.nav-overlay.open .nav-link:nth-child(5){ transition-delay:.34s, .34s, 0s, 0s, 0s; }
.nav-overlay.open .nav-link:nth-child(6){ transition-delay:.40s, .40s, 0s, 0s, 0s; }

.nav-link:hover{
  color:var(--terra);
  padding-left:1rem;
  border-bottom-color:var(--terra);
}
.nav-num{
  font-family:var(--serif);
  font-size:.95rem;
  font-style:italic;
  color:var(--terra);
  letter-spacing:.08em;
  min-width:2.5rem;
}
.nav-overlay-foot{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1.5rem;
  max-width:var(--max);
  margin:0 auto;
  width:100%;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
  opacity:0;
  transform:translateY(10px);
  transition:opacity .5s ease .5s, transform .5s ease .5s;
}
.nav-overlay.open .nav-overlay-foot{
  opacity:1;
  transform:translateY(0);
}
.nav-foot-link{
  font-size:.85rem;
  letter-spacing:.04em;
  color:var(--muted);
  transition:color .25s ease;
}
.nav-foot-link:hover{ color:var(--terra); }

body.nav-open{ overflow:hidden; }

/* Desktop: hide the hamburger, show the inline nav */
@media (min-width: 901px){
  .hamburger{ display:none; }
}

/* Mobile: hide the inline nav, show the hamburger */
@media (max-width: 900px){
  .nav-desktop{ display:none; }
  .header-actions .reserve-btn{ display:none; }
  .brand-mark{ width:64px; height:64px; }
  .site-header.scrolled .brand-mark{ width:54px; height:54px; }
}
@media (max-width: 480px){
  .brand-mark{ width:54px; height:54px; }
  .site-header.scrolled .brand-mark{ width:46px; height:46px; }
  .nav-overlay-foot{ flex-direction:column; align-items:flex-start; gap:1rem; }
}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  display:flex;
  align-items:flex-end;
  padding:8rem var(--pad) 7rem;
  color:var(--paper);
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  transform:scale(1.05);
  animation:slowZoom 20s ease-out forwards;
}
@keyframes slowZoom{
  to{ transform:scale(1); }
}
.hero-overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,22,28,.15) 0%, rgba(20,22,28,.45) 60%, rgba(20,22,28,.6) 100%);
}
.hero-content{
  position:relative;
  max-width:var(--max);
  margin:0 auto;
  width:100%;
}
.hero .eyebrow{
  color:var(--paper);
  opacity:.9;
  opacity:0;
  animation:rise .9s cubic-bezier(.2,.7,.2,1) .15s forwards;
}
.hero-title{
  font-family:"Bodoni Moda", "Bodoni 72", Bodoni, "Didot", serif;
  font-weight:400;
  font-size:clamp(3.8rem, 12vw, 10rem);
  line-height:.95;
  letter-spacing:-.015em;
  margin:1.2rem 0 2.5rem;
  opacity:0;
  transform:translateY(24px);
  animation:rise 1s cubic-bezier(.2,.7,.2,1) .35s forwards;
}
@keyframes rise{
  to{ opacity:1; transform:translateY(0); }
}
.hero-cta{
  display:flex;
  flex-wrap:wrap;
  gap:.8rem;
  opacity:0;
  animation:rise .9s cubic-bezier(.2,.7,.2,1) .65s forwards;
}

/* ---------- Story ---------- */
.story{
  padding:9rem 0 6rem;
  text-align:center;
}
.story-inner{
  max-width:46rem;
  margin:0 auto;
}
.story-intro{
  font-family:var(--serif);
  font-size:clamp(1.5rem, 2.3vw, 1.95rem);
  line-height:1.5;
  color:var(--ink);
  font-weight:500;
}
.story-quote{
  margin-top:2.2rem;
  font-family:var(--serif);
  font-size:clamp(1.25rem, 1.95vw, 1.6rem);
  line-height:1.55;
  font-style:italic;
  color:var(--ink);
  font-weight:400;
}
.story-inner .link-arrow{
  margin-top:2.6rem;
}

@media (max-width:900px){
  .story{ padding:6rem 0 4rem; }
  .story-quote br{ display:none; }
}

/* ---------- Feature Image ---------- */
.feature{
  padding:3rem 0 9rem;
}
.feature-img{
  max-width:760px;
  margin:0 auto;
  aspect-ratio:4/5;
  overflow:hidden;
}
.feature-img img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.4s ease;
}
.feature-img:hover img{ transform:scale(1.03); }

@media (max-width:900px){
  .feature{ padding:1rem 0 5rem; }
  .feature-img{ aspect-ratio:4/3; }
}

/* ---------- Menu ---------- */
.menu{ padding:6rem 0 9rem; }
.menu-head{
  text-align:center;
  margin-bottom:4rem;
}
.menu-grid{
  display:grid;
  grid-template-columns:repeat(5, 1fr);
  gap:1rem;
  max-width:1000px;
  margin:0 auto;
}
.menu-card{
  position:relative;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  aspect-ratio:3/4;
  padding:1.6rem 1.5rem;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:2px;
  transition:all .45s cubic-bezier(.2,.7,.2,1);
  overflow:hidden;
}
.menu-card::before{
  content:"";
  position:absolute;
  inset:0;
  background:var(--terra);
  transform:translateY(101%);
  transition:transform .55s cubic-bezier(.7,0,.3,1);
  z-index:0;
}
.menu-card:hover{
  border-color:var(--terra);
  transform:translateY(-3px);
}
.menu-card:hover::before{ transform:translateY(0); }
.menu-card:hover .menu-num{ color:#f8e8d4; }
.menu-card:hover .menu-name{ color:var(--paper); }
.menu-num{
  position:relative; z-index:1;
  font-family:var(--serif);
  font-size:1.25rem;
  letter-spacing:.08em;
  color:var(--terra);
  font-weight:400;
  font-style:italic;
  transition:color .35s ease;
}
.menu-name{
  position:relative; z-index:1;
  font-family:var(--serif);
  font-size:clamp(1.4rem, 2.2vw, 1.85rem);
  font-weight:400;
  line-height:1;
  color:var(--ink);
  transition:color .35s ease;
}

@media (max-width:900px){
  .menu{ padding:4rem 0 6rem; }
  .menu-grid{ grid-template-columns:repeat(2, 1fr); }
}
@media (max-width:480px){
  .menu-grid{ grid-template-columns:1fr; gap:.7rem; }
  .menu-card{
    aspect-ratio:auto;
    flex-direction:row;
    align-items:center;
    padding:1.3rem 1.5rem;
    gap:1.5rem;
  }
}

/* ---------- Triptych ---------- */
.triptych{
  padding:0 0 9rem;
}
.triptych-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1.2rem;
}
.t-img{
  aspect-ratio:3/4;
  overflow:hidden;
}
.t-img img{
  width:100%; height:100%; object-fit:cover;
  transition:transform 1.4s ease;
}
.t-img:hover img{ transform:scale(1.05); }

@media (max-width:760px){
  .triptych{ padding:0 0 5rem; }
  .triptych-grid{ grid-template-columns:1fr; gap:1rem; }
  .t-img{ aspect-ratio:4/5; }
}

/* ---------- Invoice ---------- */
.invoice{
  background:var(--blue-deep);
  color:var(--paper);
  padding:4.5rem 0;
}
.invoice-inner{
  display:grid;
  grid-template-columns:1.4fr auto;
  gap:3rem;
  align-items:center;
}
.invoice .eyebrow{ color:#cdd9ff; }
.invoice .section-title{
  color:var(--paper);
  font-size:clamp(1.7rem, 3vw, 2.5rem);
}
.invoice-note{
  margin-top:1rem;
  max-width:36rem;
  color:rgba(255,255,255,.78);
  font-size:.95rem;
  line-height:1.6;
}
.invoice .btn-solid{
  background:var(--paper);
  color:var(--blue-deep);
}
.invoice .btn-solid:hover{
  background:#fff;
  color:var(--blue);
  transform:translateY(-1px);
}

@media (max-width:760px){
  .invoice-inner{ grid-template-columns:1fr; }
}

/* ---------- Cappuccino ---------- */
.cappuccino{
  padding:9rem 0;
  text-align:center;
}
.capp-inner{
  max-width:38rem;
  margin:0 auto;
}
.capp-inner .link-arrow{ margin-top:2.2rem; }

@media (max-width:900px){
  .cappuccino{ padding:5rem 0; }
}

/* ---------- Delivery ---------- */
.delivery{
  padding:6rem 0;
  background:#faf3ed;
}
.delivery-inner{
  display:grid;
  grid-template-columns:1.4fr auto;
  gap:3rem;
  align-items:center;
}
.delivery .eyebrow{
  color:var(--terra);
}
.delivery .section-title em{
  color:var(--terra);
}
.delivery-lede{
  margin-top:1rem;
  max-width:34rem;
  color:var(--muted);
  font-family:var(--serif);
  font-size:1.15rem;
  font-style:italic;
  line-height:1.55;
}
.delivery .btn-solid{
  background:var(--terra);
  color:var(--paper);
}
.delivery .btn-solid:hover{
  background:var(--terra-soft);
  color:var(--paper);
  transform:translateY(-1px);
}

@media (max-width:760px){
  .delivery{ padding:4rem 0; }
  .delivery-inner{ grid-template-columns:1fr; }
  .delivery-btn{ justify-self:flex-start; }
}

/* ---------- Contact ---------- */
.contact{ padding:9rem 0; }
.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:5rem;
}
.contact-btn{
  margin-top:2rem;
}
.contact-info{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:2.5rem 3rem;
}
.info-block{
  border-top:1px solid var(--line);
  padding-top:1.2rem;
}
.info-label{
  display:block;
  font-size:.68rem;
  letter-spacing:.28em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--blue);
  margin-bottom:.7rem;
}
.info-block p{
  font-family:var(--serif);
  font-size:1.2rem;
  line-height:1.5;
  color:var(--ink);
}
.info-block a:hover{ color:var(--blue); }

@media (max-width:900px){
  .contact{ padding:5rem 0; }
  .contact-grid{ grid-template-columns:1fr; gap:3rem; }
  .contact-info{ grid-template-columns:1fr; gap:1.8rem; }
}

/* ---------- Footer ---------- */
.site-footer{
  background:var(--grey-cool);
  color:var(--grey-text);
  font-size:.84rem;
  padding-top:4rem;
}
.footer-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr 1fr;
  gap:3rem;
  padding-bottom:3.5rem;
  align-items:start;
}
.footer-brand .brand-mark{
  width:84px;
  height:84px;
}
.footer-label{
  display:block;
  font-size:.68rem;
  letter-spacing:.24em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--grey-ink);
  margin-bottom:.9rem;
}
.footer-col p{
  margin-bottom:.5rem;
  line-height:1.6;
}
.footer-col a:hover{ color:var(--blue); }

.footer-bottom{
  border-top:1px solid var(--grey-cool-2);
  padding:1.5rem 0;
}
.footer-bottom-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:1rem;
  font-size:.78rem;
  color:var(--grey-text);
}
.footer-links{ display:flex; gap:.6rem; align-items:center; }
.footer-links a:hover{ color:var(--blue); }
.dot{ opacity:.5; }

.footer-credit{
  letter-spacing:.02em;
}
.footer-credit a{
  color:var(--terra);
  font-weight:500;
  transition:color .25s ease;
  margin-left:.3rem;
}
.footer-credit a:hover{
  color:var(--blue);
}

@media (max-width:900px){
  .footer-grid{ grid-template-columns:1fr 1fr; gap:2.5rem 2rem; }
  .footer-brand{ grid-column:span 2; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; }
  .footer-brand{ grid-column:span 1; }
  .footer-bottom-inner{ flex-direction:column; align-items:flex-start; }
}

/* ---------- Events ---------- */
.events{
  padding:9rem 0;
  background:var(--paper-2);
  text-align:center;
}
.events-inner{
  max-width:42rem;
  margin:0 auto;
}
.events-lede{
  margin-top:1.6rem;
  font-family:var(--serif);
  font-size:clamp(1.15rem, 1.8vw, 1.45rem);
  line-height:1.55;
  font-style:italic;
  color:var(--ink);
}
.events-btn{
  margin-top:2.4rem;
}

@media (max-width:900px){
  .events{ padding:5rem 0; }
}

/* ---------- Modal ---------- */
.modal{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:flex-start;
  justify-content:center;
  padding:5vh 1rem;
  overflow-y:auto;
}
.modal.open{ display:flex; }
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(20,22,28,.55);
  backdrop-filter:blur(4px);
  -webkit-backdrop-filter:blur(4px);
  animation:fadeIn .3s ease;
}
@keyframes fadeIn{ from{ opacity:0; } to{ opacity:1; } }
.modal-panel{
  position:relative;
  background:var(--paper);
  width:100%;
  max-width:640px;
  border-radius:4px;
  padding:3rem clamp(1.5rem, 4vw, 3rem) 2.5rem;
  box-shadow:0 30px 80px -20px rgba(20,22,28,.4);
  animation:modalRise .4s cubic-bezier(.2,.7,.2,1);
}
@keyframes modalRise{
  from{ opacity:0; transform:translateY(20px); }
  to{ opacity:1; transform:translateY(0); }
}
.modal-close{
  position:absolute;
  top:1rem; right:1rem;
  width:40px; height:40px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  color:var(--muted);
  transition:all .25s ease;
}
.modal-close:hover{
  background:var(--soft);
  color:var(--ink);
}
.modal-title{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(1.6rem, 3vw, 2.2rem);
  line-height:1.15;
  letter-spacing:-.01em;
  color:var(--ink);
  margin-top:.8rem;
}
.modal-lede{
  margin-top:.9rem;
  color:var(--muted);
  font-size:.95rem;
  line-height:1.55;
}

/* ---------- Form ---------- */
.event-form{
  margin-top:2rem;
  display:flex;
  flex-direction:column;
  gap:1rem;
}
.form-row{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:1rem;
}
.form-row:has(> label:nth-child(3)){
  grid-template-columns:repeat(3, 1fr);
}
.event-form label{
  display:flex;
  flex-direction:column;
  gap:.4rem;
}
.event-form label span{
  font-size:.7rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--muted);
}
.event-form input,
.event-form select,
.event-form textarea{
  font-family:var(--sans);
  font-size:.95rem;
  color:var(--ink);
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:2px;
  padding:.75rem .9rem;
  transition:border-color .25s ease, box-shadow .25s ease;
  width:100%;
}
.event-form input:focus,
.event-form select:focus,
.event-form textarea:focus{
  outline:none;
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(29,58,161,.1);
}
.event-form textarea{
  resize:vertical;
  font-family:var(--sans);
}
.form-actions{
  margin-top:1rem;
  display:flex;
  justify-content:flex-end;
  gap:.7rem;
  flex-wrap:wrap;
}

@media (max-width:560px){
  .form-row,
  .form-row:has(> label:nth-child(3)){
    grid-template-columns:1fr;
  }
  .modal-panel{ padding:2.5rem 1.5rem 2rem; }
  .form-actions{ justify-content:stretch; }
  .form-actions .btn{ flex:1; }
}

body.modal-open{ overflow:hidden; }

/* ---------- Legal modal (Impressum) ---------- */
.modal-panel--text{
  max-width:720px;
}
.modal-body.legal{
  max-height:75vh;
  overflow-y:auto;
  padding-right:.5rem;
  margin-right:-.5rem;
}
.modal-body.legal::-webkit-scrollbar{
  width:6px;
}
.modal-body.legal::-webkit-scrollbar-thumb{
  background:var(--line);
  border-radius:3px;
}
.modal-body.legal::-webkit-scrollbar-thumb:hover{
  background:var(--muted-2);
}
.legal-block{
  margin-top:1.8rem;
}
.legal-block:first-of-type{
  margin-top:1.6rem;
  padding-top:1.6rem;
  border-top:1px solid var(--line);
}
.legal-label{
  font-family:var(--sans);
  font-size:.7rem;
  letter-spacing:.26em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--terra);
  margin-bottom:.6rem;
}
.legal-strong{
  font-family:var(--serif);
  font-size:1.3rem;
  font-weight:500;
  color:var(--ink);
  margin-bottom:.4rem;
}
.legal-block p{
  font-size:.92rem;
  line-height:1.65;
  color:var(--muted);
  margin-bottom:.7rem;
}
.legal-block p:last-child{
  margin-bottom:0;
}
.legal-block a{
  color:var(--blue);
  transition:color .25s ease;
}
.legal-block a:hover{
  color:var(--terra);
}
.legal-source{
  margin-top:2.2rem;
  padding-top:1.5rem;
  border-top:1px solid var(--line);
  font-size:.72rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--muted-2);
  text-align:center;
}

/* ---------- File upload ---------- */
.file-label .file-drop{
  position:relative;
  border:1.5px dashed var(--line);
  border-radius:2px;
  padding:1.2rem 1rem;
  background:var(--paper-2);
  text-align:center;
  cursor:pointer;
  transition:all .25s ease;
}
.file-label .file-drop:hover{
  border-color:var(--terra);
  background:#fff;
}
.file-label input[type="file"]{
  position:absolute;
  inset:0;
  opacity:0;
  cursor:pointer;
  width:100%;
  height:100%;
}
.file-hint{
  display:block;
  font-family:var(--sans);
  font-size:.82rem;
  color:var(--muted);
  letter-spacing:0;
  text-transform:none;
  font-weight:400;
}
.file-label .file-drop.has-file{
  border-style:solid;
  border-color:var(--terra);
  background:#faf3ed;
}
.file-label .file-drop.has-file .file-hint{
  color:var(--terra);
  font-weight:500;
}

/* ---------- Honeypot (hidden anti-spam field) ---------- */
.hp-field{
  position:absolute !important;
  left:-9999px !important;
  width:1px !important;
  height:1px !important;
  opacity:0 !important;
  pointer-events:none !important;
}

/* ---------- Form success message ---------- */
.form-success{
  margin-top:1.5rem;
  padding:1.2rem 1.4rem;
  background:#faf3ed;
  border:1px solid var(--terra);
  border-radius:2px;
  color:var(--terra);
  font-family:var(--serif);
  font-style:italic;
  font-size:1.1rem;
  text-align:center;
}

/* ---------- Cookie Banner ---------- */
.cookie-banner{
  position:fixed;
  left:1rem;
  right:1rem;
  bottom:1rem;
  z-index:150;
  background:var(--paper);
  border:1px solid var(--line);
  border-radius:6px;
  box-shadow:0 20px 60px -10px rgba(20,22,28,.18), 0 4px 12px -2px rgba(20,22,28,.06);
  padding:1.6rem clamp(1.2rem, 3vw, 2rem);
  max-width:1100px;
  margin:0 auto;
  opacity:0;
  transform:translateY(120%);
  pointer-events:none;
  transition:opacity .5s ease, transform .55s cubic-bezier(.2,.7,.2,1);
}
.cookie-banner.is-visible{
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.cookie-inner{
  display:grid;
  grid-template-columns:1fr auto;
  gap:1.8rem;
  align-items:center;
}
.cookie-title{
  font-family:var(--serif);
  font-size:1.25rem;
  font-weight:500;
  color:var(--ink);
  margin-bottom:.35rem;
}
.cookie-text p:last-child{
  font-size:.9rem;
  line-height:1.55;
  color:var(--muted);
  max-width:48rem;
}
.cookie-text a{
  color:var(--terra);
  text-decoration:underline;
  text-decoration-thickness:1px;
  text-underline-offset:2px;
  transition:color .25s ease;
}
.cookie-text a:hover{
  color:var(--blue);
}
.cookie-actions{
  display:flex;
  gap:.7rem;
  flex-shrink:0;
}
.cookie-btn-essential{
  font-size:.7rem;
  padding:.7rem 1.2rem;
}
.cookie-btn-accept{
  font-size:.7rem;
  padding:.7rem 1.5rem;
}

@media (max-width:760px){
  .cookie-banner{
    left:.75rem;
    right:.75rem;
    bottom:.75rem;
    padding:1.3rem 1.2rem;
  }
  .cookie-inner{
    grid-template-columns:1fr;
    gap:1.2rem;
  }
  .cookie-actions{
    flex-direction:column-reverse;
  }
  .cookie-btn-essential,
  .cookie-btn-accept{
    width:100%;
  }
}

/* ---------- Reveal-on-scroll ---------- */
.reveal{
  opacity:0;
  transform:translateY(24px);
  transition:opacity 1s ease, transform 1s ease;
}
.reveal.is-visible{
  opacity:1;
  transform:translateY(0);
}
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    animation-duration:.01ms !important;
    transition-duration:.01ms !important;
  }
}
