/* ================================================================
   MOCI Platform — Design System
   Primary color: #111111 (pure dark)
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap');

:root {
  /* ── Primary: pure #111 dark theme ── */
  --p:          #111111;
  --p-hover:    #2d2d2d;
  --p-light:    #F3F3F3;
  --p-mid:      #444444;

  /* ── Status colors ── */
  --green:      #16A34A;
  --green-lt:   #DCFCE7;
  --red:        #DC2626;
  --red-lt:     #FEE2E2;
  --orange:     #D97706;
  --orange-lt:  #FEF3C7;
  --blue:       #2563EB;
  --blue-lt:    #DBEAFE;

  /* ── Text ── */
  --t:          #0A0A0A;
  --t2:         #1F1F1F;
  --tm:         #6B7280;
  --tl:         #9CA3AF;

  /* ── Surfaces ── */
  --bg:         #F7F7F7;
  --white:      #FFFFFF;
  --border:     #E2E2E2;
  --border-l:   #F0F0F0;

  /* ── Layout ── */
  --nav-h:      64px;
  --r:          12px;
  --rs:         8px;
  --rx:         5px;

  /* ── Shadows ── */
  --sh:         0 1px 3px rgba(0,0,0,.07);
  --sh-md:      0 4px 16px rgba(0,0,0,.09);
  --sh-lg:      0 8px 32px rgba(0,0,0,.13);
}

/* ── Reset ───────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:14px;-webkit-font-smoothing:antialiased}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--t);line-height:1.5}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}
img{max-width:100%;display:block}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#CFCFCF;border-radius:4px}

/* ================================================================
   AUTH — LOGIN
   ================================================================ */
.auth-page{
  min-height:100vh;
  background:linear-gradient(135deg,#F0F0F0 0%,#FAFAFA 50%,#F5F5F5 100%);
  display:flex;align-items:center;justify-content:center;padding:20px;
}
.auth-box{
  width:100%;max-width:400px;
  background:var(--white);border-radius:16px;
  box-shadow:0 8px 40px rgba(0,0,0,.10);
  padding:40px 36px;border:1px solid var(--border);
}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-logo-mark{
  width:48px;height:48px;margin:0 auto 12px;
  background:var(--p);border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;color:#fff;
}
.auth-logo h4{font-size:1.1rem;font-weight:700;color:var(--t);margin-bottom:3px}
.auth-logo p{font-size:.78rem;color:var(--tm)}
.auth-field{margin-bottom:16px}
.auth-field label{display:block;font-size:.78rem;font-weight:600;color:var(--t2);margin-bottom:5px}
.auth-input-wrap{
  display:flex;align-items:center;
  border:1.5px solid var(--border);border-radius:var(--rs);
  overflow:hidden;background:var(--white);
  transition:border-color .15s,box-shadow .15s;
}
.auth-input-wrap:focus-within{border-color:var(--p);box-shadow:0 0 0 3px rgba(17,17,17,.08)}
.auth-input-icon{padding:0 11px;color:var(--tl);height:42px;display:flex;align-items:center;font-size:.9rem;background:var(--white)}
.auth-input-wrap input{
  flex:1;border:none;outline:none;padding:10px 12px 10px 0;
  font-size:.85rem;color:var(--t);background:var(--white);height:42px;
}
.auth-toggle-pwd{padding:0 11px;background:var(--white);border:none;color:var(--tl);height:42px;font-size:.85rem}
.auth-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}
.auth-check{display:flex;align-items:center;gap:7px;font-size:.78rem;color:var(--tm);cursor:pointer}
.auth-check input{accent-color:var(--p);width:15px;height:15px;cursor:pointer}
.auth-forgot{font-size:.78rem;color:var(--p);font-weight:500}
.btn-signin{
  width:100%;height:42px;background:var(--p);color:#fff;border:none;
  border-radius:var(--rs);font-size:.88rem;font-weight:600;
  display:flex;align-items:center;justify-content:center;gap:7px;
  transition:background .15s;
}
.btn-signin:hover{background:var(--p-hover)}

/* ================================================================
   FLASH MESSAGES
   ================================================================ */
