/* BUILD_TS: eventlist_v3.2_20260416_105251 FILE: umfragen/styles/survey-core.css */
/* =========================================================
   survey-core.css — TC Mahlow v3.2
   Design: DM Serif Display + DM Sans, flat green, card-based
   =========================================================

   FONTS: Self-hosted – keine externe Verbindung.
   Schriften einmalig herunterladen und in styles/fonts/ ablegen.
   Anleitung: styles/fonts/README.txt
   ========================================================= */

/* ── DM Sans (Body-Schrift) ── */
@font-face {
    font-family: 'DM Sans';
    src: url('fonts/DMSans-Regular.woff2') format('woff2'),
         url('fonts/DMSans-Regular.ttf')   format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'DM Sans';
    src: url('fonts/DMSans-Medium.woff2') format('woff2'),
         url('fonts/DMSans-Medium.ttf')   format('truetype');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'DM Sans';
    src: url('fonts/DMSans-SemiBold.woff2') format('woff2'),
         url('fonts/DMSans-SemiBold.ttf')   format('truetype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

/* ── DM Serif Display (Titel-Schrift) ── */
@font-face {
    font-family: 'DM Serif Display';
    src: url('fonts/DMSerifDisplay-Regular.woff2') format('woff2'),
         url('fonts/DMSerifDisplay-Regular.ttf')   format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'DM Serif Display';
    src: url('fonts/DMSerifDisplay-Italic.woff2') format('woff2'),
         url('fonts/DMSerifDisplay-Italic.ttf')   format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}

:root {
    --green:        #077407;
    --green-mid:    #3cae3c;
    --green-light:  #e8f4ed;
    --green-xlight: #f2f9f4;
    --green-line:   #c2deca;
    --green-focus:  rgba(26,107,56,.14);
    --accent:       #d4a035;
    --accent-light: #fdf6e3;
    --text:         #111a14;
    --text-2:       #3d5245;
    --text-3:       #6b8070;
    --bg:           #f7faf8;
    --bg-panel:     #ffffff;
    --bg-subtle:    #f4f7f5;
    --border:       #dce8e0;
    --border-mid:   #c8d8cc;
    --radius-sm:    8px;
    --radius:       14px;
    --radius-lg:    20px;
    --shadow-sm:    0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
    --shadow:       0 4px 16px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);
    --shadow-lg:    0 12px 40px rgba(0,0,0,.10), 0 2px 8px rgba(0,0,0,.05);
    --font-display: 'DM Serif Display', 'Palatino Linotype', Palatino, 'Book Antiqua', Georgia, serif;
    --font-body:    'DM Sans', 'Segoe UI', system-ui, -apple-system, BlinkMacSystemFont, sans-serif;
    --transition:   .18s cubic-bezier(.4,0,.2,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:15px;line-height:1.6;-webkit-font-smoothing:antialiased;}

/* Site Header */
.site-header{background:var(--green);color:#fff;padding:0 clamp(16px,5vw,48px);display:flex;align-items:center;justify-content:space-between;height:58px;gap:16px;position:sticky;top:0;z-index:50;}
.site-logo{font-family:var(--font-display);font-size:1.15rem;letter-spacing:.01em;white-space:nowrap;color:#fff;text-decoration:none;}
.site-logo span{opacity:.7;font-style:italic;}
.site-nav{display:flex;gap:4px;align-items:center;}
.site-nav a{color:rgba(255,255,255,.75);text-decoration:none;font-size:13px;font-weight:500;padding:6px 12px;border-radius:6px;transition:var(--transition);white-space:nowrap;}
.site-nav a:hover{color:#fff;background:rgba(255,255,255,.12);}
.site-nav .nav-login{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.25);}
.site-nav .nav-login:hover{background:rgba(255,255,255,.25);}
.site-nav .nav-active{color:#fff;background:rgba(255,255,255,.18);}
/* Hamburger button – hidden on desktop */
.nav-hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;gap:5px;width:40px;height:40px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:8px;cursor:pointer;padding:0;flex-shrink:0;}
.nav-hamburger span{display:block;width:20px;height:2px;background:#fff;border-radius:2px;transition:transform .22s ease,opacity .22s ease;}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
/* Mobile dropdown */
.mobile-menu{display:none;position:absolute;top:58px;left:0;right:0;background:var(--green);z-index:49;padding:8px 16px 14px;border-top:1px solid rgba(255,255,255,.12);box-shadow:0 6px 18px rgba(0,0,0,.18);}
.mobile-menu.open{display:flex;flex-direction:column;gap:4px;}
.mobile-menu a{color:rgba(255,255,255,.85);text-decoration:none;font-size:15px;font-weight:500;padding:11px 14px;border-radius:8px;transition:background var(--transition);}
.mobile-menu a:hover{background:rgba(255,255,255,.12);color:#fff;}
.mobile-menu .nav-login{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.25);color:#fff;margin-top:4px;}
.mobile-menu .nav-login:hover{background:rgba(255,255,255,.25);}
.mobile-menu .nav-active{background:rgba(255,255,255,.18);color:#fff;}
@media(max-width:480px){.site-nav{display:none;}.nav-hamburger{display:flex;}}

/* Help page */
.help-section-title{font-family:var(--font-display);font-size:1.05rem;font-weight:400;margin-bottom:12px;color:var(--text);}
.help-body{font-size:14px;color:var(--text-2);line-height:1.7;display:flex;flex-direction:column;gap:8px;}
.help-body a{color:var(--green);text-decoration:underline;text-underline-offset:2px;}
.help-body a:hover{color:var(--green-mid);}
.help-list{padding-left:20px;display:flex;flex-direction:column;gap:6px;}

/* Hero */
.hero{background:var(--green);color:#fff;padding:clamp(32px,6vw,60px) clamp(16px,5vw,48px) clamp(40px,7vw,68px);position:relative;overflow:hidden;}
.hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 80% at 80% 20%,rgba(255,255,255,.06) 0%,transparent 70%),radial-gradient(ellipse 40% 60% at 10% 90%,rgba(0,0,0,.10) 0%,transparent 60%);pointer-events:none;}
.hero-inner{position:relative;max-width:680px;margin:0 auto;text-align:center;}
.hero-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;opacity:.6;margin-bottom:10px;}
.hero h1{font-family:var(--font-display);font-size:clamp(1.9rem,5vw,3rem);line-height:1.15;margin-bottom:12px;font-weight:400;}
.hero h1 em{font-style:italic;opacity:.8;}
.hero-desc{opacity:.8;font-size:clamp(13px,2vw,15px);max-width:460px;line-height:1.6;margin:0 auto;}
.hero-contact{margin-top:16px;font-size:13px;opacity:.6;}
.hero-contact a{color:#fff;text-decoration:underline;}

/* Layout */
.page-wrap{max-width:1080px;margin:0 auto;padding:clamp(24px,4vw,48px) clamp(16px,5vw,40px);}
.section-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--green);margin-bottom:5px;}
.section-title{font-family:var(--font-display);font-size:clamp(1.25rem,3vw,1.65rem);color:var(--text);margin-bottom:18px;font-weight:400;}

/* Event grid */
.event-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:16px;}

/* Event card */
.event-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);transition:transform var(--transition),box-shadow var(--transition);text-decoration:none;color:inherit;}
.event-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);}
.event-card.card-closed{opacity:.8;}
.event-card.card-closed:hover{transform:none;box-shadow:var(--shadow-sm);cursor:default;}
.event-card.card-signed{background:var(--green-light);border-color:var(--green-line);}
.event-card.card-signed .event-card-footer{background:var(--green-xlight);border-color:var(--green-line);}
.event-card-stripe{height:4px;background:var(--green);flex-shrink:0;}
.event-card.card-closed .event-card-stripe{background:var(--border);}
.event-card.card-full .event-card-stripe{background:var(--accent);}
.event-card-body{padding:18px 20px;flex:1;display:flex;flex-direction:column;gap:10px;}
.event-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;}
.event-card-title{font-family:var(--font-display);font-size:1.05rem;line-height:1.3;color:var(--text);font-weight:400;}
.event-card.card-closed .event-card-title{color:var(--text-3);}
.event-team-badges{display:flex;gap:4px;flex-wrap:wrap;}
.event-team-prefix{display:inline-block;font-family:var(--font-body);font-size:10px;font-weight:600;color:var(--green);background:var(--green-xlight);border:1px solid var(--green-line);border-radius:4px;padding:1px 6px;letter-spacing:.02em;}
.event-card-meta{font-size:13px;color:var(--text-3);display:flex;flex-direction:column;gap:3px;}
.event-card-meta-row{display:flex;align-items:center;gap:6px;}
.event-card-desc{font-size:13.5px;color:var(--text-2);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.event-card-footer{padding:12px 20px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:8px;}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;}
.event-signups{font-size:13px;color:var(--text-3);display:flex;align-items:center;gap:8px;}
.event-signups strong{color:var(--green);font-weight:600;}
.event-signups.signups-full strong{color:var(--accent);}

