@import"https://fonts.googleapis.com/css2?family=Manrope:wght@300;400;500;600;700;800&family=Inter:wght@300;400;500;600&family=Playfair+Display:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Noto+Sans+SC:wght@300;400;500;600&family=Space+Grotesk:wght@300;400;500;600&display=swap";.app{min-height:100vh;padding:3.5rem 1.5rem 4rem;max-width:1100px;margin:0 auto;position:relative}.app:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:radial-gradient(circle at 18% 18%,rgba(26,26,26,.05) 0 1px,transparent 1px),radial-gradient(circle at 82% 28%,rgba(26,26,26,.04) 0 1px,transparent 1px),radial-gradient(circle at 28% 82%,rgba(26,26,26,.04) 0 1px,transparent 1px);background-size:280px 280px;opacity:.55;pointer-events:none;z-index:0}.app-header{--header-gap: 2.25rem;text-align:center;margin-bottom:var(--header-gap);width:min(420px,92vw);margin-left:auto;margin-right:auto;position:relative;z-index:1;animation:rise .8s ease both}.brand-logo{display:flex;justify-content:center;margin-bottom:var(--header-gap)}.brand-logo img{width:100px;height:auto;display:block}.app-header h1{font-family:var(--font-title);font-size:2rem;font-weight:800;margin:0 0 .35rem;color:var(--text);width:100%;white-space:nowrap;letter-spacing:-.01em}.app-header .subtitle{margin:0 auto;font-size:.75rem;color:var(--muted);font-weight:400;font-family:var(--font-display);font-style:italic;width:100%;white-space:nowrap}@media (max-width: 460px){.app-header h1{font-size:1.2rem}.app-header .subtitle{font-size:.52rem}}.app-main{margin-top:1.875rem;position:relative;z-index:1;animation:rise .9s ease both;display:flex;justify-content:center}@keyframes rise{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.capture-step{display:flex;flex-direction:column;align-items:center;gap:1.2rem;background:var(--surface);border-radius:28px;padding:2.2rem 2rem 3.2rem;border:1px solid var(--border);box-shadow:var(--shadow);width:min(420px,92vw);height:min(740px,88vh);overflow-y:auto;position:relative}.capture-empty{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;padding-top:1.4rem;transform:translateY(-10%)}.capture-illustration{width:208px;height:208px;color:var(--accent-strong);opacity:.8;margin-top:0}.capture-illustration-image{width:100%;height:100%;object-fit:contain;display:block}.capture-footer{position:absolute;left:1.4rem;right:1.4rem;bottom:1.2rem;margin:0;font-size:.65rem;text-align:center;color:#1a1a1a73}.capture-illustration svg{width:100%;height:100%}.capture-input{position:absolute;width:0;height:0;opacity:0;pointer-events:none}.capture-btn{width:100%;max-width:320px;padding:.95rem 2.2rem;background:var(--accent-strong);border:1px solid rgba(26,26,26,.4);border-radius:999px;color:#fff;font-size:1.05rem;font-weight:600;display:flex;flex-direction:row;align-items:center;gap:.6rem;justify-content:center;transition:border-color .2s,background .2s,transform .2s;box-shadow:var(--shadow-soft);margin-top:2.9rem;margin-bottom:1.2rem}.capture-btn:hover:not(:disabled){border-color:var(--accent-strong);background:#111;transform:translateY(-2px)}.capture-btn:disabled{opacity:.8;cursor:not-allowed}.capture-btn-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;color:#fff}.capture-btn-icon svg{width:22px;height:22px}.capture-btn-text{font-weight:600}.scan-title{margin:0;font-size:1.1rem;color:var(--accent-strong);font-weight:700}.capture-progress{display:flex;align-items:center;gap:.5rem}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent-strong);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.capture-error{color:var(--danger);font-size:.9rem;margin:0}.capture-preview-wrap{width:100%;margin-top:.5rem;display:flex;flex-direction:column;gap:1rem}.capture-preview{width:100%;max-height:240px;object-fit:contain;border-radius:16px;background:#fff;border:1px solid var(--border)}.capture-loading{width:100%;display:flex;align-items:center;justify-content:center;gap:.6rem;padding:.75rem;border-radius:14px;background:#1a1a1a0f;color:var(--text);font-weight:600}.parsed-info{background:#fff;border-radius:var(--radius);padding:1rem;border:1px solid var(--border);box-shadow:var(--shadow-soft);width:100%}.parsed-info h3{margin:0 0 .75rem;font-size:1rem;color:var(--accent-strong);font-weight:700}.parsed-info dl{display:grid;grid-template-columns:auto 1fr;gap:.25rem 1rem;margin:0 0 1rem;font-size:.95rem}.parsed-info dt{color:var(--muted);margin:0}.parsed-info dd{margin:0;font-weight:500}.parsed-actions{display:flex;gap:.75rem;flex-wrap:wrap;align-items:center}.parsed-actions .btn{white-space:nowrap}.ocr-raw{margin:.75rem 0 0;padding:.75rem;border-radius:var(--radius-sm);border:1px solid var(--border);background:#f9faf3;color:var(--text);font-size:.8rem;white-space:pre-wrap;word-break:break-word;max-height:220px;overflow:auto}.capture-hint{font-size:.72rem;color:var(--muted);margin:.5rem 0 0;white-space:nowrap}.capture-next{width:100%;display:flex;justify-content:center}.btn{padding:.55rem 1.2rem;border-radius:999px;border:none;font-size:.9rem;font-weight:500;transition:background .2s,color .2s,transform .2s,box-shadow .2s}.btn-icon{width:42px;height:42px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;border:1px solid #f3f5f3;background:#fff;color:#f5f7f5}.btn-icon:hover:not(:disabled){background:var(--surface-2);border-color:#ecefec;color:#eef2ee;transform:translateY(-1px)}.btn-icon:disabled{opacity:.5;cursor:not-allowed}.btn-icon-inner{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center}.btn-icon-inner svg{width:20px;height:20px}.btn-primary{background:var(--accent-strong);color:#fff;box-shadow:var(--shadow-soft)}.btn-primary:hover{background:#111;transform:translateY(-1px)}.btn-secondary{background:#fff;color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-2)}.btn-ghost{background:transparent;color:var(--text)}.btn-ghost:hover{color:var(--accent-strong)}.btn-ghost.btn-icon{border-color:#f3f5f3;color:#f5f7f5}.btn-ghost.btn-icon:hover:not(:disabled){border-color:#ecefec;color:#eef2ee}.btn-ghost.danger:hover{color:var(--danger)}.btn.large{padding:.9rem 1.6rem;font-size:1rem;width:100%}.form-step{width:100%;background:var(--surface);border-radius:30px;padding:2.4rem 2.1rem;border:1px solid var(--border);box-shadow:var(--shadow);width:min(420px,92vw);height:min(740px,88vh);overflow-y:auto}.form-actions-top{display:flex;justify-content:space-between;margin-bottom:1rem}.form-actions-inline{width:100%;display:flex;justify-content:flex-start;margin-bottom:.75rem}.reimbursement-form{display:flex;flex-direction:column;gap:1rem}.form-row{display:flex;flex-direction:column;gap:.35rem}.form-row label{font-size:.9rem;color:var(--muted);font-weight:500}.form-row input,.form-row textarea,.form-row select{padding:.6rem .75rem;background:#fff;border:1px solid var(--border);border-radius:14px;color:var(--text);transition:border-color .2s,box-shadow .2s}.form-row input[type=date],.field input[type=date]{text-align:left}.form-row input[type=date]::-webkit-date-and-time-value,.field input[type=date]::-webkit-date-and-time-value{text-align:left}.form-row input:focus,.form-row textarea:focus,.form-row select:focus{outline:none;border-color:#1a1a1a59;box-shadow:0 0 0 4px #1a1a1a1f}.rate-row{display:flex;gap:.5rem;align-items:center;flex-wrap:wrap}.rate-row input{flex:1;min-width:200px}.field-hint{margin:.35rem 0 0;font-size:.85rem;color:var(--muted)}.field-hint.error{color:var(--accent-strong)}.rate-section{width:100%;border:1px solid rgba(26,26,26,.18);border-radius:18px;padding:1rem;background:#1a1a1a0a;margin-bottom:.75rem}.rate-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem}.rate-header h4{margin:0;font-size:1rem;color:var(--accent-strong)}.rate-refresh{font-size:.8rem;padding:.4rem .8rem;white-space:nowrap}.rate-list{display:grid;gap:.75rem;margin-top:.75rem}.rate-item{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:.75rem;align-items:center}.rate-item input{width:100%;min-width:0}.rate-currency{display:flex;flex-direction:column;gap:.15rem}.rate-currency span{font-weight:600;color:var(--accent-strong)}.rate-currency small{color:var(--muted);font-size:.68rem;white-space:nowrap}.rate-hint{font-size:.68rem;white-space:nowrap}.form-row input.readonly{opacity:.8}.form-row textarea{resize:vertical;min-height:60px}.invoices-section{margin-top:.5rem}.invoices-section h3{margin:0 0 .5rem;font-size:1rem}.total-amount{margin:0 0 .75rem;font-size:1.1rem;color:var(--accent-strong)}.total-amount strong{font-size:1.25rem}.total-amount.small{font-size:.95rem;font-weight:600}.total-values{display:inline-flex;flex-wrap:wrap;gap:.75rem;margin-left:.4rem}.total-item{font-weight:600;color:var(--accent-strong)}.total-cny{margin:0 0 .5rem;font-size:.95rem;color:var(--muted)}.invoice-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:1rem}.invoice-card{position:relative;background:#fff;border:1px solid rgba(15,91,60,.12);border-radius:var(--radius);padding:1rem;display:flex;flex-direction:column;gap:1rem;align-items:stretch;box-shadow:var(--shadow-soft)}.invoice-card-preview{width:100px;height:100px;border-radius:0;overflow:hidden;background:var(--surface-2);align-self:center}.invoice-card-preview img{width:100%;height:100%;object-fit:contain}.invoice-card-fields{display:flex;flex-direction:column;gap:.5rem}.invoice-card-fields .field{display:grid;grid-template-columns:56px 1fr;gap:.5rem;align-items:center}.invoice-card-fields .field label{font-size:.8rem;color:var(--muted)}.invoice-card-fields .field input,.invoice-card-fields .field select{padding:.4rem .5rem;background:#fff;border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:.9rem}.btn-remove{padding:.35rem .6rem;font-size:.8rem;background:transparent;color:var(--muted);border:1px solid var(--border);border-radius:6px}.btn-remove:hover{color:var(--danger);border-color:var(--danger)}.form-actions{margin-top:1rem}.ocr-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06140cad;z-index:120;display:flex;align-items:center;justify-content:center;padding:1.5rem}.ocr-modal{width:min(680px,92vw);background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:1.2rem 1.4rem 1.4rem;position:relative}.ocr-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.6rem}.ocr-modal-header h3{margin:0;font-size:1.05rem}.ocr-close{width:36px;height:36px;border-radius:50%;border:1px solid var(--border);background:#fff;color:var(--muted);font-size:1.3rem;display:inline-flex;align-items:center;justify-content:center}.ocr-close:hover{color:var(--accent-strong);border-color:var(--accent-strong)}.print-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#06140cdb;z-index:100;overflow:auto;padding:1rem;display:flex;flex-direction:column;align-items:center}.print-actions{display:flex;justify-content:center;margin-bottom:1rem}.print-close{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;border:1px solid rgba(255,255,255,.4);background:#ffffff26;color:#fff;font-size:1.5rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s,background .2s,border-color .2s}.print-close:hover{transform:scale(1.05);background:#ffffff40;border-color:#fff9}.print-content{background:#fff;color:#111;padding:2rem;border-radius:var(--radius);max-width:800px;width:100%}.print-title{text-align:center;font-size:1.5rem;margin:0 0 1.5rem}.print-table{width:100%;border-collapse:collapse;margin-bottom:1.5rem;font-size:.95rem}.print-table td{padding:.5rem .75rem;border:1px solid #ddd}.print-table .label{width:90px;background:#f5f5f5;font-weight:500}.print-content h3{margin:1rem 0 .5rem;font-size:1rem}.print-invoices{width:100%;border-collapse:collapse;font-size:.9rem;margin-bottom:1.5rem}.print-invoices th,.print-invoices td{padding:.5rem;border:1px solid #ddd;text-align:left}.print-invoices .amount-col{text-align:right}.print-invoices th{background:#f5f5f5;font-weight:600}.print-invoices tfoot .total-label{text-align:right;font-weight:600;padding-right:1rem}.print-invoices .total-value{font-weight:700;font-size:1rem}.print-footer{margin:1.5rem 0 0;font-size:.9rem;color:#666}.print-summary{border:1px solid #e6e6e6;border-radius:10px;padding:.75rem 1rem;background:#fafafa;display:grid;gap:.4rem;margin-bottom:1.2rem}.summary-row{display:flex;justify-content:space-between;font-size:.9rem;color:#444}@media print{@page{size:A4 portrait;margin:12mm}html,body{background:#fff!important}body *{visibility:hidden}.app:before{display:none!important}.print-overlay,.print-overlay *{visibility:visible}.print-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#fff;padding:0}.print-actions,.print-close{display:none!important}.print-content{box-shadow:none;max-width:none;width:100%;padding:1.5rem;transform:none!important}}@media (max-width: 720px){.app{padding:2.6rem 1rem 3rem}.app-header h1{font-size:2.4rem}.capture-step,.form-step{height:min(720px,85vh)}}@media (max-width: 720px) and (orientation: portrait){.print-overlay{padding:.5rem}.print-actions{margin-bottom:.5rem}.print-content{width:92vh;max-width:92vh;transform:rotate(90deg) scale(.78);transform-origin:center}}@media (max-width: 520px){.rate-header{flex-direction:column;align-items:flex-start}.rate-refresh{width:100%}.rate-item{grid-template-columns:1fr}.rate-currency small,.rate-hint{white-space:normal}.parsed-actions{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr) auto;gap:.5rem}.parsed-actions .btn{padding:.45rem .7rem;font-size:.78rem}.parsed-actions .btn-icon{width:34px;height:34px;justify-self:end}.parsed-actions .btn-icon-inner,.parsed-actions .btn-icon-inner svg{width:16px;height:16px}}:root{--bg: #F8F3EC;--bg-deep: #FDFBF8;--surface: #FDFBF8;--surface-2: #F5F5F0;--border: #E5E5E5;--text: #1A1A1A;--muted: #6B7280;--accent: #1A1A1A;--accent-hover: #2D2D2D;--accent-strong: #111111;--success: #22c55e;--danger: #dc2626;--radius: 26px;--radius-sm: 14px;--shadow: 0 0 25px rgba(0, 0, 0, .08);--shadow-soft: 0 12px 28px rgba(0, 0, 0, .08);--font-title: "Manrope", "Inter", sans-serif;--font-display: "Playfair Display", "Times New Roman", serif;--font-text: "Inter", "Noto Sans SC", "PingFang SC", "Microsoft YaHei", sans-serif;--font-mono: "Space Grotesk", sans-serif}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%;font-family:var(--font-text);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased}input,button,select,textarea{font:inherit}button{cursor:pointer}
