:root {
  --blue-dark:  #1a3a6b;
  --blue-mid:   #1e56a0;
  --blue-light: #2e7dd1;
  --blue-pale:  #e8f0fb;
  --blue-border:#b8d0f0;
  --accent:     #f0a500;
  --accent-light:#fff3d0;
  --white:      #ffffff;
  --bg:         #f0f4fb;
  --text-dark:  #0f1f3d;
  --text-mid:   #2d4070;
  --text-light: #6b7a9a;
  --border:     #ccd8ee;
  --shadow:     rgba(26,58,107,0.12);
  --radius:     8px;
  --radius-lg:  14px;
  --green:      #1a7a4a;
  --green-bg:   #e6f4ed;
  --red:        #c0392b;
  --red-bg:     #fdecea;
  --orange:     #d4622a;
  --orange-bg:  #fef0e0;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--text-dark);min-height:100vh;display:flex;flex-direction:column}
.site-header{background:linear-gradient(135deg,var(--blue-dark) 0%,var(--blue-mid) 100%);color:#fff;position:sticky;top:0;z-index:100;box-shadow:0 3px 16px rgba(26,58,107,.35)}
.header-inner{max-width:1300px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:0 1.25rem;height:62px;gap:1rem;flex-wrap:wrap}
.header-brand{display:flex;align-items:center;gap:10px;flex-shrink:0}
.tent-icon{font-size:1.7rem}
.site-title{font-family:'Inter',sans-serif;font-size:1.1rem;font-weight:700;line-height:1.15;color:#fff}
.site-subtitle{font-size:10px;opacity:.65;text-transform:uppercase;letter-spacing:.12em;display:block;color:#c8d8f0}
.site-nav{display:flex;align-items:center;gap:3px;flex-wrap:wrap}
.nav-toggle{display:none}
.nav-link{color:rgba(255,255,255,.75);font-size:12.5px;padding:5px 11px;border-radius:6px;cursor:pointer;text-decoration:none;transition:all .15s}
.nav-link:hover,.nav-link.active{color:#fff;background:rgba(255,255,255,.15)}
.nav-sep{color:rgba(255,255,255,.2);margin:0 4px}
.nav-user{font-size:12px;color:rgba(255,255,255,.45)}
.nav-logout{opacity:.5}
.badge-count{background:#e74c3c;color:#fff;border-radius:10px;padding:1px 6px;font-size:10px;margin-left:4px}
.statusbar{display:flex;gap:8px;flex-shrink:0}
.stat-pill{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:4px 14px;text-align:center;min-width:65px}
.stat-total{background:rgba(255,255,255,.22)}
.stat-warn{background:rgba(240,165,0,.25);border-color:rgba(240,165,0,.4)}
.stat-val{display:block;font-family:'Inter',sans-serif;font-size:1.35rem;font-weight:700;color:#fff;line-height:1}
.stat-lbl{display:block;font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:rgba(255,255,255,.6);margin-top:1px}
.main-content{flex:1;max-width:1300px;width:100%;margin:0 auto;padding:1.5rem}
.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}
.page-title{font-family:'Inter',sans-serif;font-size:1.7rem;font-weight:800;color:var(--blue-dark)}
.year-badge{background:var(--blue-mid);color:#fff;padding:3px 12px;border-radius:100px;font-size:.95rem;font-weight:600;margin-left:8px;vertical-align:middle}
.header-actions{display:flex;gap:8px}
.flash-container{margin-bottom:1rem}
.flash{padding:10px 16px;border-radius:var(--radius);font-size:13px;font-weight:500;margin-bottom:6px;border-left:3px solid transparent}
.flash-success{background:var(--green-bg);color:var(--green);border-color:var(--green)}
.flash-error{background:var(--red-bg);color:var(--red);border-color:var(--red)}
.flash-warning{background:var(--orange-bg);color:var(--orange);border-color:var(--orange)}
.flash-info{background:var(--blue-pale);color:var(--blue-mid);border-color:var(--blue-light)}
.alert{padding:12px 16px;border-radius:var(--radius);font-size:13px;margin-bottom:1rem}
.alert-warning{background:var(--orange-bg);border-left:3px solid var(--orange);color:var(--orange)}
.alert-info{background:var(--blue-pale);border-left:3px solid var(--blue-light);color:var(--blue-mid)}
.alert ul{margin-top:6px;margin-left:1.2rem}
.alert a{color:inherit;font-weight:600}
.dash-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:1.5rem}
.dash-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1rem 1.25rem;text-align:center;box-shadow:0 2px 8px var(--shadow);transition:transform .15s}
.dash-card:hover{transform:translateY(-2px)}
.dash-total{background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid))}
.dash-total .dash-num,.dash-total .dash-lbl{color:#fff}
.dash-warn{background:var(--orange-bg);border-color:#f0c080}
.dash-warn .dash-num{color:var(--orange)}
.dash-green{background:var(--green-bg);border-color:#a0d8b8}
.dash-green .dash-num{color:var(--green)}
.dash-orange{background:#fff3d0;border-color:#f0c080}
.dash-orange .dash-num{color:#a07000}
.dash-num{font-family:'Inter',sans-serif;font-size:2rem;font-weight:800;color:var(--blue-dark);line-height:1}
.dash-lbl{font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-light);margin-top:4px}
.report-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;margin-bottom:1.5rem}
.report-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;text-align:center;text-decoration:none;display:flex;flex-direction:column;gap:6px;transition:all .18s;box-shadow:0 2px 8px var(--shadow)}
.report-card:hover{border-color:var(--blue-light);background:var(--blue-pale);transform:translateY(-2px)}
.report-icon{font-size:2rem}
.report-name{font-weight:600;font-size:14px;color:var(--blue-dark)}
.report-year{font-size:11px;color:var(--text-light)}
.section-title-row{margin:1.25rem 0 .75rem}
.section-title-row h3{font-family:'Inter',sans-serif;font-size:1.1rem;color:var(--blue-dark)}
.info-row{display:flex;gap:1.5rem;font-size:13px;color:var(--text-mid);flex-wrap:wrap;margin-top:1rem;padding:.75rem 1rem;background:var(--white);border-radius:var(--radius);border:1px solid var(--border)}
.search-bar{margin-bottom:1rem}
.search-inner{display:flex;gap:8px;align-items:center}
.search-input{flex:1;max-width:400px;padding:8px 12px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;background:var(--white);color:var(--text-dark)}
.search-input:focus{outline:none;border-color:var(--blue-light);box-shadow:0 0 0 3px rgba(46,125,209,.15)}
.search-hint{font-size:12px;color:var(--text-light)}
.table-wrapper{background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);overflow:hidden;box-shadow:0 2px 16px var(--shadow)}
.data-table{width:100%;border-collapse:collapse;font-size:13px}
.data-table thead{background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid));color:#fff}
.data-table th{padding:10px 12px;text-align:left;font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.07em;white-space:nowrap}
.data-table tbody tr{border-bottom:1px solid var(--border);transition:background .12s}
.data-table tbody tr:last-child{border-bottom:none}
.data-table tbody tr:hover{background:var(--blue-pale)}
.data-table tbody tr.row-paid{background:#eef7f2}
.data-table tbody tr.row-warteliste{background:#fff8ec;opacity:.85}
.data-table td{padding:9px 12px;vertical-align:middle}
.tc{text-align:center}
.kc{font-size:12px;font-weight:600;color:var(--blue-mid);display:block}
.kn{font-size:11px;color:var(--text-light);display:block}
.contact{font-size:11px;color:var(--text-mid);line-height:1.6}
.badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:500}
.b-kol{background:#ede9fd;color:#5340c9}
.b-bar{background:var(--orange-bg);color:var(--orange)}
.b-tbr{background:var(--blue-pale);color:var(--blue-mid)}
.b-ok{background:var(--green-bg);color:var(--green)}
.b-wl{background:var(--orange-bg);color:var(--orange)}
.badge-aenderung{background:#fff3cd;color:#856404;font-size:10px;padding:1px 5px;border-radius:4px;margin-left:4px}
.pay-btn{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--border);background:var(--white);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;margin:0 auto;transition:all .2s;color:var(--text-light)}
.pay-btn:hover{border-color:var(--blue-light);color:var(--blue-light)}
.pay-btn.is-paid{background:var(--blue-mid);border-color:var(--blue-mid);color:#fff}
.act{display:flex;gap:4px;align-items:center}
.act-b{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:var(--white);cursor:pointer;font-size:13px;display:inline-flex;align-items:center;justify-content:center;transition:all .15s;color:var(--text-mid);text-decoration:none}
.act-b:hover{background:var(--blue-pale);border-color:var(--blue-light);color:var(--blue-mid)}
.act-del:hover{background:var(--red-bg)!important;border-color:var(--red)!important;color:var(--red)!important}
.if{display:inline}
.btn-xs{padding:2px 8px;border-radius:4px;border:none;cursor:pointer;font-size:12px;font-weight:600}
.btn-green{background:var(--green);color:#fff}
.form-page{max-width:760px;margin:0 auto}
.form-header{margin-bottom:1.5rem}
.form-subtitle{color:var(--text-light);font-size:13px;margin-top:4px}
.back-link{display:inline-block;color:var(--blue-light);text-decoration:none;font-size:13px;font-weight:500;margin-bottom:8px}
.back-link:hover{color:var(--blue-dark)}
.fsec{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;box-shadow:0 2px 8px var(--shadow)}
.fsec-title{font-family:'Inter',sans-serif;font-size:1rem;font-weight:700;color:var(--blue-dark);margin-bottom:1rem;padding-bottom:8px;border-bottom:2px solid var(--blue-pale)}
.section-sub{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-light);margin-bottom:8px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:2fr 70px 1fr;gap:8px;align-items:end}
.fgrp{display:flex;flex-direction:column;gap:4px; margin-bottom:18px;}
.fgrp label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-mid)}
input[type=text],input[type=email],input[type=tel],input[type=number],input[type=password],input[type=date],textarea,select{padding:8px 11px;border:1.5px solid var(--border);border-radius:var(--radius);font-family:inherit;font-size:13px;color:var(--text-dark);background:var(--white);width:100%;transition:border-color .18s,box-shadow .18s}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--blue-light);box-shadow:0 0 0 3px rgba(46,125,209,.15)}
textarea{resize:vertical;min-height:70px}
.kind-row{border:1px solid var(--blue-border);border-radius:var(--radius);padding:10px;margin-bottom:8px;background:var(--blue-pale)}
.kind-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.kind-label{font-size:11px;font-weight:700;color:var(--blue-mid);text-transform:uppercase;letter-spacing:.06em}
.remove-kind-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:11px;padding:2px 6px;border-radius:4px;font-family:inherit}
.remove-kind-btn:hover{color:var(--red);background:var(--red-bg)}
.add-kid{width:100%;padding:8px;border:1.5px dashed var(--blue-border);border-radius:var(--radius);background:transparent;color:var(--text-light);font-family:inherit;font-size:13px;cursor:pointer;transition:all .15s;margin-top:2px}
.add-kid:hover{border-color:var(--blue-light);color:var(--blue-mid);background:var(--blue-pale)}
.radio-row{display:flex;gap:12px;padding:6px 0;align-items:center;font-size:13px}
.radio-row label{display:flex;align-items:center;gap:5px;cursor:pointer}
.betrag-buttons{display:flex;gap:10px;flex-wrap:wrap}
.betrag-opt{display:flex;align-items:center;gap:8px;padding:10px 20px;border:2px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:15px;font-weight:500;background:var(--white);transition:all .18s;user-select:none}
.betrag-opt:hover{border-color:var(--blue-light);background:var(--blue-pale)}
.betrag-opt.selected{border-color:var(--blue-mid);background:var(--blue-pale);color:var(--blue-dark);font-weight:700;box-shadow:0 0 0 3px rgba(46,125,209,.15)}
.betrag-opt input{display:none}
.chk-big{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;font-size:13px;background:var(--white);transition:all .18s}
.chk-big:hover{border-color:var(--blue-light);background:var(--blue-pale)}
input[type=checkbox],input[type=radio]{accent-color:var(--blue-mid);width:15px;height:15px;cursor:pointer;flex-shrink:0}
.form-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:.5rem}
.section-hint{font-size:11px;font-weight:400;color:var(--text-light)}
.schnellsuche-box{border-color:var(--blue-border);background:var(--blue-pale)}
.schnell-results{margin-top:10px}
.schnell-item{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;margin-bottom:6px;transition:all .15s;display:flex;justify-content:space-between;align-items:center}
.schnell-item:hover{background:var(--blue-pale);border-color:var(--blue-light)}
.schnell-item span{font-size:12px;color:var(--text-light)}
.no-results{font-size:13px;color:var(--text-light);padding:8px 0}
.load-ok{font-size:13px;color:var(--blue-mid);font-weight:500;padding:8px 12px;background:var(--blue-pale);border-radius:var(--radius);border-left:3px solid var(--blue-light)}
.diff-list{display:grid;grid-template-columns:80px 1fr;gap:4px 10px;font-size:13px}
.diff-list dt{font-weight:600;color:var(--text-light);font-size:11px;text-transform:uppercase;align-self:start;padding-top:2px}
.diff-new{color:var(--blue-mid);font-weight:600}
.detail-list{display:grid;grid-template-columns:130px 1fr;gap:5px 10px;font-size:13px}
.detail-list dt{font-weight:600;color:var(--text-light);font-size:11px;text-transform:uppercase}
.btn{display:inline-flex;align-items:center;gap:5px;padding:7px 16px;border-radius:var(--radius);font-family:inherit;font-size:13px;font-weight:600;cursor:pointer;border:2px solid transparent;text-decoration:none;transition:all .18s;line-height:1}
.btn-primary{background:linear-gradient(135deg,var(--blue-mid),var(--blue-light));color:#fff;border-color:var(--blue-mid);box-shadow:0 2px 6px rgba(46,125,209,.3)}
.btn-primary:hover{background:linear-gradient(135deg,var(--blue-dark),var(--blue-mid));box-shadow:0 4px 12px rgba(46,125,209,.4)}
.btn-secondary{background:var(--white);color:var(--text-mid);border-color:var(--border)}
.btn-secondary:hover{background:var(--blue-pale);border-color:var(--blue-light);color:var(--blue-mid)}
.btn-block{width:100%;justify-content:center;margin-top:10px;}
.btn-large{padding:10px 24px;font-size:15px}
.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-light)}
.empty-icon{font-size:4rem;margin-bottom:1rem}
.empty-state h3{font-family:'Inter',sans-serif;font-size:1.4rem;color:var(--text-mid);margin-bottom:.5rem}
.empty-state p{margin-bottom:.75rem;max-width:400px;margin-left:auto;margin-right:auto}
.login-wrap{display:flex;justify-content:center;align-items:center;min-height:65vh}
.login-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:2.5rem;width:100%;max-width:380px;box-shadow:0 8px 32px rgba(26,58,107,.15);display:flex;flex-direction:column;gap:1rem}
.login-icon{font-size:3rem;text-align:center}
.login-card h2{font-family:'Inter',sans-serif;text-align:center;color:var(--blue-dark);font-size:1.4rem;font-weight:700}
.login-sub{text-align:center;color:var(--text-light);font-size:13px;margin-top:-6px}
.site-footer{background:var(--blue-dark);color:rgba(255,255,255,.35);text-align:center;padding:1rem;font-size:12px;margin-top:auto}
@media(max-width:768px){
  .main-content{padding:1rem}
  .grid2{grid-template-columns:1fr}
  .grid3{grid-template-columns:1fr 60px}
  .header-inner{height:auto;padding:8px 1rem;gap:.5rem}
  .statusbar{gap:4px}
  .stat-pill{min-width:50px;padding:3px 8px}
  .dash-grid{grid-template-columns:repeat(3,1fr)}
  .data-table{font-size:12px}
  .data-table th,.data-table td{padding:7px 8px}
  .betrag-opt{padding:8px 14px;font-size:13px}
  .page-title{font-size:1.4rem}
}