/* Progress bar */
.progress-bar{height:4px;background:var(--border);border-radius:99px;overflow:hidden;flex:1;max-width:72px;}
.progress-fill{height:100%;background:var(--green);border-radius:99px;}
.progress-fill.fill-full{background:var(--accent);}

/* Badges */
.badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 10px;border-radius:99px;white-space:nowrap;flex-shrink:0;}
.badge-open{background:var(--green-light);color:var(--green);border:1px solid var(--green-line);}
.badge-open::before{content:'●';font-size:7px;animation:badgepulse 2s infinite;}
@keyframes badgepulse{0%,100%{opacity:1}50%{opacity:.35}}
.badge-closed{background:#f0f0f0;color:#888;border:1px solid #ddd;}
.badge-full{background:var(--accent-light);color:#8a5c00;border:1px solid #e8c97a;}
.badge-signed{background:var(--green);color:#fff;border:1px solid var(--green-mid);}
.badge-white{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.3);color:#fff;}

/* Archive */
.archive-section{margin-top:32px;}
.archive-divider{border:none;border-top:1px solid var(--border);margin-bottom:14px;}
.archive-toggle{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-3);cursor:pointer;padding:8px 0;user-select:none;background:none;border:none;font-family:var(--font-body);}
.archive-toggle:hover{color:var(--text-2);}
.archive-caret{transition:transform var(--transition);display:inline-block;}
.archive-toggle[aria-expanded="true"] .archive-caret{transform:rotate(90deg);}
.archive-grid{display:none;margin-top:10px;grid-template-columns:repeat(auto-fill,minmax(min(100%,280px),1fr));gap:10px;}
.archive-grid.open{display:grid;}
.archive-card{background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius);padding:13px 16px;display:flex;justify-content:space-between;align-items:flex-start;gap:12px;opacity:.75;transition:opacity var(--transition);text-decoration:none;color:inherit;}
.archive-card:hover{opacity:1;}
.archive-card-title{font-size:13.5px;font-weight:500;color:var(--text-2);margin-bottom:2px;}
.archive-card-meta{font-size:12px;color:var(--text-3);}
.archive-card-count{font-size:12px;color:var(--text-3);white-space:nowrap;}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:9px 20px;border-radius:var(--radius-sm);border:1.5px solid transparent;font-family:var(--font-body);font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;transition:background var(--transition),box-shadow var(--transition),border-color var(--transition),transform var(--transition);white-space:nowrap;line-height:1.2;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--green);color:#fff;border-color:var(--green);}
.btn-primary:hover{background:var(--green-mid);border-color:var(--green-mid);box-shadow:0 4px 12px rgba(26,107,56,.25);}
.btn-secondary{background:var(--bg-panel);color:var(--text-2);border-color:var(--border);}
.btn-secondary:hover{border-color:var(--border-mid);background:var(--bg-subtle);}
.btn-ghost{background:transparent;color:var(--text-3);border-color:var(--border);}
.btn-ghost:hover{border-color:var(--border-mid);color:var(--text-2);}
.btn-sm{padding:6px 14px;font-size:13px;border-radius:6px;}
.btn-card{padding:7px 16px;font-size:13px;border-radius:8px;background:var(--green);color:#fff;border-color:var(--green);}
.btn-card:hover{background:var(--green-mid);}
.btn-disabled{background:#e0e5e2 !important;color:#99a09c !important;border-color:#e0e5e2 !important;cursor:default !important;}
.btn-disabled:hover{transform:none !important;box-shadow:none !important;}
.members-only-hint{font-size:12px;color:#185fa5;}

/* iCal */
.ical-btn{display:inline-flex;align-items:center;gap:5px;padding:6px 14px;border:1px solid var(--green-line);border-radius:6px;background:var(--green-xlight);color:var(--green);font-size:12px;font-weight:600;text-decoration:none;cursor:pointer;transition:background var(--transition);font-family:var(--font-body);}
.ical-btn:hover{background:var(--green-light);color:var(--green);}

/* Detail header */
.detail-header{background:var(--green);color:#fff;padding:clamp(20px,4vw,44px) clamp(16px,5vw,48px) clamp(28px,5vw,52px);position:relative;overflow:hidden;}
.detail-header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 60% 100% at 90% 0%,rgba(255,255,255,.07) 0%,transparent 60%);pointer-events:none;}
.detail-header-inner{max-width:940px;margin:0 auto;position:relative;}
.detail-back{display:inline-flex;align-items:center;gap:6px;color:rgba(255,255,255,.7);text-decoration:none;font-size:13px;font-weight:500;margin-bottom:14px;transition:color var(--transition);position:relative;}
.detail-back:hover{color:#fff;}
.detail-header h1{font-family:var(--font-display);font-size:clamp(1.55rem,4vw,2.4rem);line-height:1.2;font-weight:400;margin-bottom:12px;position:relative;}
.detail-header-meta{display:flex;flex-wrap:wrap;gap:14px;opacity:.85;font-size:13.5px;position:relative;}
.detail-header-meta-item{display:flex;align-items:center;gap:5px;}
.detail-status-bar{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap;position:relative;}
.nav-strip{display:flex;align-items:center;gap:6px;flex-wrap:wrap;}
.nav-strip a{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;border:1px solid rgba(255,255,255,.22);border-radius:6px;color:rgba(255,255,255,.82);text-decoration:none;font-size:13px;font-weight:500;background:rgba(255,255,255,.10);transition:background var(--transition),border-color var(--transition);}
.nav-strip a:hover{background:rgba(255,255,255,.2);color:#fff;}

/* Detail body */
.detail-body{max-width:940px;margin:0 auto;padding:clamp(16px,3vw,36px) clamp(16px,5vw,40px);display:grid;grid-template-columns:1fr minmax(0,320px);gap:22px;align-items:start;}
@media(max-width:720px){.detail-body{grid-template-columns:1fr;}.detail-sidebar{order:-1;}}
.detail-sidebar-sticky{position:sticky;top:72px;}
@media(max-width:720px){.detail-sidebar-sticky{position:static;}}

/* Stats strip */
.stats-strip{display:grid;grid-template-columns:repeat(4,1fr);background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:18px;}
.stat-cell{padding:15px 8px;text-align:center;border-right:1px solid var(--border);min-width:0;}
.stat-cell:last-child{border-right:none;}
.stat-num{font-family:var(--font-display);font-size:clamp(1.2rem,4vw,1.9rem);color:var(--green);line-height:1;font-weight:400;}
.stat-lbl{font-size:clamp(9px,2vw,11px);color:var(--text-3);margin-top:4px;font-weight:500;text-transform:uppercase;letter-spacing:.05em;word-break:break-word;}

/* Alerts */
.alert{padding:12px 16px;border-radius:var(--radius-sm);margin-bottom:14px;font-size:14px;line-height:1.5;}
.alert-success{background:var(--green-xlight);color:var(--green);border:1px solid var(--green-line);}
.alert-error{background:#fff3f2;color:#8d2f22;border:1px solid #f0c8c1;}

/* Signup form */
.signup-form-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:18px;}
.signup-form-head{padding:15px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;}
.signup-form-head h2{font-family:var(--font-display);font-size:1.05rem;font-weight:400;color:var(--text);}
.signup-form-body{padding:20px;display:flex;flex-direction:column;gap:14px;}
.form-hint-strip{background:var(--green-xlight);border:1px solid var(--green-line);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--text-2);line-height:1.5;}
.form-hint-strip a{color:var(--green);font-weight:600;text-decoration:underline;}

/* Fields */
.field-group{display:flex;flex-direction:column;gap:5px;}
.field-label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.02em;}
.field-input{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);color:var(--text);background:#fff;transition:border-color var(--transition),box-shadow var(--transition);width:100%;}
.field-input:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-focus);}
.field-input:hover:not(:focus){border-color:var(--border-mid);}
.field-readonly{background:var(--bg-subtle) !important;color:var(--text-3) !important;cursor:not-allowed !important;}
.field-hint{font-size:12px;color:var(--text-3);}
.field-error{font-size:12px;color:#8d2f22;margin-top:2px;}
textarea.field-input{resize:vertical;min-height:64px;}

/* Count row */
.count-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
@media(max-width:420px){.count-row{grid-template-columns:1fr;}}

/* Stepper */
.stepper-desktop{display:flex;flex-direction:column;gap:5px;}
.stepper-desktop input[type="number"]{padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--font-body);color:var(--text);background:#fff;width:100%;transition:border-color var(--transition),box-shadow var(--transition);text-align:center;}
.stepper-desktop input[type="number"]:focus{outline:none;border-color:var(--green);box-shadow:0 0 0 3px var(--green-focus);}
.stepper-widget{display:none;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden;}
.stepper-btn{border:none;background:var(--green-xlight);color:var(--green);font-size:20px;font-weight:500;width:44px;height:44px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition);flex-shrink:0;font-family:var(--font-body);}
.stepper-btn:hover{background:var(--green-light);}
.stepper-val{flex:1;text-align:center;font-size:16px;font-weight:600;color:var(--text);line-height:44px;min-width:36px;}
@media(max-width:640px){.stepper-desktop input[type="number"]{display:none;}.stepper-widget{display:flex;}}

