:root{font-family:Inter,-apple-system,BlinkMacSystemFont,PingFang SC,Microsoft YaHei,sans-serif;color:#0f172a;background:#f1f5f9;line-height:1.5;font-weight:400}*{box-sizing:border-box}html,body,#root{margin:0;min-height:100%}button,input,select{font:inherit}button{cursor:pointer}.app-shell{display:flex;min-height:100vh;background:#f1f5f9}.app-main{flex:1;min-width:0}.content-wrap{max-width:1600px;margin:0 auto;padding:24px 20px 40px}.login-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at top left,rgba(37,99,235,.16),transparent 32%),radial-gradient(circle at bottom right,rgba(14,165,233,.12),transparent 28%),#f1f5f9}.login-panel{width:min(760px,100%);border:1px solid rgba(148,163,184,.22);border-radius:32px;background:#fffffff5;box-shadow:0 22px 64px #0f172a1f;padding:32px;display:grid;gap:24px}.login-badge{background:#0f172a;color:#fff}.login-form{max-width:420px}.login-submit{min-height:46px}.login-hint-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:16px}@media (min-width: 960px){.login-hint-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.login-error{margin:0;background:#fef2f2;border-color:#fecaca;color:#b91c1c}.sidebar{width:288px;background:#020617;color:#e2e8f0;border-right:1px solid rgba(255,255,255,.08);display:none;flex-direction:column}@media (min-width: 1024px){.sidebar{display:flex}}.sidebar-brand{padding:24px;display:flex;gap:12px;align-items:center;border-bottom:1px solid rgba(255,255,255,.08)}.brand-badge{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:16px;background:#ffffff14}.brand-title{font-size:16px;font-weight:700}.brand-subtitle{font-size:12px;color:#94a3b8}.sidebar-nav{padding:16px;display:grid;gap:8px}.nav-btn{width:100%;display:flex;align-items:center;justify-content:space-between;border:0;border-radius:16px;background:transparent;color:inherit;padding:14px;text-align:left}.nav-btn:hover{background:#ffffff0f}.nav-btn-active{background:#fff;color:#0f172a}.sticky-header{position:sticky;top:0;z-index:20;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #e2e8f0;background:#f1f5f9f2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.page-title{font-size:28px;font-weight:700;letter-spacing:-.02em}.page-subtitle{margin-top:4px;font-size:14px;color:#64748b}.hero-banner{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;padding:24px;border-radius:28px;color:#fff;background:linear-gradient(90deg,#0f172a,#1e293b,#334155)}.hero-title{font-size:34px;font-weight:800;letter-spacing:-.03em}.hero-desc{margin-top:8px;max-width:900px;font-size:14px;line-height:1.7;color:#cbd5e1}.cockpit{background:#020617;color:#fff;padding:24px;border-radius:32px;box-shadow:0 25px 60px #02061759}.cockpit-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:20px}.cockpit-eyebrow{color:#67e8f9;font-size:12px;letter-spacing:.35em;text-transform:uppercase}.cockpit-title{margin-top:8px;font-size:42px;font-weight:800;letter-spacing:-.03em}.cockpit-desc{margin-top:8px;font-size:14px;color:#94a3b8}.cockpit-card{border:1px solid rgba(255,255,255,.08);border-radius:24px;background:#ffffff0d;padding:20px}.cockpit-label{color:#94a3b8;font-size:14px}.cockpit-value{margin-top:12px;font-size:48px;font-weight:800;color:#67e8f9}.cockpit-subtitle{margin-top:8px;font-size:12px;color:#64748b}.notice{margin-bottom:24px;padding:12px 16px;border-radius:16px;background:#ecfdf5;border:1px solid #a7f3d0;color:#047857}.card{background:#fff;border:1px solid rgba(148,163,184,.25);border-radius:28px;box-shadow:0 4px 24px #0f172a0a}.card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:18px 20px;border-bottom:1px solid #f1f5f9}.card-head>*{min-width:0}.card-title{font-size:14px;font-weight:700}.card-body{padding:20px}.grid-4{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:16px}@media (min-width: 768px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.two-col,.two-col-hero{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 1280px){.two-col{grid-template-columns:repeat(2,minmax(0,1fr))}.two-col-hero{grid-template-columns:minmax(0,1.15fr) 400px}}.stack{display:grid;gap:12px}.stack-sm{display:grid;gap:6px}.stack-lg{display:grid;gap:24px}.inline-row{display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap}.button-row{display:flex;gap:8px;flex-wrap:wrap}.align-right{display:flex;justify-content:flex-end}.chip-grid{display:grid;gap:8px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.chip-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.info-grid{display:grid;gap:16px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.info-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.summary-grid{display:grid;gap:12px;grid-template-columns:repeat(2,minmax(0,1fr))}.info-field,.mini-card,.surface-box,.surface-outline{border-radius:20px;padding:16px;background:#f8fafc;min-width:0}.surface-outline{background:#fff;border:1px solid #e2e8f0}.info-field.span-2{grid-column:span 1}@media (min-width: 768px){.info-field.span-2{grid-column:span 2}}.field-label,.muted{color:#64748b;font-size:14px}.field-label.with-icon{display:inline-flex;align-items:center;gap:6px}.field-value,.title-sm{margin-top:8px;font-size:16px;font-weight:700;color:#0f172a;word-break:break-word}.section-title{font-size:20px;font-weight:700}.section-subtitle{font-size:14px;font-weight:700;color:#0f172a}.small{font-size:12px}.body{line-height:1.7;word-break:break-word}.mt-8{margin-top:8px}.spacer-sm{height:8px}.entity-switch{display:flex;flex-wrap:wrap;gap:12px}.entity-chip{border:1px solid #e2e8f0;background:#fff;color:#334155;border-radius:16px;padding:10px 14px;font-size:14px;font-weight:600}.entity-chip-active{background:#0f172a;color:#fff;border-color:#0f172a}.table-wrap{overflow:hidden;border:1px solid #e2e8f0;border-radius:20px}.table-scroll{overflow-x:auto}.table{width:100%;border-collapse:collapse;font-size:14px}.table thead{background:#f8fafc;color:#64748b}.table th{padding:12px 16px;text-align:left;white-space:nowrap;font-weight:600}.table td{padding:12px 16px;border-top:1px solid #f1f5f9;vertical-align:top}.cell.strong{font-weight:700;color:#0f172a;white-space:nowrap}.cell-nowrap{white-space:nowrap}.cell-code{white-space:nowrap;font-variant-numeric:tabular-nums}.wrap-cell{white-space:normal;word-break:break-word;min-width:220px}.row-active{background:#f8fafc}.row-active-panel{border-color:#cbd5e1;background:#f8fafc}.task-table td:last-child,.task-table th:last-child{min-width:170px}.progress-track{height:8px;background:#e2e8f0;border-radius:999px;overflow:hidden}.progress-bar{height:100%;border-radius:999px}.progress-dark{background:#0f172a}.progress-blue{background:#3b82f6}.progress-emerald{background:#10b981}.progress-red{background:#ef4444}.list-card{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;border:1px solid #e2e8f0;background:#fff;border-radius:20px;padding:16px;min-width:0}.list-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.search-wrap{position:relative}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:#94a3b8}.search-input{width:288px;border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:10px 12px 10px 36px;font-size:14px;outline:none}.filter-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-bottom:16px}@media (min-width: 768px){.filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.filter-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}select{border:1px solid #e2e8f0;background:#fff;border-radius:16px;padding:12px 14px;min-height:44px}.btn{border:0;border-radius:16px;padding:10px 14px;font-size:14px;font-weight:600;display:inline-flex;align-items:center;gap:8px;justify-content:center}.btn-xs{padding:7px 12px;font-size:12px;border-radius:12px}.btn-dark{background:#0f172a;color:#fff}.btn-blue{background:#2563eb;color:#fff}.btn-amber{background:#d97706;color:#fff}.btn-emerald{background:#059669;color:#fff}.btn-light{background:#fff;color:#334155;border:1px solid #e2e8f0}.role-btn{min-height:42px}.badge{display:inline-flex;align-items:center;white-space:nowrap;flex-shrink:0;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:600;border:1px solid transparent}.badge-red{background:#fef2f2;color:#b91c1c;border-color:#fecaca}.badge-amber{background:#fffbeb;color:#b45309;border-color:#fde68a}.badge-emerald{background:#ecfdf5;color:#047857;border-color:#a7f3d0}.badge-blue{background:#eff6ff;color:#1d4ed8;border-color:#bfdbfe}.badge-slate{background:#f1f5f9;color:#475569;border-color:#cbd5e1}.badge-violet{background:#f5f3ff;color:#6d28d9;border-color:#ddd6fe}.badge-cyan{background:#ecfeff;color:#0e7490;border-color:#a5f3fc}.icon-sm{width:16px;height:16px}.icon-md{width:22px;height:22px}.icon-xs{width:14px;height:14px}.faint{opacity:.65}.section-head{background:#fff;border:1px solid rgba(148,163,184,.25);border-radius:28px;box-shadow:0 4px 24px #0f172a0a;padding:20px;display:flex;justify-content:space-between;gap:16px;align-items:center}.task-layout{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 1280px){.task-layout{grid-template-columns:minmax(0,1.45fr) 400px}}.task-status-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media (min-width: 768px){.task-status-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width: 1280px){.task-status-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.task-status-card{width:100%;border:1px solid #e2e8f0;background:#fff;border-radius:20px;padding:16px;display:grid;gap:10px;text-align:left;cursor:pointer;font:inherit;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.task-status-card:hover{border-color:#cbd5e1;box-shadow:0 8px 24px #0f172a0f;transform:translateY(-1px)}.task-status-card-active{border-color:#0f172a;box-shadow:0 10px 24px #0f172a14}.portrait-hero{align-items:flex-start}.portrait-result-grid{display:grid;grid-template-columns:1fr;gap:24px;align-items:stretch}@media (min-width: 1280px){.portrait-result-grid{grid-template-columns:minmax(0,1.1fr) minmax(360px,.9fr)}}.portrait-risk-panel{display:grid;gap:16px}.portrait-risk-main{border-radius:20px;background:linear-gradient(135deg,#0f172a,#1e293b 60%,#334155);color:#fff;padding:18px;display:grid;gap:10px}.portrait-risk-main .muted,.portrait-risk-main .small{color:#ffffffb8}.portrait-risk-value{margin-top:8px;font-size:30px;line-height:1;font-weight:800}.portrait-alert-card{border:1px solid #fecaca;background:#fef2f2}.portrait-process-grid{align-items:flex-start}.portrait-service-list{display:grid;gap:12px}.portrait-service-item{width:100%;border:1px solid #e2e8f0;background:#fff;border-radius:20px;padding:16px;display:grid;gap:10px;text-align:left;cursor:pointer;font:inherit;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.portrait-service-item:hover{border-color:#cbd5e1;box-shadow:0 8px 24px #0f172a0f;transform:translateY(-1px)}.portrait-month-switch{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.portrait-trend-grid{display:grid;gap:12px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 1024px){.portrait-trend-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.portrait-trend-card{width:100%;border:1px solid #e2e8f0;background:#fff;border-radius:22px;padding:16px;display:grid;gap:14px;text-align:left;cursor:pointer;font:inherit;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.portrait-trend-card:hover{border-color:#cbd5e1;box-shadow:0 8px 24px #0f172a0f;transform:translateY(-1px)}.portrait-trend-card-active{border-color:#0f172a;box-shadow:0 10px 24px #0f172a14}.portrait-trend-stats{display:grid;gap:12px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.portrait-trend-stats{grid-template-columns:repeat(3,minmax(0,1fr))}}.task-status-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.task-status-count{font-size:28px;line-height:1;font-weight:800;color:#0f172a}.task-filter-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media (min-width: 768px){.task-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.task-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.task-quick-filters{display:flex;flex-wrap:wrap;gap:8px;min-width:0;justify-content:flex-end}.task-quick-chip{border:1px solid #cbd5e1;background:#fff;color:#334155;border-radius:999px;padding:8px 12px;font-size:12px;font-weight:600;cursor:pointer;font:inherit}.task-quick-chip-active{border-color:#0f172a;background:#0f172a;color:#fff}.task-detail-drawer{width:min(620px,100vw)}.portrait-snapshot-drawer{width:min(560px,100vw)}.task-detail-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.task-timeline{display:grid;gap:16px;margin-top:12px}.task-timeline-item{display:grid;grid-template-columns:18px minmax(0,1fr);gap:12px;align-items:flex-start}.task-timeline-dot{width:12px;height:12px;border-radius:999px;background:#0f172a;margin-top:6px;box-shadow:0 0 0 4px #e2e8f0}.task-timeline-body{border:1px solid #e2e8f0;border-radius:18px;background:#fff;padding:14px 16px}.task-evidence-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px;margin-top:12px}.task-evidence-head{display:flex;justify-content:space-between;align-items:center;gap:12px}@media (min-width: 768px){.task-evidence-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.task-evidence-card{border:1px solid #e2e8f0;border-radius:20px;background:#fff;padding:14px;display:grid;gap:12px}.task-evidence-preview{min-height:108px;border-radius:16px;background:linear-gradient(135deg,#e2e8f0,#f8fafc 55%,#dbeafe);color:#334155;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;letter-spacing:.04em}.task-evidence-image{width:100%;min-height:108px;max-height:180px;object-fit:cover;border-radius:16px;display:block;background:#e2e8f0}.hidden-file-input{display:none}.todo-list{display:grid;gap:10px;margin-top:10px}.todo-item{border-radius:14px;background:#f8fafc;padding:10px 12px;font-size:13px;line-height:1.7;color:#475569;word-break:break-word}.todo-action{width:100%;border:1px solid #e2e8f0;text-align:left;font:inherit;transition:border-color .16s ease,background .16s ease}.todo-action:hover{border-color:#cbd5e1;background:#fff}.score-toolbar{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:16px}@media (min-width: 1024px){.score-toolbar{grid-template-columns:repeat(3,minmax(0,1fr))}}.score-toolbar-group{display:grid;gap:8px;min-width:0}.inline-input{width:100%;border:1px solid #e2e8f0;background:#fff;border-radius:12px;padding:8px 10px;min-height:38px}.toggle-row{display:inline-flex;align-items:center;gap:8px;white-space:nowrap}.score-trend-grid{display:grid;gap:12px;grid-template-columns:repeat(1,minmax(0,1fr));margin-top:14px}@media (min-width: 768px){.score-trend-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.drawer-mask{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a47;z-index:39}.drawer-panel{position:fixed;top:0;right:0;width:min(520px,100vw);height:100vh;padding:24px;overflow-y:auto;background:#f8fafc;box-shadow:-18px 0 48px #0f172a2e;z-index:40}.drawer-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px}.overview-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:16px}@media (min-width: 768px){.overview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.overview-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.overview-card{width:100%;border:1px solid rgba(148,163,184,.25);border-radius:24px;padding:18px;background:#fff;box-shadow:0 4px 24px #0f172a0a;display:grid;gap:14px;text-align:left;transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.overview-card:hover{transform:translateY(-2px);border-color:#cbd5e1;box-shadow:0 10px 28px #0f172a14}.overview-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.overview-card-title{font-size:14px;font-weight:700;color:#334155}.overview-card-value{margin-top:10px;font-size:32px;line-height:1;font-weight:800;color:#0f172a}.overview-card-desc{font-size:13px;line-height:1.7;color:#64748b}.overview-card-icon{width:44px;height:44px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;background:#eff6ff;color:#1d4ed8;flex-shrink:0}.dashboard-main-grid{display:grid;grid-template-columns:1fr;gap:24px}@media (min-width: 1280px){.dashboard-main-grid{grid-template-columns:minmax(0,1.45fr) 420px}}.dashboard-filter-row{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media (min-width: 768px){.dashboard-filter-row{grid-template-columns:repeat(3,minmax(0,1fr))}}.risk-list{display:grid;gap:12px}.risk-item{width:100%;border:1px solid #e2e8f0;border-radius:20px;background:#fff;padding:16px;text-align:left;transition:border-color .16s ease,background .16s ease}.risk-item:hover{border-color:#cbd5e1;background:#f8fafc}.risk-item-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}.risk-item-grid{margin-top:14px;display:grid;gap:10px;grid-template-columns:repeat(2,minmax(0,1fr))}.delivery-grid{display:grid;gap:12px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.delivery-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.delivery-grid{grid-template-columns:repeat(5,minmax(0,1fr))}}.delivery-grid-compact{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.empty-state{border-radius:20px;background:#f8fafc;color:#64748b;padding:28px 20px;text-align:center;border:1px dashed #cbd5e1}.clickable-row{cursor:pointer}.clickable-row:hover{background:#f8fafc}.workspace-two-col{display:grid;grid-template-columns:1fr;gap:24px;align-items:flex-start}@media (min-width: 1280px){.workspace-two-col{grid-template-columns:minmax(0,1.35fr) minmax(360px,.95fr)}}.hazard-filter-grid{display:grid;grid-template-columns:repeat(1,minmax(0,1fr));gap:12px}@media (min-width: 768px){.hazard-filter-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (min-width: 1280px){.hazard-filter-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.search-input-wide{width:100%}.trend-list{display:grid;gap:12px}.trend-item{border:1px solid #e2e8f0;border-radius:22px;background:#fff;padding:16px;display:grid;gap:14px}.trend-metrics,.distribution-grid{display:grid;gap:12px;grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width: 768px){.trend-metrics,.distribution-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}.timeline-expander{border:1px solid #e2e8f0;border-radius:18px;background:#fff;padding:14px 16px}.timeline-summary{list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.timeline-summary::-webkit-details-marker{display:none}.timeline-details{margin-top:14px;display:grid;gap:12px}@media (max-width: 767px){.search-input{width:100%}.hero-banner,.cockpit-head,.sticky-header,.section-head,.list-card-head,.task-detail-header,.task-evidence-head,.timeline-summary{flex-direction:column;align-items:flex-start}.summary-grid{grid-template-columns:1fr}.drawer-panel{width:100vw}}
