/* ============================================================
   UniERP — Professional UI Design System
   Aesthetic: Refined Enterprise | Clean & Sophisticated
   Fonts: DM Sans (body) + Fraunces (display)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Fraunces:ital,wght@0,600;0,700;1,500&display=swap');

/* ── CSS Variables ── */
:root {
  --primary:        #1C3557;
  --primary-light:  #2A4A73;
  --primary-pale:   #EBF0F8;
  --accent:         #E07B39;
  --accent-light:   #FFF2EA;
  --success:        #2D7D52;
  --success-light:  #E8F5EE;
  --danger:         #C0392B;
  --danger-light:   #FDECEA;
  --warning:        #B7860B;
  --warning-light:  #FEF9E7;
  --info:           #1A6B8A;
  --info-light:     #E8F4F8;

  --sidebar-w:      258px;
  --sidebar-w-col:  70px;
  --topbar-h:       62px;

  --bg:             #F6F7FB;
  --surface:        #FFFFFF;
  --surface-2:      #F4F5F9;
  --border:         #E4E8F0;
  --border-light:   #F0F2F8;

  --text-primary:   #1A2332;
  --text-secondary: #5A6A80;
  --text-muted:     #8A98AA;

  --radius-sm:   6px;
  --radius:      10px;
  --radius-lg:   16px;
  --radius-xl:   24px;

  --shadow-xs:  0 1px 3px rgba(0,0,0,.06);
  --shadow-sm:  0 2px 8px rgba(0,0,0,.08);
  --shadow:     0 4px 16px rgba(0,0,0,.10);
  --shadow-lg:  0 8px 32px rgba(0,0,0,.12);
  --shadow-pri: 0 4px 16px rgba(28,53,87,.25);

  --ease: cubic-bezier(.4,0,.2,1);
  --tr:   all .2s cubic-bezier(.4,0,.2,1);
  --tr-s: all .35s cubic-bezier(.4,0,.2,1);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:'DM Sans',sans-serif;
  font-size:14px;font-weight:400;line-height:1.6;
  color:var(--text-primary);background:var(--bg);
  overflow-x:hidden;-webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,h5,h6{
  font-family:'Fraunces',serif;font-weight:600;line-height:1.3;
  color:var(--text-primary);margin-bottom:.5rem;
}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:none}

/* ─── SIDEBAR ─── */
.sidebar{
  position:fixed;top:0;left:0;
  width:var(--sidebar-w);height:100vh;
  background:var(--primary);
  display:flex;flex-direction:column;
  z-index:1040;transition:var(--tr-s);overflow:hidden;
}

.sidebar-brand{
  display:flex;align-items:center;gap:12px;
  padding:18px 18px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
  flex-shrink:0;text-decoration:none!important;
}
.brand-icon{
  width:36px;height:36px;
  background:var(--accent);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
  box-shadow:0 2px 8px rgba(224,123,57,.4);
}
.brand-name{
  font-family:'Fraunces',serif;font-size:1rem;
  font-weight:700;color:#fff;letter-spacing:.3px;line-height:1.2;
}
.brand-sub{
  font-size:.65rem;color:rgba(255,255,255,.4);
  letter-spacing:.6px;text-transform:uppercase;font-weight:500;
}

.sidebar-scroll{
  flex:1;overflow-y:auto;overflow-x:hidden;
  padding:10px 0 20px;scrollbar-width:none;
}
.sidebar-scroll::-webkit-scrollbar{display:none}

.nav-section{
  font-size:.62rem;font-weight:700;letter-spacing:1.3px;
  text-transform:uppercase;color:rgba(255,255,255,.28);
  padding:16px 18px 5px;white-space:nowrap;overflow:hidden;
}

