/* ============================================================
   Musikverein Wilfersdorf und Umgebung — Design tokens & components
   Black & white base, very subtle wine/navy uniform accents.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800&family=Source+Sans+3:ital,wght@0,400;0,500;0,600;1,400&family=IBM+Plex+Mono:wght@400;500&display=swap');

:root{
  --ink:    #17171a;   /* near-black, faintly cool */
  --paper:  #fbfbf8;   /* warm off-white */
  --panel:  #ffffff;
  --line:   #e6e5e0;   /* hairlines */
  --line-2: #d9d8d2;
  --muted:  #6e6e68;   /* secondary text */
  --faint:  #9a9a93;   /* tertiary / placeholders */
  /* uniform accents — equal L & C in oklch, hue apart */
  --wine:   oklch(0.43 0.115 19);   /* dark red  */
  --navy:   oklch(0.43 0.105 256);  /* dark blue */
  --wine-soft: oklch(0.43 0.115 19 / 0.10);
  --navy-soft: oklch(0.43 0.105 256 / 0.10);
}

*{ box-sizing:border-box; }
/* preflight is disabled (corePlugins.preflight:false) — re-establish Tailwind's
   default border so border-width utilities (border, border-t, border-l-2 …) render */
*,*::before,*::after{ border-width:0; border-style:solid; border-color:var(--line); }
html{ -webkit-text-size-adjust:100%; forced-color-adjust:none; }
:root{ forced-color-adjust:none; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:'Source Sans 3', system-ui, sans-serif;
  font-size:17px; line-height:1.6; -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
::selection{ background:var(--ink); color:var(--paper); }

.font-display{ font-family:'Archivo', sans-serif; }
.font-mono{ font-family:'IBM Plex Mono', ui-monospace, monospace; }

h1,h2,h3,h4{ font-family:'Archivo', sans-serif; font-weight:700; letter-spacing:-0.02em; line-height:1.05; margin:0; }
ul,ol{ list-style:none; margin:0; padding:0; }
button{ font:inherit; color:inherit; background:none; border:0; margin:0; padding:0; cursor:pointer; text-align:inherit; }
a{ color:inherit; text-decoration:none; }

/* ---- layout ---- */
.wrap{ width:100%; max-width:1200px; margin-inline:auto; padding-inline:28px; }
.wrap-wide{ width:100%; max-width:1400px; margin-inline:auto; padding-inline:28px; }
.hairline{ border:0; border-top:1px solid var(--line); margin:0; }

/* ---- eyebrow / kicker ---- */
.kicker{
  font-family:'IBM Plex Mono', monospace; font-size:11.5px; font-weight:500;
  letter-spacing:0.22em; text-transform:uppercase; color:var(--muted);
}
.kicker--wine{ color:var(--wine); }
.kicker--navy{ color:var(--navy); }

/* ---- links with subtle accent underline on hover ---- */
.link{ position:relative; }
.link::after{
  content:""; position:absolute; left:0; right:100%; bottom:-2px; height:1px;
  background:var(--wine); transition:right .28s cubic-bezier(.2,.7,.2,1);
}
.link:hover::after{ right:0; }

/* ---- nav ---- */
.navlink{
  font-size:14px; font-weight:600; letter-spacing:0.01em; color:var(--ink);
  padding:8px 2px; position:relative; transition:color .2s;
}
.navlink:hover{ color:#000; }
.navlink[aria-current="page"]::after,
.navlink.is-active::after{
  content:""; position:absolute; left:0; right:0; bottom:-19px; height:2px; background:var(--ink);
}

/* ---- buttons ---- */
.btn{
  display:inline-flex; align-items:center; gap:9px; font-weight:600; font-size:14px;
  padding:11px 20px; border:1px solid var(--ink); background:var(--ink); color:var(--paper);
  transition:.2s; cursor:pointer; letter-spacing:0.01em;
}
.btn:hover{ background:#000; transform:translateY(-1px); }
.btn--ghost{ background:transparent; color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:var(--paper); transform:translateY(-1px); }
.btn-sm{ padding:8px 14px; font-size:13px; }

/* ---- event category tags ---- */
.tag{
  display:inline-flex; align-items:center; gap:7px;
  font-family:'IBM Plex Mono', monospace; font-size:10.5px; font-weight:500;
  letter-spacing:0.14em; text-transform:uppercase; color:var(--muted);
}
.dot{ width:7px; height:7px; border-radius:50%; flex:none; }
.dot--wine{ background:var(--wine); }
.dot--navy{ background:var(--navy); }
.dot--ink{ background:var(--ink); }

/* ---- image placeholders (striped, labelled) ---- */
.ph{
  position:relative; overflow:hidden; background-color:#f1f0ec;
  background-image:repeating-linear-gradient(45deg,#eeede8 0 11px,#f5f4f0 11px 22px);
  display:flex; align-items:center; justify-content:center;
}
.ph::after{
  content:attr(data-ph); font-family:'IBM Plex Mono', monospace; font-size:11px;
  letter-spacing:0.16em; text-transform:uppercase; color:var(--faint);
  text-align:center; padding:0 16px; line-height:1.5;
}
.ph--dark{ background-color:#1b1b1e; background-image:repeating-linear-gradient(45deg,#202024 0 11px,#19191c 11px 22px); }
.ph--dark::after{ color:#6a6a70; }

/* poster aspect (A4 portrait) */
.aspect-a4{ aspect-ratio:1 / 1.414; }
.aspect-banner{ aspect-ratio:16 / 6.2; }
.aspect-4x3{ aspect-ratio:4 / 3; }
.aspect-3x2{ aspect-ratio:3 / 2; }

/* ---- divider with center mark ---- */
.rule-mark{ display:flex; align-items:center; gap:16px; color:var(--line-2); }
.rule-mark::before,.rule-mark::after{ content:""; height:1px; background:var(--line); flex:1; }

/* ---- cards ---- */
.card{ background:var(--panel); border:1px solid var(--line); }
.card-hover{ transition:transform .25s, box-shadow .25s, border-color .25s; }
.card-hover:hover{ transform:translateY(-3px); box-shadow:0 18px 40px -28px rgba(0,0,0,.45); border-color:var(--line-2); }

/* ---- utilities ---- */
.uppercase-wide{ text-transform:uppercase; letter-spacing:0.16em; }
.balance{ text-wrap:balance; }
.pretty{ text-wrap:pretty; }

/* ---- JS-toggled states (avoid relying on CDN JIT for dynamic classes) ---- */
.seg-btn{ transition:.18s; color:var(--muted); }
.seg-btn.is-on{ box-shadow:inset 0 0 0 2.2em var(--ink); color:var(--paper); }
.filter-btn{ transition:.18s; color:var(--muted); border:1px solid var(--line); background:transparent; }
.filter-btn:hover{ border-color:var(--line-2); color:var(--ink); }
.filter-btn.is-on{ box-shadow:inset 0 0 0 2.2em var(--ink); color:var(--paper); border-color:var(--ink); }

/* ---- lightbox ---- */
.lightbox{ position:fixed; inset:0; z-index:120; display:none; align-items:center; justify-content:center;
  background:rgba(0,0,0,.86); padding:24px; backdrop-filter:blur(3px); }
.lightbox.is-open{ display:flex; }
.lightbox__close{ position:absolute; top:18px; right:24px; color:rgba(255,255,255,.7); font-size:30px; line-height:1; background:none; border:0; cursor:pointer; }
.lightbox__close:hover{ color:#fff; }
.lightbox__cap{ font-family:'IBM Plex Mono',monospace; font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.6); margin-top:16px; text-align:center; }
.gv-nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:2; width:48px; height:48px;
  display:grid; place-items:center; font-size:30px; line-height:1; color:rgba(255,255,255,.7);
  border:1px solid rgba(255,255,255,.25); border-radius:50%; background:rgba(0,0,0,.25); cursor:pointer; }
.gv-nav:hover{ color:#fff; border-color:rgba(255,255,255,.6); }

/* keep review chrome out of the way visually */
[hidden]{ display:none !important; }
