*{box-sizing:border-box}body{margin:0;font-family:Arial,Helvetica,sans-serif;background:#edf5ff;color:#0b1b33}.app-shell{max-width:1220px;margin:0 auto;padding:12px}.topbar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.98);border:1px solid #d7e3f5;border-radius:22px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;box-shadow:0 12px 30px rgba(15,47,89,.10);margin-bottom:12px}.brand{display:flex;align-items:center;gap:12px}.logo{width:54px;height:54px;border-radius:18px;background:#1f56c2;color:#fff;display:grid;place-items:center;font-weight:900;font-size:20px}.brand h1{margin:0;font-size:18px;color:#133768}.brand p{margin:4px 0 0;color:#667085;font-size:13px}.menu-btn{display:none}.navgrid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:8px;margin:12px 0}.navgrid a{background:#fff;border:1px solid #d7e3f5;border-radius:14px;padding:11px 10px;text-align:center;text-decoration:none;color:#133768;font-weight:900}.card{background:#fff;border:1px solid #d7e3f5;border-radius:24px;padding:18px;margin:12px 0;box-shadow:0 12px 28px rgba(15,47,89,.08)}.hero{background:radial-gradient(circle at top right,#e6f0ff 0,#fff 55%)}h2,h3{color:#133768;margin-top:0}.muted{color:#667085}.grid4{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.stat{background:#f8fbff;border:1px solid #d7e3f5;border-radius:18px;padding:16px}.stat b{display:block;font-size:30px;color:#1f56c2}.stat span{font-weight:800;color:#667085}.btn{display:inline-block;border:0;border-radius:14px;padding:11px 14px;text-decoration:none;font-weight:900;cursor:pointer}.btn.primary{background:#1f56c2;color:#fff}.btn.success{background:#16a34a;color:#fff}.btn.warn{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412}.btn.ghost{background:#f8fbff;border:1px solid #d7e3f5;color:#133768}.btn.small{padding:7px 10px}.btn.full{width:100%;margin-top:12px}.badge{display:inline-block;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:6px 10px;font-weight:900}.input,select,textarea{width:100%;border:1px solid #cbd7e6;border-radius:14px;padding:12px;font-size:15px;margin:6px 0 12px;background:#fff}textarea{min-height:86px}.login-wrap{max-width:460px;margin:32px auto}.alert{padding:12px;border-radius:14px;margin:12px 0}.alert.danger{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239}.alert.success{background:#dcfce7;border:1px solid #86efac;color:#166534}.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{border:1px solid #d7e3f5;padding:9px;text-align:left;vertical-align:top}th{background:#eff6ff;color:#133768}.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px}.actions,.btnrow{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}.copy-box{display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center}.question-img,.exam-img{width:100%;max-height:440px;object-fit:contain;border:1px solid #d7e3f5;border-radius:18px;background:#f8fbff}.question-text,.qtext{font-size:22px;line-height:1.45;font-weight:900;color:#06162d}.options-preview div,.step,.essay-step{background:#f8fbff;border:1px solid #d7e3f5;border-radius:14px;padding:12px;margin:8px 0}.grid-review{display:grid;grid-template-columns:330px 1fr;gap:12px}.session-link{display:block;text-decoration:none;color:#0b1b33;border:1px solid #d7e3f5;border-radius:14px;padding:12px;margin:8px 0;background:#f8fbff}.error-list li{margin:8px 0;color:#9f1239}.exam-app{min-height:100vh;padding:8px;background:#edf5ff}.exam-card{background:#fff;border:1px solid #d7e3f5;border-radius:24px;padding:18px;margin:10px auto;max-width:980px;box-shadow:0 12px 28px rgba(15,47,89,.08)}.option-btn{display:flex;gap:10px;width:100%;border:1px solid #d7e3f5;border-radius:16px;background:#fff;padding:13px;margin:8px 0;text-align:left;font-size:16px}.option-btn.active{border-color:#1f56c2;background:#eff6ff}.navnums{display:none;gap:8px;flex-wrap:wrap;background:#f8fbff;border:1px solid #d7e3f5;border-radius:16px;padding:10px;margin:8px 0}.navnums.show{display:flex}.navnums button{width:44px;height:44px;border-radius:12px;border:1px solid #d7e3f5;background:#fff;font-weight:900}.navnums button.active{background:#1f56c2;color:#fff}.navnums button.answered{background:#dcfce7;color:#166534}@media(max-width:860px){.app-shell{padding:8px}.menu-btn{display:block;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:14px;padding:10px 12px;font-weight:900}.navgrid{display:none;grid-template-columns:1fr 1fr}.navgrid.show{display:grid}.grid4{grid-template-columns:1fr 1fr}.copy-box,.grid-review{grid-template-columns:1fr}.row-between{align-items:flex-start;flex-direction:column}.brand h1{font-size:16px}.card{border-radius:20px;padding:16px}.btn{width:100%;text-align:center}.qtext,.question-text{font-size:22px}.navnums button{width:52px;height:52px}.topbar{align-items:flex-start}.logo{width:50px;height:50px}}@media(max-width:520px){.grid4,.navgrid{grid-template-columns:1fr}.qtext,.question-text{font-size:24px}.exam-card{padding:14px;border-radius:20px}}



/* ===== Tahap 4: Tampilan Ujian Siswa Profesional ===== */
.exam-card.welcome-card{text-align:center;max-width:900px}
.exam-logo{width:72px;height:72px;border-radius:24px;background:#1f56c2;color:#fff;display:grid;place-items:center;font-weight:900;font-size:26px;margin:0 auto 14px}
.exam-subtitle{color:#667085;font-weight:700}
.exam-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin:18px 0}
.exam-stat-grid div{background:#f8fbff;border:1px solid #d7e3f5;border-radius:18px;padding:14px}
.exam-stat-grid b{display:block;font-size:28px;color:#1f56c2}
.exam-stat-grid span{font-size:13px;color:#667085;font-weight:800}
.exam-note{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:18px;padding:12px;margin:14px 0;text-align:left}
.full{width:100%;text-align:center}
.class-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin:14px 0}
.class-choice{border:1px solid #d7e3f5;background:#fff;border-radius:18px;min-height:58px;padding:14px;text-align:left;font-weight:900;color:#133768;font-size:16px}
.big-input{font-size:18px;font-weight:800;text-transform:uppercase}
.identity-card{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0}
.identity-card div{background:#f8fbff;border:1px solid #d7e3f5;border-radius:18px;padding:14px}
.identity-card span{display:block;color:#667085;font-size:13px;font-weight:800;margin-bottom:5px}
.identity-card b{color:#133768}
.center{text-align:center}
.loader{width:52px;height:52px;border-radius:50%;border:6px solid #d7e3f5;border-top-color:#1f56c2;animation:spin 1s linear infinite;margin:0 auto 14px}
@keyframes spin{to{transform:rotate(360deg)}}
.warning-icon,.done-icon{width:76px;height:76px;border-radius:28px;display:grid;place-items:center;margin:0 auto 14px;font-size:42px;font-weight:900}
.warning-icon{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}
.done-icon{background:#dcfce7;color:#166534;border:1px solid #86efac}
.exam-question-card{padding-top:8px}
.exam-sticky{position:sticky;top:6px;z-index:5;background:rgba(255,255,255,.98);border:1px solid #d7e3f5;border-radius:18px;padding:10px;margin-bottom:10px;box-shadow:0 10px 24px rgba(15,47,89,.08)}
.topline{display:flex;align-items:center;justify-content:space-between;gap:10px}
.topline.small{font-size:13px;color:#667085;font-weight:800}
.timer{border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:7px 10px;font-weight:900}
.timer.danger-time{background:#fff1f2;border-color:#fecdd3;color:#9f1239}
.progress-wrap{height:10px;background:#e5edf7;border-radius:999px;overflow:hidden;margin:9px 0}
.progress-bar{height:100%;background:linear-gradient(90deg,#1f56c2,#16a34a);border-radius:999px}
.nav-toggle{margin-bottom:8px}
.material-chip{display:inline-block;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;padding:7px 10px;font-weight:900;margin:10px 0}
.image-wrap{border:0;background:transparent;padding:0;width:100%;display:block;cursor:zoom-in}
.choice-list{display:grid;gap:10px}
.option-btn{align-items:flex-start}
.opt-letter{width:34px;height:34px;border-radius:12px;background:#e5efff;color:#1d4ed8;display:grid;place-items:center;font-weight:900;flex:0 0 auto}
.essay-guide{border:1px solid #d7e3f5;background:#f8fbff;border-radius:20px;padding:14px}
.essay-guide h3{margin:0;color:#133768}
.step-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.step-head span{font-size:13px;font-weight:900;color:#166534;background:#dcfce7;border:1px solid #86efac;border-radius:999px;padding:5px 8px}
.step-input{min-height:96px;line-height:1.5}
.exam-actions{position:sticky;bottom:6px;background:rgba(255,255,255,.96);border:1px solid #d7e3f5;border-radius:18px;padding:10px;box-shadow:0 -8px 20px rgba(15,47,89,.08)}
.ok{color:#166534;font-weight:900}
.no{color:#9f1239;font-weight:900}
.image-modal{position:fixed;inset:0;background:rgba(0,0,0,.82);z-index:9999;display:grid;place-items:center;padding:12px}
.image-modal div{max-width:1100px;width:100%}
.image-modal button{float:right;margin-bottom:8px;border:0;border-radius:12px;padding:10px 14px;font-weight:900}
.image-modal img{width:100%;max-height:86vh;object-fit:contain;border-radius:16px;background:#fff}
.error-card{border-color:#fecdd3;background:#fff1f2}
@media(max-width:760px){
  .exam-app{padding:6px}
  .exam-card{border-radius:20px;padding:14px}
  .exam-stat-grid,.identity-card,.class-grid{grid-template-columns:1fr}
  .qtext{font-size:24px}
  .exam-img{max-height:360px}
  .topline{align-items:flex-start}
  .step-head{align-items:flex-start;flex-direction:column}
  .exam-actions{display:grid;grid-template-columns:1fr;gap:8px}
  .navnums button{width:52px;height:52px}
}



/* ===== Tahap 5: Dashboard Admin/Guru Lengkap ===== */
.quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:12px 0}
.quick-card{background:#fff;border:1px solid #d7e3f5;border-radius:20px;padding:16px;text-decoration:none;color:#0b1b33;box-shadow:0 12px 28px rgba(15,47,89,.06)}
.quick-card b{display:block;color:#133768;margin-bottom:6px;font-size:16px}
.quick-card span{color:#667085;font-size:13px;line-height:1.4}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.grid3-form{display:grid;grid-template-columns:2fr 1fr 1fr;gap:10px;align-items:end}
.navgrid{grid-template-columns:repeat(5,minmax(0,1fr))}
@media(max-width:900px){
  .quick-actions,.grid2,.grid3-form{grid-template-columns:1fr}
  .navgrid{grid-template-columns:repeat(2,minmax(0,1fr))}
}



/* ===== Tahap 6: Pemeriksaan Essay Profesional ===== */
.essay-review-grid{grid-template-columns:360px 1fr}
.active-session{border-color:#1f56c2;background:#eff6ff}
.essay-filter{grid-template-columns:2fr 1fr auto}
.essay-check-list{display:grid;gap:14px}
.essay-question-block{border:1px solid #d7e3f5;background:#f8fbff;border-radius:20px;padding:14px}
.small-question{font-size:16px;font-weight:700;background:#fff;border:1px solid #d7e3f5;border-radius:16px;padding:12px}
.rubric-card{background:#fff;border:1px solid #d7e3f5;border-radius:18px;padding:14px;margin:12px 0}
.rubric-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;border-bottom:1px solid #e5edf7;padding-bottom:10px;margin-bottom:10px}
.rubric-head p{margin:5px 0 0;color:#667085;line-height:1.45}
.rubric-grid{display:grid;grid-template-columns:1fr 1fr 160px 1fr;gap:10px;align-items:start}
.student-answer-box,.ideal-answer-box{background:#f8fbff;border:1px solid #d7e3f5;border-radius:14px;padding:12px;min-height:84px;line-height:1.45}
.ideal-answer-box{background:#fff7ed;border-color:#fed7aa}
.score-input{font-size:18px;font-weight:900;text-align:center}
.teacher-note{min-height:84px}
.sticky-save{position:sticky;bottom:8px;background:rgba(255,255,255,.96);border:1px solid #d7e3f5;border-radius:18px;padding:10px;box-shadow:0 -8px 20px rgba(15,47,89,.08);margin-top:12px}
.warn-badge{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.ok-badge{background:#dcfce7;border-color:#86efac;color:#166534}
@media(max-width:980px){
  .essay-review-grid,.essay-filter,.rubric-grid{grid-template-columns:1fr}
  .rubric-head{flex-direction:column}
}



/* ===== Tahap 7: Analisis dan Laporan Lengkap ===== */
.analysis-card{border-left:5px solid #1f56c2}
.table-wrap table td small{color:#667085}
@media(max-width:900px){
  .card .actions[style]{width:100%;display:grid;grid-template-columns:1fr;gap:8px}
}



/* ===== Tahap 8: Editor Soal, CRUD Siswa, dan Admin Pro ===== */
.grid-editor{display:grid;grid-template-columns:320px 1fr;gap:12px}
.question-list{display:grid;gap:8px;max-height:650px;overflow:auto}
.q-list-item{display:block;text-decoration:none;color:#0b1b33;border:1px solid #d7e3f5;border-radius:14px;padding:12px;background:#f8fbff}
.q-list-item b{display:block;color:#133768}
.q-list-item span{display:inline-block;margin:5px 0;color:#1d4ed8;font-weight:800;font-size:13px}
.q-list-item small{display:block;color:#667085}
.tall{min-height:150px}
.mini-img{max-height:220px;margin:8px 0}
@media(max-width:980px){
  .grid-editor{grid-template-columns:1fr}
  .question-list{max-height:300px}
}



/* ===== Tahap 9: Fitur Final Sebelum Produksi ===== */
.check-list{display:grid;gap:8px;background:#f8fbff;border:1px solid #d7e3f5;border-radius:16px;padding:12px;margin:10px 0}
.check-list label{font-weight:800;color:#133768}
.audit-row{font-size:13px}
@media(max-width:900px){
  .quick-actions{grid-template-columns:1fr}
}



/* ===== Fitur Bank Soal dan Susun Paket dari Soal Tersimpan ===== */
.bank-filter{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1fr auto;gap:8px;align-items:end}
.bank-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.bank-card{border:1px solid #d7e3f5;background:#f8fbff;border-radius:18px;padding:14px}
.bank-card h3{margin:10px 0 4px}
.bank-img,.builder-img{width:100%;max-height:220px;object-fit:contain;border:1px solid #d7e3f5;border-radius:14px;background:#fff;margin:8px 0}
.bank-question{font-weight:700;line-height:1.45}
.builder-question-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.builder-question-card{display:grid;grid-template-columns:auto 1fr;gap:12px;border:1px solid #d7e3f5;background:#fff;border-radius:18px;padding:14px;cursor:pointer}
.builder-question-card:hover{border-color:#1f56c2;background:#eff6ff}
.builder-question-card input{width:24px;height:24px;margin-top:8px}
.selected-preview{border:1px solid #d7e3f5;background:#f8fbff;border-radius:16px;padding:12px;min-height:120px}
.selected-item{padding:8px;border-bottom:1px solid #e5edf7}
.selected-item:last-child{border-bottom:0}
@media(max-width:980px){
  .bank-filter,.bank-grid,.builder-question-list{grid-template-columns:1fr}
}