.flash-wrap{padding:12px 24px 0}
.flash{
  display:flex;align-items:flex-start;gap:10px;
  padding:11px 14px;border-radius:var(--rs);
  margin-bottom:8px;font-size:.82rem;font-weight:500;
}
.flash-success{background:#F0FDF4;color:var(--green);border:1px solid var(--green-lt)}
.flash-danger {background:#FEF2F2;color:var(--red);border:1px solid var(--red-lt)}
.flash-warning{background:#FFFBEB;color:var(--orange);border:1px solid var(--orange-lt)}
.flash i{font-size:.9rem;flex-shrink:0;margin-top:1px}
.flash-close{margin-left:auto;background:transparent;border:none;color:inherit;opacity:.5;cursor:pointer;font-size:1rem;line-height:1;padding:0}

/* ================================================================
   TOP NAVIGATION
   ================================================================ */
.topnav{
  position:sticky;top:0;z-index:200;
  background:var(--white);border-bottom:1px solid var(--border);
  height:var(--nav-h);
  display:flex;align-items:center;padding:0 24px;
}
.tnav-brand{display:flex;align-items:center;gap:10px;margin-right:28px;flex-shrink:0}
.tnav-logo{
  width:34px;height:34px;background:var(--p);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1rem;flex-shrink:0;
}
.tnav-tabs{display:flex;align-items:center;gap:2px;flex:1}
.tnav-tab{
  padding:6px 16px;border-radius:20px;font-size:.82rem;font-weight:500;
  color:var(--tm);background:transparent;border:none;white-space:nowrap;
  transition:all .15s;cursor:pointer;
}
.tnav-tab:hover{color:var(--t);background:var(--bg)}
.tnav-tab.active{
  background:var(--p);color:#fff;font-weight:600;
}
.tnav-right{display:flex;align-items:center;gap:4px;flex-shrink:0}
.tnav-icon{
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border-radius:var(--rs);background:transparent;border:none;
  color:var(--tm);font-size:1rem;position:relative;transition:background .15s;
}
.tnav-icon:hover{background:var(--bg);color:var(--t)}
.tnav-notif-dot{
  position:absolute;top:6px;right:6px;width:7px;height:7px;
  background:var(--red);border-radius:50%;border:1.5px solid #fff;
}
.tnav-avatar{
  width:32px;height:32px;border-radius:50%;
  background:var(--p);
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:.75rem;
  overflow:hidden;cursor:pointer;flex-shrink:0;
}
.tnav-avatar img{width:100%;height:100%;object-fit:cover}
.tnav-chevron{font-size:.62rem;color:var(--tl);margin-left:3px}

/* ================================================================
   PAGE WRAPPER
   ================================================================ */
.page-wrap{max-width:1360px;margin:0 auto;padding:22px 24px}

/* ================================================================
   DASHBOARD GRID
   ================================================================ */
.dash-layout{
  display:grid;grid-template-columns:1fr 290px;gap:18px;align-items:start;
}
@media(max-width:1024px){.dash-layout{grid-template-columns:1fr}}

/* ── Stat cards ─────────────────────────────────────── */
.stat-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
@media(max-width:860px){.stat-row{grid-template-columns:repeat(2,1fr)}}
.stat-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);box-shadow:var(--sh);padding:18px 20px;
}
.stat-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:10px}
.stat-icon{font-size:1.25rem;color:var(--t)}
.stat-menu{color:var(--tl);font-size:.9rem;line-height:1;cursor:pointer}
.stat-val{font-size:1.6rem;font-weight:700;color:var(--t);line-height:1.1;margin-bottom:4px}
.stat-val-md{font-size:1.3rem;font-weight:700;color:var(--t);line-height:1.1;margin-bottom:4px}
.stat-lbl{font-size:.72rem;color:var(--tm);line-height:1.4}