.nav-link{
  display:flex;align-items:center;gap:10px;
  padding:8px 18px;
  color:rgba(255,255,255,.58)!important;
  font-size:.83rem;font-weight:500;
  text-decoration:none!important;
  position:relative;transition:var(--tr);
  white-space:nowrap;
}
.nav-icon{
  width:30px;height:30px;border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:.8rem;flex-shrink:0;transition:var(--tr);
}
.nav-link:hover{color:rgba(255,255,255,.88)!important;background:rgba(255,255,255,.06)}
.nav-link:hover .nav-icon{background:rgba(255,255,255,.1)}
.nav-link.active{color:#fff!important;background:rgba(255,255,255,.1)}
.nav-link.active::before{
  content:'';position:absolute;left:0;top:7px;bottom:7px;
  width:3px;background:var(--accent);border-radius:0 3px 3px 0;
}
.nav-link.active .nav-icon{background:var(--accent);color:#fff;box-shadow:0 2px 8px rgba(224,123,57,.4)}

/* Sidebar footer / user */
.sidebar-footer{
  padding:10px 14px;border-top:1px solid rgba(255,255,255,.07);flex-shrink:0;
}
.sidebar-user{
  display:flex;align-items:center;gap:10px;padding:9px 10px;
  border-radius:var(--radius);cursor:pointer;transition:var(--tr);
  text-decoration:none!important;
}
.sidebar-user:hover{background:rgba(255,255,255,.07)}
.s-avatar{
  width:32px;height:32px;border-radius:50%;background:var(--accent);
  display:flex;align-items:center;justify-content:center;
  font-size:.72rem;font-weight:700;color:#fff;flex-shrink:0;
}
.s-name{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.9);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.s-role{font-size:.67rem;color:rgba(255,255,255,.38);text-transform:capitalize}

/* Collapsed */
body.sidebar-collapsed .sidebar{width:var(--sidebar-w-col)}
body.sidebar-collapsed .brand-name,
body.sidebar-collapsed .brand-sub,
body.sidebar-collapsed .nav-section,
body.sidebar-collapsed .nav-link .nav-txt,
body.sidebar-collapsed .s-name,
body.sidebar-collapsed .s-role{display:none}
body.sidebar-collapsed .sidebar-brand{padding:18px;justify-content:center}
body.sidebar-collapsed .nav-link{padding:9px;justify-content:center}
body.sidebar-collapsed .nav-icon{width:36px;height:36px}
body.sidebar-collapsed .main-content{margin-left:var(--sidebar-w-col)}
body.sidebar-collapsed .topbar{left:var(--sidebar-w-col)}
body.sidebar-collapsed .sidebar-user{justify-content:center}
body.sidebar-collapsed .s-avatar{margin:0}

/* ─── TOPBAR ─── */
.topbar{
  position:fixed;top:0;left:var(--sidebar-w);right:0;
  height:var(--topbar-h);background:var(--surface);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 24px;
  z-index:1030;transition:var(--tr-s);gap:12px;
}
.tb-toggle{
  width:34px;height:34px;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);background:transparent;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text-secondary);transition:var(--tr);flex-shrink:0;
}
.tb-toggle:hover{background:var(--surface-2);color:var(--primary)}

.tb-breadcrumb{flex:1;min-width:0;display:flex;align-items:center;gap:8px}
.page-title{
  font-family:'Fraunces',serif;font-size:.98rem;font-weight:600;
  color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.bc-sep{color:var(--border);font-size:.9rem;line-height:1}
.bc-link{
  color:var(--text-muted);font-size:.8rem;text-decoration:none;
  white-space:nowrap;transition:var(--tr);
}
.bc-link:hover{color:var(--primary)}

.tb-actions{display:flex;align-items:center;gap:6px}
.tb-btn{
  width:34px;height:34px;border:1.5px solid var(--border);
  border-radius:var(--radius-sm);background:transparent;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--text-secondary);
  text-decoration:none;transition:var(--tr);position:relative;font-size:.88rem;
}
.tb-btn:hover{background:var(--surface-2);color:var(--primary)}
.tb-dot{
  position:absolute;top:-3px;right:-3px;
  width:16px;height:16px;background:var(--danger);color:#fff;
  font-size:.55rem;font-weight:700;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--surface);
}

.ay-badge{
  display:flex;align-items:center;gap:5px;
  padding:4px 11px;background:var(--primary-pale);
  border:1px solid rgba(28,53,87,.12);border-radius:20px;
  font-size:.73rem;font-weight:600;color:var(--primary);white-space:nowrap;
}

.tb-user{
  display:flex;align-items:center;gap:8px;
  padding:5px 10px 5px 5px;
  border:1.5px solid var(--border);border-radius:var(--radius);
  cursor:pointer;transition:var(--tr);text-decoration:none;background:transparent;
}
.tb-user:hover{background:var(--surface-2);border-color:var(--primary)}
.tb-avatar{
  width:28px;height:28px;border-radius:50%;background:var(--primary);
  display:flex;align-items:center;justify-content:center;
  font-size:.65rem;font-weight:700;color:#fff;
}
.tb-uname{font-size:.82rem;font-weight:600;color:var(--text-primary)}
.tb-urole{font-size:.67rem;color:var(--text-muted);text-transform:capitalize}

