/* assets/css/style.css */
:root{
  --blue:#2d74b8;
  --blue2:#1f5f9b;
  --bg:#f3f6fb;
  --card:#ffffff;
  --muted:#6b7785;
  --danger:#d9534f;
  --warning:#f0ad4e;
  --success:#28a745;
}
*{box-sizing:border-box}
body{
  margin:0;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background: var(--bg);
  color:#1b1f23;
}
.topbar{
  height:76px;
  background: linear-gradient(0deg,var(--blue2),var(--blue));
  color:#fff;
  display:flex;
  align-items:center;
  padding:0 18px;
  gap:14px;
  position:sticky;
  top:0;
  z-index:50;
}
.brand{
  display:flex;align-items:center;gap:12px;
}
.logo-badge{
  width:44px;height:44px;border-radius:50%;
  background:rgba(255,255,255,.14);
  display:grid;place-items:center;
  border:1px solid rgba(255,255,255,.25);
}
.brand .title{
  font-weight:800;
  letter-spacing:.5px;
  line-height:1.05;
}
.brand .subtitle{
  font-size:12px;
  opacity:.9;
  letter-spacing:.6px;
}
.container{
  max-width:1100px;
  margin:22px auto;
  padding:0 14px;
}
.card{
  background:var(--card);
  border-radius:14px;
  box-shadow:0 10px 24px rgba(16,24,40,.08);
  border:1px solid rgba(16,24,40,.06);
}
.card.pad{ padding:22px; }
.center-wrap{
  min-height: calc(100vh - 76px);
  display:grid;
  place-items:center;
  padding:26px 14px;
}
.login-card{
  width:min(520px, 92vw);
  padding:26px 28px 22px;
  border-radius:18px;
}
.login-hero{
  text-align:center;
  margin:8px 0 18px;
}
.login-hero h1{
  margin:0;
  font-size:44px;
  font-weight:800;
}
.login-hero p{
  margin:10px 0 0;
  color:var(--muted);
  font-size:15px;
}
.form{
  display:flex;
  flex-direction:column;
  gap:14px;
  margin-top:18px;
}
.field{
  display:flex;
  align-items:center;
  gap:10px;
  border-bottom:2px solid #cfd7e3;
  padding:10px 6px;
}
.field svg{opacity:.55}
.field input{
  border:none;
  outline:none;
  width:100%;
  font-size:15px;
  background:transparent;
}
.btn{
  border:none;
  border-radius:10px;
  padding:12px 14px;
  font-weight:700;
  cursor:pointer;
}
.btn.primary{ background:#1e78d7; color:#fff; }
.btn.primary:hover{ filter:brightness(.95); }
.btn.ghost{ background:#eef3fb; color:#1f5f9b; }
.btn.danger{ background:#d9534f; color:#fff; }
.row{ display:flex; gap:12px; align-items:center; justify-content:space-between; }
.small{ font-size:12px; color:var(--muted); }
.alert{
  padding:10px 12px;
  border-radius:10px;
  background:#fff3cd;
  border:1px solid #ffe69c;
  color:#8a6d3b;
  font-size:14px;
}
.alert.danger{ background:#f8d7da; border-color:#f1aeb5; color:#842029; }
.kv{
  display:grid;
  grid-template-columns: 130px 1fr;
  gap:8px 12px;
  font-size:14px;
  margin:10px 0 6px;
}
.kv div:nth-child(odd){ color:var(--muted); }
hr{ border:none; border-top:1px solid #e8eef7; margin:16px 0; }

.exam-shell{
  background:#fff;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(16,24,40,.06);
  box-shadow:0 12px 26px rgba(16,24,40,.08);
}
.exam-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid #e8eef7;
  background:#fbfdff;
}
.exam-head .left{
  display:flex; align-items:center; gap:12px;
}
.pill{
  padding:8px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:700;
  background:#eaf3ff;
  color:#1e78d7;
}
.timer{
  padding:8px 12px;
  border-radius:999px;
  font-weight:800;
  background:#f2f4f7;
}
.exam-body{
  display:grid;
  grid-template-columns: 1.4fr 1fr;
  min-height:560px;
}
@media (max-width: 960px){
  .exam-body{ grid-template-columns: 1fr; }
}
.panel{
  padding:16px;
}
.panel.left{
  border-right:1px solid #eef2f7;
}
.qtitle{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
}
.qtitle h2{ margin:0; font-size:18px; }
.qtext{
  margin-top:10px;
  padding:14px;
  border-radius:12px;
  background:#fff;
  border:1px solid #eef2f7;
  max-height:420px;
  overflow:auto;
}
@media (max-width: 960px){
  .qtext{ max-height:260px; }
}
.answers{
  padding:10px 6px;
}
.opt{
  display:flex;
  gap:10px;
  padding:10px 10px;
  border-radius:12px;
  border:1px solid #eef2f7;
  margin:10px 0;
}
.opt:hover{ background:#fbfdff; }
.opt input{ margin-top:3px; }
.exam-foot{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:14px 16px;
  border-top:1px solid #e8eef7;
  background:#fbfdff;
}
.float-selfie{
  position:fixed;
  left:12px;
  top:12px;
  width: 88px;
  border-radius:16px;
  overflow:hidden;
  border:1px solid rgba(16,24,40,.12);
  box-shadow:0 12px 26px rgba(16,24,40,.18);
  background:#000;
  z-index:80;
}

.modal{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;}
.modal-back{position:absolute;inset:0;background:rgba(15,23,42,.45);}
.modal-card{position:relative;z-index:2;width:min(720px,92vw);background:#fff;border-radius:16px;border:1px solid #e5edf7;box-shadow:0 20px 60px rgba(16,24,40,.25);overflow:hidden;}
.modal-head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid #eef2f7;background:#fbfdff;}
.modal-body{padding:14px;max-height:70vh;overflow:auto;}
.float-selfie video{
  width:100%;
  height: 64px;
  object-fit:cover;
  display:block;
}
.float-selfie .cap{
  background:rgba(255,255,255,.92);
  padding:8px 10px;
  font-size: 10px;
  font-weight:700;
  color:#1f5f9b;
}
.navgrid{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:8px 0 0;
}
.navbtn{
  width:40px;height:34px;
  border-radius:10px;
  border:1px solid #dfe7f3;
  background:#fff;
  cursor:pointer;
  font-weight:800;
}
.navbtn.done{ background:#dff7e6; border-color:#bfe8c8; }
.navbtn.flag{background:rgba(245,158,11,.18);border-color:rgba(245,158,11,.55);color:#92400e;}
.navbtn.flag.curr{outline:2px solid rgba(245,158,11,.65);}

.navbtn.curr{ outline:3px solid rgba(30,120,215,.22); border-color:#7fb5ef; }

.admin-shell{
  display:grid;
  grid-template-columns: 260px 1fr;
  gap:14px;
}
@media (max-width: 1000px){
  .admin-shell{ grid-template-columns: 1fr; }
}
.sidebar{
  padding:14px;
  border-radius:14px;
  background:#0f3c63;
  color:#fff;
}
.sidebar a{
  color:#fff;
  text-decoration:none;
}
.side-title{
  font-weight:900;
  letter-spacing:.6px;
  margin:6px 0 10px;
}
.menu{
  display:flex;
  flex-direction:column;
  gap:8px;
}
.menu a{
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,255,255,.10);
}
.menu a:hover{ background:rgba(255,255,255,.16); }
.content{
  padding:0;
}
.table{
  width:100%;
  border-collapse:collapse;
}
.table th, .table td{
  padding:10px 10px;
  border-bottom:1px solid #eef2f7;
  text-align:left;
  font-size:14px;
}
.badge{
  padding:4px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:800;
  display:inline-block;
}
.badge.ok{ background:#dff7e6; color:#136c2c; }
.badge.warn{ background:#fff3cd; color:#8a6d3b; }
.badge.bad{ background:#f8d7da; color:#842029; }

/* =========================
   ADMIN (UI mirip dashboard PUSPENDIK)
   ========================= */
.admin-app{
  display:flex;
  min-height:100vh;
  background:#f4f6f9;
}
.admin-sidebar{
  width:278px;
  background:#fff;
  border-right:1px solid #e6e9ef;
  position:sticky;
  top:0;
  height:100vh;
  overflow:auto;
}
.admin-brand{
  padding:18px 16px 12px;
  border-bottom:1px solid #eef2f7;
}
.admin-logo{
  width:74px;
  height:74px;
  border-radius:50%;
  margin:0 auto 10px;
  display:grid;
  place-items:center;
  background:#f2f6fb;
  border:1px solid #e3ebf7;
}
.admin-logo svg{ width:46px; height:46px; }
.admin-brand-text{ text-align:center; }
.admin-brand-title{ font-weight:900; font-size:14px; letter-spacing:.2px; }
.admin-brand-sub{ font-size:11px; color:#6b7785; margin-top:2px; }
.admin-user{ margin-top:12px; }
.admin-user-pill{
  display:flex;
  gap:10px;
  align-items:center;
  padding:10px 12px;
  border-radius:12px;
  background:#f6f8fb;
  border:1px solid #e7edf7;
}
.admin-user-pill .ico{ color:#4b5563; }
.admin-user-name{ font-weight:900; font-size:13px; }
.admin-user-role{ font-size:11px; color:#6b7785; }

.admin-nav{ padding:12px 10px 18px; }
.admin-nav-section{
  font-size:11px;
  font-weight:900;
  color:#97a3b3;
  letter-spacing:.5px;
  margin:10px 10px 8px;
}
.admin-link,
.admin-group{
  width:100%;
  display:flex;
  align-items:center;
  gap:10px;
  padding:11px 12px;
  margin:4px 6px;
  border-radius:12px;
  color:#1f2937;
  text-decoration:none;
  border:1px solid transparent;
  background:transparent;
  cursor:pointer;
  font-weight:800;
  font-size:13px;
}

.admin-details{ margin:0; padding:0; }
.admin-details > summary{ list-style:none; }
.admin-details > summary::-webkit-details-marker{ display:none; }
.admin-details[open] .admin-sub{ display:block; }
.admin-details[open] .chev{ transform: rotate(180deg); }
.admin-group .chev{ margin-left:auto; transition: transform .15s ease; }
.admin-link .ico,
.admin-group .ico{ color:#0f3c63; opacity:.9; }
.admin-link:hover,
.admin-group:hover{ background:#f4f8ff; border-color:#e3ecfb; }
.admin-link.is-active{ background:#0f3c63; color:#fff; }
.admin-link.is-active .ico{ color:#fff; opacity:1; }

.admin-group .chev{ margin-left:auto; color:#6b7785; transition:transform .2s ease; }
.admin-group.is-open .chev{ transform:rotate(180deg); }

.admin-sub{
  display:none;
  margin:0 6px 6px;
  padding:4px 0 8px;
}
.admin-sub.is-open{ display:block; }
.admin-sublink{
  display:block;
  padding:10px 12px 10px 44px;
  margin:4px 0;
  border-radius:12px;
  color:#334155;
  text-decoration:none;
  font-weight:800;
  font-size:13px;
}
.admin-sublink:hover{ background:#f4f8ff; }
.admin-sublink.is-active{ background:#0f3c63; color:#fff; }

.admin-main{ flex:1; min-width:0; }
.admin-top{
  height:60px;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 16px;
  background:#fff;
  border-bottom:1px solid #e6e9ef;
  position:sticky;
  top:0;
  z-index:40;
}
.admin-burger{
  width:40px;height:40px;
  border-radius:10px;
  border:1px solid #e6e9ef;
  background:#fff;
  display:none;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.admin-top-title{ font-weight:900; color:#0f3c63; }
.admin-top-btn{
  display:flex;
  align-items:center;
  gap:8px;
  padding:9px 12px;
  border-radius:10px;
  border:1px solid #e3ecfb;
  background:#0ea5e9;
  color:#fff;
  text-decoration:none;
  font-weight:900;
  font-size:13px;
}
.admin-top-btn:hover{ filter:brightness(.97); }

.admin-content{
  padding:16px;
  max-width: 1180px;
}

.admin-card{
  background:#fff;
  border-radius:12px;
  border:1px solid rgba(16,24,40,.06);
  box-shadow:0 10px 24px rgba(16,24,40,.06);
}
.admin-card-h{
  padding:12px 14px;
  border-bottom:1px solid #eef2f7;
  display:flex;
  align-items:center;
  gap:10px;
}
.admin-card-h .tag{
  background:#16a34a;
  color:#fff;
  font-weight:900;
  font-size:12px;
  padding:6px 10px;
  border-radius:8px;
}
.admin-card-b{ padding:14px; }

.announce-item{
  display:flex;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid #eef2f7;
}
.announce-item:last-child{ border-bottom:none; }
.announce-ico{
  width:34px;height:34px;
  border-radius:50%;
  background:#eaf3ff;
  display:grid;
  place-items:center;
  color:#1e78d7;
  border:1px solid #dbe9ff;
  flex:0 0 auto;
}
.announce-title{
  font-weight:900;
  color:#1e78d7;
  margin:0;
}
.announce-meta{ font-size:12px; color:#6b7785; margin-top:2px; }
.announce-body{ margin-top:8px; color:#24324a; font-size:14px; line-height:1.55; }

@media (max-width: 980px){
  .admin-burger{ display:flex; }
  .admin-sidebar{
    position:fixed;
    left:-290px;
    top:0;
    z-index:60;
    transition:left .2s ease;
  }
  .admin-sidebar.is-open{ left:0; }
  .admin-content{ max-width: 100%; }
}


/* Patch: non-dropdown Data Master label */
.admin-section-label{margin:16px 14px 8px;font-size:12px;letter-spacing:.06em;color:#9aa6b2;font-weight:700;}


.admin-sidebar-overlay{ display:none; }
body.admin-menu-open{ overflow:hidden; }
@media (max-width: 980px){
  .admin-top{ padding:0 12px; }
  .admin-top-title{ font-size:15px; }
  .admin-top-btn{ padding:8px 10px; font-size:12px; }
  .admin-sidebar{
    width:280px;
    max-width:calc(100vw - 28px);
    box-shadow:0 18px 48px rgba(15,23,42,.26);
  }
  .admin-sidebar-overlay{
    display:block;
    position:fixed;
    inset:0;
    background:rgba(15,23,42,.32);
    opacity:0;
    pointer-events:none;
    z-index:55;
    transition:opacity .2s ease;
  }
  .admin-sidebar-overlay.is-open{
    opacity:1;
    pointer-events:auto;
  }
}


/* =========================
   SETTINGS PAGE POLISH
   ========================= */
.settings-shell{display:flex;flex-direction:column;gap:16px;}
.settings-form{display:flex;flex-direction:column;gap:16px;}
.settings-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:16px;}
.settings-hero{display:flex;justify-content:space-between;gap:16px;padding:18px 20px;background:linear-gradient(135deg,#f8fbff,#eef5ff);border:1px solid #dbe9ff;}
.settings-kicker{font-size:12px;font-weight:900;letter-spacing:.08em;color:#1e78d7;text-transform:uppercase;margin-bottom:6px;}
.settings-hero h2{margin:0;color:#0f3c63;font-size:28px;line-height:1.1;}
.settings-hero p{margin:8px 0 0;color:#5f6f82;max-width:660px;line-height:1.55;}
.settings-hero-right{display:flex;flex-direction:column;gap:10px;align-items:flex-end;justify-content:center;min-width:240px;}
.settings-badge{display:inline-flex;align-items:center;justify-content:center;padding:10px 14px;border-radius:999px;font-weight:900;font-size:12px;letter-spacing:.03em;border:1px solid #d7e5fb;background:#fff;color:#0f3c63;max-width:100%;text-align:center;}
.settings-badge.ok{background:#dff7e6;border-color:#bfe8c8;color:#136c2c;}
.settings-badge.muted{background:#f3f6fb;border-color:#e4ebf5;color:#637588;}
.settings-badge.soft{background:#fff;border-color:#d7e5fb;color:#1e4f86;}
.settings-block{overflow:hidden;}
.settings-block-head{padding:16px 18px;border-bottom:1px solid #eef2f7;background:#fbfdff;}
.settings-block-body{padding:18px;display:flex;flex-direction:column;gap:14px;}
.settings-title{font-size:18px;font-weight:900;color:#0f3c63;margin-bottom:4px;}
.settings-field{display:flex;flex-direction:column;gap:8px;}
.settings-field label{font-size:13px;font-weight:800;color:#23354d;}
.settings-input{width:100%;padding:13px 14px;border-radius:14px;border:1px solid #dfe7f3;background:#fff;font-size:14px;color:#1f2937;outline:none;transition:border-color .15s ease, box-shadow .15s ease;}
.settings-input:focus{border-color:#7fb5ef;box-shadow:0 0 0 4px rgba(30,120,215,.12);}
.settings-toggle-card{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:16px;border:1px solid #e6edf7;border-radius:16px;background:#fff;}
.settings-toggle-main{display:flex;align-items:flex-start;gap:12px;}
.settings-toggle-main input{margin-top:3px;transform:scale(1.05);}
.settings-mini-badge{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;font-weight:900;font-size:12px;white-space:nowrap;border:1px solid #e2e8f0;background:#f8fafc;color:#64748b;}
.settings-mini-badge.ok{background:#dff7e6;border-color:#bfe8c8;color:#136c2c;}
.settings-mini-badge.warn{background:#fff3cd;border-color:#ffe69c;color:#8a6d3b;}
.settings-mini-badge.muted{background:#f3f6fb;border-color:#e4ebf5;color:#637588;}
.settings-note-grid{display:grid;grid-template-columns:1fr 180px;gap:12px;}
.settings-note-card{padding:14px 15px;border-radius:14px;background:#f8fbff;border:1px solid #dbe9ff;}
.settings-note-label{font-size:12px;font-weight:800;color:#6780a0;margin-bottom:6px;}
.settings-note-value{font-size:14px;font-weight:900;color:#173b68;line-height:1.45;word-break:break-word;}
.settings-stack{display:flex;flex-direction:column;gap:14px;}
.settings-inline-box{display:flex;align-items:end;gap:16px;padding:14px 16px;border-radius:16px;border:1px dashed #d9e5f5;background:#f8fbff;}
.settings-field-small{max-width:200px;min-width:160px;}
.settings-subject-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;}
.settings-subject-card{padding:14px;border:1px solid #e6edf7;border-radius:16px;background:#fff;}
.settings-subject-name{font-weight:900;color:#173b68;margin-bottom:10px;}
.settings-submit-wrap{display:flex;justify-content:flex-end;}
.settings-submit{min-width:220px;padding:14px 18px;border-radius:14px;box-shadow:0 10px 24px rgba(30,120,215,.18);}
@media (max-width: 1100px){
  .settings-grid{grid-template-columns:1fr;}
  .settings-hero{flex-direction:column;align-items:flex-start;}
  .settings-hero-right{align-items:flex-start;min-width:0;}
}
@media (max-width: 760px){
  .settings-block-head,.settings-block-body,.settings-hero{padding:14px;}
  .settings-hero h2{font-size:22px;}
  .settings-toggle-card{flex-direction:column;}
  .settings-note-grid,.settings-subject-grid{grid-template-columns:1fr;}
  .settings-inline-box{flex-direction:column;align-items:stretch;}
  .settings-field-small{max-width:none;min-width:0;}
  .settings-submit-wrap{justify-content:stretch;}
  .settings-submit{width:100%;}
}
