:root{--primary:#4e79a7;--primary-dark:#3a5f87;--bg:#f4f6f9;--surface:#fff;--border:#e7e9ee;--text:#1a1a1a;--text-muted:#6b7280;--shadow-sm:0 1px 2px #1018280f;--shadow-md:0 4px 12px #10182814;color:var(--text);background:var(--bg);font:16px/1.5 system-ui,Segoe UI,Roboto,sans-serif}*{box-sizing:border-box}body{margin:0}.app{max-width:1000px;margin:0 auto}.nav{border-bottom:1px solid var(--border);background:var(--surface);box-shadow:var(--shadow-sm);z-index:10;flex-wrap:wrap;align-items:center;gap:1.25rem;padding:.85rem 1.25rem;display:flex;position:sticky;top:0}.brand{color:var(--primary-dark);margin-right:.5rem;font-size:1.15rem;font-weight:800}.nav a{color:var(--text-muted);border-bottom:2px solid #0000;padding:.3rem .1rem;font-size:.95rem;font-weight:600;text-decoration:none;transition:color .15s,border-color .15s}.nav a:hover{color:var(--primary-dark)}.nav a.active{color:var(--primary);border-bottom-color:var(--primary)}.lang-switcher{gap:.25rem;margin-left:auto;display:flex}.lang-switcher button{background:var(--surface);color:var(--text-muted);border:1px solid var(--border);padding:.3rem .65rem;font-size:.78rem}.lang-switcher button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.page{padding:1.75rem 1.5rem}.page h1{margin:0 0 1.25rem;font-size:1.5rem}.summary-cards{flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;display:flex}.card{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;flex-direction:column;flex:1;gap:.3rem;min-width:160px;padding:1.1rem 1.5rem;transition:box-shadow .15s,transform .15s;display:flex}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.card-icon{font-size:1.4rem}.card-label{color:var(--text-muted);font-size:.85rem}.card-value{font-size:1.6rem;font-weight:700}section{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;margin-bottom:1.5rem;padding:1.25rem}section h2{margin:0 0 1rem;font-size:1.05rem}.add-receipt-form{flex-direction:column;gap:1rem;max-width:480px;display:flex}.add-receipt-form label{flex-direction:column;gap:.35rem;font-size:.92rem;font-weight:600;display:flex}.add-receipt-form input{border:1px solid var(--border);border-radius:8px;padding:.55rem .65rem;font-size:1rem;transition:border-color .15s}.add-receipt-form input:focus{border-color:var(--primary);outline:none}.access-key-row{align-items:stretch;gap:.5rem;display:flex}.access-key-row input{flex:1;min-width:0}.scan-btn{flex-shrink:0;padding:.55rem .75rem;font-size:1.2rem;line-height:1}.qr-overlay{z-index:100;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.qr-modal{background:var(--surface);border-radius:16px;width:min(380px,95vw);overflow:hidden;box-shadow:0 8px 32px #0000004d}.qr-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:.85rem 1rem;font-size:.95rem;font-weight:600;display:flex}.qr-close{color:var(--text-muted);background:0 0;border:none;padding:.25rem .5rem;font-size:1rem}.qr-close:hover:not(:disabled){color:var(--text);background:#f1f2f4}.qr-viewport{width:100%}.qr-viewport video{border-radius:0;width:100%!important}.captcha-block{align-items:center;gap:1rem;display:flex}.captcha-block img{border:1px solid var(--border);border-radius:8px}.captcha-placeholder{width:180px;height:60px;color:var(--text-muted);background:#eef0f3;border-radius:8px;justify-content:center;align-items:center;font-size:.8rem;display:flex}button{cursor:pointer;border:1px solid var(--primary);background:var(--primary);color:#fff;border-radius:8px;padding:.55rem 1.1rem;font-weight:600;transition:background .15s,border-color .15s}button:hover:not(:disabled){background:var(--primary-dark);border-color:var(--primary-dark)}button:disabled{opacity:.55;cursor:not-allowed}.message{border-radius:10px;margin-top:1rem;padding:.85rem 1rem}.message.success{color:#1e7e34;background:#e8f5ea}.message.error{color:#b3261e;background:#fdecea}.receipt-summary{max-width:520px}.receipt-summary-title{margin:0 0 .85rem;font-size:1.05rem;font-weight:700}.receipt-summary dl{grid-template-columns:auto 1fr;gap:.3rem .75rem;margin:0 0 1rem;display:grid}.receipt-summary dt{opacity:.75;font-weight:600}.receipt-summary dd{margin:0}.receipt-summary-items{border-top:1px solid var(--border);margin:0;padding:0;list-style:none}.receipt-summary-items li{border-bottom:1px solid var(--border);justify-content:space-between;gap:1rem;padding:.5rem 0;font-size:.9rem;display:flex}.top-items-table{border-collapse:collapse;width:100%}.top-items-table tr:hover{background:#fafbfc}.top-items-table td{border-bottom:1px solid var(--border);padding:.5rem .6rem;font-size:.9rem}.top-items-table td.numeric{text-align:right;white-space:nowrap;color:var(--text-muted)}.history-search{border:1px solid var(--border);border-radius:8px;width:100%;max-width:480px;margin-bottom:1.5rem;padding:.65rem .75rem;font-size:1rem}.history-search:focus{border-color:var(--primary);outline:none}.receipt-list{flex-direction:column;gap:.75rem;margin:0;padding:0;list-style:none;display:flex}.receipt-list-item{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-sm);border-radius:12px;overflow:hidden}.receipt-list-header{background:var(--surface);width:100%;color:var(--text);text-align:left;border:none;justify-content:space-between;align-items:center;gap:1rem;padding:.85rem 1.1rem;font-weight:600;display:flex}.receipt-list-header:hover{background:#fafbfc}.receipt-list-icon{font-size:1.1rem}.receipt-list-store{flex:1}.receipt-list-date,.receipt-list-count{color:var(--text-muted);font-size:.85rem;font-weight:400}.receipt-list-total{color:var(--primary-dark);font-weight:700}.receipt-list-item .receipt-summary-items{padding:0 1.1rem .75rem}.item-category{color:var(--text-muted);font-size:.8rem}.granularity-toggle{gap:.5rem;margin-bottom:1rem;display:flex}.granularity-toggle button{background:var(--surface);color:var(--text-muted);border:1px solid var(--border)}.granularity-toggle button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.period-labels{color:var(--text-muted);margin-bottom:1rem}.comparison-table{border-collapse:collapse;width:100%}.comparison-table tr:hover{background:#fafbfc}.comparison-table td{border-bottom:1px solid var(--border);padding:.55rem .6rem;font-size:.9rem}.comparison-table td.numeric{text-align:right;white-space:nowrap}.change-badge{border-radius:999px;padding:.15rem .5rem;font-size:.85rem;font-weight:600}.change-badge.change-up{color:#95560e;background:#fdf0e0}.change-badge.change-down{color:#15598c;background:#e6f0fa}.change-badge.change-new{color:var(--primary-dark);background:#e9eef5}.change-badge.change-flat{color:var(--text-muted);background:#f1f2f4}@media (width<=640px){.nav{gap:.75rem}.lang-switcher{order:99;width:100%;margin-left:0}.summary-cards{flex-direction:column}}
