:root{
  --bg:#090909;
  --bg2:#121212;
  --glass:rgba(255,255,255,.08);
  --glass2:rgba(255,255,255,.05);
  --line:rgba(255,255,255,.09);
  --text:#f7f7f8;
  --muted:#b7bcc6;
  --orange:#ff8a00;
  --purple:#7b4dff;
  --blue:#26a7ff;
  --success:#20c76f;
  --danger:#ff5f6d;
  --shadow:0 20px 50px rgba(0,0,0,.35);
  --radius:24px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:radial-gradient(circle at top,#1c1c1c 0,#0b0b0d 36%,#050506 100%);color:var(--text);font-family:Inter,Segoe UI,Arial,sans-serif;min-height:100%}
body{overflow-x:hidden}
a{text-decoration:none;color:inherit}
button,input,select,textarea{font:inherit}
button{border:0;cursor:pointer}
input,select,textarea{width:100%;border:1px solid var(--line);background:rgba(255,255,255,.06);color:var(--text);padding:14px 14px;border-radius:16px;outline:none}textarea{resize:vertical;min-height:92px}
select option{color:#111}
.app-shell,.mobile-app{width:100%;max-width:520px;margin:0 auto;min-height:100vh;position:relative}
.admin-app{max-width:760px}
.auth-shell{display:flex;align-items:center;justify-content:center;padding:26px}
.auth-card{position:relative;z-index:2;background:rgba(10,10,12,.72);backdrop-filter:blur(20px);border:1px solid var(--line);border-radius:32px;padding:24px;box-shadow:var(--shadow);width:100%}
.auth-card h1{font-size:34px;line-height:1.08;margin:8px 0 10px}
.muted{color:var(--muted)}
.small{font-size:13px}
.tiny-kicker{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#f9b15d}
.glass{background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.05));backdrop-filter:blur(18px);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius)}
.role-stack{display:grid;gap:14px;margin:24px 0}
.role-btn{display:flex;align-items:center;gap:14px;width:100%;padding:18px;border-radius:24px;color:var(--text);text-align:left;transition:.25s transform,.25s background}
.role-btn:active,.nav-item:active,.primary-btn:active,.secondary-btn:active,.ghost-btn:active,.icon-btn:active{transform:scale(.985)}
.role-icon,.icon-btn,.avatar-badge{display:grid;place-items:center;width:48px;height:48px;border-radius:18px;background:linear-gradient(135deg,rgba(255,138,0,.25),rgba(123,77,255,.25));font-size:21px}
.role-btn strong{display:block;font-size:17px}
.role-btn small{display:block;color:var(--muted);margin-top:4px}
.mini-points{display:flex;flex-wrap:wrap;gap:8px}.mini-points span,.pill{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.06);font-size:12px;border:1px solid var(--line)}
.ambient{position:absolute;border-radius:999px;filter:blur(60px);opacity:.55}.ambient-a{width:180px;height:180px;background:rgba(255,138,0,.27);top:60px;right:-10px}.ambient-b{width:220px;height:220px;background:rgba(38,167,255,.18);bottom:100px;left:-40px}
.topbar{display:flex;justify-content:space-between;align-items:flex-start;padding:18px 16px;margin:12px 12px 0}.sticky{position:sticky;top:8px;z-index:20}.topbar h2{margin:4px 0;font-size:22px;line-height:1.1}.top-actions{display:flex;gap:10px}.icon-btn,.avatar-badge{width:42px;height:42px;border-radius:16px;color:#fff}
.screen-body{padding:14px 12px 100px;display:grid;gap:14px}.bottom-pad-xl{padding-bottom:110px}
.status-card,.qr-card,.scanner-panel,.result-card,.info-card,.glass{padding:16px}
.status-head,.section-title-row,.qr-topline{display:flex;justify-content:space-between;align-items:center;gap:12px}.section-title-row h3,.qr-card h3,.scanner-panel h3,.result-card h3{margin:0;font-size:18px}
.stat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin-top:14px}.stat-grid.two{grid-template-columns:repeat(2,1fr)}
.stat-mini,.stat-box{background:rgba(255,255,255,.05);border:1px solid var(--line);padding:14px;border-radius:18px}.stat-mini span,.stat-box span{display:block;font-size:12px;color:var(--muted);margin-bottom:6px}.stat-mini strong,.stat-box strong{font-size:18px}
.pill.success{background:rgba(32,199,111,.14);color:#9ef0c2}.pill.orange{background:rgba(255,138,0,.14);color:#ffc078}.pill.purple{background:rgba(123,77,255,.18);color:#d0bfff}.pill.muted-pill{color:#cbd0d8}
.qr-wrap{position:relative;background:#fff;border-radius:28px;padding:18px;margin:18px 0;display:flex;justify-content:center;align-items:center;min-height:320px;overflow:hidden}
#qrCanvas{width:min(300px,84vw)!important;height:auto!important;background:#fff;border-radius:18px}
.scan-beam.qr-refresh{position:absolute;width:100%;height:80px;top:-20%;background:linear-gradient(180deg,transparent,rgba(38,167,255,.22),transparent);animation:beamY 2.5s linear infinite}
.count-circle{width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--orange),var(--purple),var(--blue),var(--orange));padding:2px}
.count-circle span{display:grid;place-items:center;width:100%;height:100%;border-radius:50%;background:#111;font-weight:700}
.tiny-hint{font-size:12px;color:var(--muted);margin-top:4px;line-height:1.5}
.primary-btn,.secondary-btn,.ghost-btn{padding:14px 18px;border-radius:18px;color:#fff;font-weight:700;transition:.2s transform,.2s opacity}.primary-btn{background:linear-gradient(135deg,var(--orange),var(--purple))}.secondary-btn{background:rgba(255,255,255,.09);border:1px solid var(--line)}.ghost-btn{background:transparent;border:1px dashed var(--line)}.full{width:100%;margin-top:14px}.small-btn{padding:10px 12px;border-radius:14px;font-size:13px}
.info-list{display:grid;gap:10px;margin-top:12px}.info-item,.list-card{display:flex;justify-content:space-between;align-items:center;gap:10px;background:rgba(255,255,255,.04);padding:14px;border-radius:18px;border:1px solid var(--line)}
.list-cards{display:grid;gap:10px;margin-top:12px}.list-card .meta{display:flex;flex-direction:column;gap:4px}.list-card strong{font-size:15px}.list-card small{color:var(--muted)}
.bottom-nav{position:fixed;bottom:10px;left:50%;transform:translateX(-50%);width:min(490px,calc(100vw - 16px));display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:10px;border-radius:24px;z-index:30}
.nav-item{background:transparent;color:#fff;padding:10px 6px;border-radius:16px;display:grid;place-items:center;gap:4px}.nav-item small{font-size:11px;color:var(--muted)}.nav-item.active,.nav-item.active-accent{background:rgba(255,255,255,.08)}.nav-item.active-accent span{filter:drop-shadow(0 0 10px rgba(255,138,0,.55))}
.camera-shell{position:relative;overflow:hidden;border-radius:24px;background:#000;border:1px solid var(--line);aspect-ratio:3/4;margin:14px 0}video{width:100%;height:100%;object-fit:cover;background:#000}
.scan-frame{position:absolute;inset:10%;border-radius:24px;border:1px solid rgba(255,255,255,.15);pointer-events:none}.scan-frame span{position:absolute;width:28px;height:28px;border-color:#ffb74d;border-style:solid}.scan-frame span:nth-child(1){top:-1px;left:-1px;border-width:3px 0 0 3px;border-top-left-radius:18px}.scan-frame span:nth-child(2){top:-1px;right:-1px;border-width:3px 3px 0 0;border-top-right-radius:18px}.scan-frame span:nth-child(3){bottom:-1px;left:-1px;border-width:0 0 3px 3px;border-bottom-left-radius:18px}.scan-frame span:nth-child(4){bottom:-1px;right:-1px;border-width:0 3px 3px 0;border-bottom-right-radius:18px}
.beam{position:absolute;left:0;right:0;height:3px;top:0;background:linear-gradient(90deg,transparent,#55d7ff,transparent);box-shadow:0 0 20px rgba(85,215,255,.8);animation:scanDown 2s linear infinite}
.scanner-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}
.empty-state{padding:18px;text-align:center;color:var(--muted);background:rgba(255,255,255,.04);border:1px dashed var(--line);border-radius:18px}
.success-box,.failed-box{padding:14px;border-radius:18px;border:1px solid var(--line);animation:popIn .25s ease}.success-box{background:rgba(32,199,111,.12)}.failed-box{background:rgba(255,95,109,.12)}
.bar-chart{display:grid;gap:10px;margin-top:12px}.bar-row{display:grid;grid-template-columns:110px 1fr 42px;gap:10px;align-items:center}.bar-track{height:10px;border-radius:999px;background:rgba(255,255,255,.06);overflow:hidden}.bar-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--orange),var(--purple),var(--blue))}
.form-grid{display:grid;gap:12px;margin-top:12px}.compact{grid-template-columns:repeat(2,1fr)}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);display:none;place-items:end center;padding:12px;z-index:90}.modal.show{display:grid}.modal-card{width:min(760px,100%);padding:16px;border-radius:28px 28px 18px 18px}
.toast-wrap{position:fixed;left:50%;transform:translateX(-50%);bottom:94px;z-index:120;display:grid;gap:8px;width:min(480px,calc(100vw - 24px))}.toast{padding:14px 16px;border-radius:18px;border:1px solid var(--line);backdrop-filter:blur(18px);box-shadow:var(--shadow);animation:slideUp .25s ease}.toast.success{background:rgba(32,199,111,.18)}.toast.error{background:rgba(255,95,109,.18)}.toast.info{background:rgba(38,167,255,.16)}
.fade-in-up{animation:fadeUp .45s ease both}.delay-1{animation-delay:.08s}.delay-2{animation-delay:.16s}.delay-3{animation-delay:.24s}.delay-4{animation-delay:.32s}
.pad-top{padding-top:12px}
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes beamY{0%{top:-30%}100%{top:120%}}
@keyframes scanDown{0%{top:8%}100%{top:92%}}
@keyframes popIn{from{transform:scale(.96);opacity:0}to{transform:scale(1);opacity:1}}
@keyframes slideUp{from{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}
@media (max-width:640px){.compact,.stat-grid{grid-template-columns:1fr}.auth-card h1{font-size:29px}.bar-row{grid-template-columns:90px 1fr 36px}}

.day-checks{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}.day-checks label{display:flex;align-items:center;gap:6px;background:rgba(255,255,255,.04);padding:8px 10px;border-radius:12px;font-size:13px}.day-checks input{accent-color:#8b5cf6}


.admin-shell{max-width:1360px}
.schedule-admin-workspace{display:grid;grid-template-columns:290px 1fr;gap:16px;align-items:start}
.schedule-sidebar{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:22px;padding:14px;position:sticky;top:88px}
.schedule-sidebar-title{font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:#f6b870;margin-bottom:12px}
.schedule-submenu-title{font-size:12px;color:var(--muted);margin-bottom:10px}
.schedule-class-menu{display:grid;gap:8px}
.schedule-class-link{width:100%;display:flex;justify-content:space-between;align-items:center;text-align:left;padding:12px 14px;border-radius:16px;background:rgba(255,255,255,.04);border:1px solid var(--line);color:#fff}
.schedule-class-link.active{background:linear-gradient(135deg,rgba(255,138,0,.22),rgba(123,77,255,.18));border-color:rgba(255,255,255,.18)}
.schedule-canvas{min-width:0}
.teaching-board{display:grid;gap:14px;margin-top:14px}
.teaching-day-card{background:rgba(255,255,255,.04);border:1px solid var(--line);border-radius:22px;padding:14px}
.teaching-day-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}
.teaching-day-head h4{margin:0;font-size:17px}
.teaching-day-grid{display:grid;gap:10px}
.teaching-slot-row{display:grid;grid-template-columns:190px 1fr;gap:12px;align-items:center;padding:10px 12px;border-radius:16px;background:rgba(255,255,255,.03);border:1px solid rgba(255,255,255,.06)}
.teaching-slot-meta{display:flex;flex-direction:column;gap:4px}
.teaching-slot-meta strong{font-size:14px}
.teaching-slot-meta small{color:var(--muted)}
.teaching-slot-row select{padding:12px 14px;border-radius:14px}
.schedule-board-headline{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.mini-note{font-size:12px;color:var(--muted)}
@media (max-width:980px){.schedule-admin-workspace{grid-template-columns:1fr}.schedule-sidebar{position:static}.teaching-slot-row{grid-template-columns:1fr}}

.backup-panel{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.backup-card-mini{border:1px solid rgba(15,23,42,.08);background:rgba(255,255,255,.66);border-radius:18px;padding:14px;display:flex;flex-direction:column;gap:9px;box-shadow:0 10px 24px rgba(15,23,42,.06)}
.backup-card-mini strong{font-size:14px;color:#111827}
.backup-card-mini small{font-size:12px;color:#64748b;line-height:1.45}
.backup-card-mini input[type=file]{width:100%;font-size:12px;padding:10px;border-radius:12px;border:1px solid rgba(15,23,42,.12);background:#fff}
@media(max-width:720px){.backup-panel{grid-template-columns:1fr}}

.field-label{display:flex;flex-direction:column;gap:8px;color:#e9e9ef;font-size:13px;font-weight:800;letter-spacing:.01em}
.date-range-grid input{width:100%}

/* Patch: warna pembeda antar section dan card agar admin lebih cepat membaca data */
.glass:nth-of-type(4n+1){box-shadow:0 18px 55px rgba(255,120,46,.09), inset 0 1px 0 rgba(255,255,255,.05)}
.glass:nth-of-type(4n+2){box-shadow:0 18px 55px rgba(137,85,255,.09), inset 0 1px 0 rgba(255,255,255,.05)}
.glass:nth-of-type(4n+3){box-shadow:0 18px 55px rgba(40,188,255,.08), inset 0 1px 0 rgba(255,255,255,.05)}
.glass:nth-of-type(4n+4){box-shadow:0 18px 55px rgba(27,210,126,.07), inset 0 1px 0 rgba(255,255,255,.05)}
.leave-day-card{position:relative;overflow:hidden;align-items:flex-start}
.leave-day-card:before{content:"";position:absolute;inset:0 auto 0 0;width:5px;border-radius:18px 0 0 18px;background:linear-gradient(180deg,#ff8a12,#8d4cff)}
.leave-day-card.tone-1{background:linear-gradient(135deg,rgba(255,138,18,.12),rgba(255,255,255,.035));border-color:rgba(255,138,18,.22)}
.leave-day-card.tone-2{background:linear-gradient(135deg,rgba(141,76,255,.13),rgba(255,255,255,.035));border-color:rgba(141,76,255,.24)}
.leave-day-card.tone-3{background:linear-gradient(135deg,rgba(40,188,255,.11),rgba(255,255,255,.035));border-color:rgba(40,188,255,.2)}
.leave-day-card.tone-4{background:linear-gradient(135deg,rgba(28,206,126,.1),rgba(255,255,255,.035));border-color:rgba(28,206,126,.18)}
.leave-day-card.tone-5{background:linear-gradient(135deg,rgba(255,85,120,.1),rgba(255,255,255,.035));border-color:rgba(255,85,120,.2)}
.leave-day-card.is-new-leave{outline:1px solid rgba(255,138,18,.35)}
.new-pill{background:linear-gradient(135deg,#ff8a12,#ff4f73);color:#fff;border-color:rgba(255,255,255,.18)}
@media(max-width:720px){.leave-day-card{flex-direction:column}.leave-day-card>div:last-child{align-items:flex-start!important;text-align:left!important;width:100%}}

/* Patch clean: warna pembeda section admin sesuai menu agar cepat dicari */
.admin-section{position:relative;overflow:hidden;border-width:1px;isolation:isolate}
.admin-section:before{content:"";position:absolute;inset:0 auto 0 0;width:6px;border-radius:24px 0 0 24px;opacity:.95;z-index:-1}
.admin-section:after{content:"";position:absolute;inset:0;pointer-events:none;z-index:-2;opacity:.72}
.section-analytics{border-color:rgba(255,138,0,.22);box-shadow:0 18px 54px rgba(255,138,0,.08)}
.section-analytics:before{background:linear-gradient(180deg,#ff8a00,#ffb347)}
.section-analytics:after{background:linear-gradient(135deg,rgba(255,138,0,.13),rgba(255,255,255,.035))}
.section-accounts{border-color:rgba(123,77,255,.24);box-shadow:0 18px 54px rgba(123,77,255,.09)}
.section-accounts:before{background:linear-gradient(180deg,#7b4dff,#b377ff)}
.section-accounts:after{background:linear-gradient(135deg,rgba(123,77,255,.14),rgba(255,255,255,.035))}
.section-recap{border-color:rgba(38,167,255,.22);box-shadow:0 18px 54px rgba(38,167,255,.08)}
.section-recap:before{background:linear-gradient(180deg,#26a7ff,#54d7ff)}
.section-recap:after{background:linear-gradient(135deg,rgba(38,167,255,.13),rgba(255,255,255,.035))}
.section-barcode{border-color:rgba(32,199,111,.22);box-shadow:0 18px 54px rgba(32,199,111,.08)}
.section-barcode:before{background:linear-gradient(180deg,#20c76f,#84e0a8)}
.section-barcode:after{background:linear-gradient(135deg,rgba(32,199,111,.12),rgba(255,255,255,.035))}
.section-periods{border-color:rgba(255,190,72,.23);box-shadow:0 18px 54px rgba(255,190,72,.08)}
.section-periods:before{background:linear-gradient(180deg,#f6b870,#ff8a00)}
.section-periods:after{background:linear-gradient(135deg,rgba(246,184,112,.13),rgba(255,255,255,.035))}
.section-classes{border-color:rgba(255,95,109,.24);box-shadow:0 18px 54px rgba(255,95,109,.08)}
.section-classes:before{background:linear-gradient(180deg,#ff5f6d,#ff8a8f)}
.section-classes:after{background:linear-gradient(135deg,rgba(255,95,109,.13),rgba(255,255,255,.035))}
.section-leave{border-color:rgba(180,112,255,.26);box-shadow:0 18px 54px rgba(180,112,255,.09)}
.section-leave:before{background:linear-gradient(180deg,#b470ff,#ff8a00)}
.section-leave:after{background:linear-gradient(135deg,rgba(180,112,255,.13),rgba(255,138,0,.06))}
.section-teacher-schedule{border-color:rgba(84,215,255,.22);box-shadow:0 18px 54px rgba(84,215,255,.08)}
.section-teacher-schedule:before{background:linear-gradient(180deg,#54d7ff,#7b4dff)}
.section-teacher-schedule:after{background:linear-gradient(135deg,rgba(84,215,255,.12),rgba(255,255,255,.035))}
.section-schedule-board{border-color:rgba(255,138,0,.24);box-shadow:0 18px 54px rgba(255,138,0,.07)}
.section-schedule-board:before{background:linear-gradient(180deg,#ff8a00,#26a7ff)}
.section-schedule-board:after{background:linear-gradient(135deg,rgba(255,138,0,.11),rgba(38,167,255,.06))}
.section-backup{border-color:rgba(255,255,255,.16);box-shadow:0 18px 54px rgba(255,255,255,.05)}
.section-backup:before{background:linear-gradient(180deg,#f7f7f8,#64748b)}
.section-backup:after{background:linear-gradient(135deg,rgba(255,255,255,.10),rgba(100,116,139,.08))}
.section-backup .backup-card-mini{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);box-shadow:0 12px 30px rgba(0,0,0,.18)}
.section-backup .backup-card-mini strong{color:#fff}.section-backup .backup-card-mini small{color:var(--muted)}

/* Pagination kecil untuk Persetujuan Izin Guru: hanya 5 data terbaru tampil dulu. */
.leave-pager{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:10px;
  margin-top:14px;
  padding-top:12px;
  border-top:1px solid rgba(255,255,255,.08);
}
.leave-pager .pager-info{
  font-size:12px;
  color:rgba(255,255,255,.72);
}
.leave-pager button:disabled{
  opacity:.45;
  cursor:not-allowed;
  transform:none!important;
}
@media(max-width:720px){
  .leave-pager{justify-content:stretch;flex-wrap:wrap}
  .leave-pager .pager-info{width:100%;text-align:center;order:-1}
  .leave-pager button{flex:1}
}
.section-monthly-recap{border-color:rgba(20,184,166,.23);box-shadow:0 18px 54px rgba(20,184,166,.08)}
.section-monthly-recap:before{background:linear-gradient(180deg,#14b8a6,#26a7ff)}
.section-monthly-recap:after{background:linear-gradient(135deg,rgba(20,184,166,.13),rgba(38,167,255,.05))}

/* Pagination akun admin: membatasi daftar agar panel tetap ringan dibaca */
.pager-row{display:flex;align-items:center;justify-content:flex-end;gap:10px;flex-wrap:wrap;margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,.08)}
.pager-info{font-size:12px;color:var(--muted);padding:8px 10px;border-radius:999px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08)}
button[disabled]{opacity:.45;cursor:not-allowed;filter:grayscale(.2)}
.section-subjects{border-color:rgba(244,114,182,.24);box-shadow:0 18px 54px rgba(244,114,182,.08)}
.section-subjects:before{background:linear-gradient(180deg,#f472b6,#7b4dff)}
.section-subjects:after{background:linear-gradient(135deg,rgba(244,114,182,.13),rgba(123,77,255,.05))}
