/* =============================================================
   KOPERASI RT 05 - LUXURY PROFESSIONAL RESPONSIVE UI
   PC / Tablet / HP friendly, clean layout, animated premium dark.
   ============================================================= */
:root{
  --sidebar: 292px;
  --bg:#050916;
  --bg2:#0b1224;
  --card:rgba(16,25,48,.78);
  --card2:rgba(23,34,64,.9);
  --line:rgba(255,255,255,.11);
  --line2:rgba(125,211,252,.22);
  --text:#f8fbff;
  --muted:#aebbd2;
  --primary:#20d6ff;
  --secondary:#8b5cf6;
  --success:#20e29a;
  --danger:#fb7185;
  --warning:#fbbf24;
  --shadow:0 24px 80px rgba(0,0,0,.36);
  --shadow2:0 16px 48px rgba(32,214,255,.15);
  --radius:24px;
  --radius2:18px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  min-height:100vh;
  color:var(--text);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
  background:
    radial-gradient(circle at 12% 10%, rgba(32,214,255,.22), transparent 28%),
    radial-gradient(circle at 92% 5%, rgba(139,92,246,.28), transparent 34%),
    linear-gradient(135deg,#050916 0%,#080e1e 42%,#090519 100%);
  overflow-x:hidden;
}
body.app-body{
  display:grid;
  grid-template-columns:var(--sidebar) minmax(0,1fr);
  width:100%;
  min-height:100dvh;
  isolation:isolate;
}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.app-bg{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.app-bg:before{content:"";position:absolute;inset:-20%;background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);background-size:52px 52px;mask-image:linear-gradient(to bottom,transparent,black 15%,black 82%,transparent);animation:gridMove 28s linear infinite}
.app-bg span{position:absolute;width:280px;height:280px;border-radius:999px;filter:blur(48px);opacity:.42;animation:floatOrb 12s ease-in-out infinite alternate}
.app-bg span:nth-child(1){left:7%;top:9%;background:#22d3ee}
.app-bg span:nth-child(2){right:9%;top:11%;background:#8b5cf6;animation-delay:2s}
.app-bg span:nth-child(3){left:46%;bottom:4%;background:#10b981;animation-delay:4s}
@keyframes gridMove{from{transform:translate3d(0,0,0)}to{transform:translate3d(52px,52px,0)}}
@keyframes floatOrb{from{transform:translateY(0) scale(1)}to{transform:translateY(26px) scale(1.08)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes glowPulse{0%,100%{box-shadow:0 0 0 rgba(32,214,255,0)}50%{box-shadow:0 0 34px rgba(32,214,255,.25)}}
.animate-up,.panel,.stat-card,.hero,.excel-hero{animation:fadeUp .55s ease both}
.glass-card,.panel,.topbar,.hero,.stat-card,.excel-hero{
  background:linear-gradient(145deg,rgba(17,27,53,.84),rgba(10,17,34,.72));
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  backdrop-filter:blur(22px);
}
.sidebar{
  grid-column:1;
  position:sticky;
  top:0;
  height:100dvh;
  padding:22px 18px;
  z-index:30;
  background:linear-gradient(180deg,rgba(10,18,38,.95),rgba(6,10,24,.92));
  border-right:1px solid rgba(255,255,255,.1);
  box-shadow:18px 0 70px rgba(0,0,0,.3);
  display:flex;
  flex-direction:column;
  gap:18px;
}
.brand{display:flex;align-items:center;gap:13px;padding:14px;border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.09),rgba(255,255,255,.03));border:1px solid rgba(255,255,255,.12)}
.logo-badge,.avatar{display:grid;place-items:center;flex:0 0 auto;background:linear-gradient(135deg,#38bdf8,#8b5cf6 55%,#f43f5e);color:#fff;font-weight:900;box-shadow:0 14px 36px rgba(56,189,248,.28)}
.logo-badge{width:56px;height:56px;border-radius:17px;font-size:20px}.logo-badge.small{width:50px;height:50px;font-size:18px}
.brand strong{display:block;font-size:17px;letter-spacing:.2px}.brand small,.user-mini small{display:block;color:var(--muted);font-size:12px;margin-top:3px}
.nav-menu{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding:4px 2px 8px;max-height:calc(100dvh - 230px);scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.25) transparent}
.nav-link{display:flex;align-items:center;gap:12px;min-height:48px;padding:12px 13px;border-radius:16px;color:#dce6f7;border:1px solid transparent;transition:.22s ease;position:relative;overflow:hidden}
.nav-link:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(32,214,255,.22),rgba(139,92,246,.22));opacity:0;transition:.22s ease}
.nav-link span{position:relative;z-index:1;width:31px;height:31px;display:grid;place-items:center;border-radius:12px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.08)}
.nav-link:hover,.nav-link.active{color:#fff;border-color:rgba(56,189,248,.22);transform:translateX(4px);box-shadow:0 14px 26px rgba(0,0,0,.18)}
.nav-link:hover:before,.nav-link.active:before{opacity:1}.nav-link.active span{background:linear-gradient(135deg,#06b6d4,#7c3aed)}
.sidebar-footer{margin-top:auto;display:grid;gap:12px}.user-mini{display:flex;gap:11px;align-items:center;padding:13px;border-radius:18px;border:1px solid rgba(255,255,255,.11);background:rgba(255,255,255,.06)}
.avatar{width:44px;height:44px;border-radius:15px}.avatar.big{width:86px;height:86px;border-radius:28px;font-size:32px}
.main{grid-column:2;position:relative;z-index:1;min-width:0;width:100%;padding:26px 28px 34px}.topbar{position:sticky;top:18px;z-index:20;display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:24px;padding:18px 20px;border-radius:26px}
.eyebrow{margin:0 0 5px;text-transform:uppercase;letter-spacing:.13em;color:#7dd3fc;font-size:12px;font-weight:900}.topbar h1{margin:0;font-size:clamp(24px,3vw,38px);line-height:1.05}.top-actions{display:flex;align-items:center;gap:9px;color:#d7e2f5;font-weight:700;white-space:nowrap}.status-dot{width:10px;height:10px;border-radius:99px;background:var(--success);box-shadow:0 0 0 7px rgba(32,226,154,.12)}.hamburger{display:none;width:44px;height:44px;border-radius:15px;border:1px solid rgba(255,255,255,.15);background:rgba(255,255,255,.08);color:#fff;font-size:20px}.hero,.excel-hero{display:flex;align-items:center;justify-content:space-between;gap:22px;border-radius:30px;padding:28px;margin-bottom:22px;overflow:hidden;position:relative}.hero:after,.excel-hero:after{content:"";position:absolute;right:-80px;top:-80px;width:240px;height:240px;border-radius:999px;background:linear-gradient(135deg,rgba(32,214,255,.28),rgba(139,92,246,.26));filter:blur(8px)}.hero h2,.excel-hero h2{margin:0 0 8px;font-size:clamp(26px,4vw,50px);line-height:1.04}.hero p,.excel-hero p{max-width:850px}.hero-badge,.excel-badge{position:relative;z-index:1;display:grid;place-items:center;width:142px;height:142px;border-radius:38px;background:linear-gradient(135deg,#06b6d4,#7c3aed);box-shadow:0 24px 55px rgba(56,189,248,.28);text-align:center}.hero-badge span{display:block;font-size:45px;font-weight:1000}.hero-badge small{display:block;padding:0 14px}.excel-badge{font-size:58px}
.stats-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin:0 0 22px}.stat-card{position:relative;border-radius:24px;padding:18px;overflow:hidden;min-height:138px;transition:.22s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow),var(--shadow2)}.stat-card:after{content:"";position:absolute;inset:auto -38px -50px auto;width:130px;height:130px;border-radius:999px;background:rgba(255,255,255,.08)}.stat-card span{font-size:28px;display:block;margin-bottom:12px}.stat-card p{margin:0;color:var(--muted);font-weight:700;font-size:13px}.stat-card strong{display:block;margin-top:8px;font-size:clamp(19px,2vw,28px);letter-spacing:-.03em;word-break:break-word}.accent-1{border-color:rgba(56,189,248,.22)}.accent-2{border-color:rgba(32,226,154,.22)}.accent-3{border-color:rgba(139,92,246,.24)}.accent-4{border-color:rgba(251,191,36,.24)}.accent-5{border-color:rgba(244,63,94,.24)}
.grid-2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px}.align-start{align-items:start}.panel{border-radius:var(--radius);padding:22px;margin-bottom:18px}.panel h3{margin:0 0 16px;font-size:20px}.muted{color:var(--muted);line-height:1.65}.big-number{font-size:clamp(32px,5vw,52px);font-weight:1000;letter-spacing:-.04em;background:linear-gradient(90deg,#e0faff,#a78bfa);-webkit-background-clip:text;color:transparent}.rule-list{list-style:none;margin:0;padding:0;display:grid;gap:12px}.rule-list li{display:flex;gap:13px;align-items:flex-start;padding:13px;border-radius:16px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08);line-height:1.5}.rule-list li span{width:34px;height:34px;display:grid;place-items:center;border-radius:12px;background:linear-gradient(135deg,#06b6d4,#7c3aed);font-weight:900;color:#fff;flex:0 0 auto}.timeline{display:grid;gap:13px}.timeline-item{display:flex;gap:12px}.timeline-item>span{margin-top:6px;width:12px;height:12px;border-radius:99px;background:#22d3ee;box-shadow:0 0 0 6px rgba(34,211,238,.13)}.timeline-item strong{display:block}.timeline-item p{margin:3px 0;color:var(--muted)}.timeline-item small{color:#8192b2}.summary-strip{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.summary-strip>div{border-radius:18px;padding:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09)}.summary-strip span{display:block;color:var(--muted);font-size:12px;text-transform:uppercase;font-weight:900;letter-spacing:.08em}.summary-strip strong{display:block;margin-top:7px;font-size:19px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.form-stack{display:grid;gap:13px}.form-grid label,.form-stack label,.filter-bar label,.mini-filter label{display:grid;gap:7px;color:#dbe7fb;font-size:13px;font-weight:800}.span-2{grid-column:1/-1}input,select,textarea{width:100%;min-width:0;border:1px solid rgba(255,255,255,.13);background:rgba(4,9,22,.62);color:#fff;border-radius:15px;padding:12px 13px;outline:0;transition:.22s ease}input:focus,select:focus,textarea:focus{border-color:rgba(32,214,255,.65);box-shadow:0 0 0 4px rgba(32,214,255,.1)}select option{background:#0f172a;color:#fff}textarea{resize:vertical}.checkbox{display:flex!important;align-items:center;gap:10px}.checkbox input{width:auto}.filter-bar{display:flex;flex-wrap:wrap;align-items:end;gap:12px}.mini-filter{display:flex;align-items:end;gap:10px}.mini-filter input{max-width:120px}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid rgba(255,255,255,.13);border-radius:15px;padding:12px 16px;font-weight:900;color:#fff;background:rgba(255,255,255,.08);box-shadow:0 10px 24px rgba(0,0,0,.18);transition:.22s ease;min-height:44px}.btn:hover{transform:translateY(-2px);box-shadow:0 17px 34px rgba(0,0,0,.27)}.btn-primary{background:linear-gradient(135deg,#06b6d4,#7c3aed);border-color:rgba(125,211,252,.35);animation:glowPulse 3.8s ease-in-out infinite}.btn-success{background:linear-gradient(135deg,#16a34a,#14b8a6)}.btn-danger{background:linear-gradient(135deg,#e11d48,#f97316)}.btn-light{background:rgba(255,255,255,.12)}.btn-ghost{background:rgba(255,255,255,.06)}.btn-small{padding:8px 11px;border-radius:12px;min-height:36px;font-size:12px}.w-100{width:100%}.flex-actions{display:flex;flex-wrap:wrap;gap:10px}.inline-form{display:flex;gap:8px;flex-wrap:wrap}
.alert{border-radius:18px;padding:14px 16px;margin:0 0 16px;border:1px solid rgba(255,255,255,.12);box-shadow:var(--shadow);animation:fadeUp .35s ease}.alert-success{background:rgba(16,185,129,.16);border-color:rgba(16,185,129,.35)}.alert-danger{background:rgba(244,63,94,.16);border-color:rgba(244,63,94,.35)}.alert-warning{background:rgba(251,191,36,.16);border-color:rgba(251,191,36,.35)}
.table-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.table-head h3{margin:0}.table-tools{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.search-input{width:min(280px,100%)}.table-wrap{width:100%;overflow:auto;border-radius:18px;border:1px solid rgba(255,255,255,.1);background:rgba(0,0,0,.11)}table{width:100%;border-collapse:separate;border-spacing:0;min-width:760px}th,td{padding:14px 13px;border-bottom:1px solid rgba(255,255,255,.08);text-align:left;vertical-align:middle}th{position:sticky;top:0;background:rgba(12,20,41,.96);color:#dff7ff;font-size:12px;text-transform:uppercase;letter-spacing:.08em;z-index:2}td{color:#eef5ff}tr:hover td{background:rgba(255,255,255,.035)}small{color:var(--muted)}.badge{display:inline-flex;align-items:center;justify-content:center;border-radius:99px;padding:7px 10px;font-size:12px;font-weight:900;border:1px solid rgba(255,255,255,.12);background:rgba(255,255,255,.09);text-transform:capitalize}.badge.success,.badge.active,.badge.approved,.badge.paid{background:rgba(34,197,94,.18);color:#86efac;border-color:rgba(34,197,94,.3)}.badge.pending,.badge.info{background:rgba(56,189,248,.18);color:#93e6ff;border-color:rgba(56,189,248,.32)}.badge.rejected,.badge.inactive,.badge.cancelled{background:rgba(244,63,94,.18);color:#fda4af;border-color:rgba(244,63,94,.32)}.muted-badge{background:rgba(148,163,184,.16);color:#cbd5e1}.formula-card{border-radius:18px;border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.055);padding:16px;margin-top:12px}.formula-card strong,.formula-card span{display:block}.formula-card span{color:var(--muted);margin-top:5px}.payment-hint{padding:14px;border-radius:16px;background:rgba(32,214,255,.09);border:1px dashed rgba(32,214,255,.28);color:#e9faff}.profile-card{display:flex;gap:18px;align-items:center}
.excel-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;margin-bottom:18px}.import-card{position:relative;overflow:hidden}.import-card:before{content:"";position:absolute;right:-55px;top:-55px;width:135px;height:135px;background:linear-gradient(135deg,rgba(32,214,255,.25),rgba(139,92,246,.25));border-radius:999px}.import-icon{width:56px;height:56px;display:grid;place-items:center;border-radius:18px;background:linear-gradient(135deg,#06b6d4,#7c3aed);font-size:27px;margin-bottom:14px}.export-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:13px}.export-tile{display:block;border-radius:20px;padding:17px;background:linear-gradient(145deg,rgba(255,255,255,.085),rgba(255,255,255,.035));border:1px solid rgba(255,255,255,.1);transition:.22s ease;min-height:130px}.export-tile:hover{transform:translateY(-4px);border-color:rgba(32,214,255,.35);box-shadow:0 18px 38px rgba(32,214,255,.13)}.export-tile span{font-size:30px}.export-tile strong{display:block;margin-top:12px}.export-tile small{display:block;margin-top:6px;line-height:1.45}.info-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:13px}.info-grid>div{padding:15px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.08)}
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.56);backdrop-filter:blur(4px);z-index:25}.sidebar-overlay.show{display:block}
@media (max-width:1280px){.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.excel-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.export-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width:980px){body.app-body{display:block}.main{padding:14px}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(88vw,320px);height:100dvh;transform:translateX(-105%);transition:.28s ease;z-index:40}.sidebar.show{transform:translateX(0)}.hamburger{display:grid;place-items:center}.topbar{top:10px;margin-bottom:16px}.top-actions{display:none}.hero,.excel-hero{flex-direction:column;align-items:flex-start}.hero-badge,.excel-badge{width:100%;height:auto;min-height:96px;border-radius:24px}.grid-2,.excel-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.export-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.info-grid{grid-template-columns:1fr}}
@media (max-width:680px){.main{padding:10px}.topbar{padding:13px;border-radius:20px;align-items:flex-start}.topbar h1{font-size:25px}.eyebrow{font-size:10px}.panel,.hero,.excel-hero{padding:16px;border-radius:20px;margin-bottom:12px}.stats-grid{grid-template-columns:1fr;gap:10px}.stat-card{min-height:auto}.form-grid{grid-template-columns:1fr}.span-2{grid-column:auto}.table-head{display:grid;align-items:stretch}.table-tools{display:grid}.search-input{width:100%}.export-grid{grid-template-columns:1fr}.filter-bar,.mini-filter{display:grid;align-items:stretch}.summary-strip{grid-template-columns:1fr}.profile-card{align-items:flex-start}.hero h2,.excel-hero h2{font-size:28px}table{min-width:0;border-spacing:0}thead{display:none}tbody,tbody tr,tbody td{display:block;width:100%}tbody tr{margin:12px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);overflow:hidden;padding:8px}tbody td{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid rgba(255,255,255,.07);padding:11px 9px;text-align:right}tbody td:last-child{border-bottom:0}tbody td:before{content:attr(data-label);font-weight:900;color:#9edcff;text-align:left;min-width:42%;padding-right:10px}.inline-form{justify-content:flex-end}.btn{width:100%}.btn-small{width:auto}.sidebar{padding:16px}.brand{padding:12px}.nav-link{min-height:44px}}
@media print{.sidebar,.topbar,.btn,.filter-bar,.search-input,.sidebar-overlay,.app-bg{display:none!important}body.app-body{display:block;background:#fff;color:#000}.main{padding:0}.glass-card,.panel,.stat-card,.hero{box-shadow:none!important;background:#fff!important;border:1px solid #ddd;color:#000}.table-wrap{border:1px solid #ccc;overflow:visible}table{min-width:100%;color:#000}thead{display:table-header-group}tbody{display:table-row-group}tr{display:table-row;background:#fff!important}th,td{display:table-cell!important;color:#000;border-color:#ccc;text-align:left}td:before{content:none!important}.badge{border:1px solid #999;color:#000;background:#fff}.muted{color:#333}}
/* Login premium */
.login-body{min-height:100dvh;display:grid;place-items:center;padding:26px;background:radial-gradient(circle at 12% 10%,rgba(32,214,255,.26),transparent 30%),radial-gradient(circle at 85% 20%,rgba(139,92,246,.32),transparent 34%),linear-gradient(135deg,#050916,#0b1024 55%,#090519);position:relative;overflow:auto}.orb{position:fixed;border-radius:999px;filter:blur(48px);opacity:.42;pointer-events:none;animation:floatOrb 11s ease-in-out infinite alternate}.orb-1{width:300px;height:300px;background:#22d3ee;left:4%;top:6%}.orb-2{width:380px;height:380px;background:#8b5cf6;right:5%;top:12%;animation-delay:2s}.orb-3{width:260px;height:260px;background:#10b981;left:45%;bottom:4%;animation-delay:4s}.login-shell{position:relative;z-index:1;width:min(1160px,100%);display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:center}.login-brand{padding:34px;color:#fff}.login-brand h1{font-size:clamp(34px,6vw,72px);line-height:.98;margin:12px 0 18px;letter-spacing:-.055em}.login-brand p{max-width:700px;color:#bfccdd;line-height:1.7}.feature-pills{display:flex;flex-wrap:wrap;gap:10px;margin-top:20px}.feature-pills span{padding:10px 13px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);font-weight:800;color:#eaf7ff}.login-card{border-radius:30px;padding:28px}.login-card h2{margin:0 0 8px;font-size:28px}.demo-box{margin-top:16px;padding:14px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.09);color:#dfe9f9}.demo-box code{color:#7dd3fc;font-weight:900}.animate-pop{animation:fadeUp .6s ease both}@media(max-width:900px){.login-shell{grid-template-columns:1fr}.login-brand{padding:8px}.login-card{padding:20px;border-radius:22px}}@media(max-width:560px){.login-body{padding:14px;place-items:start}.feature-pills span{width:100%;text-align:center}.login-brand h1{font-size:36px}.logo-badge{width:52px;height:52px}.login-card{width:100%}}
.file-hint{display:block;margin-top:2px;color:#7dd3fc;font-weight:800}.import-card form .btn{width:100%}

/* =============================================================
   UPDATE PRO: BRANDING LOGO + ROLE ACCESS CONTROL
   ============================================================= */
.logo-badge.has-logo{
  background:rgba(255,255,255,.08)!important;
  border:1px solid rgba(255,255,255,.16);
  padding:4px;
  overflow:hidden;
}
.logo-badge.has-logo .logo-img{
  width:100%;
  height:100%;
  object-fit:cover;
  border-radius:inherit;
  display:block;
}
.logo-badge.login-logo{width:82px;height:82px;border-radius:26px;font-size:26px}
.logo-badge.hero-logo{width:104px;height:104px;border-radius:30px;font-size:28px}
.logo-badge.preview{width:92px;height:92px;border-radius:28px;font-size:28px}
.brand{min-height:82px}.brand>div:last-child{min-width:0}.brand strong{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:185px}.brand small{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.35}
.hero-brand-stack{position:relative;z-index:2;display:flex;align-items:center;gap:14px;flex-wrap:wrap;justify-content:flex-end}.hero-badge.mini{width:118px;height:104px;border-radius:28px}.hero-badge.mini span{font-size:30px}
.logo-preview-box{display:flex;align-items:center;gap:16px;padding:16px;border-radius:22px;background:linear-gradient(135deg,rgba(32,214,255,.10),rgba(139,92,246,.10));border:1px solid rgba(125,211,252,.22)}
.logo-preview-box span{font-weight:900;color:#e8f8ff}.logo-preview-box small{color:var(--muted);line-height:1.45}.field-help{display:block;margin-top:6px;color:#9edcff;font-weight:700;line-height:1.45}
.role-access-form{display:block}.role-access-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;margin-bottom:18px}.role-card{padding:0;overflow:hidden}.role-card-head{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:20px 20px 16px;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(135deg,rgba(32,214,255,.12),rgba(139,92,246,.08))}.role-card-head h3{margin:0}.role-card-head span{padding:8px 12px;border-radius:999px;background:rgba(32,214,255,.13);border:1px solid rgba(125,211,252,.2);font-weight:900;color:#bff4ff;white-space:nowrap}.permission-list{display:grid;gap:10px;padding:18px}.permission-item{display:grid;grid-template-columns:auto 38px minmax(0,1fr);gap:12px;align-items:center;padding:13px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);transition:.2s ease}.permission-item:hover{transform:translateY(-2px);border-color:rgba(32,214,255,.32);background:rgba(32,214,255,.08)}.permission-item input{width:18px;height:18px;accent-color:#22d3ee}.permission-item>span{display:grid;place-items:center;width:38px;height:38px;border-radius:14px;background:linear-gradient(135deg,rgba(14,165,233,.25),rgba(124,58,237,.25));border:1px solid rgba(255,255,255,.1)}.permission-item strong{display:block;color:#fff}.permission-item small{display:block;color:var(--muted);margin-top:4px;line-height:1.35}.permission-item.is-fixed{opacity:.78;background:rgba(255,255,255,.035)}.permission-item.is-fixed small:after{content:' · wajib aktif';color:#7dd3fc;font-weight:900}.info-grid.single{grid-template-columns:1fr;margin-top:18px}.flex-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.alert{position:relative;overflow:hidden}.alert:before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:currentColor;opacity:.65}.alert-success{background:rgba(16,185,129,.13);border-color:rgba(16,185,129,.28)}.alert-danger{background:rgba(244,63,94,.13);border-color:rgba(244,63,94,.28)}
@media (max-width:980px){.role-access-grid{grid-template-columns:1fr}.brand strong{max-width:210px}.hero-brand-stack{justify-content:flex-start}.logo-preview-box{align-items:flex-start}}
@media (max-width:680px){.logo-preview-box{display:grid}.permission-item{grid-template-columns:auto 34px minmax(0,1fr);padding:11px}.role-card-head{display:grid}.hero-brand-stack{width:100%}.logo-badge.hero-logo{width:84px;height:84px}.hero-badge.mini{width:100%;height:auto;min-height:84px}.flex-actions .btn{width:100%}}

/* =============================================================
   UPDATE PRO: MENU PEMBAYARAN / ANGSURAN PINJAMAN
   ============================================================= */
.payment-hero{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(280px,.75fr);gap:22px;align-items:stretch;border-radius:30px;padding:28px;margin-bottom:22px;overflow:hidden;position:relative}
.payment-hero:after{content:"";position:absolute;right:-90px;top:-90px;width:270px;height:270px;border-radius:999px;background:radial-gradient(circle,rgba(32,214,255,.26),transparent 68%);pointer-events:none}
.payment-hero h2{font-size:clamp(28px,4.2vw,54px);line-height:1.02;margin:0 0 12px;letter-spacing:-.04em}.payment-hero p{color:var(--muted);line-height:1.7;max-width:860px}.payment-kpi{position:relative;z-index:1;display:grid;gap:12px}.payment-kpi>div{padding:17px;border-radius:22px;background:linear-gradient(135deg,rgba(32,214,255,.14),rgba(139,92,246,.10));border:1px solid rgba(125,211,252,.2)}.payment-kpi span{display:block;color:#9edcff;font-weight:900;text-transform:uppercase;font-size:11px;letter-spacing:.12em}.payment-kpi strong{display:block;margin-top:6px;font-size:clamp(20px,2vw,28px);letter-spacing:-.02em}.payment-form-card{position:relative;overflow:hidden}.payment-form-card:before{content:"";position:absolute;inset:0 0 auto 0;height:5px;background:linear-gradient(90deg,#22d3ee,#8b5cf6,#20e29a)}.payment-hint.pro{padding:14px 16px;border-radius:18px;background:linear-gradient(135deg,rgba(32,214,255,.12),rgba(16,185,129,.10));border:1px solid rgba(125,211,252,.22);color:#dff8ff;line-height:1.55}.payment-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(145px,1fr));gap:10px}.payment-preview>div{padding:14px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.1)}.payment-preview span{display:block;color:var(--muted);font-size:12px;font-weight:800}.payment-preview strong{display:block;margin-top:5px;color:#fff;font-size:18px}.active-loan-list{display:grid;gap:10px;max-height:520px;overflow:auto;padding-right:2px}.loan-mini-card{display:grid;grid-template-columns:54px minmax(0,1fr);gap:12px;align-items:center;padding:13px;border-radius:18px;background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.09);transition:.22s ease}.loan-mini-card:hover{transform:translateY(-2px);background:rgba(32,214,255,.08);border-color:rgba(32,214,255,.28)}.loan-mini-card>span{display:grid;place-items:center;min-height:42px;border-radius:14px;background:linear-gradient(135deg,rgba(34,211,238,.24),rgba(139,92,246,.22));border:1px solid rgba(255,255,255,.1);font-weight:900;color:#bff4ff}.loan-mini-card strong{display:block;color:#fff;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loan-mini-card small{display:block;color:var(--muted);margin-top:4px;line-height:1.45}.hero-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:18px}
@media(max-width:980px){.payment-hero{grid-template-columns:1fr}.payment-preview{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:680px){.payment-hero{padding:16px;border-radius:20px}.payment-preview{grid-template-columns:1fr}.loan-mini-card{grid-template-columns:46px minmax(0,1fr)}.payment-kpi strong{font-size:22px}}


/* =============================================================
   UPDATE PRO: LOGO AKUN PER USERNAME
   ============================================================= */
.avatar.account-logo{overflow:hidden;text-transform:uppercase;letter-spacing:.02em}
.avatar.account-logo.has-logo{background:rgba(255,255,255,.08)!important;border:1px solid rgba(255,255,255,.16);padding:3px}
.avatar.account-logo .avatar-img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.user-mini .avatar.account-logo{width:44px;height:44px;border-radius:15px}
.table-wrap .avatar.account-logo{width:42px;height:42px;border-radius:14px;font-size:13px}
.account-logo-preview{display:flex;align-items:center;gap:16px;padding:15px;border-radius:22px;background:linear-gradient(135deg,rgba(32,214,255,.10),rgba(139,92,246,.10));border:1px solid rgba(125,211,252,.2)}
.account-logo-preview strong{display:block;color:#fff}.account-logo-preview small{display:block;margin-top:4px;word-break:break-word}.mt-10{margin-top:10px}
.profile-card .avatar.account-logo.big{width:96px;height:96px;border-radius:30px;font-size:34px;box-shadow:0 22px 60px rgba(32,214,255,.22)}
@media(max-width:680px){.account-logo-preview{display:grid}.profile-card{display:grid}.profile-card .avatar.account-logo.big{width:84px;height:84px}}
#paymentTable{min-width:1180px}
