*,:after,:before{box-sizing:border-box}body{margin:0;font-family:DM Sans,sans-serif;background:#f5f7fb;color:#0f172a}.site-header{background:#1b67b5;border-bottom:1px solid rgba(255,255,255,.12);padding:0 40px;display:flex;align-items:center;height:64px;gap:12px}.site-header .brand{font-family:"DM Serif Display",serif;color:#fff;text-decoration:none;display:flex;flex-direction:column;gap:1px;line-height:1.2}.brand-title{font-size:22px;letter-spacing:.3px}.brand-title em{color:rgba(255,255,255,.9);font-style:italic}.brand-sub{font-size:11px;font-weight:400;color:rgba(255,255,255,.68);font-family:DM Sans,sans-serif;letter-spacing:.2px}.site-header nav{margin-left:auto;display:flex;align-items:center;gap:24px}.site-header nav a{font-size:13.5px;color:rgba(255,255,255,.78);text-decoration:none;transition:color .15s}.site-header nav a.active,.site-header nav a:hover{color:#fff}.site-footer{background:#1b2a3b;border-top:1px solid rgba(255,255,255,.08);padding:18px 40px;text-align:center}.site-footer p{font-size:12.5px;color:rgba(255,255,255,.55);margin:0;line-height:1.6}.site-footer strong{color:rgba(255,255,255,.78);font-weight:600}.site-footer a{color:#7ec8f0;text-decoration:none;transition:color .15s}.site-footer a:hover{color:#aee0ff}.home-hero{background:#ffffff;padding:88px 40px 72px;text-align:center;position:relative;overflow:hidden;box-shadow:0 1px 0 rgba(27,103,181,.1)}.home-hero:before{content:"";position:absolute;inset:0;background-image:radial-gradient(ellipse 90% 55% at 50% 0,rgba(27,103,181,.06) 0,transparent 65%),radial-gradient(circle,rgba(27,103,181,.045) 1px,transparent 0);background-size:100% 100%,30px 30px;pointer-events:none}.home-hero h1{font-family:"DM Serif Display",serif;font-size:52px;color:#1b67b5;margin:0 0 18px;position:relative}.home-hero h1 em{color:#9b2020;font-style:italic}.home-hero p{font-size:16px;color:#64748b;max-width:600px;margin:0 auto;line-height:1.72;position:relative}.tools-grid{max-width:1100px;margin:0 auto 80px;padding:44px 40px 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));grid-gap:24px;gap:24px}.tool-card{background:#ffffff;border:1px solid rgba(148,163,184,.2);border-radius:20px;padding:28px 28px 24px;text-decoration:none;display:flex;flex-direction:column;gap:12px;box-shadow:0 1px 3px rgba(15,23,42,.06),0 4px 16px rgba(15,23,42,.04);transition:box-shadow .22s,transform .18s,border-color .22s}.tool-card:hover{box-shadow:0 8px 32px rgba(15,23,42,.11),0 1px 3px rgba(15,23,42,.05);transform:translateY(-3px);border-color:rgba(27,103,181,.3)}.tool-card-icon{width:52px;height:52px;border-radius:14px;background:linear-gradient(135deg,#1a3461,#0891b2);display:flex;align-items:center;justify-content:center}.tool-card-icon svg{width:26px;height:26px}.tool-card-icon--primeriq{background:radial-gradient(circle at 30% 30%,#4338ca,#1e1b4b)}.tool-card-icon--molarity{background:radial-gradient(circle at 30% 30%,#166534,#052e16)}.tool-card-icon--hbv{background:radial-gradient(circle at 30% 30%,#b91c1c,#450a0a)}.tool-card h3{font-family:Montserrat,sans-serif;font-size:22px;font-weight:700;color:#0f172a;margin:0}.tool-card p{font-size:13.5px;color:#64748b;line-height:1.6;margin:0}.tool-card-tag{display:inline-block;font-size:10.5px;font-weight:700;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;border-radius:20px;background:#e8f0fb;color:#1b67b5;margin-top:auto}.primeriq-root{--navy:#0b2a4a;--teal:#007b8a;--teal-lt:#e0f4f6;--accent:#00b4c8;--green:#1a8c5b;--green-lt:#e6f6ef;--amber:#c87b00;--amber-lt:#fff4e0;--red:#c0392b;--red-lt:#fdecea;--blue-lt:#e8f2fd;--blue:#1a5fa8;--border:#e2eaf3;--text:#1a2940;--muted:#6b7f99;--bg:#ffffff;--surface:#f7fafd;--primeriq-glow:0 20px 60px rgba(11,42,74,0.08);font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}.primeriq-root *{margin:0;padding:0}.primeriq-root *,.primeriq-root :after,.primeriq-root :before{box-sizing:border-box}.primeriq-root .hero{background:linear-gradient(100deg,#f2f8ff,#edf6f8);border-bottom:1px solid var(--border);padding:36px 40px 30px;position:relative;overflow:hidden}.primeriq-root .hero:after{content:"";position:absolute;width:420px;height:420px;right:-120px;top:-180px;background:radial-gradient(circle,rgba(0,180,200,.12) 0,transparent 70%);pointer-events:none}.primeriq-root .hero-inner{max-width:1440px;margin:auto}.primeriq-root .hero h1{font-family:"DM Serif Display",serif;font-size:30px;color:var(--navy);margin-bottom:6px}.primeriq-root .hero p{font-size:14.5px;color:var(--muted);font-weight:400;max-width:580px;line-height:1.6}.primeriq-root .main-wrap{max-width:1440px;margin:auto;padding:36px 40px 60px}.primeriq-root .panel{background:var(--bg);border:1px solid rgba(226,234,243,.95);border-radius:16px;padding:30px 32px;margin-bottom:28px;box-shadow:var(--primeriq-glow),0 1px 0 rgba(255,255,255,.8) inset}.primeriq-root .panel-title{font-size:11px;font-weight:600;letter-spacing:1.6px;text-transform:uppercase;color:var(--teal);margin-bottom:22px;display:flex;align-items:center;gap:8px}.primeriq-root .panel-title:before{content:"";display:block;width:4px;height:14px;background:linear-gradient(180deg,var(--accent),var(--teal));border-radius:2px}.primeriq-root .form-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:20px;gap:20px;margin-bottom:24px}.primeriq-root label{display:block;font-size:12px;font-weight:600;letter-spacing:.4px;color:var(--muted);text-transform:uppercase;margin-bottom:8px}.primeriq-root input[type=number],.primeriq-root input[type=text],.primeriq-root select{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:9px;font-family:DM Sans,sans-serif;font-size:14.5px;color:var(--text);background:var(--surface);transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.primeriq-root select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7f99' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}.primeriq-root input:focus,.primeriq-root select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,180,200,.12);background:#fff}.primeriq-root .seq-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:20px;gap:20px}.primeriq-root .seq-grid.single-mode{grid-template-columns:1fr}.primeriq-root .seq-field{position:relative}.primeriq-root .seq-badge{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:10px;font-weight:700;letter-spacing:.8px;text-transform:uppercase;background:var(--teal-lt);color:var(--teal);padding:3px 8px;border-radius:4px;pointer-events:none}.primeriq-root .seq-field input{padding-right:70px;font-family:Courier New,monospace;letter-spacing:1.5px;font-size:14px}.primeriq-root .error-box{margin-top:6px;font-size:12.5px;color:var(--red);min-height:18px}.primeriq-root .bad-char{font-weight:800;color:var(--red);background:var(--red-lt);padding:0 2px;border-radius:3px}.primeriq-root .primeriq-banner{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-radius:12px;margin-bottom:20px;font-size:14px;line-height:1.45;border:1px solid transparent}.primeriq-root .primeriq-banner--error{background:var(--red-lt);color:var(--red);border-color:rgba(192,57,43,.25)}.primeriq-root .primeriq-banner__close{margin-left:auto;background:transparent;border:none;color:inherit;cursor:pointer;font-size:18px;line-height:1;padding:0 4px;opacity:.7}.primeriq-root .btn-analyze{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:15px 24px;background:linear-gradient(125deg,var(--navy) 0,#0e5080 50%,var(--teal) 100%);color:white;border:none;border-radius:10px;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;letter-spacing:.3px;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;box-shadow:0 4px 20px rgba(0,75,120,.2)}.primeriq-root .btn-analyze:hover{opacity:.93;transform:translateY(-1px);box-shadow:0 6px 24px rgba(0,75,120,.28)}.primeriq-root .btn-analyze:active{transform:translateY(0)}.primeriq-root .btn-analyze:disabled{opacity:.65;cursor:not-allowed;transform:none}.primeriq-root .btn-analyze svg{width:18px;height:18px}.primeriq-root .dashboard{display:grid;grid-template-columns:1fr 1fr;grid-gap:22px;gap:22px;margin-top:36px;animation:piq-fadeUp .4s ease}@keyframes piq-fadeUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.primeriq-root .dashboard>.result-card:first-child:nth-last-child(2){grid-column:1/-1}.primeriq-root .result-card{background:var(--bg);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:0 2px 14px rgba(0,30,70,.05)}.primeriq-root .result-card-header{background:linear-gradient(100deg,var(--navy) 0,#0d3d6a 100%);padding:16px 22px;display:flex;align-items:center;gap:10px}.primeriq-root .result-card-header h3{font-family:"DM Serif Display",serif;font-size:17px;color:#fff;font-weight:400}.primeriq-root .result-card-header .seq-label{font-size:10px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:rgba(255,255,255,.5);margin-left:auto}.primeriq-root .result-card-body{padding:0}.primeriq-root .result-row--full{border-bottom:1px solid #f0f4f9}.primeriq-root .result-row--full:last-child{border-bottom:none}.primeriq-root .metric-pair{display:flex;border-bottom:1px solid #f0f4f9}.primeriq-root .metric-pair:last-child{border-bottom:none}.primeriq-root .metric-pair .result-row{flex:1 1;min-width:0;border-right:1px solid #f0f4f9;border-bottom:none}.primeriq-root .metric-pair .result-row:last-child{border-right:none}.primeriq-root .result-row{display:flex;align-items:flex-start;padding:11px 18px;gap:10px}.primeriq-root .result-row:hover{background:#fafcff}.primeriq-root .row-label{width:42%;flex-shrink:0;font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.3px;padding-top:2px}.primeriq-root .row-value{flex:1 1;font-size:14px;color:var(--text);min-width:0}.primeriq-root .row-value code{font-family:Courier New,monospace;font-size:13px;background:#f1f5f9;padding:3px 8px;border-radius:5px;color:var(--navy);letter-spacing:1.2px;word-break:break-all}.primeriq-root .range-hint{display:block;font-size:11px;color:var(--muted);margin-top:4px}.primeriq-root .metric{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:20px;font-size:13px;font-weight:700}.primeriq-root .metric.good{background:var(--green-lt);color:var(--green)}.primeriq-root .metric.warn{background:var(--amber-lt);color:var(--amber)}.primeriq-root .metric.bad{background:var(--red-lt);color:var(--red)}.primeriq-root .metric.info{background:var(--blue-lt);color:var(--blue)}.primeriq-root .compat-card{grid-column:1/-1}.primeriq-root .compat-card .result-card-header{background:linear-gradient(100deg,#0b3d6e 0,var(--teal) 100%)}.primeriq-root .ai-card{grid-column:1/-1}.primeriq-root .ai-card .result-card-header{background:linear-gradient(100deg,#0a2e4e,#084d6e)}.primeriq-root .ai-body{padding:24px 28px}.primeriq-root .ai-summary{font-size:15px;line-height:1.7;color:var(--text);margin-bottom:20px;padding:16px 20px;background:var(--surface);border-radius:10px;border-left:3px solid var(--accent)}.primeriq-root .ai-actions-title{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}.primeriq-root .ai-actions{list-style:none;display:flex;flex-direction:column;gap:9px}.primeriq-root .ai-actions li{display:flex;align-items:flex-start;gap:10px;font-size:14px;line-height:1.5;color:var(--text)}.primeriq-root .ai-actions li:before{content:"✓";flex-shrink:0;width:22px;height:22px;background:linear-gradient(135deg,var(--accent),var(--teal));color:white;font-size:11px;font-weight:800;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px}.primeriq-root .struct-viz-section{border-top:1px solid var(--border);padding:20px 22px 22px;background:linear-gradient(180deg,#fbfdff 0,var(--surface) 100%)}.primeriq-root .struct-viz-title{font-size:11px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--teal);margin-bottom:10px}.primeriq-root .struct-viz-scroll{overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px;margin:0 -6px;padding-left:6px;padding-right:6px}.primeriq-root .struct-viz-inner{min-width:min(100%,260px);margin:0 auto}.primeriq-root .struct-viz-note{margin-top:12px;font-size:12px;line-height:1.55;color:var(--muted)}.primeriq-root .struct-viz-note strong{color:var(--navy)}.primeriq-root .arc-legend{display:flex;flex-wrap:wrap;gap:10px 22px;margin-top:14px;padding:10px 14px;background:var(--surface);border-radius:8px;border:1px solid var(--border)}.primeriq-root .arc-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text);line-height:1.4}.primeriq-root .arc-legend-note{font-size:11px;color:var(--muted);width:100%}.primeriq-root .footer{background:var(--surface);border-top:1px solid var(--border);padding:18px 40px;text-align:center;font-size:12px;color:var(--muted)}.primeriq-root .footer strong{color:var(--navy)}@media (max-width:900px){.primeriq-root .dashboard,.primeriq-root .form-grid,.primeriq-root .seq-grid{grid-template-columns:1fr}.primeriq-root .ai-card,.primeriq-root .compat-card{grid-column:1}.primeriq-root .hero,.primeriq-root .main-wrap{padding-left:20px;padding-right:20px}.site-header{padding:0 20px}.site-footer{padding:14px 20px}.home-hero{padding:48px 20px 40px}.tools-grid{padding:0 20px;margin-top:40px}}.molarity-root{--mol-primary:#0b5394;--mol-primary-dark:#083d6e;--mol-accent:#00897b;--mol-accent-light:#e0f2f1;--mol-red:#c0392b;--mol-red-light:#fdf0ee;--mol-bg:#ffffff;--mol-surface:#f4f7fb;--mol-border:#dce3ed;--mol-text:#1a2b42;--mol-muted:#637388;--mol-result-bg:#eaf3ff;--mol-result-border:#0b5394;--mol-error:#c0392b;--mol-shadow:0 2px 14px rgba(11,83,148,.11);--mol-radius:10px;background:#eef2f7;min-height:calc(100vh - 56px);color:var(--mol-text)}.molarity-root .mol-page{max-width:960px;margin:0 auto;padding:28px 20px 80px}.molarity-root .mol-page-title{font-size:1.5rem;font-weight:700;color:var(--mol-primary-dark);margin:0 0 4px}.molarity-root .mol-page-sub{font-size:.85rem;color:var(--mol-muted);margin:0 0 24px}.molarity-root .mol-tabs-wrap{background:var(--mol-bg);border-radius:var(--mol-radius);box-shadow:var(--mol-shadow);overflow:hidden}.molarity-root .mol-tabs-header{display:flex;border-bottom:2px solid var(--mol-border);background:var(--mol-surface);overflow-x:auto;scrollbar-width:none}.molarity-root .mol-tabs-header::-webkit-scrollbar{display:none}.molarity-root .mol-tab-btn{flex:1 1;min-width:200px;height:52px;background:none;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;padding:0 16px;font-size:.84rem;font-weight:600;color:var(--mol-muted);cursor:pointer;white-space:nowrap;display:flex;align-items:center;gap:8px;justify-content:center;transition:color .2s,border-color .2s,background .2s}.molarity-root .mol-tab-btn:hover{color:var(--mol-red);background:var(--mol-red-light)}.molarity-root .mol-tab-btn.active{color:var(--mol-red);border-bottom-color:var(--mol-red);background:var(--mol-bg)}.molarity-root .mol-tab-panels{padding:30px 28px 36px}.molarity-root .mol-tab-panel{animation:mol-panelIn .3s ease}@keyframes mol-panelIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.molarity-root .mol-calc-title{font-size:1.08rem;font-weight:700;color:var(--mol-primary-dark);margin:0 0 4px;display:flex;align-items:center;gap:8px}.molarity-root .mol-calc-desc{font-size:.83rem;color:var(--mol-muted);margin:0 0 18px;line-height:1.6}.molarity-root .mol-formula-badge{display:inline-block;background:var(--mol-accent-light);color:var(--mol-accent);border:1px solid #b2dfdb;border-radius:6px;padding:6px 14px;font-size:.8rem;font-family:Courier New,monospace;font-weight:600;margin-bottom:20px}.molarity-root .mol-form-grid,.molarity-root .mol-serial-config{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px 20px;gap:14px 20px;margin-bottom:4px}.molarity-root .mol-form-group{display:flex;flex-direction:column;gap:5px}.molarity-root label{font-size:.79rem;font-weight:600;color:var(--mol-text);letter-spacing:.01em}.molarity-root .mol-req{color:var(--mol-error)}.molarity-root .mol-hint{font-weight:400;color:var(--mol-muted);font-size:.74rem}.molarity-root .mol-input-wrap{display:flex;border:1.5px solid var(--mol-border);border-radius:7px;overflow:hidden;background:var(--mol-bg);transition:border-color .2s,box-shadow .2s}.molarity-root .mol-input-wrap:focus-within{border-color:var(--mol-primary);box-shadow:0 0 0 3px rgba(11,83,148,.12)}.molarity-root .mol-input-wrap input{flex:1 1;border:none;outline:none;padding:9px 12px;font-size:.92rem;color:var(--mol-text);background:transparent;min-width:0}.molarity-root .mol-input-wrap input::placeholder{color:#b0bcc9}.molarity-root .mol-unit-select{border:none;border-left:1.5px solid var(--mol-border);background:var(--mol-surface);color:var(--mol-primary);font-size:.81rem;font-weight:600;padding:0 10px;cursor:pointer;outline:none;min-width:62px}.molarity-root .mol-unit-select:hover{background:#e8edf5}.molarity-root .mol-standalone{width:100%;border:1.5px solid var(--mol-border);border-radius:7px;padding:9px 32px 9px 12px;font-size:.92rem;color:var(--mol-text);background:var(--mol-bg);outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' fill='none'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%230b5394' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}.molarity-root .mol-standalone:focus{border-color:var(--mol-primary);box-shadow:0 0 0 3px rgba(11,83,148,.12)}.molarity-root .mol-load-chem-row{display:flex;align-items:center;gap:10px;margin-bottom:18px;flex-wrap:wrap}.molarity-root .mol-lc-label{font-size:.79rem;font-weight:600;color:var(--mol-muted)}.molarity-root .mol-btn-load-chem{display:inline-flex;align-items:center;gap:5px;padding:5.6px 11.2px;border-radius:6px;font-size:.72rem;font-weight:700;cursor:pointer;background:linear-gradient(135deg,#c0392b,#e74c3c);color:#fff;border:none;box-shadow:0 2px 6px rgba(192,57,43,.25);transition:box-shadow .2s,filter .2s}.molarity-root .mol-btn-load-chem:hover{box-shadow:0 4px 12px rgba(192,57,43,.35);filter:brightness(1.07)}.molarity-root .mol-btn-row{display:flex;gap:12px;margin-top:22px;flex-wrap:wrap}.molarity-root .mol-btn{display:inline-flex;align-items:center;gap:7px;padding:10px 22px;border-radius:7px;font-size:.89rem;font-weight:600;cursor:pointer;border:none;transition:background .18s,box-shadow .18s}.molarity-root .mol-btn:active{transform:scale(.97)}.molarity-root .mol-btn-primary{background:var(--mol-primary);color:#fff;box-shadow:0 2px 6px rgba(11,83,148,.22)}.molarity-root .mol-btn-primary:hover{background:var(--mol-primary-dark);box-shadow:0 4px 12px rgba(11,83,148,.3)}.molarity-root .mol-btn-primary:disabled{opacity:.65;cursor:not-allowed}.molarity-root .mol-btn-reset{background:#fee2e2;color:#b91c1c;border:1.5px solid #fca5a5}.molarity-root .mol-btn-reset:hover{background:#fca5a5;border-color:#f87171}.molarity-root .mol-result-box{margin-top:20px;background:var(--mol-result-bg);border:1.5px solid var(--mol-result-border);border-radius:var(--mol-radius);padding:16px 20px;animation:mol-panelIn .35s ease}.molarity-root .mol-result-label{font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--mol-primary);margin-bottom:10px}.molarity-root .mol-result-values{display:flex;flex-wrap:wrap;gap:10px}.molarity-root .mol-result-value{background:#fff;border:1.5px solid #b3cde8;border-radius:7px;padding:10px 16px;min-width:100px;transition:transform .15s,box-shadow .15s}.molarity-root .mol-result-value:hover{transform:translateY(-2px);box-shadow:0 4px 10px rgba(11,83,148,.12)}.molarity-root .mol-rv-num{font-size:1.2rem;font-weight:700;color:var(--mol-primary-dark);line-height:1.2}.molarity-root .mol-rv-unit{font-size:.76rem;color:var(--mol-muted);margin-top:2px}.molarity-root .mol-rv-label{opacity:.65;font-size:.7rem}.molarity-root .mol-error-msg{margin-top:10px;background:#fdecea;border:1.5px solid #f5c6cb;border-radius:7px;padding:10px 14px;color:var(--mol-error);font-size:.84rem;animation:mol-panelIn .25s ease}.molarity-root .mol-loaded-badge{display:inline-flex;align-items:center;gap:6px;padding:5px 10px;background:#f0fdf4;border:1px solid #86efac;border-radius:6px;font-size:.78rem;font-weight:600;color:#15803d;animation:mol-panelIn .3s ease}.molarity-root .mol-lb-remove{cursor:pointer;color:#ef4444;font-size:.9rem;line-height:1;margin-left:2px}.molarity-root .mol-lb-remove:hover{color:#b91c1c}.molarity-root .mol-tip{background:#fff8e1;border:1px solid #ffe082;border-radius:7px;padding:10px 14px;font-size:.79rem;color:#6d4c00;margin-bottom:18px;display:flex;gap:8px;align-items:flex-start;line-height:1.5}.molarity-root .mol-dilution-table-wrap{margin-top:22px;overflow-x:auto;border-radius:var(--mol-radius);border:1.5px solid var(--mol-border);animation:mol-panelIn .4s ease}.molarity-root table{width:100%;border-collapse:collapse;font-size:.84rem}.molarity-root thead{background:var(--mol-primary);color:#fff}.molarity-root thead th{padding:11px 14px;text-align:left;font-weight:600;white-space:nowrap}.molarity-root tbody tr{border-bottom:1px solid var(--mol-border);transition:background .12s}.molarity-root tbody tr:last-child{border-bottom:none}.molarity-root tbody tr:hover{background:#f0f6ff}.molarity-root tbody td{padding:10px 14px;color:var(--mol-text)}.molarity-root tbody td:first-child{font-weight:600;color:var(--mol-primary-dark)}.molarity-root .mol-conc-cell{font-family:Courier New,monospace}.molarity-root .mol-step-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--mol-primary);color:#fff;font-size:.73rem;font-weight:700}.molarity-root .mol-edu-section{margin-top:36px}.molarity-root .mol-edu-toggle{display:flex;align-items:center;justify-content:space-between;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:12px 16px;background:linear-gradient(135deg,var(--mol-red-light),#fff5f5);border:1.5px solid #fca5a5;border-radius:8px;transition:background .2s}.molarity-root .mol-edu-toggle:hover{background:linear-gradient(135deg,#fde8e6,#fff0ee)}.molarity-root .mol-edu-toggle-left{display:flex;align-items:center;gap:10px}.molarity-root .mol-edu-toggle-title{font-size:.9rem;font-weight:700;color:var(--mol-red)}.molarity-root .mol-edu-toggle-sub{font-size:.75rem;color:var(--mol-muted);margin-top:1px}.molarity-root .mol-edu-chevron{color:var(--mol-red);transition:transform .3s;flex-shrink:0}.molarity-root .mol-edu-chevron.open{transform:rotate(180deg)}.molarity-root .mol-edu-body{padding:22px 20px;background:#fff;border:1.5px solid #fca5a5;border-top:none;border-radius:0 0 8px 8px;animation:mol-panelIn .3s ease}.molarity-root .mol-edu-body h3{font-size:.93rem;font-weight:700;color:var(--mol-primary-dark);margin:16px 0 5px;display:flex;align-items:center;gap:7px}.molarity-root .mol-edu-body h3:first-child{margin-top:0}.molarity-root .mol-edu-body p{font-size:.83rem;color:#374151;line-height:1.75;margin-bottom:10px}.molarity-root .mol-edu-body ol,.molarity-root .mol-edu-body ul{padding-left:20px;margin-bottom:10px}.molarity-root .mol-edu-body li{font-size:.83rem;color:#374151;line-height:1.75;margin-bottom:3px}.molarity-root .mol-edu-formula{background:#f0f6ff;border-left:3px solid var(--mol-primary);padding:10px 14px;border-radius:0 6px 6px 0;font-family:Courier New,monospace;font-size:.84rem;color:var(--mol-primary-dark);margin:8px 0;font-weight:600}.molarity-root .mol-edu-example{background:#f0fdf4;border-left:3px solid #16a34a;padding:10px 14px;border-radius:0 6px 6px 0;font-size:.81rem;color:#14532d;margin:8px 0;line-height:1.7}.molarity-root .mol-edu-note{background:#fffbeb;border-left:3px solid #f59e0b;padding:8px 14px;border-radius:0 6px 6px 0;font-size:.79rem;color:#78350f;margin:8px 0}.molarity-root .mol-edu-body table{font-size:.8rem;margin:10px 0}.molarity-root .mol-edu-body thead th{padding:8px 12px;background:var(--mol-primary)}.molarity-root .mol-edu-body tbody td{padding:7px 12px}.molarity-root .mol-modal-overlay{position:fixed;inset:0;background:rgba(10,20,40,.45);z-index:500;display:flex;align-items:center;justify-content:center;padding:16px;opacity:0;pointer-events:none;transition:opacity .25s}.molarity-root .mol-modal-overlay.open{opacity:1;pointer-events:auto}.molarity-root .mol-modal{background:#fff;border-radius:12px;width:100%;max-width:680px;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 20px 60px rgba(0,0,0,.22);transform:translateY(16px);transition:transform .25s}.molarity-root .mol-modal-overlay.open .mol-modal{transform:translateY(0)}.molarity-root .mol-modal-header{padding:18px 22px 14px;border-bottom:1.5px solid var(--mol-border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.molarity-root .mol-modal-title{font-size:1rem;font-weight:700;color:var(--mol-primary-dark);display:flex;align-items:center;gap:8px}.molarity-root .mol-modal-close{width:32px;height:32px;border-radius:7px;border:1.5px solid var(--mol-border);background:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--mol-muted);font-size:1.1rem;transition:background .15s,color .15s}.molarity-root .mol-modal-close:hover{background:#fee2e2;color:var(--mol-red);border-color:#fca5a5}.molarity-root .mol-modal-search-row{padding:14px 22px 10px;flex-shrink:0;display:flex;gap:10px;flex-wrap:wrap}.molarity-root .mol-modal-search{flex:1 1;min-width:180px;border:1.5px solid var(--mol-border);border-radius:7px;padding:8px 12px;font-size:.88rem;outline:none;transition:border-color .2s,box-shadow .2s}.molarity-root .mol-modal-search:focus{border-color:var(--mol-primary);box-shadow:0 0 0 3px rgba(11,83,148,.1)}.molarity-root .mol-cat-filter{border:1.5px solid var(--mol-border);border-radius:7px;padding:8px 28px 8px 10px;font-size:.84rem;outline:none;cursor:pointer;background:var(--mol-surface);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%230b5394' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center;transition:border-color .2s}.molarity-root .mol-cat-filter:focus{border-color:var(--mol-primary)}.molarity-root .mol-modal-list{overflow-y:auto;flex:1 1;padding:0 22px 16px}.molarity-root .mol-chem-cat-heading{font-size:.7rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--mol-muted);padding:12px 0 6px;border-bottom:1px solid var(--mol-border);margin-bottom:2px}.molarity-root .mol-chem-row{display:flex;align-items:center;justify-content:space-between;padding:9px 10px;border-radius:7px;cursor:pointer;gap:10px;transition:background .15s}.molarity-root .mol-chem-row:hover{background:var(--mol-red-light)}.molarity-root .mol-chem-row:hover .mol-chem-name{color:var(--mol-red)}.molarity-root .mol-chem-info{flex:1 1;min-width:0}.molarity-root .mol-chem-name{font-size:.88rem;font-weight:600;color:var(--mol-text);margin-bottom:1px}.molarity-root .mol-chem-formula{font-size:.76rem;color:var(--mol-muted);font-family:Courier New,monospace}.molarity-root .mol-chem-mw{font-size:.82rem;font-weight:700;color:var(--mol-primary);background:var(--mol-result-bg);border:1px solid #b3cde8;border-radius:5px;padding:3px 8px;white-space:nowrap;flex-shrink:0}.molarity-root .mol-no-results{text-align:center;color:var(--mol-muted);font-size:.86rem;padding:30px 0}.molarity-root .mol-footer{text-align:center;font-size:.78rem;color:var(--mol-muted);padding:0 20px 32px}@media (max-width:640px){.molarity-root .mol-tab-panels{padding:18px 14px 24px}.molarity-root .mol-form-grid,.molarity-root .mol-serial-config{grid-template-columns:1fr}.molarity-root .mol-tab-btn{min-width:150px;font-size:.78rem}.molarity-root .mol-modal-search-row{flex-direction:column}}.hbv-root{--hbv-primary:#0b3d5c;--hbv-accent:#c0392b;--hbv-green:#1a7a4a;--hbv-amber:#c57c00;--hbv-surface:#f7fafd;--hbv-border:#d8e6f0;--hbv-muted:#5a7080;--hbv-mono:"DM Mono","Courier New",monospace;min-height:100vh}.hbv-root .hbv-hero{background:linear-gradient(110deg,#0b2a4a,#0b3d5c 50%,#1a5c40);padding:56px 40px 48px;text-align:center}.hbv-root .hbv-hero h1{font-family:"DM Serif Display",serif;font-size:36px;color:#fff;margin:0 0 12px}.hbv-root .hbv-hero p{font-size:15.5px;color:rgba(255,255,255,.72);max-width:580px;margin:0 auto 20px;line-height:1.65}.hbv-root .hbv-hero-badges{display:flex;justify-content:center;gap:10px;flex-wrap:wrap}.hbv-root .hbv-hero-badge{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:rgba(255,255,255,.88);border-radius:20px;padding:4px 14px;font-size:12.5px;font-weight:500}.hbv-root .hbv-container{max-width:860px;margin:0 auto;padding:36px 32px 80px}.hbv-root .hbv-progress{display:flex;align-items:center;gap:0;margin-bottom:32px}.hbv-root .hbv-progress-step{display:flex;align-items:center;gap:8px;flex:1 1;position:relative;color:var(--hbv-muted)}.hbv-root .hbv-progress-step:not(:last-child):after{content:"";position:absolute;left:calc(50% + 16px);right:0;top:50%;height:2px;background:var(--hbv-border)}.hbv-root .hbv-progress-step--done:after{background:var(--hbv-green)!important}.hbv-root .hbv-progress-dot{width:28px;height:28px;border-radius:50%;background:var(--hbv-border);color:var(--hbv-muted);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;z-index:1}.hbv-root .hbv-progress-step--active .hbv-progress-dot{background:var(--hbv-primary);color:#fff}.hbv-root .hbv-progress-step--done .hbv-progress-dot{background:var(--hbv-green);color:#fff}.hbv-root .hbv-progress-label{font-size:12.5px;font-weight:600}.hbv-root .hbv-progress-step--active .hbv-progress-label{color:var(--hbv-primary)}.hbv-root .hbv-progress-step--done .hbv-progress-label{color:var(--hbv-green)}.hbv-root .hbv-step-panel{background:#fff;border:1px solid var(--hbv-border);border-radius:14px;padding:32px 36px;box-shadow:0 2px 12px rgba(11,61,92,.06)}.hbv-root .hbv-step-header{display:flex;align-items:center;gap:14px;margin-bottom:14px}.hbv-root .hbv-step-num{width:34px;height:34px;border-radius:50%;background:var(--hbv-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;flex-shrink:0}.hbv-root .hbv-step-num--done{background:var(--hbv-green)}.hbv-root .hbv-step-header h2{font-family:"DM Serif Display",serif;font-size:22px;color:var(--hbv-primary);margin:0}.hbv-root .hbv-step-desc{font-size:14px;color:var(--hbv-muted);line-height:1.6;margin:0 0 20px}.hbv-root .hbv-label{display:block;font-size:13px;font-weight:600;color:var(--hbv-primary);margin-bottom:7px;letter-spacing:.2px}.hbv-root .hbv-textarea{width:100%;border:1.5px solid var(--hbv-border);border-radius:8px;padding:12px 14px;font-family:var(--hbv-mono);font-size:13px;line-height:1.6;color:#1a2940;background:var(--hbv-surface);resize:vertical;outline:none;transition:border-color .15s;margin-bottom:14px}.hbv-root .hbv-textarea:focus{border-color:var(--hbv-primary);background:#fff}.hbv-root .hbv-btn-primary,.hbv-root .hbv-btn-secondary{display:inline-flex;align-items:center;gap:8px;border:none;border-radius:8px;padding:10px 22px;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.hbv-root .hbv-btn-primary{background:var(--hbv-primary);color:#fff}.hbv-root .hbv-btn-primary:hover:not(:disabled){background:#0d4f78}.hbv-root .hbv-btn-primary:disabled{opacity:.55;cursor:not-allowed}.hbv-root .hbv-btn-secondary{background:var(--hbv-surface);color:var(--hbv-primary);border:1.5px solid var(--hbv-border)}.hbv-root .hbv-btn-secondary:hover{background:#eaf2fb}.hbv-root .hbv-step-actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.hbv-root .hbv-error{background:#fff5f5;border:1px solid #f5c6c6;border-radius:7px;padding:10px 14px;font-size:13.5px;color:var(--hbv-accent);margin:0 0 14px}@keyframes hbv-spin{to{transform:rotate(1turn)}}.hbv-root .hbv-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:hbv-spin .7s linear infinite}.hbv-root .hbv-orf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));grid-gap:14px;gap:14px;margin-bottom:18px}.hbv-root .hbv-orf-card{background:var(--hbv-surface);border:2px solid var(--hbv-border);border-radius:10px;padding:14px 16px;text-align:left;cursor:pointer;transition:border-color .15s,background .15s,box-shadow .15s}.hbv-root .hbv-orf-card:hover{border-color:var(--hbv-primary);background:#f0f7ff}.hbv-root .hbv-orf-card--selected{border-color:var(--hbv-primary);background:#e8f4fd;box-shadow:0 0 0 3px rgba(11,61,92,.12)}.hbv-root .hbv-orf-card--recommended{border-color:var(--hbv-green)}.hbv-root .hbv-orf-card--recommended.hbv-orf-card--selected{border-color:var(--hbv-green);box-shadow:0 0 0 3px rgba(26,122,74,.14)}.hbv-root .hbv-orf-card-top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.hbv-root .hbv-orf-frame{font-size:14px;color:var(--hbv-primary)}.hbv-root .hbv-orf-len{font-size:12px;color:var(--hbv-muted)}.hbv-root .hbv-orf-badges{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:9px}.hbv-root .hbv-badge{font-size:11px;font-weight:600;padding:2px 8px;border-radius:12px}.hbv-root .hbv-badge--met{background:#e8f4fd;color:var(--hbv-primary)}.hbv-root .hbv-badge--men{background:#e8f7ee;color:var(--hbv-green)}.hbv-root .hbv-badge--stop{background:#fff3e0;color:#b36000}.hbv-root .hbv-badge--rec{background:var(--hbv-green);color:#fff}.hbv-root .hbv-orf-preview{font-size:11.5px;color:#3a5068;word-break:break-all;line-height:1.5}.hbv-root .hbv-orf-ellipsis{color:var(--hbv-muted);margin-left:2px}.hbv-root .hbv-mono{font-family:var(--hbv-mono)}.hbv-root .hbv-result-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:20px;background:linear-gradient(135deg,#e8f4fd,#e8f7ee);border:1px solid var(--hbv-border);border-radius:12px;padding:24px 28px;margin:20px 0 16px;flex-wrap:wrap}.hbv-root .hbv-result-hero-label{font-size:11.5px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;color:var(--hbv-muted);margin-bottom:10px}.hbv-root .hbv-serotype-badge{display:inline-block;background:var(--hbv-primary);color:#fff;font-family:var(--hbv-mono);font-size:32px;font-weight:700;padding:8px 22px;border-radius:10px;letter-spacing:1px}.hbv-root .hbv-serotype-badge--unknown{background:#6b7a8d;font-size:20px}.hbv-root .hbv-result-group{font-size:13.5px;color:var(--hbv-muted);margin-top:8px}.hbv-root .hbv-conf{display:inline-block;font-size:12px;font-weight:600;padding:5px 12px;border-radius:20px;white-space:nowrap;margin-top:4px}.hbv-root .hbv-conf--high{background:#e8f7ee;color:var(--hbv-green);border:1px solid #b3dfc7}.hbv-root .hbv-conf--medium{background:#fff8e1;color:var(--hbv-amber);border:1px solid #f0d080}.hbv-root .hbv-conf--low{background:#fff3f3;color:var(--hbv-accent);border:1px solid #f5c6c6}.hbv-root .hbv-warning-box{display:flex;gap:12px;align-items:flex-start;background:#fff8e1;border:1px solid #f0d080;border-left:4px solid var(--hbv-amber);border-radius:0 8px 8px 0;padding:12px 16px;margin:12px 0 16px}.hbv-root .hbv-warning-box--critical{background:#fff3f3;border-color:#f5c6c6;border-left-color:var(--hbv-accent)}.hbv-root .hbv-warning-icon{font-size:17px;flex-shrink:0;line-height:1.4;color:var(--hbv-amber)}.hbv-root .hbv-warning-box--critical .hbv-warning-icon{color:var(--hbv-accent)}.hbv-root .hbv-warning-box p{font-size:13.5px;line-height:1.6;color:#3a3000;margin:0}.hbv-root .hbv-warning-box--critical p{color:#5a1010}.hbv-root .hbv-result-desc{font-size:14px;line-height:1.65;color:#2a3f52;margin:0 0 24px;padding:12px 16px;background:#f0f7ff;border-left:3px solid var(--hbv-primary);border-radius:0 8px 8px 0}.hbv-root .hbv-details-section{margin-top:28px;padding-top:24px;border-top:1px solid var(--hbv-border)}.hbv-root .hbv-details-section h3{font-size:15px;font-weight:700;color:var(--hbv-primary);margin:0 0 8px}.hbv-root .hbv-details-note{font-size:13px;color:var(--hbv-muted);margin:0 0 16px}.hbv-root .hbv-positions-grid{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:16px}.hbv-root .hbv-pos-card{background:var(--hbv-surface);border:1.5px solid var(--hbv-border);border-radius:10px;padding:10px 16px;text-align:center;min-width:80px}.hbv-root .hbv-pos-card--missing{border-color:#f5c6c6;background:#fff5f5}.hbv-root .hbv-pos-card--ambiguous{border-color:#f0d080;background:#fff8e1}.hbv-root .hbv-pos-num{font-size:11px;font-weight:700;letter-spacing:.5px;color:var(--hbv-muted);text-transform:uppercase;margin-bottom:6px}.hbv-root .hbv-pos-aa{font-family:var(--hbv-mono);font-size:26px;font-weight:700;color:var(--hbv-primary);line-height:1}.hbv-root .hbv-pos-card--missing .hbv-pos-aa{color:var(--hbv-accent)}.hbv-root .hbv-pos-card--ambiguous .hbv-pos-aa{color:var(--hbv-amber)}.hbv-root .hbv-pos-aa-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--hbv-amber);margin-top:2px}.hbv-root .hbv-motif-row{display:flex;align-items:center;gap:12px;background:var(--hbv-surface);border:1px solid var(--hbv-border);border-radius:8px;padding:10px 16px;flex-wrap:wrap}.hbv-root .hbv-motif-label{font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--hbv-muted)}.hbv-root .hbv-motif-seq{font-size:20px;font-weight:700;color:var(--hbv-primary);letter-spacing:3px}.hbv-root .hbv-motif-pattern{font-size:12px;color:var(--hbv-muted)}.hbv-root .hbv-motif-pattern code{background:#e8eef5;padding:1px 5px;border-radius:4px;font-family:var(--hbv-mono)}.hbv-root .hbv-seq-wrap{background:var(--hbv-surface);border:1px solid var(--hbv-border);border-radius:8px;padding:16px 18px;overflow-x:auto}.hbv-root .hbv-protein-seq{font-size:13px;line-height:1.8;word-break:break-all;margin:0;color:#2a3f52}.hbv-root .hbv-aa-highlight{background:#ffd54f;color:#1a2940;border-radius:3px;padding:0 1px}.hbv-root .hbv-edu-section{margin-top:28px;padding-top:24px;border-top:1px solid var(--hbv-border)}.hbv-root .hbv-edu-section summary{font-size:15px;font-weight:700;color:var(--hbv-primary);cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;margin-bottom:12px;list-style:none;display:flex;align-items:center;gap:8px}.hbv-root .hbv-edu-section summary:before{content:"▶";font-size:10px;transition:transform .15s}.hbv-root .hbv-edu-section[open] summary:before{transform:rotate(90deg)}.hbv-root .hbv-edu-section p,.hbv-root .hbv-edu-section ul{font-size:13.5px;line-height:1.65;color:#2a3f52;margin:0 0 12px}.hbv-root .hbv-edu-section a{color:var(--hbv-primary);text-decoration:underline}.hbv-root .hbv-edu-section ul{padding-left:20px}.hbv-root .hbv-edu-section li{margin-bottom:5px}.hbv-root .hbv-how-it-works{background:#f0f7ff;border:1px solid var(--hbv-border);border-left:4px solid var(--hbv-primary);border-radius:10px;padding:18px 22px;margin-bottom:24px}.hbv-root .hbv-hiw-title{font-size:13px;font-weight:700;letter-spacing:1px;text-transform:uppercase;color:var(--hbv-primary);margin:0 0 14px}.hbv-root .hbv-hiw-steps{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.hbv-root .hbv-hiw-steps li{display:flex;align-items:flex-start;gap:12px;font-size:13.5px;color:#2a3f52;line-height:1.55}.hbv-root .hbv-hiw-num{flex-shrink:0;width:22px;height:22px;border-radius:50%;background:var(--hbv-primary);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;margin-top:1px}@media (max-width:640px){.hbv-root .hbv-hero{padding:40px 20px 36px}.hbv-root .hbv-hero h1{font-size:28px}.hbv-root .hbv-container{padding:24px 16px 60px}.hbv-root .hbv-step-panel{padding:22px 18px}.hbv-root .hbv-orf-grid{grid-template-columns:1fr}.hbv-root .hbv-progress-label{display:none}.hbv-root .hbv-result-hero{flex-direction:column}.hbv-root .hbv-positions-grid{gap:8px}.hbv-root .hbv-pos-card{min-width:60px;padding:8px 10px}.hbv-root .hbv-motif-row{flex-direction:column;align-items:flex-start;gap:6px}}