/* Checkbox pill */
.checkbox-pill{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:border-color var(--transition),background var(--transition);user-select:none;}
.checkbox-pill:hover{border-color:var(--green);background:var(--green-xlight);}
.checkbox-pill input[type="checkbox"]{width:16px;height:16px;accent-color:var(--green);cursor:pointer;flex-shrink:0;}
.checkbox-pill-label{font-size:14px;color:var(--text);font-weight:500;cursor:pointer;line-height:1.3;}

/* Form actions */
.form-actions-row{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;}
.form-actions-row .btn-primary{width:100%;}
@media(max-width:400px){.form-actions-row{grid-template-columns:1fr;}}

/* Honeypot */
.hp-field-wrap{position:absolute !important;left:-10000px !important;top:auto !important;width:1px !important;height:1px !important;overflow:hidden !important;}

/* Info card (sidebar) */
.info-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);}
.info-card-section{padding:16px 20px;border-bottom:1px solid var(--border);}
.info-card-section:last-child{border-bottom:none;}
.info-card-label{font-size:11px;font-weight:600;letter-spacing:.10em;text-transform:uppercase;color:var(--text-3);margin-bottom:6px;}
.info-card-text{font-size:15px;color:var(--text);line-height:1.5;font-weight:500;}
.info-card-sub{font-size:13px;color:var(--text-3);margin-top:3px;line-height:1.5;}

