*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;color:#1a1a2e;background:#f6f7f9;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.layout{min-height:100vh;display:flex}.sidebar{background:#fff;border-right:1px solid #e5e7eb;flex-direction:column;width:240px;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-brand{border-bottom:1px solid #f3f4f6;padding:24px 20px 16px}.sidebar-brand h1{color:#1a1a2e;font-size:20px;font-weight:700}.sidebar-brand p{color:#9ca3af;margin-top:4px;font-size:13px}.sidebar-nav{flex:1;padding:12px;overflow-y:auto}.sidebar-nav a{color:#6b7280;border-radius:8px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s;display:block}.sidebar-nav a:hover{color:#1a1a2e;background:#f3f4f6}.sidebar-nav a.active{color:#2563eb;background:#eff6ff}.sidebar-user{border-top:1px solid #f3f4f6;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.user-info{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.user-avatar{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:14px;font-weight:700;display:flex}.user-details{min-width:0}.user-name{color:#1a1a2e;text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.user-role{color:#9ca3af;margin-top:1px;font-size:11px}.main{flex:1;max-width:calc(100vw - 240px);margin-left:240px;padding:32px}.page-title{color:#1a1a2e;margin-bottom:4px;font-size:24px;font-weight:700}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header .page-title{margin-bottom:0}.page-desc{color:#9ca3af;margin-bottom:24px;font-size:14px}.card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;margin-bottom:24px;padding:24px}.card-title{color:#1a1a2e;margin-bottom:16px;font-size:16px;font-weight:600}.card-title .optional{color:#9ca3af;margin-left:6px;font-size:12px;font-weight:400}.stats-grid{grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px;display:grid}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:24px}.stat-label{color:#9ca3af;margin-bottom:8px;font-size:13px}.stat-value{font-size:32px;font-weight:700}.stat-value.blue{color:#2563eb}.stat-value.green{color:#059669}.stat-value.purple{color:#7c3aed}.table-wrap{overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:14px}thead{background:#f9fafb}thead th{text-align:left;color:#9ca3af;text-transform:uppercase;white-space:nowrap;padding:12px 16px;font-size:12px;font-weight:600}tbody td{white-space:nowrap;border-top:1px solid #f3f4f6;padding:12px 16px}tbody tr:hover{background:#f9fafb}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:8px;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{color:#fff;background:#2563eb}.btn-primary:hover{background:#1d4ed8}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-secondary{color:#374151;background:#f3f4f6}.btn-secondary:hover{background:#e5e7eb}.btn-danger{color:#dc2626;background:0 0;padding:6px 12px;font-size:13px}.btn-danger:hover{background:#fef2f2}.btn-success{color:#fff;background:#059669}.btn-success:hover{background:#047857}.btn-orange{color:#fff;background:#f97316}.btn-orange:hover{background:#ea580c}.btn-sm{padding:6px 12px;font-size:13px}.btn-full{width:100%}.btn-link{color:#2563eb;cursor:pointer;background:0 0;border:none;padding:4px 0;font-size:13px;font-weight:500}.btn-link:hover{color:#1d4ed8;text-decoration:underline}.form-group{margin-bottom:16px}.form-label{color:#6b7280;margin-bottom:6px;font-size:13px;font-weight:500;display:block}.input{border:1px solid #d1d5db;border-radius:8px;outline:none;width:100%;padding:10px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.input:disabled{color:#9ca3af;background:#f9fafb}select.input{appearance:auto}.form-actions{gap:8px;margin-top:16px;display:flex}.upload-zone{text-align:center;cursor:pointer;border:2px dashed #d1d5db;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;padding:40px;transition:all .2s;display:flex}.upload-zone:hover{background:#f8faff;border-color:#2563eb}.upload-zone.drag-over{background:#eff6ff;border-color:#2563eb;transform:scale(1.01)}.upload-zone svg{color:#9ca3af;width:40px;height:40px;margin-bottom:12px}.upload-zone.small{padding:24px}.upload-text{color:#6b7280;font-size:14px}.upload-text.small{font-size:13px}.upload-hint{color:#9ca3af;margin-top:4px;font-size:12px}.icon-medium{font-size:32px}.icon-large{font-size:48px}.upload-page .mode-tabs{gap:8px;margin-bottom:24px;display:flex}.mode-tab{cursor:pointer;color:#6b7280;background:#fff;border:2px solid #e5e7eb;border-radius:10px;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .15s;display:flex}.mode-tab:hover{border-color:#93c5fd}.mode-tab.active{color:#2563eb;background:#eff6ff;border-color:#2563eb}.mode-icon{font-size:20px}.mode-label{font-size:14px}.processing-dot{background:#f59e0b;border-radius:50%;width:8px;height:8px;animation:1s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.upload-grid{grid-template-columns:1fr;gap:16px;margin-bottom:24px;display:grid}.upload-grid:has(.template-card){grid-template-columns:1fr 300px}@media (width<=900px){.upload-grid:has(.template-card){grid-template-columns:1fr}}.file-preview{text-align:center;padding:16px 0}.preview-image{border-radius:8px;max-height:240px;margin-bottom:12px;overflow:hidden}.preview-image img{object-fit:contain;max-width:100%;max-height:240px}.file-icon{flex-direction:column;align-items:center;gap:8px;padding:16px 0;display:flex}.file-name{color:#1a1a2e;font-size:14px;font-weight:500}.file-size{color:#9ca3af;font-size:12px}.btn-remove{color:#ef4444;cursor:pointer;background:0 0;border:none;border-radius:4px;margin-top:8px;padding:4px 8px;font-size:13px}.btn-remove:hover{background:#fef2f2}.template-info{align-items:center;gap:12px;padding:8px 0;display:flex}.template-detail{flex-direction:column;flex:1;gap:2px;display:flex}.btn-submit{margin-bottom:24px;padding:14px;font-size:16px;font-weight:600}.spinner-inline{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.6s linear infinite spin;display:inline-block}.spinner-inline.small{border-width:1.5px;border-color:#2563eb #2563eb4d #2563eb4d;width:12px;height:12px}.progress-card{margin-bottom:24px}.progress-steps{flex-direction:column;gap:8px;display:flex}.step{background:#f9fafb;border-radius:8px;align-items:center;gap:8px;padding:8px 12px;font-size:14px;display:flex}.step-done{color:#059669;background:#ecfdf5}.step-error{color:#dc2626;background:#fef2f2}.step-active{color:#2563eb;background:#eff6ff}.result-card{margin-top:0}.result-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.result-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px;display:grid}.result-item{background:#f9fafb;border-radius:8px;padding:12px 16px}.result-item.highlight{background:#eff6ff;border:1px solid #bfdbfe}.result-item.highlight.success{background:#ecfdf5;border-color:#a7f3d0}.result-item .result-label{color:#6b7280;margin-bottom:4px;font-size:12px;display:block}.result-item .result-value{color:#1a1a2e;font-size:18px;font-weight:700}.result-actions{gap:8px;margin-top:16px;display:flex}.alert{border-radius:8px;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;font-size:14px;display:flex}.alert button{cursor:pointer;opacity:.6;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:16px}.alert button:hover{opacity:1}.alert-error{color:#dc2626;background:#fef2f2;border:1px solid #fecaca}.alert-success{color:#059669;background:#ecfdf5;border:1px solid #a7f3d0}.create-form{grid-template-columns:1fr 1fr;gap:16px;display:grid}.create-form .form-actions{grid-column:1/-1}@media (width<=600px){.create-form{grid-template-columns:1fr}}.tabs{gap:8px;margin-bottom:24px;display:flex}.tab{cursor:pointer;color:#6b7280;background:#f3f4f6;border:none;border-radius:8px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s}.tab.active{color:#fff;background:#2563eb}.spinner{justify-content:center;align-items:center;padding:64px;display:flex}.spinner:after{content:"";border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;width:32px;height:32px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.empty{text-align:center;color:#9ca3af;padding:64px 24px;font-size:14px}.badge{border-radius:999px;padding:2px 8px;font-size:12px;font-weight:500;display:inline-flex}.badge-success{color:#059669;background:#ecfdf5}.badge-admin{color:#dc2626;background:#fef2f2}.badge-default{color:#6b7280;background:#f3f4f6}.login-page{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);justify-content:center;align-items:center;min-height:100vh;display:flex}.login-card{background:#fff;border-radius:16px;width:100%;max-width:420px;padding:40px;box-shadow:0 8px 40px #0000001f}.login-logo{text-align:center;margin-bottom:24px}.logo-icon{color:#fff;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);border-radius:14px;justify-content:center;align-items:center;width:56px;height:56px;margin-bottom:12px;font-size:24px;font-weight:700;display:inline-flex}.login-card h1{margin-bottom:4px;font-size:24px;font-weight:700}.login-card .subtitle{color:#9ca3af;font-size:14px}.login-card .alt-action{text-align:center;color:#6b7280;margin-top:20px;font-size:14px}.login-card .alt-action button{color:#2563eb;cursor:pointer;background:0 0;border:none;margin-left:4px;font-size:14px;font-weight:600}.error-msg{color:#dc2626;background:#fef2f2;border-radius:8px;margin-bottom:16px;padding:12px;font-size:14px}.success-msg{color:#059669;background:#ecfdf5;border-radius:8px;margin-top:8px;padding:12px;font-size:14px}.inline-form{flex-wrap:wrap;align-items:flex-end;gap:12px;display:flex}.inline-form .form-group{flex:1;min-width:160px;margin-bottom:0}.summary-text{color:#6b7280;background:#f9fafb;border-radius:8px;margin-top:8px;padding:12px 16px;font-size:13px}.chat-page{flex-direction:column;height:calc(100vh - 80px);display:flex}.chat-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.chat-messages{flex:1;min-height:0;padding:24px;overflow-y:auto}.chat-welcome{text-align:center;padding:48px 24px}.welcome-icon{margin-bottom:16px;font-size:48px}.welcome-text{color:#6b7280;margin-bottom:8px;font-size:16px}.welcome-hint{color:#9ca3af;margin-bottom:16px;font-size:13px}.suggestions{flex-wrap:wrap;justify-content:center;gap:8px;display:flex}.suggestion-btn{color:#374151;cursor:pointer;background:#f3f4f6;border:1px solid #e5e7eb;border-radius:20px;padding:8px 16px;font-size:13px;transition:all .15s}.suggestion-btn:hover{color:#2563eb;background:#eff6ff;border-color:#93c5fd}.chat-msg{gap:12px;margin-bottom:16px;display:flex}.chat-msg.user{flex-direction:row-reverse}.msg-avatar{background:#f3f4f6;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:18px;display:flex}.msg-bubble{border-radius:12px;max-width:70%;padding:12px 16px;font-size:14px;line-height:1.5}.chat-msg.user .msg-bubble{color:#fff;background:#2563eb;border-bottom-right-radius:4px}.chat-msg.assistant .msg-bubble{color:#1a1a2e;background:#f3f4f6;border-bottom-left-radius:4px}.msg-content{white-space:pre-wrap;word-break:break-word}.msg-time{opacity:.6;margin-top:4px;font-size:11px;display:block}.typing-dots{gap:4px;padding:4px 0;display:flex}.typing-dots span{background:#9ca3af;border-radius:50%;width:8px;height:8px;animation:1.4s ease-in-out infinite typing}.typing-dots span:nth-child(2){animation-delay:.2s}.typing-dots span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.4;transform:translateY(0)}30%{opacity:1;transform:translateY(-6px)}}.chat-input-area{background:#f9fafb;border-top:1px solid #e5e7eb;gap:8px;padding:16px;display:flex}.chat-input{flex:1}.btn-send{min-width:80px}@media (width<=768px){.stats-grid{grid-template-columns:1fr}.sidebar{width:200px}.main{max-width:calc(100vw - 200px);margin-left:200px;padding:20px}}@media (width<=600px){.sidebar{width:60px}.sidebar-brand h1,.sidebar-brand p{display:none}.sidebar-nav a{text-align:center;padding:8px 4px;font-size:12px}.user-details{display:none}.main{max-width:calc(100vw - 60px);margin-left:60px;padding:16px}}
