:root{
  --navy:#0b2d4a; --blue:#126eaa; --sky:#20b8e6; --gold:#ffc928; --green:#20a66a; --red:#e14b5a; --ink:#162033; --muted:#71849a; --line:#e3edf7; --soft:#f5f9fd; --white:#fff;
  --shadow:0 18px 45px rgba(10,41,74,.12); --radius:22px;
}
*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:linear-gradient(180deg,#eef6fb 0,#f8fbff 42%,#fff 100%);color:var(--ink);font-size:15px}a{color:inherit}.container{max-width:1240px;margin:0 auto;padding:26px 18px 40px}.muted{color:var(--muted)}
.topbar{position:sticky;top:0;z-index:20;min-height:76px;background:linear-gradient(90deg,#0b2d4a,#176ea5 55%,#229ac8);display:flex;align-items:center;justify-content:space-between;gap:18px;padding:12px 26px;color:white;box-shadow:0 10px 24px rgba(4,31,58,.18)}.brand{display:flex;align-items:center;gap:12px}.brand-mark{width:46px;height:46px;border-radius:15px;background:linear-gradient(135deg,var(--sky),#fff);display:grid;place-items:center;color:var(--navy);font-size:25px;box-shadow:inset -6px -6px 0 rgba(255,201,40,.85)}.brand b{font-size:21px;letter-spacing:.2px}.brand small{display:block;opacity:.85;font-weight:700;font-size:12px}.menu-toggle{display:none;background:#ffffff22;color:white;border:1px solid #ffffff55;border-radius:12px;padding:9px 12px;font-weight:900}nav{display:flex;align-items:center;gap:6px}nav a{text-decoration:none;color:white;padding:11px 13px;border-radius:13px;font-weight:800;font-size:14px;opacity:.96}nav a:hover{background:#ffffff24}.logout-link{background:#ffffff22}.footer{margin-top:30px;background:linear-gradient(90deg,#0b2d4a,#176ea5);color:white;text-align:center;padding:17px 12px;font-weight:800}.panel{background:rgba(255,255,255,.96);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow);margin-bottom:20px}.panel h2,.panel h3{margin-top:0}.welcome{position:relative;overflow:hidden;border-radius:28px;padding:32px;background:linear-gradient(120deg,#0b2d4a 0,#126eaa 50%,#20b8e6 100%);color:white;box-shadow:0 22px 55px rgba(12,83,135,.25);margin-bottom:22px}.welcome:before{content:"";position:absolute;inset:-20%;background:radial-gradient(circle at 80% 30%,rgba(255,255,255,.28),transparent 22%),repeating-linear-gradient(135deg,rgba(255,255,255,.08) 0 2px,transparent 2px 18px)}.welcome>*{position:relative}.welcome h1{font-size:34px;margin:0 0 8px}.welcome p{max-width:850px;font-size:16px;line-height:1.7}.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:20px 0}.card{position:relative;overflow:hidden;display:block;text-decoration:none;background:white;border:1px solid var(--line);border-radius:24px;padding:24px;box-shadow:var(--shadow);transition:.2s transform,.2s box-shadow}.card:before{content:"";position:absolute;right:-34px;top:-34px;width:105px;height:105px;background:linear-gradient(135deg,var(--gold),var(--sky));border-radius:50%;opacity:.32}.card:hover{transform:translateY(-4px);box-shadow:0 22px 55px rgba(10,41,74,.18)}.card b{display:block;font-size:46px;color:var(--blue);line-height:1}.card span{font-weight:900;color:#25394c}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.stack{display:grid;gap:14px}.stack label,.filter-row label{font-weight:900;color:#22384d}.stack input,.stack select,.stack textarea,.filter-row select,input,select,textarea{width:100%;margin-top:7px;padding:12px 14px;border:1px solid #cbdbea;border-radius:14px;background:white;font:inherit;outline:none;transition:.15s border,.15s box-shadow}.stack input:focus,.stack select:focus,.stack textarea:focus,input:focus,select:focus,textarea:focus{border-color:var(--sky);box-shadow:0 0 0 4px rgba(32,184,230,.14)}textarea{min-height:96px;resize:vertical}.filter-row{display:grid;grid-template-columns:1fr 1fr auto;gap:14px;align-items:end}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;border-radius:14px;padding:11px 16px;background:#e9f1f8;color:#173653;text-decoration:none;font-weight:900;cursor:pointer;transition:.15s transform,.15s box-shadow}.btn:hover{transform:translateY(-1px);box-shadow:0 8px 18px rgba(10,41,74,.12)}.btn.primary{background:linear-gradient(135deg,var(--blue),var(--sky));color:white}.btn.ghost{background:#f4f8fc;color:#24455f}.btn.small{padding:8px 11px;font-size:13px;border-radius:10px}.alert{padding:14px 16px;border-radius:16px;margin:0 0 16px;font-weight:800;border:1px solid transparent}.alert.success{background:#eafaf2;color:#11663c;border-color:#c9efd9}.alert.error{background:#fff0f1;color:#9a1e2b;border-color:#ffd4d8}.table-wrap{overflow:auto;border-radius:17px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;background:white}th,td{padding:13px 14px;border-bottom:1px solid #e8f0f8;text-align:left;vertical-align:top}th{background:#f1f7fc;color:#213a51;font-size:13px;text-transform:uppercase;letter-spacing:.04em}tr:hover td{background:#fbfdff}.example{background:linear-gradient(135deg,#0d2c49,#134f78);color:#e9f7ff;border-radius:18px;padding:18px;line-height:1.8;box-shadow:inset 0 0 0 1px rgba(255,255,255,.12)}.question-box,.question-preview{background:linear-gradient(180deg,#f8fcff,#eef8ff);border:1px solid #d6e9f7;border-radius:18px;padding:18px;margin:16px 0}.question-box pre,.question-preview pre{white-space:pre-wrap;font-family:inherit;line-height:1.7;margin-bottom:0}.analysis-layout{display:grid;grid-template-columns:260px 1fr;gap:20px}.number-list{position:sticky;top:96px;align-self:start;display:grid;grid-template-columns:repeat(3,1fr);gap:9px}.number-list h3{grid-column:1/-1;margin:0 0 8px}.num{min-height:62px;border-radius:18px;background:#eef6fb;text-decoration:none;color:#122337;display:flex;flex-direction:column;align-items:center;justify-content:center;font-weight:900;border:1px solid #dceaf5}.num small{font-size:9px;margin-top:3px}.num.active{outline:4px solid rgba(32,184,230,.25);border-color:var(--sky);background:#e6f9ff}.num.ditolak{background:#fff0f2;color:#a51f31}.num.diperbaiki{background:#fff7db;color:#735000}.num.digunakan{background:#e8fff3;color:#11683b}.status-line{display:flex;justify-content:space-between;gap:12px;align-items:center}.badge{display:inline-flex;align-items:center;white-space:nowrap;padding:8px 12px;border-radius:999px;font-weight:900;background:#eef3f8;color:#324b62}.badge.ditolak{background:#e14b5a;color:white}.badge.diperbaiki{background:#ffc928;color:#4d3800}.badge.digunakan{background:#20a66a;color:white}.badge.kosong{background:#71849a;color:white}.rubrik .category td{background:linear-gradient(90deg,#0b2d4a,#176ea5);color:white;font-weight:900}.criteria{font-size:13px;margin-bottom:7px;color:#344b5e}.dimension-box{background:#f7fbff;border:1px solid #dcebf7;border-radius:18px;padding:18px;margin:18px 0;display:grid;gap:10px}.bars div{display:grid;grid-template-columns:130px 1fr 45px;align-items:center;gap:10px;margin:13px 0}.bars i{display:block;height:26px;border-radius:999px;background:linear-gradient(90deg,var(--blue),var(--green));min-width:4px}.setup-box{max-width:820px;margin:60px auto;background:white;border-radius:24px;padding:32px;box-shadow:var(--shadow)}
/* Login model e-Rapor, dibuat tanpa gambar eksternal agar aman di hosting */
.login-page{min-height:100vh;background:#fff;display:flex;flex-direction:column}.login-topbar{height:72px;background:#6f8eaa;color:white;display:flex;align-items:center;justify-content:space-between;padding:0 18px;box-shadow:0 4px 12px rgba(0,0,0,.16)}.login-logo{display:flex;align-items:center;gap:10px;font-size:22px;font-weight:900;text-shadow:1px 2px 2px #0006}.login-logo .shield{width:44px;height:34px;border-radius:50% 45% 50% 40%;background:#28b7e7;display:grid;place-items:center;box-shadow:inset -6px -3px 0 #ffc928}.login-nav{display:flex;gap:22px;font-weight:900}.login-nav span{color:#ffd016}.login-body{display:grid;grid-template-columns:minmax(0,2.05fr) minmax(390px,.95fr);min-height:calc(100vh - 126px)}.login-hero{position:relative;overflow:hidden;background:#82a8c1;color:white;min-height:520px}.login-hero:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 70% 62%,rgba(255,255,255,.92) 0 14%,rgba(255,255,255,.42) 14.2% 28%,transparent 28.2%),radial-gradient(circle at 63% 66%,#f3c35a 0 8%,transparent 8.2%),repeating-linear-gradient(135deg,rgba(255,255,255,.11) 0 2px,transparent 2px 18px),linear-gradient(135deg,#7fa4bc,#3d7698);}.login-hero>*{position:relative}.ministry-row{display:flex;align-items:center;justify-content:space-around;gap:20px;padding:16px 18px;border-bottom:2px solid rgba(255,255,255,.35);font-weight:900;text-align:center}.login-title{padding:50px 34px;max-width:560px}.book-icon{width:190px;height:128px;border-radius:68% 40% 56% 46%;background:#20b8e6;display:grid;place-items:center;font-size:78px;box-shadow:inset -16px -10px 0 var(--gold),0 8px 22px rgba(0,0,0,.16);margin-bottom:18px}.login-title h1{font-size:55px;margin:0;text-shadow:3px 4px 2px rgba(0,0,0,.48);line-height:.95}.login-title h2{display:inline-block;background:white;color:#222;border-radius:10px;padding:7px 14px;margin:12px 0;font-size:21px}.login-title p{display:inline-block;background:rgba(255,255,255,.92);color:#303943;border-radius:12px;padding:11px 15px;font-size:19px;font-weight:800;box-shadow:0 8px 18px rgba(0,0,0,.10)}.student-visual{position:absolute;right:5.5%;bottom:58px;font-size:112px;display:flex;gap:2px;filter:drop-shadow(0 10px 7px rgba(0,0,0,.25))}.login-hero-foot{position:absolute;left:0;right:0;bottom:0;background:#356f90;color:white;text-align:center;font-weight:900;padding:13px}.login-side{display:flex;align-items:flex-start;justify-content:center;background:#fff;padding:36px 16px}.login-card{width:100%;max-width:430px;background:white;border:1px solid #dbe5ef;border-radius:5px;box-shadow:0 12px 32px rgba(59,88,130,.20);padding:32px}.login-card h1{text-align:center;margin:8px 0 18px;font-size:24px;color:#1a2e41}.login-line{border-top:1px solid #cfd7df;text-align:center;margin:17px 0}.login-line span{position:relative;top:-10px;background:white;padding:0 10px;color:#b3bcc7;font-size:12px;font-weight:700}.form-line{display:flex;margin:15px 0}.form-line label{min-width:104px;margin:0;padding:10px 12px;background:#eef2f6;border:1px solid #cbd4df;border-right:0;border-radius:5px 0 0 5px;font-weight:800}.form-line input,.form-line select{margin:0;border-radius:0 5px 5px 0;min-width:0}.eye-btn{width:48px;border:0;background:#6f8fac;color:white;border-radius:0 5px 5px 0;font-weight:900}.forgot{display:block;text-align:right;color:#006cff;margin:18px 0;text-decoration:none;font-size:14px}.login-btn{width:100%;border:0;background:#7190ae;color:white;font-weight:900;padding:13px;border-radius:5px;font-size:17px;cursor:pointer}.login-footer{background:#6f8fac;color:white;text-align:center;padding:17px;font-weight:900;border-top:27px solid #9f0041}
@media(max-width:980px){.login-body,.grid2,.cards,.analysis-layout{grid-template-columns:1fr}.student-visual{display:none}.login-side{padding:18px}.login-hero{min-height:420px}.filter-row{grid-template-columns:1fr}.number-list{position:static;grid-template-columns:repeat(5,1fr)}}@media(max-width:720px){.topbar{align-items:flex-start;flex-wrap:wrap;padding:12px}.menu-toggle{display:block;margin-left:auto}.topbar nav{display:none;width:100%;flex-direction:column;align-items:stretch;background:rgba(255,255,255,.1);border-radius:14px;padding:8px}.nav-open .topbar nav{display:flex}.cards{grid-template-columns:1fr}.login-topbar{height:auto;min-height:70px;gap:10px;flex-wrap:wrap;padding:12px 16px}.login-nav{width:100%;justify-content:space-between;gap:8px;font-size:13px}.login-title h1{font-size:44px}.ministry-row{font-size:12px}.login-card{padding:24px 18px}.number-list{grid-template-columns:repeat(4,1fr)}.status-line{display:block}.container{padding:18px 12px}}@media print{.topbar,.footer,.no-print,.number-list,.btn{display:none!important}.container{max-width:none;margin:0;padding:0}.panel{box-shadow:none;border:1px solid #bbb}.analysis-layout{display:block}body{background:white}.print-title{text-align:center}.table-wrap{border:0}}
