:root{--navy-950:#0a0e1a;--navy-900:#0f1629;--navy-800:#1a2342;--navy-700:#243056;--navy-600:#2e3d6b;--navy-500:#3d5291;--navy-400:#5b73b5;--navy-300:#8b9dd4;--navy-200:#b8c4e6;--navy-100:#e0e5f2;--gold-500:#f59e0b;--gold-400:#fbbf24;--gold-300:#fcd34d;--emerald-500:#10b981;--emerald-400:#34d399;--rose-500:#f43f5e;--sky-500:#0ea5e9;--bg-body:#070b14;--bg-surface:#0f1629cc;--bg-surface-hover:#1a2342e6;--bg-elevated:#1a234299;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--border-subtle:#5b73b526;--border-default:#5b73b540;--gradient-primary:linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-gold:linear-gradient(135deg, #f093fb 0%, #f5576c 50%, #fda085 100%);--gradient-header:linear-gradient(135deg, #0f1629 0%, #1a2342 50%, #243056 100%);--gradient-text:linear-gradient(135deg, #e0e5f2 0%, #8b9dd4 40%, #667eea 70%, #764ba2 100%);--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 12px #0006;--shadow-lg:0 8px 32px #00000080;--shadow-glow:0 0 20px #667eea26;--radius-sm:.5rem;--radius-md:.75rem;--radius-lg:1rem;--radius-xl:1.25rem;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--bg-image-1:#667eea1f;--bg-image-2:#764ba214}[data-theme=light]{--navy-900:#fff;--navy-800:#f8fafc;--bg-body:#f1f5f9;--bg-surface:#ffffffe6;--bg-surface-hover:#f8fafce6;--bg-elevated:#fff;--text-primary:#0f172a;--text-secondary:#475569;--text-muted:#64748b;--border-subtle:#94a3b833;--border-default:#94a3b866;--gradient-header:linear-gradient(135deg, #f8fafc 0%, #f1f5f9 50%, #e2e8f0 100%);--gradient-text:linear-gradient(135deg, #0f172a 0%, #334155 40%, #667eea 70%, #764ba2 100%);--shadow-sm:0 1px 2px #0000000d;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -2px #0000000d;--shadow-glow:0 0 15px #667eea4d;--bg-image-1:#667eea0d;--bg-image-2:#764ba208}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-body);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-image:radial-gradient(ellipse 80% 50% at 50% -20%, var(--bg-image-1), transparent), radial-gradient(ellipse 60% 40% at 80% 80%, var(--bg-image-2), transparent);min-height:100vh;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;line-height:1.6;transition:background-color .3s,color .3s}.app-container{flex-direction:column;gap:2rem;max-width:1440px;margin:0 auto;padding:2rem 2.5rem;display:flex}.header{text-align:center;padding:2.5rem 0 1.5rem}.header-badge{color:#8b9dd4;letter-spacing:.08em;text-transform:uppercase;background:#667eea1f;border:1px solid #667eea33;border-radius:9999px;align-items:center;gap:.5rem;margin-bottom:1rem;padding:.4rem 1rem;font-size:.75rem;font-weight:600;display:inline-flex}.header h1{letter-spacing:-.03em;background:var(--gradient-text);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin-bottom:.5rem;font-size:2.75rem;font-weight:900;line-height:1.2}.header p{color:var(--text-muted);font-size:1rem;font-weight:400}.card{background:var(--bg-surface);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:var(--radius-xl);border:1px solid var(--border-subtle);transition:var(--transition);overflow:hidden}.card:hover{border-color:var(--border-default)}.card-title{color:var(--text-primary);align-items:center;gap:.5rem;font-size:1.125rem;font-weight:700;display:flex}.form-group{margin-bottom:1rem}.form-group label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.4rem;font-size:.8rem;font-weight:600;display:block}.form-control{background-color:var(--navy-900);border:1px solid var(--border-default);border-radius:var(--radius-md);width:100%;color:var(--text-primary);transition:var(--transition);padding:.65rem .9rem;font-family:Inter,sans-serif;font-size:.9rem}.form-control:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea26}.form-control option{background-color:var(--navy-900);color:var(--text-primary)}.btn{border-radius:var(--radius-md);cursor:pointer;transition:var(--transition);border:none;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.7rem 1.25rem;font-family:Inter,sans-serif;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:0 2px 8px #667eea4d}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.btn-danger{color:var(--rose-500);background:0 0;border:1px solid #f43f5e4d}.btn-danger:hover{border-color:var(--rose-500);background:#f43f5e1a}.file-drop-area{border:2px dashed var(--border-default);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:var(--transition);background-color:var(--bg-surface-hover);padding:1.75rem}.file-drop-area:hover{background-color:#667eea0d;border-color:#667eea}.file-icon{color:var(--text-muted);margin-bottom:.25rem}.file-text{color:var(--text-secondary);font-size:.85rem;font-weight:500}.table-container{border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:var(--shadow-md);overflow-x:auto}.table{border-collapse:collapse;text-align:left;background-color:var(--navy-900);width:100%}.table th{background:var(--gradient-header);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;z-index:10;border-bottom:2px solid #667eea4d;padding:.9rem 1.2rem;font-size:.7rem;font-weight:700;position:sticky;top:0}.table td{border-bottom:1px solid var(--border-subtle);vertical-align:middle;padding:.9rem 1.2rem;font-size:.9rem}.table tbody tr{transition:var(--transition)}.table tbody tr:nth-child(2n){background-color:var(--bg-surface-hover)}.table tbody tr:hover{background-color:#667eea0f}.table tr:last-child td{border-bottom:none}.row-number{color:var(--navy-400);text-align:center;width:2rem;font-family:JetBrains Mono,monospace;font-size:.85rem;font-weight:700}.row-break{background:linear-gradient(90deg,#f59e0b14 0%,#f59e0b26 50%,#f59e0b14 100%)!important}.row-break:hover{background:linear-gradient(90deg,#f59e0b1f 0%,#f59e0b33 50%,#f59e0b1f 100%)!important}.row-break td{text-align:center;border-bottom-color:#f59e0b33!important;padding:1rem!important}.break-label{color:var(--gold-400);letter-spacing:.08em;text-transform:uppercase;align-items:center;gap:.5rem;font-size:.85rem;font-weight:700;display:inline-flex}.badge{white-space:nowrap;letter-spacing:.02em;border-radius:9999px;align-items:center;gap:.3rem;padding:.3rem .75rem;font-size:.72rem;font-weight:600;display:inline-flex}.badge-primary{color:#8b9dd4;background-color:#667eea26;border:1px solid #667eea40}.badge-lab1{color:var(--sky-500);background-color:#0ea5e91f;border:1px solid #0ea5e940}.badge-lab2{color:var(--emerald-400);background-color:#10b9811f;border:1px solid #10b98140}.badge-lab3{color:#a855f7;background-color:#a855f71f;border:1px solid #a855f740}.badge-lab4{color:var(--rose-500);background-color:#f43f5e1f;border:1px solid #f43f5e40}.time-slot{color:var(--text-primary);border-radius:var(--radius-sm);background:#667eea14;border:1px solid #667eea26;padding:.25rem .6rem;font-family:JetBrains Mono,monospace;font-size:.95rem;font-weight:700}.group-name{color:var(--text-primary);font-size:.9rem;font-weight:700}.members-list{flex-wrap:wrap;gap:.4rem;margin:0;padding:0;list-style:none;display:flex}.member-chip{background-color:var(--navy-800);border:1px solid var(--border-subtle);color:var(--text-secondary);transition:var(--transition);border-radius:9999px;align-items:center;gap:.3rem;padding:.2rem .65rem;font-size:.78rem;display:inline-flex}.member-chip:hover{color:var(--text-primary);background-color:#667eea14;border-color:#667eea66}.class-list{flex-direction:column;gap:.6rem;display:flex}.class-item{background-color:var(--navy-900);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:var(--transition);justify-content:space-between;align-items:center;padding:.75rem 1rem;display:flex}.class-item:hover{border-color:var(--border-default)}.class-item-title{color:var(--text-primary);font-size:.85rem;font-weight:600}.class-item-meta{color:var(--text-muted);margin-top:.15rem;font-size:.72rem}.action-btn{color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:0 0;border:none;padding:.35rem}.action-btn:hover{color:var(--rose-500);background-color:#f43f5e1a}.empty-state{text-align:center;color:var(--text-muted);padding:4rem 2rem}.empty-state h3{color:var(--text-secondary);margin-bottom:.5rem;font-size:1.25rem;font-weight:700}.empty-state p{max-width:380px;margin:0 auto;font-size:.9rem;line-height:1.6}.empty-icon{color:var(--navy-600);width:56px;height:56px;margin:0 auto 1.25rem}.day-section{margin-bottom:2.5rem}.day-section:last-child{margin-bottom:0}.day-header{color:var(--text-primary);border-bottom:2px solid var(--border-subtle);letter-spacing:-.01em;align-items:center;gap:.75rem;margin-bottom:1rem;padding-bottom:.75rem;font-size:1.2rem;font-weight:800;display:flex}.day-badge{letter-spacing:.06em;text-transform:uppercase;background:var(--gradient-primary);color:#fff;border-radius:9999px;align-items:center;padding:.25rem .75rem;font-size:.7rem;font-weight:700;display:inline-flex}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:#00000080;justify-content:center;align-items:center;animation:.2s ease-out forwards fadeIn;display:flex;position:fixed;inset:0}.modal-container{background:var(--navy-800);border:1px solid var(--border-default);border-radius:var(--radius-xl);width:100%;max-width:580px;box-shadow:var(--shadow-lg), var(--shadow-glow);flex-direction:column;max-height:85vh;animation:.3s cubic-bezier(.16,1,.3,1) forwards slideUp;display:flex}.modal-header{border-bottom:1px solid var(--border-subtle);background:var(--gradient-header);justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.modal-header h2{color:var(--text-primary);margin:0;font-size:1.1rem;font-weight:700}.modal-close{border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:var(--transition);background:#ffffff0d;padding:.35rem}.modal-close:hover{color:var(--text-primary);background-color:#ffffff1a}.modal-body{padding:1.5rem;overflow-y:auto}.modal-section{border-bottom:1px solid var(--border-subtle);margin-bottom:1.75rem;padding-bottom:1.75rem}.modal-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.modal-section-title{color:var(--text-primary);align-items:center;gap:.5rem;margin-bottom:1rem;font-size:.95rem;font-weight:700;display:flex}.checkbox-wrapper{cursor:pointer;align-items:center;gap:.6rem;margin-bottom:1rem;display:flex}.checkbox-wrapper input[type=checkbox]{accent-color:#667eea;cursor:pointer;width:1.1rem;height:1.1rem}.checkbox-label{color:var(--text-primary);font-size:.9rem;font-weight:600}.break-config{background-color:var(--bg-elevated);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:1rem}.fab-container{z-index:100;position:fixed;bottom:2rem;right:2rem}.fab-btn{background:var(--gradient-primary);color:#fff;cursor:pointer;border:none;border-radius:9999px;align-items:center;gap:.6rem;height:56px;padding:0 1.5rem;font-family:Inter,sans-serif;font-size:.9rem;font-weight:700;transition:transform .25s cubic-bezier(.16,1,.3,1),box-shadow .25s;display:flex;box-shadow:0 4px 20px #667eea59}.fab-btn:hover{transform:translateY(-4px);box-shadow:0 8px 30px #667eea73}.error-alert{color:var(--rose-500);border-radius:var(--radius-md);background:#f43f5e1a;border:1px solid #f43f5e40;margin-bottom:1.25rem;padding:.9rem 1.2rem;font-size:.85rem;font-weight:500}.stats-bar{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.stat-card{background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:var(--radius-md);flex:1;align-items:center;gap:.75rem;min-width:160px;padding:.75rem 1.25rem;display:flex}.stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:36px;height:36px;display:flex}.stat-icon-purple{color:#667eea;background:#667eea1f}.stat-icon-emerald{color:var(--emerald-400);background:#10b9811f}.stat-icon-gold{color:var(--gold-400);background:#f59e0b1f}.stat-icon-sky{color:var(--sky-500);background:#0ea5e91f}.stat-value{color:var(--text-primary);font-size:1.25rem;font-weight:800;line-height:1.2}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;font-weight:600}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)scale(.98)}to{opacity:1;transform:translateY(0)scale(1)}}@media (width<=768px){.app-container{padding:1rem}.header h1{font-size:1.75rem}.stats-bar{flex-direction:column}.fab-btn span{display:none}.fab-btn{justify-content:center;width:56px;height:56px;padding:0}.filter-container{flex-direction:column;align-items:flex-start!important;gap:.75rem!important}.filter-item{justify-content:space-between;width:100%}.filter-item select{flex:1;margin-left:.5rem;max-width:none!important}.table-container{box-shadow:none;background:0 0;border:none}.table,.table tbody,.table tr,.table td{width:100%;display:block}.table thead{display:none}.table tr{background-color:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:1.25rem;padding:1rem 1.25rem}.table td{border:none;border-bottom:1px dashed var(--border-subtle);justify-content:space-between;align-items:center;padding:.6rem 0;display:flex}.table td:last-child{border-bottom:none;padding-bottom:0}.table td:before{content:attr(data-label);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;margin-right:1rem;font-size:.75rem;font-weight:700}.table td[data-label=Anggota]{flex-direction:column;align-items:flex-start;gap:.75rem}.table td[data-label=Anggota]:before{border-bottom:1px solid var(--border-subtle);width:100%;margin-right:0;padding-bottom:.25rem}.table td[data-label=No]{display:none}.row-break{padding:1.5rem!important}.row-break td{text-align:center;display:block;border-bottom:none!important}.row-break td:before{display:none}.time-slot{padding:.3rem .6rem;font-size:.9rem}.member-chip{padding:.2rem .6rem;font-size:.8rem}}
