:root{--bg-main: #f1f5f9;--bg-soft: #f8fafc;--bg-card: #ffffff;--primary: #6366f1;--primary-dark: #4f46e5;--success: #22c55e;--success-dark: #16a34a;--danger: #ef4444;--text-main: #111827;--text-muted: #6b7280;--border: #e5e7eb;--shadow-sm: 0 6px 16px rgba(0, 0, 0, .08);--shadow-md: 0 10px 24px rgba(0, 0, 0, .08)}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg-main);color:var(--text-main)}.container{max-width:1200px;margin:auto;padding:24px}.card{background:var(--bg-card);border-radius:14px;padding:18px;box-shadow:var(--shadow-sm)}.muted{color:var(--text-muted);font-size:13px}.empty-state{text-align:center;padding:32px}.app-shell{min-height:100vh;background:linear-gradient(180deg,var(--bg-soft),#eef2ff)}.app-header{padding:28px 20px;background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;box-shadow:0 10px 30px #4f46e566}.app-title{margin:0;font-size:28px;font-weight:700}.app-subtitle{margin-top:4px;opacity:.85;font-size:14px}.section{margin-bottom:28px}.dashboard{display:flex;flex-direction:column;gap:16px}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px}.kpi-card{border-radius:16px;padding:18px;background:linear-gradient(135deg,var(--bg-soft),#ffffff);box-shadow:var(--shadow-md);transition:transform .2s,box-shadow .2s}.kpi-card:hover{transform:translateY(-2px)}.kpi-label{font-size:13px;opacity:.7}.kpi-value{margin-top:8px;font-size:28px;font-weight:600}.kpi-card.income{background:linear-gradient(135deg,#dcfce7,#fff);color:#166534}.kpi-card.expense{background:linear-gradient(135deg,#fee2e2,#fff);color:#991b1b}.kpi-card.balance{background:linear-gradient(135deg,#e0e7ff,#fff);color:#3730a3}.kpi-card.balance.danger{background:linear-gradient(135deg,#fecaca,#fff);color:#7f1d1d}.form-section{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:20px}.expense-form,.income-form{display:flex;flex-direction:column;gap:16px}.income-form{border-left:4px solid var(--success)}.form-header h3{margin:0}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.field{display:flex;flex-direction:column;gap:6px}.field label{font-size:13px;opacity:.7}.field input,.table-toolbar input,.table-toolbar select,select{padding:10px 12px;border-radius:10px;border:1px solid var(--border);font-size:14px}.field input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-actions{display:flex;justify-content:flex-end}button{cursor:pointer}button.primary{background:linear-gradient(135deg,var(--primary),var(--primary-dark));color:#fff;border:none;border-radius:12px;padding:10px 18px;box-shadow:0 8px 18px #6366f159}button.primary.success{background:linear-gradient(135deg,var(--success),var(--success-dark))}button.primary:disabled{opacity:.5;box-shadow:none}.icon-btn{background:transparent;border:none;opacity:0;transition:opacity .2s,color .2s}.icon-btn.danger:hover{color:var(--danger)}.table-card{padding-bottom:10px}.table-wrapper{overflow-x:auto}.expense-table{width:100%;border-collapse:collapse;font-size:14px}.expense-table thead th{position:sticky;top:0;background:var(--bg-soft);padding:12px;border-bottom:1px solid var(--border);cursor:pointer}.expense-table tbody td{padding:12px;border-bottom:1px solid #f1f5f9}.expense-table tbody tr:hover{background:var(--bg-soft)}.expense-table tbody tr:hover .icon-btn{opacity:1}.amount{text-align:right;font-weight:600}.category-pill{display:inline-block;padding:4px 10px;border-radius:999px;font-size:12px;background:#eef2ff;color:#4338ca}.category-pill.success{background:#dcfce7;color:#166534}.table-footer{display:flex;justify-content:space-between;margin-top:12px}.pager button{padding:6px 12px;border-radius:8px;border:1px solid var(--border);background:#fff}.pager button:disabled{opacity:.5}.month-tabs{display:flex;gap:6px;overflow-x:auto}.month-tabs button{padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#fff}.month-tabs button.active{background:var(--primary);color:#fff}@media (max-width: 768px){.app-title{font-size:22px}.container{padding:16px}}.header-inner{max-width:1200px;margin:auto}.section{margin-bottom:36px}.section-header{margin-bottom:14px}.section-header .muted{font-size:13px;margin-top:2px}.form-section{margin-top:16px}@media (max-width: 768px){.section{margin-bottom:28px}}.accordion-item{margin-top:10px;background:#f9fafb;border-radius:12px;padding:10px}.accordion-item summary{display:flex;justify-content:space-between;cursor:pointer;font-weight:600}.day-block{margin-top:10px}.day-header{display:flex;justify-content:space-between;font-weight:500;opacity:.8;margin-bottom:6px}.row{display:flex;justify-content:space-between;background:#fff;padding:10px 12px;border-radius:10px;margin-bottom:6px}.title{font-weight:500}.small{font-size:12px}.accordion{display:flex;flex-direction:column;gap:12px}.accordion-item{background:#f9fafb;border-radius:14px;padding:10px 12px;box-shadow:inset 0 0 0 1px #eef2f7}.accordion-item>summary{list-style:none;display:flex;justify-content:space-between;align-items:center;cursor:pointer;font-weight:600;font-size:15px;padding:6px 4px}.accordion-item>summary::-webkit-details-marker{display:none}.accordion-item>summary span:first-child{color:#111827}.summary-meta{font-size:13px;opacity:.7}.day-accordion{margin-top:10px;background:#fff;border-radius:12px;padding:8px 10px;box-shadow:inset 0 0 0 1px #f1f5f9}.day-accordion>summary{list-style:none;display:flex;justify-content:space-between;cursor:pointer;font-weight:500;font-size:13px;padding:4px 2px;opacity:.85}.day-accordion>summary::-webkit-details-marker{display:none}.row{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#f9fafb;padding:10px 12px;border-radius:10px;margin-top:8px;transition:transform .15s ease,box-shadow .15s ease}.row:hover{transform:translateY(-1px);box-shadow:0 6px 14px #00000014}.row .title{font-weight:500;font-size:14px;color:#111827}.row .muted.small{font-size:12px;opacity:.65;margin-top:2px}.row .right{display:flex;align-items:center;gap:10px}.row .amount{font-weight:600;font-size:14px;white-space:nowrap}.row .icon-btn{opacity:0;transition:opacity .2s ease,color .2s ease}.row:hover .icon-btn{opacity:1}.row .icon-btn.danger:hover{color:#ef4444}.table-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:12px}.table-header input{padding:8px 12px;border-radius:10px;border:1px solid #e5e7eb;font-size:14px;outline:none}.table-header input:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}@media (max-width: 640px){.row{flex-direction:column;align-items:flex-start}.row .right{width:100%;justify-content:space-between}.accordion-item>summary,.day-accordion>summary{font-size:14px}}.chart-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:16px;margin-top:16px}.chart-card h3{margin-bottom:10px;font-size:15px}.chart-card.full-width{grid-column:1 / -1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000073;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:14px;padding:20px;width:100%;max-width:420px;box-shadow:0 20px 50px #00000040;display:flex;flex-direction:column;gap:12px}.modal h3{margin:0 0 6px}.modal input{padding:10px 12px;border-radius:10px;border:1px solid #e5e7eb}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:10px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a8c;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;width:100%;max-width:440px;border-radius:16px;padding:18px;box-shadow:0 30px 70px #00000059;animation:modalIn .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.modal-title{display:flex;align-items:center;gap:8px;font-size:16px}.modal-title svg{color:#6366f1}.modal-body{display:flex;flex-direction:column;gap:12px;margin-top:10px}.input-group{display:flex;align-items:center;gap:10px;background:#f9fafb;border-radius:12px;padding:10px 12px;border:1px solid #e5e7eb;transition:border .2s,box-shadow .2s}.input-group svg{color:#6b7280;font-size:16px}.input-group input{border:none;outline:none;background:transparent;font-size:14px;width:100%}.input-group:focus-within{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:16px}.icon-btn.close{opacity:.6}.icon-btn.close:hover{opacity:1;color:#ef4444}@keyframes modalIn{0%{transform:translateY(8px) scale(.98);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a99;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000}.modal-form{background:#fff;border-radius:18px;padding:28px;width:100%;max-width:760px;box-shadow:0 40px 80px #00000059;animation:modalIn .25s ease}.modal-header{display:flex;justify-content:space-between;align-items:center}.modal-header h2{margin:0;font-size:22px;font-weight:600}.modal-subtitle{margin:6px 0 20px;font-size:14px;color:var(--text-muted)}.input-with-icon{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#fff}.input-with-icon svg{color:#6b7280}.input-with-icon input{border:none;outline:none;font-size:15px;width:100%}.input-with-icon:focus-within{border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.icon-btn.close{font-size:18px;opacity:.6}.icon-btn.close:hover{opacity:1;color:var(--danger)}@keyframes modalIn{0%{transform:translateY(10px) scale(.97);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.app-header.sticky{position:sticky;top:0;z-index:50}.section-card{background:var(--bg-card);border-radius:18px;padding:22px;box-shadow:var(--shadow-sm)}.section-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px}.section-header.split{align-items:center}.section-header h2{margin:0;font-size:20px;font-weight:600}.section-header .muted{margin-top:4px}.header-inner{max-width:1200px;margin:auto;padding:0 20px;display:flex;align-items:center}.header-left{display:flex;flex-direction:column}@media (max-width: 768px){.section-card{padding:16px}.section-header{flex-direction:column;align-items:flex-start;gap:6px}}.fab-container{position:fixed;right:20px;bottom:20px;display:flex;flex-direction:column;gap:14px;z-index:200}.fab{width:56px;height:56px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;cursor:pointer;box-shadow:0 12px 30px #00000040;position:relative;transition:transform .2s ease,box-shadow .2s ease}.fab:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 16px 36px #0000004d}.fab-plus{position:absolute;bottom:10px;right:10px;font-size:12px;background:#fff;color:#111827;border-radius:50%;padding:2px}.fab-income{background:linear-gradient(135deg,#22c55e,#16a34a)}.fab-expense{background:linear-gradient(135deg,#ef4444,#dc2626)}@media (max-width: 640px){.fab-container{right:14px;bottom:14px}.fab{width:52px;height:52px}}@media (max-width: 1024px){.container{padding:20px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.chart-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.modal-form{max-width:90%;padding:22px}}@media (max-width: 768px){.app-title{font-size:20px}.app-subtitle{font-size:12px}.section{margin-bottom:22px}.section-card{padding:16px}.kpi-grid{grid-template-columns:1fr}.kpi-card{padding:16px}.kpi-value{font-size:22px}.form-section,.form-grid{grid-template-columns:1fr}.row{flex-direction:column;align-items:flex-start;gap:8px}.row .right{width:100%;justify-content:space-between}.amount{font-size:13px}.accordion-item>summary,.day-accordion>summary{font-size:14px}.chart-grid{grid-template-columns:1fr}.chart-card.full-width{grid-column:auto}.modal-form{padding:18px;max-width:95%}.modal-header h2{font-size:18px}}@media (max-width: 480px){body{font-size:14px}.container,.card{padding:14px}.app-header{padding:18px 14px}.section-header h2{font-size:18px}.fab-container{right:12px;bottom:12px}.fab{width:48px;height:48px;font-size:20px}}