/* ── Chart card ─────────────────────────────────────── */
.chart-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);box-shadow:var(--sh);
  padding:20px 22px;margin-bottom:18px;
}
.cc-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:4px}
.cc-title{font-size:.9rem;font-weight:600;color:var(--t)}
.cc-sub{font-size:.72rem;color:var(--tm);margin-bottom:14px}
.cc-right{display:flex;align-items:center;gap:8px}
.cc-period{
  display:flex;align-items:center;gap:5px;
  border:1.5px solid var(--border);border-radius:var(--rx);
  padding:5px 11px;font-size:.72rem;font-weight:500;
  color:var(--tm);background:var(--white);cursor:pointer;
}
.cc-expand{
  width:27px;height:27px;border:1.5px solid var(--border);border-radius:var(--rx);
  display:flex;align-items:center;justify-content:center;
  color:var(--tm);font-size:.75rem;background:var(--white);cursor:pointer;
}
.cc-expand:hover,.cc-period:hover{border-color:var(--p);color:var(--p)}
.sales-nums{display:flex;gap:28px;margin-bottom:16px;align-items:flex-end}
.sales-lbl{font-size:.72rem;color:var(--tm);margin-bottom:3px}
.sales-amount{display:flex;align-items:baseline;gap:5px}
.sales-main{font-size:1.8rem;font-weight:800;color:var(--t)}
.pill{font-size:.67rem;font-weight:700;padding:2px 8px;border-radius:20px;display:inline-block}
.pill-up{background:var(--green-lt);color:var(--green)}
.pill-dn{background:var(--red-lt);color:var(--red)}

