/* ============================================================
   InvoiceFlow — Main Stylesheet
   ============================================================ */
:root {
  --bg: #07070f;
  --surface: #0f0f1a;
  --surface2: #171726;
  --surface3: #1e1e30;
  --border: #252538;
  --border2: #353550;
  --accent: #6c63ff;
  --accent2: #a855f7;
  --accent3: #06b6d4;
  --success: #10b981;
  --warning: #f59e0b;
  --danger: #ef4444;
  --info: #3b82f6;
  --text: #f0f0f8;
  --text2: #a0a0c0;
  --text3: #55557a;
  --radius: 12px;
  --radius-sm: 8px;
  --shadow: 0 4px 24px rgba(0,0,0,0.5);
  --sidebar-w: 248px;
  --topbar-h: 64px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;}
a{color:inherit;text-decoration:none;}
input,select,textarea,button{font-family:inherit;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:var(--surface);}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px;}

/* ===== LAYOUT ===== */
.app-layout{display:flex;min-height:100vh;}

/* ===== SIDEBAR ===== */
.sidebar{
  width:var(--sidebar-w);background:var(--surface);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;z-index:200;
  transition:transform .3s ease;
}
.sidebar-logo{
  display:flex;align-items:center;gap:12px;
  padding:22px 18px;border-bottom:1px solid var(--border);
}
.logo-icon{
  width:38px;height:38px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  border-radius:10px;display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-weight:800;font-size:14px;color:#fff;flex-shrink:0;
}
.logo-name{font-family:'Syne',sans-serif;font-weight:800;font-size:17px;background:linear-gradient(135deg,var(--accent),var(--accent2));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;}
.logo-sub{font-size:10px;color:var(--text3);letter-spacing:.08em;text-transform:uppercase;}
.sidebar-nav{flex:1;overflow-y:auto;padding:16px 10px;}
.nav-group{margin-bottom:20px;}
.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text3);padding:0 8px;margin-bottom:6px;}
.nav-item{
  display:flex;align-items:center;gap:9px;
  padding:9px 10px;border-radius:var(--radius-sm);
  font-size:14px;color:var(--text2);
  transition:all .15s;margin-bottom:2px;
  border:1px solid transparent;
}
.nav-item:hover{background:var(--surface2);color:var(--text);}
.nav-item.active{background:linear-gradient(135deg,rgba(108,99,255,.15),rgba(168,85,247,.08));border-color:rgba(108,99,255,.3);color:var(--text);}
.ni{width:18px;text-align:center;font-size:15px;}
.sidebar-user{
  padding:14px 12px;border-top:1px solid var(--border);
  display:flex;align-items:center;gap:10px;
}
.user-avatar,.chip-avatar{
  width:34px;height:34px;border-radius:9px;flex-shrink:0;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  display:flex;align-items:center;justify-content:center;
  font-family:'Syne',sans-serif;font-weight:800;font-size:13px;color:#fff;
}
.user-info{flex:1;min-width:0;}
.user-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.user-role{font-size:11px;color:var(--text3);}
.logout-btn{color:var(--text3);font-size:18px;padding:4px;transition:color .15s;}
.logout-btn:hover{color:var(--danger);}

/* ===== TOPBAR ===== */
.main-content{margin-left:var(--sidebar-w);flex:1;min-height:100vh;display:flex;flex-direction:column;}
.topbar{
  height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);
  padding:0 24px;display:flex;align-items:center;justify-content:space-between;
  position:sticky;top:0;z-index:100;
}
.topbar-left{display:flex;align-items:center;gap:14px;}
.sidebar-toggle{background:none;border:none;cursor:pointer;font-size:20px;color:var(--text2);display:none;padding:4px;}
.page-title{font-family:'Syne',sans-serif;font-size:19px;font-weight:700;}
.page-sub{font-size:12px;color:var(--text3);margin-top:1px;}
.topbar-right{display:flex;align-items:center;gap:12px;}
.user-chip{
  display:flex;align-items:center;gap:8px;
  background:var(--surface2);border:1px solid var(--border);
  border-radius:20px;padding:5px 12px 5px 5px;
  font-size:13px;cursor:pointer;
}
.chip-avatar{width:26px;height:26px;border-radius:6px;font-size:11px;}
.content-area{flex:1;padding:24px;}