/* Participant list */
.list-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);}
.list-card-head{padding:14px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:10px;}
.list-card-head h2{font-size:13.5px;font-weight:600;color:var(--text-2);letter-spacing:.01em;}
.list-card-count{font-size:13px;color:var(--text-3);}
.participants-table{width:100%;border-collapse:collapse;}
.participants-table th{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--text-3);padding:10px 16px;background:var(--bg-subtle);border-bottom:1px solid var(--border);text-align:left;}
.participants-table td{padding:11px 16px;border-bottom:1px solid var(--border);font-size:14px;color:var(--text);vertical-align:middle;}
.participants-table tr:last-child td{border-bottom:none;}
.participants-table tbody tr:hover td{background:var(--green-xlight);}
.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;background:var(--green-light);color:var(--green);font-size:11px;font-weight:700;}
@media(max-width:560px){
  .participants-table thead{display:none;}
  .participants-table,.participants-table tbody{display:block;}
  .participants-table tr{display:flex;align-items:center;gap:12px;padding:12px 16px;border-bottom:1px solid var(--border);}
  .participants-table tr:last-child{border-bottom:none;}
  .participants-table td{display:none;padding:0;border:none;}
  .participants-table td.td-name{display:block;flex:1;font-weight:600;font-size:14px;}
  .participants-table td.td-extra{display:block;font-size:12px;color:var(--text-3);}
  .participants-table td.td-rank{display:block;}
}

