:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:#1a202c;--primary: #f6c90e;--primary-dark: #e0b700;--sidebar-text: #5a6475;--sidebar-title: #1b2559}*{box-sizing:border-box}body{margin:0;background:#f4f7fe}.page-loader{position:fixed;top:0;right:0;bottom:0;left:0;display:grid;place-items:center;background:#ffffffc7;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999}.loader-card{width:180px;height:180px;border-radius:24px;background:#fff;box-shadow:0 22px 50px #1a202c2e;display:grid;place-items:center;gap:10px;padding-top:8px}.progress-circle{width:84px;height:84px;border-radius:999px;background:conic-gradient(var(--primary) 0deg,var(--primary-dark) 120deg,#f6f7fb 280deg,#f6f7fb 360deg);animation:spin 1.1s linear infinite;display:grid;place-items:center}.progress-inner{width:60px;height:60px;border-radius:999px;background:#fff;box-shadow:inset 0 0 0 1px #eef2f9}.loader-text{margin:0;font-weight:700;color:#1b2559;letter-spacing:.02em}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.horizon-shell{min-height:100vh;display:flex}.sidebar{width:240px;background:#fff;border-right:1px solid #e7ecf3;padding:28px 18px;display:flex;flex-direction:column;gap:20px}.brand-block{padding:6px 10px}.brand-eyebrow{margin:0;color:#8f9bba;font-size:12px;text-transform:uppercase;letter-spacing:.08em;font-weight:700}.brand-title{margin:6px 0 4px;color:var(--sidebar-title);font-size:24px}.brand-user{margin:0;color:var(--sidebar-text);font-size:14px}.brand-roles{margin:4px 0 0;color:#8f9bba;font-size:12px;font-weight:600;text-transform:capitalize}.roles-page-hint{margin:0 0 20px;color:#7b879f;font-size:14px}.roles-grid{display:grid;gap:20px}.role-card{border:1px solid #e7ecf3;border-radius:14px;padding:18px;background:#fafbff}.role-card__header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.role-card__header h3{margin:0;text-transform:capitalize;color:var(--sidebar-title)}.role-card__count{font-size:12px;font-weight:700;color:#8f9bba}.permission-group{margin-bottom:14px}.permission-group__title{margin:0 0 8px;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#8f9bba}.permission-list{display:flex;flex-wrap:wrap;gap:8px}.permission-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid #dce4f2;background:#fff;font-size:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.permission-chip--on{border-color:var(--primary-dark);background:#fff9df}.permission-chip input{margin:0}.permission-chip input:disabled{cursor:not-allowed}.approval-sections{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}.approval-section-tab{border:1px solid #dce4f2;background:#fff;border-radius:999px;padding:8px 14px;font-weight:600;color:var(--sidebar-text);cursor:pointer;display:inline-flex;align-items:center;gap:8px}.approval-section-tab--active{border-color:var(--primary-dark);background:#fff9df;color:var(--sidebar-title)}.approval-section-badge{min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:#e53e3e;color:#fff;font-size:11px;display:inline-grid;place-items:center}.approval-pending-note{margin:0;color:#7b879f;font-size:14px}.approval-sub{margin-top:4px;font-size:12px;color:#8f9bba}.sidebar-nav{display:flex;flex-direction:column;gap:6px}.sidebar-item{text-decoration:none;color:var(--sidebar-text);border-radius:12px;padding:10px 12px;display:flex;align-items:center;gap:10px;font-weight:600;transition:all .2s ease}.sidebar-item:hover{background:#fff8db;color:#4a5568}.sidebar-item-active{background:#fff4bf;color:#1f2937;box-shadow:0 8px 18px #f6c90e40}.sidebar-item-dot{width:8px;height:8px;border-radius:999px;background:#d6deeb}.sidebar-item-active .sidebar-item-dot{background:var(--primary)}.sidebar-logout{margin-top:auto}.language-switcher{margin-top:12px}.language-switcher label{display:block;margin-bottom:6px;font-size:12px;color:#7b879f}.content{flex:1;padding:24px;display:grid;gap:16px}.card{background:#fff;border-radius:20px;padding:24px;box-shadow:0 12px 30px #1a202c14}.btn{border:none;border-radius:12px;padding:10px 16px;font-weight:600;cursor:pointer;background:#eef2f9;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-spinner{width:16px;height:16px;flex-shrink:0;border-radius:50%;border:2px solid currentColor;border-right-color:transparent;opacity:.85;animation:spin .65s linear infinite}.btn-icon .btn-spinner{width:14px;height:14px}.btn-primary .btn-spinner{border-color:#1b2559;border-right-color:transparent}.btn-success .btn-spinner{border-color:#166534;border-right-color:transparent}.btn-danger .btn-spinner{border-color:#991b1b;border-right-color:transparent}.btn-ghost .btn-spinner{border-color:#475569;border-right-color:transparent}.btn-filter-link .btn-spinner{width:12px;height:12px;border-width:2px}.btn:disabled{opacity:.65;cursor:not-allowed}.btn-primary{background:var(--primary);color:#1b2559}.btn-primary:hover{background:var(--primary-dark)}.btn-success{background:#dcfce7;color:#166534}.btn-danger{background:#fee2e2;color:#991b1b}.btn-icon{display:inline-flex;align-items:center;gap:6px}.input{width:100%;border:1px solid #d8e1f0;border-radius:12px;padding:10px 12px}.toolbar{display:flex;justify-content:space-between;align-items:center}.table-filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:16px;padding:14px;background:#f8faff;border:1px solid #e7ecf3;border-radius:14px}.table-filters__search{flex:1 1 200px;min-width:180px}.table-filters__date{flex:0 1 160px;min-width:140px}.table-filters__actions{display:flex;gap:8px;flex-wrap:wrap}.table-filters .input{margin:0}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:10px;border-bottom:1px solid #e7ecf3;text-align:left}.actions{display:flex;gap:10px}.empty-state{text-align:center;color:#7b879f;font-weight:600}.table-loader-wrap{display:inline-flex;align-items:center;gap:10px;justify-content:center}.table-loader{width:18px;height:18px;border-radius:999px;border:3px solid #fde68a;border-top-color:#f59e0b;animation:spin .9s linear infinite}.dashboard-page{display:flex;flex-direction:column;gap:20px;width:100%;max-width:none}.dashboard-hero{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:16px;padding:8px 4px 4px}.dashboard-hero-eyebrow{margin:0 0 6px;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#8f9bba}.dashboard-hero-title{margin:0;font-size:clamp(1.5rem,2.5vw,2rem);font-weight:800;color:var(--sidebar-title);letter-spacing:-.02em}.dashboard-hero-sub{margin:8px 0 0;font-size:14px;color:#64748b;max-width:520px;line-height:1.45}.dashboard-filter-card{border:1px solid #e7ecf3;background:linear-gradient(155deg,#fff,#fbfcff 40%,#fffef8);box-shadow:0 16px 42px #1a202c12}.dashboard-filter-head{margin-bottom:14px}.dashboard-filter-head h3{margin:0 0 8px;font-size:18px;font-weight:800;color:#1b2559;letter-spacing:-.02em}.dashboard-filter-head p{margin:0;font-size:13px;color:#64748b;line-height:1.5;max-width:640px}.filter-scope-summary{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:18px;min-height:28px}.filter-scope-pill{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:700;background:#f1f5f9;color:#475569}.filter-scope-pill--active{background:linear-gradient(135deg,#fff9e0,#fff4bf);color:#854d0e;border:1px solid rgba(246,201,14,.45)}.filter-scope-idle{font-size:12px;font-weight:600;color:#94a3b8}.dashboard-filter-panels{display:grid;gap:14px}@media (min-width: 720px){.dashboard-filter-panels{grid-template-columns:1fr 1fr}}.filter-panel{border-radius:16px;border:1px solid #e8eef7;background:#fff;box-shadow:inset 0 1px #fffc;overflow:hidden;display:flex;flex-direction:column;min-height:0}.filter-panel-head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;padding:12px 14px;background:linear-gradient(180deg,#f8fafc,#fff);border-bottom:1px solid #eef2f7}.filter-panel-title{margin:0;font-size:13px;font-weight:800;color:#1e293b;letter-spacing:.02em}.filter-panel-actions{display:flex;flex-wrap:wrap;gap:6px}.filter-panel-actions .btn-filter-link{padding:6px 10px;font-size:11px;font-weight:700;border-radius:8px;border:none;background:transparent;color:#64748b;cursor:pointer;transition:color .15s ease,background .15s ease}.filter-panel-actions .btn-filter-link:hover{background:#f1f5f9;color:#0f172a}.filter-panel-scroll{max-height:260px;overflow-y:auto;padding:10px;display:flex;flex-direction:column;gap:8px;scrollbar-width:thin}.filter-option{position:relative;display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;border:1px solid #eef2f7;background:#fafbfc;cursor:pointer;transition:border-color .15s ease,background .15s ease,box-shadow .15s ease}.filter-option:hover{background:#f8fafc;border-color:#e2e8f0}.filter-option--checked{border-color:#f6c90ebf;background:linear-gradient(135deg,#fffef6,#fffbeb);box-shadow:0 4px 14px #f6c90e1f}.filter-option-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.filter-option-box{flex-shrink:0;width:20px;height:20px;border-radius:6px;border:2px solid #cbd5e1;background:#fff;display:grid;place-items:center;transition:border-color .15s ease,background .15s ease}.filter-option--checked .filter-option-box{border-color:#d4a512;background:var(--primary)}.filter-option-box:after{content:"";width:5px;height:9px;border:solid #1b2559;border-width:0 2px 2px 0;transform:rotate(45deg) translate(-.5px,-1px);opacity:0}.filter-option--checked .filter-option-box:after{opacity:1}.filter-option-main{flex:1;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:12px}.filter-option-name{font-size:14px;font-weight:600;color:#1e293b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.filter-option-amount{flex-shrink:0;font-size:12px;font-weight:700;font-variant-numeric:tabular-nums;padding:4px 10px;border-radius:999px;background:#f1f5f9;color:#475569}.filter-option--checked .filter-option-amount{background:#ffffffa6;color:#713f12}.filter-panel-empty{margin:0;padding:18px 12px;text-align:center;font-size:13px;font-weight:600;color:#94a3b8}.dashboard-filter-footer{display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:18px;border-top:1px solid #e8eef7}.btn-ghost{background:#fff;color:#475569;border:1px solid #e2e8f0}.btn-ghost:hover{background:#f8fafc;color:#0f172a;border-color:#cbd5e1}.dashboard-filter-footer .btn-primary{min-width:148px;box-shadow:0 8px 20px #f6c90e40}.dashboard-section-label{margin:0 0 12px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#94a3b8}.dashboard-stats-band{display:flex;flex-direction:column;gap:18px;width:100%}.dashboard-kpi-row{display:grid;gap:12px;width:100%}.dashboard-kpi-row>.stat-kpi{height:100%}.dashboard-kpi-row--6{grid-template-columns:repeat(2,minmax(0,1fr))}@media (min-width: 640px){.dashboard-kpi-row--6{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1080px){.dashboard-kpi-row--6{grid-template-columns:repeat(6,minmax(0,1fr))}}.dashboard-kpi-row--3{grid-template-columns:1fr}@media (min-width: 768px){.dashboard-kpi-row--3{grid-template-columns:repeat(3,minmax(0,1fr))}}.stat-kpi{position:relative;display:flex;gap:14px;align-items:flex-start;padding:18px 18px 18px 16px;border-radius:18px;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e8eef7;box-shadow:0 10px 28px #0f172a0d;overflow:hidden}.stat-kpi:before{content:"";position:absolute;inset-inline-start:0;top:14px;bottom:14px;width:4px;border-radius:0 6px 6px 0;background:var(--stat-accent, #cbd5e1)}[dir=rtl] .stat-kpi:before{border-radius:6px 0 0 6px}.stat-kpi-icon{flex-shrink:0;width:46px;height:46px;border-radius:14px;display:grid;place-items:center;background:var(--stat-icon-bg, #f1f5f9);color:var(--stat-accent, #64748b)}.stat-kpi-body{min-width:0}.stat-kpi-label{margin:0;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8}.stat-kpi-hint{margin:4px 0 0;font-size:12px;color:#94a3b8}.stat-kpi-value{margin:10px 0 0;font-size:clamp(1.25rem,2vw,1.65rem);font-weight:800;color:#0f172a;letter-spacing:-.03em;line-height:1.15;font-variant-numeric:tabular-nums}.stat-kpi--dense{flex-direction:column;align-items:flex-start;padding:14px 14px 14px 18px;gap:10px}.stat-kpi--dense .stat-kpi-icon{width:40px;height:40px;border-radius:12px}.stat-kpi--dense .stat-kpi-icon svg{width:18px;height:18px}.stat-kpi--dense .stat-kpi-value{margin-top:6px;font-size:clamp(1rem,1.35vw,1.35rem)}.stat-kpi--dense.stat-kpi:before{top:12px;bottom:12px}.stat-kpi--dense .stat-kpi-hint{font-size:11px;line-height:1.35}.stat-kpi--users{--stat-accent: #6366f1;--stat-icon-bg: #eef2ff}.stat-kpi--balances{--stat-accent: #0ea5e9;--stat-icon-bg: #e0f2fe}.stat-kpi--wallets{--stat-accent: #a855f7;--stat-icon-bg: #f3e8ff}.stat-kpi--total-balances{--stat-accent: #2563eb;--stat-icon-bg: #dbeafe}.stat-kpi--total-wallets{--stat-accent: #7c3aed;--stat-icon-bg: #ede9fe}.stat-kpi--in{--stat-accent: #059669;--stat-icon-bg: #d1fae5}.stat-kpi--out{--stat-accent: #d97706;--stat-icon-bg: #fef3c7}.stat-kpi--expense{--stat-accent: #e11d48;--stat-icon-bg: #ffe4e6}.stat-kpi--combined{--stat-accent: #0d9488;--stat-icon-bg: #ccfbf1}.dashboard-split{display:grid;gap:16px}@media (min-width: 1080px){.dashboard-split{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);align-items:start}}.dashboard-panel-title{margin:0 0 16px;font-size:16px;font-weight:800;color:#1b2559}.dashboard-table-wrap{overflow-x:auto;margin:0 -8px;padding:0 8px}.dashboard-table{width:100%;border-collapse:separate;border-spacing:0}.dashboard-table thead th{padding:12px 10px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#64748b;border-bottom:2px solid #e8eef7;background:linear-gradient(180deg,#fafbfc,#fff)}.dashboard-table tbody td{padding:12px 10px;font-size:13px;color:#334155;border-bottom:1px solid #f1f5f9}.dashboard-table tbody tr:hover td{background:#fafbff}.dash-type{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:.03em}.dash-type--in{background:#d1fae5;color:#047857}.dash-type--out{background:#fef3c7;color:#b45309}.dash-type--expense{background:#ffe4e6;color:#be123c}.table-pagination{margin-top:12px;display:flex;justify-content:space-between;align-items:center;gap:10px}.table-pagination-summary{display:inline-flex;align-items:center;gap:10px;font-weight:600;color:#64748b;font-size:13px}.table-pagination-controls{display:flex;align-items:center;gap:8px}.table-pagination-spinner{width:14px;height:14px;border-width:2px;border-color:#64748b;border-right-color:transparent}.upload-import-card{border:1px solid #e8eef7;background:linear-gradient(165deg,#fff,#fafbff 55%,#fffdf8)}.upload-import-grid{display:grid;gap:22px}@media (min-width: 760px){.upload-import-grid{grid-template-columns:minmax(0,260px) 1fr;align-items:start}}.upload-field-label{display:block;margin:0 0 8px;font-size:12px;font-weight:700;color:#64748b;letter-spacing:.04em}.upload-dropzone{border:2px dashed #c5d3e8;border-radius:18px;padding:28px 20px;text-align:center;background:linear-gradient(180deg,#f8fafc,#fff 60%);cursor:pointer;transition:border-color .2s ease,box-shadow .2s ease,background .2s ease}.upload-dropzone:hover{border-color:var(--primary-dark);box-shadow:0 14px 34px #f6c90e1f}.upload-dropzone:focus-visible{outline:2px solid var(--primary-dark);outline-offset:3px}.upload-dropzone--drag{border-color:var(--primary);border-style:solid;background:#fffbeb}.upload-dropzone-icon{width:54px;height:54px;margin:0 auto 14px;border-radius:16px;background:linear-gradient(145deg,#fff9db,#ffe994);display:grid;place-items:center;color:#92400e;box-shadow:0 10px 26px #f6c90e47}.upload-dropzone-title{margin:0 0 8px;font-size:16px;font-weight:800;color:#1b2559}.upload-dropzone-sub{margin:0;font-size:13px;color:#64748b;line-height:1.5}.upload-dropzone-formats{margin-top:10px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#94a3b8}.upload-file-chip{display:inline-flex;align-items:center;gap:12px;margin-top:14px;padding:12px 14px;border-radius:14px;background:#fff;border:1px solid #e2e8f0;box-shadow:0 6px 16px #0f172a0f}.upload-file-chip-name{font-size:13px;font-weight:700;color:#1e293b;max-width:240px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file-chip-meta{font-size:12px;font-weight:600;color:#64748b}.upload-file-chip-remove{margin-inline-start:auto;border:none;background:#fef2f2;color:#b91c1c;width:32px;height:32px;border-radius:10px;cursor:pointer;font-size:18px;font-weight:700;line-height:1;transition:background .15s ease}.upload-file-chip-remove:hover{background:#fee2e2}.upload-submit-row{margin-top:20px}.upload-submit-row .btn-primary{min-width:200px}.visually-hidden-file{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.per-page-select{width:90px;padding:8px 10px}.toast-stack{position:fixed;top:18px;right:18px;display:grid;gap:10px;z-index:99999}.toast-item{min-width:240px;max-width:420px;padding:10px 14px;border-radius:10px;color:#fff;box-shadow:0 10px 20px #0f172a2e;font-weight:600}.toast-success{background:#16a34a}.toast-error{background:#dc2626}
