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

:root {
  --navy: #0f1e35; --navy-light: #1a2e4a; --navy-mid: #243855;
  --gold: #c9a84c; --gold-light: #e8c97a; --gold-pale: #fdf6e3;
  --cream: #f9f7f3; --white: #ffffff;
  --text: #1a1a2e; --text-soft: #4a5568; --text-muted: #718096;
  --border: #e2ddd5; --border-light: #f0ece5;
  --success: #2d7d4f; --success-bg: #edf7f1;
  --warning: #b45309; --warning-bg: #fef3c7;
  --danger: #b91c1c; --danger-bg: #fee2e2;
  --info: #1e40af; --info-bg: #dbeafe;
  --review: #6d28d9; --review-bg: #ede9fe;
  --superadmin: #0e7490; --superadmin-bg: #cffafe;
  --shadow-sm: 0 1px 3px rgba(15,30,53,0.08);
  --shadow: 0 4px 16px rgba(15,30,53,0.1);
  --shadow-lg: 0 8px 32px rgba(15,30,53,0.14);
  --radius: 10px; --radius-lg: 16px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 15px; }
body { font-family: 'DM Sans', sans-serif; background: var(--cream); color: var(--text); line-height: 1.6; min-height: 100vh; }

.hidden { display: none !important; }
.flex { display: flex; } .flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; } .justify-between { justify-content: space-between; }
.gap-1{gap:6px}.gap-2{gap:12px}.gap-3{gap:18px}.gap-4{gap:24px}
.w-full{width:100%}.text-sm{font-size:0.8rem}.text-xs{font-size:0.72rem}
.text-muted{color:var(--text-muted)}.font-medium{font-weight:500}.font-semibold{font-weight:600}
.mb-1{margin-bottom:6px}.mb-2{margin-bottom:12px}.mb-3{margin-bottom:18px}.mb-4{margin-bottom:24px}
.mt-2{margin-top:12px}.mt-3{margin-top:18px}

.app-shell { display: flex; min-height: 100vh; }