/* Meine Anmeldungen cards */
.my-signup-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:14px;}
.my-signup-card-head{padding:16px 20px;border-bottom:1px solid var(--border);background:var(--bg-subtle);}
.my-signup-card-title{font-family:var(--font-display);font-size:1.05rem;font-weight:400;color:var(--text);margin-bottom:4px;}
.my-signup-card-meta{font-size:13px;color:var(--text-3);display:flex;flex-wrap:wrap;gap:10px;}
.my-signup-card-body{padding:16px 20px;font-size:14px;color:var(--text-2);display:flex;flex-direction:column;gap:6px;}
.my-signup-card-body strong{color:var(--text);}
.my-signup-card-actions{padding:12px 20px;border-top:1px solid var(--border);display:flex;gap:8px;flex-wrap:wrap;align-items:center;}
.my-signup-locked{font-size:13px;color:var(--text-3);font-style:italic;}

/* Edit form card */
.edit-form-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:18px;}
.edit-form-card-head{padding:15px 20px;border-bottom:1px solid var(--border);background:var(--bg-subtle);}
.edit-form-card-head h2{font-family:var(--font-display);font-size:1.05rem;font-weight:400;}
.edit-form-card-body{padding:20px;display:flex;flex-direction:column;gap:14px;}

/* Generic page card */
.page-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 24px;margin-bottom:16px;}
.empty-state{text-align:center;padding:32px 20px;color:var(--text-3);font-size:14px;}

