:root{--blue: #005daa;--blue-light: #e8f0fe;--red: #e31837;--green: #28a745;--gray: #6c757d;--bg: #f4f6f9;--card: #fff;--border: #e2e6ea;--text: #1a1a2e;--muted: #888;--sidebar-bg: #1a1a2e;--sidebar-text: #b4b8c5;--sidebar-active: #fff;--sidebar-hover: rgba(255, 255, 255, .08);--sidebar-width: 250px;--header-height: 72px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);min-height:100vh;color:var(--text)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:20;overflow-y:auto}.sidebar-brand{display:flex;align-items:center;gap:12px;padding:24px 20px 20px;border-bottom:1px solid rgba(255,255,255,.08)}.brand-icon{font-size:1.8em}.brand-name{font-size:1.05em;font-weight:700;color:#fff;letter-spacing:-.3px}.brand-sub{font-size:.7em;color:var(--sidebar-text);margin-top:1px}.sidebar-nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;gap:4px}.sidebar-link{display:flex;align-items:center;gap:12px;padding:10px 14px;border-radius:8px;background:transparent;border:none;color:var(--sidebar-text);font-size:.88em;cursor:pointer;transition:all .15s;text-align:left;width:100%}.sidebar-link:hover{background:var(--sidebar-hover);color:#fff}.sidebar-link.active{background:#005daa4d;color:var(--sidebar-active);font-weight:600}.sidebar-link-icon{font-size:1.15em;width:24px;text-align:center}.sidebar-link-text{flex:1}.sidebar-count{background:#ffffff26;color:#fff;font-size:.72em;padding:2px 8px;border-radius:10px;font-weight:600}.sidebar-link.active .sidebar-count{background:#ffffff40}.sidebar-footer{padding:16px;border-top:1px solid rgba(255,255,255,.08)}.user-card{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-avatar-initials{display:flex;align-items:center;justify-content:center;background:var(--blue);color:#fff;font-size:.82em;font-weight:700}.user-info{overflow:hidden}.user-name{font-size:.82em;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.7em;color:var(--sidebar-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-signout{width:100%;justify-content:center;color:var(--sidebar-text)!important;border-color:#ffffff26!important;font-size:.78em!important;padding:6px 12px!important}.sidebar-signout:hover{background:#ffffff14!important;color:#fff!important}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.main-header{background:var(--card);padding:20px 32px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;min-height:var(--header-height)}.page-title{font-size:1.35em;font-weight:700;color:var(--text);display:flex;align-items:center;gap:8px}.page-subtitle{font-size:.82em;color:var(--muted);margin-top:2px}.main-body{flex:1;padding:24px 32px 40px;max-width:1100px;width:100%}.card{background:var(--card);border-radius:12px;padding:24px;margin-bottom:20px;box-shadow:0 1px 4px #0000000d;border:1px solid var(--border);transition:box-shadow .2s}.card:hover{box-shadow:0 4px 12px #00000014}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.card-header h2{font-size:1.1em;color:var(--text);display:flex;align-items:center;gap:8px}.badge{font-size:.75em;padding:2px 10px;border-radius:12px;font-weight:500}.badge-blue{background:#e8f0fe;color:var(--blue)}.badge-red{background:#fce8eb;color:var(--red)}.badge-green{background:#e6f4ea;color:var(--green)}.btn-row{display:flex;gap:6px;flex-wrap:wrap}.btn{border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.82em;font-weight:500;transition:all .15s;display:inline-flex;align-items:center;gap:4px}.btn-primary{background:var(--blue);color:#fff}.btn-primary:hover{background:#004a8f}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#a01128;transform:scale(1.05)}.btn-ghost{background:transparent;color:var(--gray);border:1px solid var(--border)}.btn-ghost:hover{background:#f8f9fa}.btn:disabled{opacity:.5;cursor:not-allowed}.icon-btn{font-size:.75em;padding:4px 10px;text-decoration:none;border-radius:6px;transition:background .15s}.icon-btn:hover{background:#dbeafe}.icon-btn-del:hover{background:#fce8eb!important}.upload-zone{border:2px dashed var(--border);border-radius:8px;padding:20px;text-align:center;cursor:pointer;transition:all .2s}.upload-zone:hover{border-color:var(--blue);background:#f8f9ff}.search-input{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:6px;font-size:.88em;background:var(--bg)}.search-input:focus{outline:none;border-color:var(--blue);background:#fff}.tabs{display:flex;gap:4px;flex-wrap:wrap;margin:10px 0}.tab{padding:5px 12px;border-radius:16px;font-size:.78em;font-weight:500;cursor:pointer;border:1px solid var(--border);background:var(--card);color:var(--gray);transition:all .15s;-webkit-user-select:none;user-select:none}.tab:hover{background:#f0f4ff;border-color:var(--blue)}.tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}.tab .cnt{opacity:.7;margin-left:3px}.deals-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:8px;margin-top:10px;max-height:560px;overflow-y:auto}.deal{padding:12px 14px;background:var(--bg);border-radius:8px;border:1px solid transparent;transition:all .15s;position:relative}.deal:hover{border-color:var(--blue);background:#f8f9ff}.deal-del{position:absolute;top:6px;right:6px;background:none;border:none;cursor:pointer;font-size:.7em;color:var(--muted);opacity:0;transition:opacity .15s;padding:2px 5px;border-radius:4px}.deal:hover .deal-del{opacity:.6}.deal-del:hover{opacity:1!important;color:var(--red);background:#fce8eb}.deal-name{font-weight:500;font-size:.88em;margin-bottom:4px}.deal-name a{color:var(--blue);text-decoration:none}.deal-name a:hover{text-decoration:underline}.deal-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.price{font-weight:700;color:var(--green);font-size:1em}.discount{font-weight:600;color:var(--green);font-size:.9em;background:#4caf5026;padding:2px 6px;border-radius:4px}.savings-only{font-weight:600;color:var(--green);font-size:.9em;background:#4caf5026;padding:2px 6px;border-radius:4px;border:1px dashed var(--green)}.no-item-num{font-size:.75em;color:#ff9800;background:#ff980026;padding:2px 6px;border-radius:4px;border:1px solid #ff9800;font-weight:600}.item-num{font-size:.75em;color:var(--muted)}.source-tag{font-size:.68em;color:var(--gray);background:var(--card);padding:2px 8px;border-radius:10px;border:1px solid var(--border)}.expiry{font-size:.72em;color:#e67e22}.status{padding:10px 14px;border-radius:6px;margin:8px 0;font-size:.88em;font-weight:500}.status-ok{background:#e6f4ea;color:#137333}.status-err{background:#fce8eb;color:#c5221f}.status-load{background:#e8f0fe;color:#1967d2}.empty{text-align:center;padding:24px;color:var(--muted);font-size:.9em}table{width:100%;border-collapse:collapse;font-size:.85em}th,td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border)}th{background:var(--bg);font-weight:600;color:var(--gray);font-size:.8em;text-transform:uppercase;letter-spacing:.3px}tr.item-row{cursor:pointer;transition:background .1s}tr.item-row:hover{background:#f0f4ff}tr.item-row.selected{background:#dbeafe;border-left:3px solid var(--blue)}.edit-btn{background:none;border:none;cursor:pointer;font-size:.8em;padding:2px 4px;opacity:.4;transition:opacity .15s}.edit-btn:hover,.item-row:hover .edit-btn{opacity:1}.edit-overlay{position:fixed;inset:0;background:#0006;z-index:100;display:flex;align-items:center;justify-content:center}.edit-form{background:var(--card);border-radius:10px;padding:20px;width:360px;box-shadow:0 8px 30px #0003}.edit-form h3{margin-bottom:12px;font-size:1em}.edit-form label{display:block;font-size:.78em;color:var(--gray);margin:8px 0 3px;font-weight:600;text-transform:uppercase}.edit-form input{width:100%;padding:7px 10px;border:1px solid var(--border);border-radius:5px;font-size:.88em}.edit-form input:focus{outline:none;border-color:var(--blue)}.edit-form .btn-row{margin-top:14px;justify-content:flex-end}.receipt-card{padding:14px;background:var(--bg);border-radius:8px;margin:8px 0;border:1px solid transparent;cursor:pointer;transition:all .15s}.receipt-card:hover{border-color:var(--blue);background:#f8f9ff}.receipt-card.selected{border-color:var(--blue);background:#e8f0fe}.receipt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.receipt-title{font-weight:600;font-size:.92em}.receipt-stats{display:flex;gap:12px;align-items:center}.receipt-stat{text-align:center}.receipt-stat-val{font-weight:700;color:var(--blue);font-size:1.1em}.receipt-stat-lbl{font-size:.7em;color:var(--muted);text-transform:uppercase}.receipt-items{margin-top:8px}.multi-select{position:relative;width:100%;min-width:200px;flex:1}.multi-select-btn{width:100%;padding:8px 12px;border:1px solid var(--border);border-radius:6px;font-size:.85em;background:var(--card);cursor:pointer;display:flex;justify-content:space-between;align-items:center;text-align:left;color:var(--text)}.multi-select-btn:hover{border-color:var(--blue)}.multi-select-btn .arrow{font-size:.6em;color:var(--muted);transition:transform .2s}.multi-select.open .arrow{transform:rotate(180deg)}.multi-select-dd{display:none;position:absolute;top:100%;left:0;right:0;background:var(--card);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 16px #0000001a;z-index:20;max-height:260px;overflow-y:auto;margin-top:4px}.multi-select.open .multi-select-dd{display:block}.ms-opt{display:flex;align-items:center;gap:8px;padding:7px 12px;cursor:pointer;font-size:.84em;transition:background .1s}.ms-opt:hover{background:var(--bg)}.ms-opt input{accent-color:var(--blue)}.ms-opt.all{border-bottom:1px solid var(--border);font-weight:600}.upload-file-list{margin-top:10px}.upload-file{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--bg);border-radius:8px;margin-bottom:6px;font-size:.85em;border:1px solid var(--border)}.upload-file .fname{flex:1;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-file .fsize{color:var(--muted);font-size:.8em;white-space:nowrap}.upload-file .fstatus{font-size:.8em;white-space:nowrap;min-width:70px;text-align:right}.upload-file .fprog{flex:0 0 80px;height:4px;background:var(--border);border-radius:2px;overflow:hidden}.upload-file .fprog-bar{height:100%;background:var(--blue);border-radius:2px;transition:width .3s}.upload-file.done{border-color:#c6efce;background:#e6f4ea}.upload-file.err{border-color:#fcd5d5;background:#fce8eb}.date-input{padding:5px 8px;border:1px solid var(--border);border-radius:5px;font-size:.85em;background:var(--card)}.source-checks{display:flex;gap:6px;flex-wrap:wrap}.source-checks label{display:flex;align-items:center;gap:3px;font-size:.8em;color:var(--gray);cursor:pointer;padding:2px 8px;border:1px solid var(--border);border-radius:12px;transition:all .15s}.source-checks label:hover{border-color:var(--blue);background:#f0f4ff}.source-checks input:checked+span{color:var(--blue);font-weight:600}.source-checks input{display:none}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.stat-card{background:var(--card);border-radius:12px;padding:20px 24px;border:1px solid var(--border);box-shadow:0 1px 4px #0000000d;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 12px #00000014}.stat-label{font-size:.78em;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600;margin-bottom:6px}.stat-value{font-size:1.8em;font-weight:800;color:var(--text);line-height:1.1}.stat-change{font-size:.78em;font-weight:600;margin-top:6px}.stat-change.up{color:var(--red)}.stat-change.down{color:var(--green)}.stat-sub{font-size:.78em;color:var(--muted);margin-top:4px}.charts-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.chart-half{min-width:0}.spend-tabs{display:flex;gap:6px;margin-bottom:20px}.spend-tab{padding:8px 18px;border-radius:8px;border:1px solid var(--border);background:var(--card);color:var(--gray);font-size:.85em;font-weight:500;cursor:pointer;transition:all .15s}.spend-tab:hover{border-color:var(--blue);background:var(--blue-light)}.spend-tab.active{background:var(--blue);color:#fff;border-color:var(--blue)}.category-list{display:flex;flex-direction:column;gap:8px;padding:10px 0}.category-row{display:flex;align-items:center;gap:10px;padding:6px 0;font-size:.85em}.category-dot{width:12px;height:12px;border-radius:3px;flex-shrink:0}.category-name{flex:1;color:var(--text)}.category-pct{color:var(--muted);font-size:.9em;min-width:40px;text-align:right}.category-amount{font-weight:600;color:var(--text);min-width:70px;text-align:right}.admin-user-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-top:12px}.admin-user-card{background:var(--bg);border-radius:10px;padding:16px;border:1px solid var(--border);transition:border-color .15s}.admin-user-card:hover{border-color:var(--blue)}.admin-user-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.admin-user-stats{display:flex;gap:20px}.activity-list{max-height:500px;overflow-y:auto}.activity-item{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border);align-items:flex-start}.activity-item:last-child{border-bottom:none}.activity-icon{font-size:1.1em;margin-top:2px}.activity-body{flex:1;min-width:0}.activity-line{display:flex;gap:6px;align-items:center;flex-wrap:wrap;font-size:.85em}.activity-user{font-weight:600;color:var(--text)}.activity-action{color:var(--gray)}.activity-detail{color:var(--muted);font-size:.9em;background:var(--bg);padding:1px 8px;border-radius:4px}.activity-time{font-size:.72em;color:var(--muted);margin-top:2px}@media(max-width:768px){.sidebar{width:100%;position:relative;flex-direction:row;overflow-x:auto;height:auto}.sidebar-brand,.sidebar-footer{display:none}.sidebar-nav{flex-direction:row;padding:8px;gap:4px}.sidebar-link{padding:8px 12px;white-space:nowrap}.sidebar-link-text{font-size:.8em}.app-layout{flex-direction:column}.main-content{margin-left:0}.main-header,.main-body{padding:16px 20px}.deals-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}