/* SIDEBAR */
.sidebar { width:240px;min-height:100vh;background:var(--navy);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100; }
.sidebar-logo { padding:24px 20px 18px;border-bottom:1px solid rgba(255,255,255,0.08); }
.sidebar-logo .firm-name { font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--gold-light);letter-spacing:0.01em;line-height:1.3; }
.sidebar-logo .firm-sub { font-size:0.7rem;color:rgba(255,255,255,0.4);letter-spacing:0.08em;text-transform:uppercase;margin-top:2px; }
.sidebar-user { padding:14px 20px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,0.08); }
.avatar { width:36px;height:36px;border-radius:50%;background:var(--gold);color:var(--navy);display:flex;align-items:center;justify-content:center;font-size:0.7rem;font-weight:600;flex-shrink:0; }
.avatar.lg { width:44px;height:44px;font-size:0.82rem; }
.avatar.sa { background:#0e7490;color:#fff; }
.sidebar-user .user-name { font-size:0.82rem;font-weight:500;color:#fff; }
.sidebar-user .user-role { font-size:0.68rem;color:var(--gold);text-transform:uppercase;letter-spacing:0.06em; }
.sidebar-user .user-role.sa { color:#67e8f9; }
.sidebar-nav { flex:1;padding:12px 0;overflow-y:auto; }
.nav-section-label { font-size:0.62rem;text-transform:uppercase;letter-spacing:0.1em;color:rgba(255,255,255,0.3);padding:10px 20px 4px; }
.nav-item { display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:0.82rem;color:rgba(255,255,255,0.65);cursor:pointer;transition:all 0.15s;border-left:3px solid transparent;user-select:none; }
.nav-item:hover { background:rgba(255,255,255,0.06);color:#fff; }
.nav-item.active { background:rgba(201,168,76,0.12);color:var(--gold-light);border-left-color:var(--gold); }
.nav-item.active.sa-active { background:rgba(14,116,144,0.15);color:#67e8f9;border-left-color:#0e7490; }
.nav-item .nav-icon { width:16px;text-align:center;flex-shrink:0;font-size:0.9rem; }
.sidebar-footer { padding:16px 20px;border-top:1px solid rgba(255,255,255,0.08); }
.btn-logout { width:100%;padding:8px;background:rgba(255,255,255,0.05);border:1px solid rgba(255,255,255,0.1);border-radius:var(--radius);color:rgba(255,255,255,0.55);font-size:0.8rem;cursor:pointer;transition:all 0.15s;font-family:inherit; }
.btn-logout:hover { background:rgba(185,28,28,0.2);border-color:rgba(185,28,28,0.4);color:#fca5a5; }

/* MAIN */
.main-content { margin-left:240px;flex:1;min-height:100vh;display:flex;flex-direction:column; }
.page-header { background:var(--white);border-bottom:1px solid var(--border);padding:18px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:50; }
.page-title { font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--navy); }
.page-subtitle { font-size:0.78rem;color:var(--text-muted);margin-top:1px; }
.page-body { padding:28px 32px;flex:1; }

/* CARDS */
.card { background:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border);box-shadow:var(--shadow-sm); }
.card-header { padding:18px 22px 14px;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between; }
.card-title { font-weight:600;font-size:0.9rem;color:var(--navy); }
.card-body { padding:20px 22px; }

/* STATS */
.stats-grid { display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:28px; }
.stat-card { background:var(--white);border-radius:var(--radius);border:1px solid var(--border);padding:18px 20px; }
.stat-label { font-size:0.72rem;text-transform:uppercase;letter-spacing:0.06em;color:var(--text-muted);margin-bottom:6px; }
.stat-value { font-size:1.7rem;font-weight:600;color:var(--navy);line-height:1; }
.stat-sub { font-size:0.72rem;color:var(--text-muted);margin-top:4px; }
.stat-card.gold .stat-value{color:var(--gold)}.stat-card.success .stat-value{color:var(--success)}

/* BADGES */
.badge { display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:20px;font-size:0.7rem;font-weight:500;white-space:nowrap; }
.badge-assigned{background:var(--info-bg);color:var(--info)}
.badge-in_progress{background:var(--warning-bg);color:var(--warning)}
.badge-review{background:var(--review-bg);color:var(--review)}
.badge-finished{background:var(--success-bg);color:var(--success)}
.badge-danger{background:var(--danger-bg);color:var(--danger)}
.badge-partner{background:#fef3c7;color:#92400e}
.badge-employee{background:var(--info-bg);color:var(--info)}
.badge-superadmin{background:var(--superadmin-bg);color:var(--superadmin)}
.badge-inactive{background:#f3f4f6;color:#6b7280}

/* BUTTONS */
.btn { display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--radius);font-size:0.8rem;font-weight:500;cursor:pointer;border:none;font-family:inherit;transition:all 0.15s; }
.btn-primary{background:var(--navy);color:var(--white)}.btn-primary:hover{background:var(--navy-light)}
.btn-gold{background:var(--gold);color:var(--navy)}.btn-gold:hover{background:var(--gold-light)}
.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text)}.btn-outline:hover{border-color:var(--navy);color:var(--navy)}
.btn-success{background:var(--success);color:#fff}.btn-success:hover{opacity:0.9}
.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{opacity:0.9}
.btn-info{background:#0e7490;color:#fff}.btn-info:hover{opacity:0.9}
.btn-sm{padding:5px 11px;font-size:0.74rem}.btn-icon{padding:6px;border-radius:6px}
.btn:disabled{opacity:0.45;cursor:not-allowed}

/* FORMS */
.form-group { margin-bottom:16px; }
.form-label { display:block;font-size:0.78rem;font-weight:500;color:var(--text);margin-bottom:5px; }
.form-control { width:100%;padding:9px 13px;border:1px solid var(--border);border-radius:var(--radius);font-size:0.82rem;font-family:inherit;background:var(--white);color:var(--text);transition:border-color 0.15s; }
.form-control:focus { outline:none;border-color:var(--navy);box-shadow:0 0 0 3px rgba(15,30,53,0.07); }
select.form-control{cursor:pointer}textarea.form-control{resize:vertical;min-height:80px}
.form-row{display:grid;gap:14px}.form-row.cols-2{grid-template-columns:1fr 1fr}.form-row.cols-3{grid-template-columns:1fr 1fr 1fr}
.form-hint { font-size:0.72rem;color:var(--text-muted);margin-top:4px; }

/* TABLE */
.table-wrap { overflow-x:auto; }
table { width:100%;border-collapse:collapse;font-size:0.8rem; }
thead th { padding:10px 14px;text-align:left;font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.05em;color:var(--text-muted);background:var(--cream);border-bottom:1px solid var(--border); }
tbody td { padding:12px 14px;border-bottom:1px solid var(--border-light);color:var(--text);vertical-align:middle; }
tbody tr:last-child td { border-bottom:none; }
tbody tr:hover td { background:rgba(15,30,53,0.02); }
.td-actions { display:flex;gap:6px;align-items:center; }

/* MODAL */
.modal-overlay { position:fixed;inset:0;background:rgba(15,30,53,0.55);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn 0.15s; }
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
.modal { background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:580px;max-height:90vh;overflow-y:auto;animation:slideUp 0.2s; }
.modal-lg { max-width:720px; }
@keyframes slideUp{from{transform:translateY(20px);opacity:0}to{transform:none;opacity:1}}
.modal-header { padding:20px 24px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between; }
.modal-title { font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--navy); }
.modal-close { background:none;border:none;font-size:1.3rem;color:var(--text-muted);cursor:pointer;padding:2px 6px;border-radius:4px;line-height:1; }
.modal-close:hover{background:var(--border-light)}
.modal-body { padding:22px 24px; }
.modal-footer { padding:14px 24px 20px;display:flex;gap:10px;justify-content:flex-end;border-top:1px solid var(--border-light); }

/* TASK CARDS (employee) */
.task-list{display:flex;flex-direction:column;gap:14px}
.task-card { background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px;border-left:4px solid var(--border);transition:box-shadow 0.15s; }
.task-card:hover{box-shadow:var(--shadow)}
.task-card.assigned{border-left-color:#3b82f6}.task-card.in_progress{border-left-color:#f59e0b}
.task-card.review{border-left-color:#8b5cf6}.task-card.finished{border-left-color:#10b981}
.task-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:10px}
.task-client{font-weight:600;font-size:0.9rem;color:var(--navy)}
.task-type{font-size:0.75rem;color:var(--text-muted);margin-top:2px}
.task-meta{display:flex;gap:18px;flex-wrap:wrap;margin-top:8px}
.task-meta-item{font-size:0.75rem;color:var(--text-muted);display:flex;align-items:center;gap:4px}
.task-meta-item strong{color:var(--text);font-weight:500}
.task-actions{margin-top:14px;display:flex;gap:8px;flex-wrap:wrap}

/* ALERTS */
.alert{padding:12px 16px;border-radius:var(--radius);font-size:0.82rem;margin-bottom:16px}
.alert-info{background:var(--info-bg);color:var(--info);border:1px solid #bfdbfe}
.alert-success{background:var(--success-bg);color:var(--success);border:1px solid #a7f3d0}
.alert-warning{background:var(--warning-bg);color:var(--warning);border:1px solid #fde68a}
.alert-danger{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}

/* FEEDBACK BOX */
.feedback-box{background:var(--gold-pale);border:1px solid #e8d9a0;border-radius:var(--radius);padding:14px 16px;margin-top:12px}
.feedback-box .fb-label{font-size:0.7rem;font-weight:600;text-transform:uppercase;letter-spacing:0.06em;color:var(--gold);margin-bottom:4px}
.feedback-box p{font-size:0.82rem;color:var(--text)}

/* FILTER BAR */
.filter-bar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:20px}
.filter-bar .form-control{width:auto;min-width:150px}
.search-box{position:relative}
.search-box input{padding-left:32px}
.search-box .search-icon{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:0.85rem}

/* TABS */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--border);margin-bottom:22px}
.tab{padding:10px 18px;font-size:0.8rem;font-weight:500;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all 0.15s}
.tab:hover{color:var(--navy)}.tab.active{color:var(--navy);border-bottom-color:var(--navy)}

/* EMPTY STATE */
.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}
.empty-state .empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:0.4}
.empty-state p{font-size:0.85rem}

/* USER MANAGEMENT CARDS */
.user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px}
.user-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:18px 20px}
.user-card.inactive{opacity:0.6;border-style:dashed}

/* REPORT TABLE HIGHLIGHT */
.report-total td{background:var(--cream);font-weight:600;color:var(--navy)}
.month-section{margin-bottom:28px}
.month-heading{font-size:0.78rem;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;color:var(--text-muted);margin-bottom:12px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* DIVIDER */
.divider{border:none;border-top:1px solid var(--border-light);margin:16px 0}

/* RESPONSIVE */
@media (max-width:768px){
  .sidebar{transform:translateX(-100%)}.sidebar.open{transform:none}
  .main-content{margin-left:0}.page-body{padding:20px 16px}
  .form-row.cols-2,.form-row.cols-3{grid-template-columns:1fr}
  .stats-grid{grid-template-columns:1fr 1fr}
}

/* PRINT */
@media print{
  .sidebar,.page-header,.btn,nav,.modal-footer{display:none !important}
  .main-content{margin-left:0}
  .invoice-box{box-shadow:none;border:none}
}
