*{box-sizing:border-box;margin:0;padding:0}html,body{color:#2d3142;background:#f4f6fb;width:100%;min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}textarea,select,input,button{font-family:inherit}.page-loading{color:#6b7280;justify-content:center;align-items:center;min-height:100vh;font-size:1.1rem;display:flex}.login-page{background:radial-gradient(circle at 10% 20%,#4f46e51f,#0000 45%),radial-gradient(circle at 90% 80%,#38bdf81f,#0000 42%),#f4f6fb;justify-content:center;align-items:center;min-height:100vh;padding:20px;display:flex}.login-card{background:linear-gradient(#fff 0%,#fbfcff 100%);border:1px solid #e8ebfb;border-radius:24px;width:100%;max-width:420px;padding:28px 34px 30px;box-shadow:0 24px 60px #161d471f}.login-lang-switch{background:#f7f8ff;border:1px solid #d9def5;border-radius:10px;align-items:center;gap:2px;margin-bottom:18px;padding:3px;display:inline-flex}.login-lang-icon{color:#6b7280;margin:0 4px 0 6px;font-size:.82rem}.login-lang-btn{color:#6b7280;letter-spacing:.03em;cursor:pointer;background:0 0;border:none;border-radius:8px;padding:6px 10px;font-size:.78rem;font-weight:700;transition:background-color .18s,color .18s,transform .16s}.login-lang-btn.active{color:#fff;background:#4f46e5}.login-lang-btn:hover{color:#374151}.login-lang-btn:active{transform:translateY(1px)}.login-logo{background:linear-gradient(135deg,#4f46e5,#3730a3);border-radius:18px;justify-content:center;align-items:center;width:62px;height:62px;margin:0 auto 14px;font-size:2rem;display:flex;box-shadow:0 10px 24px #4f46e547}.login-title{color:#1e1b4b;text-align:center;letter-spacing:-.01em;margin-bottom:6px;font-size:1.62rem;font-weight:800}.login-sub{color:#6b7280;text-align:center;margin-bottom:24px;font-size:.95rem}.login-form{flex-direction:column;gap:16px;margin-bottom:22px;display:flex}.login-footer{text-align:center;color:#9ca3af;font-size:.8rem;line-height:1.5}.app-layout{background:#f4f6fb;flex-direction:column;min-height:100vh;display:flex}.app-header{z-index:10;background:#fff;border-bottom:1px solid #e0e2ec;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:20px 40px;display:flex;position:sticky;top:0;box-shadow:0 1px 8px #0000000a}.header-left{align-items:center;gap:16px;display:flex}.header-logo{font-size:1.8rem}.header-title{color:#1e1b4b;font-size:1.3rem;font-weight:700}.header-sub{color:#6b7280;font-size:.85rem}.header-right{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.header-user-info{background:#fff;border:1px solid #e0e2ec;border-radius:12px;align-items:center;gap:12px;padding:6px 12px;display:flex}.header-clock{font-variant-numeric:tabular-nums;color:#4b5563;font-size:.86rem}.header-user-meta{flex-direction:column;line-height:1.1;display:flex}.header-user-meta strong{color:#1e1b4b;font-size:.88rem}.header-user-meta span{color:#6b7280;font-size:.75rem}.back-link{color:#6b7280;border-radius:8px;padding:6px 12px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s}.back-link:hover{color:#4f46e5;background:#f3f4f6}.app-main{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:36px 24px}.app-footer{text-align:center;color:#9ca3af;border-top:1px solid #e0e2ec;margin-top:auto;padding:24px;font-size:.85rem}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:#374151;font-size:.85rem;font-weight:600}.form-group input,.form-group select,.form-group textarea,.editor-link-grid input{color:#2d3142;background:#fff;border:2px solid #e0e2ec;border-radius:10px;outline:none;width:100%;padding:10px 14px;font-size:.95rem;transition:border-color .2s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus,.editor-link-grid input:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.password-input-wrap{position:relative}.password-input-wrap input{padding-right:52px}.password-toggle{cursor:pointer;background:0 0;border:none;font-size:1rem;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.btn{cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:9px 18px;font-size:.9rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:#4f46e5}.btn-primary:hover{background:#4338ca}.btn-primary:disabled{cursor:not-allowed;background:#a5a6d8}.btn-ghost{color:#374151;background:#fff;border:1px solid #d1d5db}.btn-ghost:hover{background:#f9fafb;border-color:#9ca3af}.btn-full{justify-content:center;width:100%}.btn-sm{padding:6px 12px;font-size:.8rem}.search-bar{color:#2d3142;background:#fff;border:2px solid #e0e2ec;border-radius:14px;outline:none;width:100%;margin-bottom:28px;padding:14px 20px;font-size:1rem;transition:border-color .2s}.search-bar:focus{border-color:#4f46e5;box-shadow:0 0 0 3px #4f46e51a}.search-bar::placeholder{color:#9ca3af}.section-label{color:#6b7280;text-transform:uppercase;letter-spacing:.5px;align-items:center;gap:8px;margin-bottom:18px;font-size:.9rem;font-weight:700;display:flex}.section-count{color:#9ca3af;font-size:.85rem;font-weight:600}.dashboard-primary-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:16px;margin-bottom:28px;display:grid}.dashboard-primary-card{background:#fff;border:1px solid #e0e2ec;border-radius:16px;padding:22px;box-shadow:0 2px 8px #00000008}.dashboard-primary-card h2{color:#1e1b4b;margin-bottom:8px;font-size:1.05rem}.dashboard-primary-card p{color:#6b7280;font-size:.9rem;line-height:1.5}.dashboard-primary-icon{margin-bottom:10px;font-size:1.5rem}.dashboard-primary-card-link{color:inherit;text-decoration:none;transition:all .2s}.dashboard-primary-card-link:hover{border-color:#4f46e5;transform:translateY(-2px);box-shadow:0 10px 20px #4f46e514}.course-list{flex-direction:column;gap:16px;margin-bottom:40px;display:flex}.course-category-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #dfe3f3;border-radius:14px;align-items:center;gap:14px;width:100%;padding:16px 18px;display:flex;box-shadow:0 2px 8px #00000008}.course-category-card:hover{border-color:#4f46e5;box-shadow:0 8px 24px #4f46e514}.course-category-icon{font-size:1.5rem}.course-category-main{flex-direction:column;flex:1;gap:3px;display:flex}.course-category-main strong{color:#1e1b4b;font-size:1rem}.course-category-main span{color:#6b7280;font-size:.88rem}.course-category-count{color:#3730a3;background:#eef2ff;border-radius:999px;justify-content:center;align-items:center;min-width:30px;height:30px;font-weight:700;display:inline-flex}.course-category-toggle{color:#4f46e5;font-size:1.2rem;font-weight:800}.course-card{cursor:pointer;color:inherit;background:#fff;border:1px solid #e0e2ec;border-radius:16px;align-items:stretch;gap:20px;padding:24px;text-decoration:none;transition:all .25s;display:flex;box-shadow:0 2px 8px #00000008}.course-card:hover{border-color:#4f46e5;transform:translate(4px);box-shadow:0 6px 24px #4f46e51a}.course-card-admin .course-icon{color:#9333ea;background:#f3e8ff}.course-icon{background:#f0f0ff;border-radius:16px;flex:none;justify-content:center;align-items:center;width:70px;height:70px;font-size:2.8rem;display:flex}.course-info{flex:1}.course-title{color:#1e1b4b;margin-bottom:8px;font-size:1.2rem;font-weight:700}.course-desc{color:#6b7280;margin-bottom:12px;font-size:.95rem;line-height:1.5}.course-meta{flex-wrap:wrap;gap:8px;display:flex}.meta-tag{color:#3730a3;background:#e0e7ff;border-radius:8px;padding:4px 12px;font-size:.75rem;font-weight:600;display:inline-block}.meta-admin{color:#92400e;background:#fef3c7}.meta-role{color:#6b21a8;background:#f3e8ff}.course-arrow{color:#c7d2fe;flex:none;align-items:center;font-size:1.5rem;transition:color .2s;display:flex}.course-card:hover .course-arrow{color:#4f46e5}.empty-state{text-align:center;color:#9ca3af;padding:60px 20px}.empty-state span{margin-bottom:12px;font-size:3rem;display:block}.day-grid,.tools-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:16px;margin-bottom:32px;display:grid}.day-card{background:#fff;border:1px solid #e0e2ec;border-radius:12px;gap:16px;padding:20px;display:flex}.day-icon{flex:none;font-size:2.2rem}.day-title{color:#1e1b4b;margin-bottom:8px;font-size:1rem;font-weight:700}.day-topics{list-style:none}.day-topics li{color:#6b7280;padding:4px 0 4px 20px;font-size:.9rem;position:relative}.day-topics li:before{content:"→";position:absolute;left:0}.tools-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.tool-card{cursor:pointer;color:inherit;background:#fff;border:1px solid #e0e2ec;border-radius:12px;align-items:center;gap:12px;padding:16px;text-decoration:none;transition:all .2s;display:flex}.tool-card:hover{border-color:#4f46e5;transform:translateY(-2px);box-shadow:0 8px 16px #4f46e51a}.tool-icon{flex:none;font-size:2rem}.tool-card>div{flex:1}.tool-name{color:#1e1b4b;font-size:.9rem;font-weight:700}.tool-desc{color:#9ca3af;font-size:.8rem}.tool-arrow{color:#c7d2fe;flex:none;transition:color .2s}.tool-card:hover .tool-arrow{color:#4f46e5}.tabs{background:#fff;border:1px solid #e0e2ec;border-radius:12px;gap:4px;width:fit-content;margin-bottom:28px;padding:4px;display:flex}.tab{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:9px;padding:8px 20px;font-size:.9rem;font-weight:600;transition:all .15s}.tab.active{color:#fff;background:#4f46e5}.tab:not(.active):hover{color:#374151;background:#f3f4f6}.table-card{background:#fff;border:1px solid #e0e2ec;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px #00000008}.table-toolbar{border-bottom:1px solid #e0e2ec;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:18px 24px;display:flex}.table-toolbar-title{color:#1e1b4b;font-size:.95rem;font-weight:700}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%}thead tr{background:#f8f9ff}th{text-align:left;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;padding:12px 20px;font-size:.75rem;font-weight:700}td{border-top:1px solid #f0f0f8;padding:12px 20px;font-size:.9rem}tbody tr:hover{background:#fafbff}.td-center{text-align:center}.td-bold{font-weight:600}.td-muted{color:#9ca3af}.td-mono{font-family:monospace;font-size:.82rem}.td-action{color:#4f46e5}.td-truncate{text-overflow:ellipsis;white-space:nowrap;max-width:200px;overflow:hidden}.badge{border-radius:8px;padding:4px 12px;font-size:.75rem;font-weight:700;display:inline-block}.badge-dozent{color:#3730a3;background:#e0e7ff}.badge-teilnehmer,.badge-active{color:#065f46;background:#d1fae5}.badge-inactive{color:#991b1b;background:#fee2e2}.badge-role{color:#3730a3;background:#e0e7ff}.actions{flex-wrap:wrap;gap:6px;display:flex}.action-btn{cursor:pointer;border:none;border-radius:7px;padding:5px 12px;font-size:.75rem;font-weight:600;transition:all .15s}.action-deactivate{color:#92400e;background:#fef3c7;border:1px solid #fde68a}.action-deactivate:hover{background:#fde68a}.action-activate{color:#065f46;background:#d1fae5;border:1px solid #6ee7b7}.action-activate:hover{background:#a7f3d0}.action-pw{color:#3730a3;background:#e0e7ff;border:1px solid #c7d2fe}.action-pw:hover{background:#c7d2fe}.action-delete{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.action-delete:hover{background:#fca5a5}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:20px;width:100%;max-width:440px;padding:32px;box-shadow:0 20px 60px #0003}.modal h2{color:#1e1b4b;margin-bottom:20px;font-size:1.2rem;font-weight:700}.modal-actions{justify-content:flex-end;gap:10px;margin-top:24px;display:flex}.settings-main{flex-direction:column;gap:18px;max-width:900px;display:flex}.settings-card{background:#fff;border:1px solid #e0e2ec;border-radius:16px;padding:22px;box-shadow:0 2px 8px #00000008}.settings-card h2{color:#1e1b4b;margin-bottom:14px;font-size:1.05rem}.settings-form{gap:12px;display:grid}.settings-inline-form{margin-top:10px}.settings-hint{color:#6b7280;margin-bottom:12px}.settings-ok{color:#065f46;background:#d1fae5}.mfa-setup-block{background:#f8f9ff;border:1px dashed #c7d2fe;border-radius:12px;gap:10px;margin-top:14px;padding:14px;display:grid}.mfa-qr-wrap{justify-content:center;padding:8px 0;display:flex}.mfa-qr-image{background:#fff;border:1px solid #e0e2ec;border-radius:10px;width:220px;height:220px}.mfa-secret-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.mfa-mono{font-family:monospace;font-size:.86rem}.mfa-wrap{word-break:break-all}.workspace-main{max-width:1180px}.workspace-tabs{margin-bottom:16px}.workspace-subtabs{margin-bottom:18px}.workspace-toolbar{flex-wrap:wrap;justify-content:flex-end;gap:12px;margin-bottom:16px;display:flex}.workspace-panel{background:#fff;border:1px solid #e0e2ec;border-radius:18px;padding:24px;box-shadow:0 2px 8px #00000008}.presentation-shell{gap:18px;display:grid}.presentation-header-row{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.presentation-title{color:#1e1b4b;font-size:1.6rem}.presentation-counter{color:#6b7280;font-weight:700}.presentation-slide{color:#fff;background:linear-gradient(135deg,#1e1b4b,#4f46e5);border-radius:20px;align-items:center;min-height:360px;padding:32px;display:flex;box-shadow:inset 0 1px #ffffff26}.presentation-slide-body{white-space:pre-wrap;max-width:820px;font-size:1.1rem;line-height:1.7}.presentation-actions{justify-content:space-between;gap:12px;display:flex}.resource-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;display:grid}.resource-card{color:inherit;background:#f8f9ff;border:1px solid #e0e2ec;border-radius:14px;gap:10px;padding:18px;text-decoration:none;transition:all .2s;display:grid}.resource-card:hover{border-color:#4f46e5;transform:translateY(-2px);box-shadow:0 10px 24px #4f46e514}.resource-card-title{color:#1e1b4b;font-size:1rem;font-weight:700}.resource-card p{color:#6b7280;line-height:1.5}.resource-card span{color:#4f46e5;word-break:break-word;font-size:.82rem}.workspace-editor-card{margin-bottom:20px}.presentation-panel{padding-top:8px}.presentation-intro{max-width:720px;margin-bottom:28px}.presentation-intro-title{color:#1e1b4b;margin-bottom:10px;font-size:1.35rem;font-weight:700}.presentation-intro-text{color:#4b5563;font-size:.98rem;line-height:1.65}.presentation-intro-text kbd{color:#374151;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:6px;margin:0 2px;padding:2px 8px;font-family:ui-monospace,monospace;font-size:.82rem;display:inline-block}.presentation-launch-grid{grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:28px;padding:8px 0 24px;display:grid}.presentation-launch-card{text-align:center;border:1px solid #c7d2fe;border-radius:22px;flex-direction:column;align-items:center;gap:12px;padding:28px 28px 32px;transition:transform .2s,box-shadow .2s;display:flex;box-shadow:0 8px 32px #4f46e51a}.presentation-launch-card:hover{transform:translateY(-4px);box-shadow:0 14px 40px #4f46e524}.presentation-launch-card--one{background:linear-gradient(160deg,#eef0ff 0%,#f5f3ff 50%,#faf5ff 100%)}.presentation-launch-card--two{background:linear-gradient(160deg,#ecfdf5 0%,#f0fdf4 45%,#f7fee7 100%);border-color:#a7f3d0;box-shadow:0 8px 32px #10b9811f}.presentation-launch-card--two:hover{box-shadow:0 14px 40px #10b9812e}.presentation-launch-folie{flex-direction:column;align-items:center;gap:2px;margin-bottom:4px;display:flex}.presentation-launch-num{background:linear-gradient(135deg,#4f46e5,#7c3aed);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:3rem;font-weight:800;line-height:1}.presentation-launch-card--two .presentation-launch-num{background:linear-gradient(135deg,#059669,#10b981);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.presentation-launch-label{text-transform:uppercase;letter-spacing:.18em;color:#6b7280;font-size:.75rem;font-weight:700}.presentation-launch-day{letter-spacing:.06em;color:#5b21b6;font-size:.95rem;font-weight:700}.presentation-launch-card--two .presentation-launch-day{color:#047857}.presentation-launch-title{color:#1e1b4b;font-size:1.45rem;font-weight:700;line-height:1.25}.presentation-launch-desc{color:#4b5563;max-width:340px;margin:0 auto;font-size:.95rem;line-height:1.55}.presentation-launch-meta{color:#6b7280;font-size:.88rem}.presentation-launch-btn{margin-top:10px;display:inline-block;padding:14px 28px!important;font-size:1.05rem!important}.editor-textarea{resize:vertical;min-height:220px}.editor-help{color:#6b7280;font-size:.8rem}.editor-list-block{background:#fbfbff;border:1px solid #e0e2ec;border-radius:14px;gap:10px;padding:16px;display:grid}.editor-list-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.editor-list-header h3{color:#1e1b4b;font-size:1rem}.editor-link-grid{grid-template-columns:1fr 1.2fr 1.2fr auto;align-items:center;gap:10px;display:grid}.assignment-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:10px;display:grid}.assignment-item{background:#f8f9ff;border:1px solid #e0e2ec;border-radius:10px;align-items:center;gap:10px;padding:10px 12px;display:flex}.assignment-item input{width:auto}.alert{border-radius:8px;margin-bottom:16px;padding:12px 16px;font-size:.9rem}.alert-error{color:#991b1b;background:#fee2e2}.toast{z-index:200;border-radius:12px;padding:14px 22px;font-size:.9rem;font-weight:600;animation:.3s slideIn;position:fixed;bottom:28px;right:28px;box-shadow:0 8px 24px #00000026}.toast-success{color:#fff;background:#065f46}.toast-error{color:#fff;background:#991b1b}@keyframes slideIn{0%{opacity:0;transform:translateY(80px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.app-header{flex-direction:column;align-items:flex-start;padding:16px}.header-right{justify-content:space-between;width:100%}.header-user-info{width:100%}.app-main{padding:20px 16px}.workspace-toolbar{justify-content:stretch}.editor-link-grid{grid-template-columns:1fr}.presentation-slide{min-height:260px;padding:20px}.course-card{flex-direction:column;gap:12px}.course-icon{width:56px;height:56px;margin:0 auto;font-size:2.2rem}.course-arrow{display:none}th,td{padding:10px 12px}.table-toolbar{flex-direction:column;align-items:flex-start}}
