*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f0ff;--bg2: #ffffff;--bg3: #f0ebff;--border: rgba(124, 58, 237, .1);--border-strong: rgba(124, 58, 237, .2);--text: #1a1033;--text2: #7c6f8e;--primary: #7c3aed;--primary-light: #ede9fe;--primary-gradient: linear-gradient(135deg, #7c3aed 0%, #a855f7 50%, #ec4899 100%);--green: #059669;--green-bg: #d1fae5;--green-soft: rgba(5, 150, 105, .1);--red: #dc2626;--red-bg: #fee2e2;--red-soft: rgba(220, 38, 38, .1);--blue: #6366f1;--blue-bg: #e0e7ff;--blue-soft: rgba(99, 102, 241, .1);--yellow: #d97706;--yellow-bg: #fef3c7;--radius: 16px;--radius-sm: 10px;--shadow: 0 2px 16px rgba(124, 58, 237, .07);--shadow-md: 0 4px 24px rgba(124, 58, 237, .12);--shadow-lg: 0 8px 40px rgba(124, 58, 237, .18)}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:14px;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}.card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:50px;font-size:14px;font-weight:600;border:none;transition:all .2s;white-space:nowrap}.btn:active{transform:scale(.97)}.btn-primary{background:var(--primary-gradient);color:#fff;box-shadow:0 4px 14px #7c3aed59}.btn-primary:hover{box-shadow:0 6px 20px #7c3aed73;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text2);border:1.5px solid var(--border-strong)}.btn-ghost:hover{background:var(--bg3);color:var(--text);border-color:var(--primary)}.btn-danger{background:var(--red-soft);color:var(--red);border:1.5px solid rgba(220,38,38,.2)}.btn-danger:hover{background:var(--red-bg)}.btn-sm{padding:5px 12px;font-size:12px}.btn-icon{padding:6px;border-radius:8px;background:var(--bg3);border:1px solid var(--border);color:var(--text2);font-size:14px;line-height:1}.btn-icon:hover{background:var(--primary-light);color:var(--primary)}.input{width:100%;background:var(--bg3);border:1.5px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);font-size:14px;outline:none;transition:border-color .2s,box-shadow .2s}.input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #7c3aed1a;background:#fff}.input::placeholder{color:var(--text2)}select.input option{background:#fff;color:var(--text)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600;letter-spacing:.3px}.badge-income{background:var(--green-bg);color:var(--green)}.badge-expense{background:var(--red-bg);color:var(--red)}.badge-planned-income{background:var(--blue-bg);color:var(--blue)}.badge-planned-expense{background:var(--yellow-bg);color:var(--yellow)}.amount-income{color:var(--green);font-weight:700}.amount-expense{color:var(--red);font-weight:700}.amount-planned-income{color:var(--blue);font-weight:700}.amount-planned-expense{color:var(--yellow);font-weight:700}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1a103380;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg2);border:1px solid var(--border-strong);border-radius:24px;padding:28px;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.modal-title{font-size:20px;font-weight:700;margin-bottom:20px;background:var(--primary-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.form-group label{font-size:13px;color:var(--text2);font-weight:600}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.type-tabs{display:flex;gap:6px;background:var(--bg3);padding:4px;border-radius:50px;margin-bottom:16px}.type-tab{flex:1;padding:8px;text-align:center;border-radius:50px;font-size:13px;font-weight:600;border:none;background:transparent;color:var(--text2);transition:all .2s}.type-tab.income.active{background:var(--green-bg);color:var(--green)}.type-tab.expense.active{background:var(--red-bg);color:var(--red)}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--bg3);border-radius:var(--radius-sm);margin-bottom:14px;border:1.5px solid var(--border)}.toggle-row label{font-size:13px;font-weight:600;color:var(--text)}.toggle-row span{font-size:12px;color:var(--text2)}.toggle{position:relative;width:40px;height:22px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border-strong);border-radius:50px;transition:.2s;cursor:pointer}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 4px #0003}.toggle input:checked+.toggle-slider{background:var(--primary-gradient)}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.who-selector{display:flex;gap:8px}.who-btn{flex:1;padding:8px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:1.5px solid var(--border-strong);background:transparent;color:var(--text2);transition:all .2s;text-align:center}.who-btn.active{background:var(--primary-gradient);color:#fff;border-color:transparent;box-shadow:0 3px 10px #7c3aed4d}.layout{display:grid;grid-template-columns:240px 1fr;min-height:100vh}.sidebar{background:var(--primary-gradient);padding:24px 16px;display:flex;flex-direction:column;gap:4px;position:sticky;top:0;height:100vh;overflow:hidden}.sidebar:before{content:"";position:absolute;top:-60px;right:-60px;width:200px;height:200px;background:#ffffff0f;border-radius:50%;pointer-events:none}.sidebar:after{content:"";position:absolute;bottom:-80px;left:-40px;width:240px;height:240px;background:#ffffff0a;border-radius:50%;pointer-events:none}.sidebar .logo{font-size:22px;font-weight:800;color:#fff;margin-bottom:28px;padding:0 10px;letter-spacing:-.3px}.sidebar .logo-sub{font-size:11px;font-weight:500;color:#fff9;letter-spacing:.5px}.nav-item{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:50px;color:#ffffffb3;font-weight:600;font-size:14px;transition:all .2s;position:relative;z-index:1}.nav-item:hover{background:#ffffff1f;color:#fff}.nav-item.active{background:#fff3;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nav-item svg{flex-shrink:0}.sidebar-footer{margin-top:auto;padding:0 10px;font-size:12px;color:#ffffff73;position:relative;z-index:1}.page{padding:28px 32px;max-width:1200px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.page-title{font-size:24px;font-weight:800;color:var(--text);letter-spacing:-.4px}.page-subtitle{font-size:14px;color:var(--text2);margin-top:2px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:14px;margin-bottom:24px}.stat-card{border-radius:var(--radius);padding:18px 20px;border:1.5px solid transparent;position:relative;overflow:hidden}.stat-card:after{content:attr(data-emoji);position:absolute;bottom:-4px;right:10px;font-size:44px;opacity:.15;line-height:1}.stat-card-balance{background:linear-gradient(135deg,#ede9fe,#ddd6fe);border-color:#7c3aed33}.stat-card-income{background:linear-gradient(135deg,#d1fae5,#a7f3d0);border-color:#05966933}.stat-card-expense{background:linear-gradient(135deg,#fee2e2,#fecaca);border-color:#dc262633}.stat-card-planned{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);border-color:#6366f133}.stat-card .label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.7px;opacity:.6;margin-bottom:8px}.stat-card .value{font-size:24px;font-weight:800;letter-spacing:-.5px}.stat-card .sub{font-size:11px;opacity:.55;margin-top:4px}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;font-weight:700;color:var(--text2);text-transform:uppercase;letter-spacing:.6px;padding:10px 14px;border-bottom:1px solid var(--border);background:var(--bg3)}th:first-child{border-radius:10px 0 0 10px}th:last-child{border-radius:0 10px 10px 0}td{padding:13px 14px;border-bottom:1px solid var(--border);font-size:14px;vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg3)}.progress-bar{height:8px;background:var(--bg3);border-radius:50px;overflow:hidden}.progress-fill{height:100%;border-radius:50px;background:var(--primary-gradient);transition:width .6s cubic-bezier(.34,1.56,.64,1)}.progress-fill.done{background:linear-gradient(90deg,var(--green),#34d399)}.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:50px;font-size:11px;font-weight:600;background:var(--bg3);color:var(--text2);border:1px solid var(--border)}.chip-nikita{background:linear-gradient(135deg,#ede9fe,#e0e7ff);color:var(--primary);border-color:#7c3aed33}.chip-lena{background:linear-gradient(135deg,#fce7f3,#fdf4ff);color:#be185d;border-color:#be185d33}.rec-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:50px;font-size:10px;font-weight:700;background:var(--primary-light);color:var(--primary);border:1px solid rgba(124,58,237,.15)}.empty-state{text-align:center;color:var(--text2);padding:56px 0}.empty-state .emoji{font-size:48px;margin-bottom:12px}.empty-state .title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:4px}.empty-state .sub{font-size:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.section-title{font-size:15px;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.confirm-box{background:var(--bg2);border:1px solid var(--border-strong);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-md);max-width:340px}.confirm-box h3{font-size:16px;font-weight:700;margin-bottom:8px}.confirm-box p{font-size:13px;color:var(--text2);margin-bottom:16px;line-height:1.5}.confirm-actions{display:flex;gap:8px}@keyframes heartbeat{0%,to{transform:scale(1)}14%{transform:scale(1.25)}28%{transform:scale(1)}42%{transform:scale(1.18)}56%{transform:scale(1)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.cat-mobile{display:none}.cat-desktop{display:block}.float-mobile{display:none}@media(max-width:900px){.layout{grid-template-columns:1fr;padding-bottom:68px}.sidebar{position:fixed;bottom:0;left:0;right:0;top:auto;height:68px;flex-direction:row;padding:0;gap:0;border-radius:20px 20px 0 0;box-shadow:0 -4px 24px #7c3aed40;overflow:hidden;z-index:50}.sidebar:before,.sidebar:after{display:none}.sidebar .logo,.sidebar-footer,.cat-desktop{display:none}.cat-mobile,.float-mobile{display:block}.nav-item{flex:1;flex-direction:column;align-items:center;justify-content:center;padding:8px 4px 10px;border-radius:0;gap:3px;font-size:10px;font-weight:700;white-space:nowrap}.nav-item svg{width:22px;height:22px}.nav-item.active{background:#fff3}.page{padding:16px 16px 20px}.form-row,.grid-2{grid-template-columns:1fr}.stats-grid{grid-template-columns:1fr 1fr}}
