*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--red: #dc2626;--red-light: #fef2f2;--red-mid: #fca5a5;--yellow: #d97706;--yellow-light: #fffbeb;--yellow-mid: #fcd34d;--green: #16a34a;--green-light: #f0fdf4;--green-mid: #86efac;--primary: #4f46e5;--primary-dark: #4338ca;--bg: #f1f5f9;--card-bg: #ffffff;--text: #1e293b;--text-muted: #64748b;--border: #e2e8f0;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px -1px rgba(0,0,0,.1);--shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -4px rgba(0,0,0,.1);--radius: 12px;--radius-sm: 8px}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,sans-serif;background:var(--bg);color:var(--text);line-height:1.5}.app{min-height:100vh;background:var(--bg)}.header{background:var(--card-bg);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;box-shadow:var(--shadow)}.header-content{max-width:1200px;margin:0 auto;padding:.875rem 1.5rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.header-title{font-size:1.375rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-actions{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.main{max-width:1200px;margin:0 auto;padding:2rem 1.5rem}.btn{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;border-radius:var(--radius-sm);border:none;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;white-space:nowrap;line-height:1.4}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:transparent;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-ghost{background:transparent;color:var(--text-muted);padding:.5rem .75rem}.btn-ghost:hover{color:var(--text);background:var(--bg)}.btn-success{background:var(--green);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover:not(:disabled){background:#b91c1c}.btn-large{padding:.75rem 2rem;font-size:1rem}.btn-icon{background:transparent;border:none;cursor:pointer;padding:.35rem;border-radius:6px;font-size:1.05rem;line-height:1;transition:background .15s}.btn-icon:hover{background:var(--bg)}.btn-icon-danger:hover{background:var(--red-light)}.faecher-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.fach-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .2s,transform .2s}.fach-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.fach-card-header{padding:1.125rem 1.25rem;display:flex;justify-content:space-between;align-items:flex-start;gap:.5rem;border-bottom:1px solid var(--border)}.fach-card-info{min-width:0}.fach-title{font-size:1.05rem;font-weight:600;margin-bottom:.2rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fach-description{font-size:.8rem;color:var(--text-muted);margin-bottom:.3rem;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.fach-total{font-size:.72rem;color:var(--text-muted);background:var(--bg);padding:.1rem .5rem;border-radius:20px;display:inline-block}.fach-actions{display:flex;gap:.2rem;flex-shrink:0}.status-boxes{display:grid;grid-template-columns:repeat(3,1fr);border-bottom:1px solid var(--border)}.status-box{padding:.875rem .5rem;display:flex;flex-direction:column;align-items:center;gap:.1rem;border-right:1px solid var(--border);text-align:center;transition:background .15s;-webkit-user-select:none;user-select:none}.status-box:last-child{border-right:none}.status-box.status-red{background:var(--red-light)}.status-box.status-yellow{background:var(--yellow-light)}.status-box.status-green{background:var(--green-light)}.status-box.status-red:hover{background:#fee2e2}.status-box.status-yellow:hover{background:#fef3c7}.status-box.status-green:hover{background:#dcfce7}.status-count{font-size:1.6rem;font-weight:700;line-height:1}.status-box.status-red .status-count{color:var(--red)}.status-box.status-yellow .status-count{color:var(--yellow)}.status-box.status-green .status-count{color:var(--green)}.status-label{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.fach-card-footer{padding:.75rem 1.125rem;display:flex;gap:.5rem;justify-content:flex-end;margin-top:auto}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-muted)}.empty-icon{font-size:3.5rem;margin-bottom:.75rem}.empty-state h2{font-size:1.2rem;color:var(--text);margin-bottom:.4rem}.empty-state p{margin-bottom:1.5rem}.status-overview{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.status-overview-box{background:var(--card-bg);border-radius:var(--radius);padding:1.125rem 1rem;text-align:center;cursor:pointer;border:2px solid transparent;box-shadow:var(--shadow);transition:border-color .2s,background .2s;display:flex;flex-direction:column;align-items:center;gap:.2rem}.status-overview-box:hover{border-color:var(--status-color, #cbd5e1)}.status-overview-box.active{border-color:var(--status-color, #cbd5e1);background:var(--status-bg, var(--bg))}.status-overview-emoji{font-size:1.75rem;margin-bottom:.25rem}.status-overview-count{font-size:2rem;font-weight:700;color:var(--status-color, var(--text));line-height:1}.status-overview-label{font-size:.78rem;color:var(--text-muted);font-weight:500;margin-bottom:.4rem}.status-study-btn{padding:.25rem .75rem;font-size:.75rem;border-radius:20px;background:var(--status-color, var(--primary));color:#fff;border:none;cursor:pointer;transition:opacity .15s}.status-study-btn:hover{opacity:.85}.tab-bar{display:flex;gap:.3rem;margin-bottom:1.25rem;flex-wrap:wrap}.tab{padding:.4rem .9rem;border-radius:20px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;font-size:.85rem;font-weight:500;transition:background .15s,color .15s}.tab:hover{background:var(--card-bg);color:var(--text)}.tab-active{background:var(--card-bg)!important;color:var(--text)!important;box-shadow:var(--shadow)}.karten-list{display:flex;flex-direction:column;gap:.75rem}.karte-item{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);overflow:hidden;border-left:4px solid transparent;transition:box-shadow .15s}.karte-item:hover{box-shadow:var(--shadow-lg)}.karte-item.karte-red{border-left-color:var(--red)}.karte-item.karte-yellow{border-left-color:var(--yellow)}.karte-item.karte-green{border-left-color:var(--green)}.karte-content{padding:.875rem 1.125rem;display:grid;grid-template-columns:1fr auto 1fr;gap:1rem;align-items:center}.karte-side{display:flex;flex-direction:column;gap:.2rem}.karte-label{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.karte-content p{font-size:.9rem;color:var(--text);line-height:1.5}.karte-divider{color:var(--text-muted);font-size:1.1rem;text-align:center;flex-shrink:0}.karte-actions{padding:.5rem 1.125rem;display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);background:var(--bg)}.karte-buttons{display:flex;gap:.2rem}.status-badge{font-size:.75rem;font-weight:500;padding:.2rem .6rem;border-radius:20px;display:inline-flex;align-items:center;gap:.25rem}.status-badge-red{background:var(--red-light);color:var(--red)}.status-badge-yellow{background:var(--yellow-light);color:var(--yellow)}.status-badge-green{background:var(--green-light);color:var(--green)}.study-container{max-width:600px;margin:0 auto;padding:2rem 1.5rem}.study-progress-info{display:flex;flex-direction:column;align-items:center;gap:.1rem;text-align:center}.study-fach-name{font-size:.8rem;color:var(--text-muted)}.study-counter{font-size:.95rem;font-weight:600}.progress-bar{height:6px;background:var(--border);border-radius:3px;margin-bottom:2rem;overflow:hidden}.progress-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .35s ease}.flashcard-wrapper{perspective:1000px;cursor:pointer;height:280px;margin-bottom:2rem;-webkit-user-select:none;user-select:none}.flashcard{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .5s cubic-bezier(.4,0,.2,1)}.flashcard.flipped{transform:rotateY(180deg)}.flashcard-face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;-webkit-backface-visibility:hidden;border-radius:var(--radius);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;box-shadow:var(--shadow-lg);text-align:center}.flashcard-front{background:var(--card-bg)}.flashcard-back{background:#eff6ff;transform:rotateY(180deg)}.flashcard-side-label{position:absolute;top:1rem;left:1.25rem;font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.flashcard-text{font-size:1.2rem;font-weight:500;color:var(--text);line-height:1.55;max-height:180px;overflow-y:auto}.flashcard-hint{position:absolute;bottom:1rem;font-size:.72rem;color:var(--text-muted)}.rating-buttons{text-align:center}.rating-question{font-size:.875rem;color:var(--text-muted);font-weight:500;margin-bottom:1rem}.rating-row{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.rating-btn{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;border-radius:var(--radius);border:2px solid transparent;cursor:pointer;font-weight:600;font-family:inherit;transition:transform .15s,border-color .15s,background .15s}.rating-btn:hover{transform:scale(1.06)}.rating-icon{font-size:2rem}.rating-label{font-size:.8rem}.rating-red{background:var(--red-light);color:var(--red);border-color:var(--red-mid)}.rating-yellow{background:var(--yellow-light);color:var(--yellow);border-color:var(--yellow-mid)}.rating-green{background:var(--green-light);color:var(--green);border-color:var(--green-mid)}.rating-red:hover{border-color:var(--red);background:#fee2e2}.rating-yellow:hover{border-color:var(--yellow);background:#fef3c7}.rating-green:hover{border-color:var(--green);background:#dcfce7}.show-answer-hint{text-align:center}.study-finished{text-align:center;background:var(--card-bg);border-radius:var(--radius);padding:2.5rem 2rem;box-shadow:var(--shadow-lg)}.finished-icon{font-size:3.5rem;margin-bottom:.75rem}.study-finished h2{font-size:1.4rem;font-weight:700;margin-bottom:.3rem}.finished-fach{color:var(--text-muted);margin-bottom:.2rem}.finished-pct{font-size:1.5rem;font-weight:700;color:var(--primary);margin-bottom:1.75rem}.finished-results{display:grid;grid-template-columns:repeat(3,1fr);gap:.875rem;margin-bottom:2rem}.result-item{padding:.875rem .5rem;border-radius:var(--radius-sm);display:flex;flex-direction:column;align-items:center;gap:.2rem}.result-red{background:var(--red-light)}.result-yellow{background:var(--yellow-light)}.result-green{background:var(--green-light)}.result-emoji{font-size:1.4rem}.result-count{font-size:1.75rem;font-weight:700;line-height:1}.result-red .result-count{color:var(--red)}.result-yellow .result-count{color:var(--yellow)}.result-green .result-count{color:var(--green)}.result-label{font-size:.72rem;color:var(--text-muted);font-weight:500}.finished-actions{display:flex;gap:.75rem;justify-content:center}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000007a;display:flex;align-items:center;justify-content:center;z-index:100;padding:1rem;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:var(--card-bg);border-radius:var(--radius);box-shadow:0 25px 50px -12px #00000047;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;animation:modal-in .2s ease}@keyframes modal-in{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal-header{padding:1.125rem 1.5rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border)}.modal-header h2{font-size:1.1rem;font-weight:600}.modal-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.35rem}.form-group label{font-size:.85rem;font-weight:500}.form-group input,.form-group textarea{padding:.6rem .75rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.875rem;color:var(--text);background:var(--card-bg);font-family:inherit;resize:vertical;outline:none;transition:border-color .15s,box-shadow .15s}.form-group input:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #4f46e51f}.modal-footer{display:flex;justify-content:space-between;align-items:center;gap:.5rem;padding-top:.5rem;border-top:1px solid var(--border);margin-top:.25rem}.modal-footer-right{display:flex;gap:.5rem;margin-left:auto}@media (max-width: 640px){.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:1rem}.login-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2.5rem 2rem;width:100%;max-width:380px;text-align:center}.login-icon{font-size:3rem;margin-bottom:.5rem}.login-title{font-size:1.6rem;font-weight:700;margin-bottom:.25rem}.login-subtitle{color:var(--text-muted);margin-bottom:1.75rem}.login-form{text-align:left;display:flex;flex-direction:column;gap:1rem}.btn-login{width:100%;justify-content:center;padding:.65rem 1rem}.login-error{background:var(--red-light);color:var(--red);border-radius:var(--radius-sm);padding:.5rem .75rem;font-size:.875rem;text-align:center}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.loading-spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.header-user{font-size:.82rem;color:var(--text-muted);font-weight:500;white-space:nowrap}.status-overview{grid-template-columns:repeat(3,1fr);gap:.5rem}.status-overview-box{padding:.75rem .5rem}.status-overview-emoji{font-size:1.25rem}.status-overview-count{font-size:1.5rem}.rating-row{gap:.5rem}.rating-btn{padding:.75rem .5rem}.rating-icon{font-size:1.5rem}.karte-content{grid-template-columns:1fr;gap:.5rem}.karte-divider{display:none}.header-actions{gap:.35rem}.header-title{font-size:1.1rem}.faecher-grid{grid-template-columns:1fr}}
