.invoice-card-container{position:relative;margin-bottom:20px;overflow:hidden;border-radius:var(--radius-md)}.invoice-card-swipe-actions{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;z-index:0;background:var(--bg-secondary)}.swipe-action{height:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0}.invoice-card-swipe-actions.right{background:#ff3b30;justify-content:flex-start}.invoice-card-swipe-actions.right .left-action{opacity:1;display:flex;padding-left:24px;align-items:center}.invoice-card-swipe-actions.left{background:#007aff;justify-content:flex-end}.invoice-card-swipe-actions.left .right-action{opacity:1;display:flex;padding-right:24px;align-items:center}.invoice-card{position:relative;z-index:1;background:var(--bg-card);padding:24px;margin-bottom:0;border-radius:var(--radius-md);border:1px solid var(--border-color);box-shadow:var(--shadow-sm);transition:transform .1s linear,background .2s ease;display:flex;justify-content:space-between;align-items:center;touch-action:pan-y}.invoice-card.swiping{transition:none;box-shadow:var(--shadow-md)}.invoice-card-left{display:flex;flex-direction:column;gap:4px}.invoice-card-title{font-size:1.125rem;font-weight:700;color:var(--text-primary);margin:0}.invoice-card-client{font-size:.875rem;color:var(--text-secondary)}.invoice-card-date{font-size:.75rem;color:var(--text-tertiary)}.invoice-card-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.invoice-card-amount{font-size:1.125rem;font-weight:400;color:var(--text-primary);letter-spacing:-.01em}.invoice-category-dot{width:8px;height:8px;border-radius:50%}.invoice-card-actions{display:flex;gap:12px;margin-top:12px}@media (max-width: 768px){.invoice-card{padding:20px}}.invoice-list{width:100%}.invoice-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;padding:20px 24px;background:var(--bg-card);border-radius:16px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);touch-action:pan-y pan-x;pointer-events:auto}.invoice-list-header h2{margin:0;font-size:1.375rem;color:var(--text-primary);font-weight:700;letter-spacing:-.3px}.invoice-list-total{font-size:1.125rem;color:var(--text-secondary);font-weight:500}.invoice-list-total strong{color:var(--accent-gold);font-size:1.5rem;font-weight:400;letter-spacing:-.5px}.invoice-list-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:24px}.invoice-list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:80px 20px;color:var(--text-tertiary);background:var(--bg-card);border-radius:16px;border:2px dashed var(--border-color)}.empty-mascot{width:120px;height:120px;object-fit:contain;margin-bottom:24px;opacity:.8;filter:drop-shadow(0 4px 12px rgba(0,0,0,.15))}.invoice-list-empty p{font-size:1.25rem;margin:0 0 8px;font-weight:600;color:var(--text-primary)}.empty-subtitle{font-size:.95rem;color:var(--text-secondary)}@media (max-width: 768px){.invoice-list-header{flex-direction:column;align-items:flex-start;gap:12px;padding:14px 16px}.invoice-list-header h2{font-size:1.125rem}.invoice-list-total{font-size:1rem}.invoice-list-total strong{font-size:1.25rem}.invoice-list-grid{grid-template-columns:1fr;gap:16px}}.edit-mode .stat-card,.edit-mode .chart-card{border:2px dashed rgba(255,255,255,.35);position:relative}.edit-mode .stat-card:hover,.edit-mode .chart-card:hover{border-color:var(--accent-gold)}.stat-drag-handle,.chart-drag-handle,.section-drag-handle{background:#0006;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.stat-drag-handle:hover,.chart-drag-handle:hover,.section-drag-handle:hover{background:var(--accent-gold);color:#000;transform:scale(1.1)}.invoice-list-header{cursor:pointer;transition:all .2s ease}.invoice-list-header:hover{background:var(--bg-hover)}.header-content-left{display:flex;align-items:center;gap:12px}.collapse-icon{color:var(--text-secondary);transition:transform .3s ease}.collapse-icon.collapsed{transform:rotate(-90deg)}.invoice-list-content{display:flex;flex-direction:column;gap:40px}.invoice-group{display:flex;flex-direction:column;gap:20px}.invoice-group-header{display:flex;align-items:center;gap:12px;padding:0 8px 12px;border-bottom:2px solid var(--border-color);margin-bottom:8px}.invoice-group-header h3{margin:0;font-size:1.125rem;color:var(--text-primary);font-weight:700;flex:1}.invoice-group-header svg{color:var(--accent-gold)}.group-count{background:var(--bg-secondary);color:var(--text-secondary);padding:4px 12px;border-radius:20px;font-size:.8125rem;font-weight:700;border:1px solid var(--border-color)}.invoice-form-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;overflow-y:auto;animation:fadeIn .3s ease}.invoice-form{background:var(--bg-primary);border-radius:20px;width:100%;max-width:640px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);border:1px solid var(--border-color);animation:slideUp .3s cubic-bezier(.4,0,.2,1)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.invoice-form-header{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:var(--bg-primary);z-index:10;border-radius:20px 20px 0 0}.invoice-form-header h2{margin:0;font-size:1.625rem;color:var(--text-primary);font-weight:700;letter-spacing:-.5px}.btn-close{background:var(--bg-tertiary);border:none;font-size:28px;color:var(--text-secondary);cursor:pointer;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:10px;transition:all .3s ease}.btn-close:hover{background:var(--bg-hover);color:var(--text-primary);transform:rotate(90deg)}.invoice-form-content{padding:24px}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:10px;font-weight:700;color:var(--text-primary);font-size:.875rem;letter-spacing:.3px}.required{color:var(--accent-danger)}.form-group input[type=text],.form-group input[type=number],.form-group input[type=date],.form-group input[type=file],.form-group textarea,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:.9375rem;transition:all .3s ease;box-sizing:border-box;background:var(--bg-secondary);color:var(--text-primary);height:48px}.form-group textarea{height:auto;min-height:100px}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:#007acc;background:var(--bg-primary);box-shadow:0 0 0 3px #007acc1a}.form-group-toggle{background:var(--bg-tertiary);border-radius:16px;padding:16px;margin-bottom:24px;border:1px solid var(--border-color)}.toggle-row{display:flex;justify-content:space-between;align-items:center;gap:16px}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-size:.875rem;font-weight:800;color:var(--text-primary)}.toggle-hint{font-size:.75rem;color:var(--text-secondary)}.toggle-warning{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color);font-size:.75rem;color:#ef4444;line-height:1.4;font-style:italic}.form-group input[type=file]::file-selector-button{padding:8px 16px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);font-weight:600;cursor:pointer;margin-right:12px;transition:all .2s ease}.form-group input[type=file]::file-selector-button:hover{background:var(--bg-hover)}.form-group textarea{resize:vertical}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.category-pills{display:grid;grid-template-columns:repeat(2,1fr);gap:8px}.category-pill{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.category-pill-dot{width:8px;height:8px;border-radius:50%}.category-pill.active{background:#007acc;color:#fff;border-color:#007acc;box-shadow:0 4px 12px #007acc33}.category-pill:hover:not(.active){background:var(--bg-hover);transform:translateY(-1px)}.checkbox-row{display:flex;align-items:flex-start;gap:10px}.checkbox-row input[type=checkbox]{margin-top:3px}.checkbox-label{font-size:.8125rem;color:var(--text-secondary)}.tags-input{display:flex;gap:10px;margin-bottom:14px}.tags-input input{flex:1}.btn-add-tag{padding:0 20px;background:#007acc;color:#fff;border:none;border-radius:12px;cursor:pointer;font-size:.75rem;font-weight:800;text-transform:uppercase;letter-spacing:1px}.btn-add-tag:hover{background:#0089ff;box-shadow:0 4px 12px #007acc4d}.tags-list{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.tag{display:inline-flex;align-items:center;gap:8px;background:var(--bg-tertiary);color:var(--text-primary);padding:8px 14px;border-radius:20px;font-size:.875rem;font-weight:600;border:1px solid var(--border-color)}.tag-remove{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:18px;line-height:1;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease}.tag-remove:hover{background:#d4af3733;transform:scale(1.1)}.available-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}.available-tags-label{font-size:.75rem;color:var(--text-tertiary);width:100%;font-weight:600}.tag-suggestion{background:var(--bg-tertiary);border:1px solid var(--border-color);color:var(--text-primary);padding:6px 12px;border-radius:16px;font-size:.75rem;font-weight:600;cursor:pointer;transition:all .2s ease}.tag-suggestion:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-1px)}.file-actions-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:12px}.btn-camera,.btn-upload-file{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px;border-radius:12px;border:1px solid #007ACC;background:transparent;color:#007acc;font-weight:800;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);font-size:.75rem;text-transform:uppercase;letter-spacing:.5px}.btn-camera:hover,.btn-upload-file:hover{background:#007acc;color:#fff;transform:translateY(-2px);box-shadow:0 8px 16px #007acc33}.dark .btn-upload-file{background:var(--bg-tertiary)}.dark .btn-upload-file:hover{background:var(--bg-hover)}.hidden-file-input{display:none!important}.file-preview-form{margin-top:14px}.file-preview-img{max-width:100%;max-height:200px;border-radius:10px;border:2px solid var(--border-color)}.file-preview-pdf-info{padding:16px;background:var(--bg-tertiary);border-radius:10px;border:2px solid var(--border-color);color:var(--text-primary);font-weight:500}.form-actions{display:flex;gap:14px;margin-top:28px;padding-top:24px;border-top:1px solid var(--border-color)}.btn-cancel,.btn-submit{flex:1;padding:14px 24px;border:none;border-radius:10px;font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-sm)}.btn-cancel{background:var(--bg-tertiary);color:var(--text-primary);border:2px solid var(--border-color)}.btn-cancel:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-sm)}.btn-submit{background:#007acc!important;color:#fff!important;font-weight:800;text-transform:uppercase;letter-spacing:1px}.btn-submit:not(:disabled):hover{background:#0089ff;box-shadow:0 10px 20px #007acc4d}.btn-add-tag{padding:0 24px;height:48px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:12px;cursor:pointer;font-size:.8125rem;font-weight:800;text-transform:uppercase;letter-spacing:.5px;transition:all .3s cubic-bezier(.4,0,.2,1)}.btn-add-tag:hover{background:var(--accent-gold);color:#000!important;border-color:var(--accent-gold)}@media (max-width: 768px){.invoice-form{max-width:100%;max-height:100vh;border-radius:0}.invoice-form-overlay{padding:0}.form-row{grid-template-columns:1fr}.tags-input{flex-direction:column}.btn-add-tag{width:100%}}.search-bar{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:24px;margin-bottom:28px;box-shadow:var(--shadow-md);transition:all .3s ease}.search-bar:hover{box-shadow:var(--shadow-md)}.search-bar-main{display:flex;flex-direction:column;gap:20px}.search-input-group{width:100%}.search-input{width:100%;padding:14px 18px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1rem;transition:all .3s ease;box-sizing:border-box;background:var(--bg-secondary);color:var(--text-primary)}.search-input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}.filter-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}.period-filter{display:flex;flex-direction:column;gap:14px}.period-filter-label{font-size:.875rem;font-weight:700;color:var(--text-primary);letter-spacing:.3px}.period-type-select{width:100%}.custom-period-inputs{display:grid;grid-template-columns:1fr 1fr;gap:14px}.filter-select,.filter-input{padding:12px 14px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:.875rem;transition:all .3s ease;box-sizing:border-box;background:var(--bg-secondary);color:var(--text-primary)}.filter-select:focus,.filter-input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}.tags-filter{margin-top:8px}.tags-filter-label{display:block;margin-bottom:12px;font-size:.875rem;font-weight:700;color:var(--text-primary);letter-spacing:.3px}.tags-filter-list{display:flex;flex-wrap:wrap;gap:10px}.tag-filter{padding:8px 16px;border:2px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:20px;font-size:.8125rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.tag-filter:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-1px)}.tag-filter.active{background:var(--accent-gold);color:var(--accent-contrast);border-color:var(--accent-gold);box-shadow:var(--shadow-sm);font-weight:700}input[type=date]{color-scheme:light}.dark input[type=date]{color-scheme:dark}.btn-clear-filters{padding:12px 20px;background:var(--accent-danger);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);align-self:flex-start;box-shadow:var(--shadow-sm)}.btn-clear-filters:hover{background:#dc2626;transform:translateY(-2px);box-shadow:var(--shadow-md)}@media (max-width: 768px){.search-bar{padding:16px;border-radius:12px;margin-bottom:20px}.search-bar-main{gap:16px}.search-input{padding:12px 14px;font-size:.9375rem}.filter-row{grid-template-columns:1fr;gap:12px}.filter-select,.filter-input{padding:10px 12px;font-size:.8125rem}.custom-period-inputs{grid-template-columns:1fr;gap:12px}.period-filter{gap:12px}.period-filter-label,.tags-filter-label{font-size:.8125rem}.tags-filter-list{gap:8px}.tag-filter{font-size:.75rem;padding:6px 12px}.btn-clear-filters{width:100%;padding:10px 16px}}.sort-group-row{background:var(--bg-secondary);padding:16px;border-radius:var(--radius-md);border:1px dashed var(--border-color)}.filter-group{display:flex;flex-direction:column;gap:8px}.filter-group label{font-size:.75rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.file-preview-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000;display:flex;flex-direction:column;z-index:2000;animation:fadeIn .3s ease}.file-preview-content{flex:1;display:flex;flex-direction:column;position:relative;width:100vw;height:100vh;background:#000;overflow:hidden}.zoom-container{flex:1;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.file-preview-header{position:absolute;top:calc(16px + env(safe-area-inset-top));left:16px;right:16px;display:flex;justify-content:space-between;align-items:center;z-index:2001}.file-preview-close,.file-preview-action-btn{background:#ffffff1a;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);color:#fff;border:1px solid rgba(255,255,255,.2);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease}.file-preview-close{font-size:32px;line-height:1}.file-preview-close:active,.file-preview-action-btn:active{transform:scale(.9);background:#fff3}.file-preview-image{display:block;max-width:100vw;max-height:100vh;object-fit:contain;will-change:transform}.zoom-content-wrapper{display:flex;align-items:center;justify-content:center;width:100vw;height:100vh}.pdf-viewer-container{width:100%;height:100%;display:flex;flex-direction:column;background:#1a1a1a}.pdf-iframe{flex:1;width:100%;height:100%;border:none;background:#fff}.pdf-mobile-hint{padding:12px;background:#000c;color:#999;font-size:.75rem;text-align:center}.pdf-loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff;gap:16px}.spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin 1s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.chart-tooltip{background:var(--bg-card);border:1px solid var(--border-color);border-radius:8px;padding:12px 16px;box-shadow:var(--shadow-lg)}.chart-tooltip-label{margin:0 0 6px;font-size:.75rem;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.chart-tooltip-value{margin:0;font-size:1rem;font-weight:700;color:var(--accent-gold)}.chart-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-tertiary);font-size:.875rem}.stats-dashboard{width:100%;margin-bottom:40px;touch-action:pan-y}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:40px;touch-action:pan-y}.stat-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:24px;display:flex;flex-direction:column;gap:16px;transition:all .3s ease;box-shadow:var(--shadow-md);border:1px solid var(--border-color);touch-action:pan-y}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);color:var(--accent-gold);border-radius:12px;font-size:1.5rem}.stat-label{font-size:.9375rem;color:var(--text-secondary);font-weight:500}.stat-value{font-size:2.25rem;font-weight:400;color:var(--text-primary);letter-spacing:-.01em}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}.chart-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:32px;box-shadow:var(--shadow-md);border:1px solid var(--border-color);touch-action:pan-y}.chart-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.chart-header-left{display:flex;flex-direction:column;gap:4px}.chart-header h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin:0}.chart-subtitle{font-size:.875rem;color:var(--text-secondary)}.chart-container{width:100%;height:300px;min-height:300px}@media (max-width: 768px){.charts-grid{grid-template-columns:1fr}}.bottom-nav{position:fixed;bottom:0;left:0;right:0;height:75px;background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;z-index:1000;padding:0 10px;padding-bottom:env(safe-area-inset-bottom)}.bottom-nav-group{display:flex;flex:1;justify-content:space-around;align-items:center}.bottom-nav-item{width:44px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;transition:all .2s ease;position:relative}.bottom-nav-item.active{color:var(--text-primary)}.bottom-nav-item.active:after{content:"";position:absolute;bottom:4px;width:4px;height:4px;background:var(--text-primary);border-radius:50%}.bottom-nav-item svg{width:22px;height:22px;stroke-width:1.5}.bottom-nav-center{width:70px;height:100%;display:flex;align-items:center;justify-content:center;position:relative}.bottom-nav-fab{width:58px;height:58px;background:#007acc;color:#fff;border:none;border-radius:20px;display:flex;align-items:center;justify-content:center;box-shadow:0 8px 25px #007acc66;margin-top:-35px;transition:all .3s cubic-bezier(.175,.885,.32,1.275)}.bottom-nav-fab:active{transform:scale(.85)}.bottom-nav-item.active{color:#007acc}.bottom-nav-item.active:after{content:"";position:absolute;bottom:4px;width:4px;height:4px;background:#007acc;border-radius:50%}@media (min-width: 769px){.bottom-nav{display:none}}.theme-segmented-control{display:flex;background:var(--bg-tertiary);padding:4px;border-radius:12px;border:1px solid var(--border-color);width:100%}.theme-opt-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px;border:none;background:transparent;color:var(--text-secondary);font-size:.8125rem;font-weight:700;cursor:pointer;border-radius:8px;transition:all .3s cubic-bezier(.4,0,.2,1)}.theme-opt-btn.active{background:#007acc;color:#fff;box-shadow:0 4px 12px #007acc33}.theme-opt-btn:not(.active):hover{background:var(--bg-hover);color:var(--text-primary)}:root{--lamp-cable-color: #000}.dark{--lamp-cable-color: transparent}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:20px}.auth-modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:20px;padding:32px;max-width:400px;width:100%;box-shadow:0 20px 60px #0000004d;position:relative}.auth-modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:8px;border-radius:8px;transition:all .2s ease}.auth-modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.auth-header{display:flex;flex-direction:column;align-items:center;margin-bottom:24px}.auth-mascot{width:100px;height:100px;object-fit:contain;margin-bottom:16px;filter:drop-shadow(0 4px 6px rgba(0,0,0,.1))}.auth-modal h2{font-size:1.75rem;font-weight:800;margin-bottom:8px;color:var(--text-primary);text-align:center}.auth-modal-subtitle{color:var(--text-secondary);margin-bottom:24px;font-size:.9375rem}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:var(--text-primary);font-size:.875rem}.form-group input{width:100%;padding:12px 16px;border:2px solid var(--border-color);border-radius:10px;font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--text-primary);box-shadow:0 0 0 3px #0000000d}.auth-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:16px;font-size:.875rem}.btn-auth{width:100%;padding:14px 20px;background:var(--accent-gold);color:var(--accent-contrast);border:none;border-radius:10px;font-size:1rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:10px}.btn-auth:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #d4af374d}.btn-auth:disabled{opacity:.6;cursor:not-allowed}.auth-divider{display:flex;align-items:center;text-align:center;margin:20px 0;color:var(--text-tertiary);font-size:.8125rem;font-weight:600;text-transform:uppercase;letter-spacing:1px}.auth-divider:before,.auth-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.auth-divider span{padding:0 10px}.btn-google{width:100%;padding:12px 20px;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:10px;font-size:.9375rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 2px 4px #0000000d}.btn-google:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-secondary);transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.btn-google:active{transform:scale(.98)}.btn-google svg{flex-shrink:0}.auth-switch{margin-top:24px;text-align:center;color:var(--text-secondary);font-size:.875rem}.auth-switch button{background:none;border:none;color:var(--text-primary);font-weight:700;cursor:pointer;margin-left:8px;text-decoration:underline;text-underline-offset:4px}.auth-switch button:hover{opacity:.8}.urssaf-calculator{width:100%;margin:0 auto;padding:0}.urssaf-header{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:16px;margin-bottom:16px}.urssaf-header-content{display:flex;align-items:center;gap:16px}.urssaf-icon{background:#007acc1a;padding:12px;border-radius:12px;color:var(--accent-gold)}.urssaf-title{font-size:1.25rem;font-weight:800;margin:0;color:var(--text-primary);letter-spacing:-.5px}.urssaf-subtitle{font-size:.8125rem;margin:4px 0 0;color:var(--text-secondary);font-weight:500}.urssaf-content{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:16px}.period-selector{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:24px}.period-btn{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 20px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);border-radius:12px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.5px}.period-btn:hover{background:var(--bg-hover);border-color:var(--accent-gold)}.period-btn.active{background:#007acc!important;color:#fff!important;border-color:#007acc!important;box-shadow:0 4px 12px #007acc4d}.dark .period-btn.active{background:#007acc!important;color:#fff!important;border-color:#007acc!important}.calculation-section{margin-bottom:24px}.urssaf-help-box{background:#007acc14;border-left:4px solid var(--accent-primary, #007ACC);border-radius:12px;padding:20px;margin-bottom:24px}.urssaf-help-box h4{font-size:16px;font-weight:700;color:var(--text-primary, #333333);margin:0 0 12px}.urssaf-help-box p{font-size:14px;color:var(--text-primary, #333333);margin:8px 0;line-height:1.6}.urssaf-help-box ul{margin:12px 0;padding-left:20px}.urssaf-help-box li{font-size:14px;color:var(--text-primary, #333333);margin-bottom:8px;line-height:1.6}.urssaf-help-action{margin-top:16px!important;margin-bottom:12px!important}.urssaf-help-buttons{display:flex;gap:12px;flex-wrap:wrap;margin:12px 0}.urssaf-link-btn,.custom-period-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;border:none}.urssaf-link-btn{background:linear-gradient(135deg,#007acc,#005a9e);color:#fff;box-shadow:0 4px 12px #007acc4d}.urssaf-link-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #4a90e266}.custom-period-btn{background:linear-gradient(135deg,var(--accent-gold, #007ACC) 0%,#005A9E 100%);color:#fff;box-shadow:0 4px 12px #007acc4d}.custom-period-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px #d4af3766}.urssaf-help-note{font-size:13px!important;color:var(--text-secondary, #666666)!important;font-style:italic;margin-top:12px!important;padding:10px;background:#ffffff80;border-radius:8px}.urssaf-examples{margin:16px 0}.urssaf-example-detail{background:#fff9;border-radius:10px;padding:12px;cursor:pointer;transition:all .3s ease}.urssaf-example-detail:hover{background:#fffc}.urssaf-example-detail summary{font-size:14px;color:var(--accent-primary, #4a90e2);padding:8px;list-style:none;-webkit-user-select:none;user-select:none}.urssaf-example-detail summary::-webkit-details-marker{display:none}.urssaf-example-detail summary:before{content:"▶ ";display:inline-block;transition:transform .3s ease}.urssaf-example-detail[open] summary:before{transform:rotate(90deg)}.examples-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:16px}.example-item{background:#fff;padding:16px;border-radius:8px;border:2px solid var(--border-color, #e0e0e0)}.example-item strong{display:block;color:var(--accent-gold);margin-bottom:8px;font-size:14px}.example-item ul{margin:0;padding-left:20px}.example-item li{font-size:13px;color:var(--text-primary, #333333);margin-bottom:4px;line-height:1.4}.example-note{background:#007acc1a;padding:12px;border-radius:8px;margin-top:16px!important;font-size:13px!important;border-left:3px solid var(--accent-gold, #007ACC)}.input-group{margin-bottom:20px}.input-group label{display:block;font-size:14px;font-weight:600;color:var(--text-primary, #333333);margin-bottom:8px}.period-info-hint{margin-top:16px;padding:16px;background:var(--bg-tertiary);border-left:4px solid var(--accent-gold);border-radius:12px;font-size:.85rem;line-height:1.6;color:var(--text-primary);opacity:1}.period-info-hint strong{color:var(--accent-gold);font-weight:800}.label-with-action{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;flex-wrap:wrap;gap:8px}.refresh-btn{display:flex;align-items:center;gap:8px;padding:6px 14px;background:#007acc14;color:#007acc;border:1px solid rgba(0,122,204,.15);border-radius:20px;font-size:11px;font-weight:700;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.3px}.refresh-btn:hover{background:#007acc1f;border-color:#007acc4d;transform:translateY(-1px)}.refresh-btn:active{transform:scale(.96);background:#007acc33}.refresh-btn svg{color:#007acc;transition:transform .4s ease}.refresh-btn:active svg{transform:rotate(180deg)}.auto-detected-badge{display:inline-flex;align-items:center;padding:3px 10px;background:#007acc14;color:#007acc;border:1px solid rgba(0,122,204,.15);border-radius:20px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.auto-detected-hint{margin:6px 0 0;font-size:11px;color:#10b981;font-weight:600;display:flex;align-items:center;gap:6px;opacity:.9}.urssaf-select,.urssaf-input{width:100%;padding:14px 16px;border:1px solid var(--border-color);border-radius:12px;font-size:1rem;background:var(--bg-secondary);color:var(--text-primary);transition:all .3s ease;height:52px}.urssaf-select:focus,.urssaf-input:focus{outline:none;border-color:var(--accent-gold);background:var(--bg-primary);box-shadow:0 0 0 4px #007acc1a}.input-wrapper{position:relative}.input-suffix{position:absolute;right:16px;top:50%;transform:translateY(-50%);font-size:16px;font-weight:600;color:var(--text-secondary, #666666);pointer-events:none}.urssaf-input{padding-right:40px}.quarterly-inputs{display:grid;gap:16px}.start-date-config{background:var(--bg-secondary, #f3f4f6);border-radius:12px;padding:20px;margin-bottom:24px;border:2px solid var(--border-color, #e5e7eb)}.start-date-config h4{font-size:16px;font-weight:700;color:var(--text-primary, #333333);margin:0 0 8px}.config-hint{font-size:13px;color:var(--text-secondary, #666666);margin:0 0 16px}.date-selectors{display:grid;grid-template-columns:2fr 1fr;gap:16px}.start-month-selector,.start-year-selector,.quarter-selector-section{margin-bottom:20px}.start-month-selector label,.start-year-selector label,.quarter-selector-section label{display:block;font-size:14px;font-weight:600;color:var(--text-primary, #333333);margin-bottom:8px}.start-month-selector select,.start-year-selector select,.quarter-selector-section select{width:100%;padding:12px 16px;border:2px solid var(--border-color, #e0e0e0);border-radius:10px;font-size:15px;background:var(--bg-primary, #ffffff);color:var(--text-primary, #333333);transition:all .3s ease;font-weight:500}.start-month-selector select:focus,.start-year-selector select:focus,.quarter-selector-section select:focus{outline:none;border-color:var(--accent-primary, #4a90e2);box-shadow:0 0 0 4px #4a90e21a}.results-section{display:grid;gap:16px;margin-bottom:32px}.result-card{display:flex;align-items:flex-start;gap:16px;padding:24px;border-radius:16px;transition:all .3s ease;background:var(--bg-secondary);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.result-card:hover{border-color:var(--accent-gold);transform:translateY(-2px);box-shadow:var(--shadow-md)}.result-card.urssaf{border-color:var(--accent-gold);border-width:2px}.result-icon{background:var(--bg-secondary, #f3f4f6);padding:12px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--text-secondary, #6b7280)}.result-card.urssaf .result-icon{background:#4a90e21a;color:var(--accent-primary, #4a90e2)}.result-content{flex:1;display:flex;flex-direction:column;min-width:0}.result-label{font-size:13px;color:var(--text-secondary, #6b7280);margin-bottom:6px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.result-value{font-size:32px;font-weight:700;line-height:1.1;color:var(--text-primary, #111827);font-variant-numeric:tabular-nums;letter-spacing:-.5px}.result-card.urssaf .result-value{color:var(--accent-gold)}.result-detail{font-size:12px;color:var(--text-secondary, #6b7280);margin-top:6px;font-weight:400}.info-section{background:var(--bg-secondary, #f9fafb);border-left:3px solid var(--text-primary, #111827);border-radius:6px;padding:16px}.info-section h3{font-size:16px;font-weight:600;color:var(--text-primary, #333333);margin:0 0 12px}.info-section ul{margin:0;padding-left:20px;color:var(--text-primary, #333333)}.info-section li{margin-bottom:8px;line-height:1.5;font-size:13px}.info-section li:last-child{margin-bottom:0}.info-section strong{color:var(--text-primary, #111827);font-weight:600}@media (max-width: 768px){.urssaf-header{padding:16px}.urssaf-title{font-size:18px}.urssaf-subtitle{font-size:12px}.urssaf-content{padding:16px}.period-selector{grid-template-columns:1fr}.result-value{font-size:24px}.info-section{padding:12px}.date-selectors,.examples-grid{grid-template-columns:1fr}}.dark .urssaf-header,.dark .urssaf-content,.dark .result-card,.dark .example-item{background:var(--bg-primary);border-color:var(--border-color)}.dark .urssaf-icon,.dark .result-icon{background:var(--bg-tertiary);color:var(--text-secondary)}.dark .period-btn{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.dark .period-btn:hover{background:var(--bg-hover)}.dark .urssaf-select,.dark .urssaf-input{background:var(--bg-secondary);border-color:var(--border-color);color:var(--text-primary)}.dark .info-section{background:#ffffff08}.dark .info-section h3,.dark .info-section ul,.dark .info-section p{color:var(--text-secondary)}.dark .urssaf-help-note,.dark .urssaf-example-detail,.dark .example-note,.dark .period-info-hint{background:#ffffff0d;color:var(--text-secondary)!important}.dark .start-date-config{background:var(--bg-tertiary);border-color:var(--border-color)}.dark .input-suffix{color:var(--text-tertiary)}.dark .urssaf-example-detail summary{color:var(--accent-gold)}.dark .example-item strong{color:var(--accent-gold)}.dark .result-value{color:var(--text-primary)}.dark .result-card.urssaf .result-value{color:var(--accent-gold)}.dark .refresh-btn,.dark .auto-detected-badge{background:#007acc26;color:#38bdf8;border-color:#38bdf833}.dark .refresh-btn svg,.dark .auto-detected-badge svg{color:#38bdf8}.dark .auto-detected-hint{color:#34d399}.expense-card-container{position:relative;margin-bottom:12px;overflow:hidden;border-radius:16px}.expense-card-swipe-actions{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;justify-content:space-between;align-items:center;z-index:0;background:var(--bg-secondary)}.swipe-action{height:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;color:#fff;opacity:0;transition:opacity .2s ease}.expense-card-swipe-actions.right{background:#ff3b30;justify-content:flex-start}.expense-card-swipe-actions.right .left-action{opacity:1;display:flex;padding-left:20px}.expense-card-swipe-actions.left{background:#007aff;justify-content:flex-end}.expense-card-swipe-actions.left .right-action{opacity:1;display:flex;padding-right:20px}.expense-item{position:relative;z-index:1;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:16px;display:flex;align-items:center;gap:16px;transition:transform .15s cubic-bezier(.4,0,.2,1);touch-action:pan-y}.expense-item.swiping{transition:none;box-shadow:var(--shadow-md)}@media (max-width: 768px){.delete-btn{display:none}}.desktop-only{display:none}@media (min-width: 769px){.desktop-only{display:flex}}.expense-manager{padding:0;width:100%;margin:0 auto}.budget-info-banner{display:flex;align-items:flex-start;gap:12px;background:#007acc14;border:1px solid rgba(0,122,204,.15);padding:16px;border-radius:16px;margin-bottom:24px}.budget-info-banner p{margin:0;font-size:.875rem;line-height:1.6;color:var(--text-primary);font-weight:500}.budget-info-banner svg{color:#007acc;flex-shrink:0;margin-top:2px}.expense-file-actions{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}.btn-expense-action{display:flex!important;align-items:center;justify-content:center;gap:12px;padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;font-size:.8125rem;font-weight:800;color:var(--text-primary);cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:.5px;box-sizing:border-box;width:100%;-webkit-user-select:none;user-select:none;margin:0;height:52px}.btn-expense-action svg{color:#007acc;flex-shrink:0}.btn-expense-action:hover{background:var(--bg-hover);border-color:#007acc;transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.btn-expense-action:active{transform:scale(.98)}.dark .btn-expense-action{background:var(--bg-tertiary)}.dark .btn-expense-action:hover{background:var(--bg-hover);border-color:#007acc}.hidden-input{display:none}.attached-file-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#007acc1a;color:#007acc;border:1px solid rgba(0,122,204,.2);border-radius:20px;font-size:.75rem;font-weight:700;margin-top:10px;width:fit-content}.attached-file-badge button{background:none;border:none;color:inherit;font-size:16px;cursor:pointer;padding:0;display:flex;align-items:center}.expense-amount-group{display:flex;align-items:center;gap:8px}.expense-amount-stack{display:flex;flex-direction:column;align-items:flex-end}.expense-amount{font-weight:700;color:#ef4444;font-size:1rem}.expense-annual-hint{font-size:.7rem;color:var(--text-tertiary);font-weight:500;margin-top:-2px}.file-indicator{color:#007acc;opacity:.8}.small-hint{display:block;font-size:10px;color:var(--text-tertiary);margin-top:4px}@media (min-width: 1024px){.expense-manager{display:grid;grid-template-columns:350px 1fr;gap:32px;max-width:1200px}.budget-summary{position:sticky;top:100px;height:fit-content;margin-bottom:0}}.budget-summary{margin-bottom:32px}.summary-card.balance{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:24px;text-align:center;margin-bottom:16px}.summary-label{display:block;font-size:13px;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.summary-value{display:block;font-size:32px;font-weight:700;color:var(--text-primary, #111827);letter-spacing:-1px;font-variant-numeric:tabular-nums}.summary-value.negative{color:#ef4444}.summary-hint{display:block;font-size:12px;color:var(--text-secondary, #9ca3af);margin-top:8px}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.summary-small-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;padding:16px;display:flex;flex-direction:column;justify-content:center}.small-label{display:block;font-size:11px;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;margin-bottom:4px}.small-value{font-size:16px;font-weight:600;color:var(--text-primary, #111827)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{font-size:16px;font-weight:700;color:var(--text-primary, #111827);margin:0}.add-expense-btn{width:44px;height:44px;border-radius:50%;background:#007acc;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s cubic-bezier(.34,1.56,.64,1);box-shadow:0 4px 12px #007acc4d}.add-expense-btn:hover{transform:scale(1.1) rotate(90deg);background:#06a;box-shadow:0 6px 16px #007acc66}.add-expense-btn:active{transform:scale(.9)}.expenses-list{display:flex;flex-direction:column;gap:10px}.expense-item{display:flex;align-items:center;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;padding:16px;gap:16px;transition:all .2s ease}.expense-item:hover{border-color:#007acc;transform:translate(4px);background:var(--bg-hover)}.expense-icon{width:36px;height:36px;background:var(--bg-secondary, #f3f4f6);border-radius:8px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #6b7280)}.expense-info{flex:1}.expense-label{display:block;font-size:15px;font-weight:600;color:var(--text-primary, #111827)}.expense-category{font-size:12px;color:var(--text-secondary, #9ca3af)}.expense-right{display:flex;align-items:center;gap:12px}.expense-amount{font-weight:600;color:#ef4444;font-size:15px}.delete-btn{background:transparent;border:none;color:var(--text-secondary, #9ca3af);padding:4px;cursor:pointer}.add-expense-form{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin-bottom:20px;box-shadow:0 4px 12px #0000000d}.form-group{margin-bottom:12px}.form-row{display:flex;gap:10px}.flex-2{flex:2}.flex-1{flex:1}.form-group input,.form-group select{width:100%;padding:12px 16px;border:1px solid var(--border-color);border-radius:14px;font-size:.9375rem;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s cubic-bezier(.4,0,.2,1);height:52px;box-sizing:border-box;font-weight:500}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007acc;background:var(--bg-primary);box-shadow:0 0 0 4px #007acc1a}.amount-input{position:relative}.currency-suffix{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary, #9ca3af);font-weight:600}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:8px}.btn-cancel{padding:14px 20px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:14px;font-size:.8125rem;font-weight:800;color:var(--text-secondary);cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;width:100%}.btn-cancel:hover{background:var(--bg-hover);color:var(--text-primary)}.btn-submit{padding:16px;background:#007acc;color:#fff!important;border:none;border-radius:14px;font-weight:800;font-size:.8125rem;text-transform:uppercase;letter-spacing:1px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 12px #007acc33;width:100%}.btn-submit:hover:not(:disabled){background:#06a;transform:translateY(-2px);box-shadow:0 8px 24px #007acc4d}.btn-submit:disabled{opacity:.5;cursor:not-allowed}.dark .btn-submit{color:#fff!important}.toggle-option.active,.dark .toggle-option.active{background:#007acc;color:#fff!important}.recurring-toggle{display:flex;background:var(--bg-secondary);padding:6px;border-radius:16px;gap:6px;border:1px solid var(--border-color);margin-top:8px}.toggle-option{flex:1;padding:8px;text-align:center;font-size:.75rem;font-weight:700;border-radius:8px;cursor:pointer;color:var(--text-secondary);transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px}.toggle-option.active{background:#007acc;color:#fff;box-shadow:0 4px 12px #007acc33}.dark .toggle-option.active{background:#007acc;color:#fff}.expense-meta{display:flex;align-items:center;font-size:12px;color:var(--text-secondary, #9ca3af)}.expense-type{font-weight:600}.empty-expenses{text-align:center;padding:48px 20px;color:var(--text-secondary, #9ca3af)}.empty-expenses p{font-weight:600;margin:12px 0 4px;color:var(--text-primary, #374151)}.empty-expenses span{font-size:13px}.dark .expense-item,.dark .summary-card,.dark .summary-small-card,.dark .add-expense-form{background:#1e1e1e}.dark .expense-icon{background:#2a2a2a}.action-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:3000;display:flex;align-items:flex-end;animation:fadeIn .3s ease}.action-modal-content{width:100%;background:var(--bg-card);border-radius:24px 24px 0 0;padding:8px 16px calc(16px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px #0000004d;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.action-modal-header{display:flex;flex-direction:column;align-items:center;margin-bottom:8px}.action-modal-indicator{width:40px;height:4px;background:var(--border-color);border-radius:999px;margin-bottom:12px}.action-modal-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin:0;text-align:center}.action-modal-list{display:flex;flex-direction:column;gap:8px;margin-top:16px}.action-modal-item{width:100%;display:flex;align-items:center;gap:16px;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:14px;cursor:pointer;transition:all .2s ease}.action-modal-item:active{background:var(--bg-tertiary);transform:scale(.98)}.action-item-icon{width:44px;height:44px;border-radius:12px;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color);flex-shrink:0}.action-item-icon.delete{background:#ef44440d;color:#ef4444;border-color:#ef44441a}.action-item-content{display:flex;flex-direction:column;gap:2px;text-align:left}.action-item-label{font-size:.95rem;font-weight:700;color:var(--text-primary)}.action-item-label.delete{color:#ef4444}.action-item-desc{font-size:.75rem;font-weight:500;color:var(--text-secondary);opacity:.8}.action-modal-footer{margin-top:16px;padding-bottom:8px}.action-modal-cancel{width:100%;padding:16px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);border-radius:14px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .2s ease}.action-modal-cancel:active{background:var(--bg-tertiary)}.font-selector-v3{width:100%;display:flex;flex-direction:column;gap:12px}.font-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;background:var(--bg-hover);border:1px solid var(--border-color);border-radius:14px;padding:14px 16px;cursor:pointer;transition:all .2s ease}.font-trigger:active{transform:scale(.98);background:var(--bg-tertiary)}.font-trigger-left{display:flex;align-items:center;gap:12px}.font-icon{color:var(--accent-gold)}.current-font-name{font-size:1rem;font-weight:600;color:var(--text-primary)}.font-chevron{color:var(--text-tertiary)}.font-live-preview{padding:16px;background:var(--bg-secondary);border-radius:14px;font-size:.95rem;line-height:1.5;color:var(--text-primary);border:1px dashed var(--border-color);min-height:70px;display:flex;align-items:center;justify-content:center;text-align:center}.font-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10001;display:flex;align-items:flex-end;animation:fadeIn .3s ease}.font-modal-content{width:100%;background:var(--bg-card);border-radius:28px 28px 0 0;padding:24px 20px calc(24px + env(safe-area-inset-bottom));box-shadow:0 -10px 40px #0003;max-height:80vh;display:flex;flex-direction:column;animation:slideUp .3s cubic-bezier(.4,0,.2,1)}.font-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 4px}.font-modal-header-text h3{margin:0;font-size:1.25rem;font-weight:800;color:var(--text-primary)}.font-mega-preview{background:var(--bg-hover);border-radius:20px;padding:32px 20px;margin-bottom:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;border:1px solid var(--border-color);transition:all .3s ease;flex-shrink:0}.mega-amount{font-size:3.5rem;font-weight:400;color:var(--accent-gold);line-height:1;margin-bottom:8px}.mega-label{font-size:.85rem;font-weight:700;color:var(--text-secondary);text-transform:uppercase;letter-spacing:1.5px}.font-modal-close{background:var(--bg-hover);border:none;width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer}.font-modal-list{display:flex;flex-direction:column;gap:12px;overflow-y:auto;padding-right:4px}.font-modal-item-name{font-size:1.1rem;font-weight:600;color:var(--text-primary)}.font-modal-item{width:100%;display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:16px;cursor:pointer;transition:all .2s ease;text-align:left}.font-modal-item:active{background:var(--bg-tertiary);transform:scale(.99)}.font-modal-item.active{background:var(--accent-gold-transparent, rgba(197, 160, 89, .15));border-color:var(--accent-gold)}.font-modal-item-name{font-size:1.1rem;color:var(--text-primary)}.font-check-icon{color:var(--accent-gold)}.font-modal-list::-webkit-scrollbar{width:0}.mascot-game-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000e6;z-index:9999;display:flex;align-items:center;justify-content:center;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);animation:fadeIn .3s ease}.mascot-game-container{width:100%;height:100%;max-width:500px;position:relative;display:flex;flex-direction:column;background:var(--bg-primary)}.game-close-btn{position:absolute;top:16px;right:16px;width:40px;height:40px;border-radius:50%;background:#ffffff1a;color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:20}.game-header{position:absolute;top:16px;left:16px;display:flex;gap:12px;z-index:20}.game-score-card{background:#00000080;padding:8px 16px;border-radius:20px;color:#fff;display:flex;align-items:center;gap:6px;border:1px solid rgba(255,255,255,.1)}.score-label{font-size:.75rem;opacity:.8;font-weight:600}.score-value{font-size:1.25rem;font-weight:700}.trophy-icon{color:#fbbf24}.game-score-card.auto-active{border-color:#3b82f6;background:#3b82f633;box-shadow:0 0 10px #3b82f64d}.auto-badge{font-size:.65rem;background:#3b82f6;color:#fff;padding:2px 6px;border-radius:4px;font-weight:800;margin-left:4px}.game-canvas-wrapper{flex:1;width:100%;height:100%;position:relative;background:linear-gradient(180deg,#1e293b,#0f172a);overflow:hidden;touch-action:none}.game-canvas{width:100%;height:100%;display:block}.game-menu{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;color:#fff;display:flex;flex-direction:column;align-items:center;gap:16px;background:#000000b3;padding:32px;border-radius:24px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.1);width:80%;max-width:300px;animation:popIn .4s cubic-bezier(.175,.885,.32,1.275)}.menu-mascot{width:80px;height:80px;object-fit:contain;margin-bottom:8px;animation:bounce 2s infinite}.game-menu h2{font-size:2rem;margin:0;background:linear-gradient(135deg,#60a5fa,#a855f7);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.game-menu p{margin:0;opacity:.8;font-size:.95rem}.game-start-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;padding:16px 32px;border-radius:16px;font-size:1.1rem;font-weight:700;display:flex;align-items:center;gap:10px;cursor:pointer;margin-top:16px;transition:transform .2s;box-shadow:0 4px 12px #3b82f666}.game-start-btn:active{transform:scale(.95)}.final-score{font-size:4rem;font-weight:400;color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.5)}@keyframes popIn{0%{transform:translate(-50%,-50%) scale(.8);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.welcome-page{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary);padding:40px;overflow-y:auto;transition:background-color .3s ease,padding .3s ease}@media (max-height: 660px){.welcome-page{justify-content:flex-start;padding-top:20px;padding-bottom:20px}.welcome-mascot-container{height:120px;margin-bottom:40px;margin-top:40px}.welcome-mascot{width:120px;height:120px}.welcome-title{display:none}}.welcome-back-btn{position:absolute;top:16px;left:16px;background:none;border:none;color:var(--text-primary);padding:8px;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center}.welcome-theme-toggle{position:absolute;top:16px;right:16px;z-index:10}.welcome-mascot-container{margin-bottom:24px;display:flex;justify-content:center;width:100%}.welcome-mascot{width:220px;height:220px;object-fit:contain;display:block;margin:0 auto}.welcome-title{font-size:2.25rem;font-weight:800;color:var(--text-primary);margin:0 0 32px;text-align:center;letter-spacing:-.04em}.welcome-card{width:100%;max-width:320px}.welcome-card form{display:flex;flex-direction:column;gap:16px}.custom-tooltip{position:absolute;background:#ff3b30;color:#fff;padding:8px 12px;border-radius:12px;font-size:.85rem;font-weight:600;z-index:20;top:-45px;left:50%;transform:translate(-50%);white-space:nowrap;box-shadow:0 4px 10px #ff3b304d;animation:popIn .2s cubic-bezier(.175,.885,.32,1.275)}.custom-tooltip:after{content:"";position:absolute;bottom:-6px;left:50%;transform:translate(-50%);border-width:6px 6px 0;border-style:solid;border-color:#FF3B30 transparent transparent transparent}@keyframes popIn{0%{opacity:0;transform:translate(-50%) scale(.8)}to{opacity:1;transform:translate(-50%) scale(1)}}.input-pill{position:relative;width:100%;display:flex;align-items:center;background:var(--bg-secondary);border-radius:50px;padding:0 24px;box-shadow:var(--shadow-sm);transition:all .3s ease;height:60px;border:1px solid var(--border-color)}.input-icon{display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);margin-right:12px}.input-pill:focus-within{background:var(--bg-primary);box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent-gold)}.input-pill input{flex:1;width:100%;padding:18px 0;border:none!important;background:transparent!important;color:var(--text-primary);font-size:1.05rem;font-weight:500;text-align:left}.input-pill input:focus{outline:none!important;box-shadow:none!important}.btn-welcome-submit{width:100%;max-width:320px;height:60px;margin:12px auto 0;display:flex;align-items:center;justify-content:center;background:#007acc;color:#fff;border:none;border-radius:50px;font-size:1.1rem;font-weight:800;cursor:pointer;box-shadow:0 4px 15px #007acc33;transition:all .2s cubic-bezier(.4,0,.2,1);text-transform:uppercase;letter-spacing:1px}.btn-welcome-submit:active{transform:scale(.86);box-shadow:0 2px 8px #0000000d}.dark .btn-welcome-submit{background:#007acc;color:#fff;border:none;box-shadow:0 4px 15px #007acc4d}.welcome-footer{margin-top:32px;text-align:center}.welcome-footer button{background:none;border:none;color:var(--text-tertiary);font-size:.95rem;font-weight:500;cursor:pointer;padding:10px 20px;transition:color .2s}.welcome-footer button:hover{color:var(--text-primary)}.onboarding-container{position:fixed;top:0;left:0;right:0;bottom:0;background:var(--bg-primary);z-index:5000;display:flex;flex-direction:column;padding:40px 24px}.onboarding-theme-toggle{position:absolute;top:16px;right:16px;z-index:10}.onboarding-content{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center}.onboarding-mascot-container{margin-bottom:24px;display:flex;justify-content:center;width:100%;height:220px;align-items:center}.onboarding-mascot{width:220px;height:220px;object-fit:contain;filter:drop-shadow(0 10px 20px rgba(0,0,0,.15));transition:all .5s ease;display:block}.dark .onboarding-mascot{filter:drop-shadow(0 10px 20px rgba(255,255,255,.15))}.onboarding-title{font-size:1.75rem;font-weight:800;margin:0 0 16px;text-transform:uppercase;line-height:1.2;color:var(--text-primary);white-space:pre-line}.onboarding-desc{font-size:1rem;color:var(--text-secondary);line-height:1.6;max-width:300px;margin:0 auto 40px}.onboarding-indicators{display:flex;gap:8px;margin-bottom:20px}.indicator{width:8px;height:8px;border-radius:50%;background:var(--border-color);transition:all .3s ease}.indicator.active{background:var(--text-primary);width:24px;border-radius:4px}.onboarding-actions{display:flex;flex-direction:column;gap:16px;width:100%}.btn-onboarding-primary{width:100%;max-width:320px;height:60px;margin:0 auto;display:flex;align-items:center;justify-content:center;background:#fff;color:#000;border:1px solid #e5e5e5;border-radius:50px;font-size:1.1rem;font-weight:700;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);box-shadow:0 4px 15px #00000014}.btn-onboarding-primary:active{transform:scale(.96);box-shadow:0 2px 8px #0000000d}.dark .btn-onboarding-primary{background:#fff;color:#000;border:none;box-shadow:0 4px 15px #ffffff1a}.btn-onboarding-secondary{width:100%;padding:16px;background:transparent;color:var(--text-secondary);border:none;font-size:1rem;font-weight:600;cursor:pointer}*{margin:0;padding:0;box-sizing:border-box}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{height:100%;display:flex;flex-direction:column;background:var(--bg-primary);overflow:hidden}.app-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:24px 40px;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.app-header-content{width:100%;display:flex;justify-content:space-between;align-items:center;gap:20px}.app-header-left{flex:1}.app-logo{display:inline-flex;align-items:center;gap:10px;flex:1;min-width:0}.app-logo-icon{color:#007acc}.app-header h1{font-size:2.25rem;font-weight:800;margin-bottom:4px;letter-spacing:-.04em;color:var(--text-primary)}.app-title-input{font-size:2.25rem;font-weight:800;letter-spacing:-.04em;border:none;background:transparent;color:var(--text-primary);padding:0;margin:0;max-width:100%;flex:1}.app-title-input:focus{outline:none}.app-subtitle{font-size:.9375rem;opacity:.95;margin:0;font-weight:400}.theme-toggle{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;width:48px;height:48px;border-radius:12px;font-size:1.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);flex-shrink:0}.theme-toggle:hover{background:#ffffff4d;transform:scale(1.05);box-shadow:0 4px 12px #0003}.app-header-right{display:flex;align-items:center;gap:16px}.app-menu-actions{display:inline-flex;align-items:center;gap:8px}.app-menu-btn{padding:6px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#00000040;color:#f5f5f5;font-size:.8rem;font-weight:500;cursor:pointer;transition:background .2s ease,border-color .2s ease,transform .1s ease}.app-menu-btn:hover{background:#ffffff0f;border-color:#fff3;transform:translateY(-1px)}.app-main{flex:1;overflow-y:scroll!important;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:16px;position:relative}@media (max-width: 768px){.app-main{overflow-y:scroll!important;-webkit-overflow-scrolling:touch!important;touch-action:pan-y!important}}.desktop-content{display:block}.mobile-app{display:none}@media (max-width: 768px){.app-header,.desktop-content{display:none}.mobile-app{display:flex!important}}.settings-section .btn-secondary{width:100%;margin-bottom:12px}.settings-section .theme-selector{position:relative!important;top:auto!important;right:auto!important}.btn-primary,.btn-secondary{padding:12px 24px;border:none;border-radius:var(--radius-md);font-size:.9375rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:var(--shadow-sm);touch-action:manipulation}.btn-primary{background:#007acc;color:#fff;font-weight:800;text-transform:uppercase;letter-spacing:1px}.btn-primary:hover{background:#0089ff;transform:translateY(-2px);box-shadow:0 10px 20px #007acc4d}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-hover);transform:translateY(-2px);box-shadow:var(--shadow-md)}.draggable-section{position:relative}.section-drag-handle{position:absolute;top:10px;right:10px;border:none;background:#0006;color:#e5e5e5;border-radius:999px;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;cursor:grab;z-index:10}.section-drag-handle:hover{background:#0009}.edit-mode .draggable-section{border:2px dashed rgba(255,255,255,.35);border-radius:16px;padding-top:12px;margin-top:12px}@media (max-width: 768px){.app-header{padding:16px}.app-title-input{font-size:1.5rem}.app-header-content{flex-direction:column;align-items:stretch;gap:12px}.app-header-left{width:100%}.app-logo{justify-content:flex-start}.app-header-right{width:100%;flex-direction:column;align-items:stretch;gap:8px}.app-menu-actions{width:100%;display:grid;grid-template-columns:1fr 1fr;gap:8px}.app-menu-actions .btn-secondary{font-size:.75rem;padding:10px 12px;white-space:nowrap}.theme-selector{position:absolute!important;top:16px;right:16px;z-index:200}.edit-toggle{grid-column:1 / -1}.app-main{padding:16px 12px 24px}.btn-primary,.btn-secondary{width:100%;justify-content:center;padding:12px 16px;font-size:.875rem}}.mobile-app{height:100%;display:flex;flex-direction:column;overflow:auto;position:relative}.home-hero-bg{position:fixed;top:0;left:0;right:0;height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);overflow:hidden;z-index:0;pointer-events:none}.hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(180deg,#0000,#0000001a)}.hero-content-wrapper{position:absolute;top:0;left:0;right:0;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:80px;z-index:2;pointer-events:none}.hero-mascot-container{pointer-events:auto;margin-bottom:16px;transition:opacity .3s ease;position:absolute;top:-57.5px;left:50%;transform:translate(-50%);z-index:9999}.hero-mascot{width:115px;height:115px;object-fit:contain;opacity:1;filter:none!important;cursor:pointer;-webkit-tap-highlight-color:transparent}.mascot-speech-bubble{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:4px;background:#fff;color:#3a3a3a;padding:10px 18px;border-radius:18px;font-size:.8125rem;font-weight:700;text-transform:none;letter-spacing:.2px;width:90vw;max-width:350px;text-align:center;overflow:visible;box-shadow:0 4px 12px #00000026}.bubble-text{display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;line-height:1.4}.mascot-speech-bubble:after{content:"";position:absolute;top:100%;left:50%;transform:translate(-50%);width:0;height:0;border-left:8px solid transparent;border-right:8px solid transparent;border-top:8px solid #ffffff}.dark .mascot-speech-bubble{background:#2a2a2a;color:#fff}.dark .mascot-speech-bubble:after{border-top-color:#2a2a2a}.hero-text-container{pointer-events:auto;text-align:center;display:flex;flex-direction:column;gap:2px;transition:opacity .3s ease;margin-bottom:12px;padding:0 32px;opacity:0;transform:translateY(40px)}.hero-greeting{font-size:.875rem;font-weight:600;margin:0;letter-spacing:1px;text-transform:lowercase;line-height:1;color:#888;text-shadow:none}.hero-greeting-name{font-size:2.5rem;font-weight:400;margin:4px 0 0;letter-spacing:-1px;text-transform:capitalize;line-height:1;color:#1a1a1a}.dark .hero-greeting{color:#999}.dark .hero-greeting-name{color:#fff}.hero-subtitle{font-size:.9375rem;font-weight:600;color:#666;margin-top:2px;margin-bottom:4px;text-transform:none;letter-spacing:0;line-height:1.4}.dark .hero-subtitle{color:#999}.hero-info-block{pointer-events:auto;max-width:100%;margin:0 24px 180px;padding:0;opacity:0;transform:translateY(30px) scale(.95);transition:all .3s cubic-bezier(.4,0,.2,1)}.hero-info-block p{font-size:.875rem;font-weight:500;color:#666;line-height:1;margin:0;text-align:center;text-shadow:none;letter-spacing:0}.dark .hero-info-block p{color:#aaa}.enter-down .hero-mascot-container{animation:mascotEnter .2s cubic-bezier(.25,.46,.45,.94) forwards}.enter-down .hero-text-container{animation:textEnter .2s cubic-bezier(.25,.46,.45,.94) .05s forwards}.enter-down .hero-info-block{animation:infoEnter .2s cubic-bezier(.25,.46,.45,.94) .1s forwards}.exit-up .hero-mascot-container{animation:mascotExit .15s cubic-bezier(.55,.055,.675,.19) forwards}.exit-up .hero-text-container{animation:textExit .15s cubic-bezier(.55,.055,.675,.19) forwards}.exit-up .hero-info-block{animation:infoExit .15s cubic-bezier(.55,.055,.675,.19) forwards}@keyframes mascotEnter{0%{transform:translate(-50%) translateY(-80px) scale(.8);opacity:0}to{transform:translate(-50%) translateY(0) scale(1);opacity:1}}@keyframes mascotExit{0%{transform:translate(-50%) translateY(0) scale(1);opacity:1}to{transform:translate(-50%) translateY(-80px) scale(.8);opacity:0}}@keyframes textEnter{0%{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes textExit{0%{transform:translateY(0);opacity:1}to{transform:translateY(60px);opacity:0}}@keyframes infoEnter{0%{transform:translateY(30px) scale(.95);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}@keyframes infoExit{0%{transform:translateY(0) scale(1);opacity:1}to{transform:translateY(40px) scale(.95);opacity:0}}.home-content-card{position:absolute;top:50vh;left:50%;transform:translate(-50%);width:95%;min-height:100vh;background:var(--bg-primary);border-radius:32px 32px 0 0;box-shadow:0 -20px 50px #0003;padding:12px 16px 120px;z-index:1;overflow-y:visible}.home-content-card:before{content:"";display:block;width:50px;height:5px;background:var(--border-color);border-radius:3px;margin:8px auto 20px;opacity:.6}.dark .home-content-card{background:var(--bg-secondary);box-shadow:0 -10px 40px #00000080}.home-hero-bg[data-page=home]{background:#fff!important}.dark .home-hero-bg[data-page=home]{background:#1d1d1d!important}.home-hero-bg[data-page=invoices]{background:#fff!important}.dark .home-hero-bg[data-page=invoices]{background:#1d1d1d!important}.home-hero-bg[data-page=stats]{background:#fff!important}.dark .home-hero-bg[data-page=stats]{background:#1d1d1d!important}.home-hero-bg[data-page=settings]{background:#fff!important}.dark .home-hero-bg[data-page=settings]{background:#1d1d1d!important}.home-hero-bg[data-page=urssaf]{background:#fff!important}.dark .home-hero-bg[data-page=urssaf]{background:#1d1d1d!important}.home-hero-bg[data-page=budget]{background:#fff!important}.dark .home-hero-bg[data-page=budget]{background:#1d1d1d!important}.hero-title-top h1,.hero-subtitle-bottom p{color:#fff!important;text-shadow:0 2px 10px rgba(0,0,0,.1)!important}.mascot-party-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;z-index:9999;display:flex;align-items:center;justify-content:center;animation:fadeIn .3s ease-out}.mascot-party-container{position:relative;width:100%;height:100%}.party-mascot{position:absolute;width:120px;height:120px;object-fit:contain;filter:drop-shadow(0 0 20px rgba(255,255,255,.5))}.party-mascot-1{top:50%;left:50%;transform:translate(-50%,-50%) translate(-80px,-80px);animation:mascotSpin1 2s infinite ease-in-out}.party-mascot-2{top:50%;left:50%;transform:translate(-50%,-50%) translate(80px,-80px);animation:mascotSpin2 2s infinite ease-in-out}.party-mascot-3{top:50%;left:50%;transform:translate(-50%,-50%) translate(-80px,80px);animation:mascotSpin3 2s infinite ease-in-out}.party-mascot-4{top:50%;left:50%;transform:translate(-50%,-50%) translate(80px,80px);animation:mascotSpin4 2s infinite ease-in-out}@keyframes mascotSpin1{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(90deg) scale(1.3)}50%{transform:rotate(180deg) scale(1)}75%{transform:rotate(270deg) scale(1.3)}}@keyframes mascotSpin2{0%,to{transform:rotate(0) scale(1)}25%{transform:rotate(-90deg) scale(1.3)}50%{transform:rotate(-180deg) scale(1)}75%{transform:rotate(-270deg) scale(1.3)}}@keyframes mascotSpin3{0%,to{transform:rotate(0) scale(1) translateY(0)}50%{transform:rotate(180deg) scale(1.5) translateY(-30px)}}@keyframes mascotSpin4{0%,to{transform:rotate(0) scale(1) translateY(0)}50%{transform:rotate(-180deg) scale(1.5) translateY(-30px)}}@keyframes pulse{0%,to{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.1)}}.mobile-header{position:sticky;top:0;z-index:100;background:#ffffffd9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-color);transition:background .3s ease}.dark .mobile-header{background:#000000d9}.mobile-header h1{font-size:1.25rem;margin:0;color:var(--text-primary);background:none;-webkit-text-fill-color:var(--text-primary)}.header-brand{display:flex;align-items:center;gap:12px}.header-mascot{width:28px;height:28px;object-fit:contain;transition:filter .3s ease}.dark .header-mascot,.dark .settings-mascot-banner,.dark .auth-mascot,.dark .empty-mascot{filter:drop-shadow(0 2px 4px rgba(255,255,255,.1))}.header-mascot,.settings-mascot-banner,.auth-mascot,.empty-mascot{filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.btn-new-invoice{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0}.mobile-main{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;padding:16px 16px 120px;background:var(--bg-primary)}.mobile-main *{touch-action:pan-y!important}.mobile-settings{max-width:100%;margin:0;padding:0 0 40px}.settings-header-banner{display:flex;flex-direction:column;align-items:center;text-align:center;margin-bottom:40px;padding:48px 20px 0}.settings-mascot-banner{width:120px;height:120px;object-fit:contain;margin-bottom:16px}.settings-header-text h2{font-size:2.25rem;font-weight:400;letter-spacing:-.02em;margin:0;color:var(--text-primary)}.settings-header-text p{color:var(--text-secondary);margin:8px 0 0;font-size:1rem;font-weight:500}.settings-header{display:none}.settings-group{margin-bottom:24px}.settings-group-title{font-size:.8rem;font-weight:800;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1.5px;margin-bottom:12px;margin-left:0}.settings-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:20px;overflow:hidden;box-shadow:var(--shadow-sm);width:100%}.dark .settings-card{background:var(--bg-tertiary)}.settings-action-row{width:100%;display:flex;align-items:center;padding:16px 20px;background:transparent;border:none!important;cursor:pointer;transition:background .2s ease;text-align:left;gap:16px}.settings-action-row:active{background:var(--bg-hover)}.row-icon{width:40px;height:40px;background:#007acc1a;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#007acc}.settings-section-container{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.row-info{flex:1;display:flex;flex-direction:column;gap:4px}.row-label{font-size:.9375rem;font-weight:800;color:var(--text-primary);letter-spacing:-.01em}.row-sublabel{font-size:.75rem;font-weight:500;color:var(--text-secondary);line-height:1.4}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;gap:16px}.row-status{font-size:.8125rem;color:#007acc;font-weight:700;margin-right:4px}.account-row{display:flex;align-items:center;padding:16px;gap:16px}.user-avatar{width:48px;height:48px;background:var(--text-primary);color:var(--bg-primary);border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:800}.user-info{flex:1}.user-email{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0}.user-status{font-size:.875rem;color:var(--text-secondary);margin:2px 0 0}.pseudo-row-container{padding:16px 20px;display:flex;flex-direction:column;gap:12px}.pseudo-input-premium{width:100%;padding:14px 16px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:14px;font-size:1rem;font-weight:700;color:var(--text-primary);transition:all .3s cubic-bezier(.4,0,.2,1)}.pseudo-input-premium:focus{outline:none;border-color:#007acc;box-shadow:0 0 0 4px #007acc1a;transform:translateY(-2px)}.row-chevron{color:var(--text-tertiary);opacity:.6;margin-left:auto}.settings-action-row:active .row-chevron{opacity:1;color:#007acc}.settings-card.about{padding:24px}.about-header{display:flex;align-items:center;gap:16px;margin-bottom:20px}.app-icon-small-img{width:64px;height:64px;border-radius:18px;box-shadow:0 8px 20px #0000001a;cursor:pointer;transition:transform .2s cubic-bezier(.175,.885,.32,1.275);background:#fff;padding:8px;object-fit:contain}.app-icon-small-img:active{transform:scale(.92)}.app-name{font-size:1.25rem;font-weight:900!important;color:var(--text-primary);margin:0;letter-spacing:-.02em}.app-version{font-size:.85rem;color:#007acc;font-weight:700;margin:4px 0 0;opacity:.9}.app-description{font-size:.9375rem;color:var(--text-secondary);line-height:1.6;margin:0;font-weight:500}.settings-card.appearance{padding:12px 16px}.settings-card.appearance .theme-selector{width:100%;justify-content:space-between}.mobile-bottom-fade{position:fixed;bottom:0;left:0;right:0;height:180px;background:linear-gradient(to top,var(--bg-primary) 0%,var(--bg-primary) 30%,transparent 100%);pointer-events:none;z-index:999}.spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.mobile-app.privacy-mode .stat-value,.mobile-app.privacy-mode .invoice-card-amount,.mobile-app.privacy-mode .invoice-amount,.mobile-app.privacy-mode .invoice-list-total strong,.mobile-app.privacy-mode .total-value,.mobile-app.privacy-mode .invoice-card-client,.mobile-app.privacy-mode .chart-container{filter:blur(8px);transition:all .3s ease;-webkit-user-select:none;user-select:none;pointer-events:auto!important;cursor:pointer}.mobile-app.privacy-mode .stat-value:active,.mobile-app.privacy-mode .invoice-card-amount:active,.mobile-app.privacy-mode .invoice-amount:active,.mobile-app.privacy-mode .invoice-list-total strong:active,.mobile-app.privacy-mode .total-value:active,.mobile-app.privacy-mode .invoice-card-client:active{filter:blur(0)}.mobile-app.privacy-mode .chart-container{filter:blur(15px) grayscale(1);opacity:.5}.mobile-app.privacy-mode .chart-container:active{filter:blur(0) grayscale(0);opacity:1}.lamp-container{position:fixed;top:0;left:50%;transform:translate(-50%);z-index:10000;pointer-events:none;display:flex;flex-direction:column;align-items:center;transition:transform .6s cubic-bezier(.4,0,.2,1)}.lamp-container:not(.is-active){transform:translate(-50%) translateY(-100px)}.lamp-cable{width:2px;background:#000;height:0;position:relative;transition:height .8s cubic-bezier(.68,-.6,.32,1.6);transform-origin:top}.lamp-container.is-active .lamp-cable{height:40px}.lamp-bulb{position:absolute;bottom:-40px;left:50%;transform:translate(-50%);width:30px;height:40px;background:#fff;border-radius:50% 50% 40% 40%;border:1px solid #ccc;box-shadow:0 0 50px #ffffb4b3,inset 0 -5px 10px #0000000d;display:flex;align-items:center;justify-content:center;transition:opacity .3s ease}.lamp-bulb:before{content:"";position:absolute;top:-8px;width:14px;height:10px;background:#666;border-radius:2px}.lamp-glow-inner{width:12px;height:18px;background:#ffff96e6;border-radius:50%;filter:blur(4px);animation:flicker 4s infinite alternate}@keyframes flicker{0%{opacity:.8;transform:scale(.95)}to{opacity:1;transform:scale(1.05)}}.site-light-effect{position:fixed;top:0;left:0;width:100vw;height:100vh;background:radial-gradient(circle at 50% 140px,rgba(255,255,180,.15) 0%,rgba(255,255,180,.05) 40%,transparent 80%);pointer-events:none;opacity:0;transition:opacity 1s ease;z-index:9999}.site-light-effect.is-active{opacity:1}.dark .site-light-effect{display:none}.install-prompt-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;z-index:10000;animation:fadeIn .3s ease;padding:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.install-prompt{background:var(--bg-primary);border-radius:24px 24px 0 0;padding:32px 24px 24px;max-width:500px;width:100%;position:relative;animation:slideUp .4s cubic-bezier(.16,1,.3,1);box-shadow:0 -8px 32px #0003}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.install-prompt-close{position:absolute;top:16px;right:16px;background:var(--bg-secondary);border:none;border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-secondary);transition:all .2s}.install-prompt-close:hover{background:var(--bg-tertiary);color:var(--text-primary);transform:scale(1.1)}.install-prompt-icon{width:80px;height:80px;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:20px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:#fff;box-shadow:0 8px 24px #6366f14d}.install-prompt-title{font-size:24px;font-weight:700;color:var(--text-primary);text-align:center;margin:0 0 16px}.install-prompt-content{margin-bottom:24px}.install-prompt-content p{color:var(--text-secondary);text-align:center;margin:0 0 16px;font-size:15px;line-height:1.5}.install-steps{list-style:none;padding:0;margin:0}.install-steps li{background:var(--bg-secondary);padding:14px 16px;border-radius:12px;margin-bottom:8px;color:var(--text-primary);font-size:14px;display:flex;align-items:center;gap:12px}.install-steps li:before{content:counter(list-item);counter-increment:list-item;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0}.ios-share-icon{display:inline-block;font-size:18px;vertical-align:middle;margin:0 2px}.install-benefits{list-style:none;padding:0;margin:0 0 20px}.install-benefits li{color:var(--text-secondary);padding:8px 0;font-size:14px;display:flex;align-items:center;gap:8px}.install-button{width:100%;background:linear-gradient(135deg,#6366f1,#8b5cf6);color:#fff;border:none;border-radius:12px;padding:16px;font-size:16px;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:all .2s;box-shadow:0 4px 12px #6366f14d}.install-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #6366f166}.install-button:active{transform:translateY(0)}.install-prompt-later{width:100%;background:transparent;color:var(--text-secondary);border:none;padding:12px;font-size:14px;cursor:pointer;transition:color .2s}.install-prompt-later:hover{color:var(--text-primary)}@media (prefers-color-scheme: dark){.install-prompt{box-shadow:0 -8px 32px #0009}}@media (min-width: 768px){.install-prompt-overlay{align-items:center}.install-prompt{border-radius:24px;max-width:420px}}.toast-container{position:fixed;right:24px;bottom:24px;display:flex;flex-direction:column;gap:10px;z-index:9999}.toast{min-width:220px;max-width:320px;padding:10px 14px;border-radius:10px;font-size:.85rem;font-weight:500;box-shadow:var(--shadow-md);background:#1a1a1a;color:#fff;border-left:3px solid #ffffff}.toast-success{border-left-color:#22c55e}.toast-info{border-left-color:#3b82f6}.toast-error{border-left-color:#ef4444}:root{--font-main: "Fredoka", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--font-display: "Bungee", cursive;line-height:1.5;font-weight:400;--bg-primary: #ffffff;--bg-secondary: #f4f4f4;--bg-tertiary: #eeeeee;--bg-card: #ffffff;--bg-hover: #f1f1f1;--text-primary: #000000;--text-secondary: #555555;--text-tertiary: #999999;--border-color: #e5e5e5;--border-hover: #d4d4d4;--accent-primary: #007ACC;--accent-gold: #007ACC;--accent-gold-hover: #005A9E;--accent-contrast: #ffffff;--accent-success: #10b981;--accent-danger: #ef4444;--shadow-sm: 0 2px 4px rgba(0,0,0,.02);--shadow-md: 0 4px 20px rgba(0,0,0,.05);--shadow-lg: 0 10px 40px rgba(0,0,0,.08);--shadow-xl: 0 20px 60px rgba(0,0,0,.12);--radius-sm: 10px;--radius-md: 16px;--radius-lg: 24px;--radius-xl: 32px}.dark{--bg-primary: #181818;--bg-secondary: #1f1f1f;--bg-tertiary: #242424;--bg-card: #181818;--bg-hover: #2a2a2a;--text-primary: #ffffff;--text-secondary: #999999;--text-tertiary: #555555;--border-color: #2a2a2a;--border-hover: #333333;--accent-primary: #007ACC;--accent-gold: #007ACC;--accent-gold-hover: #0089ff;--accent-contrast: #ffffff;--shadow-sm: 0 4px 12px rgba(0,0,0,.5);--shadow-md: 0 10px 40px rgba(0,0,0,.8);--shadow-lg: 0 20px 60px rgba(0,0,0,1)}html{height:100%;overflow:hidden}body{margin:0;padding:0;height:100%;overflow:hidden;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;user-select:none;-webkit-user-select:none}#root{height:100%;overflow:hidden}.switch-premium{position:relative;display:inline-block;width:50px;height:28px;flex-shrink:0}.switch-premium input{opacity:0;width:0;height:0}.slider-premium{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--bg-hover);transition:.3s;border-radius:34px}.slider-premium:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%;box-shadow:0 2px 4px #0000001a}input:checked+.slider-premium{background-color:#007acc!important}input:checked+.slider-premium:before{transform:translate(22px)}.row-divider{height:1px;background:var(--border-color);margin:0;opacity:.6}*{scrollbar-width:none;-webkit-tap-highlight-color:transparent;font-family:inherit}*::-webkit-scrollbar{display:none}input,textarea,button,select{user-select:text;-webkit-user-select:text}.theme-midnight{--accent-gold: #38bdf8;--accent-gold-hover: #0ea5e9;--gradient-gold: linear-gradient(135deg, #38bdf8 0%, #818cf8 100%)}.dark.theme-midnight{--bg-primary: #020617;--bg-secondary: #0f172a;--bg-card: #0f172a;--bg-hover: #1e293b;--border-color: #1e293b}.theme-forest{--accent-gold: #10b981;--accent-gold-hover: #059669;--gradient-gold: linear-gradient(135deg, #10b981 0%, #34d399 100%)}.dark.theme-forest{--bg-primary: #022c22;--bg-secondary: #064e3b;--bg-card: #064e3b;--bg-hover: #065f46;--border-color: #065f46}.theme-sunset{--accent-gold: #fb923c;--accent-gold-hover: #f97316;--gradient-gold: linear-gradient(135deg, #fb923c 0%, #f43f5e 100%)}.dark.theme-sunset{--bg-primary: #450a0a;--bg-secondary: #7f1d1d;--bg-card: #7f1d1d;--bg-hover: #991b1b;--border-color: #991b1b}.theme-aurora{--accent-gold: #a855f7;--accent-gold-hover: #9333ea;--gradient-gold: linear-gradient(135deg, #a855f7 0%, #ec4899 100%)}.dark.theme-aurora{--bg-primary: #0f172a;--bg-secondary: #1e1b4b;--bg-card: #1e1b4b;--bg-hover: #312e81;--border-color: #312e81}.btn-primary,.btn-submit,.btn-welcome-submit{background:#007acc!important;color:#fff!important;border:none!important;font-weight:800!important;text-transform:uppercase!important;letter-spacing:1px!important;transition:all .2s cubic-bezier(.4,0,.2,1)!important}.btn-primary:active,.btn-submit:active{transform:scale(.95)}.btn-secondary,.btn-cancel{background:var(--bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;font-weight:700!important}.dark .btn-secondary,.dark .btn-cancel{background:var(--bg-tertiary)!important}.app-icon-small-img{width:40px;height:40px;border-radius:12px;object-fit:cover;box-shadow:var(--shadow-sm)}