/* ===== BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 18px;border-radius:var(--radius-sm);
  font-size:14px;font-weight:500;cursor:pointer;
  transition:all .15s;border:none;white-space:nowrap;
  font-family:'DM Sans',sans-serif;
}
.btn-primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#fff;box-shadow:0 4px 12px rgba(108,99,255,.3);}
.btn-primary:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 6px 20px rgba(108,99,255,.4);}
.btn-secondary{background:var(--surface2);color:var(--text2);border:1px solid var(--border);}
.btn-secondary:hover{background:var(--surface3);color:var(--text);border-color:var(--border2);}
.btn-ghost{background:transparent;color:var(--text2);border:1px solid transparent;}
.btn-ghost:hover{background:var(--surface2);color:var(--text);}
.btn-success{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.3);}
.btn-success:hover{background:rgba(16,185,129,.2);}
.btn-danger{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.3);}
.btn-danger:hover{background:rgba(239,68,68,.2);}
.btn-warning{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.3);}
.btn-warning:hover{background:rgba(245,158,11,.2);}
.btn-sm{padding:6px 13px;font-size:13px;}
.btn-xs{padding:4px 9px;font-size:12px;}
.btn-icon{padding:8px;border-radius:var(--radius-sm);}
a.btn{text-decoration:none;}

/* ===== CARDS ===== */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;}
.card-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;}
.card-title{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;}
.card-body{padding:20px;}
.card-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:10px;}

/* ===== STATS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.stat-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;position:relative;overflow:hidden;
  transition:all .2s;
}
.stat-card:hover{border-color:var(--border2);transform:translateY(-2px);}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--accent),var(--accent2));}
.stat-icon{position:absolute;top:18px;right:18px;font-size:26px;opacity:.12;}
.stat-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;}
.stat-value{font-family:'Syne',sans-serif;font-size:26px;font-weight:700;}
.stat-change{font-size:12px;margin-top:5px;}
.stat-change.up{color:var(--success);}
.stat-change.down{color:var(--danger);}
.stat-change.neutral{color:var(--text3);}

/* ===== TABLES ===== */
.table-wrap{overflow-x:auto;}
table{width:100%;border-collapse:collapse;}
th{text-align:left;padding:11px 14px;font-size:11px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);background:var(--surface2);border-bottom:1px solid var(--border);white-space:nowrap;cursor:pointer;}
th:hover{color:var(--text2);}
td{padding:13px 14px;font-size:14px;border-bottom:1px solid var(--border);vertical-align:middle;}
tr:hover td{background:rgba(108,99,255,.04);}
tr:last-child td{border-bottom:none;}

/* ===== FORMS ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-grid-3{grid-template-columns:1fr 1fr 1fr;}
.form-full{grid-column:1/-1;}
.form-group{display:flex;flex-direction:column;gap:5px;}
.form-label{font-size:12px;font-weight:500;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;}
.form-control{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:10px 12px;
  color:var(--text);font-size:14px;outline:none;
  transition:border-color .15s;width:100%;
}
.form-control:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(108,99,255,.1);}
.form-control::placeholder{color:var(--text3);}
.form-control:disabled{opacity:.5;cursor:not-allowed;}
textarea.form-control{resize:vertical;min-height:80px;}
select.form-control{cursor:pointer;}
.form-hint{font-size:11px;color:var(--text3);margin-top:3px;}
.form-error{font-size:11px;color:var(--danger);margin-top:3px;}

/* ===== SECTION DIVIDER ===== */
.section-title{
  font-family:'Syne',sans-serif;font-size:14px;font-weight:700;color:var(--text2);
  padding-bottom:10px;margin:20px 0 16px;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:8px;
}
.section-title::before{content:'';width:3px;height:16px;background:linear-gradient(var(--accent),var(--accent2));border-radius:2px;}

