/* CAS Client Access Control — Modern responsive theme */
:root{
  --cas-bg:#f5f7fb;--cas-bg-soft:#eef4ff;--cas-surface:#ffffff;--cas-surface-2:#f8fafc;--cas-border:#e2e8f0;--cas-text:#0f172a;--cas-muted:#64748b;--cas-primary:#2563eb;--cas-primary-2:#1d4ed8;--cas-accent:#06b6d4;--cas-success:#16a34a;--cas-danger:#dc2626;--cas-warning:#f59e0b;--cas-info:#0ea5e9;--cas-sidebar:#08111f;--cas-sidebar-2:#111c31;--cas-sidebar-text:#cbd5e1;--cas-sidebar-active:rgba(37,99,235,.18);--cas-radius:20px;--cas-radius-sm:12px;--cas-shadow:0 22px 70px rgba(15,23,42,.11);--cas-shadow-sm:0 10px 28px rgba(15,23,42,.08);--cas-nav-w:280px;--cas-mobile-nav-h:74px}
*{box-sizing:border-box}html{scroll-behavior:smooth}body.cas-body{min-height:100vh;margin:0;background:radial-gradient(circle at top left,rgba(37,99,235,.16),transparent 30%),radial-gradient(circle at top right,rgba(6,182,212,.13),transparent 28%),linear-gradient(180deg,var(--cas-bg),#eef2f7);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--cas-text);font-size:15px}.cas-app{min-height:100vh;display:flex}.cas-sidebar{position:fixed;inset:0 auto 0 0;width:var(--cas-nav-w);background:linear-gradient(180deg,var(--cas-sidebar),var(--cas-sidebar-2));color:white;padding:22px 18px;display:flex;flex-direction:column;z-index:30;box-shadow:18px 0 50px rgba(15,23,42,.18)}.cas-side-brand{display:flex;gap:13px;align-items:center;padding:8px 8px 24px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:16px}.cas-logo{width:48px;height:48px;border-radius:17px;background:linear-gradient(135deg,var(--cas-primary),var(--cas-accent));display:grid;place-items:center;color:white;font-weight:950;font-size:18px;box-shadow:0 16px 38px rgba(37,99,235,.28)}.cas-brand-title{font-weight:950;letter-spacing:-.04em;font-size:1.25rem;line-height:1}.cas-brand-subtitle{color:#94a3b8;font-size:.82rem;margin-top:4px}.cas-nav{display:grid;gap:6px}.cas-nav-link{display:flex;align-items:center;gap:11px;padding:12px 13px;border-radius:15px;color:var(--cas-sidebar-text);text-decoration:none;font-weight:800;transition:.18s ease}.cas-nav-link:hover,.cas-nav-link.active{background:var(--cas-sidebar-active);color:#fff;transform:translateX(2px)}.cas-nav-icon{width:25px;text-align:center}.cas-sidebar-footer{margin-top:auto;color:#94a3b8;font-size:.78rem;padding:16px 8px 4px}.cas-main{width:100%;margin-left:var(--cas-nav-w);padding:26px 28px 34px}.cas-topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:20px}.cas-page-kicker{display:inline-flex;align-items:center;gap:8px;padding:7px 11px;border:1px solid #bfdbfe;background:#eff6ff;color:#1d4ed8;border-radius:999px;font-weight:900;font-size:.76rem;margin-bottom:8px}.cas-page-title{margin:0;font-size:clamp(1.55rem,2.6vw,2.3rem);font-weight:950;letter-spacing:-.055em}.cas-page-subtitle{margin:5px 0 0;color:var(--cas-muted);max-width:850px}.cas-user-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}.cas-user-pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--cas-border);border-radius:999px;padding:9px 13px;font-weight:850;color:#334155;box-shadow:var(--cas-shadow-sm)}.cas-card{background:rgba(255,255,255,.93);border:1px solid rgba(226,232,240,.92);border-radius:var(--cas-radius);box-shadow:var(--cas-shadow-sm);padding:20px;backdrop-filter:blur(12px)}.cas-card-lg{padding:24px}.cas-card-title{font-size:1.05rem;font-weight:950;letter-spacing:-.025em;margin:0 0 4px}.cas-card-muted{color:var(--cas-muted);margin:0}.cas-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px}.cas-stat{display:flex;align-items:center;gap:14px}.cas-stat-icon{width:50px;height:50px;border-radius:17px;display:grid;place-items:center;color:white;font-size:1.25rem}.cas-stat strong{font-size:1.9rem;line-height:1;font-weight:950;letter-spacing:-.055em}.cas-stat span{display:block;color:var(--cas-muted);font-weight:800;margin-top:3px}.cas-stat-link{display:block;text-decoration:none;color:inherit;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease;cursor:pointer}.cas-stat-link:hover{color:inherit;transform:translateY(-3px);box-shadow:var(--cas-shadow);border-color:#bfdbfe}.cas-stat-link:focus-visible{outline:3px solid rgba(37,99,235,.28);outline-offset:3px}.cas-stat-link small{display:block;margin-top:5px;color:#94a3b8;font-weight:900;font-size:.76rem}.cas-stat-link-danger:hover{border-color:#fecaca;box-shadow:0 22px 70px rgba(220,38,38,.16)}.cas-grad-blue{background:linear-gradient(135deg,#2563eb,#06b6d4)}.cas-grad-green{background:linear-gradient(135deg,#16a34a,#22c55e)}.cas-grad-red{background:linear-gradient(135deg,#dc2626,#f97316)}.cas-grad-dark{background:linear-gradient(135deg,#0f172a,#334155)}.cas-alert{border:0;border-radius:16px;padding:14px 16px;font-weight:800}.cas-alert-success{background:#ecfdf5;color:#166534}.cas-alert-danger{background:#fef2f2;color:#991b1b}.cas-alert-info{background:#eff6ff;color:#1e40af}.cas-alert-warning{background:#fffbeb;color:#92400e}.cas-cache-pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:6px 10px;font-size:.78rem;font-weight:900;background:#eff6ff;color:#1d4ed8;margin-left:8px}.cas-cache-pill.cached{background:#f0fdf4;color:#15803d}.cas-table-card{padding:0;overflow:hidden}.cas-table-head{display:flex;align-items:center;justify-content:space-between;gap:12px;color:white;padding:16px 20px}.cas-table-head h5{margin:0;font-weight:950;letter-spacing:-.02em}.cas-table-wrap{padding:16px;overflow:auto}.cas-table-wrap::-webkit-scrollbar{height:9px}.cas-table-wrap::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:999px}.table{vertical-align:middle}.table thead th{font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:#475569;background:#f8fafc!important;white-space:nowrap}.table td{white-space:nowrap}.btn{border-radius:12px;font-weight:850}.form-control,.form-select{border-radius:13px;border-color:#cbd5e1;padding:.68rem .85rem;font-weight:650}.form-control:focus,.form-select:focus{box-shadow:0 0 0 .22rem rgba(37,99,235,.14);border-color:#60a5fa}.cas-router-panel{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.cas-router-panel .form-select{min-width:min(420px,100%)}.cas-kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;background:#0f172a;color:#e2e8f0;border-radius:8px;padding:2px 7px;font-size:.8rem}.cas-help-list{padding-left:1.15rem;margin-bottom:0}.cas-help-list li{margin-bottom:.56rem}.cas-footer-note{color:#94a3b8;text-align:center;margin:20px 0 0}.cas-mobile-top{display:none}.cas-bottom-nav{display:none}.cas-login-shell{min-height:100vh;display:grid;place-items:center;padding:22px;background:radial-gradient(circle at top left,rgba(37,99,235,.35),transparent 32%),linear-gradient(135deg,#07111f,#0f172a 55%,#111827)}.cas-login-card{width:min(460px,100%);background:rgba(255,255,255,.95);border:1px solid rgba(255,255,255,.7);box-shadow:0 24px 80px rgba(0,0,0,.24);border-radius:30px;padding:30px}.cas-login-mark{width:70px;height:70px;border-radius:24px;background:linear-gradient(135deg,#2563eb,#06b6d4);display:grid;place-items:center;color:white;font-size:30px;font-weight:950;margin:0 auto 16px}.cas-toast-zone{position:fixed;right:18px;bottom:18px;display:grid;gap:10px;z-index:80}.cas-toast{border-radius:16px;padding:12px 14px;box-shadow:var(--cas-shadow);background:#fff;border:1px solid var(--cas-border);font-weight:850}.cas-toast.success{background:#ecfdf5;color:#166534}.cas-toast.danger{background:#fef2f2;color:#991b1b}.cas-loading .cas-on-load{opacity:.68;pointer-events:none}.cas-loading .cas-submit-spinner{display:inline-block}.cas-submit-spinner{display:none;width:1rem;height:1rem;border:.15em solid currentColor;border-right-color:transparent;border-radius:50%;animation:cas-spin .65s linear infinite;margin-right:6px;vertical-align:-2px}@keyframes cas-spin{to{transform:rotate(360deg)}}
@media(max-width:1100px){:root{--cas-nav-w:244px}.cas-main{padding:22px}.cas-grid{gap:14px}.cas-card{padding:17px}.cas-table-wrap{padding:12px}}
@media(max-width:820px){body.cas-body{padding-bottom:var(--cas-mobile-nav-h)}.cas-app{display:block}.cas-sidebar{display:none}.cas-main{margin-left:0;padding:16px 14px 22px}.cas-mobile-top{display:flex;align-items:center;justify-content:space-between;gap:10px;background:linear-gradient(135deg,#07111f,#16233b);color:white;border-radius:20px;padding:12px 14px;margin-bottom:14px;box-shadow:var(--cas-shadow-sm)}.cas-topbar{align-items:flex-start;flex-direction:column}.cas-user-actions{width:100%;justify-content:flex-start}.cas-user-actions .btn{flex:1}.cas-grid{grid-template-columns:1fr}.cas-card{grid-column:1!important}.cas-router-panel{display:grid}.cas-router-panel .btn,.cas-router-panel .form-select{width:100%;min-width:100%}.cas-table-head{align-items:flex-start;flex-direction:column}.cas-table-wrap{padding:10px}.table{font-size:.88rem}.cas-bottom-nav{position:fixed;left:0;right:0;bottom:0;height:var(--cas-mobile-nav-h);display:flex;overflow-x:auto;overflow-y:hidden;background:rgba(255,255,255,.96);border-top:1px solid var(--cas-border);box-shadow:0 -16px 40px rgba(15,23,42,.12);z-index:70;backdrop-filter:blur(16px)}.cas-bottom-nav a{display:flex;flex:0 0 72px;flex-direction:column;align-items:center;justify-content:center;gap:2px;text-decoration:none;color:#64748b;font-size:.68rem;font-weight:900}.cas-bottom-nav a.active{color:var(--cas-primary)}.cas-bottom-nav span:first-child{font-size:1.18rem}.cas-login-card{padding:24px;border-radius:24px}}


/* 2026-05-23 Premium polish — frontend-design-alvii: distinctive, safe, no architecture change */
:root{--cas-focus:0 0 0 .24rem rgba(37,99,235,.20);--cas-danger-soft:#fff1f2;--cas-success-soft:#ecfdf5;--cas-warning-soft:#fffbeb;--cas-info-soft:#eff6ff}
::selection{background:rgba(37,99,235,.18)}
a{transition:color .16s ease,background .16s ease,border-color .16s ease,transform .16s ease,box-shadow .16s ease}.btn{box-shadow:0 8px 18px rgba(15,23,42,.05)}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:focus-visible,.form-control:focus-visible,.form-select:focus-visible,.form-check-input:focus-visible{outline:0;box-shadow:var(--cas-focus)}
.cas-sidebar:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 18% 8%,rgba(6,182,212,.20),transparent 30%),linear-gradient(180deg,rgba(255,255,255,.04),transparent 28%);pointer-events:none}.cas-sidebar>*{position:relative}.cas-side-brand{border-radius:20px;padding:12px;margin-bottom:18px;background:rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.07)}.cas-logo{position:relative;overflow:hidden}.cas-logo:after{content:"";position:absolute;inset:-60%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.28),transparent);transform:rotate(20deg) translateX(-60%);animation:cas-logo-sheen 5.5s ease-in-out infinite}@keyframes cas-logo-sheen{0%,55%{transform:rotate(20deg) translateX(-70%)}75%,100%{transform:rotate(20deg) translateX(70%)}}
.cas-nav-link{position:relative}.cas-nav-link.active:before{content:"";position:absolute;left:6px;top:50%;width:4px;height:24px;border-radius:999px;background:linear-gradient(180deg,var(--cas-accent),var(--cas-primary));transform:translateY(-50%)}.cas-nav-link.active{padding-left:18px;box-shadow:inset 0 0 0 1px rgba(255,255,255,.06),0 12px 24px rgba(37,99,235,.11)}.cas-sidebar-footer{border-top:1px solid rgba(255,255,255,.08);margin-top:auto;padding-top:16px;line-height:1.55}
.cas-main{position:relative}.cas-main:before{content:"";position:fixed;right:-180px;top:-180px;width:420px;height:420px;border-radius:999px;background:radial-gradient(circle,rgba(37,99,235,.10),transparent 65%);pointer-events:none;z-index:-1}.cas-topbar{background:rgba(255,255,255,.72);border:1px solid rgba(226,232,240,.82);box-shadow:0 14px 38px rgba(15,23,42,.06);border-radius:26px;padding:18px 20px;backdrop-filter:blur(16px)}.cas-page-kicker{box-shadow:0 8px 22px rgba(37,99,235,.08)}
.cas-command-strip{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:12px;margin:-4px 0 18px}.cas-command-chip{display:flex;align-items:center;gap:12px;background:rgba(255,255,255,.78);border:1px solid rgba(226,232,240,.88);border-radius:18px;padding:12px 14px;box-shadow:0 10px 28px rgba(15,23,42,.045);min-width:0}.cas-command-icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:#eff6ff;color:#1d4ed8;font-weight:950;flex:0 0 auto}.cas-command-chip strong{display:block;font-size:.88rem;letter-spacing:-.01em}.cas-command-chip span{display:block;color:var(--cas-muted);font-size:.76rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cas-command-chip.danger .cas-command-icon{background:#fef2f2;color:#b91c1c}.cas-command-chip.success .cas-command-icon{background:#ecfdf5;color:#15803d}
.cas-card{position:relative}.cas-card:before{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;background:linear-gradient(135deg,rgba(255,255,255,.52),transparent 36%);opacity:.72}.cas-card>*{position:relative}.cas-card:hover{border-color:#cbd5e1}.cas-card-title{line-height:1.15}.cas-card-muted{line-height:1.6}.cas-stat-link{overflow:hidden}.cas-stat-link:after{content:"";position:absolute;right:-34px;bottom:-34px;width:104px;height:104px;border-radius:999px;background:rgba(37,99,235,.055);transition:.2s ease}.cas-stat-link:hover:after{transform:scale(1.18)}
.cas-hero-panel{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(260px,.7fr);gap:18px;align-items:stretch;margin-bottom:18px}.cas-hero-copy{overflow:hidden}.cas-hero-copy:after{content:"";position:absolute;right:-64px;top:-64px;width:190px;height:190px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.14),rgba(6,182,212,.10));pointer-events:none}.cas-hero-title{font-size:clamp(1.35rem,2vw,2rem);font-weight:950;letter-spacing:-.045em;margin:0 0 8px}.cas-hero-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:16px}.cas-mini-metric{display:grid;gap:10px}.cas-mini-metric .cas-command-chip{height:100%}
.cas-table-wrap{position:relative}.cas-table-wrap:before{content:"Geser tabel ke samping jika kolom belum terlihat";display:none;color:#64748b;font-size:.76rem;font-weight:850;margin:0 0 8px}.table thead th{position:sticky;top:0;z-index:2}.table tbody tr{transition:background .14s ease,transform .14s ease}.table tbody tr:hover{background:#f8fbff}.dataTables_wrapper .dataTables_filter input,.dataTables_wrapper .dataTables_length select{border:1px solid #cbd5e1;border-radius:12px;padding:.42rem .65rem;margin-left:.35rem}.dataTables_wrapper .dataTables_filter label,.dataTables_wrapper .dataTables_length label{font-weight:800;color:#475569}.dataTables_wrapper .page-link{border-radius:10px;margin:0 2px;color:#2563eb;font-weight:800}.dataTables_wrapper .page-item.active .page-link{background:#2563eb;border-color:#2563eb}.dataTables_info{color:#64748b;font-weight:750}.cas-empty-state{text-align:center;padding:36px 18px;color:#64748b}.cas-empty-state .cas-empty-icon{width:58px;height:58px;border-radius:20px;background:#eff6ff;color:#1d4ed8;display:grid;place-items:center;margin:0 auto 12px;font-size:1.55rem}.cas-empty-state strong{display:block;color:#0f172a;font-size:1.05rem;margin-bottom:4px}
.cas-login-card{position:relative;overflow:hidden}.cas-login-card:before{content:"";position:absolute;right:-80px;top:-80px;width:190px;height:190px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(6,182,212,.12))}.cas-login-card>*{position:relative}.cas-login-trust{display:grid;gap:8px;margin:18px 0 0;padding:14px;border-radius:18px;background:#f8fafc;border:1px solid #e2e8f0;color:#475569;font-size:.86rem;font-weight:750}.cas-login-trust span{display:flex;gap:8px;align-items:flex-start}.cas-login-trust b{color:#0f172a}
@media(max-width:980px){.cas-command-strip,.cas-hero-panel{grid-template-columns:1fr}.cas-command-strip{margin-top:0}.cas-mini-metric{grid-template-columns:repeat(3,1fr)}}
@media(max-width:820px){.cas-topbar{border-radius:22px;padding:16px}.cas-command-strip{gap:9px}.cas-command-chip{padding:11px 12px}.cas-mini-metric{grid-template-columns:1fr}.cas-table-wrap:before{display:block}.cas-bottom-nav a{min-width:72px}.dataTables_wrapper .row{gap:8px}.dataTables_wrapper .dataTables_filter,.dataTables_wrapper .dataTables_length{text-align:left!important}.cas-page-subtitle{font-size:.94rem}}
@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation:none!important;transition:none!important;scroll-behavior:auto!important}.btn:hover,.cas-nav-link:hover,.cas-stat-link:hover{transform:none!important}}
.cas-grad-purple{background:linear-gradient(135deg,#7c3aed,#06b6d4)!important;color:#fff!important;}
