/* =====================================================================
   Madam's Aesthetic Clinic — app.css  (tema sesuai logo)
   Identitas: espresso gelap + emas, aksen cincin gradien neon.
   Font: Poppins (judul/brand) · Plus Jakarta Sans (body)
   ===================================================================== */
:root{
  --espresso:#211712;        /* badge logo - sidebar & navbar */
  --espresso-2:#2E2119;
  --gold:#C9A24B;
  --gold-soft:#E4C77A;
  --gold-deep:#A07B2C;
  --cream:#FBF8F3;
  --paper:#FFFFFF;
  --ink:#2A2520;
  --muted:#8C8077;
  --line:#ECE4DA;
  --ring:linear-gradient(90deg,#E5409B 0%,#9B3BB0 30%,#F5923B 68%,#E9C45A 100%);
  --sidebar-w:252px;
  --navbar-h:62px;
}
*{box-sizing:border-box}
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  background:var(--cream);color:var(--ink);margin:0;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,.km-brand,.modal-title{font-family:'Poppins',sans-serif}

/* ---------------- NAVBAR ---------------- */
.km-navbar{
  height:var(--navbar-h);background:var(--espresso);
  display:flex;align-items:center;justify-content:space-between;padding:0 18px;left:0;right:0;
  box-shadow:0 2px 14px rgba(33,23,18,.25);z-index:1040;border-bottom:1px solid rgba(201,162,75,.18);
}
.km-navbar::before{content:"";position:fixed;top:0;left:0;right:0;height:3px;background:var(--ring);z-index:1041}
.km-brand{font-weight:700;font-size:1.12rem;color:var(--gold-soft);letter-spacing:1px}
.km-brand span{font-weight:500;opacity:.7;font-size:.9rem;color:#EBDFCB}
.km-avatar{width:33px;height:33px;border-radius:50%;background:var(--ring);color:#fff;font-weight:700;
  display:inline-flex;align-items:center;justify-content:center;font-size:.85rem}
.km-role-badge{display:block;font-size:.66rem;line-height:1;opacity:.7;text-transform:capitalize;margin-top:2px;color:var(--gold-soft)}
.km-navbar .text-white{color:#F1E8DA!important}
.km-navbar .dropdown-toggle::after{margin-left:8px}

/* ---------------- SIDEBAR ---------------- */
.km-sidebar{
  position:fixed;top:var(--navbar-h);left:0;bottom:0;width:var(--sidebar-w);
  background:var(--espresso);border-right:1px solid rgba(201,162,75,.12);
  display:flex;flex-direction:column;z-index:1035;transition:transform .25s ease;
}
.km-sidebar-head{display:flex;align-items:center;gap:11px;padding:16px 18px 14px;border-bottom:1px solid rgba(201,162,75,.12)}
.km-logo-img{width:46px;height:46px;border-radius:12px;background:#fff;padding:3px;object-fit:contain;box-shadow:0 0 0 2px rgba(201,162,75,.4)}
.km-logo-text strong{display:block;color:var(--gold-soft);letter-spacing:1.5px;font-size:.92rem;font-family:'Poppins'}
.km-logo-text span{font-size:.66rem;color:#B9AC99;letter-spacing:1px}

.km-menu{list-style:none;margin:0;padding:10px 0;flex:1;overflow-y:auto}
.km-menu-label{font-size:.66rem;text-transform:uppercase;letter-spacing:1.2px;color:#86796B;padding:14px 20px 6px;font-weight:600}
.km-menu a{display:flex;align-items:center;gap:12px;padding:11px 20px;color:#E7DCCB;text-decoration:none;
  font-size:.88rem;border-left:3px solid transparent;transition:.15s}
.km-menu a i{width:18px;text-align:center;color:#9A8C79}
.km-menu a:hover{background:rgba(201,162,75,.10);color:#fff}
.km-menu a.active{background:linear-gradient(90deg,rgba(201,162,75,.18),transparent);border-left-color:var(--gold);color:var(--gold-soft);font-weight:600}
.km-menu a.active i{color:var(--gold)}
.km-menu a.km-soon{opacity:.45;cursor:default}
.km-menu a.km-soon small{margin-left:auto;font-size:.58rem;background:rgba(255,255,255,.08);padding:2px 7px;border-radius:20px;color:#B9AC99}
.km-sidebar-foot{padding:13px 20px;border-top:1px solid rgba(201,162,75,.12)}
.km-sidebar-foot a{color:var(--gold-soft);text-decoration:none;font-size:.84rem;font-weight:500}
.km-sidebar-foot a i{margin-right:8px}
.km-sidebar-overlay{display:none}

/* ---------------- KONTEN ---------------- */
.content{margin-left:var(--sidebar-w);padding:calc(var(--navbar-h) + 22px) 26px 40px}
.block-header .breadcrumb{background:transparent;padding:0;margin:0 0 18px}
.breadcrumb-bg-red li{font-weight:600;color:var(--gold-deep);letter-spacing:.6px;font-size:.74rem;text-transform:uppercase}

/* ---------------- DASHBOARD ---------------- */
.km-welcome h2{color:var(--espresso);margin-bottom:4px;font-weight:700}
.km-welcome p{color:var(--muted);margin-bottom:22px}
.km-card{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px;height:100%;position:relative;transition:.2s;overflow:hidden}
.km-card::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--ring);opacity:0;transition:.2s}
.km-card:hover{box-shadow:0 10px 28px rgba(33,23,18,.10);transform:translateY(-3px)}
.km-card:hover::before{opacity:1}
.km-card i{font-size:1.5rem;color:var(--gold-deep);margin-bottom:12px}
.km-card.done i{color:var(--espresso)}
.km-card h4{font-size:1rem;font-weight:600;margin-bottom:6px}
.km-card p{font-size:.82rem;color:var(--muted);margin:0}
.km-tag{position:absolute;top:18px;right:18px;font-size:.64rem;font-weight:700;padding:3px 10px;border-radius:20px;background:#E7F3EC;color:#2E7D52}
.km-tag.soon{background:#FBEFD9;color:var(--gold-deep)}

/* ---------------- PANEL & TABEL ---------------- */
.km-panel{background:var(--paper);border:1px solid var(--line);border-radius:16px;padding:22px}
.km-panel-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;flex-wrap:wrap;margin-bottom:18px}
.km-panel-head h3{color:var(--espresso);font-size:1.25rem;margin:0;font-weight:700}
.km-panel-head p{color:var(--muted);font-size:.83rem;margin:2px 0 0}

.km-btn-primary{border:0;border-radius:10px;padding:9px 16px;font-size:.85rem;font-weight:600;cursor:pointer;
  background:linear-gradient(90deg,var(--gold-soft),var(--gold));color:#3A2A12;box-shadow:0 2px 8px rgba(201,162,75,.3)}
.km-btn-primary:hover{filter:brightness(1.05);color:#3A2A12}
.km-btn-primary i{margin-right:6px}
.btn-light{border-radius:10px}

.km-table{width:100%;border-collapse:collapse;font-size:.86rem}
.km-table thead th{text-align:left;padding:11px 12px;border-bottom:2px solid var(--line);color:var(--muted);
  font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap}
.km-table tbody td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.km-table tbody tr:hover{background:var(--cream)}
.text-right{text-align:right}.text-muted{color:var(--muted)}
.km-empty{text-align:center;color:var(--muted);padding:24px;font-size:.88rem}

.km-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:capitalize}
.km-badge.ok{background:#E7F3EC;color:#2E7D52}
.km-badge.off{background:#F3E6E6;color:#9B2C2C}
.km-badge.role-owner{background:var(--espresso);color:var(--gold-soft)}
.km-badge.role-admin{background:var(--gold-deep);color:#fff}
.km-badge.role-kasir{background:#E8DCC9;color:#7A5A1F}
.km-badge.role-dokter{background:#D9E6F2;color:#1F4E7A}
.km-badge.role-terapis{background:#EFD9EC;color:#8E2E7A}
.km-badge.role-staff{background:var(--line);color:var(--muted)}
.km-badge.gender-L{background:#E1ECF7;color:#1F4E7A}
.km-badge.gender-P{background:#F7E1EE;color:#9B2C6A}
.km-badge.rm{background:#FBEFD9;color:var(--gold-deep);font-family:'Plus Jakarta Sans';letter-spacing:.4px}

.km-actions{white-space:nowrap}
.km-ico{display:inline-flex;align-items:center;justify-content:center;width:31px;height:31px;border:0;border-radius:9px;
  background:var(--cream);color:var(--muted);cursor:pointer;margin-left:3px;font-size:.78rem;text-decoration:none;transition:.15s}
.km-ico:hover{filter:brightness(.96)}
.km-ico.edit:hover{background:#D9E6F2;color:#1F4E7A}
.km-ico.key:hover{background:#FBEFD9;color:var(--gold-deep)}
.km-ico.off:hover,.km-ico.del:hover{background:#F3E6E6;color:#9B2C2C}
.km-ico.on:hover{background:#E7F3EC;color:#2E7D52}
.km-ico.view:hover{background:#EFD9EC;color:#8E2E7A}

.modal-title{color:var(--espresso)}
.modal-body label{font-size:.78rem;font-weight:600}
.modal-content{border:0;border-radius:14px;overflow:hidden}
.modal-header{border-bottom:1px solid var(--line)}
.form-control:focus{border-color:var(--gold);box-shadow:0 0 0 .2rem rgba(201,162,75,.18)}

/* ---------------- DATATABLES penyesuaian ---------------- */
.dataTables_wrapper .dataTables_filter input,
.dataTables_wrapper .dataTables_length select{border:1px solid var(--line);border-radius:8px;padding:5px 10px}
.dataTables_wrapper .dataTables_filter input:focus{border-color:var(--gold);outline:0}
table.dataTable thead th{border-bottom:2px solid var(--line)!important}
.page-item.active .page-link{background:var(--gold)!important;border-color:var(--gold)!important;color:#3A2A12!important}
.page-link{color:var(--gold-deep)}
.dataTables_wrapper .dataTables_paginate .paginate_button{border-radius:8px}

/* ---------------- LOGIN ---------------- */
.km-login{display:flex;min-height:100vh}
.km-login-brand{flex:1;background:radial-gradient(circle at 30% 20%,#2E2119,#160F0C);
  display:flex;align-items:center;justify-content:center;color:#fff;position:relative;overflow:hidden}
.km-login-brand::after{content:"";position:absolute;width:460px;height:460px;border-radius:50%;
  background:var(--ring);filter:blur(90px);opacity:.22;right:-150px;bottom:-150px}
.km-login-brand-inner{text-align:center;z-index:1;padding:34px}
.km-logo-ring{width:148px;height:148px;border-radius:50%;margin:0 auto 22px;padding:6px;background:var(--ring);
  display:flex;align-items:center;justify-content:center;box-shadow:0 8px 30px rgba(0,0,0,.4)}
.km-logo-ring img{width:100%;height:100%;border-radius:50%;background:#fff;object-fit:contain;padding:6px}
.km-login-brand h1{font-size:2rem;margin:0;font-weight:700;letter-spacing:1px;color:var(--gold-soft)}
.km-script{font-size:.95rem;color:#CDBFA9;margin:2px 0 0;letter-spacing:2px;text-transform:uppercase}
.km-rule{display:block;width:60px;height:3px;border-radius:3px;background:var(--ring);margin:18px auto}
.km-clinic-info{font-size:.78rem;color:#B6A892;line-height:1.6;max-width:300px;margin:0 auto}
.km-clinic-info a{color:var(--gold-soft);text-decoration:none}
.km-clinic-info i{color:var(--gold);width:16px}

.km-login-form{flex:1;display:flex;align-items:center;justify-content:center;background:var(--cream);padding:30px}
.km-login-card{width:100%;max-width:360px}
.km-login-card h2{color:var(--espresso);font-size:1.55rem;margin-bottom:4px;font-weight:700}
.km-sub{color:var(--muted);font-size:.85rem;margin-bottom:22px}
.km-field{margin-bottom:16px}
.km-field label{font-size:.78rem;font-weight:600;color:var(--ink);display:block;margin-bottom:6px}
.km-input{display:flex;align-items:center;background:#fff;border:1px solid var(--line);border-radius:11px;padding:0 12px;transition:.15s}
.km-input:focus-within{border-color:var(--gold);box-shadow:0 0 0 3px rgba(201,162,75,.16)}
.km-input i{color:var(--muted);font-size:.85rem}
.km-input input{border:0;outline:0;flex:1;padding:12px 10px;font-size:.9rem;background:transparent;color:var(--ink)}
.km-eye{background:0;border:0;color:var(--muted);cursor:pointer;padding:4px}
.km-btn-login{width:100%;border:0;border-radius:11px;padding:13px;margin-top:6px;font-weight:700;font-size:.95rem;cursor:pointer;
  background:linear-gradient(90deg,var(--gold-soft),var(--gold));color:#3A2A12;transition:.2s;box-shadow:0 4px 14px rgba(201,162,75,.35)}
.km-btn-login:hover{filter:brightness(1.06)}
.km-hint{text-align:center;font-size:.76rem;color:var(--muted);margin-top:18px}

/* ---------------- RESPONSIVE ---------------- */
@media (max-width: 991.98px){
  .km-sidebar{transform:translateX(-100%)}
  .km-sidebar.show{transform:translateX(0)}
  .content{margin-left:0}
  .km-sidebar-overlay.show{display:block;position:fixed;inset:var(--navbar-h) 0 0 0;background:rgba(22,15,12,.5);z-index:1030}
}
@media (max-width: 767.98px){.km-login-brand{display:none}}

/* ── Select2 brand override ───────────────────────────────────────── */
.select2-container--bootstrap4 .select2-selection--single{
  height:38px!important;border-color:var(--line);border-radius:8px!important;
}
.select2-container--bootstrap4 .select2-selection--single .select2-selection__rendered{
  line-height:36px!important;padding-left:10px;font-size:.87rem;color:var(--ink);
}
.select2-container--bootstrap4 .select2-selection--single .select2-selection__arrow{top:5px!important}
.select2-container--bootstrap4 .select2-results__option--highlighted{
  background:var(--espresso)!important;color:var(--gold-soft)!important;
}
.select2-container--bootstrap4 .select2-search__field:focus{
  border-color:var(--gold)!important;box-shadow:0 0 0 .15rem rgba(201,162,75,.2)!important;
}
.select2-container--bootstrap4.select2-container--focus .select2-selection--single{
  border-color:var(--gold)!important;box-shadow:0 0 0 .15rem rgba(201,162,75,.2)!important;
}
.select2-container--bootstrap4 .select2-selection--single.form-control-sm{height:31px!important}
.select2-container--bootstrap4 .select2-selection--single.form-control-sm .select2-selection__rendered{line-height:29px!important}