/* ===== BADGES ===== */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:500;}
.badge::before{content:'';width:5px;height:5px;border-radius:50%;}
.badge-paid{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.2);}
.badge-paid::before{background:var(--success);}
.badge-pending{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.2);}
.badge-pending::before{background:var(--warning);}
.badge-draft{background:rgba(96,96,150,.12);color:var(--text3);border:1px solid var(--border);}
.badge-draft::before{background:var(--text3);}
.badge-overdue{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2);}
.badge-overdue::before{background:var(--danger);box-shadow:0 0 5px var(--danger);}
.badge-cancelled{background:rgba(96,96,150,.1);color:var(--text3);border:1px solid var(--border);}
.badge-cancelled::before{background:var(--text3);}
.badge-approved{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.2);}
.badge-approved::before{background:var(--success);}
.badge-rejected{background:rgba(239,68,68,.1);color:var(--danger);border:1px solid rgba(239,68,68,.2);}
.badge-rejected::before{background:var(--danger);}
.badge-on_hold{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.2);}
.badge-on_hold::before{background:var(--warning);}
.badge-active{background:rgba(16,185,129,.1);color:var(--success);border:1px solid rgba(16,185,129,.2);}
.badge-active::before{background:var(--success);}
.badge-inactive{background:rgba(96,96,150,.1);color:var(--text3);border:1px solid var(--border);}
.badge-inactive::before{background:var(--text3);}

.service-tag{display:inline-block;padding:3px 9px;border-radius:5px;font-size:11px;font-weight:500;}
.tag-ssm{background:rgba(6,182,212,.1);color:var(--accent3);border:1px solid rgba(6,182,212,.2);}
.tag-web{background:rgba(108,99,255,.1);color:var(--accent);border:1px solid rgba(108,99,255,.2);}
.tag-saas{background:rgba(168,85,247,.1);color:var(--accent2);border:1px solid rgba(168,85,247,.2);}
.tag-combo{background:rgba(245,158,11,.1);color:var(--warning);border:1px solid rgba(245,158,11,.2);}
.tag-other{background:var(--surface3);color:var(--text2);border:1px solid var(--border);}

/* ===== FLASH ===== */
.flash-msg{
  position:fixed;top:18px;right:18px;z-index:9999;
  background:var(--surface2);border-radius:var(--radius-sm);
  padding:13px 16px;display:flex;align-items:center;gap:10px;
  box-shadow:var(--shadow);font-size:14px;max-width:360px;
  border-left:3px solid var(--success);transition:opacity .5s;
}
.flash-error{border-left-color:var(--danger);}
.flash-msg button{background:none;border:none;cursor:pointer;color:var(--text3);margin-left:8px;font-size:16px;}

/* ===== TOAST ===== */
.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;}
.toast{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:13px 16px;
  font-size:13px;box-shadow:var(--shadow);
  display:flex;align-items:center;gap:8px;
  animation:slideInRight .3s ease;
  min-width:240px;max-width:340px;
}
@keyframes slideInRight{from{transform:translateX(100%);opacity:0}to{transform:none;opacity:1}}
.toast.success{border-left:3px solid var(--success);}
.toast.error{border-left:3px solid var(--danger);}
.toast.info{border-left:3px solid var(--accent);}

/* ===== SEARCH & FILTERS ===== */
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;padding:14px 18px;border-bottom:1px solid var(--border);}
.search-box{display:flex;align-items:center;gap:7px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;flex:1;min-width:200px;max-width:320px;}
.search-box input{background:none;border:none;outline:none;color:var(--text);font-size:14px;font-family:'DM Sans',sans-serif;flex:1;}
.search-box input::placeholder{color:var(--text3);}
.filter-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:8px 12px;color:var(--text2);font-size:13px;cursor:pointer;outline:none;font-family:'DM Sans',sans-serif;}
.filter-select:focus{border-color:var(--accent);}

/* ===== INVOICE SPECIFIC ===== */
.inv-id{font-family:'JetBrains Mono',monospace;font-size:13px;color:var(--accent);font-weight:500;}
.amount{font-family:'JetBrains Mono',monospace;}
.actions-cell{display:flex;gap:5px;align-items:center;}

