*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--g9: #003d24;--g8: #00693E;--g7: #00874f;--acc: #B9D9EB;--acc2: #8ec8e0;--white: #fff;--bg: #f0f7fb;--border:#cce4f0;--text: #0d2416;--muted: #6b8fa3;--r: 12px;--shadow: 0 2px 12px rgba(0,105,62,.08)}body{font-family:Plus Jakarta Sans,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}@keyframes slideDown{0%{transform:translateY(-64px);opacity:0}to{transform:none;opacity:1}}@keyframes fadeUp{0%{transform:translateY(16px);opacity:0}to{transform:none;opacity:1}}@keyframes modalIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:none}}@keyframes panelIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.hero{background:linear-gradient(135deg,var(--g9) 0%,var(--g8) 55%,var(--g7) 100%);padding:2rem 1.5rem 3.5rem;animation:fadeUp .5s .08s cubic-bezier(.16,1,.3,1) both;overflow:hidden}.hero-inner{max-width:1280px;margin:auto;text-align:center}.hero-eyebrow{font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#b9d9eb8c;margin-bottom:5px}.hero-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:clamp(1.5rem,4vw,2.1rem);color:#fff;letter-spacing:-.02em;margin-bottom:4px}.hero-desc{font-size:13px;color:#b9d9eb8c;margin-bottom:14px}.period-badge{display:inline-flex;align-items:center;gap:7px;padding:5px 13px;border-radius:999px;background:#b9d9eb1a;border:1px solid rgba(185,217,235,.22);font-size:13px;font-weight:600;color:var(--acc);transition:background .2s}.period-badge:hover{background:#b9d9eb2e}.legend{display:flex;flex-wrap:wrap;gap:7px;margin-top:13px;animation:fadeUp .5s .14s cubic-bezier(.16,1,.3,1) both;justify-content:center}.legend-item{display:flex;align-items:center;gap:7px;padding:5px 11px;border-radius:8px;background:#b9d9eb12;border:1px solid rgba(185,217,235,.14);transition:background .15s,transform .15s;cursor:default}.legend-item:hover{background:#b9d9eb24;transform:translateY(-1px)}.legend-dot{width:13px;height:13px;border-radius:4px;flex-shrink:0}.legend-text{font-size:11px;color:#b9d9ebd9}.main{max-width:1280px;margin:-20px auto 0;padding:0 1.5rem 3rem;animation:fadeUp .5s .2s cubic-bezier(.16,1,.3,1) both}.flash{margin-bottom:14px;padding:11px 15px;border-radius:10px;font-size:13px;font-weight:600;animation:fadeUp .3s both}.flash-ok{color:#00693e;background:#e8f5fb;border:1px solid #B9D9EB}.flash-err{color:#991b1b;background:#fef2f2;border:1px solid #fecaca}.week-nav{display:flex;align-items:center;gap:8px;margin-bottom:16px}.week-btn{display:flex;align-items:center;gap:5px;font-size:13px;font-weight:700;text-decoration:none;padding:9px 16px;border-radius:11px;flex-shrink:0;transition:transform .15s,box-shadow .15s;cursor:pointer;border:none;font-family:inherit}.week-btn:hover{transform:translateY(-2px)}.week-btn-prev{background:linear-gradient(135deg,var(--g9),var(--g8));color:var(--acc);box-shadow:0 3px 10px #003d2438}.week-btn-prev:hover{box-shadow:0 6px 16px #003d2452}.week-btn-next{background:linear-gradient(135deg,var(--acc),var(--acc2));color:var(--g9);box-shadow:0 3px 10px #b9d9eb59}.week-btn-next:hover{box-shadow:0 6px 16px #b9d9eb73}.week-label{flex:1;min-width:0;text-align:center;font-size:12px;font-weight:700;color:var(--g8);background:#fff;padding:9px 12px;border-radius:10px;border:1.5px solid var(--border);box-shadow:0 1px 4px #00693e0d}.tabs{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}.tab-btn{display:flex;align-items:center;gap:7px;padding:8px 15px;border-radius:11px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;border:1.5px solid var(--border);background:#fff;color:var(--muted);transition:border-color .18s,color .18s,transform .18s,box-shadow .18s,background .18s;white-space:nowrap}.tab-btn:hover:not(.tab-active){border-color:var(--acc);color:var(--g7);transform:translateY(-1px);box-shadow:0 3px 10px #00693e1a}.tab-btn.tab-active{background:linear-gradient(135deg,var(--g9),var(--g8));color:var(--acc);border-color:transparent;box-shadow:0 4px 14px #003d2447;transform:translateY(-1px)}.skeleton-wrap{background:#fff;border-radius:14px;border:1px solid var(--border);box-shadow:var(--shadow);overflow:hidden;display:none}.skel-header{display:flex;align-items:center;gap:13px;padding:15px 22px;background:linear-gradient(135deg,var(--g9),var(--g8))}.skel-icon{width:38px;height:38px;border-radius:11px;background:#b9d9eb26;border:1.5px solid rgba(185,217,235,.25);animation:pulse 2s ease-in-out infinite}.skel-header-text{flex:1;display:flex;flex-direction:column;gap:4px}.skel-title{height:20px;width:150px;border-radius:6px;background:linear-gradient(90deg,#b9d9eb33 25%,#b9d9eb59,#b9d9eb33 75%);background-size:600px 100%;animation:shimmer 1.4s infinite}.skel-cap{height:14px;width:100px;border-radius:4px;background:linear-gradient(90deg,#b9d9eb26 25%,#b9d9eb40,#b9d9eb26 75%);background-size:600px 100%;animation:shimmer 1.4s infinite;animation-delay:.1s}.skel-actions{display:flex;gap:8px}.skel-btn{width:80px;height:32px;border-radius:8px;background:linear-gradient(90deg,#b9d9eb1a 25%,#b9d9eb33,#b9d9eb1a 75%);background-size:600px 100%;animation:shimmer 1.4s infinite;animation-delay:.2s}.skel-body{padding:0;overflow:hidden}.skel-table{padding:12px 16px;display:flex;flex-direction:column;gap:6px}.skel-row{display:grid;grid-template-columns:78px repeat(7,1fr);gap:5px}.skel-cell{height:56px;border-radius:9px;background:linear-gradient(90deg,#cce4f0 25%,#daeef8,#cce4f0 75%);background-size:600px 100%;animation:shimmer 1.4s infinite}.skel-cell-time{height:40px;background:linear-gradient(90deg,#eaf5fc 25%,#f5fbff,#eaf5fc 75%);background-size:600px 100%}.skel-cell-day{height:36px;background:linear-gradient(90deg,#eaf5fc 25%,#f5fbff,#eaf5fc 75%);background-size:600px 100%}.skel-card{position:relative;background:linear-gradient(135deg,#e8f5fb 25%,#d4eef7,#e8f5fb 75%);background-size:600px 100%;border:1.5px solid #cce4f0}.skel-card:before{content:"";position:absolute;top:6px;left:9px;width:60%;height:12px;border-radius:4px;background:linear-gradient(90deg,#cce4f0 25%,#daeef8,#cce4f0 75%);background-size:600px 100%;animation:shimmer 1.4s infinite}.skel-card:after{content:"";position:absolute;top:22px;left:9px;width:40%;height:8px;border-radius:3px;background:linear-gradient(90deg,#daeef8 25%,#e8f5fb,#daeef8 75%);background-size:600px 100%;animation:shimmer 1.4s infinite;animation-delay:.1s}@keyframes pulse{0%,to{opacity:1}50%{opacity:.7}}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.lab-panel{animation:panelIn .28s cubic-bezier(.16,1,.3,1) both}.panel-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);border:1px solid var(--border);overflow:hidden}.panel-header{display:flex;align-items:center;gap:13px;padding:15px 22px;background:linear-gradient(135deg,var(--g9),var(--g8))}.panel-icon{width:38px;height:38px;border-radius:11px;background:#b9d9eb1f;border:1.5px solid rgba(185,217,235,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}.panel-name{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;color:#fff;font-size:17px}.panel-cap{font-size:11px;color:#b9d9eb80;margin-top:2px}.swipe-hint{display:none}@media (max-width: 768px){.swipe-hint{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--muted);background:#fff;border:1px solid var(--border);border-radius:8px;padding:6px 12px;margin:10px 16px 0;width:-moz-fit-content;width:fit-content}}.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.tbl-wrap::-webkit-scrollbar{height:4px}.tbl-wrap::-webkit-scrollbar-thumb{background:var(--acc);border-radius:4px}table{width:100%;border-collapse:collapse;min-width:780px;font-size:12px;height:1px}thead tr{background:#eaf5fc;border-bottom:2px solid var(--border)}thead th{padding:9px 7px;text-align:center;font-size:10px;font-weight:700;color:var(--muted);letter-spacing:.1em;text-transform:uppercase;width:calc((100% - 78px) / 7)}thead th.col-time{text-align:left;padding-left:13px;width:78px}thead th.th-today{color:var(--g8);border-bottom:3px solid var(--acc)}thead th.th-sun{color:#dc2626}tbody tr{border-top:1px solid #ddeef7;transition:background .12s}tbody tr:hover,tbody tr:hover .col-time{background:#eef6fb}.col-time{padding:9px 9px 9px 13px;position:sticky;left:0;z-index:2;background:#fff;border-right:1px solid #ddeef7}.slot-label{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;color:var(--text);font-size:11px}.slot-time{font-size:10px;color:var(--muted);margin-top:1px}td.slot-td{padding:4px 3px;border-right:1px solid #ddeef7}td.slot-td.td-today{background:#00693e08}td.slot-td.td-sun{background:#fee2e226}.sc{border-radius:9px;padding:6px 9px;overflow:hidden;position:relative;transition:transform .18s,box-shadow .18s,filter .18s}.sc:before{content:"";position:absolute;top:0;left:-70%;width:45%;height:100%;background:linear-gradient(105deg,transparent,rgba(255,255,255,.2),transparent);transform:skew(-18deg);transition:left .45s ease;pointer-events:none}.sc:hover:before{left:130%}.sc:hover{transform:translateY(-2px) scale(1.02);box-shadow:0 6px 16px #0000001a;filter:brightness(1.04);z-index:4}.sc-name{font-weight:700;font-size:11px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-class,.sc-subject{font-size:10px;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sc-status{font-size:10px;margin-top:1px}.sc-tetap{background:linear-gradient(135deg,#d4eef7,#9fd4c8);border:1.5px solid var(--acc)}.sc-tetap .sc-name{color:var(--g9)}.sc-tetap .sc-class{color:var(--g7)}.sc-tetap .sc-subject{color:#1a7a52}.sc-approved{background:linear-gradient(135deg,#e8f5fb,#a8daf0);border:1.5px solid #1a9e6e}.sc-approved .sc-name{color:#003d24}.sc-approved .sc-class{color:#00693e}.sc-approved .sc-status{color:#00874f}.sc-pending{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fcd34d}.sc-pending .sc-name{color:#92400e}.sc-pending .sc-class{color:#b45309}.sc-pending .sc-status{color:#f59e0b}.slot-past{text-align:center;padding:13px 0;font-size:11px;color:var(--muted);opacity:.3}.slot-locked{text-align:center;padding:9px 3px;border-radius:9px;background:#fee2e266;border:1.5px dashed #fca5a5}.bk-btn{width:100%;border-radius:9px;padding:13px 3px;background:transparent;cursor:pointer;border:1.5px dashed #B9D9EB;transition:background .18s,border-color .18s,transform .18s,box-shadow .18s;display:flex;flex-direction:column;align-items:center;gap:3px}.bk-btn:hover{background:#00693e0d;border-color:var(--acc);transform:scale(1.04);box-shadow:0 3px 12px #00693e1f}.bk-btn:hover .bk-icon{color:var(--acc);transform:rotate(90deg)}.bk-icon{transition:transform .2s,color .2s;color:#c5bfb4}.bk-text{font-size:10px;font-weight:500;color:var(--muted)}.bk-btn-sun{border-color:#fca5a5}.bk-btn-sun:hover{background:#f871710d;border-color:#f87171;box-shadow:0 3px 12px #f871711f}.bk-btn-sun:hover .bk-icon{color:#f87171}.bk-btn-sun .bk-icon,.bk-btn-sun .bk-text{color:#fca5a5}.break-row td{text-align:center;padding:8px;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;background:linear-gradient(135deg,#fef9ec,#fef3c7);color:#92400e;border-top:1px solid #fde68a;border-bottom:1px solid #fde68a}td.td-sun[rowspan]{padding:6px!important;vertical-align:top;width:calc((100% - 78px) / 7);max-width:calc((100% - 78px) / 7);overflow:hidden;height:100%}td.td-sun[rowspan] .sc{height:100%;min-height:400px;display:flex;flex-direction:column;justify-content:flex-start;padding:8px}td.td-sun[rowspan] .bk-btn{height:100%;min-height:400px;width:100%;justify-content:center}.detail-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:110;background:#003d24d1;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);align-items:center;justify-content:center;padding:1rem}.detail-overlay.show{display:flex}.detail-box{background:#fff;border-radius:16px;width:100%;max-width:420px;max-height:93vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;animation:modalIn .22s cubic-bezier(.16,1,.3,1)}.detail-head{padding:16px 20px 14px;flex-shrink:0}.detail-head-top{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.detail-type{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:3px}.detail-teacher{font-family:Plus Jakarta Sans,sans-serif;font-weight:800;font-size:18px;line-height:1.2}.detail-close{background:none;border:none;cursor:pointer;padding:4px;border-radius:7px;flex-shrink:0;transition:background .15s;color:#fff9}.detail-close:hover{background:#ffffff26;color:#fff}.detail-body{flex:1;overflow-y:auto;padding:14px 20px 18px;display:flex;flex-direction:column;gap:10px}.detail-row{display:flex;align-items:flex-start;gap:10px;padding:9px 12px;border-radius:9px;background:#eaf5fc;border:1px solid var(--border)}.detail-icon{font-size:14px;flex-shrink:0;margin-top:1px}.detail-key{font-size:10px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.detail-val{font-size:13px;font-weight:600;color:var(--text);margin-top:1px}.modal-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;background:#003d24d1;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);align-items:center;justify-content:center;padding:1rem}.modal-overlay.show{display:flex}.modal-box{background:#fff;border-radius:16px;width:100%;max-width:510px;max-height:93vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000059;animation:modalIn .22s cubic-bezier(.16,1,.3,1)}.modal-head{padding:18px 22px 14px;flex-shrink:0;background:linear-gradient(135deg,var(--g9),var(--g8))}.modal-head-top{display:flex;align-items:flex-start;justify-content:space-between}.modal-eyebrow{font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#b9d9eb8c;margin-bottom:3px}.modal-title{font-family:Plus Jakarta Sans,sans-serif;font-weight:700;font-size:19px;color:#fff}.modal-close{background:none;border:none;cursor:pointer;color:#b9d9eb80;padding:4px;border-radius:7px;transition:color .15s,background .15s}.modal-close:hover{color:var(--acc);background:#b9d9eb1a}.modal-badges{display:flex;flex-wrap:wrap;gap:5px;margin-top:11px}.badge{font-size:11px;padding:3px 10px;border-radius:999px;font-weight:600;background:#b9d9eb1a;color:var(--acc);border:1px solid rgba(185,217,235,.2);white-space:nowrap}.modal-body{flex:1;overflow-y:auto;padding:18px 22px;display:flex;flex-direction:column;gap:13px}.field-label{display:block;font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:5px}.inp{width:100%;border-radius:9px;border:1.5px solid var(--border);padding:9px 12px;font-size:13px;font-family:inherit;background:#f5fbff;outline:none;transition:border-color .15s,box-shadow .15s,transform .12s}.inp:focus{border-color:var(--acc);box-shadow:0 0 0 3px #00693e1a;transform:translateY(-1px)}.inp:disabled{opacity:.5;cursor:not-allowed;background:#ddeef7}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:11px}.slot-opts{display:flex;gap:7px;flex-wrap:wrap}.slot-opt{flex:1;min-width:100px;padding:9px 11px;border-radius:10px;cursor:pointer;text-align:center;font-size:12px;font-family:inherit;border:2px solid var(--border);background:#f5fbff;color:var(--muted);transition:border-color .15s,background .15s,color .15s,transform .15s,box-shadow .15s;display:flex;flex-direction:column;align-items:center;gap:3px;line-height:1.3}.slot-opt-label{font-weight:700;font-size:12px}.slot-opt-time{font-size:10px;opacity:.75}.slot-opt:not(:disabled):hover{border-color:var(--acc2);background:#eaf5fc;color:var(--g8);transform:translateY(-1px);box-shadow:0 3px 10px #00693e1a}.slot-opt.selected{border-color:var(--g7);background:linear-gradient(135deg,var(--g9),var(--g8));color:var(--acc);box-shadow:0 3px 12px #003d2440}.slot-opt.selected .slot-opt-time{opacity:.7}.slot-opt-full{border-color:var(--acc2);background:linear-gradient(135deg,#e0f2fe,#bae6fd);color:var(--g9);border-width:2px;border-style:dashed}.slot-opt-full:hover{background:linear-gradient(135deg,#bae6fd,#7dd3fc)!important;border-color:var(--g7)!important;border-style:solid;color:var(--g9)!important;box-shadow:0 3px 12px #00693e2e!important}.slot-opt-full.selected{border-color:var(--acc);border-style:solid;background:linear-gradient(135deg,var(--g8),var(--g7));color:#fff;box-shadow:0 3px 14px #00693e4d}.slot-opt-full.selected .slot-opt-time{opacity:.8}.slot-opt:disabled{opacity:.5;cursor:not-allowed;border-style:dashed}.slot-duration-wrap{background:#eaf5fc;border:1.5px solid var(--border);border-radius:11px;padding:11px 13px}.modal-actions{display:flex;gap:9px;padding-top:3px;padding-bottom:3px}.btn-cancel{flex:1;background:#ddeef7;border:none;color:var(--text);font-weight:700;padding:12px;border-radius:11px;font-size:13px;font-family:inherit;cursor:pointer;transition:background .15s,transform .15s}.btn-cancel:hover{background:#cce4f0;transform:translateY(-1px)}.btn-submit{flex:1;background:linear-gradient(135deg,var(--g9),var(--g8));border:none;color:var(--acc);font-weight:700;padding:12px;border-radius:11px;font-size:13px;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #003d2440;transition:transform .15s,box-shadow .15s,filter .15s}.btn-submit:hover{transform:translateY(-2px);box-shadow:0 6px 20px #003d2459;filter:brightness(1.08)}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(20px);background:var(--g9);color:#fff;padding:12px 22px;border-radius:12px;font-size:13px;font-weight:600;box-shadow:0 6px 24px #00000040;z-index:9999;opacity:0;transition:opacity .25s,transform .25s;white-space:nowrap;border-left:4px solid #ef4444}.toast.show{opacity:1;transform:translate(-50%) translateY(0)}.hide-xs{display:inline}.show-xs{display:none}@media (max-width: 600px){.hide-xs{display:none}.show-xs{display:inline}.field-row{grid-template-columns:1fr}.hero,.main{padding-left:1rem;padding-right:1rem}}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;transition-duration:.01ms!important}}.sc-important{background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1.5px solid #fcd34d}.sc-important .sc-name{color:#78350f}.sc-important .sc-subject{color:#92400e}.sc-important .sc-status{color:#b45309}.detail-head--important{background:linear-gradient(135deg,#78350f,#92400e)}.detail-head--important .detail-type{color:#fde68ab3}.detail-head--important .detail-teacher{color:#fef3c7}.detail-head--tetap{background:linear-gradient(135deg,var(--g9),var(--g8))}.detail-head--tetap .detail-type{color:#b9d9eb8c}.detail-head--tetap .detail-teacher{color:#fff}.detail-head--approved{background:linear-gradient(135deg,#003d24,#00693e)}.detail-head--approved .detail-type{color:#b9d9eb99}.detail-head--approved .detail-teacher{color:#e8f5fb}.detail-head--pending{background:linear-gradient(135deg,#78350f,#92400e)}.detail-head--pending .detail-type{color:#fde68a99}.detail-head--pending .detail-teacher{color:#fffbeb}.detail-badge{display:inline-block;font-size:11px;font-weight:700;padding:4px 13px;border-radius:999px;margin-top:4px;align-self:flex-start}.detail-badge--important{background:#fef3c7;color:#78350f;border:1.5px solid #fcd34d}.detail-badge--approved{background:#e8f5fb;color:#00693e;border:1.5px solid #8ec8e0}.detail-badge--pending{background:#fffbeb;color:#92400e;border:1.5px solid #fcd34d}
