.app-header{border-bottom:1px solid var(--border);background:var(--surface);align-items:center;gap:1rem;padding:1rem 1.5rem;display:flex}.back-link{color:var(--accent);border-radius:6px;padding:.35rem .75rem;font-size:.9375rem;text-decoration:none;transition:background .2s}.back-link:hover{background:var(--hover)}.app-title{margin:0;font-size:1.25rem}.app-user{color:var(--text-muted);margin-left:auto;font-size:.875rem}.logout-button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:6px;padding:.5rem 1rem;font-size:.875rem;transition:background .2s}.logout-button:hover{background:var(--hover)}.vcf-form{flex-wrap:wrap;align-items:center;gap:.75rem;display:flex}.vcf-file-label{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:6px;align-items:stretch;transition:border-color .2s;display:inline-flex;overflow:hidden}.vcf-file-label:hover{border-color:var(--accent)}.vcf-file-input{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.vcf-file-button{background:var(--hover);color:var(--text);border-right:1px solid var(--border);white-space:nowrap;padding:.5rem 1rem;font-size:.875rem;font-weight:500}.vcf-file-name{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:260px;padding:.5rem .875rem;font-size:.875rem;overflow:hidden}.vcf-upload-btn{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.5rem 1.25rem;font-size:.875rem;font-weight:500;transition:background .2s}.vcf-upload-btn:hover:not(:disabled){background:var(--accent-hover)}.vcf-upload-btn:disabled{opacity:.5;cursor:not-allowed}.vcf-toast{background:var(--surface);border:1px solid var(--border);z-index:100;border-radius:8px;max-width:24rem;padding:.75rem 1rem;font-size:.875rem;animation:.2s ease-out vcf-toast-in;position:fixed;bottom:1.5rem;right:1.5rem;box-shadow:0 4px 12px #00000026}.vcf-toast--success{border-color:#16a34a73}.vcf-toast--error{color:#dc2626;border-color:#dc262673}.vcf-toast a{color:var(--accent)}@keyframes vcf-toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.detail-layout{background:var(--bg);min-height:100vh}.detail-main{max-width:960px;margin:0 auto;padding:1.5rem}.detail-muted{color:var(--text-muted)}.detail-banner{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem}.detail-banner.error{background:#dc26261f;border:1px solid #dc262659}.detail-section{margin-bottom:2rem}.detail-section h2{margin:0 0 .75rem;font-size:1.05rem}.detail-dl{gap:.75rem;margin:0;display:grid}.detail-dl>div{grid-template-columns:200px 1fr;gap:.5rem;font-size:.875rem;display:grid}@media (width<=600px){.detail-dl>div{grid-template-columns:1fr}}.detail-dl dt{color:var(--text-muted);margin:0;font-weight:500}.detail-dl dd{margin:0}.detail-pill{background:var(--hover);border-radius:999px;padding:.15rem .5rem;font-size:.8125rem;display:inline-block}.detail-table{border-collapse:collapse;border:1px solid var(--border);border-radius:8px;width:100%;font-size:.8125rem;overflow:hidden}.detail-table th,.detail-table td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .65rem}.detail-table th{background:var(--hover);color:var(--text-muted);font-weight:600}.detail-table tr:last-child td{border-bottom:none}.detail-json{border:1px solid var(--border);background:var(--surface);border-radius:8px;max-height:420px;margin:0;padding:1rem;font-size:.75rem;line-height:1.45;overflow:auto}.orders-layout{background:var(--bg);min-height:100vh}.orders-main{max-width:1200px;margin:0 auto;padding:1.5rem}.orders-toolbar{margin-bottom:1rem}.orders-search{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.orders-search-input{border:1px solid var(--border);background:var(--surface);min-width:220px;max-width:420px;color:var(--text);border-radius:6px;flex:1;padding:.5rem .65rem;font-size:.875rem}.orders-btn{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:6px;padding:.5rem .85rem;font-size:.8125rem}.orders-btn:hover:not(:disabled){background:var(--hover)}.orders-btn:disabled{opacity:.45;cursor:not-allowed}.orders-btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}.orders-btn.primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.orders-btn.ghost{color:var(--accent);background:0 0;border-color:#0000}.orders-banner{border-radius:8px;margin-bottom:1rem;padding:.75rem 1rem;font-size:.875rem}.orders-banner.error{background:#dc26261f;border:1px solid #dc262659}.orders-muted{color:var(--text-muted)}.orders-count{color:var(--text-muted);margin:0 0 .75rem;font-size:.875rem}.orders-table-wrap{border:1px solid var(--border);background:var(--surface);border-radius:8px;overflow:hidden}.orders-table{border-collapse:collapse;width:100%;font-size:.875rem}.orders-table th,.orders-table td{text-align:left;border-bottom:1px solid var(--border);padding:.65rem .85rem}.orders-table th{background:var(--hover);color:var(--text-muted);font-size:.8125rem;font-weight:600}.orders-table tr:last-child td{border-bottom:none}.orders-empty{text-align:center;color:var(--text-muted);padding:2rem 1rem!important}.orders-row-clickable{cursor:pointer}.orders-row-clickable:hover{background:var(--hover)}.orders-row-clickable:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}.orders-pill{background:var(--hover);border-radius:999px;padding:.15rem .5rem;font-size:.8125rem;display:inline-block}.orders-pagination{justify-content:center;align-items:center;gap:1rem;margin-top:1.25rem;display:flex}.orders-page-info{color:var(--text-muted);font-size:.875rem}.loading-container{min-height:100vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.config-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;max-width:480px;margin:4rem auto;padding:2rem}.config-error h2{color:#dc2626;margin:0 0 .5rem}.config-error code{background:#fee2e2;border-radius:3px;padding:.125rem .375rem;font-size:.875rem}.login-container{justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:12px;width:100%;max-width:400px;padding:3rem 2.5rem;box-shadow:0 4px 24px #0000000f}.login-card h1{margin:0 0 .5rem;font-size:1.75rem}.login-card p{color:var(--text-muted);margin:0 0 2rem}.login-button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;padding:.75rem 2rem;font-size:1rem;font-weight:500;transition:background .2s;display:inline-flex}.login-button:hover{background:var(--accent-hover)}.login-button:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.error-container{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:100vh;padding:2rem;display:flex}.error-container h2{color:#dc2626;margin:0}.error-container p{color:var(--text-muted);margin:0 0 1rem}:root{--text:#111827;--text-muted:#6b7280;--bg:#fff;--surface:#fff;--border:#e5e7eb;--hover:#f3f4f6;--accent:#2563eb;--accent-hover:#1d4ed8;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;line-height:1.5}@media (prefers-color-scheme:dark){:root{--text:#f3f4f6;--text-muted:#9ca3af;--bg:#111827;--surface:#1f2937;--border:#374151;--hover:#374151;--accent:#3b82f6;--accent-hover:#2563eb}.config-error{color:#fca5a5;background:#450a0a;border-color:#7f1d1d}.config-error h2{color:#fca5a5}.config-error code{background:#7f1d1d}}*,:before,:after{box-sizing:border-box}body{margin:0}h1,h2,h3{color:var(--text);font-weight:600}
