*,:after,:before{box-sizing:border-box}body{background:#f0f4f8;color:#0f2537;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;margin:0}.main-header{background:linear-gradient(135deg,#0f2537,#1e3a5f 40%,#2d5aa0 75%,#4a90b8);color:#fff;overflow:hidden;padding:64px 24px 56px;position:relative}.main-header:before{background-image:linear-gradient(#ffffff0a 1px,#0000 0),linear-gradient(90deg,#ffffff0a 1px,#0000 0);background-size:40px 40px;content:"";inset:0;pointer-events:none;position:absolute}.main-header:after{background:#f0f4f8;bottom:-2px;-webkit-clip-path:ellipse(58% 100% at 50% 100%);clip-path:ellipse(58% 100% at 50% 100%);content:"";height:48px;left:0;position:absolute;right:0}.hero-content{margin:0 auto;max-width:1200px;position:relative;text-align:center;z-index:1}.hero-title{font-size:42px;font-weight:800;letter-spacing:-.5px;margin:0 0 12px;text-shadow:0 2px 16px #00000040}.hero-subtitle{font-size:16px;letter-spacing:.3px;margin:0;opacity:.85}.app-container{margin:0 auto;max-width:1200px;padding:0 24px 48px}.main-grid{grid-gap:28px;align-items:start;display:grid;gap:28px;grid-template-columns:380px 1fr;margin-top:48px}.card{background:#fff;border:1px solid #e4edf5;border-radius:16px;box-shadow:0 4px 24px #0f253712;padding:24px}.card-title{border-bottom:1px solid #e4edf5;color:#64748b;font-size:11px;font-weight:700;letter-spacing:1px;margin:0 0 20px;padding-bottom:12px;text-transform:uppercase}.input-group{margin-bottom:16px}.input-group label{align-items:center;color:#334155;display:flex;font-size:13px;font-weight:600;gap:6px;margin-bottom:6px}.input-group input,.input-group select{-webkit-appearance:none;appearance:none;background:#fafcfe;border:1.5px solid #d1dce8;border-radius:10px;color:#0f2537;font-size:14px;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.input-group select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='m1 1 5 5 5-5' stroke='%234a90b8' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;padding-right:36px}.input-group input:focus,.input-group select:focus{background:#fff;border-color:#4a90b8;box-shadow:0 0 0 3px #4a90b826}.input-group input:hover,.input-group select:hover{border-color:#7fb3d3}.tooltip-icon{align-items:center;background:#e4edf5;border-radius:50%;color:#4a90b8;cursor:help;display:inline-flex;flex-shrink:0;font-size:10px;font-weight:700;height:16px;justify-content:center;position:relative;transition:background .2s;width:16px}.tooltip-icon:hover{background:#4a90b8;color:#fff}.tooltip-icon:after{background:#0f2537;border-radius:8px;bottom:calc(100% + 8px);box-shadow:0 4px 16px #0003;color:#fff;content:attr(data-tooltip);font-size:12px;font-weight:400;left:50%;line-height:1.5;opacity:0;padding:8px 12px;pointer-events:none;position:absolute;transform:translateX(-50%);transition:opacity .2s;white-space:normal;width:210px;z-index:200}.tooltip-icon:hover:after{opacity:1}.logp-gauge-container{margin:-4px 0 20px}.gauge{background:linear-gradient(90deg,#3b82f6,#10b981,#84cc16,#f59e0b,#ef4444);border-radius:10px;height:10px;margin-bottom:6px;position:relative}.gauge-dot{background:#fff;border:3px solid #1f2937;border-radius:50%;box-shadow:0 2px 8px #0003;height:20px;position:absolute;top:-5px;transition:left .45s cubic-bezier(.34,1.56,.64,1);width:20px}.gauge-labels{color:#94a3b8;display:flex;font-size:10px;justify-content:space-between}.gauge-value-label{color:#2d5aa0;font-size:11px;font-weight:600}.hsp-section{border-top:1px solid #e4edf5;margin-top:4px;padding-top:16px}.hsp-header{margin-bottom:12px}.hsp-header h4{align-items:center;color:#334155;display:flex;font-size:13px;font-weight:600;gap:6px;margin:0}.optional-label{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;color:#94a3b8;font-size:10px;font-weight:600;letter-spacing:.4px;padding:1px 6px;text-transform:uppercase}.hsp-hint{color:#94a3b8;font-size:12px;font-style:italic;margin:2px 0 10px}.hsp-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(3,1fr)}.hsp-grid .input-group{margin-bottom:0}.error-message{animation:fadeInUp .25s ease;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-size:13px;line-height:1.5;margin:8px 0 14px;padding:10px 14px}.predict-button{align-items:center;background:linear-gradient(135deg,#1e3a5f,#2d5aa0);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:15px;font-weight:600;gap:8px;justify-content:center;letter-spacing:.3px;margin-top:8px;padding:14px;transition:all .25s ease;width:100%}.predict-button:hover:not(:disabled){background:linear-gradient(135deg,#2d5aa0,#4a90b8);box-shadow:0 8px 24px #2d5aa059;transform:translateY(-2px)}.predict-button:active:not(:disabled){box-shadow:none;transform:translateY(0)}.predict-button:disabled{cursor:not-allowed;opacity:.65}.spinner{animation:spin .65s linear infinite;border:2px solid #ffffff59;border-radius:50%;border-top-color:#fff;display:inline-block;height:16px;width:16px}@keyframes spin{to{transform:rotate(1turn)}}.confidence-card{animation:fadeInUp .4s ease;margin-top:20px}.stars{display:flex;gap:4px;margin-bottom:12px}.star{font-size:26px;line-height:1;transition:transform .15s}.star.filled{animation:starPop .3s ease backwards;color:#f59e0b}.star.empty{color:#e2e8f0}@keyframes starPop{0%{opacity:0;transform:scale(.6)}60%{transform:scale(1.2)}to{opacity:1;transform:scale(1)}}.star:first-child{animation-delay:.05s}.star:nth-child(2){animation-delay:.1s}.star:nth-child(3){animation-delay:.15s}.star:nth-child(4){animation-delay:.2s}.star:nth-child(5){animation-delay:.25s}.strategy-tag{background:#eff6ff;border-radius:20px;color:#1d4ed8;display:inline-block;font-size:12px;font-weight:600;margin:0 0 10px;padding:4px 12px}.confidence-note{color:#64748b;font-size:12px;line-height:1.6;margin:0}.right-panel{display:flex;flex-direction:column;min-height:440px}.results-list{animation:fadeInUp .4s ease}.section-title{color:#0f2537;font-size:20px;font-weight:700;margin:0 0 4px}.results-subtitle{color:#64748b;font-size:13px;margin:0 0 16px}.hydrophilic-panel{animation:fadeInUp .4s ease;background:#fff;border:2px solid #bfdbfe;border-radius:16px;padding:40px 36px}.hydrophilic-icon{animation:float 3s ease-in-out infinite;font-size:48px;margin-bottom:16px}.hydrophilic-panel h3{color:#1e3a5f;font-size:22px;font-weight:700;margin:0 0 12px}.hydrophilic-intro{border-bottom:1px solid #e4edf5;color:#475569;font-size:14px;line-height:1.7;margin:0 0 28px;padding-bottom:24px}.hydrophilic-alternatives h4{color:#64748b;font-size:11px;font-weight:700;letter-spacing:1px;margin:0 0 16px;text-transform:uppercase}.alt-card{align-items:flex-start;background:#f8fafc;border:1px solid #e4edf5;border-radius:12px;display:flex;gap:14px;margin-bottom:10px;padding:14px;transition:box-shadow .2s}.alt-card:hover{box-shadow:0 4px 16px #0f253714}.alt-icon{flex-shrink:0;font-size:22px;margin-top:2px}.alt-card strong{color:#0f2537;display:block;font-size:14px;font-weight:700;margin-bottom:4px}.alt-card p{color:#64748b;font-size:12px;line-height:1.6;margin:0}.logp-only-banner{align-items:flex-start;animation:fadeInUp .3s ease;background:#fffbeb;border:1px solid #fde68a;border-left:4px solid #f59e0b;border-radius:10px;color:#78350f;display:flex;font-size:13px;gap:10px;line-height:1.5;margin-bottom:18px;padding:12px 14px}.logp-only-icon{flex-shrink:0;font-size:16px;margin-top:1px}.empty-state{align-items:center;background:#fff;border:2px dashed #d1dce8;border-radius:16px;display:flex;flex:1 1;flex-direction:column;justify-content:center;min-height:440px;padding:56px 40px;text-align:center}.empty-icon{animation:float 3s ease-in-out infinite;font-size:52px;margin-bottom:20px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.empty-state h3{color:#0f2537;font-size:22px;font-weight:700;margin:0 0 10px}.empty-state p{color:#64748b;font-size:14px;line-height:1.7;margin:0 auto 28px;max-width:380px}.empty-steps{flex-direction:column;margin:0 auto;max-width:300px}.empty-steps,.step{display:flex;gap:12px}.step{color:#475569;font-size:13px;text-align:left}.step,.step-num{align-items:center}.step-num{background:linear-gradient(135deg,#1e3a5f,#2d5aa0);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:26px;justify-content:center;width:26px}.formulation-card{animation:fadeInUp .4s ease backwards;border:2px solid;border-radius:14px;margin-bottom:16px;padding:18px;transition:transform .2s ease,box-shadow .2s ease}.formulation-card:first-child{animation-delay:.05s}.formulation-card:nth-child(2){animation-delay:.12s}.formulation-card:nth-child(3){animation-delay:.19s}.formulation-card:nth-child(4){animation-delay:.26s}.formulation-card:hover{box-shadow:0 10px 28px #0000001c;transform:translateY(-3px)}.fc-header{justify-content:space-between;margin-bottom:12px}.fc-header,.fc-title-group{align-items:center;display:flex}.fc-title-group{gap:10px}.rank-badge{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:12px;font-weight:700;height:32px;justify-content:center;width:32px}.fc-name{color:#0f2537;font-size:16px;font-weight:700;margin:0}.score-badge{align-items:center;border:2px solid;border-radius:10px;display:flex;flex-direction:column;padding:5px 14px}.score-value{color:#0f2537;font-size:20px;font-weight:700;line-height:1}.score-label{color:#94a3b8;font-size:9px;letter-spacing:.5px;text-transform:uppercase}.score-bar-container{align-items:center;display:flex;gap:10px;margin-bottom:14px}.score-bar-track{background:#e4edf5;border-radius:4px;flex:1 1;height:6px;overflow:hidden}.score-bar-fill{animation:growBar .8s ease backwards;border-radius:4px;height:100%}@keyframes growBar{0%{width:0!important}}.score-percent{color:#64748b;font-size:12px;text-align:right;width:36px}.spatial-viz{align-items:center;background:#f8fafb;border:1px solid #e4edf5;border-radius:10px;display:flex;gap:16px;margin-bottom:12px;padding:14px}.particle-container{align-items:center;display:flex;flex-direction:column;flex-shrink:0;gap:8px}.particle-shell{align-items:center;background:radial-gradient(circle at 35% 35%,#bfdbfe 0,#4a90b8 100%);border:3px solid #4a90b8;border-radius:50%;display:flex;height:64px;justify-content:center;position:relative;width:64px}.particle-core{background:radial-gradient(circle at 35% 35%,#93c5fd 0,#1e3a5f 100%);border-radius:50%;height:30px;width:30px}.drug-dot{background:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 1px 5px #0000004d;height:12px;position:absolute;transition:all .5s ease;width:12px}.drug-dot.drug-core{left:50%;top:50%;transform:translate(-50%,-50%)}.drug-dot.drug-interface{left:50%;top:-4px;transform:translateX(-50%)}.particle-legend{display:flex;flex-direction:column;gap:3px}.legend-row{align-items:center;color:#64748b;display:flex;font-size:10px;gap:5px;white-space:nowrap}.legend-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.core-dot{background:#1e3a5f}.shell-dot{background:#4a90b8}.drug-dot-legend{background:#ef4444}.spatial-info{color:#334155;font-size:12px;line-height:1.7}.spatial-info p{margin:0 0 4px}.location-tag{border-radius:4px;display:inline-block;font-size:11px;font-weight:600;padding:2px 8px}.location-core{background:#dbeafe;color:#1e40af}.location-interface{background:#f0fdf4;color:#166534}.distance-table{display:flex;flex-direction:column;gap:4px;margin-top:8px}.dist-row{align-items:center;background:#f1f5f9;border-radius:5px;color:#64748b;display:flex;font-size:11px;justify-content:space-between;padding:3px 7px}.dist-row.dist-winner{background:#e0f2fe;color:#0369a1;font-weight:600}.dist-label{letter-spacing:.1px}.dist-value{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.fc-note{border-left:3px solid #4a90b8;color:#64748b;font-size:12px;font-style:italic;line-height:1.6;margin:0;padding-left:10px}@keyframes fadeInUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}@media (max-width:800px){.main-grid{grid-template-columns:1fr}.hero-title{font-size:30px}.hsp-grid{grid-template-columns:1fr}.spatial-viz{flex-direction:column;text-align:center}.particle-legend{flex-direction:row;gap:12px}}@media (max-width:480px){.app-container{padding:0 12px 32px}.card{padding:18px}.main-header{padding:48px 16px 44px}.hero-title{font-size:26px}}
/*# sourceMappingURL=main.926c97b8.css.map*/