/* ============================================================
   SG Neustadt 1485 — Subpage styles
   Reuses tokens + components from colors_and_type.css & landing.css.
   Topbar / nav / burger styles live in modern/nav.css.
   ============================================================ */
body{background:var(--bg-1)}
main.page{min-height:60vh}


/* ---------- page header band ---------- */
.subhero{position:relative;background:linear-gradient(160deg,#16201a,#10160f);color:#fff;overflow:hidden}
.subhero::after{content:"";position:absolute;right:-60px;top:-40px;width:320px;height:320px;border-radius:50%;
  background:radial-gradient(circle at 38% 34%,rgba(226,195,65,.16),transparent 62%);pointer-events:none}
.subhero .wrap{padding:54px 28px 48px;position:relative;z-index:2}
.crumb{font-family:var(--font-sans);font-size:12px;font-weight:600;letter-spacing:.04em;color:rgba(255,255,255,.6);margin-bottom:16px}
.crumb a{color:rgba(255,255,255,.6);text-decoration:none}
.crumb a:hover{color:var(--gold-title)}
.subhero .eyebrow{color:var(--gold-title)}
.subhero .eyebrow::before{background:var(--gold-500)}
.subhero h1{font-family:var(--font-serif);font-weight:700;font-size:clamp(2.1rem,4.4vw,3.4rem);line-height:1.08;letter-spacing:-.01em;margin:14px 0 0;color:#fff}
.subhero p.sublead{font-family:var(--font-serif);font-size:clamp(1.05rem,1.5vw,1.25rem);line-height:1.6;color:#cfd6c8;max-width:620px;margin:16px 0 0}

/* ---------- prose ---------- */
.prose{max-width:760px}
.prose.wide{max-width:980px}
.prose h2{font-family:var(--font-serif);font-weight:700;font-size:1.7rem;color:var(--ink-900);margin:36px 0 12px;line-height:1.2}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--font-serif);font-weight:700;font-size:1.25rem;color:var(--ink-900);margin:26px 0 8px}
.prose p{font-family:var(--font-serif);font-size:1.05rem;line-height:1.75;color:var(--ink-700);margin:0 0 16px}
.prose ul,.prose ol{font-family:var(--font-serif);font-size:1.05rem;line-height:1.7;color:var(--ink-700);padding-left:22px;margin:0 0 18px}
.prose li{margin:0 0 8px}
.prose a{color:var(--link);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--ink-900)}
.lead-quote{border-left:3px solid var(--gold-500);background:var(--paper-warm);padding:18px 24px;border-radius:0 6px 6px 0;margin:0 0 28px}
.lead-quote p{font-style:italic;color:var(--ink-700);margin:0}

/* two-column layout for content + aside */
.split{display:grid;grid-template-columns:1fr 320px;gap:48px;align-items:start}
@media(max-width:880px){.split{grid-template-columns:1fr}}
.aside-card{background:var(--paper-warm);border:1px solid var(--border);border-radius:8px;padding:22px 24px;position:sticky;top:88px}
body[data-page="termine"] .aside-card,
body[data-page="vereinsgeschichte"] .aside-card{position:static;top:auto}
.aside-card h4{font-family:var(--font-sans);font-size:12px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--gold-700);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.aside-card .h-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-bottom:1px solid var(--border);font-family:var(--font-serif);font-size:1rem}
.aside-card .h-row:last-child{border-bottom:0}
.aside-card .h-row .tm{color:var(--green-700);font-weight:600;font-variant-numeric:tabular-nums;white-space:nowrap}

/* ---------- Mannschaften (Disziplinen) ---------- */
.disc-block{margin-bottom:40px}
.disc-block:last-child{margin-bottom:0}
.disc-block-head{display:flex;align-items:center;gap:14px;margin:0 0 18px}
.disc-block-head .ic{width:44px;height:44px;border-radius:8px;flex:none;background:var(--green-700);color:var(--gold-title,#e2c341);display:flex;align-items:center;justify-content:center}
.disc-block-head .ic i{width:22px;height:22px}
.disc-block-head h3{font-family:var(--font-serif);font-weight:700;font-size:1.5rem;color:var(--ink-900);margin:0}
.disc-block-head .meta{font-family:var(--font-sans);font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-700);margin-top:2px}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
@media(max-width:680px){.team-grid{grid-template-columns:1fr}}
.team{background:var(--bg-1);border:1px solid var(--border);border-radius:10px;padding:20px 22px;box-shadow:var(--shadow-xs)}
.team .t-tag{display:inline-block;font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--green-800);background:var(--green-100);padding:4px 10px;border-radius:999px;margin-bottom:12px}
.team h4{font-family:var(--font-serif);font-weight:700;font-size:1.2rem;color:var(--ink-900);margin:0 0 10px}
.team .t-row{display:flex;justify-content:space-between;gap:14px;padding:8px 0;border-top:1px solid var(--border);font-family:var(--font-sans);font-size:.88rem}
.team .t-row .k{color:var(--ink-400)}
.team .t-row .v{color:var(--ink-700);font-weight:600;text-align:right}

