:root{--color-bg:#0f1117;--color-surface:#1a1d27;--color-surface-raised:#222639;--color-border:#ffffff14;--color-border-hover:#ffffff29;--color-primary:#6366f1;--color-primary-light:#818cf8;--color-primary-glow:#6366f140;--color-accent:#06b6d4;--color-accent-glow:#06b6d433;--color-success:#22c55e;--color-success-bg:#22c55e1a;--color-danger:#ef4444;--color-danger-bg:#ef44441a;--color-warning:#f59e0b;--color-warning-bg:#f59e0b1a;--color-info:#3b82f6;--color-info-bg:#3b82f61a;--color-text:#f1f5f9;--color-text-secondary:#94a3b8;--color-text-muted:#64748b;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:24px;--shadow-sm:0 1px 3px #0000004d;--shadow-md:0 4px 20px #0006;--shadow-lg:0 8px 40px #00000080;--shadow-glow:0 0 30px var(--color-primary-glow);--font-sans:"Inter", -apple-system, system-ui, sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-base:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.4s cubic-bezier(.4, 0, .2, 1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(80% 60% at 50% 0,#6366f114,#0000 60%),radial-gradient(60% 40% at 80% 100%,#06b6d40f,#0000 50%);position:fixed;inset:0}h1,h2,h3,h4{letter-spacing:-.02em;font-weight:700;line-height:1.2}a{color:var(--color-primary-light);transition:color var(--transition-fast);text-decoration:none}.app-container{max-width:1060px;margin:0 auto;padding:1.5rem}.app-header{text-align:center;padding:.5rem 0 1rem}.app-header__icon{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));border-radius:var(--radius-lg);width:56px;height:56px;box-shadow:var(--shadow-glow);place-items:center;margin:0 auto 1rem;font-size:1.5rem;animation:3s ease-in-out infinite alternate pulse-glow;display:grid}@keyframes pulse-glow{0%{box-shadow:0 0 20px var(--color-primary-glow)}to{box-shadow:0 0 40px var(--color-primary-glow), 0 0 60px var(--color-accent-glow)}}.app-header h1{background:linear-gradient(135deg, var(--color-text), var(--color-primary-light));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.75rem}.app-header p{color:var(--color-text-secondary);margin-top:.35rem;font-size:.95rem}.summary-bar{grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.25rem;display:grid}.summary-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;transition:border-color var(--transition-base);padding:1.25rem;position:relative;overflow:hidden}.summary-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.summary-card--total:before{background:var(--color-info)}.summary-card--success:before{background:var(--color-success)}.summary-card--failed:before{background:var(--color-danger)}.summary-card--amount:before{background:var(--color-accent)}.summary-card:hover{border-color:var(--color-border-hover)}.summary-card__label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:.4rem;font-size:.75rem}.summary-card__value{font-size:1.5rem;font-weight:700}.summary-card--total .summary-card__value{color:var(--color-info)}.summary-card--success .summary-card__value{color:var(--color-success)}.summary-card--failed .summary-card__value{color:var(--color-danger)}.summary-card--amount .summary-card__value{color:var(--color-accent);font-family:var(--font-mono);font-size:1.35rem}.summary-card__subvalue{color:var(--color-text-muted);margin-top:.25rem;font-size:.8rem}.summary-card--amount .summary-card__subvalue{color:#06b6d4cc;font-weight:500}.summary-card.clickable{cursor:pointer;transition:all var(--transition-fast)}.summary-card.clickable:hover{transform:translateY(-2px)}.summary-card.active{border-color:var(--color-primary-light);box-shadow:0 4px 15px var(--color-primary-glow)}.summary-card--total.active{border-color:var(--color-info);box-shadow:0 4px 15px var(--color-info-bg)}.summary-card--success.active{border-color:var(--color-success);box-shadow:0 4px 15px var(--color-success-bg)}.summary-card--failed.active{border-color:var(--color-danger);box-shadow:0 4px 15px var(--color-danger-bg)}.summary-card--amount.active{border-color:var(--color-accent);box-shadow:0 4px 20px var(--color-accent-glow)}.upload-container{border-radius:var(--radius-xl);background-color:#0003;border:2px dashed #ffffff1a;flex-direction:column;justify-content:center;align-items:center;margin-bottom:1.25rem;padding:3rem 2rem;transition:all .3s;display:flex;position:relative}.upload-container--drag{border-color:var(--color-primary);background-color:#4361ee26;box-shadow:inset 0 0 30px #4361ee33}.upload-container__drop-hint{color:var(--color-primary);opacity:0;pointer-events:none;font-size:1rem;font-weight:600;transition:all .3s;position:absolute;top:1.2rem;transform:translateY(-10px)}.upload-container--drag .upload-container__drop-hint{opacity:1;transform:translateY(0)}.desktop-only{display:block}@media (width<=768px){.desktop-only{display:none!important}.upload-container{background-color:#0000;border:none;padding:0}}.btn-upload-lg{background:linear-gradient(135deg, var(--color-primary), var(--color-accent));color:#fff;border-radius:var(--radius-xl);cursor:pointer;box-shadow:0 4px 20px var(--color-primary-glow);transition:all var(--transition-base);border:none;justify-content:center;align-items:center;gap:1rem;padding:1.5rem 3rem;font-size:1.25rem;font-weight:700;display:inline-flex;position:relative;overflow:hidden}.btn-upload-lg:before{content:"";opacity:0;transition:opacity var(--transition-fast);background:linear-gradient(135deg,#ffffff1a,#fff0);position:absolute;inset:0}.btn-upload-lg:hover{box-shadow:0 8px 30px var(--color-primary-glow);transform:translateY(-3px)}.btn-upload-lg:hover:before{opacity:1}.btn-upload-lg:active{transform:translateY(1px)}.btn-upload-lg__icon{font-size:2rem;line-height:1}.upload-container__hint{color:var(--color-text-secondary);margin-top:.75rem;font-size:.95rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:border-color var(--transition-base);padding:1.5rem}.card:hover{border-color:var(--color-border-hover)}.card__title{color:var(--color-text);border-bottom:1px solid var(--color-border);margin-bottom:1.5rem;padding-bottom:.75rem;font-size:1.15rem;font-weight:700}.card__title-count{background:var(--color-surface-raised);color:var(--color-text-muted);border-radius:var(--radius-xl);margin-left:.75rem;padding:.2rem .6rem;font-size:.85rem;font-weight:600}.date-filter-group{gap:.4rem;width:100%;margin-top:.25rem;display:flex}@media (width<=600px){.date-filter-group{flex-direction:column;gap:.4rem}}.date-field{background:var(--color-surface-raised);border-radius:var(--radius-sm);border:1px solid var(--color-border);cursor:text;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);flex:1;align-items:center;gap:.5rem;padding:.4rem .6rem;display:flex}.date-field:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f126}.date-label{color:var(--color-text-muted);min-width:1.5rem;font-size:.85rem;font-weight:600}.date-input{color:var(--color-text);font-family:var(--font-mono);cursor:pointer;background:0 0;border:none;outline:none;width:100%;font-size:.95rem}.date-input::-webkit-calendar-picker-indicator{filter:invert();cursor:pointer;opacity:.6;transition:opacity var(--transition-fast)}.date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.slip-list{flex-direction:column;gap:.75rem;list-style:none;display:flex}.slip-card{background:var(--color-surface-raised);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:border-color var(--transition-fast);align-items:stretch;gap:1rem;padding:1rem;animation:.3s ease-out slide-in;display:flex}.slip-card:hover{border-color:var(--color-border-hover)}@keyframes slide-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.slip-card__thumb{border-radius:var(--radius-sm);cursor:pointer;background:var(--color-surface);flex-shrink:0;width:72px;height:72px;position:relative;overflow:hidden}.slip-card__thumb img{object-fit:cover;width:100%;height:100%;transition:transform var(--transition-base)}.slip-card__thumb:hover img{transform:scale(1.1)}.thumb-overlay{opacity:0;transition:opacity var(--transition-fast);background:#00000080;place-items:center;display:grid;position:absolute;inset:0}.slip-card__thumb:hover .thumb-overlay{opacity:1}.slip-card__info{flex-direction:column;flex:1;justify-content:center;gap:.25rem;min-width:0;display:flex}.slip-card__amount{font-size:1.3rem;font-weight:700;font-family:var(--font-mono);color:var(--color-text);line-height:1.2}.slip-card__amount--pending{color:var(--color-text-muted);font-size:.95rem;font-style:italic;font-weight:400}.slip-card__datetime{color:var(--color-text-secondary);font-size:.9rem}.status-badge{text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;border-radius:100px;align-items:center;gap:.3rem;padding:.2rem .6rem;font-size:.65rem;font-weight:600;display:inline-flex}.status-badge--uploaded{color:#94a3b8;background:#64748b26}.status-badge--ocr_processing,.status-badge--llm_processing{background:var(--color-warning-bg);color:var(--color-warning);animation:1.5s ease-in-out infinite badge-pulse}.status-badge--ocr_done{background:var(--color-info-bg);color:var(--color-info)}.status-badge--success{background:var(--color-success-bg);color:var(--color-success)}.status-badge--failed{background:var(--color-danger-bg);color:var(--color-danger)}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.5}}.slip-card__actions{flex-direction:column;flex-shrink:0;align-self:center;gap:.35rem;display:flex}.btn-icon{border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;justify-content:center;align-items:center;gap:.3rem;padding:.35rem .65rem;font-size:.7rem;font-weight:500;display:inline-flex}.btn-icon:hover{border-color:var(--color-border-hover);color:var(--color-text);background:#ffffff0d}.btn-icon--danger:hover{border-color:var(--color-danger);color:var(--color-danger);background:var(--color-danger-bg)}.empty-state{text-align:center;color:var(--color-text-muted);padding:2.5rem 1rem}.empty-state__icon{opacity:.5;margin-bottom:.75rem;font-size:2.5rem}.empty-state p{font-size:.9rem}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000d9;justify-content:center;align-items:center;padding:2rem;animation:.2s ease-out fade-in;display:flex;position:fixed;inset:0}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{max-width:90vw;max-height:85vh;animation:.25s ease-out scale-in;position:relative}@keyframes scale-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-content img{object-fit:contain;border-radius:var(--radius-md);max-width:100%;max-height:85vh;box-shadow:var(--shadow-lg)}.modal-close{border:1px solid var(--color-border);background:var(--color-surface);width:36px;height:36px;color:var(--color-text);cursor:pointer;transition:all var(--transition-fast);z-index:1;border-radius:50%;place-items:center;font-size:1rem;display:grid;position:absolute;top:-12px;right:-12px}.modal-close:hover{background:var(--color-danger);border-color:var(--color-danger)}.uploading-bar{background:var(--color-surface-raised);border:1px solid var(--color-primary);border-radius:var(--radius-md);align-items:center;gap:.75rem;margin-bottom:1rem;padding:.75rem 1rem;animation:.3s ease-out slide-in;display:flex}.uploading-bar__spinner{border:2px solid #6366f14d;border-top-color:var(--color-primary);border-radius:50%;width:18px;height:18px;animation:.6s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.uploading-bar__text{color:var(--color-primary-light);font-size:.85rem}.load-more-spinner{justify-content:center;align-items:center;margin-top:1rem;padding:1.5rem;display:flex}.status-bar{color:var(--color-text-muted);justify-content:center;align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:.8rem;display:flex}.status-dot{background:var(--color-success);border-radius:50%;width:7px;height:7px;animation:2s ease-in-out infinite blink}.status-dot--error{background:var(--color-danger);animation:none}@keyframes blink{0%,to{opacity:1}50%{opacity:.4}}.app-footer{text-align:center;color:var(--color-text-muted);border-top:1px solid var(--color-border);margin-top:2rem;padding:1.25rem 0;font-size:.75rem}@media (width<=640px){.app-container{padding:1rem}.app-header h1{font-size:1.4rem}.summary-bar{grid-template-columns:1fr;gap:.75rem}.slip-card{flex-direction:column;align-items:flex-start}.slip-card__thumb{width:100%;height:120px}.slip-card__actions{flex-direction:row;width:100%}.slip-card__actions .btn-icon{flex:1}.modal-content{max-width:95vw}}.group-chips-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.25rem;padding:1rem 1.25rem}.group-chips-header{margin-bottom:.75rem}.group-chips{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.group-chip{border:1px solid var(--color-border);color:var(--color-text-secondary);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;background:0 0;border-radius:100px;align-items:center;gap:.4rem;padding:.45rem .85rem;font-size:.82rem;font-weight:500;display:inline-flex}.group-chip:hover{border-color:var(--color-primary-light);color:var(--color-text);background:#6366f114}.group-chip--active{border-color:var(--color-primary);background:var(--color-primary-glow);color:var(--color-primary-light);box-shadow:0 0 12px var(--color-primary-glow);font-weight:600}.group-chip__count{text-align:center;background:#ffffff1a;border-radius:100px;min-width:1.4rem;padding:.1rem .4rem;font-size:.7rem;font-weight:600}.group-chip--active .group-chip__count{background:#6366f14d}.group-chip--add{color:var(--color-text-muted);border-style:dashed}.group-chip--add:hover{border-color:var(--color-success);color:var(--color-success);background:var(--color-success-bg)}.group-filter-bar{flex-wrap:wrap;gap:.4rem;margin-bottom:1rem;display:flex}.group-filter-chip{border:1px solid var(--color-border);color:var(--color-text-muted);font-family:var(--font-sans);cursor:pointer;transition:all var(--transition-fast);background:0 0;border-radius:100px;padding:.3rem .7rem;font-size:.75rem;font-weight:500}.group-filter-chip:hover{border-color:var(--color-accent);color:var(--color-text)}.group-filter-chip--active{border-color:var(--color-accent);background:var(--color-accent-glow);color:var(--color-accent);font-weight:600}.btn-upload-lg--disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.btn-upload-lg--disabled:hover{box-shadow:none;transform:none}
