:root{--primary-color: #1a1a1a;--accent-color: #e86a3b;--text-primary: #ffffff;--text-secondary: #9ca3af;--background: #0f0f0f;--surface: #262626;--border: #404040;--error: #ef4444;--success: #10b981;--border-radius: 8px;--bg-secondary: #1a1a1a;--bg-tertiary: #2a2a2a}*{box-sizing:border-box;margin:0;padding:0}html{scrollbar-gutter:stable}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--background);color:var(--text-primary);line-height:1.6}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--primary-color) 0%,var(--surface) 100%);padding:1rem}.dashboard-container{min-height:100vh;background-color:var(--background)}.card{background-color:var(--surface);border-radius:12px;box-shadow:0 10px 25px #0000004d;border:1px solid var(--border);width:100%;max-width:400px;position:relative;overflow:visible}.title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}.subtitle{color:var(--text-secondary);margin-bottom:2rem}.form-group{margin-bottom:1.5rem;position:relative}.form-label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.5rem;font-size:.875rem}.form-control{width:100%;padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;background-color:var(--primary-color);color:var(--text-primary);font-size:1rem;transition:border-color .2s,box-shadow .2s}.form-control:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #e86a3b1a}.form-control::-moz-placeholder{color:var(--text-secondary)}.form-control::placeholder{color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background-color:var(--accent-color);color:#fff}.btn-primary:hover:not(:disabled){background-color:#d85a2f;transform:translateY(-1px)}.btn-secondary{background-color:var(--surface);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background-color:var(--bg-tertiary)}.btn-link{background:none;color:var(--accent-color);text-decoration:underline;padding:0;border:none;cursor:pointer}.btn-link:hover{color:#d85a2f}.navbar{background-color:var(--surface);border-bottom:1px solid var(--border);padding:1rem 0}.navbar-content{max-width:1200px;margin:0 auto;padding:0 1rem;display:flex;justify-content:space-between;align-items:center}.navbar-brand{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.navbar-user{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary);font-size:.875rem}.user-role{background-color:var(--primary-color);color:var(--accent-color);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.dashboard-card{background-color:var(--surface);border:1px solid var(--border);border-radius:12px;padding:1.5rem;transition:all .2s;text-decoration:none;color:inherit;display:block}.dashboard-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000004d;border-color:var(--accent-color)}.dashboard-card-title{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.dashboard-card-description{color:var(--text-secondary);font-size:.875rem}.alert{padding:1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.alert-error{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--error)}.alert-success{background-color:#10b9811a;border:1px solid rgba(16,185,129,.3);color:var(--success)}.table-container{background-color:var(--surface);border-radius:12px;overflow:hidden;border:1px solid var(--border)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.table th{background-color:var(--primary-color);color:var(--text-secondary);font-weight:500;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.table td{color:var(--text-primary)}.table tbody tr:hover{background-color:var(--primary-color)}.status-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:9999px;font-size:.75rem;font-weight:500}.status-pending{background-color:#fbbf241a;color:#fbbf24}.status-approved{background-color:#10b9811a;color:var(--success)}.status-rejected{background-color:#ef44441a;color:var(--error)}textarea.form-control{resize:vertical;min-height:80px}select.form-control{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.grid{display:grid;gap:1.5rem}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}@media (max-width: 768px){.grid-cols-2,.grid-cols-3{grid-template-columns:1fr}}.text-center{text-align:center}.w-full{width:100%}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.page-container{padding:2rem 0}.p-6{padding:1.5rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.file-upload-area{position:relative;margin-top:.5rem;border:2px dashed var(--border);border-radius:var(--border-radius);background-color:var(--bg-secondary);transition:border-color .3s ease,background-color .3s ease}.file-upload-area:hover{border-color:var(--accent-color);background-color:var(--bg-tertiary)}.file-upload-label{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;padding:2rem;color:var(--text-secondary);cursor:pointer;text-align:center;min-height:150px;position:relative}.file-upload-label:hover{color:var(--text-primary)}.file-upload-label.loading{cursor:not-allowed;opacity:.9}.file-upload-label small{font-size:.75rem;color:var(--text-secondary)}.spinner{display:inline-flex;gap:.3rem;position:relative}.spinner>div{width:10px;height:10px;background-color:var(--accent-color);border-radius:50%;display:inline-block;animation:bounce-delay 1.4s infinite ease-in-out both}.spinner .bounce1{animation-delay:-.32s}.spinner .bounce2{animation-delay:-.16s}.spinner .bounce3{animation-delay:0s}@keyframes bounce-delay{0%,80%,to{transform:scale(.8);opacity:.5}40%{transform:scale(1.2);opacity:1}}.file-info{display:flex;align-items:center;gap:.75rem;margin-top:1rem;padding:1rem;background-color:var(--bg-tertiary);border-radius:var(--border-radius);border:1px solid var(--border);color:var(--text-primary);font-size:.875rem;position:relative;animation:fadeIn .3s ease}.file-preview{margin-top:1rem;text-align:center;border-radius:var(--border-radius);overflow:hidden;background-color:var(--bg-tertiary);padding:1rem;border:1px solid var(--border);animation:fadeIn .3s ease}.file-preview img{max-width:100%;max-height:300px;-o-object-fit:contain;object-fit:contain;border-radius:var(--border-radius)}.processing-step{margin-top:.5rem;padding:.75rem;background-color:#e86a3b1a;color:var(--accent-color);border-radius:var(--border-radius);font-size:.875rem;text-align:center;border:1px solid rgba(232,106,59,.3);animation:slideIn .3s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.notification-enter{animation:slideInRight .3s ease-out}.modal-enter{animation:fadeIn .2s ease-out}.card-enter{animation:scaleIn .2s ease-out}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.loading-shimmer{background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.05) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 1.5s infinite}.btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #0003}.btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px #0003}.btn,.form-control,.file-upload-label,.dashboard-card{transition:all .3s cubic-bezier(.4,0,.2,1)}.form-help{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}@media (max-width: 640px){.title{font-size:1.5rem}.container{padding:0 .75rem}.p-6{padding:1rem}.file-upload-label{padding:1.5rem}}.expense-card{position:relative;background-color:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem;margin-bottom:.75rem}.expense-amount-badge{position:absolute;top:-8px;right:12px;background-color:var(--accent-color);color:#fff;padding:.25rem .75rem;border-radius:4px;font-size:1rem;font-weight:700;box-shadow:0 2px 4px #0003}.expense-title{color:var(--text-primary);margin-bottom:.5rem;font-size:1rem;font-weight:600}.expense-meta{display:flex;gap:.75rem;font-size:.8rem;color:var(--text-secondary);margin-bottom:.75rem;flex-wrap:wrap;align-items:center}.edit-form{margin-top:.75rem;padding:.75rem;background-color:var(--background);border-radius:4px}.form-grid{display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);margin-bottom:.75rem}.edit-form label{font-size:.75rem;color:var(--text-secondary);display:block;margin-bottom:.25rem}.btn-group{display:flex;gap:.4rem;flex-wrap:wrap;margin-top:.75rem}.btn-group-sm{display:flex;gap:.25rem}.btn-xs{font-size:.7rem;padding:.2rem .4rem}.btn-sm{font-size:.8rem;padding:.4rem .8rem}.btn-success{background-color:var(--success);color:#fff}.btn-danger{background-color:var(--error);color:#fff}.month-container{margin-bottom:2rem;background:var(--surface);border-radius:12px;border:1px solid var(--border);overflow:hidden}.month-header{padding:1rem 1.5rem;background:var(--primary-color);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:background .2s}.month-header:hover{background:var(--surface)}.month-header h3{margin:0;font-size:1.2rem;font-weight:600;text-transform:capitalize}.month-header .count{color:var(--text-secondary);font-size:.9rem}.month-header .total{font-size:1.2rem;font-weight:700;color:var(--accent-color)}.month-content{padding:1.5rem}.categories-grid{display:grid;gap:1.5rem}.categories-grid:has(>:nth-child(2)){grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.category-container{background:var(--background);border-radius:8px;padding:1rem;border:1px solid var(--border)}.category-header{margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;align-items:center}.category-header h4{margin:0;color:var(--text-primary);font-size:1rem;font-weight:600}.category-header span{font-size:.9rem;color:var(--accent-color);font-weight:700}.section-title{margin-bottom:1.5rem;color:var(--text-primary);font-size:1.5rem}h2.section-title:last-of-type{font-size:1.3rem;margin-bottom:1rem}.settings-grid{display:grid;gap:2rem;grid-template-columns:repeat(2,1fr)}@media (max-width: 800px){.settings-grid{grid-template-columns:1fr}}
