*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#f5f5f5}#root{min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}.app{max-width:1200px;margin:0 auto;padding:2rem}.app-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:3px solid #007bff;text-align:center}.app-header h1{margin:0 0 .5rem;color:#007bff;font-size:2.5rem}.app-header .subtitle{margin:0;color:#666;font-size:1.1rem;font-weight:400}.header-info{display:flex;gap:1rem;align-items:center}.badge{display:inline-block;padding:.25rem .75rem;background:#007bff;color:#fff;border-radius:1rem;font-size:.875rem;font-weight:500}.module-count{color:#666;font-size:.9rem}.loading-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-content{background:#fff;padding:3rem;border-radius:1rem;box-shadow:0 20px 60px #0000004d;min-width:400px;max-width:500px}.loading-content h2{margin:0 0 2rem;color:#333;font-size:1.5rem;text-align:center}.progress-bar-container{width:100%;height:30px;background-color:#e9ecef;border-radius:15px;overflow:hidden;box-shadow:inset 0 2px 4px #0000001a;margin-bottom:1rem}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#007bff,#0056b3);transition:width .3s ease;display:flex;align-items:center;justify-content:center;border-radius:15px;position:relative}.progress-bar-text{color:#fff;font-weight:700;font-size:.875rem;text-shadow:0 1px 2px rgba(0,0,0,.2)}.loading-message{text-align:center;color:#666;font-size:.95rem;margin:.5rem 0 0;min-height:1.5rem}.error{text-align:center;padding:3rem;font-size:1.2rem;color:#dc3545}.no-results{text-align:center;padding:2rem;color:#666;font-size:1.1rem}.handbook-switcher{margin-bottom:1.5rem;padding:1rem;background:#f8f9fa;border-radius:.5rem;display:flex;align-items:center;gap:1rem}.handbook-switcher label{font-weight:600;color:#495057}.handbook-switcher select{flex:1;padding:.5rem 1rem;font-size:1rem;border:1px solid #ced4da;border-radius:.25rem;background:#fff;cursor:pointer;transition:border-color .15s ease-in-out}.handbook-switcher select:hover{border-color:#007bff}.handbook-switcher select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 .2rem #007bff40}.selected-handbook-view{margin-top:2rem;padding-top:2rem;border-top:2px solid #e0e0e0}.handbook-header{margin-bottom:1.5rem;background:#fff;padding:1.5rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.handbook-header h2{margin:0 0 1rem;color:#333;font-size:1.75rem}.handbook-header .header-info{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.global-module-filter{padding:1rem;background:#f5f5f5;border-radius:.5rem}.stats-bar{display:flex;gap:1.5rem;padding:.75rem 1rem;background:#fff;border-radius:.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.stat-item{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem;font-size:.9rem;min-width:0}.stat-label{color:#666;font-weight:500}.stat-value{font-size:1.2rem;font-weight:700;color:#333}.stat-item.highlight .stat-value{color:#ef5350}.stat-item.success .stat-value{color:#66bb6a}.stat-percent{font-size:.85rem;color:#999}.stat-unique{font-size:.8rem;color:#888;margin-left:.25rem;font-style:italic}.explanation-section{padding:1rem;background:#f8f9fa;border-radius:.5rem;margin-bottom:1rem;border:1px solid #e0e0e0;box-shadow:0 1px 2px #0000000d}.explanation-section h3{margin:0 0 .75rem;color:#666;font-size:1rem;font-weight:600;display:flex;align-items:center;gap:.5rem}.explanation-content{display:block;font-size:.85rem;line-height:1.6;color:#6c757d}.explanation-item{margin-bottom:.5rem}.explanation-item strong{display:inline;color:#495057;margin-right:.3rem;font-size:.85rem;font-weight:600}.explanation-item p{display:inline;margin:0;font-size:.85rem;line-height:1.6;color:#6c757d}.explanation-item .example{display:none}.explanation-item .warning{display:inline;margin:0;font-size:.85rem}.keyword-list{display:flex;flex-wrap:wrap;gap:.3rem;margin:.4rem 0;padding:.5rem;background:#f8f9fa;border-radius:.3rem}.keyword-list code{background:#e9ecef;color:#495057;padding:.15rem .4rem;border-radius:.2rem;font-size:.8rem;font-family:Monaco,Courier New,monospace}.filter-controls{display:grid;gap:.75rem;padding:1rem;background:#fff;border-radius:.5rem;margin-bottom:1rem;box-shadow:0 1px 3px #0000001a}.filter-group{display:flex;align-items:center;gap:.75rem}.filter-group.search-group{grid-column:1 / -1}.filter-label{font-size:.9rem;font-weight:600;color:#555;min-width:140px;display:flex;align-items:center;gap:.4rem}.info-tooltip{display:inline-block;cursor:help;font-size:.85rem;color:#1976d2;transition:transform .2s ease}.info-tooltip:hover{transform:scale(1.2)}.search-input{flex:1;padding:.6rem 1rem;border:1px solid #ddd;border-radius:.4rem;font-size:.95rem;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:#1976d2}.radio-group{display:flex;gap:.5rem}.radio-group label{display:flex;align-items:center;gap:.4rem;padding:.4rem .8rem;border:1px solid #ddd;border-radius:.4rem;cursor:pointer;font-size:.9rem;background:#fff;transition:all .2s ease}.radio-group label:hover{background:#f5f5f5}.radio-group label.active{background:#1976d2;color:#fff;border-color:#1976d2}.radio-group input[type=radio]{margin:0}.checkbox-group.compact{display:flex;flex-wrap:wrap;gap:.4rem}.checkbox-group.compact label{display:flex;align-items:center;gap:.3rem;padding:.3rem .6rem;border:1px solid #ddd;border-radius:.3rem;cursor:pointer;font-size:.85rem;background:#fff;transition:all .2s ease}.checkbox-group.compact label:hover{background:#f5f5f5}.checkbox-group.compact label.active{background:#e3f2fd;border-color:#1976d2;color:#1976d2;font-weight:600}.checkbox-group.compact input[type=checkbox]{margin:0}.charts-wrapper{background:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.charts-header{display:flex;align-items:center;gap:.5rem;padding:.5rem;cursor:pointer;transition:background .2s ease;border-radius:.3rem}.charts-header:hover{background:#f5f5f5}.charts-header h3{margin:0;font-size:1.1rem;color:#333;font-weight:600}.charts-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));gap:1.5rem;margin-bottom:1.5rem;margin-top:1rem}.chart-container{background:#fff;border-radius:.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1.5rem}.chart-container h3{margin:0 0 1rem;font-size:1.1rem;color:#333;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.chart-info-group{display:flex;align-items:center;gap:.75rem;font-size:.85rem;font-weight:500}.mode-toggle-btn{padding:.3rem .6rem;background:#1976d2;color:#fff;border:none;border-radius:.3rem;cursor:pointer;font-size:.9rem;font-weight:600;transition:background .2s ease;min-width:32px}.mode-toggle-btn:hover{background:#1565c0}.mode-toggle-btn:active{background:#0d47a1}.faculty-tree{background:#fff;border-radius:.5rem;padding:1rem;box-shadow:0 1px 3px #0000001a}.faculty-section{margin-bottom:.5rem}.faculty-header{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#e3f2fd;border-radius:.4rem;cursor:pointer;transition:background .2s ease;font-weight:600}.faculty-header:hover{background:#bbdefb}.faculty-name{font-size:1rem;color:#1976d2}.faculty-stats{margin-left:auto;font-size:.85rem;color:#666;font-weight:500}.export-csv-btn{padding:.2rem .6rem;background:#1976d2;color:#fff;border:none;border-radius:.3rem;font-size:.75rem;font-weight:600;cursor:pointer;flex-shrink:0}.export-csv-btn:hover{background:#1565c0}.studiengaenge-list{margin-left:1.5rem;margin-top:.5rem}.studiengang-section{margin-bottom:.5rem}.studiengang-header{display:flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:#f5f5f5;border-radius:.3rem;cursor:pointer;transition:background .2s ease;position:relative}.studiengang-header:hover{background:#eee}.studiengang-header:hover:before{opacity:1}.studiengang-name{font-family:Monaco,Courier New,monospace;font-size:.9rem;font-weight:600;color:#1976d2;background:#e3f2fd;padding:.2rem .5rem;border-radius:.3rem}.spo-version{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-size:.8rem;font-weight:500;color:#666;opacity:.9}.studiengang-title{font-size:.9rem;color:#333;flex:1}.studiengang-stats{font-size:.8rem;color:#666;margin-left:auto}.modules-list{margin-left:1.5rem;margin-top:.5rem;display:grid;gap:.5rem}.module-wrapper{display:flex;flex-direction:column}.module-item{display:flex;align-items:center;gap:.75rem;padding:.6rem 1rem;border-left:3px solid #e0e0e0;background:#fff;border-radius:.3rem;transition:all .2s ease}.module-item.has-ap{border-left-color:#ef5350;background:#ffebee}.module-item.no-ap{border-left-color:#66bb6a;background:#e8f5e9}.module-item:hover{box-shadow:0 2px 8px #0000001a}.module-expand{cursor:pointer;padding:.25rem}.module-expand:hover{background:#0000001a;border-radius:.2rem}.module-kennung{font-family:Monaco,Courier New,monospace;font-size:.85rem;font-weight:600;color:#1976d2;background:#e3f2fd;padding:.25rem .5rem;border-radius:.3rem;white-space:nowrap}.module-title{flex:1;font-size:.9rem;color:#333;cursor:pointer;min-width:0;word-break:break-word}.module-title:hover{text-decoration:underline}.module-badges{display:flex;align-items:center;gap:.3rem;flex-shrink:0}.uncertain-badge{display:inline-flex;align-items:center;justify-content:center;margin-left:.4rem;width:1.1rem;height:1.1rem;background:#f57c00;color:#fff;border-radius:50%;font-size:.7rem;font-weight:700;cursor:help;vertical-align:middle;flex-shrink:0}.course-badge{padding:.15rem .4rem;background:#1976d21a;color:#1976d2;border-radius:.25rem;font-size:.75rem;font-weight:600}.ap-badge{padding:.2rem .4rem;border-radius:.25rem;font-size:.75rem;font-weight:600}.ap-badge.with-ap{background:#c62828;color:#fff}.ap-badge.without-ap{background:#2e7d32;color:#fff}.expand-icon{color:#666;font-size:.8rem;margin-right:.25rem;flex-shrink:0}.module-details-expanded{margin-left:2rem;margin-top:.5rem;padding:1rem;background:#fff;border-left:2px solid #e0e0e0;border-radius:.3rem}.module-fields{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.module-field{display:flex;flex-direction:column;gap:.25rem}.module-field strong{font-size:.9rem;color:#1976d2}.module-field p{margin:0;font-size:.9rem;color:#555;line-height:1.5}.module-appearances{margin-top:1rem;padding-top:1rem;border-top:1px solid #e0e0e0}.module-appearances>strong{display:block;margin-bottom:.75rem;font-size:.95rem;color:#333}.appearances-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:.75rem}.appearance-card{padding:.75rem;border-radius:.4rem;border:1px solid #e0e0e0;transition:all .2s ease}.appearance-card.has-ap{background:#ffebee;border-left:3px solid #ef5350}.appearance-card.no-ap{background:#e8f5e9;border-left:3px solid #66bb6a}.appearance-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.appearance-sg{font-family:Monaco,Courier New,monospace;font-size:.85rem;font-weight:600;color:#1976d2;background:#e3f2fd;padding:.2rem .5rem;border-radius:.3rem}.ap-indicator{padding:.2rem .5rem;border-radius:.3rem;font-size:.75rem;font-weight:600}.ap-indicator.with-ap{background:#c62828;color:#fff}.ap-indicator.without-ap{background:#2e7d32;color:#fff}.appearance-title{font-size:.85rem;color:#555;margin-bottom:.25rem}.appearance-faculty{font-size:.8rem;color:#888;margin-bottom:.5rem}.appearance-types{display:flex;flex-wrap:wrap;gap:.25rem}.type-tag{padding:.15rem .4rem;background:#1976d21a;color:#1976d2;border-radius:.25rem;font-size:.7rem;font-weight:500}.anwesenheit-highlight{background:#ffeb3b;color:#000;padding:.1rem .2rem;border-radius:.2rem;font-weight:600}.no-results{text-align:center;padding:3rem;color:#999;font-size:1rem}.loading{text-align:center;padding:2rem;color:#666}@media(max-width:768px){.stats-bar{flex-direction:column;gap:.75rem}.filter-group{flex-direction:column;align-items:flex-start}.filter-label{min-width:auto}.radio-group,.checkbox-group.compact{width:100%}.charts-section{grid-template-columns:1fr}.studiengaenge-list,.modules-list{margin-left:.5rem}.module-item{flex-direction:column;align-items:flex-start;gap:.5rem}.module-badges{flex-wrap:wrap}.faculty-stats,.studiengang-stats{font-size:.75rem}}