/* ===== LINE ITEMS ===== */
.li-table{width:100%;border-collapse:collapse;font-size:13px;}
.li-table th{background:var(--surface2);padding:9px 10px;font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text3);border-bottom:1px solid var(--border);}
.li-table td{padding:7px 5px;border-bottom:1px solid var(--border);}
.li-table tr:last-child td{border-bottom:none;}
.li-table .form-control{padding:8px 10px;}
.add-row-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:10px;margin-top:8px;background:rgba(108,99,255,.06);border:1px dashed rgba(108,99,255,.3);border-radius:var(--radius-sm);color:var(--accent);cursor:pointer;font-size:13px;transition:all .15s;}
.add-row-btn:hover{background:rgba(108,99,255,.12);border-color:var(--accent);}
.remove-row{background:none;border:none;cursor:pointer;color:var(--danger);font-size:16px;opacity:.6;transition:opacity .15s;padding:3px;}
.remove-row:hover{opacity:1;}
.totals-block{display:flex;flex-direction:column;align-items:flex-end;gap:5px;margin-top:16px;}
.total-row{display:flex;gap:20px;font-size:14px;}
.total-row .lbl{color:var(--text3);min-width:120px;text-align:right;}
.total-row .val{font-family:'JetBrains Mono',monospace;min-width:110px;text-align:right;}
.total-row.grand{padding-top:8px;border-top:1px solid var(--border);font-size:17px;font-family:'Syne',sans-serif;font-weight:700;}
.total-row.grand .val{color:var(--accent);}

/* ===== TEMPLATES GRID ===== */
.tpl-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;}
.tpl-card{background:var(--surface2);border:2px solid var(--border);border-radius:var(--radius);padding:12px;cursor:pointer;transition:all .2s;position:relative;}
.tpl-card:hover{border-color:var(--accent);transform:translateY(-2px);}
.tpl-card.selected{border-color:var(--accent);background:rgba(108,99,255,.08);}
.tpl-card.selected::after{content:'✓';position:absolute;top:8px;right:10px;width:20px;height:20px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;color:#fff;}
.tpl-preview{height:80px;border-radius:7px;margin-bottom:10px;overflow:hidden;position:relative;}
.tpl-name{font-weight:600;font-size:13px;margin-bottom:3px;}
.tpl-desc{font-size:11px;color:var(--text3);}
.tpl-modern-prev{background:linear-gradient(135deg,#0a0a1f,#16163a);}
.tpl-modern-prev::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;background:linear-gradient(var(--accent),var(--accent2));}
.tpl-classic-prev{background:#fff;}
.tpl-classic-prev::before{content:'';position:absolute;top:0;left:0;right:0;height:24px;background:#1a1a2e;}
.tpl-minimal-prev{background:#f8f9fa;}
.tpl-corporate-prev{background:linear-gradient(135deg,#1e3a5f,#0d2137);}

/* ===== EMPLOYEE CARDS ===== */
.emp-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;}
.emp-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;transition:all .2s;}
.emp-card:hover{border-color:var(--border2);}
.emp-avatar{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--accent),var(--accent2));display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:18px;color:#fff;margin-bottom:12px;}
.emp-name{font-family:'Syne',sans-serif;font-weight:700;font-size:15px;margin-bottom:3px;}
.emp-role{font-size:12px;color:var(--text3);}

/* ===== LOGIN PAGE ===== */
.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:20px;}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:40px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.5);}
.login-logo{text-align:center;margin-bottom:28px;}
.login-logo-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--accent),var(--accent2));border-radius:14px;display:flex;align-items:center;justify-content:center;font-family:'Syne',sans-serif;font-weight:800;font-size:20px;color:#fff;margin:0 auto 12px;}
.login-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;}
.login-sub{font-size:13px;color:var(--text3);margin-top:4px;}
.login-error{background:rgba(239,68,68,.1);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-sm);padding:10px 14px;font-size:13px;color:var(--danger);margin-bottom:16px;}

/* ===== CHARTS (CSS only) ===== */
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:150px;padding:8px 0;}
.bar{flex:1;background:linear-gradient(var(--accent),var(--accent2));border-radius:4px 4px 0 0;min-height:3px;opacity:.8;transition:opacity .2s;position:relative;cursor:pointer;}
.bar:hover{opacity:1;}
.bar-labels{display:flex;gap:6px;}
.bar-label{flex:1;text-align:center;font-size:10px;color:var(--text3);margin-top:5px;}

