:root{--bg-primary: #faf5f5;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #fdf0f0;--bg-card-rose: #fdf2f2;--text-primary: #2d2d3a;--text-secondary: #555566;--text-muted: #888899;--accent: #8B2332;--accent-hover: #a52a3a;--accent-light: #f8e8ea;--green: #2e7d32;--red: #c62828;--yellow: #e65100;--peach: #8B2332;--border: #e8dede;--border-light: #f0e6e6;--radius: 12px;--radius-sm: 8px;--shadow: 0 2px 12px rgba(139, 35, 50, .08);--shadow-lg: 0 4px 24px rgba(139, 35, 50, .12)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;line-height:1.6}.header{background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:.75rem 2rem;display:flex;align-items:center;justify-content:space-between;top:0;z-index:100;box-shadow:0 1px 4px #0000000a}.header-brand{display:flex;align-items:center;gap:.75rem}.header-logo{height:36px;width:auto}.header h1{font-size:1.2rem;font-weight:700;color:var(--accent)}.header-actions{max-width:70%;display:flex;gap:.75rem;align-items:center}.nav-tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border);padding:0 2rem;gap:0}.nav-tab{padding:.875rem 1.5rem;background:none;border:none;color:var(--text-muted);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2.5px solid transparent;transition:all .2s}.nav-tab:hover{color:var(--text-secondary);background:var(--accent-light)}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.nav-tab:disabled{opacity:.3;cursor:not-allowed}.main{padding:1.5rem 2rem;max-width:1600px;margin:0 auto}.tab-content{display:none}.tab-content.active{display:block}.upload-zone{border:2px dashed var(--border);border-radius:var(--radius);padding:4rem 2rem;text-align:center;cursor:pointer;transition:all .3s;background:var(--bg-secondary);max-width:700px;margin:3rem auto;box-shadow:var(--shadow)}.upload-zone:hover,.upload-zone.dragover{border-color:var(--accent);background:var(--accent-light)}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.upload-zone h2{font-size:1.25rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.upload-zone p{color:var(--text-muted);font-size:.9rem}.upload-zone input[type=file]{display:none}.btn{padding:.5rem 1.25rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-secondary);color:var(--text-primary);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.btn:hover{background:var(--bg-card-hover);border-color:var(--accent)}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-signout{color:var(--text-muted);border-color:transparent;background:transparent}.btn-signout:hover{color:var(--red);border-color:var(--red);background:#fde8e8}.btn-danger{border-color:var(--red);color:var(--red)}.btn-danger:hover{background:#fde8e8}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.dashboard-top-row{display:grid;grid-template-columns:minmax(240px,320px) minmax(0,1fr);gap:1rem;align-items:stretch;margin-bottom:2rem}.dashboard-top-row .insights-card{margin-bottom:0}.kpi-card{background:var(--bg-card);border-radius:var(--radius);padding:1.25rem 1.5rem;border:1px solid var(--border-light);box-shadow:var(--shadow)}.kpi-card .kpi-label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:.25rem}.kpi-card .kpi-value{font-size:2rem;font-weight:700;color:var(--accent)}.kpi-card .kpi-value.green{color:var(--green)}.kpi-card .kpi-value.red{color:var(--red)}.kpi-card .kpi-value.yellow{color:var(--yellow)}.kpi-card .kpi-value.peach{color:var(--accent)}.kpi-card .kpi-value-courses{font-size:1.05rem;line-height:1.35;font-weight:600;white-space:normal;word-break:break-word}.insights-card{background:var(--bg-card);border-radius:var(--radius);padding:1.25rem 1.5rem;border:1px solid var(--border-light);box-shadow:var(--shadow);margin-bottom:2rem}.insights-card h3{font-size:1.05rem;color:var(--accent);margin-bottom:.5rem}.insights-conclusion{color:var(--text-primary);margin-bottom:.75rem}.insights-columns{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.insights-column h4{font-size:.85rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-secondary);margin-bottom:.25rem}.insights-column ul{margin:0;padding-left:1.1rem}.insights-column li{color:var(--text-secondary);margin-bottom:.2rem}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(450px,1fr));gap:1.5rem;margin-bottom:2rem}.chart-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;overflow:hidden;box-shadow:var(--shadow);min-height:450px;display:flex;flex-direction:column}.chart-card-full{grid-column:1 / -1}.chart-card h3{font-size:.95rem;font-weight:600;margin-bottom:1rem;color:var(--accent);flex-shrink:0}.chart-card-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:1rem}.chart-card-header-row h3{margin-bottom:0;flex:1}.chart-export-btn{flex-shrink:0;padding:.22rem .55rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-muted);font-size:.72rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;line-height:1.4}.chart-export-btn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.question-card-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.9rem}.question-card-title-row .question-card-title{margin-bottom:0;flex:1}.export-progress-label{font-size:.75rem;color:var(--text-muted);max-width:260px;text-align:right;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.export-progress-error{color:var(--red)}.dashboard-overall-histogram-card{min-height:0}.analysis-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--radius);box-shadow:var(--shadow);padding:1rem}.metric-chip{display:inline-flex;flex-direction:column;gap:.12rem;border:1px solid var(--border-light);border-radius:10px;background:#fff;padding:.42rem .55rem;color:var(--text-secondary);font-size:.8rem;min-width:96px}.metric-chip-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted)}.metric-chip strong{color:var(--text-primary);font-size:.95rem}.metric-chip-highlight{background:#f7fbff;border-color:#c7deef}.course-overview-section{margin-top:2rem}.course-overview-section h3{color:var(--accent);margin-bottom:.35rem}.course-overview-subtitle{color:var(--text-muted);margin-bottom:1rem;font-size:.9rem}.course-card-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.course-card{text-align:left;cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;color:inherit}.course-card:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow-lg)}.course-card.active{border-color:var(--accent);background:var(--accent-light)}.course-card-header{font-size:1rem;font-weight:700;margin-bottom:.75rem;color:var(--accent)}.course-card-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;margin-bottom:.75rem}.course-bucket-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;margin-bottom:.6rem}.course-bucket-item{border:1px solid #e8e3e3;border-radius:var(--radius-sm);padding:.4rem;font-size:.74rem;color:var(--text-secondary);background:#fff;display:flex;flex-direction:column;gap:.2rem}.course-bucket-item.low{background:#f8ecef;border-color:#e7c9d1}.course-bucket-item.mid{background:#f4f0ea;border-color:#e4d7c8}.course-bucket-item.high{background:#edf4fa;border-color:#c8ddec}.course-card-hint{font-size:.78rem;color:var(--text-muted);border-top:1px dashed var(--border);padding-top:.5rem}.course-detail-panel{margin-top:1.5rem;display:flex;flex-direction:column;gap:1rem}.course-detail-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem}.course-detail-chart-card{min-height:0}.course-detail-header{display:flex;justify-content:space-between;align-items:baseline;gap:1rem}.course-detail-header p{color:var(--text-muted);font-size:.88rem}.course-detail-loading{color:var(--text-secondary);font-weight:600}.course-detail-error{margin-top:1rem;color:var(--red);background:#fff0f0;border:1px solid #f5cccc;border-radius:var(--radius-sm);padding:.75rem}.category-stat-row{display:flex;flex-wrap:wrap;gap:.7rem;margin-bottom:.6rem;color:var(--text-secondary);font-size:.83rem}.question-card{padding:1.1rem}.question-card-title{margin-top:0;margin-bottom:.9rem;font-size:1.03rem;color:#2c3e50;border-bottom:1px solid #eee;padding-bottom:.65rem;line-height:1.35}.question-id{margin-right:10px;color:#6c757d;font-weight:700}.question-answer-chip{margin-left:10px;font-size:.72rem;font-weight:600;color:#7f1d2d;background:#fdecef;border:1px solid #f3c7d0;border-radius:999px;padding:3px 8px;vertical-align:middle;white-space:nowrap}.question-numeric-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:.65rem}.question-numeric-title-row{display:flex;align-items:center;gap:8px}.question-numeric-title{font-size:.9rem;color:#666}.question-note-box{margin-top:15px;padding:12px;background:#f8f4ec;border-left:4px solid #d0b07b;border-radius:4px;color:#5d4037}.question-text-box{background:#f3f8f6;padding:15px;border-radius:6px;border-left:4px solid #87b39f}.chart-placeholder{min-height:400px;flex:1}.generator-top-row{display:flex;gap:1.5rem;margin-bottom:1.5rem}.generator-settings{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;display:flex;flex-direction:column;gap:.75rem;min-width:220px;flex-shrink:0;box-shadow:var(--shadow)}.generator-filters{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;flex:1;display:flex;gap:1.5rem;overflow:hidden;box-shadow:var(--shadow)}.filter-section{flex:1;min-width:0}.filter-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.filter-header label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;flex:1}.btn-link{background:none;border:none;color:var(--accent);font-size:.75rem;cursor:pointer;padding:0;text-decoration:underline}.btn-link:hover{color:var(--accent-hover)}.checkbox-list{max-height:180px;overflow-y:auto;display:flex;flex-direction:column;gap:.25rem;padding-right:.25rem}.checkbox-list::-webkit-scrollbar{width:4px}.checkbox-list::-webkit-scrollbar-track{background:transparent}.checkbox-list::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.checkbox-item{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;padding:.3rem .5rem;border-radius:var(--radius-sm);font-size:.82rem;color:var(--text-secondary);line-height:1.3;transition:background .15s}.checkbox-item:hover{background:var(--accent-light)}.checkbox-item input[type=checkbox]{accent-color:var(--accent);margin-top:2px;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.form-group select,.form-group input{padding:.5rem .75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-primary);color:var(--text-primary);font-size:.875rem}.form-group select:focus,.form-group input:focus{outline:none;border-color:var(--accent)}#generator-result{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;min-height:450px;box-shadow:var(--shadow)}#generator-result .download-btns{display:flex;gap:.5rem;margin-bottom:1rem}.inzichten-container{max-width:900px;margin:0 auto}.inzichten-header{text-align:center;margin-bottom:2rem}.inzichten-header p{color:var(--text-muted);margin-top:.5rem}.inzichten-content{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:2rem;min-height:300px;font-size:.95rem;line-height:1.8;box-shadow:var(--shadow)}.inzichten-content h2{color:var(--accent);font-size:1.2rem;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.inzichten-content h2:first-child{margin-top:0}.inzichten-content ul{margin-left:1.5rem;margin-bottom:.75rem}.inzichten-content li{margin-bottom:.4rem}.inzichten-content strong{color:var(--accent)}.inzichten-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;color:var(--text-muted)}.inzichten-placeholder p{margin-top:.5rem;font-size:.9rem}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top,#fffffff2,#f5eceeeb);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:200;align-items:center;justify-content:center;overflow:hidden}.loading-overlay__bg{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;pointer-events:none}.loading-orb{position:absolute;border-radius:50%;filter:blur(1px);opacity:.45;animation:floatOrb 8s ease-in-out infinite}.loading-orb--one{width:280px;height:280px;top:8%;left:12%;background:#8b233238}.loading-orb--two{width:360px;height:360px;right:8%;top:18%;background:#c2818b3d;animation-duration:10s}.loading-orb--three{width:240px;height:240px;left:34%;bottom:6%;background:#7846602e;animation-duration:12s}.loading-glass-card{position:relative;width:min(620px,calc(100vw - 2rem));padding:2rem;border-radius:20px;border:1px solid rgba(255,255,255,.6);background:linear-gradient(150deg,#ffffff9e,#ffffff52);box-shadow:0 12px 48px #58182233;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);text-align:center;display:flex;flex-direction:column;align-items:center;gap:.9rem}.loading-glass-card h2{color:var(--accent);font-size:1.5rem;font-weight:700}.loading-glass-card p{color:var(--text-secondary);max-width:520px;font-size:.95rem}.loading-glass-card .btn{margin-top:.25rem}.spinner{width:48px;height:48px;border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes floatOrb{0%,to{transform:translateZ(0) scale(1)}50%{transform:translate3d(20px,-28px,0) scale(1.07)}}.loading-inline{display:inline-block;width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem;vertical-align:middle}.cursor-blink:after{content:"|";animation:blink .8s step-end infinite;color:var(--accent)}@keyframes blink{50%{opacity:0}}.notification{position:fixed;top:1rem;right:1rem;padding:1rem 1.5rem;border-radius:var(--radius-sm);font-size:.9rem;z-index:300;animation:slideIn .3s ease;max-width:500px;box-shadow:var(--shadow-lg)}.notification.error{background:#fff0f0;border:1px solid var(--red);color:var(--red)}.notification.success{background:#f0fff0;border:1px solid var(--green);color:var(--green)}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.combo-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:2rem}.combo-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border-light);padding:1.25rem;box-shadow:var(--shadow)}.combo-card h3{font-size:.95rem;font-weight:600;margin-bottom:1rem;color:var(--accent)}.combo-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--border-light);font-size:.85rem}.combo-item:last-child{border-bottom:none}.combo-item .combo-label{color:var(--text-secondary);flex:1;margin-right:1rem}.combo-item .combo-score{font-weight:700;font-size:1rem}.combo-item .combo-score.high{color:var(--green)}.combo-item .combo-score.low{color:var(--red)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(circle at top left,#fffffff7,#f5eceeed);position:relative;overflow:hidden}.login-page__bg{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;pointer-events:none}.login-card{position:relative;width:min(440px,calc(100vw - 2rem));padding:2.5rem;background:linear-gradient(150deg,#ffffffd9,#ffffffa6);border:1px solid rgba(255,255,255,.7);border-radius:20px;box-shadow:0 8px 40px #8b233224,0 1px #fffc inset;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.login-card__brand{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-light)}.login-card__logo{height:52px;width:auto;flex-shrink:0}.login-card__title-group{display:flex;flex-direction:column;gap:.15rem}.login-card__title{font-size:1.1rem;font-weight:700;color:var(--accent);line-height:1.2}.login-card__subtitle{font-size:.8rem;color:var(--text-muted)}.login-form{display:flex;flex-direction:column;gap:1.1rem}.login-form__field{display:flex;flex-direction:column;gap:.4rem}.login-form__label{font-size:.78rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.login-form__input{padding:.65rem .875rem;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fffc;color:var(--text-primary);font-size:.95rem;font-family:inherit;transition:border-color .2s,box-shadow .2s;outline:none}.login-form__input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #8b23321a}.login-form__input::placeholder{color:var(--text-muted)}.login-form__error{background:#fef2f2;border:1px solid #fca5a5;border-radius:var(--radius-sm);padding:.6rem .875rem;font-size:.875rem;color:var(--red)}.login-form__submit{margin-top:.4rem;padding:.75rem;background:var(--accent);color:#fff;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .1s,box-shadow .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 2px 8px #8b233240}.login-form__submit:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 4px 12px #8b23324d;transform:translateY(-1px)}.login-form__submit:active:not(:disabled){transform:translateY(0)}.login-form__submit:disabled{opacity:.65;cursor:not-allowed}@media(max-width:1024px){.chart-grid,.combo-grid{grid-template-columns:1fr}.course-card-grid,.course-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:768px){.header{padding:.75rem 1rem}.nav-tabs{padding:0 1rem}.main{padding:1rem}.generator-top-row,.generator-filters{flex-direction:column}.kpi-grid{grid-template-columns:repeat(2,1fr)}.dashboard-top-row,.course-card-grid,.course-detail-grid,.course-bucket-grid,.course-card-metrics{grid-template-columns:1fr}.course-detail-header,.question-numeric-header{flex-direction:column;align-items:flex-start}}