/* ─── LAYOUT ─── */
.main-content{
  margin-left:var(--sidebar-w);
  padding-top:var(--topbar-h);
  min-height:100vh;transition:var(--tr-s);
}
.page-wrap{padding:26px 28px 56px}

/* Flash messages */
.flash-wrap{
  position:fixed;top:74px;right:24px;
  z-index:9999;min-width:300px;max-width:420px;
}
@keyframes slideIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
.flash-wrap .alert{animation:slideIn .3s ease}

/* ─── CARDS ─── */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);
  overflow:hidden;transition:var(--tr);
}
.card-header{
  background:transparent;border-bottom:1px solid var(--border-light);
  padding:15px 20px;font-weight:600;font-size:.875rem;
  color:var(--text-primary);display:flex;align-items:center;gap:8px;
}
.card-header i{color:var(--primary);font-size:.82rem;opacity:.8}
.card-body{padding:20px}
.card-body.p-0{padding:0}

/* ─── STAT CARDS ─── */
.stat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:20px;
  display:flex;align-items:center;gap:15px;
  transition:var(--tr);position:relative;overflow:hidden;
}
.stat-card::after{
  content:'';position:absolute;bottom:0;left:0;right:0;
  height:3px;border-radius:0 0 var(--radius-lg) var(--radius-lg);
}
.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.stat-icon{
  width:46px;height:46px;border-radius:var(--radius);
  display:flex;align-items:center;justify-content:center;
  font-size:1.1rem;flex-shrink:0;
}
.stat-info{}
.stat-value{
  font-family:'Fraunces',serif;font-size:1.55rem;
  font-weight:700;line-height:1;color:var(--text-primary);
}
.stat-label{
  font-size:.72rem;color:var(--text-muted);font-weight:600;
  margin-top:3px;text-transform:uppercase;letter-spacing:.5px;
}

.stat-primary .stat-icon{background:var(--primary-pale);color:var(--primary)}
.stat-primary::after{background:var(--primary)}
.stat-success .stat-icon{background:var(--success-light);color:var(--success)}
.stat-success::after{background:var(--success)}
.stat-danger  .stat-icon{background:var(--danger-light);color:var(--danger)}
.stat-danger::after{background:var(--danger)}
.stat-warning .stat-icon{background:var(--warning-light);color:var(--warning)}
.stat-warning::after{background:var(--warning)}
.stat-info    .stat-icon{background:var(--info-light);color:var(--info)}
.stat-info::after{background:var(--info)}
.stat-accent  .stat-icon{background:var(--accent-light);color:var(--accent)}
.stat-accent::after{background:var(--accent)}

/* ─── TABLES ─── */
.table{
  font-size:.84rem;color:var(--text-primary);margin-bottom:0;
  --bs-table-hover-bg:var(--surface-2);
}
.table thead th{
  font-size:.7rem;font-weight:700;letter-spacing:.7px;
  text-transform:uppercase;color:var(--text-muted);
  background:#FAFBFD;border-bottom:1px solid var(--border);
  padding:11px 16px;white-space:nowrap;border-top:none;
}
.table td{
  padding:13px 16px;border-bottom:1px solid var(--border-light);
  vertical-align:middle;
}
.table tbody tr:last-child td{border-bottom:none}
.table tbody tr:hover td{background:var(--surface-2)}

/* ─── BADGES ─── */
.badge{
  font-size:.67rem;font-weight:700;letter-spacing:.3px;
  padding:3px 9px;border-radius:20px;
}
.badge.bg-primary  {background:var(--primary-pale)!important;color:var(--primary)!important}
.badge.bg-success  {background:var(--success-light)!important;color:var(--success)!important}
.badge.bg-danger   {background:var(--danger-light)!important;color:var(--danger)!important}
.badge.bg-warning  {background:var(--warning-light)!important;color:var(--warning)!important}
.badge.bg-info     {background:var(--info-light)!important;color:var(--info)!important}
.badge.bg-secondary{background:var(--surface-2)!important;color:var(--text-secondary)!important}

