:root{--bg:#f5f7fb;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--primary:#23e4ef;--primary-dark:#16b8c1;--primary-text:#0a4f53;--danger:#dc2626;--success:#16a34a;--warning:#d97706;--shadow:0 4px 14px #0f172a0f;--sidebar-w:250px;--sidebar-bg:#0c1a2e;--sidebar-hover:#23e4ef1a;--sidebar-active:#23e4ef2e;--radius:12px;--transition:0.2s ease}*{box-sizing:border-box}#root,body,html{background:#f5f7fb;background:var(--bg);color:#0f172a;color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Sans,Yu Gothic UI,Noto Sans JP,sans-serif;font-size:14px;height:100%;line-height:1.6;margin:0;padding:0}a{color:inherit;text-decoration:none}.app-layout{display:flex;min-height:100vh}.page{flex:1 1;max-width:1280px;min-width:0;padding:24px 32px;transition:max-width .25s ease}.sidebar.collapsed~.page{max-width:none}.center{align-items:center;color:#64748b;color:var(--muted);display:flex;justify-content:center;padding:32px}.page-header{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.page-header-text{flex:1 1;min-width:0}.page-title{color:#0f172a;color:var(--text);font-size:24px;font-weight:700;margin:0 0 4px}.page-desc{color:#64748b;color:var(--muted);font-size:14px;line-height:1.5;margin:0}.tip-banner{align-items:flex-start;background:linear-gradient(135deg,#f0fdfa,#ecfeff);border:1px solid #a7f3d0;border-left:4px solid #23e4ef;border-left:4px solid var(--primary);border-radius:12px;border-radius:var(--radius);color:#065f46;display:flex;font-size:13px;gap:10px;line-height:1.6;padding:12px 16px}.tip-banner svg{color:#0d9488;flex-shrink:0;margin-top:2px}.tip-banner strong{color:#064e3b}.tip-steps{gap:2px;margin:6px 0 0;padding-left:18px}.sidebar,.tip-steps{display:flex;flex-direction:column}.sidebar{background:#0c1a2e;background:var(--sidebar-bg);color:#e2e8f0;flex-shrink:0;overflow:hidden;position:relative;transition:width .25s ease;width:250px;width:var(--sidebar-w);z-index:10}.sidebar.collapsed{width:56px}.sidebar-header{align-items:center;border-bottom:1px solid #ffffff0f;display:flex;justify-content:space-between;min-height:56px;padding:16px 14px}.sidebar-logo{color:#23e4ef;color:var(--primary);font-size:15px;font-weight:700;letter-spacing:-.02em;overflow:hidden;white-space:nowrap}.collapsed .sidebar-logo{opacity:0;width:0}.sidebar-toggle{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px}.sidebar-toggle:hover{background:#23e4ef1a;background:var(--sidebar-hover);color:#fff}.sidebar-toggle svg{height:20px;width:20px}.sidebar-nav{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:12px 8px}.sidebar-link{align-items:center;background:none;border:none;border-radius:8px;color:#94a3b8;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;padding:10px;text-align:left;transition:background .15s,color .15s;white-space:nowrap;width:100%}.sidebar-link:hover{background:#23e4ef1a;background:var(--sidebar-hover);color:#fff}.sidebar-link.active{background:#23e4ef2e;background:var(--sidebar-active);color:#23e4ef;color:var(--primary)}.sidebar-link svg{flex-shrink:0;height:18px;width:18px}.sidebar-link span{overflow:hidden;transition:opacity .2s}.collapsed .sidebar-link span{opacity:0;width:0}.sidebar-section{color:#475569;font-size:10px;font-weight:600;letter-spacing:.08em;overflow:hidden;padding:16px 10px 4px;text-transform:uppercase;white-space:nowrap}.collapsed .sidebar-section{height:0;margin:0;opacity:0;padding:0}.sidebar-footer{align-items:center;border-top:1px solid #ffffff0f;display:flex;gap:10px;padding:12px 10px}.sidebar-user{flex:1 1;min-width:0;overflow:hidden}.sidebar-user-name{color:#e2e8f0;font-size:13px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sidebar-user-role{color:#23e4ef;color:var(--primary);font-size:11px}.collapsed .sidebar-user{opacity:0;width:0}.sidebar-avatar{background:linear-gradient(135deg,#23e4ef,#16b8c1);background:linear-gradient(135deg,var(--primary),#16b8c1);border-radius:50%;color:#0a4f53;font-size:13px;font-weight:700;height:32px;justify-content:center;width:32px}.sidebar-avatar,.sidebar-logout{align-items:center;display:flex;flex-shrink:0}.sidebar-logout{background:none;border:none;border-radius:6px;color:#64748b;cursor:pointer;padding:6px}.sidebar-logout:hover{background:#dc262626;color:#ef4444}.sidebar-logout svg{height:18px;width:18px}.collapsed .sidebar-logout{display:none}.card{background:#fff;background:var(--card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 14px #0f172a0f;box-shadow:var(--shadow);padding:20px 24px}.card+.card{margin-top:16px}.card-header{align-items:center;display:flex;gap:12px;justify-content:space-between;margin-bottom:16px}.card-header h2{font-size:17px;margin:0}.stack{gap:16px}.stack,.stack-sm{display:flex;flex-direction:column}.stack-sm{gap:8px}h1,h2,h3{margin:0 0 12px}.empty-state{align-items:center;color:#64748b;color:var(--muted);display:flex;flex-direction:column;gap:8px;padding:40px 20px;text-align:center}.empty-state svg{color:#cbd5e1}.empty-state p{font-weight:500;margin:0}.stat-chips{display:flex;flex-wrap:wrap;gap:6px}.stat-chip{align-items:center;border-radius:999px;display:inline-flex;font-size:12px;font-weight:600;gap:5px;padding:4px 10px}.stat-chip-num{font-size:14px;font-weight:800}label{display:block;font-weight:500;margin:8px 0}.label-text{color:#334155;font-size:13px;font-weight:600}label input,label select,label textarea{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:inherit;display:block;font-family:inherit;font-size:14px;margin-top:4px;padding:9px 12px;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition),box-shadow var(--transition);width:100%}label input:focus,label select:focus,label textarea:focus{border-color:#23e4ef;border-color:var(--primary);box-shadow:0 0 0 3px #23e4ef26;outline:none}label input::placeholder,label textarea::placeholder{color:#94a3b8}textarea{resize:vertical}label.checkbox{align-items:center;display:flex;font-weight:500;gap:8px}label.checkbox input{margin:0;width:auto}.inline-select{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;padding:4px 8px}.filter-select,.inline-select{background:#fff;cursor:pointer;font-family:inherit;font-size:13px}.filter-select{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;padding:6px 10px}.grid-2{grid-gap:12px;grid-template-columns:1fr 1fr}.grid-2,.grid-3{display:grid;gap:12px}.grid-3{grid-gap:12px;align-items:end;grid-template-columns:repeat(3,1fr)}.form-actions{align-items:end;display:flex}.btn{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;color:#0f172a;color:var(--text);cursor:pointer;display:inline-flex;font-size:13px;font-weight:500;gap:4px;justify-content:center;padding:8px 16px;transition:background .2s ease,border-color .2s ease,box-shadow .2s ease;transition:background var(--transition),border-color var(--transition),box-shadow var(--transition)}.btn:hover{background:#f1f5f9}.btn:disabled{cursor:not-allowed;opacity:.6}.btn-primary{background:#23e4ef;background:var(--primary);border-color:#23e4ef;border-color:var(--primary);color:#0a4f53;color:var(--primary-text);font-weight:600}.btn-primary:hover{background:#16b8c1;background:var(--primary-dark);border-color:#16b8c1;border-color:var(--primary-dark)}.btn-secondary{background:#0ea5e9;border-color:#0284c7;color:#fff}.btn-secondary:hover{background:#0284c7}.btn-danger{background:#dc2626;background:var(--danger);border-color:#dc2626;border-color:var(--danger);color:#fff}.btn-danger:hover{background:#b91c1c}.btn-ghost{background:#0000;border-color:#ffffff1a;color:#94a3b8}.btn-ghost:hover{background:#ffffff0f;color:#fff}.btn-small{border-radius:6px;font-size:12px;padding:5px 10px}.btn-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.small-gap{gap:4px}.table{border-collapse:collapse;font-size:13px;width:100%}.table td,.table th{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);padding:10px 12px;text-align:left;vertical-align:top}.table th{background:#f8fafc;color:#475569;font-size:12px;font-weight:600;letter-spacing:.03em;text-transform:uppercase}.table td.wrap{max-width:380px;white-space:pre-wrap}.table td.nowrap{white-space:nowrap}.table tbody tr{transition:background .2s ease;transition:background var(--transition)}.table tbody tr:hover{background:#f8fafc}.table-link{color:#0369a1;font-weight:500}.table-link:hover{text-decoration:underline}.table-toolbar{align-items:center;display:flex;gap:12px;margin-bottom:12px}.row-disabled{opacity:.5}.login-wrap{align-items:center;background:linear-gradient(135deg,#0c1a2e,#132740 50%,#0e2a4a);display:flex;justify-content:center;min-height:100vh;overflow:hidden;position:relative}.login-wrap:before{background:radial-gradient(circle,#23e4ef14 0,#0000 70%);border-radius:50%;content:"";height:800px;pointer-events:none;position:absolute;right:-30%;top:-50%;width:800px}.login-container{align-items:center;display:flex;flex-direction:column;gap:24px;max-width:440px;padding:0 16px;width:100%;z-index:1}.login-brand{color:#e2e8f0;text-align:center}.login-brand-icon{align-items:center;background:#23e4ef1a;border:1px solid #23e4ef33;border-radius:20px;display:inline-flex;height:72px;justify-content:center;margin-bottom:16px;width:72px}.login-brand-icon svg{color:#23e4ef;color:var(--primary)}.login-brand h1{color:#fff;font-size:22px;font-weight:700;margin:0 0 8px;white-space:nowrap}.login-brand p{color:#94a3b8;font-size:14px;line-height:1.6;margin:0}.login-card{width:100%}.login-title{color:#0f172a;color:var(--text);font-size:18px;font-weight:700;margin:0 0 4px}.login-subtitle{font-size:13px;margin:0 0 8px}.login-btn{font-size:14px;margin-top:8px;padding:10px;width:100%}.login-footer{text-align:center}.login-footer p{color:#64748b;font-size:12px;margin:0}.error{background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;color:var(--danger);font-size:13px;padding:8px 12px}.muted{color:#64748b;color:var(--muted)}.small{font-size:12px}.row-between{gap:12px;justify-content:space-between}.modal-overlay,.row-between{align-items:center;display:flex}.modal-overlay{animation:fade-in .15s ease;background:#00000080;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal-content{animation:modal-in .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #0003;display:flex;flex-direction:column;max-height:80vh;max-width:600px;width:100%}@keyframes modal-in{0%{opacity:0;transform:translateY(12px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-header{align-items:center;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px}.modal-header h2{font-size:18px;margin:0}.modal-close{background:none;border:none;border-radius:6px;color:#64748b;color:var(--muted);cursor:pointer;font-size:20px;line-height:1;padding:4px 8px}.modal-close:hover{background:#f1f5f9;color:#0f172a;color:var(--text)}.modal-body{overflow-y:auto;padding:20px 24px}.guide-modal{animation:modal-in .2s ease;background:#fff;border-radius:16px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;max-height:88vh;max-width:780px;width:100%}.guide-modal-header{align-items:flex-start;border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;padding:20px 24px 16px}.guide-modal-header h2{font-size:18px;margin:0 0 2px}.guide-modal-nav{border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--border);display:flex;gap:2px;overflow-x:auto;padding:0 24px}.guide-nav-item{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#64748b;color:var(--muted);cursor:pointer;display:flex;font-family:inherit;font-size:12px;font-weight:500;gap:6px;padding:10px 12px;transition:all .15s;white-space:nowrap}.guide-nav-item:hover{color:#0f172a;color:var(--text)}.guide-nav-item.active{border-bottom-color:#23e4ef;border-bottom-color:var(--primary);color:#0a4f53;color:var(--primary-text)}.guide-nav-num{align-items:center;background:#e2e8f0;border-radius:50%;color:#475569;display:inline-flex;font-size:11px;font-weight:700;height:20px;justify-content:center;width:20px}.guide-nav-item.active .guide-nav-num{background:#23e4ef;background:var(--primary);color:#0a4f53;color:var(--primary-text)}.guide-modal-body{flex:1 1;overflow-y:auto;padding:24px}.guide-detail{grid-gap:24px;align-items:start;display:grid;gap:24px;grid-template-columns:1fr 1fr}.guide-detail-badge{background:#e0f2fe;border-radius:999px;color:#0369a1;display:inline-block;font-size:11px;font-weight:600;margin-bottom:8px;padding:2px 10px}.guide-detail-text h3{color:#0f172a;font-size:18px;font-weight:700;margin:0 0 8px}.guide-detail-desc{color:#475569;font-size:14px;line-height:1.6;margin:0 0 16px}.guide-detail-list{display:flex;flex-direction:column;gap:10px;list-style:none;margin:0;padding:0}.guide-detail-list li{align-items:flex-start;color:#334155;display:flex;font-size:13px;gap:10px;line-height:1.5}.guide-bullet-num{align-items:center;background:linear-gradient(135deg,#23e4ef,#16b8c1);background:linear-gradient(135deg,var(--primary),#16b8c1);border-radius:50%;color:#0a4f53;color:var(--primary-text);display:inline-flex;flex-shrink:0;font-size:11px;font-weight:700;height:22px;justify-content:center;width:22px}.guide-modal-footer{align-items:center;border-top:1px solid #e2e8f0;border-top:1px solid var(--border);display:flex;justify-content:space-between;padding:14px 24px}.gi-frame{background:#f8fafc;border:1px solid #d1d5db;border-radius:8px;box-shadow:0 2px 8px #0000000f;overflow:hidden}.gi-titlebar{align-items:center;background:#e2e8f0;display:flex;height:18px;justify-content:space-between;padding:4px 8px}.gi-dots{display:flex;gap:3px}.gi-dots span{background:#94a3b8;border-radius:50%;height:6px;width:6px}.gi-dots span:first-child{background:#ef4444}.gi-dots span:nth-child(2){background:#f59e0b}.gi-dots span:last-child{background:#22c55e}.gi-titlebar-text{color:#475569;font-size:7px;font-weight:600}.gi-body{padding:6px}.gi-row{display:flex;gap:6px}.gi-sidebar-mini{background:#0c1a2e;border-radius:4px;display:flex;flex-direction:column;gap:3px;padding:4px 3px;width:24px}.gi-sb-item{background:#ffffff1a;border-radius:2px;height:6px}.gi-sb-item.active{background:#23e4ef4d}.gi-main{display:flex;flex:1 1;flex-direction:column;gap:4px;min-width:0}.gi-card{background:#fff;border:1px solid #e2e8f0;border-radius:4px;padding:6px}.gi-label{color:#0f172a;font-size:7px;font-weight:700;margin-bottom:4px}.gi-label.small{font-size:6px}.gi-bar{background:#e2e8f0;border-radius:2px;height:4px;margin-bottom:3px}.gi-bar.short{height:3px}.gi-bar.highlighted{background:#23e4ef80;position:relative}.gi-btn-row{display:flex;gap:3px;margin-top:4px}.gi-btn{background:#e2e8f0;border-radius:3px;color:#475569;display:inline-block;font-size:6px;font-weight:600;padding:2px 6px}.gi-btn.accent{background:#23e4ef;background:var(--primary);color:#0a4f53;color:var(--primary-text)}.gi-btn.blue{background:#0ea5e9;color:#fff}.gi-btn-mini{background:#e2e8f0;border-radius:2px;color:#475569;font-size:5px;margin-left:auto;padding:1px 4px}.gi-btn-mini.accent{background:#23e4ef;background:var(--primary);color:#0a4f53;color:var(--primary-text)}.gi-table-row{align-items:center;border-bottom:1px solid #f1f5f9;color:#475569;display:flex;font-size:6px;gap:4px;padding:3px 0}.gi-chip-row{display:flex;gap:3px;margin-bottom:4px}.gi-chip{border-radius:999px;font-size:5px;font-weight:700;padding:1px 5px}.gi-chip.red{background:#fee2e2;color:#b91c1c}.gi-chip.yellow{background:#fef3c7;color:#a16207}.gi-chip.green{background:#dcfce7;color:#166534}.gi-badge{border-radius:50%;flex-shrink:0;height:6px;width:6px}.gi-badge.red{background:#ef4444}.gi-badge.yellow{background:#f59e0b}.gi-badge.green{background:#22c55e}.gi-search-mock{height:10px;margin-bottom:4px}.gi-input-mock,.gi-search-mock{background:#fff;border:1px solid #d1d5db;border-radius:3px}.gi-input-mock{height:8px;margin-bottom:3px}.gi-dropzone{align-items:center;border:1.5px dashed #94a3b8;border-radius:4px;gap:3px;padding:8px 4px}.gi-dropzone,.gi-preview-mock{display:flex;flex-direction:column}.gi-preview-mock{gap:4px;min-height:100px}.gi-highlight-area{padding:2px 0;position:relative}.gi-tooltip-mock{background:#23e4ef;background:var(--primary);border-radius:3px;box-shadow:0 1px 4px #00000026;color:#0a4f53;color:var(--primary-text);font-size:5px;font-weight:700;padding:2px 5px;position:absolute;right:0;top:-8px;white-space:nowrap}.gi-cursor-icon{bottom:18px;position:absolute;right:28px}.gi-comment-mock{background:#fff;border:1px solid #e2e8f0;border-radius:3px;height:14px;margin-bottom:2px}.gi-download-arrow{animation:bounce-down 1.2s ease infinite;bottom:8px;left:45px;position:absolute}@keyframes bounce-down{0%,to{transform:translateY(0)}50%{transform:translateY(3px)}}@media (max-width:700px){.guide-detail{grid-template-columns:1fr}.guide-modal{max-width:calc(100% - 32px)}.guide-nav-item{padding:8px}.guide-nav-label{display:none}}.latest-hero{align-items:flex-start;display:flex;gap:16px;justify-content:space-between}.latest-title{font-size:20px;font-weight:600}.latest-actions{flex-shrink:0}.meta{color:#64748b;color:var(--muted);display:flex;flex-wrap:wrap;font-size:13px;gap:16px;margin-top:4px}.preview-layout{grid-gap:12px;align-items:stretch;display:grid;gap:12px;grid-template-columns:380px 1fr;height:calc(100vh - 80px);transition:grid-template-columns .25s ease}.sidebar.collapsed~.page .preview-layout{grid-template-columns:420px 1fr}.preview-side{display:flex;flex-direction:column;gap:8px;min-height:0}.preview-main{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 14px #0f172a0f;box-shadow:var(--shadow);overflow:hidden}.pside-top{display:flex;flex:0 0 auto;flex-direction:column;max-height:50%;overflow:hidden;padding:0!important}.pside-doc-info{flex-shrink:0;padding:12px 16px 8px}.pside-title{font-size:15px;font-weight:700;line-height:1.3;margin:0 0 4px}.pside-section-title{align-items:baseline;color:#0c4a6e;display:flex;font-size:13px;font-weight:700;margin:0 0 6px}.pside-form-area{border-top:1px solid #e2e8f0;border-top:1px solid var(--border);flex-shrink:0;min-height:0;overflow-y:auto;padding:10px 16px 12px}.pside-form,.pside-form-area{display:flex;flex-direction:column}.pside-form{gap:6px}.pside-form-submit{align-items:center;background:#fff;background:var(--card);bottom:0;display:flex;gap:8px;justify-content:space-between;padding:6px 0 0;position:sticky;z-index:2}.pside-input{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:13px;padding:6px 10px;transition:border-color .2s ease;transition:border-color var(--transition);width:100%}.pside-input:focus{border-color:#23e4ef;border-color:var(--primary);box-shadow:0 0 0 3px #23e4ef1f;outline:none}.pside-textarea{border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;box-sizing:border-box;font-family:inherit;font-size:13px;min-height:44px;padding:6px 10px;resize:vertical;transition:border-color .2s ease;transition:border-color var(--transition);width:100%}.pside-textarea:focus{border-color:#23e4ef;border-color:var(--primary);box-shadow:0 0 0 3px #23e4ef1f;outline:none}.pside-bottom{display:flex;flex:1 1;flex-direction:column;min-height:0;overflow-y:auto;padding:12px 14px!important}.pside-list-header{align-items:center;display:flex;flex-wrap:wrap;gap:8px;margin-bottom:6px}.selected-quote.compact{border-radius:6px;font-size:12px;padding:6px 10px}.selected-quote.compact .selected-quote-text{font-size:11px;max-height:48px;overflow:hidden;text-overflow:ellipsis}.pdf-annotator{background:#525659;height:100%;overflow:auto;position:relative}.pdf-pages{align-items:center;display:flex;flex-direction:column;gap:8px;padding:16px}.pdf-page{background:#fff;box-shadow:0 2px 8px #0000002e;position:relative}.pdf-page canvas{display:block}.pdf-text-layer{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;forced-color-adjust:none;left:0;line-height:1;opacity:1;position:absolute;top:0;transform-origin:0 0;-webkit-user-select:text;user-select:text;z-index:2}.pdf-text-layer br,.pdf-text-layer span{color:#0000;cursor:text;line-height:1;position:absolute;transform-origin:0 0;white-space:pre}.pdf-text-layer ::selection{background:#23e4ef66}.pdf-text-layer ::-moz-selection{background:#23e4ef66}.pdf-tooltip{animation:tooltip-in .15s ease;position:absolute;transform:translateX(-50%);z-index:20}@keyframes tooltip-in{0%{opacity:0;transform:translateX(-50%) translateY(4px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}.pdf-tooltip-btn{align-items:center;box-shadow:0 4px 12px #00000040;display:flex;gap:6px;white-space:nowrap}.pdf-hl{background:#ffd54f66;border-radius:2px;mix-blend-mode:multiply;transition:background .2s}.pdf-hl.active{background:#23e4ef80}.selected-quote{background:#fffbeb;border:1px solid #fde68a;border-left:3px solid #f59e0b;border-radius:8px;font-size:13px;padding:10px 12px}.selected-quote-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:6px}.selected-quote-header span{color:#92400e;font-size:12px;font-weight:600}.selected-quote-close{background:none;border:none;border-radius:4px;color:#92400e;cursor:pointer;font-size:16px;line-height:1;padding:0 4px}.selected-quote-close:hover{background:#92400e1a}.selected-quote-text{color:#78350f;font-size:12px;line-height:1.5;white-space:pre-wrap}.comment-filters{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}.comment-search{align-items:center;background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;display:flex;gap:6px;padding:6px 10px;transition:border-color .2s ease,box-shadow .2s ease;transition:border-color var(--transition),box-shadow var(--transition)}.comment-search:focus-within{border-color:#23e4ef;border-color:var(--primary);box-shadow:0 0 0 3px #23e4ef26}.comment-search svg{color:#64748b;color:var(--muted);flex-shrink:0}.comment-search-input{background:#0000;border:none;color:#0f172a;color:var(--text);flex:1 1;font-family:inherit;font-size:13px;min-width:0;outline:none;padding:0}.comment-search-input::placeholder{color:#94a3b8}.comment-search-clear{background:none;border:none;border-radius:4px;color:#64748b;color:var(--muted);cursor:pointer;font-size:14px;line-height:1;padding:0 2px}.comment-search-clear:hover{color:#dc2626;color:var(--danger)}.comment-filter-chips{display:flex;flex-wrap:wrap;gap:4px}.comment-filter-chip{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:999px;color:#64748b;color:var(--muted);cursor:pointer;font-size:11px;font-weight:600;padding:4px 10px;transition:all .15s}.comment-filter-chip:hover{border-color:#23e4ef;border-color:var(--primary);color:#16b8c1;color:var(--primary-dark)}.comment-filter-chip.active{background:#23e4ef;background:var(--primary);border-color:#23e4ef;border-color:var(--primary);color:#0a4f53;color:var(--primary-text)}.comment-filter-count{margin-bottom:4px}.comment-list{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.comment{background:#fff;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:8px;padding:10px 12px;transition:border-color .2s,box-shadow .2s}.comment.status-done{background:#f0fdf4;border-color:#bbf7d0}.comment.status-in_progress{background:#fffbeb;border-color:#fde68a}.comment.comment-active{border-color:#23e4ef;border-color:var(--primary);box-shadow:0 0 0 2px #23e4ef33}.comment-head{display:flex;gap:8px;justify-content:space-between;margin-bottom:4px}.comment-quote{background:#fffbeb;border-radius:4px;color:#78350f;font-size:12px;line-height:1.4;margin-bottom:6px;padding:4px 8px}.comment-page{background:#f59e0b;border-radius:3px;color:#fff;display:inline-block;font-size:10px;font-weight:700;margin-right:4px;padding:1px 5px;vertical-align:middle}.comment-body{font-size:13px;white-space:pre-wrap}.resolution{color:#15803d;font-size:12px;margin-top:4px}.status-badge{border-radius:999px;font-size:11px;font-weight:600;padding:3px 10px;white-space:nowrap}.st-open{background:#fee2e2;color:#b91c1c}.st-in_progress{background:#fef3c7;color:#a16207}.st-done{background:#dcfce7;color:#166534}.chip-row{display:flex;gap:8px}.chip{border-radius:999px;font-size:12px;font-weight:600;padding:4px 10px}.back-link{align-items:center;color:#16b8c1;color:var(--primary-dark);display:inline-flex;font-size:13px;font-weight:500;gap:4px;margin-top:12px}.back-link:hover{text-decoration:underline}.att-upload-area{align-items:center;display:flex;gap:8px}.att-upload-label{align-items:center;border:1px dashed #e2e8f0;border:1px dashed var(--border);border-radius:6px;color:#475569;cursor:pointer;display:inline-flex;font-size:12px;gap:4px;padding:4px 10px;transition:border-color .15s,background .15s}.att-upload-label:hover{background:#23e4ef0d;border-color:#23e4ef;border-color:var(--primary)}.att-count,.att-upload-label:hover{color:#16b8c1;color:var(--primary-dark)}.att-count{font-size:11px;font-weight:600}.att-pending-list{display:flex;flex-direction:column;gap:3px;list-style:none;margin:0;padding:0}.att-pending-item{align-items:center;background:#f8fafc;border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:6px;display:flex;font-size:12px;gap:6px;padding:3px 8px}.att-icon{flex-shrink:0;font-size:13px}.att-name{color:#334155;flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.att-size{color:#94a3b8;flex-shrink:0;font-size:11px}.att-remove{background:none;border:none;border-radius:4px;color:#94a3b8;cursor:pointer;font-size:14px;line-height:1;padding:0 2px;transition:color .15s}.att-remove:hover{color:#dc2626;color:var(--danger)}.att-list{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.att-chip{align-items:center;background:#eff6ff;border:1px solid #bfdbfe;border-radius:999px;color:#1e40af;cursor:pointer;display:inline-flex;font-size:11px;gap:4px;max-width:180px;padding:2px 8px;transition:background .15s,border-color .15s}.att-chip:hover{background:#dbeafe;border-color:#93c5fd}.att-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropzone{align-items:center;border:2px dashed #e2e8f0;border:2px dashed var(--border);border-radius:12px;border-radius:var(--radius);cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:36px 20px;text-align:center;transition:border-color .2s,background .2s}.dropzone:hover{background:#23e4ef08}.dropzone-active,.dropzone:hover{border-color:#23e4ef;border-color:var(--primary)}.dropzone-active{background:#23e4ef14}.dropzone-ready{background:#16a34a0a;border-color:#16a34a;border-color:var(--success)}.dropzone-icon{color:#64748b;color:var(--muted)}.dropzone-active .dropzone-icon{color:#23e4ef;color:var(--primary)}.dropzone-ready .dropzone-icon{color:#16a34a;color:var(--success)}.dropzone-text{display:flex;flex-direction:column;gap:4px}.dropzone-text strong{font-size:14px}.dropzone-text .muted,.json-preview{font-size:12px}.json-preview{background:#0f172a;border-radius:8px;color:#e2e8f0;line-height:1.5;max-height:360px;overflow:auto;padding:16px;white-space:pre-wrap}.doc-viewer{background:#f0f2f5;height:100%;overflow:auto;position:relative;-webkit-user-select:text;user-select:text}.doc-paper{background:#fff;border-radius:8px;box-shadow:0 2px 12px #00000014;color:#1e293b;font-family:Hiragino Sans,Yu Gothic UI,Noto Sans JP,-apple-system,sans-serif;font-size:14px;line-height:1.8;margin:24px auto;max-width:800px;padding:48px 56px}.doc-title-page{border-bottom:2px solid #e2e8f0;margin-bottom:40px;padding:60px 0 48px;text-align:center}.doc-main-title{color:#0f172a;font-size:26px;font-weight:700;letter-spacing:.04em;margin:0 0 12px}.doc-date{color:#64748b;font-size:15px;margin:0}.doc-section{border-top:1px solid #e2e8f0;margin-bottom:32px;padding-top:20px}.doc-section:first-of-type{border-top:none;padding-top:0}.doc-heading{border-bottom:2px solid #23e4ef;border-bottom:2px solid var(--primary);color:#0c4a6e;font-size:18px;font-weight:700;margin:0 0 16px;padding-bottom:8px}.doc-subheading{color:#1e40af;font-size:15px;font-weight:600;margin:20px 0 8px}.doc-para{margin:0 0 12px;text-align:justify;word-break:break-all}.doc-table{border-collapse:collapse;font-size:13px;margin:16px 0;width:100%}.doc-table td,.doc-table th{border:1px solid #d1d5db;padding:8px 12px;text-align:left;vertical-align:top}.doc-table th{background:#dbeafe;color:#1e3a5f;font-weight:600;white-space:nowrap}.doc-table tbody tr:nth-child(2n){background:#f8fafc}.doc-table tbody tr:hover{background:#eff6ff}.doc-highlight{background:#ffd54f59;border-bottom:2px solid #f59e0b99;border-radius:2px;mix-blend-mode:multiply;transition:background .2s}.doc-highlight.active{background:#23e4ef66;border-bottom-color:#23e4efcc}.doc-hl-indicator{align-items:center;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-bottom:1px solid #fde68a;color:#92400e;display:flex;font-size:12px;font-weight:600;gap:6px;padding:6px 16px;position:sticky;top:0;z-index:10}.doc-viewer ::selection{background:#23e4ef66}.doc-viewer ::-moz-selection{background:#23e4ef66}.toast-container{display:flex;flex-direction:column;gap:8px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:9999}.toast{align-items:center;animation:toast-in .3s ease;background:#fff;border-left:4px solid #e2e8f0;border-radius:10px;box-shadow:0 8px 30px #0000001f,0 2px 8px #0000000f;color:#0f172a;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:10px;max-width:420px;min-width:280px;padding:12px 16px;pointer-events:auto}.toast-success{border-left-color:#16a34a}.toast-success .toast-icon{color:#16a34a}.toast-error{border-left-color:#dc2626}.toast-error .toast-icon{color:#dc2626}.toast-info{border-left-color:#0ea5e9}.toast-info .toast-icon{color:#0ea5e9}.toast-exit{animation:toast-out .3s ease forwards}.toast-icon{flex-shrink:0}.toast-msg{flex:1 1}.toast-close{background:none;border:none;color:#94a3b8;cursor:pointer;font-size:14px;line-height:1;padding:0 2px}.toast-close:hover{color:#475569}@keyframes toast-in{0%{opacity:0;transform:translateX(40px) scale(.95)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes toast-out{0%{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(40px) scale(.95)}}.breadcrumb{align-items:center;color:#64748b;color:var(--muted);display:flex;font-size:12px;gap:4px;margin-bottom:8px}.breadcrumb a{color:#16b8c1;color:var(--primary-dark);text-decoration:none;transition:color .15s}.breadcrumb a:hover{text-decoration:underline}.breadcrumb-sep{color:#cbd5e1}.inline-hint{align-items:center;animation:hint-in .3s ease;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;color:#1e40af;display:flex;font-size:11px;gap:6px;line-height:1.4;margin-bottom:4px;padding:6px 10px}.inline-hint svg{color:#3b82f6;flex-shrink:0}.inline-hint-close{background:none;border:none;color:#93c5fd;cursor:pointer;flex-shrink:0;font-size:12px;margin-left:auto;padding:0 2px}.inline-hint-close:hover{color:#1e40af}@keyframes hint-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.pside-count-badge{align-items:center;background:#23e4ef;background:var(--primary);border-radius:999px;color:#0a4f53;color:var(--primary-text);display:inline-flex;font-size:11px;font-weight:700;height:20px;justify-content:center;margin-left:8px;min-width:20px;padding:0 6px}.comment-empty{align-items:center;color:#64748b;color:var(--muted);display:flex;flex-direction:column;font-size:13px;gap:6px;padding:20px 10px;text-align:center}.quick-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(4,1fr)}.quick-summary-card{background:#fff;background:var(--card);border:1px solid #e2e8f0;border:1px solid var(--border);border-radius:12px;border-radius:var(--radius);box-shadow:0 4px 14px #0f172a0f;box-shadow:var(--shadow);padding:16px;text-align:center;transition:transform .15s,box-shadow .15s}.quick-summary-card:hover{box-shadow:0 6px 20px #0f172a1a;transform:translateY(-2px)}.qs-num{font-size:28px;font-weight:800;line-height:1.2}.qs-label{font-size:12px;font-weight:600;margin-top:4px}.qs-open{border-top:3px solid #dc2626}.qs-open .qs-num{color:#dc2626}.qs-open .qs-label{color:#b91c1c}.qs-progress{border-top:3px solid #d97706}.qs-progress .qs-num{color:#d97706}.qs-progress .qs-label{color:#a16207}.qs-done{border-top:3px solid #16a34a}.qs-done .qs-num{color:#16a34a}.qs-done .qs-label{color:#166534}.qs-link{border-top:3px solid #23e4ef;border-top:3px solid var(--primary);cursor:pointer;text-decoration:none}.qs-link .qs-label,.qs-link .qs-num{color:#16b8c1;color:var(--primary-dark)}.login-particles{inset:0;overflow:hidden;pointer-events:none;position:absolute}.login-particle{background:#23e4ef0f;border-radius:50%;position:absolute}.p1{animation:float-1 20s ease-in-out infinite;height:600px;right:-15%;top:-20%;width:600px}.p2{animation:float-2 25s ease-in-out infinite;bottom:-10%;height:400px;left:-10%;width:400px}.p3{animation:float-3 18s ease-in-out infinite;background:#23e4ef0a;height:200px;left:30%;top:40%;width:200px}@keyframes float-1{0%,to{transform:translate(0) scale(1)}50%{transform:translate(-30px,20px) scale(1.05)}}@keyframes float-2{0%,to{transform:translate(0) scale(1)}50%{transform:translate(20px,-15px) scale(1.08)}}@keyframes float-3{0%,to{transform:translate(0)}50%{transform:translate(-20px,-20px)}}.login-container{animation:login-appear .6s ease}@keyframes login-appear{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.login-spinner{animation:spin .6s linear infinite;border:2.5px solid #0a4f534d;border-radius:50%;border-top:2.5px solid var(--primary-text);display:inline-block;height:18px;width:18px}@keyframes spin{to{transform:rotate(1turn)}}.card{transition:box-shadow .2s ease}.table tbody tr{transition:background .2s ease,transform .1s;transition:background var(--transition),transform .1s}@media (max-width:960px){.sidebar{height:100vh;left:0;position:fixed;top:0;z-index:100}.sidebar.collapsed{width:0}.page{padding:16px}.page-header{flex-direction:column}.preview-layout{grid-template-columns:1fr;height:auto}.preview-side,.pside-top{max-height:none}.pside-bottom{max-height:50vh}.preview-main{height:70vh;min-height:500px}.grid-2,.grid-3{grid-template-columns:1fr}.doc-paper{margin:12px;padding:24px 20px}.table-toolbar{flex-direction:column}.login-brand h1{font-size:18px}.quick-summary{grid-template-columns:repeat(2,1fr)}.toast-container{left:20px;right:20px}.toast{min-width:auto}}
/*# sourceMappingURL=main.041d6105.css.map*/