:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-card: #1a1a2e;--bg-card-hover: #1f1f35;--bg-input: #16162a;--bg-modal: #0f0f1a;--gold-primary: #f0c040;--gold-secondary: #d4a828;--gold-light: #ffd76e;--gold-glow: rgba(240, 192, 64, .15);--gold-gradient: linear-gradient(135deg, #f0c040, #d4a828);--green: #34d399;--green-bg: rgba(52, 211, 153, .1);--red: #f87171;--red-bg: rgba(248, 113, 113, .1);--blue: #60a5fa;--blue-bg: rgba(96, 165, 250, .1);--text-primary: #f0f0f5;--text-secondary: #a0a0b8;--text-muted: #6b6b80;--border: rgba(255, 255, 255, .06);--border-gold: rgba(240, 192, 64, .2);--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 20px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--shadow-gold: 0 4px 30px rgba(240, 192, 64, .08);--transition: .2s cubic-bezier(.4, 0, .2, 1);--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-webkit-tap-highlight-color:transparent}body{font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100dvh;overflow-x:hidden;-webkit-font-smoothing:antialiased}.app{display:flex;flex-direction:column;min-height:100dvh;padding-bottom:calc(72px + var(--safe-bottom))}.page{flex:1;padding:16px;padding-top:calc(var(--safe-top) + 16px);max-width:600px;margin:0 auto;width:100%}.page-title{font-size:28px;font-weight:800;letter-spacing:-.5px;margin-bottom:20px;background:var(--gold-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.bottom-nav{position:fixed;bottom:0;left:0;right:0;background:#0c0c14eb;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--border);display:flex;justify-content:space-around;padding:8px 0 calc(8px + var(--safe-bottom));z-index:100}.nav-item{display:flex;flex-direction:column;align-items:center;gap:4px;text-decoration:none;color:var(--text-muted);font-size:10px;font-weight:500;padding:4px 12px;border-radius:var(--radius-sm);transition:var(--transition);cursor:pointer;border:none;background:none}.nav-item.active{color:var(--gold-primary)}.nav-item.nav-center{position:relative;padding:0}.nav-center-btn{width:52px;height:52px;border-radius:50%;background:var(--gold-gradient);display:flex;align-items:center;justify-content:center;margin-top:-28px;box-shadow:0 4px 20px #f0c04059;transition:var(--transition)}.nav-item.nav-center.active .nav-center-btn{box-shadow:0 4px 30px #f0c0408c;transform:scale(1.08)}.nav-center-btn svg{width:24px;height:24px;stroke:#0a0a0f}.nav-item svg{width:24px;height:24px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;margin-bottom:12px;transition:var(--transition)}.card:hover{background:var(--bg-card-hover)}.card-gold{border-color:var(--border-gold);box-shadow:var(--shadow-gold)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-label{font-size:13px;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.card-value{font-size:28px;font-weight:700;letter-spacing:-.5px}.card-value.gold{color:var(--gold-primary)}.stats-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:16px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px}.stat-label{font-size:11px;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.8px;margin-bottom:8px}.stat-value{font-size:20px;font-weight:700}.badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;padding:4px 10px;border-radius:20px}.badge-up{background:var(--green-bg);color:var(--green)}.badge-down{background:var(--red-bg);color:var(--red)}.price-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.price-table thead th{background:var(--bg-secondary);color:var(--text-secondary);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:10px 12px;text-align:left;position:sticky;top:0;z-index:1}.price-table thead th:first-child{border-radius:var(--radius-sm) 0 0 0}.price-table thead th:last-child{border-radius:0 var(--radius-sm) 0 0}.price-table tbody td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text-primary)}.price-table tbody tr:last-child td{border-bottom:none}.price-table .price-buy{color:var(--green);font-weight:600}.price-table .price-sell{color:var(--red);font-weight:600}.source-badge{display:inline-block;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:6px;background:var(--gold-glow);color:var(--gold-primary)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.form-input,.form-select{width:100%;padding:12px 14px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:15px;font-family:inherit;outline:none;transition:var(--transition)}.form-input:focus,.form-select:focus{border-color:var(--gold-primary);box-shadow:0 0 0 3px var(--gold-glow)}.form-input::placeholder{color:var(--text-muted)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-md);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;border:none;transition:var(--transition);text-decoration:none}.btn-primary{background:var(--gold-gradient);color:#0a0a0f}.btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 20px #f0c0404d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-danger{background:var(--red-bg);color:var(--red)}.btn-sm{padding:8px 14px;font-size:12px}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:var(--transition)}.btn-icon:hover{color:var(--text-primary);background:var(--bg-card-hover)}.btn-full{width:100%}.holding-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:10px;transition:var(--transition)}.holding-item:hover{background:var(--bg-card-hover)}.holding-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px}.holding-type{font-weight:700;font-size:15px;color:var(--gold-primary)}.holding-store{font-size:12px;color:var(--text-muted)}.holding-details{display:flex;gap:16px;font-size:13px;color:var(--text-secondary)}.holding-detail-label{color:var(--text-muted);font-size:11px}.holding-detail-value{font-weight:600;margin-top:2px}.holding-actions{display:flex;gap:6px}.news-item{padding:14px 0;border-bottom:1px solid var(--border)}.news-item:last-child{border-bottom:none}.news-title{font-weight:600;font-size:14px;color:var(--text-primary);margin-bottom:4px;line-height:1.4}.news-title a{color:inherit;text-decoration:none}.news-title a:hover{color:var(--gold-primary)}.news-summary{font-size:13px;color:var(--text-secondary);line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-time{font-size:11px;color:var(--text-muted);margin-top:6px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.modal-content{background:var(--bg-modal);border-radius:var(--radius-xl) var(--radius-xl) 0 0;padding:24px;padding-bottom:calc(24px + var(--safe-bottom));width:100%;max-width:600px;max-height:85vh;overflow-y:auto;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-title{font-size:20px;font-weight:700;margin-bottom:20px}.modal-actions{display:flex;gap:10px;margin-top:20px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.chart-wrapper{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.chart-title{font-size:14px;font-weight:600;color:var(--text-secondary)}.chart-period{display:flex;gap:4px}.chart-period button{padding:4px 10px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:var(--transition)}.chart-period button.active{background:var(--gold-glow);color:var(--gold-primary)}.refresh-btn{position:fixed;bottom:calc(82px + var(--safe-bottom));right:16px;width:48px;height:48px;border-radius:50%;background:var(--gold-gradient);border:none;color:#0a0a0f;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px #f0c0404d;transition:var(--transition);z-index:50}.refresh-btn:hover{transform:scale(1.05)}.refresh-btn:active{transform:scale(.95)}.refresh-btn.spinning svg{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px 24px;color:var(--text-muted)}.empty-state svg{width:48px;height:48px;margin-bottom:16px;opacity:.3}.empty-state p{font-size:14px;margin-bottom:16px}.loading{display:flex;justify-content:center;padding:40px}.loading-dot{width:8px;height:8px;border-radius:50%;background:var(--gold-primary);margin:0 4px;animation:bounce 1.4s infinite ease-in-out both}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.section-title{font-size:16px;font-weight:700;margin:20px 0 12px;color:var(--text-primary)}.text-gold{color:var(--gold-primary)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-muted{color:var(--text-muted)}.text-right{text-align:right}.text-center{text-align:center}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center}.gap-8{gap:8px}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.expense-header{display:flex;justify-content:space-between;align-items:center}.month-picker{display:flex;align-items:center;justify-content:center;gap:16px;margin-bottom:16px}.month-btn{background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);width:36px;height:36px;border-radius:50%;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.month-btn:hover{background:var(--bg-card-hover);color:var(--gold-primary)}.month-label{font-size:16px;font-weight:700;color:var(--text-primary);min-width:140px;text-align:center}.card-expense-summary{text-align:center;border-color:#f8717126;background:linear-gradient(135deg,var(--bg-card),rgba(248,113,113,.03))}.category-breakdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px;margin-bottom:16px}.category-bar-item{margin-bottom:12px}.category-bar-item:last-child{margin-bottom:0}.category-bar-header{display:flex;justify-content:space-between;font-size:13px;margin-bottom:6px}.category-bar-track{height:6px;background:#ffffff0d;border-radius:3px;overflow:hidden}.category-bar-fill{height:100%;border-radius:3px;transition:width .5s ease}.expense-list{display:flex;flex-direction:column;gap:8px}.expense-item{display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px;transition:var(--transition)}.expense-item:hover{background:var(--bg-card-hover)}.expense-item-left{display:flex;align-items:center;gap:12px;overflow:hidden}.expense-thumb{width:44px;height:44px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.expense-thumb-icon{display:flex;align-items:center;justify-content:center;background:var(--bg-secondary);font-size:20px}.expense-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:160px}.expense-meta{display:flex;align-items:center;gap:8px;margin-top:4px}.expense-category-badge{font-size:10px;font-weight:600;padding:2px 6px;border-radius:4px;color:#fff;text-transform:uppercase;letter-spacing:.3px}.expense-item-right{display:flex;align-items:center;gap:8px;flex-shrink:0}.expense-amount{font-weight:700;font-size:14px;color:var(--red)}.expense-del-btn{background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:4px;transition:var(--transition)}.expense-del-btn:hover{color:var(--red)}.camera-fullscreen{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;z-index:300;display:flex;flex-direction:column}.camera-video{width:100%;height:100%;object-fit:cover}.camera-close-btn{position:absolute;top:calc(16px + var(--safe-top));right:16px;width:40px;height:40px;border-radius:50%;background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;color:#fff;font-size:18px;cursor:pointer;z-index:10}.camera-controls{position:absolute;bottom:0;left:0;right:0;padding:20px;padding-bottom:calc(40px + var(--safe-bottom));display:flex;flex-direction:column;align-items:center;gap:16px;background:linear-gradient(transparent,#000000b3)}.camera-hint{color:#ffffffb3;font-size:13px;font-weight:500}.camera-shutter{width:72px;height:72px;border-radius:50%;border:4px solid rgba(255,255,255,.8);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.camera-shutter:hover{border-color:#fff}.camera-shutter:active{transform:scale(.9)}.shutter-inner{width:56px;height:56px;border-radius:50%;background:#ffffffe6;transition:var(--transition)}.camera-shutter:active .shutter-inner{background:var(--gold-primary)}.camera-actions-row{display:flex;align-items:center;justify-content:center;gap:28px;width:100%}.gallery-btn{width:44px;height:44px;border-radius:12px;background:#ffffff26;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.25);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition)}.gallery-btn:hover{background:#ffffff40}.gallery-btn:active{transform:scale(.9)}.review-screen{padding-bottom:20px}.review-back-btn{background:none;border:none;color:var(--gold-primary);font-size:14px;font-weight:600;cursor:pointer;margin-bottom:12px;padding:4px 0;font-family:inherit}.review-image-wrapper{position:relative;border-radius:var(--radius-lg);overflow:hidden;margin-bottom:16px;max-height:200px}.review-image{width:100%;height:200px;object-fit:cover;display:block}.review-scanning-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;color:#fff;font-size:14px;font-weight:500}.scanning-pulse{width:40px;height:40px;border-radius:50%;background:var(--gold-primary);animation:pulse 1.5s ease infinite}@keyframes pulse{0%{transform:scale(.8);opacity:1}50%{transform:scale(1.2);opacity:.5}to{transform:scale(.8);opacity:1}}.review-form{animation:fadeIn .3s ease}.review-form .form-group label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.category-chips{display:flex;flex-wrap:wrap;gap:6px}.category-chip{padding:6px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg-input);color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;transition:var(--transition);font-family:inherit}.category-chip:hover{border-color:var(--text-muted)}.category-chip.active{color:#fff;border-color:transparent}.price-suggestions{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.price-chip{padding:8px 14px;border-radius:var(--radius-sm);border:1px solid var(--border-gold);background:var(--gold-glow);color:var(--gold-primary);font-size:14px;font-weight:700;cursor:pointer;transition:var(--transition);font-family:inherit}.price-chip:hover{background:#f0c04040}.price-chip.active{background:var(--gold-gradient);color:#0a0a0f;border-color:transparent}.price-chip-secondary{border-color:var(--border);background:var(--bg-input);color:var(--text-secondary);font-weight:600;font-size:13px}.price-chip-secondary:hover{border-color:var(--text-muted)}.form-input-amount{font-size:20px;font-weight:700;text-align:center;letter-spacing:1px}.save-expense-btn{width:100%;padding:14px;border-radius:var(--radius-md);background:var(--gold-gradient);color:#0a0a0f;border:none;font-size:16px;font-weight:700;cursor:pointer;margin-top:8px;transition:var(--transition);font-family:inherit}.save-expense-btn:hover{transform:translateY(-1px);box-shadow:0 4px 20px #f0c0404d}.save-expense-btn:active{transform:translateY(0)}.save-expense-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