/* ─── BUTTONS ─── */
.btn{
  font-size:.83rem;font-weight:600;border-radius:var(--radius-sm);
  padding:7px 16px;transition:var(--tr);letter-spacing:.2px;
  border-width:1.5px;display:inline-flex;align-items:center;gap:6px;
}
.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-light);border-color:var(--primary-light);transform:translateY(-1px);box-shadow:var(--shadow-pri)}
.btn-outline-primary{border-color:var(--border);color:var(--text-secondary);background:transparent}
.btn-outline-primary:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.btn-outline-secondary{border-color:var(--border);color:var(--text-secondary);background:transparent}
.btn-outline-secondary:hover{background:var(--surface-2);border-color:var(--border);color:var(--text-primary)}
.btn-outline-danger{border-color:var(--border);color:var(--text-secondary)}
.btn-outline-danger:hover{background:var(--danger-light);border-color:var(--danger);color:var(--danger)}
.btn-outline-success{border-color:var(--border);color:var(--text-secondary)}
.btn-outline-success:hover{background:var(--success-light);border-color:var(--success);color:var(--success)}
.btn-warning{background:var(--warning-light);border-color:var(--warning);color:var(--warning)}
.btn-warning:hover{background:var(--warning);color:#fff}
.btn-success{background:var(--success);border-color:var(--success);color:#fff}
.btn-success:hover{background:#246442;border-color:#246442}
.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}
.btn-sm{padding:5px 12px;font-size:.78rem}
.btn-lg{padding:10px 24px;font-size:.9rem}
.btn-xs{padding:3px 9px!important;font-size:.71rem!important;border-radius:var(--radius-sm)!important}

/* ─── FORMS ─── */
.form-control,.form-select{
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:.85rem;color:var(--text-primary);background:var(--surface);
  padding:8px 12px;transition:var(--tr);font-family:'DM Sans',sans-serif;
}
.form-control:focus,.form-select:focus{
  border-color:var(--primary);box-shadow:0 0 0 3px rgba(28,53,87,.1);background:var(--surface);
}
.form-control::placeholder{color:var(--text-muted)}
.form-label{font-size:.79rem;font-weight:600;color:var(--text-secondary);margin-bottom:5px}
.form-control-sm,.form-select-sm{padding:5px 10px;font-size:.8rem}
.form-text{font-size:.75rem;color:var(--text-muted)}
.input-group-text{
  background:var(--surface-2);border:1.5px solid var(--border);
  color:var(--text-muted);font-size:.85rem;
}
.form-check-input:checked{background-color:var(--primary);border-color:var(--primary)}
.form-check-input:focus{box-shadow:0 0 0 3px rgba(28,53,87,.1)}

/* ─── ALERTS ─── */
.alert{border-radius:var(--radius);padding:12px 16px;font-size:.84rem;border-width:1px}
.alert-success{background:var(--success-light);border-color:rgba(45,125,82,.2);color:var(--success)}
.alert-danger{background:var(--danger-light);border-color:rgba(192,57,43,.2);color:var(--danger)}
.alert-warning{background:var(--warning-light);border-color:rgba(183,134,11,.2);color:var(--warning)}
.alert-info{background:var(--info-light);border-color:rgba(26,107,138,.2);color:var(--info)}

/* ─── DATATABLES ─── */
.dataTables_wrapper{padding:16px 20px 20px}
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input{
  border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-size:.82rem;padding:6px 10px;font-family:'DM Sans',sans-serif;color:var(--text-primary);
}
.dataTables_wrapper .dataTables_filter input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(28,53,87,.1)}
.dataTables_wrapper .dataTables_info,.dataTables_wrapper .dataTables_paginate{margin-top:12px;font-size:.79rem;color:var(--text-muted)}
.dataTables_wrapper .paginate_button{border-radius:var(--radius-sm)!important;font-size:.79rem!important;padding:4px 10px!important}
.dataTables_wrapper .paginate_button.current,
.dataTables_wrapper .paginate_button.current:hover{background:var(--primary)!important;color:#fff!important;border-color:var(--primary)!important}
.dataTables_wrapper .paginate_button:hover{background:var(--surface-2)!important;color:var(--primary)!important;border-color:var(--border)!important}

/* ─── SELECT2 ─── */
.select2-container--default .select2-selection--single{
  border:1.5px solid var(--border)!important;border-radius:var(--radius-sm)!important;
  height:38px!important;display:flex!important;align-items:center!important;background:var(--surface)!important;
}
.select2-container--default .select2-selection--single .select2-selection__rendered{
  line-height:1!important;color:var(--text-primary)!important;padding:0 30px 0 12px!important;font-size:.85rem;
}
.select2-container--default .select2-selection--single .select2-selection__arrow{height:36px!important;right:8px!important}
.select2-container--default.select2-container--focus .select2-selection--single{border-color:var(--primary)!important;box-shadow:0 0 0 3px rgba(28,53,87,.1)!important}
.select2-dropdown{border:1.5px solid var(--border)!important;border-radius:var(--radius)!important;box-shadow:var(--shadow)!important}
.select2-container--default .select2-results__option--highlighted{background:var(--primary)!important}
.select2-search--dropdown .select2-search__field{border:1px solid var(--border)!important;border-radius:var(--radius-sm)!important;font-family:'DM Sans',sans-serif!important}

/* ─── MODALS ─── */
.modal-content{border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.modal-header{border-bottom:1px solid var(--border-light);padding:16px 22px}
.modal-title{font-size:.94rem;font-weight:600}
.modal-body{padding:20px 22px}
.modal-footer{border-top:1px solid var(--border-light);padding:12px 22px}

/* ─── TABS ─── */
.nav-tabs{border-bottom:2px solid var(--border);gap:2px}
.nav-tabs .nav-link{
  border:none!important;padding:8px 16px;font-size:.82rem;font-weight:600;
  color:var(--text-muted)!important;border-radius:0!important;background:transparent!important;
  position:relative;margin-bottom:-2px;
}
.nav-tabs .nav-link:hover{color:var(--primary)!important}
.nav-tabs .nav-link.active{color:var(--primary)!important}
.nav-tabs .nav-link.active::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;
  height:2px;background:var(--primary);border-radius:2px 2px 0 0;
}

/* ─── DROPDOWNS ─── */
.dropdown-menu{
  border:1px solid var(--border);border-radius:var(--radius);
  box-shadow:var(--shadow-lg);padding:6px;font-size:.84rem;
}
.dropdown-item{border-radius:var(--radius-sm);padding:7px 12px;color:var(--text-primary);transition:var(--tr)}
.dropdown-item:hover{background:var(--surface-2);color:var(--primary)}
.dropdown-divider{border-color:var(--border-light)}
.dropdown-header{font-size:.68rem;letter-spacing:.7px;text-transform:uppercase;color:var(--text-muted);padding:8px 12px 4px;font-weight:700}

/* ─── QUICK ACTIONS ─── */
.quick-action{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  padding:16px 10px;background:var(--surface);
  border:1.5px solid var(--border);border-radius:var(--radius-lg);
  text-decoration:none!important;transition:var(--tr);text-align:center;
}
.quick-action:hover{border-color:var(--primary);background:var(--primary-pale);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.qa-icon{
  width:42px;height:42px;border-radius:var(--radius);
  background:var(--primary-pale);display:flex;align-items:center;justify-content:center;
  font-size:1rem;color:var(--primary);transition:var(--tr);
}
.quick-action:hover .qa-icon{background:var(--primary);color:#fff}
.qa-label{font-size:.73rem;font-weight:600;color:var(--text-secondary)}
.quick-action:hover .qa-label{color:var(--primary)}

/* ─── AVATAR ─── */
.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}
.av-sm{width:32px;height:32px;font-size:.7rem}
.av-md{width:40px;height:40px;font-size:.84rem}
.av-lg{width:52px;height:52px;font-size:1.05rem}
.av-xl{width:72px;height:72px;font-size:1.5rem}

/* ─── STEP WIZARD ─── */
.step-wizard{display:flex;align-items:center;margin-bottom:28px}
.step-item{flex:1;display:flex;align-items:center}
.step-num{
  width:30px;height:30px;border-radius:50%;border:2px solid var(--border);
  display:flex;align-items:center;justify-content:center;font-size:.76rem;font-weight:700;
  color:var(--text-muted);background:var(--surface);z-index:1;flex-shrink:0;transition:var(--tr);
}
.step-lbl{font-size:.73rem;font-weight:600;color:var(--text-muted);margin-left:7px;white-space:nowrap}
.step-line{flex:1;height:2px;background:var(--border);margin:0 8px}
.step-item.active .step-num{background:var(--primary);border-color:var(--primary);color:#fff}
.step-item.active .step-lbl{color:var(--primary)}
.step-item.done .step-num{background:var(--success);border-color:var(--success);color:#fff}
.step-item.done .step-line{background:var(--success)}

/* ─── ATTENDANCE ─── */
.att-ring{
  width:42px;height:42px;border-radius:50%;border:3px solid;
  display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;
}
.att-high{border-color:var(--success);color:var(--success)}
.att-med{border-color:var(--warning);color:var(--warning)}
.att-low{border-color:var(--danger);color:var(--danger)}

/* ─── PROGRESS ─── */
.progress{border-radius:20px;background:var(--surface-2)}
.progress-bar{border-radius:20px}

/* ─── SECTION HEADER ─── */
.section-header{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:18px;flex-wrap:wrap;gap:10px;
}
.section-title{font-size:.92rem;font-weight:600;color:var(--text-primary)}

/* ─── PROFILE DETAIL ROW ─── */
.detail-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px solid var(--border-light);
}
.detail-row:last-child{border-bottom:none}
.detail-label{font-size:.78rem;color:var(--text-muted);font-weight:500}
.detail-val{font-size:.84rem;font-weight:600;color:var(--text-primary);text-align:right}

/* ─── LOGIN ─── */
.login-page{min-height:100vh;display:flex;background:var(--bg)}
.login-left{
  width:42%;background:var(--primary);position:relative;
  display:flex;align-items:center;justify-content:center;
  flex-direction:column;padding:60px;overflow:hidden;
}
.login-left::before{
  content:'';position:absolute;top:-100px;right:-100px;
  width:350px;height:350px;border-radius:50%;background:rgba(255,255,255,.03);
}
.login-left::after{
  content:'';position:absolute;bottom:-80px;left:-80px;
  width:280px;height:280px;border-radius:50%;background:rgba(224,123,57,.12);
}
.login-feat{
  position:relative;z-index:1;
  display:flex;flex-direction:column;gap:22px;
}
.login-feat-item{display:flex;align-items:center;gap:14px}
.feat-icon{
  width:42px;height:42px;border-radius:10px;
  background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;flex-shrink:0;
}
.feat-text-title{font-size:.88rem;font-weight:600;color:#fff;margin-bottom:2px}
.feat-text-sub{font-size:.76rem;color:rgba(255,255,255,.5)}

.login-right{flex:1;display:flex;align-items:center;justify-content:center;padding:48px}
.login-box{width:100%;max-width:400px}
.login-head{margin-bottom:32px}
.login-logo{display:flex;align-items:center;gap:12px;margin-bottom:24px}
.login-logo-icon{
  width:44px;height:44px;background:var(--primary);border-radius:12px;
  display:flex;align-items:center;justify-content:center;font-size:1.3rem;
  box-shadow:var(--shadow-pri);
}
.login-title{font-size:1.5rem;margin-bottom:4px}
.login-sub{color:var(--text-muted);font-size:.88rem}

/* ─── RESPONSIVE ─── */
@media(max-width:991px){
  .sidebar{transform:translateX(-100%);box-shadow:var(--shadow-lg)}
  .sidebar.mobile-open{transform:translateX(0)}
  .main-content{margin-left:0!important}
  .topbar{left:0!important}
  .login-left{display:none}
  .login-right{padding:32px 24px}
  body.sidebar-collapsed .sidebar{transform:translateX(-100%)}
  .overlay-bg{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:1039;backdrop-filter:blur(2px)}
}
@media(max-width:576px){
  .page-wrap{padding:18px 14px 48px}
  .topbar{padding:0 14px}
  .content-wrapper{padding:18px 14px 48px}
}

/* ─── PRINT ─── */
@media print{
  .sidebar,.topbar,.btn,.no-print{display:none!important}
  .main-content{margin:0!important;padding:0!important}
  .card{box-shadow:none;border:1px solid #ddd}
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .35s ease forwards}
.du-1{animation-delay:.04s;opacity:0}.du-2{animation-delay:.08s;opacity:0}
.du-3{animation-delay:.12s;opacity:0}.du-4{animation-delay:.16s;opacity:0}
.du-5{animation-delay:.20s;opacity:0}.du-6{animation-delay:.24s;opacity:0}
