/* ============================================================
   SG Neustadt 1485 — Modern Landing  (page styles)
   Heritage-modern: olive green + gold + black + warm white,
   Noto Serif display, Noto Sans UI. Depends on ../colors_and_type.css
   ============================================================ */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg-1);color:var(--ink-700);font-family:var(--font-serif);-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}
.u-sans{font-family:var(--font-sans)}

/* ---------- shared buttons ---------- */
.btn{font-family:var(--font-sans);font-size:14px;font-weight:600;border-radius:4px;padding:13px 24px;cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:8px;text-decoration:none;transition:background .16s,color .16s,border-color .16s,transform .12s;white-space:nowrap;line-height:1}
.btn:active{transform:translateY(1px)}
.btn i{width:17px;height:17px}
.btn-gold{background:var(--gold-500);color:#2c2407}
.btn-gold:hover{background:var(--gold-300)}
.btn-green{background:var(--green-600);color:#fff}
.btn-green:hover{background:var(--green-700)}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.45)}
.btn-ghost:hover{background:rgba(255,255,255,.12)}
.btn-outline{background:transparent;color:var(--green-700);border-color:var(--border-strong)}
.btn-outline:hover{background:var(--green-100);border-color:var(--green-400)}

/* ---------- section scaffolding ---------- */
.section{padding:clamp(56px,9vh,108px) 0}
.section.tight{padding:clamp(40px,6vh,72px) 0}
.eyebrow{font-family:var(--font-sans);font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-700);display:inline-flex;align-items:center;gap:9px}
.eyebrow::before{content:"";width:22px;height:1px;background:var(--gold-600)}
.section-title{font-family:var(--font-serif);font-weight:700;font-size:clamp(1.9rem,3.6vw,2.9rem);line-height:1.1;color:var(--ink-900);margin:14px 0 0;letter-spacing:-.01em}
.section-intro{font-size:clamp(1rem,1.4vw,1.18rem);line-height:1.65;color:var(--ink-500);max-width:560px;margin:14px 0 0}
.head-row{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:42px}

/* ---------- topbar / nav / burger styles live in modern/nav.css ---------- */

/* ---------- stats band (dark) ---------- */
.stats{background:linear-gradient(180deg,#11160f,#161c12);color:#fff;border-top:1px solid rgba(226,195,65,.18);border-bottom:1px solid rgba(226,195,65,.18)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
@media(max-width:680px){.stats .grid{grid-template-columns:1fr 1fr}}
.stat{padding:38px 24px;text-align:center;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:0}
@media(max-width:680px){.stat:nth-child(2){border-right:0}.stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(255,255,255,.08)}}
.stat .num{font-family:var(--font-serif);font-weight:700;font-size:clamp(2.2rem,4vw,3.1rem);line-height:1;color:var(--gold-title)}
.stat .lab{font-family:var(--font-sans);font-size:12.5px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.66);margin-top:10px}

/* ---------- news ---------- */
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:860px){.news-grid{grid-template-columns:1fr}}
.news-card{background:var(--bg-1);border:1px solid var(--border);border-radius:6px;overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .18s,transform .18s;text-decoration:none}
.news-card:hover{box-shadow:var(--shadow-md);transform:translateY(-3px)}
.news-card .ph{height:172px;overflow:hidden;background:var(--bg-3)}
.news-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-card:hover .ph img{transform:scale(1.04)}
.news-card .nb{padding:20px 22px 24px;flex:1;display:flex;flex-direction:column}
.news-card .meta{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700);display:flex;align-items:center;gap:8px}
.news-card h3{font-family:var(--font-serif);font-weight:700;font-size:1.3rem;color:var(--ink-900);margin:11px 0 9px;line-height:1.22}
.news-card p{font-size:.96rem;line-height:1.6;color:var(--ink-500);margin:0}
.news-card .more{font-family:var(--font-sans);font-size:13px;font-weight:700;color:var(--green-700);margin-top:16px;display:inline-flex;align-items:center;gap:6px}

