*{box-sizing:border-box}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,sans-serif;background:#f3f4f6;color:#1f2937}#root{min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(circle at top left,rgba(34,197,94,.18),transparent 32%),linear-gradient(180deg,#f8fafc,#eef2f7)}.app-header{display:flex;justify-content:space-between;align-items:center;gap:24px;padding:18px 24px;border-bottom:1px solid rgba(148,163,184,.2);background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.app-brand{display:flex;flex-direction:row;align-items:center;gap:12px}.app-brand-logo{height:56px;width:auto;flex-shrink:0}.app-brand-text{display:flex;flex-direction:column;gap:2px}.app-brand h1{margin:0;font-size:1.35rem}.app-brand-kicker{font-size:.72rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#15803d}.app-nav{display:flex;align-items:center;gap:10px}.app-nav-link{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:999px;text-decoration:none;color:#1f2937;background:#fff;border:1px solid rgba(148,163,184,.25);font-weight:600}.app-nav-button{font:inherit;cursor:pointer}.app-nav-link.active{background:#14532d;color:#fff;border-color:#14532d}.app-main{flex:1;min-height:0}.editor-layout{display:flex;flex-direction:column;height:100%;min-height:0}.editor-document-bar{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:12px 16px;background:#fff;border-bottom:1px solid #e5e7eb}.editor-document-fields{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.editor-back-button{min-height:42px;padding:0 14px;border:1px solid #cbd5e1;border-radius:10px;background:#fff;color:#0f172a;font:inherit;font-weight:600;cursor:pointer;flex-shrink:0}.editor-document-title,.editor-document-meta,.editor-description-input{border:1px solid #cbd5e1;border-radius:10px;background:#f8fafc;color:#0f172a;font:inherit}.editor-document-title{flex:1;min-width:180px;padding:10px 12px;font-weight:600}.editor-document-meta{width:140px;padding:10px 12px}.editor-document-actions{display:flex;align-items:center;gap:12px}.editor-save-state{font-size:13px;color:#166534}.editor-save-state-error{color:#b91c1c}.editor-save-button{min-height:42px;padding:0 16px;border:none;border-radius:10px;background:#14532d;color:#fff;font-weight:700;cursor:pointer}.editor-save-button:disabled{cursor:wait;opacity:.7}.editor-description-bar{padding:10px 16px 12px;background:#fff;border-bottom:1px solid #e5e7eb}.editor-template-banner{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f8fafc;border-bottom:1px solid #e5e7eb}.editor-template-badge{display:inline-flex;align-items:center;min-height:28px;padding:0 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:12px;font-weight:700}.editor-template-text{color:#334155;font-size:14px;font-weight:600}.editor-description-input{width:100%;resize:vertical;padding:10px 12px}.toolbar{display:flex;flex-direction:row;gap:4px;padding:8px;background:#fff;border-bottom:1px solid #e5e7eb;overflow-x:auto}.toolbar-btn{padding:8px 14px;border:1px solid #d1d5db;background:#f9fafb;border-radius:6px;cursor:pointer;font-size:14px;white-space:nowrap}.toolbar-btn:hover{background:#e5e7eb}.toolbar-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.editor-haupt-zeile{display:flex;flex:1;overflow:hidden}.editor-canvas-wrapper{position:relative;flex:1;display:flex;justify-content:center;align-items:flex-start;overflow:auto;background:#d1d5db;padding:16px}.editor-reference-panel{width:320px;min-width:320px;display:flex;flex-direction:column;gap:12px;padding:16px;background:#f8fafc;border-left:1px solid #e5e7eb;overflow-y:auto}.editor-reference-title{font-size:13px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#64748b}.editor-reference-image{width:100%;height:auto;display:block;border-radius:16px;border:1px solid rgba(148,163,184,.22);background:#fff;box-shadow:0 18px 30px #0f172a14}.properties-panel{width:280px;min-width:280px;background:#fff;border-left:1px solid #e5e7eb;overflow-y:auto;padding:0 0 16px}.pp-titel{font-size:13px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;padding:12px 16px 8px;border-bottom:1px solid #f3f4f6}.pp-gruppe{padding:12px 16px 4px;border-bottom:1px solid #f3f4f6}.pp-gruppe-titel{font-size:11px;font-weight:600;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px}.pp-zeile{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.pp-label{font-size:13px;color:#374151}.pp-steuerung{display:flex;align-items:center;gap:6px}.pp-radio-gruppe{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:4px}.pp-radio-btn{padding:4px 10px;font-size:12px;border:1px solid #d1d5db;background:#f9fafb;border-radius:4px;cursor:pointer;color:#374151}.pp-radio-btn:hover{background:#e5e7eb}.pp-radio-btn.aktiv{background:#2563eb;color:#fff;border-color:#2563eb}.pp-farb-wrapper{position:relative;display:flex;align-items:center;gap:6px}.pp-farb-vorschau{width:24px;height:24px;border-radius:4px;border:1px solid #d1d5db;cursor:pointer}.pp-farb-input{position:absolute;opacity:0;width:24px;height:24px;cursor:pointer;left:0;top:0}.pp-farb-reihe{display:flex;align-items:center;gap:6px}.pp-zahl-input{width:60px;padding:4px 6px;font-size:13px;border:1px solid #d1d5db;border-radius:4px;text-align:right}.pp-loeschen-btn{width:100%;padding:8px;background:#fee2e2;color:#dc2626;border:1px solid #fca5a5;border-radius:6px;cursor:pointer;font-size:13px;font-weight:500;margin-top:4px}.pp-loeschen-btn:hover{background:#fecaca}.field-background{position:absolute;top:16px;left:50%;transform:translate(-50%);line-height:0;box-shadow:0 2px 12px #00000040}.editor-stage{position:relative;z-index:1}.placement-hint{position:absolute;top:4px;left:50%;transform:translate(-50%);z-index:10;background:#1f2937;color:#fff;padding:6px 14px;border-radius:6px;font-size:13px}.timeline{display:flex;align-items:center;gap:16px;padding:10px 16px;background:#fff;border-top:1px solid #e5e7eb}.timeline-play{padding:8px 16px;border-radius:6px;border:none;background:#16a34a;color:#fff;cursor:pointer;font-size:14px}.timeline-track{display:flex;align-items:center;gap:8px;overflow-x:auto}.timeline-frame-wrapper{position:relative}.timeline-frame{width:36px;height:36px;border-radius:6px;border:1px solid #d1d5db;background:#f9fafb;cursor:pointer}.timeline-frame.active{background:#2563eb;color:#fff;border-color:#2563eb}.timeline-frame-delete{position:absolute;top:-6px;right:-6px;width:16px;height:16px;font-size:10px;line-height:1;border-radius:50%;border:none;background:#dc2626;color:#fff;cursor:pointer}.timeline-add{padding:8px 14px;border-radius:6px;border:1px dashed #9ca3af;background:#fff;cursor:pointer;font-size:13px}.picker-overlay{position:fixed;inset:0;background:#f9fafb;z-index:100;display:flex;flex-direction:column;overflow-y:auto}.picker-header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#fff}.picker-close{padding:8px 14px;border-radius:6px;border:1px solid #d1d5db;background:#f3f4f6;cursor:pointer}.picker-body{padding:24px}.picker-group{margin-bottom:32px}.picker-group h3{text-align:center;margin-bottom:16px;color:#374151}.picker-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:16px;max-width:900px;margin:0 auto}.picker-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px;border:1px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer}.picker-card:hover{background:#eff6ff;border-color:#93c5fd}.picker-icon{width:56px;height:56px;background:#f3f4f6;border-radius:6px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:18px;overflow:hidden}.picker-icon-img{max-width:100%;max-height:100%;object-fit:contain}.library-page{padding:28px 24px 40px}.library-hero{display:grid;grid-template-columns:minmax(0,1.3fr) minmax(320px,.9fr);gap:24px;align-items:end;margin-bottom:28px}.library-eyebrow{margin:0 0 10px;text-transform:uppercase;letter-spacing:.12em;font-size:.75rem;color:#166534;font-weight:700}.library-hero h2{margin:0;font-size:clamp(2rem,4vw,3.2rem);line-height:.95}.library-intro{margin:14px 0 0;max-width:62ch;color:#475569;font-size:1rem;line-height:1.6}.library-search{padding:20px;border-radius:22px;background:#ffffffe6;border:1px solid rgba(148,163,184,.25);box-shadow:0 18px 40px #0f172a14}.library-search-label{display:block;margin-bottom:8px;font-size:.9rem;font-weight:600;color:#334155}.library-search-row{display:flex;gap:12px}.library-search-input{flex:1;min-width:0;padding:14px 16px;border-radius:14px;border:1px solid #cbd5e1;font-size:1rem;background:#f8fafc}.library-search-input:focus{outline:2px solid #86efac;border-color:#16a34a}.library-search-button{border:none;border-radius:14px;padding:0 20px;background:linear-gradient(135deg,#166534,#22c55e);color:#fff;font-weight:700;cursor:pointer}.library-search-button:disabled{cursor:wait;opacity:.7}.library-search-button-secondary{background:#e2e8f0;color:#0f172a}.login-page{min-height:100%;display:flex;align-items:center;justify-content:center;padding:32px 16px}.login-card{width:min(100%,420px);display:flex;flex-direction:column;gap:12px;padding:24px;border-radius:24px;background:#ffffffeb;border:1px solid rgba(148,163,184,.22);box-shadow:0 18px 40px #0f172a14}.login-card h2{margin:0 0 8px}.login-label{font-size:.92rem;font-weight:600;color:#334155}.login-input{width:100%;min-height:48px;padding:12px 14px;border:1px solid #cbd5e1;border-radius:12px;background:#f8fafc;font:inherit}.login-submit{min-height:48px}.pdf-upload-panel{display:flex;flex-direction:column;gap:12px}.pdf-upload-input{width:100%;padding:12px;border:1px dashed #94a3b8;border-radius:14px;background:#f8fafc;font:inherit}.pdf-upload-list{display:grid;gap:12px}.pdf-upload-item{padding:16px 18px;border-radius:16px;background:#ffffffe0;border:1px solid rgba(148,163,184,.22)}.pdf-upload-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:8px}.pdf-upload-status{font-weight:700;color:#166534}.pdf-upload-message{margin-top:6px;color:#475569;font-size:.92rem;word-break:break-word}.library-results-meta{margin:0 0 16px;color:#475569;font-size:.95rem}.library-state{margin:18px 0 24px;padding:18px 20px;border-radius:18px;background:#ffffffb8;border:1px solid rgba(148,163,184,.2);color:#334155}.library-state-error{background:#fef2f2;border-color:#fecaca;color:#991b1b}.library-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px}.exercise-card{display:flex;flex-direction:column;gap:16px;min-height:240px;padding:20px;border-radius:24px;background:linear-gradient(180deg,#fffffff7,#f8fafcfa),linear-gradient(135deg,#16a34a1f,#0f172a05);border:1px solid rgba(148,163,184,.22);box-shadow:0 18px 40px #0f172a14}.exercise-card-thumbnail{overflow:hidden;border-radius:18px;border:1px solid rgba(148,163,184,.2);background:#d9e8d2;aspect-ratio:16 / 10}.exercise-card-thumbnail-portrait{aspect-ratio:3 / 4}.exercise-card-thumbnail img{display:block;width:100%;height:100%;object-fit:contain;object-position:center;background:#d9e8d2}.exercise-card-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#22c55e14,#0f172a0a),repeating-linear-gradient(-45deg,#ffffff5c,#ffffff5c 10px,#ffffff14 10px 20px);color:#475569;font-size:.95rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.exercise-card-header{display:flex;flex-direction:column;gap:8px}.exercise-card-header h3{margin:0;font-size:1.2rem;line-height:1.15}.exercise-card-players{display:inline-flex;width:fit-content;padding:6px 10px;border-radius:999px;background:#dcfce7;color:#166534;font-size:.85rem;font-weight:700}.exercise-card-summary{margin:0;color:#475569;line-height:1.6;display:-webkit-box;-webkit-line-clamp:6;-webkit-box-orient:vertical;overflow:hidden}.exercise-card-focus{display:flex;flex-wrap:wrap;gap:8px}.exercise-card-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:auto}.exercise-card-action{min-height:44px;padding:0 16px;border:none;border-radius:12px;background:#14532d;color:#fff;font-weight:700;cursor:pointer}.exercise-card-action:hover{background:#166534}.exercise-card-action-danger{background:#b91c1c}.exercise-card-action-danger:hover{background:#991b1b}.exercise-card-action:disabled{cursor:wait;opacity:.7}.my-exercise-meta-row{display:flex;flex-wrap:wrap;gap:8px}.exercise-chip{padding:7px 10px;border-radius:999px;background:#e2e8f0;color:#1e293b;font-size:.82rem}.exercise-chip-muted{background:#f1f5f9;color:#64748b}.exercise-chip-extern{background:#dbeafe;color:#1d4ed8}.library-section{margin-top:2.5rem}.library-section-title{font-size:1.1rem;font-weight:600;color:#1e293b;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.library-section-count{display:inline-flex;align-items:center;justify-content:center;background:#e2e8f0;color:#475569;font-size:.8rem;font-weight:600;border-radius:999px;padding:.1rem .55rem;min-width:1.5rem}@media(max-width:900px){.app-header{flex-direction:column;align-items:flex-start}.editor-haupt-zeile{flex-direction:column}.editor-reference-panel,.properties-panel{width:100%;min-width:0;border-left:none;border-top:1px solid #e5e7eb}.library-hero{grid-template-columns:1fr}}@media(max-width:700px){.library-page{padding:20px 16px 32px}.library-search-row{flex-direction:column}.library-search-button{min-height:48px}.editor-document-bar,.editor-document-fields,.editor-template-banner{flex-direction:column;align-items:stretch}}