/* Footer */
.site-footer{background:var(--green);color:rgba(255,255,255,.6);text-align:center;padding:18px 20px;font-size:13px;margin-top:48px;}
.site-footer a{color:rgba(255,255,255,.85);text-decoration:none;}
.site-footer a:hover{color:#fff;text-decoration:underline;}
.build-footer{padding:8px 16px 12px;font-size:11px;color:var(--text-3);text-align:right;opacity:.6;}

/* Login page */
.login-wrap{min-height:calc(100vh - 58px);display:flex;align-items:center;justify-content:center;padding:clamp(24px,5vw,60px) 16px;}
.login-card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:clamp(24px,4vw,40px);width:100%;max-width:420px;}
.login-card h1{font-family:var(--font-display);font-size:1.7rem;font-weight:400;margin-bottom:6px;}
.login-card-sub{font-size:13px;color:var(--text-3);margin-bottom:24px;}
.login-fields{display:flex;flex-direction:column;gap:14px;}

/* Optionsgruppe Ja/Nein buttons */
.og-btn{display:inline-flex;align-items:center;gap:5px;padding:9px 20px;border-radius:var(--radius-md);border:1.5px solid;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s,box-shadow .12s;user-select:none;}
.og-ja{border-color:#3B6D11;color:#3B6D11;}
.og-ja:hover,.og-ja.og-active{background:#EAF3DE;box-shadow:0 0 0 3px rgba(59,109,17,.15);}
.og-nein{border-color:#A32D2D;color:#A32D2D;}
.og-nein:hover,.og-nein.og-active{background:#FCEBEB;box-shadow:0 0 0 3px rgba(163,45,45,.15);}
.og-vielleicht{border-color:#854F0B;color:#854F0B;}
.og-vielleicht:hover,.og-vielleicht.og-active{background:#FAEEDA;box-shadow:0 0 0 3px rgba(133,79,11,.15);}

/* ── Mannschaftsbereich auf index.php ─────────────────────────────────────── */
.subsection-eyebrow{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-3);margin:0 0 10px;}
.team-section{margin-top:36px;border-top:2px solid var(--green);padding-top:24px;}
.team-section-header{display:flex;align-items:center;gap:8px;margin-bottom:16px;}
.team-section-icon{font-size:1.2rem;line-height:1;}
.team-section-label{font-family:var(--font-display);font-size:1.15rem;font-weight:400;color:var(--green);}
