@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@300;400;500;600;700;800&display=swap";:root{--bg-gradient:radial-gradient(circle at 50% 50%, #1a1f35 0%, #0d0f1b 100%);--panel-bg:#161c2da6;--panel-border:#ffffff14;--panel-glow:#0000004d;--text-primary:#f3f4f6;--text-secondary:#9ca3af;--text-muted:#6b7280;--color-primary:#8b5cf6;--color-primary-glow:#8b5cf659;--color-success:#10b981;--color-success-glow:#10b98140;--color-danger:#f43f5e;--color-danger-glow:#f43f5e40;--color-warning:#f59e0b;--color-info:#06b6d4;--font-sans:"Inter", system-ui, -apple-system, sans-serif;--font-title:"Outfit", sans-serif;--nav-height:64px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg-gradient);color:var(--text-primary);background-attachment:fixed;min-height:100vh;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#0d0f1b80}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.app-container{min-height:100vh;padding-bottom:calc(var(--nav-height) + 24px);flex-direction:column;display:flex}@media (width>=769px){.app-container{flex-direction:row;padding-bottom:0;padding-left:240px}}h1,h2,h3,h4{font-family:var(--font-title);letter-spacing:-.02em;font-weight:600}.glow-text{text-shadow:0 0 12px var(--color-primary-glow)}.glass-card{background:var(--panel-bg);-webkit-backdrop-filter:blur(16px);border:1px solid var(--panel-border);box-shadow:0 8px 32px 0 var(--panel-glow);border-radius:16px;padding:20px;transition:transform .2s,border-color .2s,box-shadow .2s}.glass-card:hover{border-color:#ffffff26;box-shadow:0 12px 40px #0006}.btn{font-family:var(--font-sans);cursor:pointer;border:1px solid #0000;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:10px 18px;font-size:.95rem;font-weight:500;transition:all .2s;display:inline-flex}.btn-primary{color:#fff;box-shadow:0 4px 15px var(--color-primary-glow);background:linear-gradient(135deg,#8b5cf6 0%,#6366f1 100%)}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #8b5cf680}.btn-secondary{color:var(--text-primary);background:#ffffff14;border:1px solid #ffffff1a}.btn-secondary:hover{background:#ffffff26;border-color:#fff3}.btn-danger{color:#ff8a9e;background:#f43f5e26;border:1px solid #f43f5e4d}.btn-danger:hover{background:#f43f5e4d;border-color:#f43f5e80}.btn-sm{border-radius:8px;padding:6px 12px;font-size:.85rem}.form-group{margin-bottom:16px}.form-group label{color:var(--text-secondary);margin-bottom:6px;font-size:.85rem;font-weight:500;display:block}.form-control{border:1px solid var(--panel-border);width:100%;color:var(--text-primary);font-family:var(--font-sans);background:#0d0f1b99;border-radius:10px;padding:10px 14px;font-size:.95rem;transition:border-color .2s,box-shadow .2s}.form-control:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-glow);outline:none}.form-control::placeholder{color:var(--text-muted)}select.form-control{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%239ca3af'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M19 9l-7 7-7-7'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:16px;padding-right:36px}.mobile-nav{height:var(--nav-height);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--panel-border);z-index:100;background:#0f1423d9;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.nav-item{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;flex-direction:column;flex:1;align-items:center;gap:4px;padding:8px 0;font-size:.7rem;text-decoration:none;transition:color .2s;display:flex}.nav-item svg{width:20px;height:20px;transition:transform .2s}.nav-item.active{color:var(--color-primary);font-weight:600}.nav-item.active svg{filter:drop-shadow(0 0 6px var(--color-primary-glow));transform:translateY(-2px)}.desktop-sidebar{display:none}@media (width>=769px){.mobile-nav{display:none}.desktop-sidebar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-right:1px solid var(--panel-border);z-index:100;background:#0f1423b3;flex-direction:column;width:240px;padding:24px 16px;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{font-family:var(--font-title);background:linear-gradient(135deg,#a78bfa 0%,#818cf8 100%);-webkit-text-fill-color:transparent;-webkit-background-clip:text;margin-bottom:32px;padding-left:12px;font-size:1.4rem;font-weight:800}.sidebar-menu{flex-direction:column;gap:8px;display:flex}.sidebar-item{color:var(--text-secondary);cursor:pointer;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;width:100%;padding:12px;font-size:.95rem;text-decoration:none;transition:all .2s;display:flex}.sidebar-item svg{width:20px;height:20px}.sidebar-item:hover{color:var(--text-primary);background:#ffffff0d}.sidebar-item.active{color:#c084fc;border-left:3px solid var(--color-primary);background:#8b5cf626;padding-left:9px;font-weight:600}}.main-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:16px}@media (width>=769px){.main-content{padding:32px}}.page-header{justify-content:space-between;align-items:center;gap:16px;margin-bottom:24px;display:flex}.page-title{font-size:1.5rem;font-weight:700}@media (width>=769px){.page-title{font-size:2rem}}.month-picker{background:var(--panel-bg);border:1px solid var(--panel-border);border-radius:12px;align-items:center;gap:8px;padding:6px 12px;display:flex}.month-picker span{font-family:var(--font-title);text-align:center;min-width:90px;font-size:1.1rem;font-weight:600}.month-btn{color:var(--text-primary);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;display:flex}.month-btn:hover{background:#ffffff14}.month-btn svg{width:20px;height:20px}.summary-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width>=769px){.summary-grid{grid-template-columns:repeat(4,1fr);gap:20px}}.summary-card{position:relative;overflow:hidden}.summary-card:before{content:"";width:4px;height:100%;position:absolute;top:0;left:0}.summary-card.expense:before{background:var(--color-danger)}.summary-card.income:before{background:var(--color-success)}.summary-card.net:before{background:var(--color-primary)}.summary-card.unpaid:before{background:var(--color-info)}.summary-label{color:var(--text-secondary);margin-bottom:4px;font-size:.75rem}.summary-value{font-family:var(--font-title);font-size:1.25rem;font-weight:700}@media (width>=769px){.summary-value{font-size:1.8rem}}.chart-grid{grid-template-columns:1fr;gap:20px;margin-bottom:20px;display:grid}@media (width>=1024px){.chart-grid{grid-template-columns:3fr 2fr}.chart-grid.three-cols{grid-template-columns:1fr 1fr 1fr}}.chart-card h3{color:var(--text-secondary);margin-bottom:16px;font-size:1rem;font-weight:500}.chart-container{justify-content:space-between;align-items:flex-end;height:240px;padding-top:20px;display:flex;position:relative}.bar-chart-y-axis{height:100%;color:var(--text-muted);flex-direction:column;justify-content:space-between;width:40px;padding-bottom:20px;font-size:.7rem;display:flex}.bar-chart-body{flex-direction:column;flex:1;height:100%;display:flex}.bar-chart-bars{border-bottom:1px solid #ffffff1a;flex:1;justify-content:space-around;align-items:flex-end;padding-bottom:4px;display:flex}.bar-wrapper{cursor:pointer;flex-direction:column;flex:1;justify-content:flex-end;align-items:center;height:100%;display:flex;position:relative}.bar-value-tooltip{color:#fff;opacity:0;pointer-events:none;white-space:nowrap;z-index:10;background:#000000d9;border-radius:4px;padding:2px 6px;font-size:.65rem;transition:opacity .2s;position:absolute;top:-24px}.bar-wrapper:hover .bar-value-tooltip{opacity:1}.bar{border-top-left-radius:4px;border-top-right-radius:4px;width:60%;max-width:14px;transition:height .6s cubic-bezier(.17,.67,.83,.67)}.bar.expense{background:linear-gradient(to top, #f43f5e33, var(--color-danger))}.bar.income{background:linear-gradient(to top, #10b98133, var(--color-success))}.bar-chart-labels{height:20px;color:var(--text-muted);justify-content:space-around;align-items:center;font-size:.65rem;display:flex}.donut-chart-container{justify-content:center;align-items:center;gap:16px;height:100%;display:flex}.donut-svg-wrapper{width:140px;height:140px;position:relative}.donut-center-text{text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.donut-center-label{color:var(--text-secondary);font-size:.7rem}.donut-center-val{font-family:var(--font-title);font-size:.95rem;font-weight:700}.donut-legend{flex-direction:column;flex:1;gap:8px;max-height:180px;padding-right:4px;display:flex;overflow-y:auto}.legend-item{color:var(--text-secondary);align-items:center;gap:8px;font-size:.75rem;display:flex}.legend-color{border-radius:50%;width:8px;height:8px}.legend-text{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.legend-value{font-family:var(--font-title);color:var(--text-primary);font-weight:600}.payment-list{flex-direction:column;gap:14px;display:flex}.payment-item{flex-direction:column;gap:6px;display:flex}.payment-info{justify-content:space-between;font-size:.85rem;display:flex}.payment-bar-track{background:#ffffff0d;border-radius:3px;height:6px;overflow:hidden}.payment-bar-fill{background:linear-gradient(90deg,#818cf8,#8b5cf6);border-radius:3px;height:100%;transition:width .6s cubic-bezier(.1,.8,.2,1)}.table-card{padding:0;overflow:hidden}.table-header-row{border-bottom:1px solid var(--panel-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.table-responsive{overflow-x:auto}table.kakeibo-table{border-collapse:collapse;text-align:left;width:max-content;min-width:1180px;font-size:.9rem}table.kakeibo-table th{color:var(--text-secondary);border-bottom:1px solid var(--panel-border);white-space:nowrap;background:#00000026;padding:14px 20px;font-weight:500}table.kakeibo-table td{white-space:nowrap;border-bottom:1px solid #ffffff08;padding:14px 20px}table.kakeibo-table tbody tr:hover{background:#ffffff05}table.kakeibo-table th.text-right,table.kakeibo-table td.text-right{text-align:right;white-space:nowrap;min-width:100px;padding-left:16px;padding-right:20px}table.kakeibo-table th:last-child,table.kakeibo-table td:last-child{padding-right:24px}table.kakeibo-table th.col-shop,table.kakeibo-table td.col-shop{text-overflow:ellipsis;white-space:nowrap;min-width:180px;max-width:240px;overflow:hidden}table.kakeibo-table th.col-description,table.kakeibo-table td.col-description{text-overflow:ellipsis;white-space:nowrap;min-width:180px;max-width:260px;overflow:hidden}@media (width<=768px){table.kakeibo-table{font-size:12px}table.kakeibo-table th,table.kakeibo-table td{padding:10px 12px;font-size:12px}table.kakeibo-table th.text-right,table.kakeibo-table td.text-right{padding-left:10px;padding-right:12px}table.kakeibo-table th:last-child,table.kakeibo-table td:last-child{padding-right:16px}}.mobile-transaction-list{flex-direction:column;gap:12px;display:flex}.mobile-transaction-card{justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.tx-main{flex-direction:column;gap:4px;display:flex}.tx-title{font-size:.95rem;font-weight:500}.tx-meta{color:var(--text-secondary);gap:8px;font-size:.75rem;display:flex}.tx-badge{background:#ffffff14;border-radius:4px;padding:1px 6px}.tx-amount{font-family:var(--font-title);text-align:right;font-size:1.05rem;font-weight:700}.tx-out{color:#f43f5e}.tx-in{color:#10b981}.tx-actions{align-items:center;gap:8px;display:flex}.drag-drop-area{text-align:center;cursor:pointer;background:#8b5cf608;border:2px dashed #8b5cf64d;border-radius:16px;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;transition:all .2s;display:flex}.drag-drop-area:hover,.drag-drop-area.dragover{border-color:var(--color-primary);background:#8b5cf614}.drag-drop-area svg{width:48px;height:48px;color:var(--text-secondary)}.import-preview-container{margin-top:24px}.preview-badge-row{gap:12px;margin-bottom:12px;font-size:.85rem;display:flex}.preview-badge{border-radius:6px;padding:4px 10px;font-weight:500}.preview-badge.success{color:#8ae4c4;background:#10b98126}.preview-badge.warning{color:#fccf7a;background:#f59e0b26}.preview-badge.error{color:#ff8a9e;background:#f43f5e26}.preview-row-warning{background:#f59e0b14!important}.preview-row-error{background:#f43f5e14!important}.filter-bar{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px;display:grid}@media (width>=769px){.filter-bar{grid-template-columns:repeat(4,1fr);gap:16px}}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal-content{width:100%;max-width:500px;max-height:90vh;animation:.3s cubic-bezier(.1,.8,.2,1) modalFadeIn;overflow-y:auto}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-close-btn{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;display:flex}.modal-close-btn:hover{color:var(--text-primary)}.modal-actions{justify-content:flex-end;gap:12px;margin-top:24px;display:flex}.settings-section{margin-bottom:24px}.settings-section h3{color:var(--text-secondary);border-bottom:1px solid var(--panel-border);margin-bottom:12px;padding-bottom:8px;font-size:1.1rem}.category-master-grid{grid-template-columns:1fr;gap:12px;display:grid}@media (width>=769px){.category-master-grid{grid-template-columns:repeat(2,1fr);gap:16px}}.category-master-card{flex-direction:column;gap:6px;padding:14px 16px;display:flex}.category-master-name{color:var(--color-primary);font-size:1rem;font-weight:600}.category-master-genres{color:var(--text-secondary);font-size:.85rem;line-height:1.4}.toast{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--panel-border);z-index:2000;background:#161c2de6;border-radius:30px;align-items:center;gap:8px;padding:12px 24px;font-size:.9rem;animation:.3s toastIn,.3s 2.7s toastOut;display:flex;position:fixed;bottom:80px;left:50%;transform:translate(-50%);box-shadow:0 10px 25px #00000080}@keyframes toastIn{0%{opacity:0;bottom:60px}to{opacity:1;bottom:80px}}.text-success{color:var(--color-success)!important}.text-danger{color:var(--color-danger)!important}.text-warning{color:var(--color-warning)!important}.text-info{color:var(--color-info)!important}.text-right{text-align:right}.flex-row-center{align-items:center;gap:8px;display:flex}.cursor-pointer{cursor:pointer}.empty-state{text-align:center;color:var(--text-muted);padding:40px 20px}
