:root{--bg:#f4f8fb;--card:#fff;--text:#0f172a;--muted:#64748b;--primary:#0f766e;--primary-dark:#115e59;--blue:#2563eb;--amber:#d97706;--emerald:#059669;--slate:#475569;--danger:#dc2626;--border:#dbe7e5;--shadow:0 16px 40px rgba(15,23,42,.08);--radius:20px}
*{box-sizing:border-box}body{margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;background:var(--bg);color:var(--text)}a{text-decoration:none;color:inherit}
.km-app{display:flex;min-height:100vh}.km-sidebar{width:280px;background:linear-gradient(180deg,#064e3b,#0f766e);color:#ecfdf5;padding:20px;position:fixed;inset:0 auto 0 0;overflow-y:auto;z-index:20}
.km-brand{display:flex;gap:12px;align-items:center;padding:8px 6px 20px;border-bottom:1px solid rgba(255,255,255,.16);margin-bottom:14px}.brand-icon{width:44px;height:44px;border-radius:16px;background:rgba(255,255,255,.14);display:grid;place-items:center}.km-brand strong{display:block;font-size:16px}.km-brand span{font-size:12px;color:#bbf7d0}
.km-menu{display:flex;flex-direction:column;gap:5px}.km-menu a{display:flex;gap:10px;align-items:center;padding:10px 12px;border-radius:14px;color:#dcfce7;font-size:14px}.km-menu a:hover,.km-menu a.active{background:rgba(255,255,255,.13)}.menu-label{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#a7f3d0;margin:16px 12px 6px}.icon{width:19px;height:19px;flex:0 0 auto}
.km-main{margin-left:280px;width:calc(100% - 280px)}.km-topbar{min-height:84px;background:#fff;display:flex;align-items:center;justify-content:space-between;padding:16px 28px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.km-topbar h1{font-size:22px;margin:0}.km-topbar p{margin:3px 0 0;color:var(--muted);font-size:13px}
.topbar-user{display:flex;align-items:center;gap:10px}.avatar{width:42px;height:42px;border-radius:50%;background:#ccfbf1;color:#115e59;font-weight:800;display:grid;place-items:center;overflow:hidden}.avatar img{width:100%;height:100%;object-fit:cover}.user-info strong{display:block;font-size:14px}.user-info span{font-size:12px;color:var(--muted)}
.km-content{padding:26px}.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;margin-bottom:22px}.card-header{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:16px}.card-header h3{margin:0;font-size:17px}.card-header span{color:var(--muted);font-size:13px}
.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px;margin-bottom:22px}.stat-card{padding:20px;border-radius:22px;color:#fff;box-shadow:var(--shadow)}.stat-card span,.stat-card small{display:block;opacity:.88}.stat-card strong{display:block;font-size:26px;margin:8px 0}.stat-card.emerald{background:linear-gradient(135deg,#059669,#0f766e)}.stat-card.blue{background:linear-gradient(135deg,#2563eb,#0ea5e9)}.stat-card.amber{background:linear-gradient(135deg,#d97706,#f59e0b)}.stat-card.slate{background:linear-gradient(135deg,#475569,#0f172a)}
.grid-2{display:grid;grid-template-columns:1.5fr 1fr;gap:22px}.role-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}.table-responsive{overflow-x:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid #e5edf0;text-align:left;font-size:14px;vertical-align:top}th{font-size:12px;text-transform:uppercase;letter-spacing:.04em;color:#64748b;background:#f8fafc}.text-right{text-align:right}.empty{text-align:center;color:var(--muted);padding:24px}
.badge{display:inline-flex;align-items:center;padding:5px 9px;border-radius:999px;font-size:12px;font-weight:700}.badge.success{background:#dcfce7;color:#166534}.badge.warning{background:#fef3c7;color:#92400e}.badge.muted{background:#e2e8f0;color:#475569}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;border:0;border-radius:12px;padding:10px 14px;font-weight:700;cursor:pointer;font-size:14px}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-light{background:#f1f5f9;color:#0f172a}.btn-danger{background:#fee2e2;color:#991b1b}.btn-small{padding:7px 10px;font-size:12px;border-radius:10px}.full{width:100%}
.page-actions{display:flex;justify-content:flex-end;gap:10px;margin-bottom:16px;flex-wrap:wrap}.actions{display:flex;justify-content:flex-end;gap:8px;flex-wrap:wrap}.actions form{display:inline-flex}form label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;color:#334155}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:12px;padding:11px 12px;font:inherit;background:#fff;color:#0f172a}textarea{resize:vertical}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.form-grid.one{grid-template-columns:1fr}.form-grid .full{grid-column:1/-1}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.filter-bar{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;margin-bottom:16px;align-items:end}.filter-bar input[type=text]{grid-column:span 2}.alert{padding:13px 15px;border-radius:14px;margin-bottom:18px;font-weight:600}.alert.success{background:#dcfce7;color:#166534}.alert.danger{background:#fee2e2;color:#991b1b}
.detail-list{display:grid;grid-template-columns:180px 1fr;gap:10px;margin:0}.detail-list dt{font-weight:800;color:#475569}.detail-list dd{margin:0}.permission-group{border:1px solid #e2e8f0;border-radius:14px;padding:12px;margin-bottom:12px}.permission-group strong{display:block;margin-bottom:8px}.check-row{display:flex;gap:8px;align-items:center;margin:7px 0}.check-row input{width:auto}.muted-text{color:var(--muted)}
.icon-button{border:0;background:#f1f5f9;border-radius:12px;width:42px;height:42px;display:grid;place-items:center}.mobile-only{display:none}.pagination{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px}.pagination a,.pagination span{padding:8px 11px;background:#f8fafc;border-radius:10px}
.login-page{
    min-height:100vh;
    background:
        linear-gradient(110deg, rgba(6,78,59,.86) 0%, rgba(15,118,110,.72) 42%, rgba(20,184,166,.48) 100%),
        var(--login-bg, url("images/login-bg-masjid.jpg")),
        radial-gradient(circle at top left,#064e3b,#0f766e 45%,#ecfeff);
    background-size:cover;
    background-position:center;
    background-repeat:no-repeat;
    background-attachment:fixed;
    display:grid;
    place-items:center;
    padding:24px;
}.login-shell{width:min(1050px,100%);display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:center}.login-hero{padding:34px}.login-hero h1{font-size:44px;line-height:1.05;margin:18px 0}.login-hero p{font-size:18px;color:#475569}.hero-badge{display:inline-flex;align-items:center;gap:9px;background:#fff;border:1px solid var(--border);border-radius:999px;padding:10px 14px;color:var(--primary);font-weight:800}.login-points{display:flex;gap:10px;flex-wrap:wrap;margin-top:20px}.login-points span{background:#fff;border:1px solid var(--border);border-radius:999px;padding:9px 13px}.login-card{background:#fff;border-radius:26px;padding:28px;box-shadow:var(--shadow);border:1px solid var(--border)}.login-card h2{margin-top:0}.login-card p,.demo-info{color:var(--muted)}.login-card form{display:grid;gap:12px}.demo-info{margin-top:14px;font-size:13px}
@media(max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.role-grid{grid-template-columns:1fr}.filter-bar{grid-template-columns:repeat(2,1fr)}.filter-bar input[type=text]{grid-column:span 2}}
@media(max-width:820px){.mobile-only{display:grid}.km-sidebar{transform:translateX(-105%);transition:.2s ease}.km-sidebar.open{transform:translateX(0)}.km-overlay.show{position:fixed;inset:0;background:rgba(15,23,42,.35);z-index:15}.km-main{margin-left:0;width:100%}.km-topbar{height:auto;padding:16px;align-items:flex-start}.topbar-user{gap:6px}.user-info{display:none}.km-content{padding:16px}.stats-grid{grid-template-columns:1fr}.form-grid{grid-template-columns:1fr}.form-grid .full{grid-column:auto}.filter-bar{grid-template-columns:1fr}.filter-bar input[type=text]{grid-column:auto}.login-shell{grid-template-columns:1fr}.login-hero{padding:10px}.login-hero h1{font-size:32px}.detail-list{grid-template-columns:1fr}.actions{justify-content:flex-start}}
@media print{.km-sidebar,.km-topbar,.page-actions,.filter-bar,.btn{display:none!important}.km-main{margin:0;width:100%}.km-content{padding:0}.card{box-shadow:none;border:0}}
/* Login background masjid - green overlay refinement */
.login-hero h1{
    color:#ffffff;
    text-shadow:0 4px 22px rgba(0,0,0,.32);
}
.login-hero p{
    color:#ecfdf5;
    text-shadow:0 2px 12px rgba(0,0,0,.28);
}
.login-points span{
    background:rgba(255,255,255,.16);
    border-color:rgba(255,255,255,.34);
    color:#ffffff;
    backdrop-filter:blur(8px);
}
.hero-badge{
    background:rgba(255,255,255,.18);
    border-color:rgba(255,255,255,.34);
    color:#ffffff;
    backdrop-filter:blur(8px);
}
.login-card{
    background:rgba(255,255,255,.94);
    backdrop-filter:blur(12px);
}
.login-card h2{
    color:#064e3b;
}
/* Copyright Ifti Media Computindo */
.km-main{display:flex;flex-direction:column;min-height:100vh}
.km-content{flex:1}
.km-footer{
    margin:0 26px 20px;
    padding:14px 18px;
    border:1px solid var(--border);
    border-radius:16px;
    background:rgba(255,255,255,.86);
    color:#64748b;
    text-align:center;
    font-size:13px;
    box-shadow:0 10px 28px rgba(15,23,42,.05);
}
.login-page{position:relative}
.login-copyright{
    position:fixed;
    left:50%;
    bottom:16px;
    transform:translateX(-50%);
    z-index:5;
    padding:8px 14px;
    border-radius:999px;
    background:rgba(6,78,59,.72);
    border:1px solid rgba(255,255,255,.24);
    color:#ecfdf5;
    backdrop-filter:blur(8px);
    box-shadow:0 10px 24px rgba(6,78,59,.18);
    font-size:12px;
    font-weight:700;
    letter-spacing:.01em;
    text-align:center;
    white-space:nowrap;
}
@media(max-width:820px){
    .km-footer{margin:0 16px 16px;font-size:12px}
    .login-copyright{bottom:10px;max-width:calc(100% - 28px);white-space:normal}
}
@media print{
    .km-footer,.login-copyright{display:none!important}
}


/* Menu dropdown modern */
.brand-logo{width:100%;height:100%;object-fit:cover;border-radius:14px}
.km-menu-group{display:flex;flex-direction:column;gap:5px}
.km-menu-toggle{width:100%;display:flex;gap:10px;align-items:center;padding:10px 12px;border:0;border-radius:14px;background:transparent;color:#dcfce7;font:inherit;font-size:14px;cursor:pointer;text-align:left}
.km-menu-toggle:hover,.km-menu-group.open>.km-menu-toggle{background:rgba(255,255,255,.13)}
.km-menu-toggle span:nth-child(2){flex:1}
.menu-caret{margin-left:auto;font-weight:900;transition:.2s ease;line-height:1}
.km-menu-group.open .menu-caret{transform:rotate(180deg)}
.km-submenu{display:none;margin-left:9px;padding-left:10px;border-left:1px solid rgba(255,255,255,.18)}
.km-menu-group.open .km-submenu{display:flex;flex-direction:column;gap:5px}
.km-submenu a{padding:9px 10px;font-size:13px}
.logo-setting-row{display:flex;gap:14px;align-items:center}
.logo-preview{width:74px;height:74px;border-radius:20px;background:#ecfdf5;border:1px solid var(--border);display:grid;place-items:center;overflow:hidden;color:var(--primary)}
.logo-preview img{width:100%;height:100%;object-fit:cover}
.logo-setting-input{flex:1}
.km-footer{padding:18px 26px;color:#64748b;font-size:12px;text-align:center}
.trial-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:16px;padding:12px 14px;margin-bottom:18px}
.trial-banner strong{display:block;color:#7c2d12}.trial-banner span{font-size:13px}
@media(max-width:820px){.logo-setting-row{align-items:flex-start}.trial-banner{align-items:flex-start;flex-direction:column}}


/* Final display control + settings UI */
.display-control-card{margin:8px 0 4px;padding:10px;border:1px solid rgba(255,255,255,.16);border-radius:16px;background:rgba(255,255,255,.08)}
.display-control-link{display:flex!important;padding:8px!important;border-radius:12px!important}
.display-control-badge{display:inline-flex;margin:6px 0 8px;padding:4px 9px;border-radius:999px;font-size:11px;font-weight:800;background:#dcfce7;color:#166534}
.display-control-card.is-off .display-control-badge{background:#fee2e2;color:#991b1b}
.display-control-toggle{width:100%;border:0;border-radius:10px;padding:8px 10px;background:#ecfdf5;color:#064e3b;font-weight:900;cursor:pointer}
.display-control-card.is-off .display-control-toggle{background:#fef3c7;color:#92400e}
.brand-logo{width:100%;height:100%;object-fit:cover;border-radius:16px}
.logo-setting-row{display:flex;gap:14px;align-items:center;border:1px solid #e2e8f0;border-radius:16px;padding:12px;background:#f8fafc}
.logo-preview{width:72px;height:72px;border-radius:18px;background:#ecfdf5;color:#0f766e;display:grid;place-items:center;overflow:hidden;flex:0 0 auto}
.logo-preview img{width:100%;height:100%;object-fit:cover}
.logo-setting-input{flex:1}
.setting-box{border:1px solid #e2e8f0;border-radius:18px;padding:16px;background:#f8fafc}
.setting-box h4{margin:0 0 6px;font-size:16px}
.switch-row{display:flex!important;align-items:center;gap:10px;margin:10px 0 14px;font-weight:800;color:#0f172a}
.switch-row input{width:auto;transform:scale(1.15)}
.km-menu-group{display:block}
.km-menu-toggle{width:100%;border:0;background:transparent;color:#dcfce7;display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:14px;font-size:14px;font-weight:700;cursor:pointer;text-align:left}
.km-menu-toggle:hover,.km-menu-group.open>.km-menu-toggle{background:rgba(255,255,255,.13)}
.km-menu-toggle .menu-caret{margin-left:auto;transition:.2s ease}
.km-menu-group.open .menu-caret{transform:rotate(180deg)}
.km-submenu{display:none;margin:4px 0 6px 12px;padding-left:8px;border-left:1px solid rgba(255,255,255,.14)}
.km-menu-group.open .km-submenu{display:flex;flex-direction:column;gap:4px}
.km-submenu a{padding:9px 10px!important;font-size:13px!important}
@media(max-width:820px){.logo-setting-row{align-items:flex-start}.display-control-card{margin-right:0}}


.package-badge{display:inline-flex;align-items:center;border-radius:999px;background:#ecfdf5;color:#047857;border:1px solid #bbf7d0;padding:5px 9px;font-size:11px;font-weight:800}