/* ---------- disciplines ---------- */
.disc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:860px){.disc-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.disc-grid{grid-template-columns:1fr}}
.disc{background:var(--paper-warm);border:1px solid var(--border);border-radius:6px;padding:24px 22px;transition:border-color .18s,box-shadow .18s}
.disc:hover{border-color:var(--green-400);box-shadow:var(--shadow-sm)}
.disc .ic{width:46px;height:46px;border-radius:8px;background:var(--green-700);color:var(--gold-title);display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.disc .ic i{width:24px;height:24px}
.disc h3{font-family:var(--font-serif);font-weight:700;font-size:1.22rem;color:var(--ink-900);margin:0 0 4px}
.disc .d-meta{font-family:var(--font-sans);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-700);margin-bottom:9px}
.disc p{font-size:.92rem;line-height:1.55;color:var(--ink-500);margin:0}

/* ---------- schützenhaus feature ---------- */
.feature{background:var(--bg-2)}
.feat-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(32px,5vw,72px);align-items:center}
@media(max-width:860px){.feat-grid{grid-template-columns:1fr}}
.feat-media{position:relative;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-lg)}
.feat-media img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/3}
.feat-media .badge{position:absolute;left:18px;bottom:18px;background:rgba(17,22,15,.86);color:#fff;font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.04em;padding:9px 14px;border-radius:5px;backdrop-filter:blur(4px);border:1px solid rgba(226,195,65,.3)}
.lane-list{margin:26px 0 0;padding:0;list-style:none;display:grid;gap:2px}
.lane{display:flex;align-items:baseline;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.lane .n{font-family:var(--font-serif);font-weight:700;font-size:1.5rem;color:var(--green-700);min-width:54px;font-variant-numeric:tabular-nums}
.lane .t{font-family:var(--font-sans);font-size:.96rem;color:var(--ink-700);font-weight:600}
.lane .s{font-family:var(--font-sans);font-size:.82rem;color:var(--ink-400);margin-left:auto}

/* ---------- gallery ---------- */
.gal{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:170px;gap:12px}
@media(max-width:860px){.gal{grid-template-columns:repeat(2,1fr)}}
.gal a{position:relative;overflow:hidden;border-radius:6px;background:var(--bg-3)}
.gal a img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.gal a:hover img{transform:scale(1.05)}
.gal a.wide{grid-column:span 2}
.gal a.tall{grid-row:span 2}
.gal a .cap{position:absolute;left:0;right:0;bottom:0;padding:22px 14px 10px;background:linear-gradient(transparent,rgba(17,22,15,.82));color:#fff;font-family:var(--font-sans);font-size:12px;font-weight:600;opacity:0;transition:opacity .25s}
.gal a:hover .cap{opacity:1}

/* ---------- events ---------- */
.ev-list{display:grid;gap:0;border-top:1px solid var(--border)}
.ev-row{display:grid;grid-template-columns:96px 1fr auto;gap:22px;align-items:center;padding:22px 6px;border-bottom:1px solid var(--border);transition:background .15s}
.ev-row:hover{background:var(--paper-warm)}
@media(max-width:560px){.ev-row{grid-template-columns:72px 1fr}}
.ev-date{text-align:center;font-family:var(--font-sans)}
.ev-date .d{font-family:var(--font-serif);font-weight:700;font-size:2rem;line-height:.9;color:var(--green-700)}
.ev-date .m{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-700);margin-top:6px}
.ev-row h3{font-family:var(--font-serif);font-weight:700;font-size:1.28rem;color:var(--ink-900);margin:0 0 4px}
.ev-row p{font-family:var(--font-sans);font-size:.9rem;color:var(--ink-500);margin:0}
.ev-row .tag{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;background:var(--green-100);color:var(--green-800)}
@media(max-width:560px){.ev-row .tag{display:none}}

/* ---------- join / contact ---------- */
.join{background:linear-gradient(160deg,#16201a,#10160f);color:#fff;border-radius:0}
.join-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px)}
@media(max-width:860px){.join-grid{grid-template-columns:1fr}}
.join h2{font-family:var(--font-serif);font-weight:700;font-size:clamp(2rem,3.6vw,3rem);line-height:1.08;margin:14px 0 0;color:#fff}
.join .eyebrow{color:var(--gold-title)}
.join .eyebrow::before{background:var(--gold-500)}
.join p.lead{font-size:1.08rem;line-height:1.7;color:#cfd6c8;margin:18px 0 0;max-width:440px}
.hours-card{background:rgba(255,255,255,.05);border:1px solid rgba(226,195,65,.22);border-radius:8px;padding:22px 24px;margin-top:28px}
.hours-card .h-title{font-family:var(--font-sans);font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-title);margin-bottom:12px;display:flex;align-items:center;gap:8px}
.hours-card .h-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.08);font-size:.98rem}
.hours-card .h-row:last-child{border-bottom:0}
.hours-card .h-row .day{font-weight:600}
.hours-card .h-row .tm{color:var(--gold-title);font-variant-numeric:tabular-nums}
.form{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.12);border-radius:10px;padding:28px}
.form .fl{margin-bottom:16px}
.form label{display:block;font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.02em;color:#cfd6c8;margin-bottom:6px}
.form input,.form select,.form textarea{width:100%;font-family:var(--font-serif);font-size:15px;color:#fff;background:rgba(0,0,0,.28);border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:11px 13px;outline:none;transition:border-color .15s,box-shadow .15s}
.form input::placeholder,.form textarea::placeholder{color:rgba(255,255,255,.4)}
.form input:focus,.form select:focus,.form textarea:focus{border-color:var(--gold-500);box-shadow:0 0 0 3px rgba(226,195,65,.22)}
.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:480px){.form .row2{grid-template-columns:1fr}}
.form .ok{text-align:center;padding:14px 0}
.form .ok .ring{width:58px;height:58px;border-radius:50%;background:rgba(82,162,64,.18);color:var(--gold-title);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.form .ok .ring i{width:28px;height:28px}
.form .ok h3{font-family:var(--font-serif);font-weight:700;font-size:1.4rem;margin:0 0 6px;color:#fff}
.form .ok p{font-size:.95rem;color:#cfd6c8;margin:0}

/* ---------- footer ---------- */
.footer{background:#0b0e08;color:#9a978d}
.footer .top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:32px;padding:56px 0 40px}
.footer .top>*{min-width:0}
@media(max-width:760px){.footer .top{grid-template-columns:1fr 1fr}}
.footer .about .fbrand{display:flex;align-items:center;gap:12px;margin-bottom:16px}
@media(max-width:950px){.footer .about .fbrand{flex-direction:column;align-items:flex-start}}
.footer .about .fbrand img{width:46px;height:46px;border-radius:50%;box-shadow:0 0 0 1px rgba(226,195,65,.4)}
.footer .about .fbrand .n{font-family:var(--font-serif);font-weight:700;font-size:18px;color:#fff;line-height:1.1;min-width:0;overflow-wrap:break-word;hyphens:auto}
.footer .about p{font-size:.92rem;line-height:1.65;max-width:300px;margin:0}
.footer h5{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-title);margin:0 0 14px}
.footer a.fl{display:block;color:#b7b5ad;text-decoration:none;font-size:.93rem;padding:5px 0;transition:color .15s}
.footer a.fl:hover{color:#fff}
.footer .bar{border-top:1px solid rgba(255,255,255,.08);padding:18px 0;font-family:var(--font-sans);font-size:12px;display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}

/* ---------- reveal on scroll (transform-only; safe if frozen) ---------- */
.reveal{transform:translateY(26px);opacity:.999;transition:transform .7s cubic-bezier(.2,.7,.2,1),opacity .7s}
.reveal.in{transform:none}
@media(prefers-reduced-motion:reduce){.reveal{transition:none;transform:none}}