/* ===== INVOICE PRINT STYLES ===== */
@media print{
  .sidebar,.topbar,.btn,.actions-cell,.toolbar{display:none!important;}
  .main-content{margin-left:0!important;}
  .content-area{padding:0!important;}
  .invoice-print-page{padding:0!important;}
}

/* ===== TABS ===== */
.tabs{display:flex;gap:3px;background:var(--surface2);padding:4px;border-radius:var(--radius-sm);margin-bottom:20px;}
.tab-btn{padding:7px 16px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;color:var(--text3);transition:all .15s;background:none;border:none;font-family:'DM Sans',sans-serif;}
.tab-btn.active{background:var(--surface);color:var(--text);box-shadow:0 1px 6px rgba(0,0,0,.25);}
.tab-btn:hover:not(.active){color:var(--text2);}
.tab-pane{display:none;}
.tab-pane.active{display:block;}

/* ===== EMPTY STATE ===== */
.empty-state{text-align:center;padding:48px 20px;color:var(--text3);}
.empty-state .es-icon{font-size:44px;margin-bottom:14px;}
.empty-state h3{font-family:'Syne',sans-serif;font-size:17px;color:var(--text2);margin-bottom:7px;}
.empty-state p{font-size:13px;}

/* ===== PAGINATION ===== */
.pagination{display:flex;align-items:center;gap:5px;justify-content:center;padding:16px;}
.page-btn{width:34px;height:34px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:13px;cursor:pointer;border:1px solid var(--border);background:var(--surface2);color:var(--text2);transition:all .15s;}
.page-btn:hover,.page-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;}

/* ===== RESPONSIVE ===== */
@media(max-width:1200px){.stats-grid{grid-template-columns:1fr 1fr;}.tpl-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:none;}
  .main-content{margin-left:0;}
  .sidebar-toggle{display:block;}
  .stats-grid{grid-template-columns:1fr;}
  .form-grid{grid-template-columns:1fr;}
  .form-grid-3{grid-template-columns:1fr;}
}
@media(max-width:600px){.content-area{padding:14px;}}

/* ===== MODAL (pure CSS) ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);backdrop-filter:blur(6px);z-index:500;display:none;align-items:flex-start;justify-content:center;padding:20px;overflow-y:auto;}
.modal-overlay.open{display:flex;animation:fadeIn .2s ease;}
.modal{background:var(--surface);border:1px solid var(--border);border-radius:14px;width:100%;max-width:560px;margin:auto;box-shadow:0 20px 60px rgba(0,0,0,.5);animation:slideUp .25s ease;}
.modal-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;}
.modal-title{font-family:'Syne',sans-serif;font-size:16px;font-weight:700;}
.modal-close{width:30px;height:30px;background:var(--surface2);border:1px solid var(--border);border-radius:7px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text2);font-size:14px;transition:all .15s;}
.modal-close:hover{background:var(--surface3);color:var(--text);}
.modal-body{padding:22px 24px;}
.modal-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:flex-end;gap:10px;}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(24px);opacity:0}to{transform:none;opacity:1}}

/* ===== PAYSLIP ===== */
.payslip{background:#fff;color:#1a1a2e;padding:36px;max-width:680px;margin:0 auto;font-family:'DM Sans',sans-serif;}
.payslip-header{background:#0a0a1f;color:#fff;margin:-36px -36px 24px;padding:24px 36px;display:flex;justify-content:space-between;align-items:center;}
.payslip-title{font-family:'Syne',sans-serif;font-size:22px;font-weight:800;color:#6c63ff;}
.payslip table{width:100%;font-size:13px;}
.payslip th{background:#f5f5f5;color:#444;font-size:11px;text-transform:uppercase;letter-spacing:.06em;padding:9px 12px;text-align:left;border-bottom:1px solid #e0e0e0;}
.payslip td{padding:9px 12px;border-bottom:1px solid #f0f0f0;}
.payslip .net-row td{background:#0a0a1f;color:#fff;font-weight:700;font-family:'Syne',sans-serif;font-size:15px;}