/* ── List card ──────────────────────────────────────── */
.list-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);box-shadow:var(--sh);padding:18px 22px;
}
.lc-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.lc-title{font-size:.88rem;font-weight:600;color:var(--t)}
.lc-link{font-size:.73rem;color:var(--p);font-weight:500}
.lc-row{
  display:grid;grid-template-columns:30px 130px 1fr auto auto auto;
  align-items:center;gap:10px;
  padding:9px 0;border-bottom:1px solid var(--border-l);
}
.lc-row:last-child{border-bottom:none}
.lc-avatar{
  width:30px;height:30px;border-radius:50%;
  background:var(--p-light);color:var(--p);
  font-size:.68rem;font-weight:700;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden;
}
.lc-name{font-size:.79rem;font-weight:600;color:var(--t);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lc-meta{font-size:.73rem;color:var(--tm);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.lc-count{font-size:.73rem;color:var(--tm);white-space:nowrap}
.lc-time{font-size:.7rem;color:var(--tl);white-space:nowrap}

/* ── Right panel ────────────────────────────────────── */
.rpanel-card{
  background:var(--white);border-radius:var(--r);
  border:1px solid var(--border);box-shadow:var(--sh);
  padding:18px 20px;margin-bottom:14px;
}
.rpanel-card:last-child{margin-bottom:0}
.rp-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px}
.rp-title{font-size:.88rem;font-weight:700;color:var(--t)}
.rp-sub{font-size:.72rem;color:var(--tm);margin-top:2px}
.rp-expand{
  width:27px;height:27px;border:1.5px solid var(--border);border-radius:var(--rx);
  display:flex;align-items:center;justify-content:center;
  color:var(--tm);font-size:.75rem;background:var(--white);cursor:pointer;flex-shrink:0;
}
.rp-expand:hover{border-color:var(--p);color:var(--p)}

/* Formation progress */
.form-bar{height:9px;border-radius:20px;background:var(--p-light);overflow:hidden;margin-bottom:16px}
.form-bar-fill{
  height:100%;border-radius:20px;
  background:repeating-linear-gradient(
    45deg,var(--p) 0px,var(--p) 4px,var(--p-mid) 4px,var(--p-mid) 8px
  );
  transition:width .4s ease;
}
.form-est-title{font-size:.79rem;font-weight:600;color:var(--t);margin-bottom:2px}
.form-est-sub{font-size:.72rem;color:var(--tm);margin-bottom:14px}
.btn-vs{
  width:100%;padding:10px;
  border:1.5px solid var(--border);border-radius:20px;
  background:var(--white);font-size:.8rem;font-weight:600;color:var(--t);
  cursor:pointer;transition:all .15s;
  display:flex;align-items:center;justify-content:center;gap:7px;
}
.btn-vs:hover{border-color:var(--p);background:var(--p);color:#fff}

/* Donut */
.donut-wrap{text-align:center;padding:6px 0}
.donut-num{font-size:1.8rem;font-weight:800;color:var(--t);margin-top:6px;line-height:1}
.donut-sub{font-size:.72rem;color:var(--green);font-weight:600;margin-top:3px}
.donut-msg{font-size:.72rem;color:var(--tm);text-align:center;margin:10px 0;line-height:1.5}
.mini-row{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--border-l);padding-top:10px;margin-top:2px}
.mini-col{text-align:center}
.mini-col:first-child{border-right:1px solid var(--border-l)}
.mini-val{font-size:1.1rem;font-weight:700;color:var(--t)}
.mini-lbl{font-size:.69rem;color:var(--tm)}

/* ================================================================
   GENERIC PAGE COMPONENTS
   ================================================================ */
.g-card{background:var(--white);border-radius:var(--r);border:1px solid var(--border);box-shadow:var(--sh);overflow:hidden}
.g-card-head{
  padding:14px 20px;border-bottom:1px solid var(--border-l);
  display:flex;align-items:center;justify-content:space-between;
}
.g-card-title{font-size:.88rem;font-weight:600;color:var(--t)}
.g-card-body{padding:20px}

/* Table */
.g-table{width:100%;border-collapse:collapse}
.g-table thead th{
  background:#F9F9F9;font-size:.68rem;font-weight:600;
  text-transform:uppercase;letter-spacing:.05em;
  color:var(--tm);padding:10px 16px;
  border-bottom:1px solid var(--border);white-space:nowrap;
}
.g-table tbody td{
  padding:11px 16px;font-size:.81rem;color:var(--t2);
  border-bottom:1px solid var(--border-l);vertical-align:middle;
}
.g-table tbody tr:last-child td{border-bottom:none}
.g-table tbody tr:hover{background:#FAFAFA}

/* Status badges */
.sb{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:.69rem;font-weight:600;white-space:nowrap}
.sb::before{content:'';width:5px;height:5px;border-radius:50%;background:currentColor;display:block;flex-shrink:0}
.sb-pending   {background:var(--orange-lt);color:var(--orange)}
.sb-completed,.sb-active,.sb-synced{background:var(--green-lt);color:var(--green)}
.sb-failed,.sb-error{background:var(--red-lt);color:var(--red)}
.sb-processing{background:var(--blue-lt);color:var(--blue)}
.sb-partial   {background:#FEF3C7;color:#92400E}
.sb-cancelled,.sb-inactive{background:#F3F4F6;color:#6B7280}
.sb-info      {background:var(--blue-lt);color:var(--blue)}

/* Buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:5px;
  font-size:.81rem;font-weight:500;border-radius:var(--rs);
  padding:7px 15px;border:1.5px solid transparent;
  cursor:pointer;transition:all .15s;font-family:inherit;
  line-height:1.4;text-decoration:none;
}
.btn-primary{background:var(--p);border-color:var(--p);color:#fff}
.btn-primary:hover{background:var(--p-hover);border-color:var(--p-hover);color:#fff}
.btn-secondary{background:#F3F4F6;border-color:#F3F4F6;color:var(--t2)}
.btn-secondary:hover{background:#E5E7EB}
.btn-outline{border-color:var(--border);background:var(--white);color:var(--t2)}
.btn-outline:hover{border-color:var(--p);color:var(--p)}
.btn-danger{background:var(--red);border-color:var(--red);color:#fff}
.btn-danger:hover{background:#B91C1C}
.btn-success{background:var(--green);border-color:var(--green);color:#fff}
.btn-sm{padding:5px 11px;font-size:.74rem}
.btn-xs{padding:2px 8px;font-size:.68rem;border-radius:var(--rx)}

/* Forms */
.f-group{margin-bottom:15px}
.f-label{display:block;font-size:.77rem;font-weight:600;color:var(--t2);margin-bottom:5px}
.f-input,.f-select,.f-textarea{
  width:100%;border:1.5px solid var(--border);border-radius:var(--rs);
  padding:8px 12px;font-size:.83rem;color:var(--t);background:var(--white);
  transition:border-color .15s,box-shadow .15s;font-family:inherit;
}
.f-input:focus,.f-select:focus,.f-textarea:focus{
  border-color:var(--p);box-shadow:0 0 0 3px rgba(17,17,17,.07);outline:none;
}
.f-input-group{display:flex}
.f-input-group .f-input-icon{
  padding:0 11px;background:#F9F9F9;border:1.5px solid var(--border);border-right:none;
  border-radius:var(--rs) 0 0 var(--rs);display:flex;align-items:center;color:var(--tl);font-size:.88rem;
}
.f-input-group .f-input{border-radius:0 var(--rs) var(--rs) 0}
.f-textarea{resize:vertical;min-height:90px}
.f-hint{font-size:.71rem;color:var(--tl);margin-top:4px}
.f-required::after{content:' *';color:var(--red)}

/* Bootstrap overrides */
.dropdown-menu{border:1px solid var(--border);border-radius:var(--r);box-shadow:var(--sh-md);padding:6px;font-size:.82rem}
.dropdown-item{border-radius:var(--rx);padding:7px 12px;color:var(--t2)}
.dropdown-item:hover{background:var(--bg);color:var(--t)}
.dropdown-divider{border-color:var(--border-l);margin:4px 0}
.form-control,.form-select{border:1.5px solid var(--border);border-radius:var(--rs);font-size:.83rem;padding:7px 11px}
.form-control:focus,.form-select:focus{border-color:var(--p);box-shadow:0 0 0 3px rgba(17,17,17,.07)}
.form-label{font-size:.77rem;font-weight:600;color:var(--t2);margin-bottom:4px}
.input-group-text{background:#F9F9F9;border:1.5px solid var(--border);color:var(--tm);font-size:.83rem}
.table>:not(caption)>*>*{padding:10px 16px}
.pagination .page-link{border-color:var(--border);color:var(--tm);font-size:.76rem;border-radius:var(--rx)!important}
.page-item.active .page-link{background:var(--p);border-color:var(--p)}
.badge.bg-primary{background:var(--p)!important}
.badge.bg-success{background:var(--green)!important}
.badge.bg-danger{background:var(--red)!important}
.alert{border:none;border-radius:var(--rs);font-size:.82rem}
.alert-success{background:var(--green-lt);color:var(--green)}
.alert-danger{background:var(--red-lt);color:var(--red)}
.modal-content{border-radius:var(--r);border:none;box-shadow:var(--sh-lg)}
.modal-header{border-bottom:1px solid var(--border-l);padding:16px 20px}
.modal-footer{border-top:1px solid var(--border-l);padding:12px 20px}
.modal-body{padding:20px}

/* DataTables */
.dataTables_wrapper .dataTables_filter input{border:1.5px solid var(--border)!important;border-radius:var(--rs)!important;padding:6px 10px!important;font-size:.78rem!important}
.dataTables_wrapper .dataTables_filter input:focus{border-color:var(--p)!important;box-shadow:none!important;outline:none!important}
.dataTables_wrapper .dataTables_length select{border:1.5px solid var(--border)!important;border-radius:var(--rx)!important;padding:4px 8px!important;font-size:.78rem!important}

/* Select2 */
.select2-container--bootstrap-5 .select2-selection{border:1.5px solid var(--border)!important;border-radius:var(--rs)!important;font-size:.83rem!important}
.select2-container--bootstrap-5.select2-container--focus .select2-selection{border-color:var(--p)!important;box-shadow:0 0 0 3px rgba(17,17,17,.07)!important}
.select2-container--bootstrap-5 .select2-results__option--highlighted{background:var(--p)!important}

/* Toast */
#toastContainer{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px}
.moci-toast{
  display:flex;align-items:center;gap:10px;
  background:var(--white);border-radius:var(--rs);box-shadow:var(--sh-lg);
  padding:11px 15px;min-width:260px;max-width:380px;
  border-left:4px solid var(--p);font-size:.81rem;font-weight:500;color:var(--t);
  animation:tin .2s ease;
}
.moci-toast.t-success{border-color:var(--green)}
.moci-toast.t-danger{border-color:var(--red)}
.moci-toast.t-warning{border-color:var(--orange)}
@keyframes tin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* Notification dropdown */
.notif-dd{width:340px;padding:0!important}
.notif-dh{padding:13px 16px;border-bottom:1px solid var(--border-l);display:flex;align-items:center;justify-content:space-between}
.notif-df{padding:9px 16px;border-top:1px solid var(--border-l);text-align:center}
.notif-item{padding:10px 16px!important}

/* Utility */
.text-primary{color:var(--p)!important}
.bg-primary-lt{background:var(--p-light)!important}
.fw-7{font-weight:700!important}
.fw-6{font-weight:600!important}
.fw-5{font-weight:500!important}
.divider{border:none;border-top:1px solid var(--border-l);margin:10px 0}
