/* HepaVision Pro Design System v1.0 */
/* 新增: 3D打印辅助 + Histotripsy 组织碎毁术 */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--primary:#1A56DB;--primary-l:#3B82F6;--primary-bg:#EBF2FF;--purple:#7C3AED;--purple-bg:#EDE9FE;--green:#16A34A;--green-bg:#ECFDF5;--cyan:#0891B2;--cyan-bg:#ECFEFF;--orange:#EA580C;--orange-bg:#FFF7ED;--red:#DC2626;--red-bg:#FEE2E2;--hist:#7C2D12;--hist-bg:#FFF7ED;--bg:#F0F4F8;--bg-card:#fff;--text:#1E293B;--text-2:#64748B;--text-3:#94A3B8;--border:#E2E8F0;--border-h:#CBD5E1;--shadow-s:0 1px 3px rgba(0,0,0,.06);--shadow-m:0 4px 12px rgba(0,0,0,.08);--r:12px;--r-lg:16px;--r-sm:8px;--sidebar-w:240px;--ease:.25s cubic-bezier(.4,0,.2,1)}
body{font-family:'Noto Sans SC','Inter',sans-serif;background:var(--bg);color:var(--text);display:flex;min-height:100vh;-webkit-font-smoothing:antialiased}

/* SIDEBAR */
.sidebar{width:var(--sidebar-w);background:linear-gradient(180deg,#1E293B,#0F172A);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:50;padding:24px 16px}
.sidebar-logo{display:flex;align-items:center;gap:12px;padding:0 8px 28px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:20px}
.logo-icon svg{width:36px;height:36px;filter:drop-shadow(0 2px 8px rgba(26,86,219,.4))}
.logo-name{font-size:1.25rem;font-weight:800;color:#fff;letter-spacing:.06em;display:block}
.logo-sub{font-size:.65rem;color:rgba(255,255,255,.4);letter-spacing:.12em}
.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:4px}
.nav-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--r-sm);color:rgba(255,255,255,.55);text-decoration:none;font-size:.9rem;font-weight:500;transition:all var(--ease);position:relative}
.nav-item:hover{color:rgba(255,255,255,.9);background:rgba(255,255,255,.06)}
.nav-item.active{color:#fff;background:var(--primary);box-shadow:0 2px 10px rgba(26,86,219,.4)}
.nav-icon{width:20px;height:20px;flex-shrink:0}
.nav-badge{position:absolute;right:12px;background:rgba(255,255,255,.2);color:#fff;font-size:.7rem;padding:2px 8px;border-radius:12px;font-weight:600}
.nav-item.active .nav-badge{background:rgba(255,255,255,.3)}
.sidebar-footer{padding-top:16px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center}
.system-status{display:flex;align-items:center;gap:6px;color:rgba(255,255,255,.4);font-size:.75rem}
.status-dot{width:6px;height:6px;border-radius:50%;background:#4ADE80;animation:pulseDot 2s infinite}
@keyframes pulseDot{0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.5)}50%{box-shadow:0 0 0 5px rgba(74,222,128,0)}}
.version{font-size:.7rem;color:rgba(255,255,255,.3)}

/* MAIN */
.main-wrapper{flex:1;margin-left:var(--sidebar-w);display:flex;flex-direction:column;min-height:100vh}
.top-header{display:flex;justify-content:space-between;align-items:center;padding:16px 32px;background:#fff;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:40}
.patient-context{display:flex;align-items:center;gap:14px}
.patient-avatar{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--primary-l));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1.1rem}
.patient-name{font-size:1.2rem;font-weight:700}
.patient-name-row{display:flex;align-items:center;gap:10px}
.patient-id{font-size:.8rem;color:var(--text-2);font-family:'Inter',monospace}
.patient-stage-badge{background:#DBEAFE;color:var(--primary);font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:6px}
.patient-meta{display:flex;align-items:center;gap:6px;font-size:.8rem;color:var(--text-2);margin-top:3px}
.meta-sep{color:var(--border)}
.header-actions{display:flex;align-items:center;gap:16px}
.btn-icon{background:none;border:1px solid var(--border);border-radius:var(--r-sm);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text-2);position:relative;transition:all var(--ease)}
.btn-icon:hover{border-color:var(--primary);color:var(--primary)}
.notification-dot{position:absolute;top:8px;right:8px;width:7px;height:7px;background:var(--red);border-radius:50%}
.doctor-profile{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:var(--r-sm);border:1px solid var(--border);cursor:pointer;transition:all var(--ease)}
.doctor-profile:hover{border-color:var(--primary-l);box-shadow:var(--shadow-s)}
.doctor-avatar{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#059669,#34D399);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem}
.doctor-name{font-size:.85rem;font-weight:600;display:block}
.doctor-dept{font-size:.7rem;color:var(--text-3);display:block}

/* PAGES */
.page-content{padding:28px 32px;flex:1;animation:pageIn .3s ease}
.page-content.hidden{display:none}
@keyframes pageIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.page-header{margin-bottom:24px}
.page-title{font-size:1.5rem;font-weight:800}
.page-desc{font-size:.85rem;color:var(--text-2);margin-top:4px}

/* GRID */
.dashboard{display:flex;flex-direction:column;gap:24px}
.dashboard-row{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.dashboard-row.full-width-row{grid-template-columns:1fr}

/* CARDS */
.card{background:var(--bg-card);border-radius:var(--r-lg);border:1px solid var(--border);box-shadow:var(--shadow-s);transition:all var(--ease);overflow:hidden}
.card:hover{box-shadow:var(--shadow-m);border-color:var(--border-h)}
.card-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}
.card-title-group{display:flex;align-items:center;gap:12px}
.card-icon{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.ci-blue{background:var(--primary-bg)}.ci-purple{background:var(--purple-bg)}.ci-green{background:var(--green-bg)}.ci-orange{background:var(--orange-bg)}.ci-cyan{background:var(--cyan-bg)}.ci-red{background:var(--red-bg)}.ci-hist{background:var(--hist-bg)}
.card-title{font-size:1rem;font-weight:700}
.card-subtitle{font-size:.72rem;color:var(--text-3);margin-top:1px}
.card-body{padding:24px}
.completeness-badge{font-size:.8rem;font-weight:600;color:var(--green)}
.update-time{font-size:.75rem;color:var(--text-3)}

/* DATA LIST */
.data-list{list-style:none;display:flex;flex-direction:column;gap:10px;margin-bottom:20px}
.data-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--r-sm);transition:all var(--ease)}
.data-item:hover{background:var(--bg)}
.di-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.di-icon.done{background:var(--green)}.di-icon.pending{background:#CBD5E1;color:#fff;font-size:.6rem}
.di-info{flex:1}.di-name{font-size:.9rem;font-weight:600;display:block}.di-detail{font-size:.75rem;color:var(--text-3);display:block;margin-top:2px}
.di-badge{font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:6px}
.di-badge.done{background:var(--green-bg);color:var(--green)}.di-badge.pending{background:#F1F5F9;color:var(--text-3)}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 20px;border-radius:var(--r-sm);font-size:.85rem;font-weight:600;cursor:pointer;transition:all var(--ease);border:none;font-family:inherit}
.btn-outline{border:1.5px solid var(--primary);color:var(--primary);background:transparent}
.btn-outline:hover{background:var(--primary-bg)}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-l));color:#fff;position:relative;overflow:hidden}
.btn-primary:hover{box-shadow:0 4px 20px rgba(26,86,219,.35);transform:translateY(-1px)}
.btn-secondary{background:#fff;border:1px solid var(--border);color:var(--primary);font-size:.82rem}
.btn-secondary:hover{border-color:var(--primary);background:var(--primary-bg)}
.btn-hist{background:linear-gradient(135deg,var(--hist),#A0522D);color:#fff}
.btn-hist:hover{box-shadow:0 4px 20px rgba(124,45,18,.35);transform:translateY(-1px)}
.btn-inner{display:flex;align-items:center;gap:8px;position:relative;z-index:1}
.btn-shimmer{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}
@keyframes shimmer{0%{left:-100%}100%{left:100%}}
.full-width{width:100%}
.btn-analysis{width:100%;padding:18px;font-size:1rem;margin-bottom:20px}
.btn-analysis.running{background:linear-gradient(135deg,#059669,#34D399);pointer-events:none}
.btn-analysis.running .btn-shimmer{display:none}
.btn-analysis.done{background:var(--green);cursor:pointer}

/* PIPELINE */
.pipeline{display:flex;flex-direction:column;gap:0;margin-bottom:20px}
.pipe-step{display:flex;align-items:flex-start;gap:14px;position:relative;padding-bottom:16px}
.pipe-step:last-child{padding-bottom:0}
.pipe-connector{position:absolute;left:14px;top:36px;width:2px;height:calc(100% - 20px);background:var(--border)}
.pipe-step[data-state=done] .pipe-connector{background:var(--green)}
.pipe-step[data-state=active] .pipe-connector{background:linear-gradient(to bottom,var(--primary),var(--border))}
.pipe-step:last-child .pipe-connector{display:none}
.pipe-dot{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:var(--border);color:var(--text-3);position:relative;z-index:2;flex-shrink:0}
.pipe-step[data-state=done] .pipe-dot{background:var(--green);color:#fff}
.pipe-step[data-state=active] .pipe-dot{background:var(--primary);color:#fff;box-shadow:0 0 0 4px rgba(26,86,219,.2)}
.pipe-num{font-size:.7rem;font-weight:600}
.pipe-info{flex:1;padding-top:4px}
.pipe-label{font-size:.88rem;font-weight:600;display:block}
.pipe-sub{font-size:.72rem;color:var(--text-3);display:block}
.pipe-state{font-size:.72rem;font-weight:600;display:block;margin-top:2px;color:var(--text-3)}
.pipe-step[data-state=done] .pipe-state{color:var(--green)}
.pipe-step[data-state=active] .pipe-state{color:var(--primary)}
.pipe-loader{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

/* PROGRESS */
.progress-box{background:var(--bg);border-radius:var(--r-sm);padding:16px}
.progress-top{display:flex;justify-content:space-between;margin-bottom:8px;font-size:.82rem;font-weight:600}
.progress-pct{color:var(--primary)}
.progress-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-l));border-radius:3px;transition:width .5s ease}
.progress-eta{font-size:.75rem;color:var(--text-3);margin-top:6px}

/* PREDICTION */
.pred-result{display:flex;align-items:center;gap:28px;margin-bottom:24px}
.gauge-wrap{position:relative;width:160px;height:160px;flex-shrink:0}
.gauge-center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.gauge-val{font-size:2.4rem;font-weight:800;color:var(--text);font-family:'Inter',sans-serif}
.gauge-unit{font-size:.8rem;color:var(--text-2);font-weight:500}
.pred-info{flex:1}
.tier-badge{display:inline-block;padding:6px 18px;border-radius:20px;font-size:.9rem;font-weight:700;margin-bottom:4px}
.tier-high{background:var(--green-bg);color:var(--green)}.tier-mid{background:#FEF3C7;color:#D97706}.tier-low{background:var(--red-bg);color:var(--red)}
.tier-en{font-size:.75rem;color:var(--text-3);display:block;margin-bottom:8px}
.tier-desc{font-size:.82rem;color:var(--text-2);line-height:1.6}
.factors-title{font-size:.85rem;font-weight:600;margin-bottom:12px;color:var(--text-2)}
.radar-wrap{display:flex;justify-content:center}

/* Treatment recommendation for different tiers */
.treatment-rec{background:var(--bg);border-radius:var(--r-sm);padding:16px;margin-top:16px;border-left:3px solid var(--green)}
.treatment-rec.low-benefit{border-left-color:var(--red);background:var(--red-bg)}
.treatment-rec-title{font-size:.85rem;font-weight:700;margin-bottom:8px;color:var(--text)}
.treatment-rec.low-benefit .treatment-rec-title{color:var(--red)}
.treatment-rec-list{font-size:.8rem;color:var(--text-2);line-height:1.8;padding-left:16px}
.treatment-rec-list li{margin-bottom:4px}
.treatment-highlight{background:linear-gradient(90deg,var(--red-bg),transparent);padding:2px 8px;border-radius:4px;color:var(--red);font-weight:600}
.hist-badge{display:inline-flex;align-items:center;gap:6px;background:var(--hist-bg);color:var(--hist);padding:4px 12px;border-radius:20px;font-size:.78rem;font-weight:600;margin-top:8px;cursor:pointer;transition:all var(--ease)}
.hist-badge:hover{background:var(--hist);color:#fff}
.hist-icon{font-size:1rem}

/* XAI */
.xai-tabs{display:flex;gap:4px;background:var(--bg);border-radius:var(--r-sm);padding:4px;margin-bottom:16px}
.xai-tab{flex:1;padding:10px 12px;border:none;background:transparent;cursor:pointer;font-family:inherit;font-size:.82rem;font-weight:600;color:var(--text-2);border-radius:6px;transition:all var(--ease)}
.xai-tab:hover{color:var(--text)}
.xai-tab.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-s)}
.xai-panels{min-height:380px}
.xai-panel{display:none;animation:fadeIn .3s ease}
.xai-panel.active{display:block}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.med-img-box{position:relative;border-radius:var(--r);overflow:hidden;background:#0D1117}
.med-img{width:100%;height:320px;object-fit:cover;display:block}
.med-img-overlay{position:absolute;bottom:0;left:0;right:0;background:linear-gradient(transparent,rgba(0,0,0,.85));padding:16px 20px}
.med-badge{display:inline-block;background:rgba(26,86,219,.8);color:#fff;font-size:.7rem;font-weight:600;padding:3px 10px;border-radius:4px;margin-bottom:10px;letter-spacing:.05em}
.med-info-grid{display:flex;flex-direction:column;gap:4px}
.med-info-row{display:flex;justify-content:space-between;font-size:.78rem}
.mil{color:rgba(255,255,255,.5)}.miv{color:rgba(255,255,255,.9);font-weight:500}.miv.accent{color:#60A5FA}

/* 3D Viewer */
.three-container{width:100%;height:380px;background:#080C14;border-radius:var(--r);overflow:hidden;cursor:grab;position:relative}
.three-container:active{cursor:grabbing}
.three-controls{display:flex;justify-content:space-between;align-items:center;padding:10px 0;flex-wrap:wrap;gap:8px}
.three-hint{font-size:.72rem;color:var(--text-3)}
.three-legend{display:flex;gap:16px;flex-wrap:wrap}
.leg-item{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-2)}
.leg-dot{width:10px;height:10px;border-radius:3px}

/* 3D Control Toolbar */
.three-toolbar{display:flex;gap:6px;padding:8px 12px;background:#0f1724;border-radius:8px;margin-bottom:8px;flex-wrap:wrap;align-items:center}
.three-tool-btn{padding:6px 12px;border:1px solid #1e293b;border-radius:6px;background:transparent;color:#94a3b8;font-size:.75rem;font-family:inherit;cursor:pointer;transition:all var(--ease);display:flex;align-items:center;gap:4px}
.three-tool-btn:hover{border-color:#3b82f6;color:#60a5fa;background:rgba(59,130,246,.1)}
.three-tool-btn.active{border-color:#3b82f6;color:#60a5fa;background:rgba(59,130,246,.15)}
.three-slider-group{display:flex;align-items:center;gap:6px}
.three-slider-label{font-size:.7rem;color:#64748b;white-space:nowrap}
.three-slider{width:60px;height:4px;-webkit-appearance:none;appearance:none;background:#1e293b;border-radius:2px;outline:none}
.three-slider::-webkit-slider-thumb{-webkit-appearance:none;width:12px;height:12px;background:#3b82f6;border-radius:50%;cursor:pointer}

.xai-disclaimer{background:#FFFBEB;border:1px solid #FDE68A;border-radius:var(--r-sm);padding:10px 16px;font-size:.78rem;color:#92400E;margin-top:16px}

/* TIMELINE */
.timeline{display:flex;gap:24px}
.tl-item{flex:1;display:flex;flex-direction:column;align-items:center}
.tl-marker{display:flex;flex-direction:column;align-items:center;margin-bottom:16px}
.tl-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;position:relative}
.tl-dot.done{background:var(--green)}.tl-dot.current{background:var(--primary);box-shadow:0 0 0 4px rgba(26,86,219,.2)}.tl-dot.future{background:#CBD5E1}
.tl-pulse{position:absolute;inset:-6px;border-radius:50%;border:2px solid var(--primary);animation:pulseRing 2s infinite}
@keyframes pulseRing{0%{opacity:1;transform:scale(1)}100%{opacity:0;transform:scale(1.5)}}
.tl-line{width:140px;height:3px;background:var(--green);margin-top:-18px;position:relative;right:-88px}
.tl-item.current .tl-line{background:linear-gradient(90deg,var(--primary),#CBD5E1)}
.tl-item.future .tl-line{display:none}
.tl-card{background:var(--bg);border:1px solid var(--border);border-radius:var(--r);padding:20px;width:100%}
.tl-card.active-border{border-color:rgba(26,86,219,.3);background:rgba(26,86,219,.03)}
.tl-card.future-card{opacity:.6}
.tl-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}
.tl-date{font-size:.78rem;color:var(--text-2)}
.tl-badge{font-size:.68rem;font-weight:600;padding:3px 10px;border-radius:6px}
.tl-done{background:var(--green-bg);color:var(--green)}.tl-current{background:var(--primary-bg);color:var(--primary)}.tl-future{background:#F1F5F9;color:var(--text-3)}
.tl-phase{font-size:.95rem;font-weight:700}
.tl-phase-en{font-size:.72rem;color:var(--text-3);margin-bottom:12px}
.tl-details{display:flex;flex-direction:column;gap:6px}
.tl-row{display:flex;justify-content:space-between;font-size:.8rem}
.tl-k{color:var(--text-3)}.tl-v{font-weight:600}
.tl-v.highlight{color:var(--green)}.tl-v.warning{color:var(--orange)}.tl-v.trend-good{color:var(--green)}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:24px}
.stat-card{background:#fff;border-radius:var(--r);border:1px solid var(--border);padding:20px 24px;transition:all var(--ease)}
.stat-card:hover{box-shadow:var(--shadow-m);border-color:var(--border-h)}
.stat-val{font-size:1.8rem;font-weight:800;font-family:'Inter',sans-serif}
.stat-label{font-size:.8rem;color:var(--text-2);margin-top:2px}
.stat-trend{font-size:.75rem;font-weight:600;margin-top:4px}
.stat-trend.up{color:var(--green)}.stat-trend.neutral{color:var(--text-3)}

/* TABLES */
.data-table{width:100%;border-collapse:collapse}
.data-table th{text-align:left;padding:12px 16px;font-size:.78rem;font-weight:600;color:var(--text-2);border-bottom:1px solid var(--border);background:var(--bg)}
.data-table td{padding:14px 16px;font-size:.85rem;border-bottom:1px solid var(--border)}
.data-table tr:last-child td{border-bottom:none}
.data-table tbody tr{transition:all var(--ease)}
.data-table tbody tr:hover{background:#F8FAFC}
.font-mono{font-family:'Inter',monospace;font-size:.8rem}
.t-badge{font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:6px}
.t-success{background:var(--green-bg);color:var(--green)}.t-warning{background:#FEF3C7;color:#D97706}.t-danger{background:var(--red-bg);color:var(--red)}.t-neutral{background:#F1F5F9;color:var(--text-3)}

/* METRICS */
.metrics-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.metric-item{background:var(--bg);border-radius:var(--r-sm);padding:16px}
.metric-label{font-size:.78rem;color:var(--text-2);margin-bottom:6px}
.metric-val{font-size:1.5rem;font-weight:800;font-family:'Inter',sans-serif;margin-bottom:8px}
.metric-bar{height:6px;background:#E2E8F0;border-radius:3px;overflow:hidden}
.metric-fill{height:100%;border-radius:3px;transition:width 1s ease}

/* SETTINGS */
.settings-form{display:flex;flex-direction:column;gap:20px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:.82rem;font-weight:600;color:var(--text-2)}
.form-input{padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:.88rem;font-family:inherit;color:var(--text);transition:all var(--ease);background:#fff}
.form-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(26,86,219,.1)}
.form-input[readonly]{background:var(--bg);color:var(--text-2)}
.form-input-sm{width:60px;padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:.82rem;text-align:center;font-family:inherit}
.form-select{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-sm);font-size:.88rem;font-family:inherit;appearance:none;background:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E") no-repeat right 12px center #fff;cursor:pointer}
.form-select:focus{outline:none;border-color:var(--primary)}
.threshold-row{display:flex;gap:16px;align-items:center}
.thr-item{display:flex;align-items:center;gap:6px;font-size:.85rem;color:var(--text-2)}
.toggle-wrap{display:flex;align-items:center;gap:10px}
.toggle{position:relative;display:inline-block;width:44px;height:24px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;inset:0;background:#CBD5E1;border-radius:12px;cursor:pointer;transition:all var(--ease)}
.toggle-slider::before{content:'';position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:all var(--ease)}
.toggle input:checked+.toggle-slider{background:var(--primary)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px)}
.toggle-text{font-size:.82rem;color:var(--text-2)}

/* LOGIN */
.login-screen{position:fixed;inset:0;z-index:9999;background:linear-gradient(135deg,#0B1120 0%,#1A2744 50%,#0F172A 100%);display:flex;align-items:center;justify-content:center;transition:opacity .6s ease,visibility .6s ease}
.login-screen.hidden{opacity:0;visibility:hidden;pointer-events:none}
.login-particles{position:absolute;inset:0;overflow:hidden}
.login-particle{position:absolute;width:3px;height:3px;background:rgba(59,130,246,.3);border-radius:50%;animation:floatUp linear infinite}
@keyframes floatUp{0%{transform:translateY(100vh) scale(0);opacity:0}10%{opacity:1}90%{opacity:1}100%{transform:translateY(-10vh) scale(1);opacity:0}}
.login-container{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:32px;max-width:420px;width:100%;padding:0 24px}
.login-brand{text-align:center}
.login-logo{margin-bottom:16px}
.login-logo svg{width:72px;height:72px;filter:drop-shadow(0 4px 20px rgba(26,86,219,.5))}
.login-title{font-size:2.8rem;font-weight:900;color:#fff;letter-spacing:.1em;text-shadow:0 2px 20px rgba(26,86,219,.3)}
.login-subtitle-en{font-size:.85rem;color:rgba(255,255,255,.5);letter-spacing:.15em;margin-top:4px}
.login-desc{font-size:.82rem;color:rgba(255,255,255,.35);margin-top:12px;line-height:1.7}
.login-card{width:100%;background:rgba(255,255,255,.06);backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.1);border-radius:20px;padding:32px;box-shadow:0 8px 40px rgba(0,0,0,.3)}
.login-card-title{font-size:1.2rem;font-weight:700;color:#fff;text-align:center}
.login-card-sub{font-size:.75rem;color:rgba(255,255,255,.4);text-align:center;margin-bottom:24px}
.login-form{display:flex;flex-direction:column;gap:16px}
.login-field{display:flex;flex-direction:column;gap:6px}
.login-field label{font-size:.82rem;font-weight:600;color:rgba(255,255,255,.6)}
.login-input-wrap{position:relative;display:flex;align-items:center}
.login-input-icon{position:absolute;left:14px;color:rgba(255,255,255,.3)}
.login-input{width:100%;padding:12px 14px 12px 44px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);border-radius:10px;color:#fff;font-size:.9rem;font-family:inherit;transition:all var(--ease)}
.login-input:focus{outline:none;border-color:var(--primary-l);box-shadow:0 0 0 3px rgba(59,130,246,.2);background:rgba(255,255,255,.1)}
.login-input::placeholder{color:rgba(255,255,255,.25)}
.login-options{display:flex;justify-content:space-between;align-items:center;font-size:.8rem}
.login-remember{color:rgba(255,255,255,.4);display:flex;align-items:center;gap:6px;cursor:pointer}
.login-remember input{accent-color:var(--primary)}
.login-forgot{color:var(--primary-l);text-decoration:none;font-size:.8rem}
.login-forgot:hover{text-decoration:underline}
.login-btn{width:100%;padding:14px;background:linear-gradient(135deg,var(--primary),var(--primary-l));color:#fff;border:none;border-radius:10px;font-size:1rem;font-weight:700;font-family:inherit;cursor:pointer;transition:all var(--ease);display:flex;align-items:center;justify-content:center;gap:8px;margin-top:4px}
.login-btn:hover{box-shadow:0 4px 24px rgba(26,86,219,.5);transform:translateY(-2px)}
.login-btn-loader{display:flex;align-items:center;justify-content:center}
.login-footer-text{text-align:center;font-size:.72rem;color:rgba(255,255,255,.25);margin-top:8px}
.login-tech-tags{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.lt-tag{padding:6px 14px;background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);border-radius:20px;font-size:.72rem;color:rgba(255,255,255,.4)}

/* ========== 3D PRINTING PAGE ========== */
.print-layout{display:grid;grid-template-columns:1fr 380px;gap:24px}
.print-preview-card{grid-column:1}
.print-settings-card{grid-column:2;grid-row:1/3}
.print-info-cards{grid-column:1;display:grid;grid-template-columns:1fr 1fr;gap:24px}

.print-preview-container{width:100%;height:360px;background:#F0F2F5;border-radius:var(--r);overflow:hidden;position:relative}
.print-preview-container canvas{display:block}

.print-param-group{margin-bottom:20px}
.print-param-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;font-size:.82rem;font-weight:600;color:var(--text-2)}
.print-param-val{color:var(--primary);font-weight:700;font-family:'Inter',monospace}
.print-param-slider{width:100%;height:6px;-webkit-appearance:none;appearance:none;background:var(--border);border-radius:3px;outline:none}
.print-param-slider::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary);border-radius:50%;cursor:pointer;box-shadow:0 2px 6px rgba(26,86,219,.3)}
.print-param-hint{font-size:.72rem;color:var(--text-3);margin-top:4px}

.print-material-select{display:flex;gap:8px;flex-wrap:wrap}
.print-material-btn{flex:1;min-width:100px;padding:12px;border:1.5px solid var(--border);border-radius:var(--r-sm);background:#fff;cursor:pointer;font-family:inherit;font-size:.8rem;font-weight:600;color:var(--text-2);transition:all var(--ease);text-align:center}
.print-material-btn:hover{border-color:var(--primary-l);color:var(--primary)}
.print-material-btn.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}
.print-material-name{display:block;font-weight:700;margin-bottom:2px}
.print-material-desc{font-size:.72rem;color:var(--text-3);font-weight:400}

.print-estimate-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:20px}
.print-estimate-item{background:var(--bg);border-radius:var(--r-sm);padding:14px;text-align:center}
.print-estimate-label{font-size:.75rem;color:var(--text-3);margin-bottom:4px}
.print-estimate-val{font-size:1.3rem;font-weight:800;font-family:'Inter',sans-serif;color:var(--text)}
.print-estimate-unit{font-size:.72rem;color:var(--text-3)}

.print-actions{display:flex;gap:12px;margin-top:20px}
.print-actions .btn{flex:1}

.print-feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.print-feature-item{display:flex;align-items:flex-start;gap:12px;padding:16px;background:var(--bg);border-radius:var(--r-sm)}
.print-feature-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.1rem}
.print-feature-icon.blue{background:var(--primary-bg)}.print-feature-icon.green{background:var(--green-bg)}.print-feature-icon.orange{background:var(--orange-bg)}.print-feature-icon.purple{background:var(--purple-bg)}
.print-feature-title{font-size:.85rem;font-weight:700;margin-bottom:2px}
.print-feature-desc{font-size:.75rem;color:var(--text-3);line-height:1.5}

/* ========== HISTOTRIPSY MODAL ========== */
.hist-modal .modal{width:900px;max-width:95vw;max-height:92vh}
.hist-content{display:flex;flex-direction:column;gap:24px}
.hist-hero{background:linear-gradient(135deg,var(--hist-bg),#FEF3C7);border-radius:var(--r);padding:24px;display:flex;gap:20px;align-items:center}
.hist-hero-icon{font-size:3rem;flex-shrink:0}
.hist-hero-text{flex:1}
.hist-hero-title{font-size:1.3rem;font-weight:800;color:var(--hist);margin-bottom:6px}
.hist-hero-desc{font-size:.85rem;color:#92400E;line-height:1.6}
.hist-hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--hist);color:#fff;padding:4px 12px;border-radius:20px;font-size:.75rem;font-weight:600;margin-top:8px}

.hist-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.hist-section{background:var(--bg);border-radius:var(--r);padding:20px}
.hist-section-title{font-size:.95rem;font-weight:700;margin-bottom:12px;color:var(--text);display:flex;align-items:center;gap:8px}
.hist-section-title .icon{color:var(--hist);font-size:1.1rem}
.hist-section-text{font-size:.82rem;color:var(--text-2);line-height:1.8}
.hist-section-text p{margin-bottom:8px}
.hist-section-text ul{padding-left:18px;margin-bottom:8px}
.hist-section-text li{margin-bottom:4px}

.hist-compare-table{width:100%;border-collapse:collapse;font-size:.8rem;margin-top:12px}
.hist-compare-table th{text-align:left;padding:10px 12px;background:rgba(124,45,18,.08);color:var(--hist);font-weight:600;border-radius:6px 6px 0 0}
.hist-compare-table td{padding:10px 12px;border-bottom:1px solid var(--border)}
.hist-compare-table tr:last-child td{border-bottom:none}
.hist-compare-table .check{color:var(--green);font-weight:700}
.hist-compare-table .cross{color:var(--red)}
.hist-compare-table .partial{color:var(--orange)}

.hist-immune-flow{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin-top:12px}
.hist-immune-step{background:#fff;border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 14px;font-size:.78rem;text-align:center;flex:1;min-width:120px}
.hist-immune-step .step-title{font-weight:700;color:var(--hist);margin-bottom:2px}
.hist-immune-step .step-desc{color:var(--text-3);font-size:.72rem}
.hist-immune-arrow{color:var(--hist);font-size:1.2rem;font-weight:700}

.hist-limitation{background:#FFFBEB;border:1px solid #FDE68A;border-radius:var(--r);padding:16px}
.hist-limitation-title{font-size:.85rem;font-weight:700;color:#92400E;margin-bottom:8px;display:flex;align-items:center;gap:6px}
.hist-limitation-text{font-size:.8rem;color:#B45309;line-height:1.7}

.hist-indication{background:var(--green-bg);border:1px solid #86EFAC;border-radius:var(--r);padding:16px}
.hist-indication-title{font-size:.85rem;font-weight:700;color:var(--green);margin-bottom:8px}
.hist-indication-list{font-size:.8rem;color:#166534;line-height:1.8;padding-left:18px}
.hist-indication-list li{margin-bottom:2px}

/* ========== MODAL / UPLOAD ========== */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,.5);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;animation:fadeIn .2s ease}
.modal-overlay.show{display:flex}
.modal{background:#fff;border-radius:var(--r-lg);width:720px;max-width:90vw;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.2)}
.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}
.modal-title-group{display:flex;align-items:center;gap:12px}
.modal-title{font-size:1.05rem;font-weight:700}
.modal-close{background:none;border:none;font-size:1.3rem;cursor:pointer;color:var(--text-3);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:all var(--ease)}
.modal-close:hover{color:var(--text);background:var(--bg)}
.modal-body{padding:24px}
.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border)}
.upload-cats{display:flex;gap:6px;margin-bottom:20px;flex-wrap:wrap}
.ucat{display:flex;align-items:center;gap:6px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--r-sm);background:#fff;cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;color:var(--text-2);transition:all var(--ease);flex-direction:column;flex:1;min-width:100px;text-align:center}
.ucat:hover{border-color:var(--primary-l);color:var(--primary)}
.ucat.active{border-color:var(--primary);background:var(--primary-bg);color:var(--primary)}
.ucat-fmt{font-size:.65rem;font-weight:400;color:var(--text-3);margin-top:2px;display:block}
.ucat.active .ucat-fmt{color:var(--primary)}
.dropzone{border:2px dashed var(--border);border-radius:var(--r);padding:40px 20px;text-align:center;cursor:pointer;transition:all var(--ease);margin-bottom:16px;background:#FAFBFC}
.dropzone:hover,.dropzone.drag-over{border-color:var(--primary);background:var(--primary-bg)}
.dropzone-icon{margin-bottom:12px}
.dropzone-text{font-size:.92rem;font-weight:600;color:var(--text);margin-bottom:6px}
.dropzone-link{color:var(--primary);cursor:pointer;text-decoration:underline}
.dropzone-hint{font-size:.78rem;color:var(--text-3);margin-bottom:4px}
.dropzone-limit{font-size:.72rem;color:var(--text-3)}
.file-queue{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:200px;overflow-y:auto}
.fq-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg);border-radius:var(--r-sm);border:1px solid var(--border);animation:fadeIn .3s ease}
.fq-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.8rem}
.fq-icon.us{background:#DBEAFE;color:var(--primary)}.fq-icon.ceus{background:var(--purple-bg);color:var(--purple)}.fq-icon.ct{background:var(--cyan-bg);color:var(--cyan)}.fq-icon.path{background:var(--orange-bg);color:var(--orange)}.fq-icon.lab{background:var(--green-bg);color:var(--green)}
.fq-info{flex:1;min-width:0}
.fq-name{font-size:.85rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.fq-detail{font-size:.72rem;color:var(--text-3);display:flex;gap:8px;margin-top:2px}
.fq-progress{height:4px;background:var(--border);border-radius:2px;overflow:hidden;margin-top:4px}
.fq-progress-fill{height:100%;background:linear-gradient(90deg,var(--primary),var(--primary-l));border-radius:2px;transition:width .3s ease}
.fq-status{font-size:.72rem;font-weight:600;flex-shrink:0}
.fq-status.uploading{color:var(--primary)}.fq-status.done{color:var(--green)}.fq-status.error{color:var(--red)}
.fq-remove{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:1rem;padding:4px;border-radius:4px;transition:all var(--ease);flex-shrink:0}
.fq-remove:hover{color:var(--red);background:#FEE2E2}
.upload-meta{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.upload-meta-group{display:flex;flex-direction:column;gap:6px}
.upload-meta-group label{font-size:.82rem;font-weight:600;color:var(--text-2)}

/* ========== CLINICAL PATIENT WORKBENCH ========== */
.clinical-dashboard{display:flex;flex-direction:column;gap:20px}
.clinical-hero{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px 24px;border:1px solid #D7E4F5;border-radius:var(--r-lg);background:linear-gradient(135deg,#fff 0%,#F6FAFF 52%,#EAF4FF 100%);box-shadow:var(--shadow-s)}
.clinical-eyebrow{font-size:.72rem;font-weight:800;color:var(--primary);letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px}
.hero-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
#startAnalysisBtn.running{background:linear-gradient(135deg,#059669,#34D399);pointer-events:none}
#startAnalysisBtn.done{background:var(--green)}
.clinical-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.clinical-stat-card{position:relative;overflow:hidden;background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:16px 18px;min-height:108px;box-shadow:var(--shadow-s)}
.clinical-stat-card::before{content:"";position:absolute;inset:0 auto 0 0;width:4px;background:var(--primary)}
.clinical-stat-card.accent-green::before{background:var(--green)}
.clinical-stat-card.accent-orange::before{background:var(--orange)}
.clinical-stat-card.accent-red::before{background:var(--red)}
.clinical-stat-card .stat-k{font-size:.76rem;color:var(--text-2);font-weight:700;display:block}
.clinical-stat-card strong{font-size:1.9rem;font-family:'Inter',sans-serif;font-weight:800;display:block;margin:8px 0 2px;color:var(--text)}
.clinical-stat-card .stat-note{font-size:.72rem;color:var(--text-3)}
.patient-workspace{display:grid;grid-template-columns:318px minmax(0,1fr);gap:20px;align-items:start}
.patient-queue-panel{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-s);padding:18px;position:sticky;top:90px}
.queue-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.queue-head h3{font-size:1rem;font-weight:800}
.queue-head span{font-size:.72rem;color:var(--text-3)}
.queue-add{width:32px;height:32px;border-radius:8px;border:none;background:var(--primary);color:#fff;font-size:1.2rem;cursor:pointer}
.queue-search{height:38px;border:1px solid var(--border);background:#F8FAFC;border-radius:8px;color:var(--text-3);font-size:.78rem;display:flex;align-items:center;padding:0 12px;margin-bottom:12px}
.queue-tabs{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;background:#F1F5F9;border-radius:8px;padding:4px;margin-bottom:14px}
.queue-tabs button{border:none;background:transparent;border-radius:6px;padding:7px 0;font-family:inherit;font-size:.76rem;font-weight:700;color:var(--text-2);cursor:pointer}
.queue-tabs button.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-s)}
.queue-list{display:flex;flex-direction:column;gap:10px}
.queue-patient{display:grid;grid-template-columns:38px 1fr;gap:10px;padding:12px;border:1px solid var(--border);border-radius:10px;background:#fff;cursor:pointer;transition:all var(--ease)}
.queue-patient:hover,.queue-patient.active{border-color:#A9C8F8;background:#F6FAFF;box-shadow:0 6px 18px rgba(26,86,219,.08)}
.qp-avatar{width:38px;height:38px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-l));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800}
.qp-avatar.teal{background:linear-gradient(135deg,#0891B2,#22D3EE)}
.qp-avatar.red{background:linear-gradient(135deg,#DC2626,#FB7185)}
.qp-avatar.purple{background:linear-gradient(135deg,#7C3AED,#A78BFA)}
.qp-main{min-width:0}.qp-main strong{font-size:.9rem;display:block}.qp-main span{font-size:.72rem;color:var(--text-3);display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.qp-tags{grid-column:2;display:flex;gap:6px;flex-wrap:wrap;margin-top:-4px}
.status-pill{display:inline-flex;align-items:center;height:24px;border-radius:999px;padding:0 9px;font-size:.7rem;font-weight:800;white-space:nowrap}
.status-pill.good{background:var(--green-bg);color:var(--green)}
.status-pill.warn{background:#FEF3C7;color:#B45309}
.status-pill.danger{background:var(--red-bg);color:var(--red)}
.status-pill.neutral{background:#EEF2FF;color:#475569}
.status-pill.running{background:#DBEAFE;color:var(--primary)}
.queue-summary{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:14px}
.queue-summary div{background:#F8FAFC;border-radius:8px;padding:12px;text-align:center}.queue-summary span{display:block;font-size:.72rem;color:var(--text-3)}.queue-summary strong{font-size:1.3rem;font-family:'Inter',sans-serif}
.patient-command{min-width:0;display:flex;flex-direction:column;gap:18px}
.patient-overview-panel{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-s);padding:20px;display:grid;grid-template-columns:minmax(0,1.2fr) minmax(360px,.8fr);gap:20px;align-items:center}
.overview-identity{display:flex;align-items:center;gap:14px;min-width:0}
.patient-avatar.xl{width:56px;height:56px;font-size:1.3rem}
.overview-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.overview-metrics div{background:#F8FAFC;border:1px solid var(--border);border-radius:10px;padding:12px;text-align:center}
.overview-metrics span{display:block;font-size:.72rem;color:var(--text-3);font-weight:700}.overview-metrics strong{display:block;font-size:1.05rem;font-weight:800;margin:3px 0}.overview-metrics small{font-size:.7rem;color:var(--text-3)}
.command-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:18px}
.work-panel{background:#fff;border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-s);padding:18px;min-width:0}
.work-panel:hover{border-color:var(--border-h);box-shadow:var(--shadow-m)}
.section-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.section-title-row h3{font-size:1rem;font-weight:800}
.pred-result.compact{gap:20px;margin-bottom:14px}
.analysis-result-state.is-hidden,.treatment-result-state.is-hidden,.analysis-pending-state.is-hidden,.treatment-pending-state.is-hidden{display:none}
.analysis-pending-state{min-height:360px;border:1px dashed #BDD3F4;border-radius:12px;background:linear-gradient(135deg,#F8FBFF,#F3F8FF);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:28px}
.analysis-wait-icon{width:58px;height:58px;border-radius:16px;background:linear-gradient(135deg,#EAF2FF,#DCEBFF);color:var(--primary);font-family:'Inter',sans-serif;font-weight:900;display:flex;align-items:center;justify-content:center;margin-bottom:14px;box-shadow:inset 0 0 0 1px #C8DCF8}
.analysis-pending-state h4{font-size:1rem;font-weight:800;margin-bottom:8px}
.analysis-pending-state p{max-width:440px;font-size:.82rem;color:var(--text-2);line-height:1.7;margin-bottom:16px}
.analysis-ready-list{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;width:min(420px,100%)}
.analysis-ready-list span{background:#fff;border:1px solid var(--border);border-radius:8px;padding:9px 10px;font-size:.74rem;font-weight:700;color:var(--text-2)}
.report-strip{display:grid;grid-template-columns:auto 1fr auto 1fr;align-items:center;gap:7px;background:#F1F7FF;border:1px solid #D7E8FF;border-radius:10px;padding:10px 12px;margin-top:12px}
.report-strip strong{color:var(--primary);font-family:'Inter',sans-serif;font-size:1.05rem}.report-strip span{font-size:.72rem;color:var(--text-2);font-weight:700}
.fusion-flow{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:14px}
.fusion-flow div{background:#F8FAFC;border:1px solid var(--border);border-radius:10px;padding:12px}
.fusion-flow div.pending{border-style:dashed;opacity:.7}
.fusion-flow strong{font-size:.9rem;display:block}.fusion-flow span{font-size:.72rem;color:var(--text-3);display:block;margin-top:2px}
.data-progress{height:8px;background:#E2E8F0;border-radius:999px;overflow:hidden;margin:2px 0 14px}.data-progress span{display:block;height:100%;background:linear-gradient(90deg,var(--primary),#22D3EE);border-radius:999px}
.pipeline-panel .pipeline{margin-bottom:14px}
.therapy-card{background:linear-gradient(135deg,#F0FDF4,#EFF6FF);border:1px solid #CFE7D8;border-radius:10px;padding:14px;margin-bottom:12px}
.therapy-card strong{display:block;font-size:.95rem;margin-bottom:5px}.therapy-card span{font-size:.78rem;color:var(--text-2);line-height:1.6}
.treatment-pending-state{background:#F8FAFC;border:1px dashed #CBD5E1;border-radius:10px;padding:18px;min-height:172px;display:flex;flex-direction:column;justify-content:center}
.treatment-pending-state strong{font-size:.95rem;margin-bottom:8px}.treatment-pending-state span{font-size:.8rem;color:var(--text-2);line-height:1.7}
.mini-link{border:none;background:#EAF2FF;color:var(--primary);border-radius:999px;padding:6px 12px;font-family:inherit;font-size:.74rem;font-weight:800;cursor:pointer}
.todo-list{display:flex;flex-direction:column;gap:9px;margin-bottom:12px}.todo-list div{font-size:.8rem;color:var(--text-2);display:flex;align-items:center;gap:8px}.todo-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.todo-dot.blue{background:var(--primary)}.todo-dot.orange{background:var(--orange)}.todo-dot.green{background:var(--green)}
.follow-loop-panel{padding-bottom:16px}
.compact-timeline{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.compact-timeline div{position:relative;background:#F8FAFC;border:1px solid var(--border);border-radius:10px;padding:12px;min-height:96px}
.compact-timeline div::before{content:"";position:absolute;left:12px;top:12px;width:8px;height:8px;border-radius:50%;background:#CBD5E1}
.compact-timeline div.done::before{background:var(--green)}.compact-timeline div.current{border-color:#8CB9F7;background:#F3F8FF}.compact-timeline div.current::before{background:var(--primary);box-shadow:0 0 0 5px rgba(26,86,219,.12)}
.compact-timeline span,.compact-timeline em{display:block;font-size:.72rem;color:var(--text-3);font-style:normal;margin-left:16px}.compact-timeline strong{display:block;font-size:.84rem;margin:16px 0 6px 16px}

/* ========== CLINICAL 3D PRINT PAGE ========== */
.threed-header{display:flex;align-items:center;justify-content:space-between;gap:20px}
.threed-header-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;min-width:420px}
.threed-header-metrics div{background:#fff;border:1px solid var(--border);border-radius:10px;padding:12px 16px;text-align:center}.threed-header-metrics span{display:block;font-size:.72rem;color:var(--text-3);font-weight:700}.threed-header-metrics strong{font-size:1rem;font-weight:800}
.clinical-print-layout{grid-template-columns:minmax(0,1fr) 390px;align-items:start}
.clinical-viewport-card{min-height:0}
.clinical-settings-card{position:sticky;top:90px}
.view-mode-switch{display:flex;gap:6px;background:#F1F5F9;border-radius:8px;padding:4px}.view-mode-switch button{border:none;background:transparent;border-radius:6px;padding:7px 10px;font-family:inherit;font-size:.72rem;font-weight:800;color:var(--text-2);cursor:pointer}.view-mode-switch button.active{background:#fff;color:var(--primary);box-shadow:var(--shadow-s)}
.print-preview-container.enhanced{height:560px;background:linear-gradient(180deg,#F8FBFF 0%,#EEF4FA 100%);border:1px solid #D6E2EF}
.print-preview-container.reference-viewport{display:flex;align-items:center;justify-content:center;background:#858585;overflow:hidden}
.reference-gif-stage{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#858585;--model-scale:1}
.reference-liver-gif{display:block;max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transform:scale(var(--model-scale));transform-origin:center center}
.quality-panel{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin:12px 0}
.quality-row{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:10px 11px;background:#F8FAFC;border:1px solid var(--border);border-radius:8px}.quality-row span{font-size:.72rem;color:var(--text-3);font-weight:700}.quality-row strong{font-size:.82rem}.quality-row.ok strong{color:var(--green)}.quality-row.warn strong{color:var(--orange)}
.model-info-strip{grid-column:1/-1;display:grid;grid-template-columns:repeat(5,1fr);gap:12px}
.model-info-card{background:#fff;border:1px solid var(--border);border-radius:var(--r);padding:14px 16px;box-shadow:var(--shadow-s)}.model-info-card span{font-size:.72rem;color:var(--text-3);font-weight:700;display:block}.model-info-card strong{font-size:1rem;font-weight:800;display:block;margin:5px 0}.model-info-card em{font-size:.72rem;color:var(--text-3);font-style:normal}.model-info-card.danger strong{color:var(--red)}
.clinical-use-card{grid-column:1/-1}
.mini-section-title{font-size:.95rem;font-weight:800;margin-bottom:12px}

/* ========== RESPONSIVE ========== */
@media(max-width:1400px){
    .dashboard-row{grid-template-columns:1fr}
    .timeline{flex-direction:column}
    .tl-line{display:none}
    .stats-row{grid-template-columns:repeat(2,1fr)}
    .print-layout{grid-template-columns:1fr}
    .print-settings-card{grid-column:1;grid-row:auto}
    .print-info-cards{grid-column:1}
    .hist-grid{grid-template-columns:1fr}
    .patient-workspace{grid-template-columns:1fr}
    .patient-queue-panel,.clinical-settings-card{position:static}
    .patient-overview-panel,.command-grid{grid-template-columns:1fr}
    .model-info-strip{grid-template-columns:repeat(2,1fr)}
    .threed-header{align-items:flex-start;flex-direction:column}
    .threed-header-metrics{min-width:0;width:100%}
}
@media(max-width:768px){
    .sidebar{display:none}
    .main-wrapper{margin-left:0}
    .top-header{padding:12px 16px;align-items:flex-start;gap:12px;flex-direction:column}
    .page-content{padding:18px 14px}
    .clinical-hero{align-items:flex-start;flex-direction:column;padding:18px}
    .clinical-stats,.overview-metrics,.compact-timeline,.model-info-strip,.threed-header-metrics{grid-template-columns:1fr}
    .hero-actions{width:100%}.hero-actions .btn{width:100%}
    .patient-name-row,.patient-meta{flex-wrap:wrap}
    .overview-identity{align-items:flex-start}
    .fusion-flow,.quality-panel{grid-template-columns:1fr}
    .print-preview-container.enhanced{height:380px}
    .metrics-grid{grid-template-columns:1fr}
    .stats-row{grid-template-columns:1fr}
    .print-feature-grid{grid-template-columns:1fr}
    .hist-modal .modal{width:100vw;max-width:100vw;margin:0;border-radius:0}
}

/* ============================================================
   HepaVision Pro product skin
   ============================================================ */
:root{--primary:#2563EB;--primary-l:#38BDF8;--primary-bg:#EAF4FF;--green:#0F766E;--green-bg:#E6FFFA;--cyan:#0891B2;--cyan-bg:#E6F7FB;--orange:#D97706;--orange-bg:#FFF7E6;--red:#DC2626;--red-bg:#FEE2E2;--bg:#EEF4F8;--bg-card:#FFFFFF;--text:#122033;--text-2:#5D6B7C;--text-3:#8B9AAF;--border:#DCE6F0;--border-h:#BBD0E5;--shadow-s:0 1px 2px rgba(15,23,42,.05);--shadow-m:0 12px 30px rgba(15,23,42,.09);--r:8px;--r-lg:8px;--r-sm:6px}
body{background:linear-gradient(180deg,#F4F8FC 0%,#EDF4F8 100%);color:var(--text)}
.login-screen{display:none!important}
.sidebar{background:linear-gradient(180deg,#081421 0%,#111C2D 58%,#0A1220 100%)}
.nav-item.active{background:linear-gradient(135deg,#0F766E,#2563EB);box-shadow:0 12px 26px rgba(37,99,235,.28)}
.top-header{background:rgba(255,255,255,.88);backdrop-filter:blur(16px)}
.card,.work-panel,.patient-queue-panel,.patient-overview-panel,.stat-card{border-radius:8px}
.clinical-hero{border-color:#C8D9EA;background:linear-gradient(135deg,#FFFFFF 0%,#F4FAFF 58%,#EAF7F6 100%)}
.clinical-eyebrow{color:#0F766E}.btn-primary{background:linear-gradient(135deg,#0F766E,#2563EB)}.btn-primary:hover{box-shadow:0 12px 28px rgba(37,99,235,.24);transform:translateY(-1px)}
.btn-ghost{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.28);color:#fff}.btn-ghost:hover{background:rgba(255,255,255,.18)}.btn-xl{min-height:48px;padding:14px 22px;font-size:.94rem}

body.is-home{display:block;min-height:100vh;overflow-x:hidden;background:#07111F}
body.is-home .sidebar,body.is-home .top-header{display:none}
body.is-home .main-wrapper{margin-left:0;min-height:100vh}
body.is-home #page-home{padding:0;animation:none}
.home-hero{position:relative;min-height:92vh;display:flex;align-items:center;overflow:hidden;background:#07111F;color:#fff}
.home-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.9) contrast(1.04) brightness(.68)}
.home-hero-overlay{position:absolute;inset:0;background:linear-gradient(90deg,rgba(5,13,24,.94) 0%,rgba(5,13,24,.82) 42%,rgba(5,13,24,.42) 100%)}
.home-nav{position:absolute;top:0;left:0;right:0;z-index:3;display:flex;align-items:center;justify-content:space-between;padding:24px clamp(20px,5vw,72px)}
.home-brand-mark{display:flex;align-items:center;gap:12px;font-weight:800;letter-spacing:.02em}.brand-symbol{display:grid;place-items:center;width:38px;height:38px;border-radius:8px;background:linear-gradient(135deg,#0F766E,#2563EB);font-size:.8rem;letter-spacing:.08em}
.home-nav-actions{display:flex;align-items:center;gap:16px}.home-nav-actions a{color:rgba(255,255,255,.78);text-decoration:none;font-size:.9rem;font-weight:700}.home-nav-actions a:hover{color:#fff}
.home-hero-content{position:relative;z-index:2;width:min(760px,calc(100% - 40px));margin-left:clamp(20px,7vw,96px);padding-top:36px}
.home-eyebrow{display:block;color:#8EE7D6;font-size:.78rem;font-weight:900;letter-spacing:.16em;text-transform:uppercase;margin-bottom:16px}
.home-hero h1{font-size:clamp(3.8rem,9vw,8.8rem);line-height:.9;letter-spacing:0;font-weight:900;margin-bottom:24px}
.home-hero p{max-width:680px;font-size:clamp(1rem,1.4vw,1.22rem);line-height:1.85;color:rgba(255,255,255,.78)}
.home-hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:30px}
.home-proof-row{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;width:min(620px,100%);margin-top:36px}
.home-proof-row div{min-height:82px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.08);backdrop-filter:blur(14px);border-radius:8px;padding:16px}
.home-proof-row strong{display:block;font-size:1.8rem;font-weight:900;color:#fff}.home-proof-row span{display:block;margin-top:4px;color:rgba(255,255,255,.68);font-size:.82rem}
.home-band{padding:76px clamp(20px,6vw,88px);background:#F4F8FC}
.home-section-head{max-width:760px;margin-bottom:28px}.home-section-head span,.home-preview-copy span{display:block;color:#0F766E;font-size:.78rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px}
.home-section-head h2,.home-preview-copy h2{font-size:clamp(1.9rem,3vw,3rem);line-height:1.15;letter-spacing:0;margin-bottom:12px}
.home-section-head p,.home-preview-copy p{color:var(--text-2);font-size:1rem;line-height:1.8}
.home-capability-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}
.home-capability-grid article{background:#fff;border:1px solid var(--border);border-radius:8px;padding:24px;box-shadow:var(--shadow-s)}
.home-capability-grid strong{display:block;color:#0F766E;font-size:.78rem;margin-bottom:24px}.home-capability-grid h3{font-size:1.05rem;margin-bottom:10px}.home-capability-grid p{font-size:.86rem;color:var(--text-2);line-height:1.7}
.home-preview-band{display:grid;grid-template-columns:minmax(0,.9fr) minmax(360px,.8fr);gap:28px;align-items:center;background:#EAF2F8}
.home-report-preview{background:#071421;color:#fff;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:26px;box-shadow:0 28px 70px rgba(8,20,33,.22)}
.preview-score{display:flex;align-items:end;gap:12px;margin-bottom:26px}.preview-score strong{font-size:5rem;line-height:.85}.preview-score span{color:#8EE7D6;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;font-weight:900}
.preview-lines{display:grid;gap:12px;margin-bottom:24px}.preview-lines span{display:block;height:10px;border-radius:999px;background:linear-gradient(90deg,#0F766E,#38BDF8)}
.preview-risk{border-top:1px solid rgba(255,255,255,.12);padding-top:18px}.preview-risk b,.preview-risk em{display:block}.preview-risk em{margin-top:5px;color:rgba(255,255,255,.58);font-style:normal}

.predict-header{align-items:center}.predict-mode-badge{padding:8px 12px;border-radius:999px;background:#E6FFFA;color:#0F766E;font-size:.76rem;font-weight:900}
.predict-command-layout{display:grid;grid-template-columns:minmax(340px,.8fr) minmax(0,1.2fr);gap:22px;margin-bottom:22px}
.predict-case-panel,.predict-upload-panel,.predict-result-panel{background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-s);padding:22px}
.predict-case-hero{display:flex;gap:16px;align-items:center;margin-bottom:18px}.predict-case-hero h3{font-size:1.35rem;margin:2px 0}.predict-case-hero small{font-size:.84rem;color:var(--text-3);font-weight:700}.predict-case-hero p{color:var(--text-2);font-size:.84rem}
.predict-case-metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}.predict-case-metrics div{background:#F6FAFD;border:1px solid var(--border);border-radius:8px;padding:14px}.predict-case-metrics span{display:block;font-size:.72rem;color:var(--text-3);font-weight:800}.predict-case-metrics strong{display:block;margin-top:5px}
.predict-disclaimer-inline{margin-top:14px;padding:12px;border-left:3px solid #D97706;background:#FFF7E6;color:#87520A;font-size:.78rem;line-height:1.65;border-radius:6px}
.predict-tabs{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;background:#EEF4F8;padding:5px;border-radius:8px;margin-bottom:16px}.predict-tabs button{border:none;background:transparent;border-radius:6px;padding:10px;font-family:inherit;font-weight:900;color:var(--text-2);cursor:pointer}.predict-tabs button.active{background:#fff;color:#0F766E;box-shadow:var(--shadow-s)}
.predict-dropzone{border:1.5px dashed #BBD0E5;border-radius:8px;padding:34px 22px;text-align:center;background:#F8FBFE;cursor:pointer;transition:all var(--ease)}.predict-dropzone.drag-over,.predict-dropzone:hover{border-color:#0F766E;background:#F2FFFC}.predict-dropzone input{display:none}
.predict-drop-icon{display:grid;place-items:center;width:54px;height:54px;border-radius:14px;margin:0 auto 14px;background:linear-gradient(135deg,#0F766E,#2563EB);color:#fff;font-weight:900;letter-spacing:.08em}.predict-dropzone h3{font-size:1.12rem;margin-bottom:8px}.predict-dropzone p{color:var(--text-2);font-size:.84rem;line-height:1.65}
.predict-file-list{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:16px;color:var(--text-3);font-size:.8rem}.predict-file-list span{background:#fff;border:1px solid var(--border);border-radius:999px;padding:7px 10px;color:var(--text-2);font-weight:700}.predict-file-list em{font-style:normal;color:var(--text-3);font-weight:500;margin-left:5px}
.predict-action-row{display:flex;align-items:center;gap:14px;margin-top:16px}.predict-error{color:var(--red);font-size:.82rem;min-height:22px}
.predict-empty-state{min-height:220px;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-3);gap:8px}.predict-empty-state strong{font-size:1.05rem;color:var(--text)}
.hepa-report-card{display:grid;gap:18px}.hepa-report-top{display:flex;justify-content:space-between;gap:20px}.hepa-report-top h3{font-size:1.8rem;letter-spacing:0;margin:4px 0 10px}.hepa-report-top p{max-width:680px;color:var(--text-2);line-height:1.7}
.hepa-score-ring{display:grid;place-items:center;width:132px;height:132px;border-radius:50%;border:3px solid #0F766E;flex:0 0 auto;text-align:center}.hepa-score-ring[data-level=moderate]{border-color:#D97706}.hepa-score-ring strong{display:block;font-size:2.2rem}.hepa-score-ring span{font-size:.72rem;color:var(--text-3);font-weight:800;text-transform:uppercase}
.hepa-factor-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.hepa-factor-grid div{background:#F6FAFD;border:1px solid var(--border);border-radius:8px;padding:14px}.hepa-factor-grid strong{display:block}.hepa-factor-grid span{display:block;margin-top:5px;color:var(--text-3);font-size:.75rem}
.hepa-report-body{display:grid;grid-template-columns:minmax(0,.8fr) minmax(0,1fr);gap:22px}.hepa-report-body h4{font-size:.95rem;margin-bottom:10px}.hepa-report-body li{margin-left:18px;color:var(--text-2);line-height:1.7}.hepa-report-body p{margin-top:10px;color:var(--text-2);line-height:1.6}
.hepa-bar{position:relative;height:36px;background:#EEF4F8;border-radius:8px;overflow:hidden;margin-bottom:10px}.hepa-bar span{display:block;height:100%;background:linear-gradient(90deg,#0F766E,#38BDF8)}.hepa-bar em{position:absolute;left:12px;top:9px;font-style:normal;font-size:.78rem;font-weight:900;color:#102033}
.hepa-report-footer{padding:12px 14px;border-radius:8px;background:#FFF7E6;color:#87520A;border:1px solid #F3D08B;font-size:.82rem;line-height:1.55}

@media(max-width:980px){.home-nav{position:absolute;padding:18px 16px}.home-nav-actions a{display:none}.home-hero{min-height:88vh}.home-hero-content{margin:0 auto;padding:104px 20px 42px;width:100%}.home-proof-row,.home-capability-grid,.home-preview-band,.predict-command-layout,.hepa-report-body{grid-template-columns:1fr}.home-preview-band{gap:22px}.predict-case-metrics,.hepa-factor-grid{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.home-hero h1{font-size:3.4rem}.home-hero-actions,.predict-action-row,.hepa-report-top{flex-direction:column;align-items:stretch}.home-proof-row,.predict-case-metrics,.hepa-factor-grid{grid-template-columns:1fr}.hepa-score-ring{width:112px;height:112px}}

@media(max-width:768px){
    .top-header{flex-direction:row;align-items:center;padding:10px 12px;gap:10px}
    .patient-context{min-width:0;flex:1;gap:10px}
    .patient-avatar{width:38px;height:38px;border-radius:10px;font-size:.95rem}
    .patient-info{min-width:0}
    .patient-name-row{gap:6px}
    .patient-name{font-size:1rem;line-height:1.1}
    .patient-id{font-size:.7rem;max-width:116px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .patient-stage-badge{font-size:.62rem;padding:2px 7px;border-radius:6px}
    .patient-meta{font-size:.68rem;line-height:1.45;gap:4px}
    .header-actions{gap:8px;flex-shrink:0}
    .btn-icon{width:36px;height:36px;border-radius:8px}
    .doctor-profile{padding:5px 8px;border-radius:8px}
    .doctor-avatar{width:30px;height:30px;border-radius:8px}
    .doctor-name{font-size:.76rem}
    .doctor-dept,.doctor-profile svg{display:none}
}

@media(max-width:430px){
    .top-header{align-items:flex-start}
    .patient-context{align-items:flex-start}
    .patient-id{max-width:96px}
    .header-actions{padding-top:2px}
}