/* ---------- board / vorstand ---------- */
.board-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
@media(max-width:820px){.board-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.board-grid{grid-template-columns:1fr}}
.board{background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:22px;text-align:center}
.board .av{width:72px;height:72px;border-radius:50%;margin:0 auto 14px;background:radial-gradient(circle at 38% 32%,var(--green-500),var(--green-800));color:var(--gold-title);display:flex;align-items:center;justify-content:center;font-family:var(--font-serif);font-weight:700;font-size:24px;box-shadow:inset 0 0 0 1px rgba(226,195,65,.5)}
.board .role{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700)}
.board h3{font-family:var(--font-serif);font-weight:700;font-size:1.22rem;color:var(--ink-900);margin:6px 0 2px}
.board p{font-family:var(--font-sans);font-size:.86rem;color:var(--ink-400);margin:0}

/* ---------- dues table ---------- */
.dues{width:100%;border-collapse:collapse;font-family:var(--font-serif);background:var(--bg-1);border:1px solid var(--border);border-radius:8px;overflow:hidden}
.dues th,.dues td{text-align:left;padding:15px 20px;border-bottom:1px solid var(--border)}
.dues thead th{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold-700);background:var(--paper-warm)}
.dues td{font-size:1.05rem;color:var(--ink-700)}
.dues tr:last-child td{border-bottom:0}
.dues td.amt{text-align:right;font-weight:700;color:var(--green-700);font-variant-numeric:tabular-nums;white-space:nowrap}

