.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:radial-gradient(ellipse at top left,rgba(99,102,241,.15) 0%,transparent 60%),radial-gradient(ellipse at bottom right,rgba(99,102,241,.1) 0%,transparent 60%),var(--bg);padding:24px}.auth-card{width:100%;max-width:420px}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo svg{font-size:48px;color:var(--primary);margin-bottom:8px}.auth-logo h1{font-size:28px;font-weight:700;color:var(--text)}.auth-logo p{color:var(--text-muted);margin-top:4px;font-size:15px}.input-icon{position:relative;width:100%;display:flex;align-items:center}.input-icon>svg:first-child{position:absolute;left:14px;color:var(--text-muted);font-size:20px;pointer-events:none;z-index:2}.input-icon .form-control{width:100%;padding-left:44px;padding-right:44px;height:48px}.password-toggle{position:absolute;right:14px;background:none;border:none;padding:0;display:flex;align-items:center;justify-content:center;color:var(--text-muted);cursor:pointer;font-size:20px;transition:color .2s;z-index:3}.password-toggle:hover{color:var(--primary)}.auth-footer{text-align:center;margin-top:24px;font-size:14px;color:var(--text-muted)}.auth-link{color:var(--primary-light);font-weight:500;text-decoration:none}.auth-link:hover{text-decoration:underline}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-box{width:100%;max-width:520px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.modal-header h2{font-size:20px;font-weight:600}.btn-icon{width:36px;height:36px;padding:0;display:flex;align-items:center;justify-content:center;font-size:20px;border-radius:8px}.type-toggle{display:flex;gap:8px}.toggle-btn{flex:1;padding:10px;border:1px solid var(--border);border-radius:8px;background:var(--bg-card2);color:var(--text-muted);font-size:14px;font-weight:500;transition:all .2s;cursor:pointer}.toggle-btn.active.expense{background:#ef444426;border-color:var(--danger);color:var(--danger)}.toggle-btn.active.income{background:#22c55e26;border-color:var(--success);color:var(--success)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.checkbox-group label{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-muted);cursor:pointer;text-transform:none;letter-spacing:0}.checkbox-group input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary)}.modal-footer{display:flex;gap:12px;justify-content:flex-end;margin-top:8px}@media (max-width: 480px){.form-row{grid-template-columns:1fr}}.amount-input-wrapper{position:relative;display:flex;align-items:center}.amount-input{padding-right:60px!important;font-weight:700;font-size:1.2rem;color:var(--primary);text-align:left}.currency-unit{position:absolute;right:12px;font-size:.9rem;font-weight:600;color:var(--text-muted);pointer-events:none}.amount-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6366f133}.form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;background-color:var(--bg-input, #fff);color:var(--text);font-size:15px;transition:all .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}select.form-control{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236b7280'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'%3E%3C/path%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;background-size:16px;padding-right:40px;cursor:pointer}select.form-control option{background-color:var(--bg-card, #fff);color:var(--text);padding:10px}.form-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11a}.dashboard{max-width:900px}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:28px;gap:16px}.page-header h1{font-size:24px;font-weight:700}.summary-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.summary-card{display:flex;align-items:center;gap:16px}.summary-icon{width:52px;height:52px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.summary-card.income .summary-icon{background:#22c55e26;color:var(--success)}.summary-card.expense .summary-icon{background:#ef444426;color:var(--danger)}.summary-card.balance-positive .summary-icon,.summary-card.balance-negative .summary-icon{background:#6366f126;color:var(--primary-light)}.summary-label{font-size:13px;color:var(--text-muted);margin-bottom:4px}.summary-amount{font-size:20px;font-weight:700}.summary-card.income .summary-amount{color:var(--success)}.summary-card.expense .summary-amount{color:var(--danger)}.summary-card.balance-positive .summary-amount{color:var(--text)}.summary-card.balance-negative .summary-amount{color:var(--danger)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-header h2{font-size:18px;font-weight:600}.btn-sm{padding:7px 14px;font-size:13px}.tx-list{display:flex;flex-direction:column;gap:12px}.tx-item{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-card2);border-radius:10px;gap:16px}.tx-category{font-size:15px;font-weight:500;margin-bottom:4px}.tx-meta{font-size:12px;color:var(--text-muted)}.tx-owner{color:var(--primary-light);font-weight:500}.tx-amount{font-size:16px;font-weight:700;white-space:nowrap}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted);display:flex;flex-direction:column;align-items:center;gap:16px}@media (max-width: 640px){.summary-grid{grid-template-columns:1fr}.page-header{flex-direction:column}}:root{--primary: #6366f1;--primary-hover: #4f46e5;--success: #10b981;--danger: #ef4444;--warning: #f59e0b;--bg-main: #f8fafc;--glass: rgba(255, 255, 255, .8);--shadow-sm: 0 1px 3px rgba(0,0,0,.1);--shadow-md: 0 10px 15px -3px rgba(0,0,0,.05)}.dashboard{max-width:1100px;margin:0 auto;padding:24px;animation:fadeIn .5s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.card-premium{background:var(--glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);border-radius:20px;box-shadow:var(--shadow-md);padding:24px;transition:transform .2s}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;margin-bottom:32px}.summary-card{padding:24px;position:relative;overflow:hidden}.summary-card:after{content:"";position:absolute;top:-20px;right:-20px;width:100px;height:100px;background:currentColor;opacity:.05;border-radius:50%}.summary-icon{width:48px;height:48px;border-radius:14px;margin-bottom:16px}.tx-item{display:grid;grid-template-columns:auto 1fr auto;align-items:center;padding:16px;margin-bottom:12px;border-bottom:1px solid #f1f5f9;transition:all .2s}.tx-item:hover{background:#f1f5f9;transform:scale(1.01);border-radius:12px}@media (max-width: 768px){.page-header{flex-direction:column;align-items:flex-start;gap:20px}.btn-primary{width:100%;justify-content:center}.tx-item{grid-template-columns:1fr auto}.tx-info{grid-column:1 / 2}.tx-amount{grid-column:2 / 3}}.summary-grid{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.summary-row-mini{display:grid;grid-template-columns:1fr 1fr;gap:12px}.mini-card{background:var(--bg-card);padding:12px;border-radius:16px;display:flex;align-items:center;gap:10px;border:1px solid var(--border)}.mini-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px}.income .mini-icon{background:#10b9811a;color:var(--success)}.expense .mini-icon{background:#ef44441a;color:var(--danger)}.mini-content p:first-child{font-size:12px;color:var(--text-muted);margin:0}.mini-content .amount{font-size:14px;font-weight:700;margin:0}.balance-card{position:relative;overflow:hidden;padding:20px;border-radius:18px;background:linear-gradient(135deg,var(--primary),#818cf8);color:#fff;display:flex;justify-content:space-between;align-items:center}.balance-card.neg{background:linear-gradient(135deg,#ef4444,#f87171)}.balance-info p{opacity:.9;font-size:13px;margin-bottom:4px}.balance-info h3{font-size:24px;font-weight:800;margin:0}.balance-bg-icon{font-size:40px;opacity:.2}@media (min-width: 768px){.summary-grid{flex-direction:row;align-items:stretch}.summary-row-mini{flex:2}.balance-card{flex:1}}.transactions-page{max-width:1200px;margin:0 auto;padding:2rem;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.filters-card{background:var(--bg-card);border-radius:16px;border:1px solid rgba(255,255,255,.05);box-shadow:0 4px 20px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:24px;margin-bottom:24px}.filters-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.form-control{background:#ffffff08!important;border:1px solid rgba(255,255,255,.1)!important;border-radius:10px!important;color:var(--text)!important;transition:all .3s ease}.form-control:focus{border-color:var(--primary)!important;box-shadow:0 0 0 3px #6366f133!important}.tx-table-wrapper{background:var(--bg-card);border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.05)}.tx-table thead{background:#ffffff05}.tx-table th{padding:16px;color:var(--primary-light);font-weight:700;font-size:11px}.tx-table td{padding:18px 16px;transition:background .2s}.tx-table tr:hover td{background:#6366f10a}@media (max-width: 992px){.tx-table thead{display:none}.tx-table,.tx-table tbody,.tx-table tr,.tx-table td{display:block;width:100%}.tx-table tr{margin-bottom:16px;border-bottom:1px solid var(--border);padding:12px;position:relative}.tx-table td{border:none;padding:8px 0;display:flex;justify-content:space-between;align-items:center;text-align:right}.tx-table td:before{content:attr(data-label);font-weight:600;color:var(--text-muted);float:left;font-size:13px}.action-btns{justify-content:flex-end}}.transactions-page{max-width:1100px}.filters-card{margin-bottom:20px;padding:20px 24px}.filters-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--text-muted);margin-bottom:16px;text-transform:uppercase;letter-spacing:.05em}.filters-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}.filters-grid .form-group{margin-bottom:0}.tx-table-wrapper{overflow-x:auto}.tx-table{width:100%;border-collapse:collapse;font-size:14px}.tx-table th{text-align:left;padding:10px 12px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.tx-table td{padding:14px 12px;border-bottom:1px solid var(--border);vertical-align:middle}.tx-table tr:last-child td{border-bottom:none}.tx-table tr:hover td{background:#ffffff05}.cat-badge{display:inline-flex;padding:4px 10px;background:var(--bg-card2);border-radius:6px;font-size:13px;font-weight:500;white-space:nowrap}.owner-tag{display:inline-flex;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.owner-tag.me{background:#6366f126;color:var(--primary-light)}.owner-tag.other{background:#f59e0b26;color:var(--warning)}.tx-amount-cell{font-weight:700;white-space:nowrap}.action-btns{display:flex;gap:8px}.btn-icon-sm{width:32px;height:32px;border-radius:6px;border:1px solid var(--border);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s}.btn-icon-sm:hover{border-color:var(--primary);color:var(--primary-light)}.btn-icon-sm.danger:hover{border-color:var(--danger);color:var(--danger)}.pagination{display:flex;gap:8px;justify-content:center;margin-top:20px}.page-btn{width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:transparent;color:var(--text-muted);font-size:14px;transition:all .2s}.page-btn:hover,.page-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.loading-state{padding:48px;text-align:center;color:var(--text-muted)}@media (max-width: 768px){.filters-grid{grid-template-columns:1fr 1fr}}@media (max-width: 480px){.filters-grid{grid-template-columns:1fr}}.mobile-only{display:none}.desktop-only{display:block}@media (max-width: 768px){.mobile-only{display:flex;flex-direction:column;gap:12px}.desktop-only{display:none}.tx-mobile-card{background:var(--bg-card);border-left:5px solid transparent;padding:12px 16px;border-radius:12px;box-shadow:0 2px 8px #0000000d;border:1px solid var(--border)}.tx-mobile-card.income{border-left-color:var(--success)}.tx-mobile-card.expense{border-left-color:var(--danger)}.tx-card-main{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.tx-card-left{display:flex;flex-direction:column;gap:4px}.type-tag{font-size:10px;text-transform:uppercase;font-weight:700;padding:2px 6px;border-radius:4px;width:fit-content}.type-tag.income{background:#10b9811a;color:var(--success)}.type-tag.expense{background:#ef44441a;color:var(--danger)}.tx-card-category{font-weight:600;font-size:15px}.tx-card-date{font-size:12px;color:var(--text-muted)}.tx-card-amount{font-weight:700;font-size:16px}.tx-card-amount.income{color:var(--success)}.tx-card-amount.expense{color:var(--danger)}.tx-card-footer{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:8px;margin-top:4px}.tx-card-desc{font-size:13px;color:var(--text-muted);font-style:italic;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}.tx-card-actions{display:flex;gap:15px;font-size:20px;color:var(--primary)}.tx-card-actions svg:last-child{color:var(--danger)}.filters-grid{grid-template-columns:1fr 1fr;gap:10px}}.statistics-page{max-width:1100px}.stats-filters{display:flex;gap:12px}.stats-filters .form-control{width:auto}.stats-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:24px}.stat-item{padding:20px 24px}.stat-label{font-size:13px;color:var(--text-muted);margin-bottom:8px}.stat-value{font-size:22px;font-weight:700}.chart-card{margin-bottom:20px}.chart-card h3{font-size:16px;font-weight:600;margin-bottom:20px}.chart-container{height:300px;position:relative}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px}.empty-chart{height:200px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);font-size:14px}.cat-breakdown{display:flex;flex-direction:column;gap:12px}.cat-row{display:grid;grid-template-columns:12px 120px 1fr 130px 90px;align-items:center;gap:12px}.cat-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.cat-name{font-size:14px;font-weight:500;white-space:nowrap}.cat-bar-wrap{height:8px;background:var(--bg-card2);border-radius:4px;overflow:hidden}.cat-bar{height:100%;border-radius:4px;transition:width .5s ease;opacity:.8}.cat-total{font-size:14px;font-weight:600;text-align:right;white-space:nowrap}.cat-count{font-size:12px;text-align:right}@media (max-width: 768px){.stats-summary,.charts-row{grid-template-columns:1fr}.stats-filters{flex-direction:column}.cat-row{grid-template-columns:12px 100px 1fr 100px}.cat-count{display:none}}@media (max-width: 480px){.page-header{flex-direction:column;gap:12px}}.layout{display:flex;min-height:100vh}.sidebar{width:260px;min-width:260px;background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 16px;position:sticky;top:0;height:100vh}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 8px;margin-bottom:32px;font-size:20px;font-weight:700;color:var(--primary-light)}.logo-icon{font-size:28px;color:var(--primary)}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;font-size:15px;font-weight:500;color:var(--text-muted);transition:all .2s}.nav-item:hover{background:var(--bg-card2);color:var(--text)}.nav-item.active{background:#6366f126;color:var(--primary-light)}.nav-item svg{font-size:20px}.sidebar-footer{display:flex;flex-direction:column;gap:12px;border-top:1px solid var(--border);padding-top:16px}.user-info{display:flex;align-items:center;gap:12px;padding:8px}.user-avatar{width:40px;height:40px;border-radius:50%;background:#6366f133;display:flex;align-items:center;justify-content:center;font-size:20px;color:var(--primary-light);flex-shrink:0}.user-name{font-size:14px;font-weight:600}.user-email{font-size:12px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}.logout-btn{width:100%;justify-content:center}.main-content{flex:1;overflow:auto;padding:32px}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:18px;color:var(--text-muted)}.mobile-menu-btn{display:none;position:fixed;top:15px;left:15px;z-index:1100;background:#3b82f6;color:#fff;border:none;padding:8px;border-radius:6px;font-size:24px;cursor:pointer}.sidebar-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;z-index:1001}.mobile-menu-btn{display:none;position:fixed;top:15px;left:15px;z-index:1100;background:var(--primary);color:#fff;border:none;padding:8px;border-radius:6px;font-size:24px;cursor:pointer;box-shadow:0 2px 8px #0003}.sidebar-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#00000080;z-index:1040;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}@media (max-width: 768px){.mobile-menu-btn{display:flex}.sidebar{position:fixed;top:0;left:0;transform:translate(-100%);width:260px;min-width:260px;height:100vh;z-index:1050;background:var(--bg-card);transition:transform .3s cubic-bezier(.4,0,.2,1);border-right:1px solid var(--border)}.sidebar.active{transform:translate(0)}.main-content{margin-left:0!important;padding:35px 0 0}}*{margin:0;padding:0;box-sizing:border-box}:root{--primary: #6366f1;--primary-dark: #4f46e5;--primary-light: #a5b4fc;--success: #22c55e;--danger: #ef4444;--warning: #f59e0b;--bg: #0f172a;--bg-card: #1e293b;--bg-card2: #334155;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--border-light: #475569;--radius: 12px;--shadow: 0 4px 24px rgba(0, 0, 0, .3)}body{font-family:Inter,sans-serif;background-color:var(--bg);color:var(--text);min-height:100vh}a{text-decoration:none;color:inherit}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:3px}.container{max-width:1200px;margin:0 auto;padding:0 20px}.card{background:var(--bg-card);border-radius:var(--radius);padding:24px;border:1px solid var(--border);box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:8px;border:none;font-size:14px;font-weight:500;transition:all .2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--text-muted);color:var(--text)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group label{font-size:13px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.form-control{width:100%;padding:10px 14px;background:var(--bg-card2);border:1px solid var(--border);border-radius:8px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s}.form-control:focus{border-color:var(--primary)}.form-control::placeholder{color:var(--text-muted)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600}.badge-income{background:#22c55e26;color:var(--success)}.badge-expense{background:#ef444426;color:var(--danger)}.text-income{color:var(--success)}.text-expense{color:var(--danger)}.text-muted{color:var(--text-muted)}@media (max-width: 768px){.container{padding:0 16px}}
