*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #111518;--surface: #1a2128;--surface2: #222c34;--border: #2a3840;--green: #22c55e;--green-dim: rgba(34, 197, 94, .15);--gold: #f0a500;--text: #f1f5f9;--text-muted: #7a8fa0;--danger: #ef4444;--radius: 14px;--radius-sm: 8px}html,body,#root{height:100%;width:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-webkit-tap-highlight-color:transparent}input,button{font-family:inherit;font-size:inherit}button{cursor:pointer;border:none;background:none}.login-page{min-height:100dvh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--bg)}.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:2.5rem 2rem;display:flex;flex-direction:column;align-items:center;gap:.4rem}.login-logo{width:90px;height:90px;border-radius:20px;margin-bottom:.8rem;box-shadow:0 8px 24px #00000080}.login-title{font-size:1.8rem;font-weight:800;color:var(--green);letter-spacing:-.5px}.login-sub{font-size:.9rem;color:var(--text-muted);margin-bottom:1.2rem}.login-form{width:100%;display:flex;flex-direction:column;gap:1rem}.login-field{display:flex;flex-direction:column;gap:.35rem}.login-label{font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.login-input{background:var(--bg);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.85rem 1rem;font-size:1rem;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--green)}.login-error{font-size:.87rem;color:var(--danger);background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:var(--radius-sm);padding:.6rem .8rem;text-align:center}.login-btn{background:var(--green);color:#fff;font-size:1rem;font-weight:700;padding:.95rem;border-radius:var(--radius-sm);transition:background .2s,transform .1s;display:flex;align-items:center;justify-content:center;min-height:50px}.login-btn:active:not(:disabled){transform:scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-spinner{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}.courses-page{display:flex;flex-direction:column;height:100dvh;background:var(--bg);overflow:hidden}.courses-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.courses-logo{width:36px;height:36px;border-radius:8px;flex-shrink:0}.courses-header-center{flex:1;display:flex;flex-direction:column;min-width:0}.courses-title{font-size:1rem;font-weight:800;color:var(--green);line-height:1.2}.courses-date{font-size:.78rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.logout-btn{color:var(--text-muted);padding:.5rem;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:color .15s;flex-shrink:0}.logout-btn:active{color:var(--text)}.date-strip-wrap{background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-shrink:0}.date-strip-wrap::-webkit-scrollbar{display:none}.date-strip{display:flex;gap:.4rem;padding:.6rem 1rem;width:max-content;min-width:100%;justify-content:space-between}.date-chip{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.4rem .65rem;border-radius:10px;border:1.5px solid transparent;background:var(--bg);min-width:44px;transition:background .15s,border-color .15s}.date-chip:active{background:var(--surface2)}.date-chip--active{background:var(--green-dim);border-color:var(--green)}.date-chip-day{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px;color:var(--text-muted)}.date-chip--active .date-chip-day{color:var(--green)}.date-chip-num{font-size:1rem;font-weight:800;color:var(--text);line-height:1.1}.date-chip--active .date-chip-num{color:var(--green)}.date-chip-month{font-size:.62rem;color:var(--text-muted);line-height:1}.courses-past-badge{color:var(--gold);font-weight:700}.course-card--past{opacity:.85}.courses-content{flex:1;overflow-y:auto;padding:1rem;-webkit-overflow-scrolling:touch}.courses-loading,.courses-error,.courses-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:4rem 1rem;color:var(--text-muted);text-align:center}.courses-empty-icon{font-size:2.5rem}.retry-btn{margin-top:.5rem;background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem 1.4rem;font-size:.9rem;font-weight:600}.courses-section-label{font-size:.75rem;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:.75rem}.courses-list{list-style:none;display:flex;flex-direction:column;gap:.6rem}.course-card{width:100%;display:flex;align-items:center;gap:1rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1rem .85rem 1rem 1rem;text-align:left;transition:background .15s,border-color .15s;-webkit-tap-highlight-color:transparent}.course-card:active{background:var(--surface2)}.course-card--now{border-color:var(--green);background:#22c55e12}.course-time-block{display:flex;flex-direction:column;align-items:center;min-width:52px;flex-shrink:0}.course-time{font-size:1rem;font-weight:700;color:var(--text);line-height:1.2}.course-time-sep{font-size:.7rem;color:var(--text-muted);line-height:1}.course-time-end{font-size:.85rem;color:var(--text-muted)}.course-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem}.course-name{font-size:.97rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-trainer{font-size:.8rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.course-right{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.course-count{background:var(--green-dim);color:var(--green);font-size:.82rem;font-weight:700;padding:.25rem .55rem;border-radius:20px;min-width:28px;text-align:center}.course-now-badge{background:var(--green);color:#fff;font-size:.65rem;font-weight:800;letter-spacing:.5px;padding:.22rem .5rem;border-radius:6px}.course-arrow{color:var(--text-muted)}.tab-bar{display:flex;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.tab-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.7rem .5rem;font-size:.88rem;font-weight:600;color:var(--text-muted);border-bottom:2px solid transparent;transition:color .15s,border-color .15s}.tab-btn--active{color:var(--gold);border-bottom-color:var(--gold)}.verkauf-search-content{display:flex!important;flex-direction:column;padding:.75rem 1rem 1rem}.vk-search-wrap{margin-bottom:.75rem}.vk-search-inner{position:relative;display:flex;align-items:center}.member-list{list-style:none;display:flex;flex-direction:column;gap:0;flex:1;overflow-y:auto}.member-row{display:flex;align-items:center;gap:.85rem;padding:.75rem 0;border-bottom:1px solid var(--border)}.member-avatar{width:40px;height:40px;border-radius:50%;border:2px solid;background:var(--surface2);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:800;color:var(--text);flex-shrink:0}.member-name-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:.1rem}.member-name{font-size:.95rem;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-belt{font-size:.75rem;font-weight:600;text-transform:capitalize}.member-btn{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.member-btn--checkin{background:#f0a50026;border:1.5px solid var(--gold);color:var(--gold)}.member-btn--checkin:active{background:#f0a5004d}.member-list-empty{padding:3rem 1rem;text-align:center;color:var(--text-muted);font-size:.9rem}.search-icon{position:absolute;left:.85rem;color:var(--text-muted);pointer-events:none}.checkin-search{width:100%;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:.75rem 2.5rem;font-size:1rem;outline:none;-webkit-appearance:none}.checkin-search:focus{border-color:var(--gold)}.search-clear{position:absolute;right:.5rem;color:var(--text-muted);padding:.5rem;font-size:1.2rem;line-height:1}.qr-btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:var(--surface2);border:1.5px solid var(--border);color:var(--text-muted);flex-shrink:0;transition:border-color .15s,color .15s;-webkit-tap-highlight-color:transparent}.qr-btn:active{border-color:var(--green);color:var(--green)}.qr-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;z-index:300;display:flex;align-items:flex-end;justify-content:center}.qr-sheet{width:100%;max-width:420px;background:var(--surface);border-radius:20px 20px 0 0;padding-bottom:env(safe-area-inset-bottom);animation:sheet-up .22s ease}.qr-sheet-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem .75rem;border-bottom:1px solid var(--border)}.qr-sheet-title{font-size:1rem;font-weight:800;color:var(--text)}.qr-sheet-close{width:30px;height:30px;border-radius:50%;background:var(--surface2);color:var(--text-muted);font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center}.qr-sheet-body{display:flex;flex-direction:column;align-items:center;padding:1.5rem 1.25rem 1.75rem;gap:.75rem}.qr-image{width:min(260px,70vw);height:min(260px,70vw);border-radius:12px;background:#fff;display:block}.qr-hint{font-size:.85rem;color:var(--text-muted);text-align:center;line-height:1.5}.qr-url{font-size:.7rem;color:var(--text-muted);opacity:.6;text-align:center;word-break:break-all}.refresh-fab{position:fixed;bottom:calc(1.5rem + env(safe-area-inset-bottom));right:1.5rem;width:52px;height:52px;background:var(--green);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #22c55e66;transition:transform .15s}.refresh-fab:active{transform:scale(.93)}.checkin-page{display:flex;flex-direction:column;height:100dvh;background:var(--bg);overflow:hidden}.checkin-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.back-btn{color:var(--green);padding:.4rem;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background .15s;flex-shrink:0}.back-btn:active{background:var(--green-dim)}.checkin-header-info{flex:1;display:flex;flex-direction:column;min-width:0}.checkin-course-name{font-size:.97rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checkin-course-time{font-size:.78rem;color:var(--text-muted)}.checkin-past-label{color:var(--gold);font-weight:600}.checkin-count-badge{display:flex;flex-direction:column;align-items:center;background:var(--green-dim);border:1px solid rgba(34,197,94,.3);border-radius:10px;padding:.3rem .7rem;flex-shrink:0}.checkin-count-num{font-size:1.1rem;font-weight:800;color:var(--green);line-height:1.1}.checkin-count-label{font-size:.62rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.3px}.checkin-search-wrap{padding:.75rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.checkin-search-inner{position:relative;display:flex;align-items:center}.search-icon{position:absolute;left:.8rem;color:var(--text-muted);pointer-events:none}.checkin-search{width:100%;background:var(--bg);border:1.5px solid var(--border);border-radius:10px;color:var(--text);padding:.7rem 2.4rem;font-size:.95rem;outline:none;transition:border-color .15s}.checkin-search:focus{border-color:var(--green)}.search-clear{position:absolute;right:.7rem;color:var(--text-muted);font-size:1.2rem;line-height:1;padding:.2rem}.sort-bar{display:flex;gap:.4rem;padding:.6rem 1rem;background:var(--surface);border-bottom:1px solid var(--border);overflow-x:auto;scrollbar-width:none;flex-shrink:0}.sort-bar::-webkit-scrollbar{display:none}.sort-chip{white-space:nowrap;padding:.35rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;border:1.5px solid var(--border);background:var(--bg);color:var(--text-muted);flex-shrink:0;transition:background .15s,border-color .15s,color .15s}.sort-chip--active{background:var(--green-dim);border-color:var(--green);color:var(--green)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:200;display:flex;align-items:flex-end}.modal-sheet{width:100%;max-height:70dvh;background:var(--surface);border-radius:18px 18px 0 0;display:flex;flex-direction:column;animation:sheet-up .22s ease;padding-bottom:env(safe-area-inset-bottom)}@keyframes sheet-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1rem .75rem;border-bottom:1px solid var(--border);flex-shrink:0}.modal-title{font-size:1rem;font-weight:800;color:var(--green)}.modal-close{width:30px;height:30px;border-radius:50%;background:var(--surface2);color:var(--text-muted);font-size:1.3rem;line-height:1;display:flex;align-items:center;justify-content:center}.modal-list{list-style:none;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.4rem 0}.modal-empty{text-align:center;padding:2rem;color:var(--text-muted);font-size:.9rem}.modal-member-row{display:flex;align-items:center;gap:.85rem;padding:.6rem 1rem;border-bottom:1px solid var(--border)}.modal-member-row:last-child{border-bottom:none}.modal-member-info{display:flex;flex-direction:column;gap:.1rem}.modal-member-name{font-size:.95rem;font-weight:600;color:var(--text)}.modal-member-belt{font-size:.72rem;font-weight:600;text-transform:capitalize}.checkin-list-wrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.checkin-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;color:var(--text-muted)}.checkin-error{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem 1rem;color:var(--text-muted);text-align:center}.spinner{width:28px;height:28px;border:3px solid rgba(34,197,94,.2);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}.retry-btn{background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:var(--radius-sm);padding:.6rem 1.4rem;font-size:.9rem;font-weight:600}.member-list{list-style:none;padding:.5rem 0}.member-list-empty{text-align:center;padding:2rem;color:var(--text-muted);font-size:.9rem}.member-row{display:flex;align-items:center;gap:.85rem;padding:.7rem 1rem;border-bottom:1px solid var(--border);transition:background .1s}.member-row:last-child{border-bottom:none}.member-row--in{background:#22c55e0d}.member-avatar{width:42px;height:42px;border-radius:50%;background:var(--surface2);border:2px solid;display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:800;color:var(--text);flex-shrink:0}.member-name-wrap{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.member-name{font-size:.95rem;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-belt{font-size:.72rem;font-weight:600;text-transform:capitalize}.member-btn{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .1s}.member-btn:active:not(:disabled){transform:scale(.9)}.member-btn--checkin{background:var(--surface2);border:2px solid var(--border);color:var(--text-muted)}.member-btn--checkin:hover{border-color:var(--green);color:var(--green)}.member-btn--checked{background:var(--green);color:#fff;border:2px solid var(--green)}.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--text-muted);border-radius:50%;animation:spin .7s linear infinite}.toast{position:fixed;bottom:calc(1.5rem + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);white-space:nowrap;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:.7rem 1.4rem;border-radius:30px;font-size:.87rem;font-weight:600;box-shadow:0 4px 20px #00000080;animation:toast-in .2s ease;z-index:100}.toast--success{border-color:var(--green);color:var(--green)}.toast--error{border-color:var(--danger);color:var(--danger)}.toast--info{border-color:var(--text-muted);color:var(--text-muted)}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.offline-banner{background:#ef44441f;border-bottom:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:.78rem;font-weight:600;padding:.4rem 1rem;display:flex;align-items:center;gap:.4rem;flex-shrink:0}.offline-banner--syncing{background:#f0a5001a;border-color:#f0a5004d;color:var(--gold)}.progress-bar-wrap{padding:.4rem 1rem .3rem;background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:.6rem;flex-shrink:0}.progress-bar-track{flex:1;height:5px;background:var(--border);border-radius:99px;overflow:hidden}.progress-bar-fill{height:100%;background:var(--green);border-radius:99px;transition:width .4s ease}.progress-bar-label{font-size:.72rem;font-weight:700;color:var(--text-muted);white-space:nowrap;flex-shrink:0}.member-name-row{display:flex;align-items:center;gap:.35rem}.member-sub-row{display:flex;align-items:center;gap:.5rem}.member-badge{font-size:.78rem;line-height:1}.member-badge--zehner{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3);border-radius:4px;padding:.1rem .3rem;font-weight:700;font-size:.7rem}.member-away{font-size:.73rem;font-weight:700}.member-btn--offline{background:#f0a50026;border:1.5px solid var(--gold);color:var(--gold);width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.member-name-wrap--clickable{cursor:pointer;border-radius:6px;padding:.1rem .3rem;margin:-.1rem -.3rem;transition:background .12s}.member-name-wrap--clickable:active{background:#ffffff0d}.injury-sheet{width:100%;max-height:85dvh;background:var(--surface);border-radius:18px 18px 0 0;display:flex;flex-direction:column;animation:sheet-up .22s ease;padding-bottom:env(safe-area-inset-bottom)}.injury-sheet-title{font-size:1rem;font-weight:800;color:var(--text)}.injury-sheet-body{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:1rem;display:flex;flex-direction:column;gap:.85rem}.injury-error{background:#ef44441f;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#f87171;font-size:.85rem;padding:.5rem .8rem}.injury-label{display:flex;flex-direction:column;gap:.35rem;font-size:.8rem;font-weight:600;color:var(--text-muted)}.injury-row{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}.injury-input{background:var(--bg);border:1.5px solid var(--border);border-radius:8px;color:var(--text);padding:.55rem .7rem;font-size:.9rem;width:100%;box-sizing:border-box;outline:none;transition:border-color .15s;-webkit-appearance:none}.injury-input:focus{border-color:var(--green)}.injury-textarea{resize:none;font-family:inherit;line-height:1.4}.injury-submit-btn{width:100%;padding:.85rem;background:var(--green);color:#fff;border-radius:10px;font-size:.97rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:.4rem;margin-top:.2rem;transition:opacity .15s}.injury-submit-btn:disabled{opacity:.6}.modal-avg{font-size:.82rem;font-weight:600;color:var(--text-muted)}.choice-sheet{background:var(--card-bg, #1e1e2e);border-radius:16px 16px 0 0;width:100%;max-width:480px;padding-bottom:env(safe-area-inset-bottom)}.choice-buttons{display:flex;flex-direction:column;gap:12px;padding:16px}.choice-btn{width:100%;padding:18px;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.choice-btn:active{opacity:.8}.choice-btn--verkauf{background:#16a34a;color:#fff}.choice-btn--injury{background:#dc2626;color:#fff}.checkin-absent-badge{display:flex;flex-direction:column;align-items:center;background:#ef444426;border:1px solid rgba(239,68,68,.35);border-radius:10px;padding:6px 12px;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none}.checkin-absent-badge:active{background:#ef444440}.checkin-absent-num{font-size:1.1rem;font-weight:700;color:#f87171;line-height:1}.checkin-absent-label{font-size:.6rem;color:#f87171;text-transform:uppercase;letter-spacing:.05em}.member-row--absent{opacity:.55}.member-row--absent .member-name{text-decoration:line-through;text-decoration-color:#ef444480}.member-badge--absent{font-size:.85rem}.vk-page{display:flex;flex-direction:column;height:100dvh;background:var(--bg);overflow:hidden}.vk-header{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;padding-top:calc(.75rem + env(safe-area-inset-top));background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.vk-back{color:var(--text-muted);padding:.4rem;border-radius:8px;display:flex;align-items:center;flex-shrink:0}.vk-back:active{color:var(--text)}.vk-header-info{flex:1;display:flex;flex-direction:column;min-width:0}.vk-member-name{font-size:1rem;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vk-header-sub{font-size:.75rem;color:var(--gold);font-weight:600}.vk-content{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:.75rem 1rem .5rem}.vk-loading,.vk-error{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1rem;color:var(--text-muted)}.vk-kategorie{margin-bottom:1.25rem}.vk-kat-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);margin-bottom:.6rem;display:flex;align-items:center;gap:.35rem}.vk-artikel-grid{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}.vk-artikel-card{background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:.85rem .75rem;display:flex;flex-direction:column;gap:.35rem;transition:border-color .15s,background .15s}.vk-artikel-card--selected{border-color:var(--gold);background:#f0a50012}.vk-artikel-card--out{opacity:.45}.vk-artikel-name{font-size:.88rem;font-weight:700;color:var(--text);line-height:1.3}.vk-artikel-preis{font-size:.95rem;font-weight:800;color:var(--gold)}.vk-artikel-out{font-size:.75rem;color:var(--danger);font-weight:600}.vk-artikel-controls{display:flex;align-items:center;gap:.5rem;margin-top:.25rem}.vk-ctrl-btn{width:32px;height:32px;border-radius:8px;background:var(--surface2);border:1px solid var(--border);color:var(--text);font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.vk-ctrl-btn--add{background:var(--gold);border-color:var(--gold);color:#000}.vk-ctrl-count{font-size:1rem;font-weight:800;color:var(--text);min-width:20px;text-align:center}.vk-add-btn{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:8px;color:var(--text-muted);font-size:.8rem;font-weight:600;padding:.45rem 0;text-align:center;margin-top:.25rem}.vk-add-btn:active{background:var(--gold);color:#000;border-color:var(--gold)}.vk-checkout{background:var(--surface);border-top:1px solid var(--border);padding:.75rem 1rem;padding-bottom:calc(.75rem + env(safe-area-inset-bottom));flex-shrink:0;display:flex;flex-direction:column;gap:.6rem}.vk-cart-items{display:flex;flex-direction:column;gap:.25rem;max-height:90px;overflow-y:auto}.vk-cart-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.vk-cart-name{color:var(--text-muted);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.vk-cart-price{color:var(--text);font-weight:700;flex-shrink:0;margin-left:.5rem}.vk-payment-row{display:flex;gap:.5rem}.vk-pay-btn{flex:1;padding:.55rem .25rem;border-radius:8px;border:1.5px solid var(--border);background:var(--surface2);color:var(--text-muted);font-size:.82rem;font-weight:600;text-align:center;transition:all .15s}.vk-pay-btn--active{border-color:var(--gold);background:#f0a50026;color:var(--gold)}.vk-pay-btn--lastschrift{flex:1.4}.vk-lastschrift-hint{font-size:.78rem;color:var(--text-muted);text-align:center;margin-top:.25rem;padding:0 .5rem;line-height:1.4}.vk-submit-btn{width:100%;background:var(--gold);color:#000;font-weight:800;font-size:1rem;padding:.9rem;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;gap:.5rem}.vk-submit-btn:active{opacity:.85}.vk-submit-btn:disabled{opacity:.5}.vk-success{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;height:100dvh;padding:2rem;background:var(--bg)}.vk-success-icon{width:72px;height:72px;background:#22c55e26;border:2px solid var(--green);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;color:var(--green)}.vk-success-name{font-size:1.3rem;font-weight:800;color:var(--text)}.vk-success-text{font-size:1rem;color:var(--green);font-weight:600}.vk-success-btn{width:100%;max-width:300px;background:var(--gold);color:#000;font-weight:800;font-size:1rem;padding:.9rem;border-radius:var(--radius-sm);text-align:center}.vk-success-btn--sec{background:var(--surface2);color:var(--text-muted);border:1px solid var(--border);font-weight:600}.spinner{width:32px;height:32px;border:3px solid rgba(34,197,94,.2);border-top-color:var(--green);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.btn-spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(0,0,0,.3);border-top-color:#000;border-radius:50%;animation:spin .7s linear infinite}.toast{position:fixed;bottom:calc(6rem + env(safe-area-inset-bottom));left:50%;transform:translate(-50%);background:var(--surface2);color:var(--text);padding:.75rem 1.5rem;border-radius:999px;font-size:.9rem;font-weight:600;white-space:nowrap;border:1px solid var(--border);z-index:100}.toast--error{background:#ef444426;border-color:var(--danger);color:var(--danger)}*{box-sizing:border-box;margin:0;padding:0}.sc-page{display:flex;flex-direction:column;min-height:100dvh;background:#111518;color:#e8eaed;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.sc-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;padding-top:calc(1rem + env(safe-area-inset-top));background:#1a1f24;border-bottom:1px solid #2a3038;flex-shrink:0}.sc-header-logo{font-size:1.1rem;font-weight:900;color:#22c55e;letter-spacing:1px}.sc-kurs-info{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem}.sc-kurs-name{font-size:.9rem;font-weight:700;color:#e8eaed}.sc-kurs-time{font-size:.75rem;color:#8b9bb4}.sc-error{background:#ef44441f;border-bottom:1px solid rgba(239,68,68,.3);color:#ef4444;font-size:.85rem;font-weight:600;padding:.75rem 1.25rem;text-align:center}.sc-loading{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:4rem 1rem;color:#8b9bb4;font-size:.9rem}.sc-spinner{width:32px;height:32px;border:3px solid rgba(34,197,94,.2);border-top-color:#22c55e;border-radius:50%;animation:sc-spin .7s linear infinite}@keyframes sc-spin{to{transform:rotate(360deg)}}.sc-search-wrap{position:relative;display:flex;align-items:center;padding:.85rem 1.25rem;background:#1a1f24;border-bottom:1px solid #2a3038;flex-shrink:0}.sc-search-icon{position:absolute;left:2.1rem;color:#8b9bb4;pointer-events:none}.sc-search{width:100%;background:#111518;border:1.5px solid #2a3038;border-radius:12px;color:#e8eaed;padding:.8rem 2.6rem;font-size:1rem;outline:none;transition:border-color .15s;-webkit-appearance:none}.sc-search:focus{border-color:#22c55e}.sc-clear{position:absolute;right:1.9rem;color:#8b9bb4;font-size:1.3rem;line-height:1;padding:.3rem;background:none;border:none;cursor:pointer}.sc-list-wrap{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch}.sc-list{list-style:none;padding:.5rem 0}.sc-hint{text-align:center;padding:3rem 1rem;color:#8b9bb4;font-size:.9rem}.sc-member-row{display:flex;align-items:center;gap:.9rem;padding:.85rem 1.25rem;border-bottom:1px solid #1e252c;transition:background .1s}.sc-member-row:last-child{border-bottom:none}.sc-member-row:active{background:#1a1f24}.sc-avatar{width:44px;height:44px;border-radius:50%;background:#1e252c;border:2.5px solid;display:flex;align-items:center;justify-content:center;font-size:.95rem;font-weight:800;color:#e8eaed;flex-shrink:0}.sc-member-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.sc-member-name{font-size:1rem;font-weight:600;color:#e8eaed;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-member-belt{font-size:.73rem;font-weight:600;text-transform:capitalize}.sc-checkin-btn{min-width:108px;height:42px;background:#22c55e;color:#fff;border:none;border-radius:10px;font-size:.88rem;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;cursor:pointer;transition:transform .1s,opacity .15s;-webkit-tap-highlight-color:transparent}.sc-checkin-btn:active:not(:disabled){transform:scale(.94)}.sc-checkin-btn:disabled{opacity:.6}.sc-btn-spinner{width:18px;height:18px;border:2.5px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:sc-spin .7s linear infinite}.sc-success-page{align-items:center;justify-content:center;gap:1rem;padding:2rem;text-align:center}.sc-success-icon{font-size:4.5rem;line-height:1;margin-bottom:.5rem}.sc-success-name{font-size:2rem;font-weight:900;color:#22c55e}.sc-success-msg{font-size:1.1rem;color:#8b9bb4}.sc-success-kurs{font-size:.9rem;color:#8b9bb4;background:#1a1f24;border:1px solid #2a3038;border-radius:10px;padding:.6rem 1.2rem;margin-top:.5rem}.sc-back-btn{margin-top:1.5rem;background:#1a1f24;border:1.5px solid #2a3038;color:#e8eaed;border-radius:12px;padding:.85rem 2.5rem;font-size:1rem;font-weight:700;cursor:pointer;transition:background .15s}.sc-back-btn:active{background:#2a3038}
