*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{color:#1a1a2e;background:#f0f2f8;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{color:#fff;background:#1e1e3f;flex-direction:column;width:220px;min-width:220px;padding:0;display:flex}.sidebar-logo{border-bottom:1px solid #ffffff1a;align-items:center;gap:10px;padding:20px 18px;font-size:16px;font-weight:700;display:flex}.logo-circle{background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:16px;font-weight:800;display:flex}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 10px;display:flex}.nav-item{color:#ffffffa6;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:10px 12px;font-size:13.5px;transition:background .15s,color .15s;display:flex}.nav-item:hover{color:#fff;background:#ffffff14}.nav-item.active{color:#fff;background:#6366f1}.nav-icon{text-align:center;width:20px;font-size:16px}.sidebar-footer{border-top:1px solid #ffffff1a;padding:14px}.user-info{align-items:center;gap:10px;margin-bottom:10px;display:flex}.user-avatar{background:#6366f1;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:12px;font-weight:700;display:flex}.user-name{color:#fff;font-size:13px;font-weight:600}.user-role{color:#ffffff80;font-size:11px}.logout-btn{justify-content:center;width:100%;padding:6px 0;font-size:12px;color:#ffffff80!important}.logout-btn:hover{color:#fff!important;background:#ffffff14!important}.main-content{background:#f0f2f8;flex:1;overflow-y:auto}.page-content{max-width:1200px;padding:28px 32px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:#1a1a2e;font-size:22px;font-weight:700}.page-sub{color:#6b7280;margin-top:2px;font-size:13px}.stats-row{flex-wrap:wrap;gap:14px;margin-bottom:28px;display:flex}.stat-card{border-left:4px solid var(--accent,#6366f1);background:#fff;border-radius:12px;flex:1;min-width:130px;padding:16px 18px;box-shadow:0 1px 4px #0000000f}.stat-value{color:#1a1a2e;font-size:24px;font-weight:800}.stat-label{color:#6b7280;margin-top:2px;font-size:12px}.stat-sub{color:#9ca3af;margin-top:2px;font-size:11px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:24px;display:grid}.info-card{background:#fff;border:1.5px solid #0000;border-radius:12px;padding:16px 18px;transition:border-color .15s,box-shadow .15s;box-shadow:0 1px 4px #0000000f}.info-card.clickable{cursor:pointer}.info-card.clickable:hover{border-color:#6366f1;box-shadow:0 4px 12px #6366f11f}.info-card-title{margin-bottom:6px;font-size:14px;font-weight:700}.info-card-meta{color:#6b7280;font-size:12px}.info-card-action{color:#6366f1;margin-top:8px;font-size:12px}.section-block{background:#fff;border-radius:12px;margin-bottom:20px;padding:20px 22px;box-shadow:0 1px 4px #0000000f}.section-block h2{color:#1a1a2e;margin-bottom:14px;font-size:15px;font-weight:700}.table-wrapper{background:#fff;border-radius:12px;margin-bottom:24px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.04em;background:#f8f9ff;border-bottom:1px solid #e5e7eb;padding:11px 14px;font-size:12px;font-weight:600}.data-table td{color:#374151;border-bottom:1px solid #f3f4f6;padding:12px 14px;font-size:13.5px}.data-table tr:last-child td{border-bottom:none}.data-table tr.clickable{cursor:pointer}.data-table tr.clickable:hover td{background:#fafbff}.data-table .empty{text-align:center;color:#9ca3af;padding:32px}.data-table .total-row td{background:#f8f9ff;font-weight:600}.modal-backdrop{z-index:1000;background:#0006;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal-box{background:#fff;border-radius:16px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0003}.modal-box.modal-wide{max-width:820px}.modal-header{z-index:1;background:#fff;border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:18px 22px;display:flex;position:sticky;top:0}.modal-header h2{font-size:16px;font-weight:700}.close-btn{color:#6b7280;cursor:pointer;background:#f3f4f6;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;display:flex}.close-btn:hover{background:#e5e7eb}.modal-body{padding:20px 22px}.modal-two-col{grid-template-columns:1fr 1fr;gap:24px;display:grid}.modal-col h3{margin-bottom:12px;font-size:14px;font-weight:700}.modal-col-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-col-header h3{margin-bottom:0}.modal-stats-row{color:#374151;gap:20px;margin-bottom:16px;font-size:13px;display:flex}.field{margin-bottom:14px}.field label{color:#374151;text-transform:uppercase;letter-spacing:.04em;margin-bottom:5px;font-size:12px;font-weight:600;display:block}.field input,.field select,input,select{color:#1a1a2e;background:#fff;border:1.5px solid #e5e7eb;border-radius:8px;outline:none;width:100%;padding:9px 12px;font-size:14px;transition:border-color .15s}input:focus,select:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f11f}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;align-items:center;gap:6px;padding:9px 16px;font-size:13px;font-weight:600;transition:background .15s,transform 80ms;display:inline-flex}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{color:#fff;background:#6366f1}.btn-primary:hover:not(:disabled){background:#4f46e5}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover:not(:disabled){background:#e5e7eb}.btn-success{color:#065f46;background:#d1fae5}.btn-success:hover:not(:disabled){background:#a7f3d0}.btn-danger{color:#991b1b;background:#fee2e2}.btn-danger:hover:not(:disabled){background:#fecaca}.btn-ghost{color:#6b7280;background:0 0}.btn-ghost:hover:not(:disabled){background:#f3f4f6}.btn-sm{border-radius:6px;padding:5px 10px;font-size:12px}.btn-full{justify-content:center;width:100%;margin-top:6px}.badge{white-space:nowrap;border-radius:20px;padding:3px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-default{color:#374151;background:#f3f4f6}.badge-success{color:#065f46;background:#d1fae5}.badge-neutral{color:#6b7280;background:#f3f4f6}.badge-admin{color:#5b21b6;background:#ede9fe}.progress-bar{background:#f0f2f8;border-radius:99px;height:6px;margin-top:6px;overflow:hidden}.progress-fill{background:#6366f1;border-radius:99px;height:100%;transition:width .3s}.aufgaben-list{flex-direction:column;gap:14px;display:flex}.aufgabe-row{background:#f8f9ff;border-radius:10px;padding:12px 14px}.aufgabe-info{justify-content:space-between;margin-bottom:6px;display:flex}.aufgabe-name{font-size:13.5px;font-weight:600}.aufgabe-stat{color:#6b7280;font-size:12px}.sponsor-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;display:grid}.sponsor-card{background:#f8f9ff;border:1.5px solid #e5e7eb;border-radius:10px;padding:14px}.sponsor-name{margin-bottom:6px;font-size:13px;font-weight:700}.sponsor-amount{color:#f59e0b;font-size:18px;font-weight:800}.sponsor-points{color:#6b7280;font-size:12px}.sponsor-sachspende{color:#9ca3af;margin-top:4px;font-size:11px}.punkte-breakdown{flex-direction:column;gap:0;display:flex}.punkte-row{background:#f8f9ff;border-bottom:1px solid #e5e7eb;justify-content:space-between;padding:10px 14px;font-size:13.5px;display:flex}.punkte-row.total{color:#5b21b6;background:#ede9fe;border-bottom:none;border-radius:0 0 8px 8px;font-weight:700}.anwesenheit-list{flex-direction:column;gap:8px;display:flex}.anwesenheit-row{background:#f8f9ff;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 14px;font-size:13.5px;display:flex}.anwesenheit-row.anwesend{background:#d1fae5}.person-checklist{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.person-check-row{background:#f8f9ff;border:1.5px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;font-size:13.5px;display:flex}.person-check-row.active{background:#ede9fe;border-color:#c4b5fd}.person-check-row input[type=checkbox]{flex-shrink:0;width:16px;height:16px}.alle-anwesend-row{cursor:pointer;background:#eef2ff;border-color:#c7d2fe;margin-bottom:10px}.termin-list{flex-direction:column;gap:6px;display:flex}.termin-row{background:#f8f9ff;border:1.5px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;padding:10px 14px;font-size:13.5px;display:flex}.termin-row.clickable{cursor:pointer}.termin-row.clickable:hover{background:#eef0ff;border-color:#6366f1}.aufgabe-person-row{background:#f8f9ff;border-radius:8px;align-items:center;gap:12px;margin-bottom:6px;padding:8px 12px;font-size:13.5px;display:flex}.stueck-editor{align-items:center;gap:6px;margin-left:auto;display:flex}.stueck-editor input{text-align:center;width:70px;padding:5px 8px}.two-panel{gap:20px;height:calc(100vh - 120px);display:flex}.panel{background:#fff;border-radius:12px;flex:1;padding:18px;overflow-y:auto;box-shadow:0 1px 4px #0000000f}.panel-narrow{max-width:240px}.panel h3{border-bottom:1px solid #f0f0f0;margin-bottom:12px;padding-bottom:10px;font-size:14px;font-weight:700}.panel-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.panel-header h3{border:none;margin:0;padding:0}.person-list{flex-direction:column;gap:4px;display:flex}.person-list-item{cursor:pointer;border:1.5px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;padding:10px 12px;font-size:13.5px;transition:background .12s;display:flex}.person-list-item:hover{background:#f8f9ff}.person-list-item.active{background:#ede9fe;border-color:#c4b5fd;font-weight:600}.search-bar{margin-bottom:16px}.search-bar input{max-width:360px;padding-left:14px}.action-btns{flex-wrap:wrap;gap:6px;display:flex}.login-page{background:linear-gradient(135deg,#1e1e3f 0%,#3730a3 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:20px;width:100%;max-width:400px;padding:36px 32px;box-shadow:0 24px 60px #0000004d}.login-logo{text-align:center;margin-bottom:28px}.login-logo .logo-circle{width:52px;height:52px;margin:0 auto 10px;font-size:24px}.login-logo h1{color:#1a1a2e;margin-bottom:4px;font-size:22px;font-weight:800}.login-logo p{color:#6b7280;font-size:13.5px}.login-hint{text-align:center;color:#9ca3af;margin-top:14px;font-size:11.5px}.center{justify-content:center;align-items:center;display:flex}.fullscreen{height:100vh}.muted{color:#9ca3af;font-size:12px}.empty-hint{color:#9ca3af;padding:16px 0;font-size:13px}.empty-state{color:#9ca3af;justify-content:center;align-items:center;height:200px;display:flex}.mt-2{margin-top:12px}.error-box{color:#991b1b;background:#fee2e2;border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:13px}.sponsor-table-wrapper{overflow-x:auto}.spinner{border:3px solid #e5e7eb;border-top-color:#6366f1;border-radius:50%;width:32px;height:32px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.topbar{color:#fff;z-index:200;background:#1e1e3f;align-items:center;gap:12px;padding:10px 14px;display:none;position:sticky;top:0}.topbar-logo{align-items:center;gap:8px;font-weight:700;display:flex}.menu-toggle,.menu-close{color:#fff;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:22px;line-height:1}.menu-close{margin-left:auto;font-size:16px;display:none}.sidebar-overlay{z-index:250;background:#00000073;display:none;position:fixed;inset:0}.toast-container{z-index:2000;flex-direction:column;gap:10px;max-width:min(360px,100vw - 40px);display:flex;position:fixed;bottom:20px;right:20px}.toast{color:#fff;border-radius:10px;align-items:center;gap:10px;padding:12px 14px;font-size:13.5px;font-weight:500;animation:.2s ease-out toast-in;display:flex;box-shadow:0 8px 24px #0000002e}.toast button{color:#fff;cursor:pointer;background:#fff3;border:none;border-radius:6px;width:auto;margin-left:auto;padding:2px 8px;font-size:12px}.toast-error{background:#dc2626}.toast-success{background:#059669}.toast-info{background:#4f46e5}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.app-layout{flex-direction:column;height:auto;min-height:100vh;overflow:visible}.topbar{display:flex}.sidebar{z-index:300;width:250px;min-width:250px;transition:transform .22s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.menu-close{display:inline-block}.main-content{overflow-y:visible}.page-content{padding:18px 16px}.page-header{flex-wrap:wrap;gap:10px}.modal-two-col{grid-template-columns:1fr;gap:16px}.stats-row{gap:10px}.stat-card{min-width:45%}.two-panel{flex-direction:column;height:auto}.panel-narrow{max-width:none}.action-btns .btn{flex:auto}}.sidebar-overlay{display:none}@media (width<=768px){.sidebar-overlay{display:block}}.multiselect-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.multiselect-toolbar-btns{gap:6px;display:flex}.klasse-gruppe{margin-bottom:10px}.klasse-header{background:#eef0ff;border-radius:6px;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px;padding:6px 10px;display:flex;position:sticky;top:0}.klasse-name{color:#4338ca;text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:700}.klasse-toggle{color:#6366f1;cursor:pointer;background:0 0;border:none;padding:2px 4px;font-size:12px;font-weight:600}.klasse-toggle:hover:not(:disabled){text-decoration:underline}.klasse-toggle:disabled{opacity:.4;cursor:not-allowed}label.person-check-row{cursor:pointer}.voll-check{white-space:nowrap;cursor:pointer;align-items:center;gap:5px;margin-left:auto;display:inline-flex}.voll-check input[type=checkbox]{width:15px;height:15px}.aufgabe-person-row .stueck-editor{margin-left:0}
