:root{--bg: #f8fafc;--surface: #fff;--border: #e2e8f0;--text: #0f172a;--text-muted: #64748b;--primary: #0f172a;--primary-hover: #334155;--accent: #3b82f6;--success: #059669;--error: #dc2626;--radius: 10px;--radius-sm: 6px;--shadow: 0 1px 3px rgba(0, 0, 0, .06);--font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-doc: "Times New Roman", Times, serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}input,select,textarea{font-family:inherit}button{font-family:inherit;cursor:pointer}@media(max-width:768px){body{font-size:15px}}@media(max-width:480px){body{font-size:14px}}.app-header{background:var(--surface);border-bottom:1px solid var(--border);padding:12px 24px;position:sticky;top:0;z-index:100;box-shadow:0 1px #0000000a}.app-header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}.app-nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;padding:10px;border:none;background:transparent;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;transition:background .15s}.app-nav-toggle:hover{background:var(--bg)}.nav-toggle-bar{display:block;width:22px;height:2px;background:currentColor;border-radius:1px;transition:transform .2s,opacity .2s}.app-nav-toggle.is-open .nav-toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg)}.app-nav-toggle.is-open .nav-toggle-bar:nth-child(2){opacity:0}.app-nav-toggle.is-open .nav-toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.app-brand{display:flex;flex-direction:column;gap:0}.app-logo{font-size:1.25rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.app-tagline{font-size:.8rem;color:var(--text-muted);font-weight:500}.app-nav{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.app-nav a{padding:10px 16px;border-radius:var(--radius-sm);color:var(--text-muted);text-decoration:none;font-size:.9rem;font-weight:500;transition:color .15s,background .15s}.app-nav a:hover{color:var(--text);background:var(--bg)}.app-nav a.active{color:var(--primary);background:var(--bg)}.app-nav .nav-soon{padding:10px 14px;color:var(--text-muted);cursor:default;font-size:.85rem;opacity:.8;border-radius:var(--radius-sm)}@media(max-width:768px){.app-nav-toggle{display:flex}.app-nav{position:fixed;top:0;right:0;width:280px;max-width:85vw;height:100vh;background:var(--surface);border-left:1px solid var(--border);box-shadow:-4px 0 20px #0000001a;flex-direction:column;align-items:stretch;gap:0;padding:60px 0 24px;z-index:101;transform:translate(100%);transition:transform .25s ease;overflow-y:auto}.app-nav.app-nav-open{transform:translate(0)}.app-nav a,.app-nav .nav-soon{padding:14px 20px;font-size:1rem;min-height:48px;display:flex;align-items:center;border-radius:0;border-bottom:1px solid var(--border)}.app-nav a:last-of-type{border-bottom:1px solid var(--border)}.app-nav .nav-soon{opacity:.7}.app-nav-overlay{position:fixed;inset:0;background:#0000004d;z-index:100;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.app-header{padding:10px 16px}.app-logo{font-size:1.1rem}.app-tagline{font-size:.75rem}}@media(max-width:640px){.app-header{padding:8px 12px}.app-header-inner{gap:12px}.app-nav{width:260px;padding-top:56px}.app-nav a,.app-nav .nav-soon{padding:12px 16px;min-height:48px}.app-brand{min-width:0}.app-logo{font-size:1rem}}.contract-form-card .seller-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.seller-card{padding:12px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--surface);transition:border-color .2s,background .2s;text-align:left;font:inherit}.seller-card:hover{border-color:var(--text-muted)}.seller-card.selected{border-color:var(--primary);background:var(--bg)}.seller-card h3{font-size:.9rem;font-weight:600;margin-bottom:4px}.seller-card p{font-size:.75rem;color:var(--text-muted);margin:2px 0}.buyer-type-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:16px}.buyer-type-option{position:relative;padding:14px 14px 14px 42px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:var(--surface);transition:border-color .2s,background .2s}.buyer-type-option:hover{border-color:var(--text-muted)}.buyer-type-option input{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;margin:0;accent-color:var(--primary);cursor:pointer}.buyer-type-option.selected{border-color:var(--primary);background:var(--bg)}.buyer-type-option .label-text{font-size:.875rem;font-weight:500;color:var(--text)}.buyer-type-option .label-sub{font-size:.75rem;color:var(--text-muted);margin-top:2px}.hidden-input{position:absolute;width:0;height:0;opacity:0;overflow:hidden}.recognize-row{margin-bottom:12px}.btn-recognize{width:100%}.recognize-loading{display:flex;align-items:center;gap:12px;margin-top:12px;padding:14px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:var(--radius-sm);font-size:.9rem;color:var(--text)}.recognize-loading-spinner{display:inline-block;width:24px;height:24px;border:3px solid #bfdbfe;border-top-color:var(--accent);border-radius:50%;animation:recognize-spin .8s linear infinite;flex-shrink:0}.recognize-loading-text{font-weight:500}@keyframes recognize-spin{to{transform:rotate(360deg)}}.recognize-error-box{margin-top:12px;padding:12px 14px;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-sm);font-size:.85rem}.recognize-error-title{font-weight:600;color:var(--error);margin-bottom:8px}.recognize-error-text{margin:0 0 12px;padding:10px;background:#fff;border:1px solid #e5e7eb;border-radius:4px;white-space:pre-wrap;word-break:break-word;font-size:.8rem;line-height:1.4;max-height:200px;overflow-y:auto}.recognize-error-actions{display:flex;gap:8px;flex-wrap:wrap}.recognize-error-actions .btn-sm{padding:6px 12px;font-size:.8rem}@media(max-width:640px){.contract-form-card .seller-grid{grid-template-columns:1fr;gap:8px}.seller-card{padding:14px 12px;min-height:44px}.buyer-type-row{grid-template-columns:1fr;gap:8px}.buyer-type-option{padding:14px 14px 14px 44px;min-height:48px}.btn-recognize{min-height:48px}}.contract-preview-card .view-toggle{display:flex;flex-wrap:wrap;gap:2px;background:var(--bg);padding:4px;border-radius:var(--radius-sm);margin-bottom:12px;min-width:0}.contract-preview-card{min-width:0;overflow:hidden}.view-toggle-label{flex:1 1 0;min-width:0;margin:0;padding:6px 8px;text-align:center;cursor:pointer;font-size:.8rem;border-radius:4px;color:var(--text-muted)}.view-toggle-label span{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.view-toggle-label input{display:none}.view-toggle-label input:checked+span{background:var(--surface);color:var(--text);font-weight:500;border-radius:4px;box-shadow:var(--shadow);padding:2px 4px;margin:-2px -4px}.contract-preview{max-height:75vh;overflow-y:auto;overflow-x:auto;font-family:var(--font-doc);font-size:12pt;line-height:1.5;padding:24px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);-webkit-overflow-scrolling:touch}.contract-preview::-webkit-scrollbar{width:6px}.contract-preview::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}@media(max-width:768px){.contract-preview{max-height:60vh;padding:16px;font-size:11pt}}@media(max-width:640px){.view-toggle-label{padding:10px 8px;min-height:44px}.view-toggle-label span{font-size:.75rem}.contract-preview{max-height:50vh;padding:12px}}.create-view.container{max-width:1200px;margin:0 auto;padding:24px;min-height:0}.create-view .grid{display:grid;grid-template-columns:380px 1fr;gap:24px;align-items:start}@media(max-width:900px){.create-view .grid{grid-template-columns:1fr;gap:20px}}@media(max-width:768px){.create-view.container{padding:16px}.create-view .grid{gap:16px}}@media(max-width:480px){.create-view.container{padding:12px}.create-view .grid{gap:12px}}.doc-view.container{max-width:1200px;margin:0 auto;padding:24px}.doc-view-header{margin-bottom:20px;display:flex;flex-wrap:wrap;align-items:center;gap:12px}.doc-view-title{font-size:1.25rem;font-weight:600;margin:0}.doc-view-hint{font-size:.9rem;color:var(--text-muted);margin:0}.doc-view-grid{display:grid;grid-template-columns:380px 1fr;gap:24px;align-items:start}.doc-line-table{width:100%;border-collapse:collapse;font-size:.85rem;margin-bottom:12px}.doc-line-table th,.doc-line-table td{padding:6px 8px;text-align:left;border-bottom:1px solid var(--border)}.doc-line-table th{font-weight:600;color:var(--text-muted);font-size:.75rem}.doc-line-table input{width:100%;padding:6px 8px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem}.doc-line-table input:focus{outline:none;border-color:var(--accent)}.doc-line-table td:nth-child(2) input,.doc-line-table td:nth-child(4) input{width:70px}.btn-icon{width:28px;height:28px;padding:0;border:none;background:var(--bg);color:var(--text-muted);border-radius:var(--radius-sm);font-size:1.2rem;line-height:1;cursor:pointer}.btn-icon:hover{background:var(--border);color:var(--text)}.doc-view-actions{margin-top:16px}.doc-preview-inner{max-height:75vh;overflow-y:auto;overflow-x:auto;padding:16px;border:1px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);font-size:11pt}.doc-classic-wrap .doc-classic-title{font-size:1.1rem;font-weight:700;margin-bottom:10px;text-align:center}.doc-classic-wrap .doc-classic-note{font-size:.9rem;color:var(--text-muted);margin-bottom:10px}.doc-classic-wrap .doc-classic-req{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:.85rem}.doc-classic-wrap .doc-classic-req-label{width:120px;vertical-align:top;font-weight:600;color:var(--text-muted);padding-right:8px}.doc-classic-wrap .doc-classic-table{width:100%;border-collapse:collapse;margin-bottom:12px;font-size:.85rem}.doc-classic-wrap .doc-classic-table th,.doc-classic-wrap .doc-classic-table td{border:1px solid var(--border);padding:6px 8px;text-align:left}.doc-classic-wrap .doc-classic-table th{background:var(--bg);font-weight:600}.doc-classic-wrap .doc-classic-total{font-weight:600;margin:10px 0}.doc-classic-wrap .doc-classic-sig{margin-top:20px;font-size:.9rem}@media(max-width:900px){.doc-view-grid{grid-template-columns:1fr}}@media(max-width:768px){.doc-view.container{padding:16px}.doc-line-table td:nth-child(2) input,.doc-line-table td:nth-child(4) input{width:100%}}.history-view.container{max-width:1200px;margin:0 auto;padding:24px}.history-header{margin-bottom:20px}.history-header h2{font-size:1.1rem;font-weight:600;margin-bottom:4px}.history-meta{font-size:.85rem;color:var(--text-muted)}.history-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.history-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.history-item-info{flex:1;min-width:200px}.history-item-title{font-weight:600;font-size:.95rem;margin-bottom:2px}.history-item-meta{font-size:.8rem;color:var(--text-muted)}.history-item-actions{display:flex;gap:8px;flex-wrap:wrap}.history-empty{text-align:center;padding:48px 24px;color:var(--text-muted);font-size:.95rem}.history-loading{text-align:center;padding:24px;color:var(--text-muted)}.history-error{padding:16px;background:#fee2e2;color:#991b1b;border-radius:var(--radius-sm);margin-bottom:16px}.btn-sm{padding:6px 12px;font-size:.8rem}.toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%) translateY(80px);z-index:9999;padding:14px 24px;border-radius:var(--radius);font-size:.9rem;font-weight:500;opacity:0;visibility:hidden;transition:transform .25s ease,opacity .25s ease,visibility .25s;box-shadow:0 4px 20px #00000026;max-width:90vw}.toast[role=alert]{animation:toastIn .3s ease forwards}@keyframes toastIn{to{transform:translate(-50%) translateY(0);opacity:1;visibility:visible}}.toast-success{background:#d1fae5;color:#065f46}.toast-error{background:#fee2e2;color:#991b1b}.card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:20px;box-shadow:var(--shadow)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border)}.card-header h2{font-size:.95rem;font-weight:600;color:var(--text)}.badge{font-size:.7rem;color:var(--text-muted);font-weight:500}.form-group{margin-bottom:12px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-group label{display:block;font-size:.8rem;font-weight:500;color:var(--text-muted);margin-bottom:4px}.form-group input,.form-group select,.form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;background:var(--surface)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px #3b82f626}.button-row{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.button-row .btn{flex:1;min-width:100px}.btn{padding:10px 16px;border:none;border-radius:var(--radius-sm);font-size:.875rem;font-weight:500;display:inline-flex;align-items:center;justify-content:center;gap:6px;background:var(--primary);color:#fff;transition:background .2s;text-decoration:none}.btn:hover:not(:disabled){background:var(--primary-hover)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--bg)}.btn-success{background:var(--success)}.btn-pdf{background:#b91c1c}.btn-pdf:hover:not(:disabled){background:#991b1b}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}@media(max-width:640px){.form-row{grid-template-columns:1fr}.button-row .btn{min-width:auto}}@media(max-width:768px){.card{padding:16px}.card-header h2{font-size:.9rem}.form-group input,.form-group select,.form-group textarea{padding:12px 14px;font-size:16px;min-height:48px}.button-row .btn{min-height:48px;padding:12px 16px}}@media(max-width:480px){.card{padding:12px;border-radius:8px}.card-header{margin-bottom:12px;padding-bottom:10px}.form-group{margin-bottom:10px}.button-row{flex-direction:column;gap:8px;margin-top:12px}.button-row .btn{width:100%;min-height:48px}}.contract-preview .contract-content{color:#1a1a1a}.contract-preview .doc-header-block{margin-bottom:16px}.contract-preview .doc-title{font-weight:700;text-align:center;margin-bottom:4px}.contract-preview .doc-subtitle{text-align:center;margin-bottom:0;font-size:.95em}.contract-preview .doc-block{margin-bottom:6px}.contract-preview .doc-date{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.contract-preview .doc-date-value{text-align:right}.contract-preview .doc-section{font-weight:700;margin-top:14px;margin-bottom:6px}.contract-preview .doc-req-line{margin:2px 0}.contract-preview .doc-req-line b{font-weight:700}.contract-preview .doc-req-cols{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-top:12px}.contract-preview .doc-req-col{border:1px solid #e0e0e0;padding:12px;border-radius:6px}.contract-preview .doc-req-col-header{font-weight:700;margin-bottom:8px;padding-bottom:6px;border-bottom:1px solid #ddd}.contract-preview .doc-block.doc-intro .doc-intro-party{margin-bottom:1em;padding-bottom:1em;border-bottom:1px solid #e5e7eb}.contract-preview .doc-block.doc-intro .doc-intro-party:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.contract-preview .doc-sign-block{margin-top:24px}.contract-preview .doc-sign{margin-top:24px;padding-top:16px;border-top:1px dashed #999}.contract-preview .doc-sig-line{margin-top:14px}.contract-style-wrapper-classic .contract-content{padding:0}.contract-style-wrapper-creative .contract-content{padding:0;position:relative}.contract-style-wrapper-creative .contract-preview{border-radius:12px;overflow-x:auto;overflow-y:auto;box-shadow:0 4px 24px #0f172a14;border:1px solid #e2e8f0}.contract-style-wrapper-creative .contract-preview:before{content:"";display:block;height:6px;background:linear-gradient(90deg,#0f172a,#1e3a5f,#2563eb,#1e3a5f,#0f172a)}.contract-style-wrapper-creative .doc-header-block{text-align:center;padding:24px 20px 28px;margin-bottom:0;background:linear-gradient(180deg,#f8fafc,#fff);border-bottom:3px solid #2563eb}.contract-style-wrapper-creative .doc-title{font-size:1.35em;letter-spacing:.02em;color:#0f172a;font-weight:800;margin-bottom:6px}.contract-style-wrapper-creative .doc-subtitle{color:#475569;font-size:.95em;font-weight:500}.contract-style-wrapper-creative .doc-date{margin:16px 20px 24px;padding:14px 20px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border-radius:10px;border:1px solid #93c5fd}.contract-style-wrapper-creative .doc-date-value{font-weight:700;color:#1e40af}.contract-style-wrapper-creative .doc-block{margin:0 20px 20px;padding:22px 24px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 1px 4px #0000000a}.contract-style-wrapper-creative .doc-block:nth-child(odd){background:#fafbff}.contract-style-wrapper-creative .doc-block.doc-intro{background:linear-gradient(135deg,#eff6ff,#e0e7ff);border-color:#a5b4fc}.contract-style-wrapper-creative .doc-block .doc-section{margin:0 0 14px;padding:0 0 10px;border:none;border-bottom:3px solid #2563eb;background:none;font-size:1.05em;display:inline-block;color:#0f172a;font-weight:800}.contract-style-wrapper-creative .doc-block .doc-section:before{content:"";display:inline-block;width:10px;height:10px;background:#2563eb;border-radius:50%;margin-right:12px;vertical-align:middle}.contract-style-wrapper-creative .doc-req-cols{margin:0 20px 24px;gap:0;border:none;border-radius:12px;overflow:hidden;box-shadow:0 4px 16px #0000000f;border:1px solid #e2e8f0}.contract-style-wrapper-creative .doc-req-col{border:none;border-radius:0;padding:24px;background:#f8fafc}.contract-style-wrapper-creative .doc-req-col:first-child{border-right:3px solid #2563eb;background:linear-gradient(135deg,#f0f9ff,#e0f2fe)}.contract-style-wrapper-creative .doc-req-col-header{font-size:.95em;color:#0f172a;border-bottom:2px solid #2563eb;padding-bottom:12px;margin-bottom:16px;font-weight:800}.contract-style-wrapper-minimal .contract-content{padding:0}.contract-style-wrapper-minimal .contract-preview{background:#fafafa;border-color:#e5e5e5}.contract-style-wrapper-minimal .doc-header-block{text-align:center;padding:24px 0 28px;margin-bottom:28px;border-bottom:1px solid #e5e5e5}.contract-style-wrapper-minimal .doc-title{font-size:1.1em;font-weight:700;color:#171717;letter-spacing:.02em}.contract-style-wrapper-minimal .doc-subtitle{color:#737373;font-size:.9em;margin-top:4px}.contract-style-wrapper-minimal .doc-date{margin:0 0 24px;padding:14px 20px;background:#fff;border-radius:6px;border:1px solid #e5e5e5}.contract-style-wrapper-minimal .doc-date-value{font-weight:500;color:#171717}.contract-style-wrapper-minimal .doc-block{margin-bottom:24px;padding:20px 24px;border-radius:8px;border:1px solid #e5e5e5;background:#fff}.contract-style-wrapper-minimal .doc-block.doc-intro{background:#fff;border-color:#e5e5e5}.contract-style-wrapper-minimal .doc-block .doc-section{margin:0 0 10px;padding:0;border:none;font-size:.95em;color:#171717}.contract-style-wrapper-minimal .doc-req-cols{margin-top:16px;gap:0;border-radius:8px;overflow:hidden;border:1px solid #e5e5e5}.contract-style-wrapper-minimal .doc-req-col{border:none;border-radius:0;padding:20px 24px;background:#fff;border-bottom:1px solid #e5e5e5}.contract-style-wrapper-minimal .doc-req-col:last-of-type{border-bottom:none}.contract-style-wrapper-minimal .doc-req-cols{grid-template-columns:1fr 1fr}.contract-style-wrapper-minimal .doc-req-col-header{font-size:.9em;color:#404040;border-bottom:1px solid #e5e5e5;padding-bottom:8px;margin-bottom:12px}.contract-style-wrapper-minimal .doc-sign-block{margin-top:28px;padding:20px 24px;border-radius:8px;background:#fff;border:1px solid #e5e5e5}.contract-style-wrapper-minimal .doc-sign{margin-top:0;padding-top:12px;border-top:none}@media(max-width:640px){.contract-preview .doc-req-cols{grid-template-columns:1fr}}@media(max-width:768px){.contract-style-wrapper-creative .doc-header-block{padding:16px 12px 20px}.contract-style-wrapper-creative .doc-date{margin:12px 12px 16px;padding:10px 14px}.contract-style-wrapper-creative .doc-block{margin:0 12px 14px;padding:14px 16px}.contract-style-wrapper-creative .doc-req-cols{margin:0 12px 16px}.contract-style-wrapper-creative .doc-req-col{padding:16px}.contract-style-wrapper-creative .doc-req-col:first-child{border-right:none;border-bottom:3px solid #2563eb}}@media(max-width:480px){.contract-style-wrapper-creative .doc-header-block{padding:12px 10px 16px}.contract-style-wrapper-creative .doc-title{font-size:1.15em}.contract-style-wrapper-creative .doc-date{margin:10px 10px 12px;padding:8px 12px}.contract-style-wrapper-creative .doc-block{margin:0 10px 12px;padding:12px 14px}.contract-style-wrapper-creative .doc-block .doc-section{font-size:1em}.contract-style-wrapper-creative .doc-req-cols{margin:0 10px 14px}.contract-style-wrapper-creative .doc-req-col{padding:12px}.contract-style-wrapper-creative .doc-req-col-header{font-size:.9em;padding-bottom:8px;margin-bottom:12px}}