/* ---------- download list (formulare) ---------- */
.dl-list{display:grid;gap:12px}
.dl{display:flex;align-items:center;gap:16px;background:var(--bg-1);border:1px solid var(--border);border-radius:8px;padding:16px 20px;text-decoration:none;transition:border-color .16s,box-shadow .16s,transform .16s}
.dl:hover{border-color:var(--green-400);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.dl .ic{width:42px;height:42px;border-radius:7px;flex:none;background:var(--green-100);color:var(--green-700);display:flex;align-items:center;justify-content:center}
.dl .ic i{width:21px;height:21px}
.dl .dt{flex:1}
.dl .dt b{display:block;font-family:var(--font-serif);font-size:1.08rem;color:var(--ink-900);font-weight:700}
.dl .dt span{font-family:var(--font-sans);font-size:.82rem;color:var(--ink-400)}
.dl .go{font-family:var(--font-sans);font-size:12px;font-weight:700;color:var(--green-700);display:flex;align-items:center;gap:6px}
.dl .go i{width:16px;height:16px}

/* ---------- contact ---------- */
.map{width:100%;aspect-ratio:16/10;border-radius:10px;overflow:hidden;border:1px solid var(--border);background:
  repeating-linear-gradient(0deg,#e9ecdf 0 22px,#eef1e6 22px 44px),
  repeating-linear-gradient(90deg,rgba(82,162,64,.06) 0 60px,transparent 60px 120px);position:relative;display:flex;align-items:center;justify-content:center}
.map .pin{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--green-700)}
.map .pin i{width:40px;height:40px}
.map .pin span{font-family:var(--font-sans);font-size:13px;font-weight:700;background:#fff;border:1px solid var(--border);padding:6px 12px;border-radius:999px;color:var(--ink-700)}
.info-row{display:flex;align-items:flex-start;gap:14px;padding:16px 0;border-bottom:1px solid var(--border)}
.info-row:last-child{border-bottom:0}
.info-row .ic{width:38px;height:38px;border-radius:7px;flex:none;background:var(--green-100);color:var(--green-700);display:flex;align-items:center;justify-content:center}
.info-row .ic i{width:19px;height:19px}
.info-row .t b{font-family:var(--font-serif);font-size:1.05rem;color:var(--ink-900);display:block}
.info-row .t span{font-family:var(--font-serif);font-size:1rem;color:var(--ink-500);line-height:1.5}

/* ---------- login ---------- */
.login-wrap{max-width:440px;margin:0 auto}
.login-card{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-md);padding:34px;text-align:center}
.login-card .crest{width:66px;height:66px;border-radius:50%;margin:0 auto 16px;box-shadow:0 0 0 1px rgba(226,195,65,.5)}
.login-card h2{font-family:var(--font-serif);font-weight:700;font-size:1.6rem;color:var(--ink-900);margin:0 0 6px}
.login-card p.sub{font-family:var(--font-sans);font-size:.9rem;color:var(--ink-400);margin:0 0 24px}
.login-card .fl{margin-bottom:14px;text-align:left}
.login-card label{display:block;font-family:var(--font-sans);font-size:12px;font-weight:600;color:var(--ink-500);margin-bottom:6px}
.login-card input{width:100%;font-family:var(--font-serif);font-size:15px;color:var(--ink-900);background:#fff;border:1px solid var(--border-strong);border-radius:7px;padding:11px 13px;outline:none;box-sizing:border-box}
.login-card input:focus{border-color:var(--green-500);box-shadow:var(--ring)}
.login-card .row-between{display:flex;align-items:center;justify-content:space-between;font-family:var(--font-sans);font-size:13px;margin:4px 0 18px}
.login-card .row-between a{color:var(--green-700);text-decoration:none}
.login-note{font-family:var(--font-sans);font-size:12px;color:var(--ink-400);margin-top:18px}

/* generic note callout */
.note{background:var(--paper-warm);border:1px solid var(--border);border-left:3px solid var(--gold-500);border-radius:0 6px 6px 0;padding:14px 18px;font-family:var(--font-sans);font-size:.9rem;color:var(--ink-500);margin:24px 0}

/* ---------- editierbare Anlagen-Blöcke (Schießanlagen) ---------- */
.anlage{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;padding:26px;margin-bottom:24px;box-shadow:var(--shadow-xs)}
.anlage:last-child{margin-bottom:0}
.anlage-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.anlage-head .badge-k{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--green-800);background:var(--green-100);padding:6px 12px;border-radius:999px;display:inline-flex;align-items:center;gap:7px}
.anlage-head .badge-k i{width:14px;height:14px}
.anlage-head h3{font-family:var(--font-serif);font-weight:700;font-size:1.5rem;color:var(--ink-900);margin:0}
.anlage-imgs{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}
@media(max-width:620px){.anlage-imgs{grid-template-columns:1fr}}
.anlage-imgs image-slot{width:100%;height:170px;display:block}
.field-label{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:7px;margin-bottom:8px}
.field-label i{width:14px;height:14px}
.anlage-field{width:100%;box-sizing:border-box;font-family:var(--font-serif);font-size:1.02rem;line-height:1.6;color:var(--ink-700);background:var(--paper-warm);border:1px solid var(--border-strong);border-radius:8px;padding:13px 15px;outline:none;resize:vertical;min-height:96px;transition:border-color .15s,box-shadow .15s,background .15s}
.anlage-field:hover{background:#fff}
.anlage-field:focus{background:#fff;border-color:var(--green-500);box-shadow:var(--ring)}
.anlage-field::placeholder{color:var(--ink-300)}
.edit-hint{display:flex;align-items:center;gap:9px;font-family:var(--font-sans);font-size:.85rem;color:var(--ink-500);background:var(--green-100);border:1px solid var(--green-200);border-radius:8px;padding:11px 15px;margin-bottom:26px}
.edit-hint i{width:17px;height:17px;color:var(--green-700);flex:none}

/* ---------- month calendar (termine) ---------- */
.cal-card{background:var(--bg-1);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow-sm);overflow:hidden}
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--border);background:var(--paper-warm)}
.cal-head .mname{font-family:var(--font-serif);font-weight:700;font-size:1.3rem;color:var(--ink-900);white-space:nowrap}
.cal-head .nav{display:flex;gap:8px}
.cal-head .nav button{width:36px;height:36px;border-radius:8px;border:1px solid var(--border-strong);background:#fff;color:var(--ink-500);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color .15s,color .15s}
.cal-head .nav button:hover{border-color:var(--green-500);color:var(--green-700)}
.cal-head .nav button i{width:18px;height:18px}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-grid .dow{font-family:var(--font-sans);font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold-700);text-align:center;padding:14px 0 10px}
.cal-cell{min-height:92px;border-top:1px solid var(--border);border-left:1px solid var(--border);padding:8px 10px;position:relative}
.cal-cell:nth-child(7n+1){border-left:0}
.cal-cell.empty{background:var(--paper-warm)}
.cal-cell .dnum{font-family:var(--font-serif);font-size:1.05rem;color:var(--ink-700)}
.cal-cell.train .dnum::after{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--green-500);margin-left:6px;vertical-align:middle}
.cal-ev{display:block;margin-top:6px;font-family:var(--font-sans);font-size:11px;font-weight:600;line-height:1.25;color:#fff;background:var(--green-700);border-radius:5px;padding:4px 7px;text-decoration:none}
.cal-ev.gold{background:var(--gold-600,#b8901f)}
.cal-legend{display:flex;flex-wrap:wrap;gap:20px;margin-top:18px;font-family:var(--font-sans);font-size:.86rem;color:var(--ink-500)}
.cal-legend .lg{display:flex;align-items:center;gap:8px}
.cal-legend .sw{width:12px;height:12px;border-radius:50%}
.cal-legend .sw.train{background:var(--green-500)}
.cal-legend .sw.ev{background:var(--green-700);border-radius:3px}
.cal-legend .sw.fest{background:var(--gold-600,#b8901f);border-radius:3px}
@media(max-width:620px){.cal-cell{min-height:64px;padding:5px 5px}.cal-cell .dnum{font-size:.9rem}.cal-ev{font-size:9px;padding:2px 4px}}