.name-link{text-decoration:none;color:var(--blue-mid);font-weight:600}
.name-link:hover{color:var(--blue-dark);text-decoration:underline}
.sortable{user-select:none}
.sortable:hover{background:rgba(255,255,255,.08);cursor:pointer}
.sort-icon{font-size:10px;opacity:.6;margin-left:2px}

/* ── Audit-Log Badges ── */
.audit-badge-login{background:#e8f4e8;color:#1a7a4a}
.audit-badge-logout{background:#f0f4fb;color:#1a3a6b}
.audit-badge-anmeldung{background:#e8f0fb;color:#1e56a0}
.audit-badge-admin{background:#fff3d0;color:#a07000}
.audit-badge-freigabe{background:#e6f4ed;color:#1a7a4a}
.audit-badge-ablehnung{background:#fdecea;color:#c0392b}
.audit-badge-token{background:#f0ebfe;color:#5340c9}
.audit-badge-jahresfortschreibung{background:#fef0e0;color:#d4622a}
.audit-badge-csv{background:#e8f0fb;color:#1e56a0}
.audit-badge-passwort{background:#fff3d0;color:#a07000}
.audit-badge-warteliste{background:#e8f0fb;color:#1e56a0}
.audit-badge-lager{background:#e8f7f5;color:#0f766e}

/* ══════════════════════════════════════════
   MOBILE OPTIMIERUNGEN
   ══════════════════════════════════════════ */

/* ── Navigation Mobile ── */
@media(max-width:768px){
  .site-header{ padding-bottom: 6px }
  .header-inner{
    flex-wrap: wrap;
    height: auto;
    padding: 8px 12px;
    gap: 6px;
  }
  .header-brand{ flex: 0 0 auto }
  .site-nav{
    order: 3;
    width: 100%;
    flex-wrap: wrap;
    gap: 2px;
    padding-bottom: 4px;
    display: none; /* hidden by default, toggled via .nav-open on header */
  }
  .nav-link{
    font-size: 12px;
    padding: 5px 9px;
  }
  .nav-sep{ display: none }
  .nav-user{ display: none }
  .statusbar{
    order: 2;
    margin-left: auto;
  }
  .stat-pill{ min-width: 48px; padding: 3px 8px }
  .stat-val{ font-size: 1.1rem }
  .stat-lbl{ font-size: 8px }
  .nav-toggle{
    display: flex;
    align-items: center;
    justify-content: center;
    order: 0;
    background: rgba(255,255,255,.15);
    border: none;
    color: #fff;
    font-size: 1.3rem;
    width: 38px;
    height: 38px;
    border-radius: 8px;
    cursor: pointer;
    flex-shrink: 0;
  }
  .site-header.nav-open .site-nav{
    display: flex !important;
  }
}

/* ── Tabelle Mobile: Card-Layout ── */
@media(max-width:768px){
  .table-wrapper{ border-radius: var(--radius); overflow: hidden }

  .data-table thead{ display: none } /* Header ausblenden */

  .data-table tbody tr{
    display: block;
    border-bottom: 2px solid var(--border);
    padding: 10px 12px;
    position: relative;
  }
  .data-table tbody tr:last-child{ border-bottom: none }

  .data-table td{
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 3px 0;
    border: none;
    font-size: 13px;
  }

  /* Datenlabel vor jedem Wert */
  .data-table td::before{
    content: attr(data-label);
    font-size: 10px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .05em;
    color: var(--text-light);
    flex-shrink: 0;
    width: 90px;
  }

  /* Name-Zelle prominent */
  .data-table td:first-child{
    font-size: 15px;
    font-weight: 700;
    padding-bottom: 6px;
    border-bottom: 1px solid var(--border);
    margin-bottom: 4px;
    justify-content: flex-start;
    gap: 8px;
  }
  .data-table td:first-child::before{ display: none }

  /* Bezahlt-Button rechtsbündig */
  .pay-btn{ margin: 0 }

  /* Aktionen-Zelle */
  .td-actions, .data-table td:last-child{
    justify-content: flex-end;
    padding-top: 6px;
    margin-top: 4px;
    border-top: 1px solid var(--border);
  }
  .data-table td:last-child::before{ display: none }

  /* Zellen die nichts anzeigen ausblenden */
  .data-table td:empty{ display: none }
}

/* ── Dashboard Mobile ── */
@media(max-width:768px){
  .dash-grid{ grid-template-columns: repeat(2, 1fr) }
  .report-grid{ grid-template-columns: repeat(2, 1fr) }
  .page-header{ flex-direction: column; align-items: flex-start }
  .header-actions{ width: 100%; justify-content: stretch }
  .header-actions .btn{ flex: 1; justify-content: center }
  .page-title{ font-size: 1.4rem }
  .year-badge{ font-size: .8rem }
}

/* ── Formulare Mobile ── */
@media(max-width:768px){
  .form-page{ padding: 0 }
  .fsec{ border-radius: var(--radius); padding: 1rem }
  .grid2{ grid-template-columns: 1fr }
  .grid3{
    grid-template-columns: 1fr 60px;
    grid-template-rows: auto auto;
  }
  .kind-geschlecht-group{ grid-column: 1 / -1 }
  .betrag-buttons{ gap: 8px }
  .betrag-opt{ flex: 1; justify-content: center; padding: 12px 8px }
  .form-actions{ flex-direction: column }
  .form-actions .btn{ width: 100%; justify-content: center }
  .btn-large{ padding: 12px; font-size: 15px }
  .search-inner{ flex-wrap: wrap }
  .search-input{ max-width: 100%; width: 100% }
}

/* helper touch-friendly classes */
.touch-large .btn{ padding: 12px 18px; font-size: 15px }
.btn-block{ width: 100%; display:inline-flex; justify-content:center }

/* table horizontal scroll fallback for very small devices */
@media(max-width:420px){
  .table-wrapper{ overflow-x:auto }
  .table-wrapper table{ min-width:600px }
}

/* ── Schnellsuche Mobile ── */
@media(max-width:768px){
  .schnell-item{ flex-direction: column; align-items: flex-start; gap: 2px }
}

/* ── Audit-Log Mobile ── */
@media(max-width:768px){
  .data-table td[style*="font-family:monospace"]{ font-size: 10px }
}

/* ── Anmeldetag: Betrag-Buttons auf Mobile größer ── */
@media(max-width:768px){
  .betrag-opt{ font-size: 16px; padding: 14px 10px }
}

/* ── Responsive Spalten ausblenden ── */
@media(max-width:900px){
  .col-hide-md{ display: none !important }
}
@media(max-width:1100px){
  .col-hide-lg{ display: none !important }
}

/* ── Bezahlt-Indikator in Namenszelle ── */
.bezahlt-dot{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 20px; height: 20px;
  border-radius: 50%;
  background: var(--blue-mid);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  margin-left: 6px;
  vertical-align: middle;
  flex-shrink: 0;
}

/* ── Einstellungen: Jahresfortschreibung-Sektion ── */
.fsec[style*="border-color:#f0c080"]{
  border-width: 1.5px;
}

/* ── Mobile: Card-Layout data-label Fixes ── */
@media(max-width:768px){
  .kn{ display: block; margin-top: 2px }
  .data-table td[data-label="Kontakt"]{
    flex-direction: column;
    align-items: flex-start;
  }
  .data-table td[data-label="Kontakt"]::before{
    margin-bottom: 2px;
  }
}
/* ── Dashboard Charts ── */
.chart-grid{
  display: grid;
  grid-template-columns: 1fr 1.8fr 1fr;
  gap: 1rem;
  margin-bottom: 1.5rem;
  align-items: stretch; /* ensure grid items stretch to equal height */
}
.chart-card{
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1rem 1.25rem 0.75rem;
  box-shadow: 0 2px 8px var(--shadow);
  display: flex;
  flex-direction: column;
  height: 100%;
}
.chart-title{
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--text-light);
  margin-bottom: .65rem;
  padding-bottom: .5rem;
  border-bottom: 1px solid var(--border);
}
.chart-body{
  display: flex;
  align-items: center;
  justify-content: center;
  flex: 1; /* allow chart body to expand so cards have equal height */
}
.chart-summary{
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  margin-top: .5rem;
  padding-top: .5rem;
  border-top: 1px solid var(--border);
  gap: .5rem;
  flex-wrap: wrap;
}

@media(max-width:1100px){
  .chart-grid{
    grid-template-columns: 1fr 1fr;
  }
  .chart-card-wide{
    grid-column: 1 / -1;
    order: -1;
  }
}
@media(max-width:600px){
  .chart-grid{
    grid-template-columns: 1fr;
  }
  .chart-card-wide{
    grid-column: auto;
    order: 0;
  }
}

/* ── Teilnehmerliste Mobile: versteckte Spalten wieder einblenden ── */
@media(max-width:768px){
  /* Alle Spalten auf Mobile als Cards zeigen */
  .data-table td.col-hide-md,
  .data-table td.col-hide-lg{
    display: flex !important;
  }

  /* Kontakt-Zelle: mehrzeilig */
  .data-table td.contact{
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
    font-size: 13px;
    color: var(--text-mid);
  }
  .data-table td.contact::before{
    margin-bottom: 2px;
  }
  .data-table td.contact div{
    word-break: break-all;
  }

  /* Zentrierte Zellen auf Mobile linksbündig */
  .data-table td.tc{
    justify-content: space-between;
  }

  /* Leere col-hide Zellen (kein Inhalt) weiter ausblenden */
  .data-table td.col-hide-md:empty,
  .data-table td.col-hide-lg:empty{
    display: none !important;
  }

  /* Badges in Zeilen nicht umbrechen */
  .data-table td .badge{
    white-space: nowrap;
  }

  /* Kinder-Namen umbrechen statt abschneiden */
  .kn{
    white-space: normal;
    word-break: break-word;
    color: var(--text-light);
    font-size: 12px;
  }
}

/* ── Desktop/Mobile Toggle ── */
.mobile-only { display: none }
@media(max-width:768px){
  .desktop-only { display: none !important }
  .mobile-only   { display: block }
}

/* ── Teilnehmer Mobile Cards ── */
.tn-card{
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: .75rem;
  overflow: hidden;
  box-shadow: 0 1px 6px var(--shadow);
}
.tn-card-wl{
  background: #fff8ec;
  border-color: #f0c080;
}
.tn-card-head{
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: .75rem 1rem;
  border-bottom: 1px solid var(--border);
  gap: .5rem;
}
.tn-card-head .name-link strong{
  font-size: 1rem;
}
.tn-card-badges{
  display: flex;
  align-items: center;
  gap: .35rem;
  flex-shrink: 0;
}
.tn-card-body{
  padding: .6rem 1rem;
  display: flex;
  flex-direction: column;
  gap: .35rem;
}
.tn-card-row{
  display: flex;
  align-items: baseline;
  gap: .5rem;
  font-size: 13px;
  flex-wrap: wrap;
}
.tn-card-lbl{
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-light);
  flex-shrink: 0;
  width: 60px;
}
.tn-card-contact{
  word-break: break-all;
  font-size: 13px;
}
.tn-card-foot{
  display: flex;
  gap: .5rem;
  padding: .6rem 1rem;
  border-top: 1px solid var(--border);
  background: #f8fafd;
}
.btn-sm{
  padding: 5px 10px;
  font-size: 12px;
}
.btn-danger{
  background: #f8d7da;
  color: #721c24;
  border: 1px solid #f5c6cb;
  border-radius: var(--radius-sm, 6px);
  cursor: pointer;
  font-size: 12px;
  padding: 5px 10px;
}
