:root{color:#1f2937;background:#f3f5f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}button,input,select{font:inherit}button{border-radius:6px;cursor:pointer;font-weight:700;min-height:42px;padding:0 18px}button:disabled{cursor:wait;opacity:.68}.app-shell{min-height:100vh;padding:48px 20px}.login-layout,.dashboard{margin:0 auto;max-width:1080px}.login-layout{align-items:stretch;display:grid;gap:24px;grid-template-columns:minmax(0,1fr) minmax(360px,430px)}.brand-panel,.login-panel,.info-panel{background:#fff;border:1px solid #d7dce8;border-radius:8px;box-shadow:0 18px 50px #1f293714}.brand-panel{display:flex;flex-direction:column;justify-content:center;min-height:520px;padding:48px}.login-panel{display:flex;flex-direction:column;gap:18px;justify-content:center;padding:34px}.eyebrow,.label{color:#0f766e;font-size:13px;font-weight:800;letter-spacing:0;margin:0 0 10px;text-transform:uppercase}h1,h2,p{margin-top:0}h1{color:#111827;font-size:42px;line-height:1.1;margin-bottom:16px}h2{color:#111827;font-size:24px;line-height:1.25;margin-bottom:0}.summary{color:#4b5563;font-size:17px;line-height:1.75;margin-bottom:0;max-width:620px}.panel-title{margin-bottom:4px}label{display:grid;gap:8px}label span{color:#374151;font-size:14px;font-weight:700}input,select{background:#f9fafb;border:1px solid #cfd6e3;border-radius:6px;color:#111827;min-height:44px;outline:none;padding:0 12px;width:100%}input:focus,select:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb24}.primary-button{background:#2563eb;border:1px solid #1d4ed8;color:#fff;width:100%}.ghost-button,.small-button{background:#fff;border:1px solid #cfd6e3;color:#1f2937}.small-button{min-height:36px}.hint{color:#6b7280;font-size:13px;margin-bottom:0;text-align:center}.error{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#b91c1c;margin-bottom:0;padding:10px 12px}.topbar{align-items:center;display:flex;gap:18px;justify-content:space-between;margin-bottom:24px}.dashboard-grid{display:grid;gap:24px;grid-template-columns:minmax(300px,.85fr) minmax(0,1.15fr);margin-bottom:24px}.info-panel{padding:28px}.panel-header{align-items:center;display:flex;gap:16px;justify-content:space-between;margin-bottom:18px}dl{display:grid;gap:18px;margin:0}dl div{border-bottom:1px solid #eef1f6;padding-bottom:14px}dt{color:#6b7280;font-size:13px;font-weight:700;margin-bottom:6px}dd{color:#111827;font-size:16px;font-weight:700;margin:0}pre{background:#111827;border-radius:6px;color:#d1fae5;margin:0;overflow:auto;padding:18px;white-space:pre-wrap}.crawler-panel{margin-top:0}.crawler-form{display:grid;gap:16px;grid-template-columns:minmax(0,1.4fr) minmax(180px,.5fr) minmax(0,1fr);margin-bottom:18px}.crawl-result{display:grid;gap:18px;margin-top:20px}.result-summary{align-items:center;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;display:flex;gap:16px;justify-content:space-between;padding:16px}.result-summary h3,.result-list h3{color:#111827;font-size:18px;line-height:1.35;margin:0}.result-summary span{color:#0f766e;font-weight:800;white-space:nowrap}.result-list{display:grid;gap:12px}.result-item{border:1px solid #e5e7eb;border-radius:6px;padding:14px}.result-item strong{color:#2563eb;display:block;margin-bottom:8px}.result-item p{color:#374151;line-height:1.65;margin:0}.tab-bar{display:flex;gap:8px}.tab-button{background:#f3f5f8;border:1px solid #cfd6e3;border-radius:6px;color:#374151;font-weight:700;min-height:36px;padding:0 14px}.tab-active{background:#2563eb;border-color:#1d4ed8;color:#fff}.crawler-form.stacked{display:flex;flex-direction:column;gap:14px;margin-bottom:18px}.form-row{display:grid;gap:14px;grid-template-columns:repeat(3,minmax(0,1fr))}.form-row.check-row{display:flex;flex-wrap:wrap;gap:12px 18px}.check-label{align-items:center;color:#374151;display:inline-flex;font-size:14px;font-weight:600;gap:6px}.check-label input{min-height:auto;width:auto}.kv-section{border:1px solid #e5e7eb;border-radius:6px;padding:12px}.kv-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.kv-header span{color:#374151;font-size:14px;font-weight:700}.kv-row{display:grid;gap:8px;grid-template-columns:1fr 1fr auto;margin-bottom:6px}.tiny-button{background:#2563eb;border:1px solid #1d4ed8;border-radius:4px;color:#fff;font-weight:700;min-height:28px;padding:0 10px}.tiny-button.danger{background:#ef4444;border-color:#dc2626}.action-bar{display:flex;gap:12px;margin-bottom:12px}.action-bar .primary-button{width:auto}textarea{background:#f9fafb;border:1px solid #cfd6e3;border-radius:6px;color:#111827;font:inherit;outline:none;padding:10px 12px;resize:vertical;width:100%}textarea:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb24}.image-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.image-grid img{border-radius:6px;height:120px;object-fit:cover;width:100%}.image-grid figcaption{color:#6b7280;font-size:12px;margin-top:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width: 820px){.app-shell{padding:24px 14px}.login-layout,.dashboard-grid,.crawler-form{grid-template-columns:1fr}.brand-panel{min-height:auto;padding:32px}.topbar,.panel-header,.result-summary{align-items:stretch;flex-direction:column}h1{font-size:34px}}
