@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{font-family:Inter,Segoe UI,system-ui,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--primary: #4361ee;--primary-light: #eef1fd;--page-bg: #f0f2f8;--border: #eef0f8;--text-main: #1a1f36;--text-muted: #a0aec0;--text-secondary: #64748b}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:var(--page-bg)}#root{min-height:100vh}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d0d5e8;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:#a0a8cc}.sidebar{background:#fff;border-right:1.5px solid var(--border);overflow:hidden;flex-shrink:0}.sidebar-brand{height:64px;display:flex;align-items:center;justify-content:flex-start;padding:0 20px;gap:10px;border-bottom:1.5px solid var(--border);overflow:hidden;flex-shrink:0;transition:padding .2s,justify-content .2s}.sidebar-brand--collapsed{justify-content:center;padding:0}.sidebar-logo-mark{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#4361ee,#7c3aed);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #4361ee4d}.sidebar-logo-mark span{color:#fff;font-weight:800;font-size:14px;letter-spacing:-.5px}.sidebar-brand-text{overflow:hidden;max-width:160px;opacity:1;transition:opacity .18s ease,max-width .2s ease;white-space:nowrap}.sidebar-brand-text--hidden{opacity:0;max-width:0}.sidebar-brand-name{font-weight:700;font-size:15px;color:var(--text-main);line-height:1.2;white-space:nowrap}.sidebar-brand-sub{font-size:11px;color:var(--text-muted);white-space:nowrap}.sidebar-menu-wrap{overflow-y:auto;overflow-x:hidden;height:calc(100vh - 64px)}.sidebar-menu{border:none!important;background:transparent!important;padding-top:8px}.sidebar-section-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted);padding:18px 20px 4px;display:block;-webkit-user-select:none;user-select:none;opacity:1;max-height:40px;overflow:hidden;transition:opacity .15s ease,max-height .2s ease,padding .2s ease}.sidebar-section-label--hidden{opacity:0;max-height:0;padding:0}.topbar{padding:0 20px;background:#fff;display:flex;justify-content:space-between;align-items:center;position:sticky;top:0;z-index:99;border-bottom:1.5px solid var(--border);gap:16px}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-right{display:flex;align-items:center;gap:8px}.topbar-icon-btn{font-size:16px!important;width:38px!important;height:38px!important;color:var(--text-secondary)!important;border-radius:8px!important}.header-search{background:#f4f6fb;border:1.5px solid #e8ecf5;border-radius:10px;padding:6px 14px;display:flex;align-items:center;gap:8px;width:220px;cursor:text;transition:border-color .2s,box-shadow .2s}.header-search:hover,.header-search:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #4361ee1a}.header-search-icon{color:var(--text-muted);font-size:14px}.header-search input{border:none;outline:none;background:transparent;font-size:13px;color:#333;width:100%;font-family:inherit}.header-search input::placeholder{color:var(--text-muted)}.user-card{cursor:pointer;display:flex;align-items:center;gap:10px;padding:6px 10px 6px 6px;border-radius:10px;border:1.5px solid var(--border);background:#fafbff;transition:background .15s}.user-card:hover{background:var(--page-bg)}.user-avatar{background:linear-gradient(135deg,#4361ee,#7c3aed)!important;font-weight:700!important;font-size:12px!important;flex-shrink:0}.user-info{line-height:1.3}.user-name{font-size:13px;font-weight:600;color:var(--text-main);white-space:nowrap}.user-role{font-size:11px;font-weight:600;white-space:nowrap}.user-chevron{font-size:11px;color:var(--text-muted)}.page-content{margin:28px 28px 0;padding-bottom:28px}.page-inner{background:#fff;border-radius:16px;padding:28px 32px;min-height:calc(100vh - 120px);box-shadow:0 1px 8px #4361ee0f}.login-root{display:flex;min-height:100vh;background:var(--page-bg)}.login-left{flex:1;display:none;background:linear-gradient(135deg,#4361ee,#7c3aed);align-items:center;justify-content:center;padding:48px;flex-direction:column;gap:24px}@media(min-width:900px){.login-left{display:flex}}.login-left-icon{width:64px;height:64px;border-radius:18px;background:#ffffff26;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:flex;align-items:center;justify-content:center;font-size:28px;font-weight:800;color:#fff;border:2px solid rgba(255,255,255,.25)}.login-left-title{color:#fff;margin:0;font-size:30px;font-weight:800;text-align:center}.login-left-desc{color:#ffffffbf;font-size:16px;margin:0;text-align:center;max-width:340px;line-height:1.7}.login-right{width:100%;max-width:480px;display:flex;align-items:center;justify-content:center;padding:40px 32px;background:#fff;box-shadow:-4px 0 32px #0000000f}.login-form-wrap{width:100%;max-width:380px}.login-form-header{margin-bottom:36px}.login-logo-mark{width:46px;height:46px;border-radius:13px;background:linear-gradient(135deg,#4361ee,#7c3aed);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:20px;color:#fff;box-shadow:0 6px 20px #4361ee4d;margin-bottom:20px}.login-title{margin:0;font-size:24px;font-weight:700;color:var(--text-main)}.login-subtitle{margin:6px 0 0;color:var(--text-secondary);font-size:14px}.login-field-label{font-weight:500;color:#374151}.login-btn{border-radius:10px!important;font-weight:600!important;height:46px!important;background:linear-gradient(135deg,#4361ee,#7c3aed)!important;border:none!important;box-shadow:0 6px 20px #4361ee59!important}.login-btn-wrap{margin-top:8px}.login-dev-hint{margin-top:16px;padding:10px 14px;background:var(--page-bg);border-radius:8px;border:1px dashed #c7d2fe}.login-dev-label{margin:0;font-size:12px;color:var(--text-secondary);font-weight:500}.login-dev-creds{margin:2px 0 0;font-size:12px;color:var(--primary)}.ant-table-wrapper{overflow-x:auto}.unpaid-row{background-color:#fff5f5}.unpaid-row:hover>td{background-color:#ffe8e8!important}.loading-container{display:flex;justify-content:center;align-items:center;min-height:200px}.empty-state{padding:50px 0;text-align:center}@media print{.ant-layout-sider,.ant-layout-header,button:not(.print-keep),.no-print{display:none!important}.ant-layout-content{padding:20px!important}@page{size:A4;margin:2cm}}
