@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap');

:root {
  --primary:#C0293A; --primary-dark:#9B1E2C; --primary-light:#F5D0D4;
  --sidebar-bg:#141824; --sidebar-text:#9ba3b8;
  --body-bg:#F4F6FA; --card-bg:#FFFFFF;
  --text-main:#1a2035; --text-muted:#6c757d;
  --border:#E8EBF0;
  --shadow-sm:0 2px 8px rgba(0,0,0,.06);
  --shadow-md:0 4px 20px rgba(0,0,0,.08);
  --shadow-lg:0 8px 32px rgba(0,0,0,.12);
  --radius:14px; --radius-sm:8px;
  --sidebar-w:240px; --header-h:68px;
  --green:#22c55e; --orange:#f59e0b; --blue:#3b82f6; --red:#ef4444;
  --transition:all .25s cubic-bezier(.4,0,.2,1);
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--body-bg);color:var(--text-main);font-size:14px;overflow-x:hidden}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:3px}

/* ── SIDEBAR ── */
.sidebar{position:fixed;left:0;top:0;bottom:0;width:var(--sidebar-w);background:var(--sidebar-bg);display:flex;flex-direction:column;z-index:1000;transition:var(--transition)}
.sidebar.collapsed{width:68px}
.sidebar.collapsed .brand-text,.sidebar.collapsed .nav-link span,.sidebar.collapsed .nav-section-label,.sidebar.collapsed .user-details,.sidebar.collapsed .btn-logout,.sidebar.collapsed .sidebar-version{display:none}
.sidebar.collapsed .sidebar-brand{justify-content:center}
.sidebar.collapsed .nav-link{justify-content:center;padding:10px 0}
.sidebar.collapsed .nav-link i{margin:0;font-size:20px}
.sidebar.collapsed .user-card{justify-content:center;padding:10px}
.sidebar-brand{padding:20px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,0.06);min-height:var(--header-h)}
.brand-icon{width:38px;height:38px;background:var(--primary);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;color:#fff;flex-shrink:0}
.brand-name{font-size:15px;font-weight:700;color:#fff;line-height:1.2}
.brand-sub{font-size:11px;color:var(--sidebar-text)}
.sidebar-nav{flex:1;overflow-y:auto;padding:12px 0}
.nav-section-label{font-size:10px;font-weight:700;color:rgba(155,163,184,0.5);text-transform:uppercase;letter-spacing:1px;padding:10px 18px 4px}
.sidebar-nav ul{list-style:none;padding:0 10px}
.sidebar-nav ul li{margin:2px 0}
.nav-link{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--radius-sm);color:var(--sidebar-text);text-decoration:none;font-size:13.5px;font-weight:500;transition:var(--transition)}
.nav-link:hover{background:rgba(255,255,255,0.06);color:#fff}
.nav-link.active{background:var(--primary);color:#fff;box-shadow:0 4px 12px rgba(192,41,58,0.3)}
.nav-link i{font-size:16px;flex-shrink:0}
.sidebar-footer{border-top:1px solid rgba(255,255,255,0.06);padding:12px 10px 10px}
.user-card{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm);background:rgba(255,255,255,0.04)}
.user-avatar-sm{width:34px;height:34px;background:var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:14px;flex-shrink:0}
.user-details{flex:1;min-width:0}
.user-fn{font-size:12.5px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.user-role-badge{display:inline-block;font-size:10px;font-weight:600;padding:1px 7px;border-radius:10px}
.role-admin{background:rgba(192,41,58,0.2);color:#f87171}
.role-member{background:rgba(59,130,246,0.2);color:#93c5fd}
.role-guest{background:rgba(107,114,128,0.2);color:#9ca3af}
.btn-logout{background:none;border:none;color:var(--sidebar-text);cursor:pointer;font-size:16px;padding:4px;transition:var(--transition);flex-shrink:0}
.btn-logout:hover{color:#ef4444}
.sidebar-version{font-size:10px;color:rgba(155,163,184,0.3);text-align:center;padding:6px 0 0}
/* Login button in sidebar for guests */
.btn-login-sidebar{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:var(--radius-sm);color:#fff;text-decoration:none;font-size:13px;font-weight:600;background:var(--primary);margin:0 10px;transition:var(--transition)}
.btn-login-sidebar:hover{background:var(--primary-dark);color:#fff}

/* ── MAIN LAYOUT ── */
.main-wrapper{margin-left:var(--sidebar-w);min-height:100vh;display:flex;flex-direction:column;transition:var(--transition)}
.main-wrapper.sidebar-collapsed{margin-left:68px}

/* ── HEADER ── */
.top-header{position:sticky;top:0;z-index:900;height:var(--header-h);background:var(--card-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:16px;padding:0 24px;box-shadow:var(--shadow-sm)}
.btn-toggle{background:none;border:none;font-size:20px;cursor:pointer;color:var(--text-muted);padding:4px 8px;border-radius:var(--radius-sm);transition:var(--transition)}
.btn-toggle:hover{background:var(--body-bg);color:var(--text-main)}
.search-wrap{flex:1;max-width:400px}
.search-wrap .input-group-text{background:var(--body-bg);border-color:var(--border);color:var(--text-muted)}
.search-wrap .form-control{background:var(--body-bg);border-color:var(--border);font-size:13.5px}
.search-wrap .form-control:focus{box-shadow:none;border-color:var(--primary)}
.header-right{margin-left:auto;display:flex;align-items:center;gap:8px}
.header-icon-btn{position:relative;background:none;border:none;width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:18px;cursor:pointer;transition:var(--transition)}
.header-icon-btn:hover{background:var(--body-bg);color:var(--text-main)}
.badge-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--primary);border-radius:50%;border:2px solid #fff}
.user-info{display:flex;align-items:center;gap:10px;padding:6px 10px;border:1px solid var(--border);border-radius:10px;cursor:pointer}
.user-name{font-size:13px;font-weight:600;color:var(--text-main)}
.user-role{font-size:11px;color:var(--text-muted)}
.user-avatar{width:34px;height:34px;background:var(--primary-light);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--primary);font-size:16px}
/* Guest login button in header */
.btn-header-login{background:var(--primary);color:#fff;border:none;border-radius:10px;padding:8px 18px;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:6px;transition:var(--transition);text-decoration:none}
.btn-header-login:hover{background:var(--primary-dark);color:#fff;transform:translateY(-1px)}

/* ── CONTENT ── */
.page-content{padding:28px;flex:1}
.page-title{font-size:22px;font-weight:700;color:var(--text-main);margin-bottom:2px}
.page-subtitle{font-size:13px;color:var(--text-muted)}

/* ── STAT CARDS ── */
.stat-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-sm);transition:var(--transition)}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.stat-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:20px}
.icon-pink{background:rgba(192,41,58,0.1);color:var(--primary)}
.icon-green{background:rgba(34,197,94,0.1);color:var(--green)}
.icon-blue{background:rgba(59,130,246,0.1);color:var(--blue)}
.icon-orange{background:rgba(245,158,11,0.1);color:var(--orange)}
.icon-purple{background:rgba(139,92,246,0.1);color:#8b5cf6}
.stat-value{font-size:24px;font-weight:700;color:var(--text-main);margin:12px 0 2px}
.stat-label{font-size:12.5px;color:var(--text-muted)}
.stat-change{font-size:12px;font-weight:600;display:flex;align-items:center;gap:2px}
.stat-change.up{color:var(--green)}.stat-change.down{color:var(--red)}

/* ── CARDS ── */
.card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-sm)}
.card-header-custom{padding:18px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:15px;font-weight:700;color:var(--text-main);margin:0}
.card-body-custom{padding:20px}

/* ── FEE BREAKDOWN ── */
.fee-card-primary{background:var(--primary);color:#fff;border-radius:var(--radius);padding:24px 20px;position:relative;overflow:hidden}
.fee-card-orange{background:#f97316;color:#fff;border-radius:var(--radius);padding:24px 20px;position:relative;overflow:hidden}
.fee-card-blue{background:#3b82f6;color:#fff;border-radius:var(--radius);padding:24px 20px;position:relative;overflow:hidden}
.fee-card-icon{width:36px;height:36px;background:rgba(255,255,255,0.2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;position:absolute;top:20px;right:20px}
.fee-card-label{font-size:12px;font-weight:600;opacity:.8;margin-bottom:8px}
.fee-card-value{font-size:28px;font-weight:700}
.fee-card-sub{font-size:11px;opacity:.7;margin-top:4px}

/* ── BUTTONS ── */
.btn-primary-custom{background:var(--primary);color:#fff;border:none;border-radius:var(--radius-sm);padding:9px 18px;font-size:13.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:var(--transition);box-shadow:0 2px 8px rgba(192,41,58,0.25)}
.btn-primary-custom:hover{background:var(--primary-dark);color:#fff;transform:translateY(-1px);box-shadow:0 4px 14px rgba(192,41,58,0.35)}
.btn-outline-custom{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 14px;font-size:13px;font-weight:600;color:var(--text-muted);cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:var(--transition)}
.btn-outline-custom:hover{border-color:var(--primary);color:var(--primary)}

/* ── TABLES ── */
.table-custom{width:100%}
.table-custom th{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 16px;border-bottom:1px solid var(--border);white-space:nowrap}
.table-custom td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle;font-size:13.5px}
.table-custom tr:last-child td{border-bottom:none}
.table-custom tr:hover td{background:rgba(0,0,0,.015)}

/* ── BADGES ── */
.badge-custom{display:inline-block;padding:4px 10px;border-radius:20px;font-size:11.5px;font-weight:600}
.badge-success{background:rgba(34,197,94,0.12);color:#16a34a}
.badge-warning{background:rgba(245,158,11,0.12);color:#d97706}
.badge-danger{background:rgba(239,68,68,0.12);color:#dc2626}
.badge-info{background:rgba(59,130,246,0.12);color:#2563eb}
.badge-purple{background:rgba(139,92,246,0.12);color:#7c3aed}
.badge-gray{background:rgba(107,114,128,0.12);color:#4b5563}

/* ── ACTION BUTTONS ── */
.action-btn{width:30px;height:30px;border:none;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;transition:var(--transition)}
.action-btn-edit{background:rgba(59,130,246,0.1);color:var(--blue)}
.action-btn-delete{background:rgba(239,68,68,0.1);color:var(--red)}
.action-btn-view{background:rgba(34,197,94,0.1);color:var(--green)}
.action-btn-perm{background:rgba(139,92,246,0.1);color:#8b5cf6}
.action-btn:hover{filter:brightness(1.15);transform:scale(1.05)}

/* ── SITE CARDS ── */
.site-card{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:22px;transition:var(--transition)}
.site-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}
.site-icon-wrap{width:44px;height:44px;background:var(--primary);border-radius:12px;display:flex;align-items:center;justify-content:center;color:#fff;font-size:20px}

/* ── ASSOC STATS ── */
.assoc-stat{border-radius:var(--radius);padding:20px;display:flex;align-items:center;gap:14px}
.assoc-stat-icon{font-size:28px}
.assoc-stat-value{font-size:26px;font-weight:700}
.assoc-stat-label{font-size:12px;color:var(--text-muted)}
.assoc-stat-pink{background:rgba(192,41,58,0.06)}
.assoc-stat-blue{background:rgba(59,130,246,0.06)}
.assoc-stat-green{background:rgba(34,197,94,0.06)}
.assoc-stat-gold{background:rgba(245,158,11,0.06)}

/* ── LEGAL FUND BADGE ── */
.legal-fund-badge{background:rgba(245,158,11,0.1);border:1px solid rgba(245,158,11,0.2);border-radius:var(--radius);padding:10px 18px;display:flex;align-items:center;gap:10px}
.lf-label{font-size:11px;font-weight:600;color:var(--orange);text-transform:uppercase;letter-spacing:.5px}
.lf-value{font-size:18px;font-weight:700;color:var(--text-main)}

/* ── PROGRESS ── */
.progress{height:8px;border-radius:4px;background:var(--border)}
.progress-bar-primary{background:var(--primary)}

/* ── TIMELINE ── */
.timeline-item{background:var(--card-bg);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;margin-bottom:12px}
.timeline-phase{font-size:16px;font-weight:700;color:var(--text-main)}
.timeline-deadline{font-size:12px;color:var(--text-muted);margin-bottom:12px}
.phase-badge-active{background:rgba(34,197,94,0.1);color:var(--green);font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}
.phase-badge-upcoming{background:rgba(245,158,11,0.1);color:var(--orange);font-size:12px;font-weight:600;padding:3px 10px;border-radius:20px}

/* ── CHARTS ── */
.chart-wrap{position:relative;height:260px}

/* ── PERMISSION TABLE ── */
.perm-table{width:100%;border-collapse:collapse}
.perm-table th{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);padding:10px 12px;background:var(--body-bg)}
.perm-table td{padding:10px 12px;border-bottom:1px solid var(--border);font-size:13px;vertical-align:middle}
.perm-table .form-check-input{cursor:pointer;width:16px;height:16px}
.perm-table .form-check-input:checked{background-color:var(--primary);border-color:var(--primary)}

/* ── TOAST ── */
.toast-container{position:fixed;top:20px;right:20px;z-index:9999}
.toast-custom{background:#fff;border-radius:10px;box-shadow:var(--shadow-lg);padding:12px 16px;display:flex;align-items:center;gap:10px;font-size:13.5px;font-weight:500;min-width:260px;border-left:4px solid;animation:slideIn .3s ease;margin-bottom:8px}
.toast-custom.success{border-color:var(--green)}
.toast-custom.error{border-color:var(--red)}
.toast-custom.warning{border-color:var(--orange)}
@keyframes slideIn{from{transform:translateX(100px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── ACTIVITY ── */
.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}
.activity-item:last-child{border-bottom:none}
.activity-icon{width:34px;height:34px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:15px;flex-shrink:0}
.activity-text{font-size:13px;color:var(--text-main);line-height:1.4}
.activity-time{font-size:11.5px;color:var(--text-muted);margin-top:2px}

/* ── DATATABLE ── */
.dataTables_wrapper .dataTables_filter input{background:var(--body-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:13px}
.dataTables_wrapper .dataTables_length select{background:var(--body-bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px}
.dataTables_wrapper .dataTables_paginate .paginate_button.current{background:var(--primary)!important;color:#fff!important;border:none!important;border-radius:6px!important}
.dataTables_wrapper .dataTables_paginate .paginate_button:hover{background:var(--body-bg)!important;color:var(--text-main)!important;border:1px solid var(--border)!important;border-radius:6px!important}
.dataTables_wrapper .dataTables_info{font-size:12px;color:var(--text-muted)}

/* ── MODALS ── */
.modal-content{border-radius:var(--radius);border:none}
.modal-header{border-bottom:1px solid var(--border);padding:18px 24px}
.modal-title{font-size:16px;font-weight:700}
.modal-body{padding:24px}
.modal-footer{border-top:1px solid var(--border);padding:16px 24px}
.form-label{font-size:12.5px;font-weight:600;color:var(--text-muted);margin-bottom:5px}
.form-control,.form-select{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13.5px;padding:9px 12px;color:var(--text-main);transition:var(--transition)}
.form-control:focus,.form-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(192,41,58,0.1)}

/* ── EMPTY STATE ── */
.empty-state{text-align:center;padding:40px 20px;color:var(--text-muted)}
.empty-state i{font-size:48px;opacity:.3;display:block;margin-bottom:12px}

/* ── GUEST BANNER ── */
.guest-banner{background:linear-gradient(135deg,#141824,#1e2535);color:#fff;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;font-size:13px;border-radius:var(--radius);margin-bottom:20px}
.guest-banner a{color:#f87171;font-weight:700;text-decoration:none}
.guest-banner a:hover{color:#fca5a5}

/* ── OVERLAY ── */
.sidebar-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:999}
@media(max-width:992px){
  .sidebar{transform:translateX(-100%)}
  .sidebar.mobile-open{transform:translateX(0)}
  .main-wrapper{margin-left:0!important}
  .sidebar-overlay{display:block;display:none}
  .sidebar.mobile-open ~ .sidebar-overlay{display:block}
}

/* ── DATATABLE FIXES – top spacing, per-page select, search ── */
.dataTables_wrapper { padding-top: 0; }
.dataTables_wrapper > .row:first-child,
.dataTables_wrapper > .dt-row:first-child { margin-top: 14px; margin-bottom: 10px; }
.dataTables_wrapper .dataTables_length { padding-top: 2px; }
.dataTables_wrapper .dataTables_length label {
  display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-muted); flex-wrap: nowrap; white-space: nowrap;
}
.dataTables_wrapper .dataTables_length select {
  background: var(--body-bg) !important; border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important; padding: 6px 10px !important;
  font-size: 13px !important; color: var(--text-main) !important;
  min-width: 70px; cursor: pointer; display: inline-block;
  -webkit-appearance: auto; appearance: auto;
}
.dataTables_wrapper .dataTables_filter { padding-top: 2px; }
.dataTables_wrapper .dataTables_filter label {
  display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-muted); flex-wrap: nowrap;
}
.dataTables_wrapper .dataTables_filter input {
  background: var(--body-bg) !important; border: 1px solid var(--border) !important;
  border-radius: var(--radius-sm) !important; padding: 7px 12px !important;
  font-size: 13px !important; color: var(--text-main) !important;
  outline: none !important; box-shadow: none !important;
  min-width: 200px;
}
.dataTables_wrapper .dataTables_filter input:focus {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 3px rgba(192,41,58,0.1) !important;
}
.dataTables_wrapper .dataTables_info { font-size: 12.5px !important; color: var(--text-muted) !important; padding-top: 14px !important; }
.dataTables_wrapper .dataTables_paginate { padding-top: 10px !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button { border-radius: 6px !important; padding: 5px 11px !important; font-size: 13px !important; border: 1px solid transparent !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button.current { background: var(--primary) !important; color: #fff !important; border-color: var(--primary) !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button:hover:not(.current):not(.disabled) { background: var(--body-bg) !important; color: var(--text-main) !important; border-color: var(--border) !important; }
.dataTables_wrapper .dataTables_paginate .paginate_button.disabled { color: #ccc !important; cursor: default !important; }

/* Fix Bootstrap 5 DataTables layout – show length left, filter right */
div.dataTables_wrapper div.dataTables_length { float: left; }
div.dataTables_wrapper div.dataTables_filter { float: right; }
div.dataTables_wrapper div.dataTables_length,
div.dataTables_wrapper div.dataTables_filter { padding: 10px 0; }
div.dataTables_wrapper div.dataTables_info { padding-top: 12px; }
div.dataTables_wrapper div.dataTables_paginate { padding-top: 8px; }
