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

:root {
    --sidebar-bg: #0d1526;
    --sidebar-hover: #162040;
    --sidebar-active: #1e3a6e;
    --accent: #4f7bff;
    --accent-2: #00d4aa;
    --accent-glow: rgba(79,123,255,0.25);
    --body-bg: #f0f4ff;
    --card-bg: #ffffff;
    --text-dark: #0d1a3a;
    --text-mid: #4a5568;
    --text-light: #8a95b0;
    --border: #e2e8f8;
    --success: #10b981;
    --danger: #ef4444;
    --warning: #f59e0b;
    --info: #3b82f6;
    --shadow-sm: 0 2px 8px rgba(13,26,58,0.07);
    --shadow-md: 0 8px 30px rgba(13,26,58,0.12);
    --shadow-lg: 0 20px 60px rgba(13,26,58,0.18);
    --radius: 14px;
    --radius-sm: 8px;
    --sidebar-w: 260px;
    --topbar-h: 64px;
}

* { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Outfit',sans-serif; background:var(--body-bg); color:var(--text-dark); min-height:100vh; }

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

/* SIDEBAR */
.sidebar {
    width:var(--sidebar-w);
    background:var(--sidebar-bg);
    position:fixed; top:0; left:0; height:100vh;
    display:flex; flex-direction:column;
    z-index:100; overflow-y:auto;
    border-right:1px solid rgba(255,255,255,0.04);
}
.sidebar-logo {
    padding:24px 20px 20px;
    border-bottom:1px solid rgba(255,255,255,0.06);
    display:flex; align-items:center; gap:12px;
}
.logo-icon {
    width:42px; height:42px; border-radius:12px;
    background:linear-gradient(135deg,#4f7bff,#00d4aa);
    display:flex; align-items:center; justify-content:center;
    font-size:18px; color:white; font-weight:800;
    box-shadow:0 4px 15px rgba(79,123,255,0.35);
    flex-shrink:0;
}
.logo-text { color:white; }
.logo-text h2 { font-size:18px; font-weight:800; letter-spacing:2px; line-height:1; }
.logo-text small { font-size:10px; color:rgba(255,255,255,0.4); letter-spacing:1px; text-transform:uppercase; }

.nav-section { padding:16px 12px 6px; }
.nav-section-title { font-size:9px; text-transform:uppercase; letter-spacing:2px; color:rgba(255,255,255,0.3); padding:0 10px; margin-bottom:6px; font-weight:600; }

.nav-item { display:block; padding:11px 14px; border-radius:10px; color:rgba(255,255,255,0.55); text-decoration:none; display:flex; align-items:center; gap:12px; font-size:13.5px; font-weight:500; transition:all 0.2s; margin-bottom:2px; }
.nav-item i { width:18px; text-align:center; font-size:14px; }
.nav-item:hover { background:var(--sidebar-hover); color:rgba(255,255,255,0.85); }
.nav-item.active { background:var(--sidebar-active); color:white; }
.nav-item.active i { color:var(--accent); }
.nav-badge { margin-left:auto; background:var(--danger); color:white; font-size:10px; padding:2px 7px; border-radius:20px; font-weight:600; }

.sidebar-footer { margin-top:auto; padding:16px 12px; border-top:1px solid rgba(255,255,255,0.06); }
.user-info { display:flex; align-items:center; gap:12px; padding:10px; border-radius:10px; background:rgba(255,255,255,0.05); }
.avatar { width:36px; height:36px; border-radius:50%; background:linear-gradient(135deg,#4f7bff,#00d4aa); display:flex; align-items:center; justify-content:center; color:white; font-weight:700; font-size:13px; }
.user-meta { flex:1; min-width:0; }
.user-meta strong { color:white; font-size:13px; display:block; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.user-meta span { color:rgba(255,255,255,0.4); font-size:11px; }
.logout-btn { color:rgba(255,255,255,0.4); font-size:14px; text-decoration:none; }
.logout-btn:hover { color:var(--danger); }

/* TOPBAR */
.topbar {
    height:var(--topbar-h); background:white; border-bottom:1px solid var(--border);
    display:flex; align-items:center; justify-content:space-between;
    padding:0 28px; position:sticky; top:0; z-index:50;
    box-shadow:var(--shadow-sm);
}
.topbar h1 { font-size:18px; font-weight:700; color:var(--text-dark); }
.topbar-right { display:flex; align-items:center; gap:16px; }
.wallet-chip { background:linear-gradient(135deg,#0d1526,#1e3a6e); color:white; padding:7px 16px; border-radius:30px; font-size:13px; font-weight:600; display:flex; align-items:center; gap:8px; }
.wallet-chip i { color:#00d4aa; }

/* MAIN CONTENT */
.main { margin-left:var(--sidebar-w); flex:1; display:flex; flex-direction:column; min-height:100vh; }
.content { padding:28px; flex:1; }

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

/* STAT CARDS */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:20px; margin-bottom:28px; }
.stat-card { background:var(--card-bg); border-radius:var(--radius); padding:22px; box-shadow:var(--shadow-sm); border:1px solid var(--border); display:flex; align-items:center; gap:18px; transition:transform 0.2s,box-shadow 0.2s; }
.stat-card:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.stat-icon { width:52px; height:52px; border-radius:14px; display:flex; align-items:center; justify-content:center; font-size:20px; flex-shrink:0; }
.stat-icon.blue { background:rgba(79,123,255,0.1); color:var(--accent); }
.stat-icon.green { background:rgba(16,185,129,0.1); color:var(--success); }
.stat-icon.amber { background:rgba(245,158,11,0.1); color:var(--warning); }
.stat-icon.red { background:rgba(239,68,68,0.1); color:var(--danger); }
.stat-icon.teal { background:rgba(0,212,170,0.1); color:var(--accent-2); }
.stat-val { font-size:24px; font-weight:800; color:var(--text-dark); line-height:1; }
.stat-label { font-size:12px; color:var(--text-light); margin-top:4px; font-weight:500; text-transform:uppercase; letter-spacing:0.5px; }

/* SERVICE CARDS */
.service-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(240px,1fr)); gap:20px; }
.service-card {
    background:var(--card-bg); border-radius:var(--radius); border:2px solid var(--border);
    padding:24px; cursor:pointer; text-decoration:none; color:inherit;
    display:flex; flex-direction:column; gap:14px;
    transition:all 0.25s; position:relative; overflow:hidden;
}
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:4px; background:linear-gradient(90deg,var(--accent),var(--accent-2)); }
.service-card:hover { border-color:var(--accent); transform:translateY(-3px); box-shadow:0 12px 35px var(--accent-glow); }
.service-icon { width:50px; height:50px; border-radius:14px; background:linear-gradient(135deg,rgba(79,123,255,0.12),rgba(0,212,170,0.08)); display:flex; align-items:center; justify-content:center; font-size:22px; color:var(--accent); }
.service-name { font-size:15px; font-weight:700; color:var(--text-dark); }
.service-price { font-size:20px; font-weight:800; color:var(--accent); }
.service-price span { font-size:11px; font-weight:400; color:var(--text-light); }
.service-desc { font-size:12px; color:var(--text-mid); line-height:1.5; }
.service-arrow { margin-top:auto; color:var(--accent); font-size:13px; font-weight:600; display:flex; align-items:center; gap:6px; }

/* BUTTONS */
.btn { display:inline-flex; align-items:center; gap:8px; padding:10px 20px; border-radius:var(--radius-sm); font-size:13.5px; font-weight:600; cursor:pointer; border:none; text-decoration:none; transition:all 0.2s; font-family:inherit; }
.btn-primary { background:linear-gradient(135deg,#4f7bff,#3b63d8); color:white; box-shadow:0 4px 15px rgba(79,123,255,0.3); }
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 6px 20px rgba(79,123,255,0.4); }
.btn-success { background:linear-gradient(135deg,#10b981,#059669); color:white; }
.btn-success:hover { transform:translateY(-1px); }
.btn-danger { background:linear-gradient(135deg,#ef4444,#dc2626); color:white; }
.btn-danger:hover { transform:translateY(-1px); }
.btn-warning { background:linear-gradient(135deg,#f59e0b,#d97706); color:white; }
.btn-outline { background:transparent; border:2px solid var(--border); color:var(--text-mid); }
.btn-outline:hover { border-color:var(--accent); color:var(--accent); background:rgba(79,123,255,0.04); }
.btn-sm { padding:7px 14px; font-size:12px; }
.btn-lg { padding:14px 28px; font-size:15px; }

/* FORMS */
.form-group { margin-bottom:20px; }
.form-label { display:block; font-size:13px; font-weight:600; color:var(--text-dark); margin-bottom:6px; }
.form-label .required { color:var(--danger); }
.form-control { width:100%; padding:11px 14px; border:2px solid var(--border); border-radius:var(--radius-sm); font-size:14px; font-family:inherit; color:var(--text-dark); background:white; transition:border-color 0.2s,box-shadow 0.2s; outline:none; }
.form-control:focus { border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-glow); }
.form-hint { font-size:11.5px; color:var(--text-light); margin-top:5px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
select.form-control { appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a95b0' d='M6 8L1 3h10z'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; }

/* TABLES */
.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; }
thead th { background:#f8faff; padding:12px 16px; font-size:11.5px; font-weight:700; text-transform:uppercase; letter-spacing:0.5px; color:var(--text-light); border-bottom:2px solid var(--border); white-space:nowrap; }
tbody td { padding:14px 16px; border-bottom:1px solid var(--border); font-size:13.5px; color:var(--text-mid); vertical-align:middle; }
tbody tr:hover td { background:#f8faff; }
tbody tr:last-child td { border-bottom:none; }

/* BADGES */
.badge { display:inline-flex; align-items:center; gap:5px; padding:4px 12px; border-radius:20px; font-size:11.5px; font-weight:600; }
.badge::before { content:''; width:6px; height:6px; border-radius:50%; background:currentColor; }
.badge-warning { background:#fef3c7; color:#d97706; }
.badge-success { background:#d1fae5; color:#059669; }
.badge-danger { background:#fee2e2; color:#dc2626; }
.badge-secondary { background:#f1f5f9; color:#64748b; }
.badge-info { background:#dbeafe; color:#2563eb; }

/* ALERTS */
.alert { padding:14px 18px; border-radius:var(--radius-sm); font-size:13.5px; margin-bottom:20px; display:flex; align-items:flex-start; gap:10px; }
.alert i { margin-top:1px; }
.alert-success { background:#d1fae5; color:#065f46; border-left:4px solid var(--success); }
.alert-danger { background:#fee2e2; color:#991b1b; border-left:4px solid var(--danger); }
.alert-warning { background:#fef3c7; color:#92400e; border-left:4px solid var(--warning); }
.alert-info { background:#dbeafe; color:#1e40af; border-left:4px solid var(--info); }

/* TOGGLE */
.toggle { position:relative; display:inline-block; width:44px; height:24px; }
.toggle input { opacity:0; width:0; height:0; }
.slider { position:absolute; cursor:pointer; top:0;left:0;right:0;bottom:0; background:#e2e8f0; border-radius:34px; transition:0.3s; }
.slider:before { position:absolute; content:""; height:18px; width:18px; left:3px; bottom:3px; background:white; border-radius:50%; transition:0.3s; box-shadow:0 1px 4px rgba(0,0,0,0.2); }
input:checked + .slider { background:var(--accent); }
input:checked + .slider:before { transform:translateX(20px); }

/* WALLET CARD */
.wallet-card { background:linear-gradient(135deg,#0d1526,#1e3a6e); border-radius:var(--radius); padding:28px; color:white; position:relative; overflow:hidden; }
.wallet-card::after { content:''; position:absolute; right:-30px; top:-30px; width:150px; height:150px; border-radius:50%; background:rgba(79,123,255,0.15); }
.wallet-card::before { content:''; position:absolute; right:40px; bottom:-20px; width:100px; height:100px; border-radius:50%; background:rgba(0,212,170,0.1); }
.wallet-amount { font-size:36px; font-weight:800; position:relative; z-index:1; }
.wallet-label { font-size:12px; text-transform:uppercase; letter-spacing:2px; opacity:0.6; margin-bottom:8px; }

/* PAGE HEADER */
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:24px; }
.page-title { font-size:22px; font-weight:800; color:var(--text-dark); }
.page-title small { font-size:13px; font-weight:400; color:var(--text-light); display:block; margin-top:3px; }
.breadcrumb { display:flex; align-items:center; gap:6px; font-size:13px; color:var(--text-light); }
.breadcrumb a { color:var(--accent); text-decoration:none; }

/* REQUEST DETAIL */
.req-detail { background:#f8faff; border:1px solid var(--border); border-radius:var(--radius-sm); padding:16px; }
.req-detail p { font-size:13px; color:var(--text-mid); margin-bottom:8px; }
.req-detail strong { color:var(--text-dark); }

/* MODAL */
.modal-overlay { position:fixed; inset:0; background:rgba(13,26,58,0.6); backdrop-filter:blur(4px); z-index:500; display:none; align-items:center; justify-content:center; }
.modal-overlay.show { display:flex; }
.modal { background:white; border-radius:var(--radius); padding:32px; max-width:520px; width:90%; box-shadow:var(--shadow-lg); animation:slideUp 0.25s ease; }
@keyframes slideUp { from{opacity:0;transform:translateY(20px)} to{opacity:1;transform:translateY(0)} }
.modal-title { font-size:18px; font-weight:800; margin-bottom:20px; }

/* LOGIN PAGE */
.login-page { min-height:100vh; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#0d1526 0%,#0a2048 50%,#0d1526 100%); position:relative; overflow:hidden; }
.login-page::before { content:''; position:absolute; top:-200px; right:-200px; width:600px; height:600px; border-radius:50%; background:radial-gradient(circle,rgba(79,123,255,0.12),transparent 70%); }
.login-page::after { content:''; position:absolute; bottom:-150px; left:-150px; width:400px; height:400px; border-radius:50%; background:radial-gradient(circle,rgba(0,212,170,0.08),transparent 70%); }
.login-card { background:rgba(255,255,255,0.05); backdrop-filter:blur(20px); border:1px solid rgba(255,255,255,0.1); border-radius:20px; padding:48px 40px; width:440px; max-width:90vw; position:relative; z-index:1; }
.login-logo { text-align:center; margin-bottom:32px; }
.login-logo .logo-icon { width:64px; height:64px; font-size:28px; margin:0 auto 12px; display:flex; align-items:center; justify-content:center; background:linear-gradient(135deg,#4f7bff,#00d4aa); border-radius:18px; box-shadow:0 8px 30px rgba(79,123,255,0.4); }
.login-logo h1 { color:white; font-size:28px; font-weight:800; letter-spacing:4px; }
.login-logo p { color:rgba(255,255,255,0.5); font-size:12px; letter-spacing:2px; text-transform:uppercase; margin-top:6px; }
.login-form .form-label { color:rgba(255,255,255,0.7); }
.login-form .form-control { background:rgba(255,255,255,0.08); border-color:rgba(255,255,255,0.12); color:white; }
.login-form .form-control::placeholder { color:rgba(255,255,255,0.3); }
.login-form .form-control:focus { border-color:var(--accent); background:rgba(79,123,255,0.1); }
.login-submit { width:100%; padding:14px; font-size:15px; font-weight:700; background:linear-gradient(135deg,#4f7bff,#00d4aa); color:white; border:none; border-radius:10px; cursor:pointer; font-family:inherit; transition:all 0.2s; margin-top:8px; letter-spacing:0.5px; }
.login-submit:hover { transform:translateY(-2px); box-shadow:0 8px 25px rgba(79,123,255,0.4); }

/* RESULT BOX */
.result-box { background:#f0fdf4; border:2px solid #86efac; border-radius:10px; padding:16px; margin-top:12px; }
.result-box.pdf { background:#eff6ff; border-color:#93c5fd; }

/* EMPTY STATE */
.empty-state { text-align:center; padding:60px 20px; }
.empty-state i { font-size:48px; color:var(--border); margin-bottom:16px; display:block; }
.empty-state p { color:var(--text-light); font-size:14px; }

/* PAGINATION */
.pagination { display:flex; align-items:center; gap:6px; margin-top:20px; }
.page-link { padding:7px 12px; border-radius:6px; border:1px solid var(--border); color:var(--text-mid); text-decoration:none; font-size:13px; transition:all 0.2s; }
.page-link:hover,.page-link.active { background:var(--accent); border-color:var(--accent); color:white; }

/* RESPONSIVE */
@media(max-width:768px) {
    .sidebar { transform:translateX(-100%); }
    .sidebar.open { transform:translateX(0); }
    .main { margin-left:0; }
    .form-row { grid-template-columns:1fr; }
    .stats-grid { grid-template-columns:1fr 1fr; }
}
