/* Self-hosted fonts (OFL 1.1) */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('fonts/inter-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 600;
  font-display: swap;
  src: url('fonts/inter-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('fonts/oswald-latin-ext.woff2') format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
  font-family: 'Oswald';
  font-style: normal;
  font-weight: 400 700;
  font-display: swap;
  src: url('fonts/oswald-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}

:root {
  --ink:       #0d0d0d;
  --page:      #f5f5f5;
  --paper:     #ffffff;
  --concrete:  #6b6b67;
  --hair:      #e3e3e0;
  --light:     #f5f5f5;
  --signal:    #4caf50;
  --signal-ink:#3c8e40;
  --display:   "Oswald", system-ui, sans-serif;
  --body:      "Inter", system-ui, sans-serif;
  --maxw:      1080px;
  --gap:       clamp(1rem, 4vw, 2.5rem);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }
body { margin: 0; background: var(--page); color: var(--ink); font-family: var(--body); font-size: 1.0625rem; line-height: 1.6; }
.wrap { width: min(var(--maxw), 100% - 2 * var(--gap)); margin-inline: auto; }
a { color: var(--ink); text-decoration-thickness: 1px; text-underline-offset: 3px; }
a:hover { color: var(--signal-ink); }
img { max-width: 100%; display: block; }
.skip { position: absolute; left: -999px; top: 0; background: var(--ink); color: var(--light); padding: .6rem 1rem; z-index: 100; }
.skip:focus { left: 0; }
:focus-visible { outline: 3px solid var(--signal); outline-offset: 2px; }

/* brand mark */
.brand-mark { display: inline-block; width: 46px; height: 46px; flex: 0 0 auto; }
.brand-mark.small { width: 26px; height: 26px; }

/* header */
.site-header { background: var(--ink); color: var(--light); position: sticky; top: 0; z-index: 30; border-bottom: 1px solid #000; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; padding-block: .7rem; }
.brand { display: flex; align-items: center; gap: .7rem; color: var(--light); text-decoration: none; }
.brand-text { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: .82rem; line-height: .96; letter-spacing: .06em; }
.site-nav { display: flex; align-items: center; gap: clamp(.8rem, 2.5vw, 1.8rem); flex-wrap: wrap; }
.site-nav a { color: var(--light); text-decoration: none; font-family: var(--display); text-transform: uppercase; letter-spacing: .08em; font-size: .82rem; font-weight: 600; padding: .2rem 0; border-bottom: 2px solid transparent; white-space: nowrap; }
.site-nav a:hover, .site-nav a[aria-current="page"] { border-bottom-color: var(--signal); color: #fff; }
.langswitch { display: inline-flex; gap: .4rem; font-family: var(--display); font-size: .8rem; }
.langswitch a { border-bottom: none; padding: 0; color: #b9b9b4; }
.langswitch a[aria-current] { color: var(--signal); }

/* hero */
.hero {
  background:
    linear-gradient(180deg, rgba(13,13,13,.52), rgba(13,13,13,.80)),
    var(--hero-img, #1a1a1a) center / cover no-repeat;
  color: #fff;
  padding-block: clamp(4rem, 12vw, 8rem);
  border-bottom: 6px solid var(--signal);
}
.hero-kicker { font-family: var(--display); text-transform: uppercase; letter-spacing: .26em; font-size: .8rem; color: #fff; display: inline-flex; gap: .6rem; align-items: center; margin: 0 0 1rem; }
.hero-kicker::before { content: ""; width: 30px; height: 1px; background: var(--signal); display: inline-block; }
.hero h1 { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(2.4rem, 7vw, 5rem); line-height: .95; letter-spacing: .005em; margin: 0 0 1.2rem; max-width: 16ch; }
.hero h1 .accent { color: var(--signal); }
.hero-lead { font-size: clamp(1.05rem, 2.2vw, 1.3rem); max-width: 46ch; color: #e9e7e0; margin: 0 0 2rem; }
.hero-cta { display: flex; flex-wrap: wrap; gap: .8rem; }

/* buttons */
.btn { font-family: var(--display); text-transform: uppercase; letter-spacing: .08em; font-weight: 600; font-size: .95rem; display: inline-flex; align-items: center; gap: .5rem; padding: .85rem 1.4rem; border: 2px solid currentColor; cursor: pointer; text-decoration: none; background: transparent; transition: transform .08s ease, background .15s ease, color .15s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--signal); border-color: var(--signal); color: #06210b; }
.btn-primary:hover { background: var(--signal-ink); border-color: var(--signal-ink); color: #fff; }
.btn-ghost { color: #fff; }
.btn-ghost:hover { background: #fff; color: var(--ink); }
.btn-dark { color: var(--ink); }
.btn-dark:hover { background: var(--ink); color: var(--light); }

/* sections */
.section { padding-block: clamp(3rem, 8vw, 5.5rem); }
.section + .section { border-top: 1px solid var(--hair); }
.section-kicker { font-family: var(--display); text-transform: uppercase; letter-spacing: .2em; font-size: .78rem; color: var(--concrete); margin: 0 0 .8rem; }
.section h2 { font-family: var(--display); text-transform: uppercase; font-weight: 700; font-size: clamp(1.8rem, 4.5vw, 2.8rem); line-height: 1; letter-spacing: .01em; margin: 0 0 1.4rem; }
.lede { font-size: 1.15rem; max-width: 60ch; }
.about-body { max-width: 62ch; font-size: 1.08rem; color: #2c2c2a; }

/* event card */
.event { display: grid; grid-template-columns: 1fr; gap: 1.5rem; }
@media (min-width: 760px) { .event { grid-template-columns: 1.1fr 1fr; align-items: start; } }
.event-card { background: var(--paper); border: 2px solid var(--ink); box-shadow: 10px 10px 0 var(--ink); padding: clamp(1.4rem, 3vw, 2rem); }
.event-card .when { font-family: var(--display); font-weight: 700; text-transform: uppercase; font-size: clamp(1.1rem, 2.6vw, 1.7rem); line-height: 1.1; letter-spacing: .01em; margin: 0 0 1rem; }
.event-card .when.event-not-found { font-size: 1rem; color: var(--concrete); font-weight: 400; }
.event-row { display: flex; gap: .8rem; padding: .7rem 0; border-top: 1px solid var(--hair); }
.event-row:first-of-type { border-top: none; }
.event-row .label { font-family: var(--display); text-transform: uppercase; letter-spacing: .1em; font-size: .72rem; color: var(--concrete); flex: 0 0 6.5rem; padding-top: .15rem; }
.event-row .val { font-weight: 500; }
.event-flag { display: inline-block; background: var(--signal); color: #06210b; font-family: var(--display); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; padding: .25rem .6rem; margin-bottom: 1rem; }
.event-note { font-size: .82rem; color: var(--concrete); margin-top: .8rem; }
.event-note a { color: var(--signal-ink); }
.event-aside .lede { margin-bottom: 1.4rem; }

/* join / form */
.join { background: var(--ink); color: var(--light); }
.join h2 { color: var(--light); }
.join .section-kicker { color: #b9b9b4; }
.join .lede { color: #dcdcd6; }
.form-grid { display: grid; gap: 1.1rem; max-width: 34rem; margin-top: 1.8rem; }
.field label { display: block; font-family: var(--display); text-transform: uppercase; letter-spacing: .1em; font-size: .76rem; margin-bottom: .35rem; color: #cdcdc7; }
.field .req { color: var(--signal); }
.field input, .field textarea { width: 100%; background: #161616; border: 1px solid #38382f; color: var(--light); font: inherit; padding: .8rem .9rem; border-radius: 0; }
.field input::placeholder, .field textarea::placeholder { color: #6f6f68; }
.field input:focus, .field textarea:focus { border-color: var(--signal); outline: none; }
.field textarea { min-height: 7rem; resize: vertical; }
.turnstile-ph { border: 1px dashed #38382f; background: #161616; color: #b9b9b4; padding: 1rem; font-size: .82rem; display: flex; align-items: center; gap: .7rem; }
.turnstile-ph .box { width: 22px; height: 22px; border: 2px solid var(--signal); flex: 0 0 auto; }
.form-note { font-size: .8rem; color: #b9b9b4; margin: 0; }

/* form feedback */
.form-feedback { padding: .9rem 1.1rem; margin-bottom: .5rem; border-left: 4px solid; font-size: .95rem; }
.join .form-feedback.success { border-color: var(--signal); background: rgba(76,175,80,.12); color: #7ed080; }
.join .form-feedback.error   { border-color: #e55; background: rgba(200,50,50,.12); color: #e88; }

/* go-vegan resources */
.gv-grid { display: grid; gap: clamp(1.2rem, 3vw, 2rem); }
@media (min-width: 720px) { .gv-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.gv-block { background: var(--paper); border: 2px solid var(--ink); padding: 1.4rem 1.5rem; }
.gv-block h3 { font-family: var(--display); text-transform: uppercase; font-weight: 700; font-size: 1.15rem; letter-spacing: .04em; margin: 0 0 1rem; display: flex; align-items: center; gap: .6rem; }
.gv-block h3 .dot { width: 12px; height: 12px; background: var(--signal); flex: 0 0 auto; }
.gv-list { list-style: none; margin: 0; padding: 0; }
.gv-list li { padding: .85rem 0; border-top: 1px solid var(--hair); }
.gv-list li:first-child { border-top: none; }
.gv-line { display: flex; align-items: baseline; gap: .6rem; flex-wrap: wrap; }
.gv-name { font-weight: 600; text-decoration: none; color: var(--ink); }
a.gv-name:hover { color: var(--signal-ink); }
.gv-host { font-size: .78rem; color: var(--concrete); }
.gv-desc { margin: .25rem 0 .4rem; font-size: .92rem; color: #494945; }
.gv-ext { font-size: .76rem; font-family: var(--display); text-transform: uppercase; letter-spacing: .08em; color: var(--signal-ink); text-decoration: none; }
.gv-ext:hover { text-decoration: underline; }
.gv-flyer { margin-top: 2rem; font-size: .95rem; color: var(--concrete); display: flex; gap: .7rem; align-items: center; }
.gv-flyer .brand-mark.small { color: var(--ink); }

/* next-square banner */
.next-square-bar { background: #161616; border-bottom: 3px solid var(--signal); padding: .6rem 0; }
.next-square-inner { display: flex; align-items: center; gap: .5rem 1.2rem; flex-wrap: wrap; }
.ns-label { font-family: var(--display); text-transform: uppercase; letter-spacing: .14em; font-size: .7rem; font-weight: 700; color: var(--signal); white-space: nowrap; flex-shrink: 0; }
.ns-when { font-family: var(--display); font-weight: 600; font-size: .92rem; color: #fff; white-space: nowrap; }
.ns-where { font-size: .88rem; color: #b9b9b4; }
@media (max-width: 560px) { .ns-when, .ns-where { font-size: .85rem; } }

/* dominion page */
.dominion-layout { display: grid; gap: clamp(1.5rem, 4vw, 2.5rem); }
@media (min-width: 760px) { .dominion-layout { grid-template-columns: 3fr 2fr; align-items: start; } }
.dominion-video-col { border: 3px solid var(--ink); box-shadow: 7px 7px 0 var(--signal); }
.dominion-player { width: 100%; display: block; background: #111; aspect-ratio: 16/9; }
.dominion-text-col .section-kicker { margin-top: 0; }
.dominion-text-col h2 { font-size: clamp(1.3rem, 3vw, 1.8rem); margin-top: .4rem; }
.dominion-intro { font-size: .92rem; color: #2c2c2a; margin: 0; line-height: 1.6; }
.video-coming-soon { background: #1a1a1a; aspect-ratio: 16/9; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: .5rem; color: #555; font-family: var(--display); text-transform: uppercase; letter-spacing: .12em; font-size: .72rem; }
.video-coming-soon .mark { width: 28px; height: 28px; border: 2px solid #333; position: relative; }
.video-coming-soon .mark::after { content: ""; position: absolute; inset: 5px; border: 1px solid #333; opacity: .5; }

/* prose pages (impressum, datenschutz) */
.prose { max-width: 68ch; }
.prose h2 { font-family: var(--display); text-transform: uppercase; font-weight: 700; font-size: clamp(1.3rem, 3vw, 1.8rem); margin: 2.4rem 0 .7rem; line-height: 1.1; }
.prose h2:first-child { margin-top: 0; }
.prose h3 { font-family: var(--display); text-transform: uppercase; font-weight: 600; font-size: .92rem; letter-spacing: .08em; margin: 1.8rem 0 .4rem; color: var(--concrete); }
.prose p { margin: 0 0 .9rem; color: #2c2c2a; }
.prose a { color: var(--signal-ink); }
.prose ul { margin: .4rem 0 1rem 1.2rem; color: #2c2c2a; }
.prose li { margin-bottom: .35rem; }
.placeholder { background: #fff9e6; border: 1px dashed #d4a017; padding: .1rem .4rem; font-size: .88em; color: #7a5000; border-radius: 2px; }

/* footer */
.site-footer { background: var(--ink); color: var(--light); padding-block: 2rem; }
.footer-inner { display: flex; justify-content: center; }
.footer-meta { font-size: .9rem; color: #b9b9b4; margin: 0; text-align: center; }
.footer-meta a { color: #dcdcd6; }
.footer-meta a:hover { color: var(--signal); }

@media (prefers-reduced-motion: reduce) { * { animation: none !important; transition: none !important; scroll-behavior: auto !important; } }
@media (max-width: 560px) {
  .header-inner { flex-direction: column; align-items: flex-start; gap: .6rem; }
  .site-nav { gap: .8rem 1.2rem; }
  .event-card { box-shadow: 6px 6px 0 var(--ink); }
}
