.layout{min-height:100vh;display:flex;flex-direction:column}.navbar{background:var(--bg-secondary);border-bottom:2px solid var(--border);box-shadow:0 2px 8px var(--shadow);position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.navbar-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 2rem}.navbar-brand{display:flex;align-items:center;gap:1rem}.logo-icon{height:45px;width:auto}.navbar-title{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}.navbar-subtitle{font-size:.85rem;color:var(--text-muted);margin:0}.navbar-menu{display:flex;list-style:none;gap:.5rem;margin:0;padding:0}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;color:var(--text-secondary);text-decoration:none;border-radius:8px;font-weight:600;transition:all .2s ease;position:relative}.nav-link svg{width:20px;height:20px}.nav-link:hover{background:var(--bg-card);color:var(--primary-light)}.nav-link.active{background:var(--primary-light);color:#fff}.nav-link.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:var(--primary-light)}.main-content{flex:1;padding:2rem 0}.footer{background:var(--bg-secondary);border-top:2px solid var(--border);margin-top:4rem}.footer-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem;padding:3rem 0}.footer-section h3{color:var(--text-primary);margin-bottom:.5rem;font-size:1.25rem}.footer-section h4{color:var(--text-secondary);margin-bottom:1rem;font-size:1rem}.footer-section p{color:var(--text-muted);line-height:1.6}.footer-section ul{list-style:none;padding:0;margin:0}.footer-section li{margin-bottom:.5rem;color:var(--text-muted)}.footer-section a{color:var(--text-muted);text-decoration:none;transition:color .2s ease}.footer-section a:hover{color:var(--primary-light)}.footer-bottom{border-top:1px solid var(--border);padding:1.5rem 0;text-align:center;color:var(--text-muted)}.footer-logo{height:20px;width:auto;vertical-align:middle;margin-left:.25rem;margin-right:.25rem}@media (max-width: 768px){.navbar-content{flex-direction:column;gap:1rem;padding:1rem}.navbar-title{font-size:1.25rem}.navbar-subtitle{font-size:.75rem}.navbar-menu{width:100%;justify-content:center}.nav-link{flex:1;justify-content:center}.footer-content{grid-template-columns:1fr}}.home-page{min-height:100vh}.hero-section{background:linear-gradient(135deg,#3b82f61a,#9333ea1a);padding:4rem 2rem;margin-bottom:4rem;border-radius:16px;text-align:center}.hero-title{font-size:3rem;font-weight:800;color:var(--text-primary);margin-bottom:1rem;line-height:1.2}.hero-description{font-size:1.25rem;color:var(--text-secondary);max-width:800px;margin:0 auto 2rem;line-height:1.6}.hero-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.btn-large{padding:1rem 2rem;font-size:1.125rem}.stats-section{margin-bottom:4rem}.section-title{font-size:2rem;font-weight:700;color:var(--text-primary);margin-bottom:2rem;text-align:center}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem;margin-bottom:3rem}.stat-card{background:var(--bg-card);border-radius:12px;padding:2rem;display:flex;align-items:center;gap:1.5rem;border:1px solid var(--border);transition:all .3s ease}.stat-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow)}.stat-icon{width:64px;height:64px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-icon svg{width:32px;height:32px}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.stats-loading,.stats-error{text-align:center;padding:3rem;color:var(--text-secondary)}.stats-error svg{width:48px;height:48px;color:var(--error);margin-bottom:1rem}.features-section{margin-bottom:4rem}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:2rem}.feature-card{background:var(--bg-card);border-radius:12px;padding:2rem;border:1px solid var(--border);transition:all .3s ease}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--shadow);border-color:var(--primary-light)}.feature-icon{width:56px;height:56px;background:linear-gradient(135deg,var(--primary-light),var(--primary-dark));border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:1.5rem;color:#fff}.feature-icon svg{width:28px;height:28px}.feature-card h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:.75rem}.feature-card p{color:var(--text-secondary);line-height:1.6;margin:0}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .6s ease-out}.animate-fade-in-delay{animation:fadeIn .6s ease-out .2s both}.animate-fade-in-delay-2{animation:fadeIn .6s ease-out .4s both}.animate-slide-up{animation:slideUp .5s ease-out}.animate-slide-up-delay{animation:slideUp .5s ease-out .1s both}@media (max-width: 768px){.hero-title{font-size:2rem}.hero-description{font-size:1rem}.stats-grid,.features-grid{grid-template-columns:1fr}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.modal-content{background:linear-gradient(135deg,#1a1a2e,#16213e);border-radius:16px;width:100%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;border:1px solid rgba(255,255,255,.1)}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:2rem;border-bottom:1px solid rgba(255,255,255,.1)}.modal-header h2{margin:0 0 .5rem;color:#fff;font-size:1.5rem}.smiles-small{display:inline-block;background:#ffffff1a;padding:.25rem .75rem;border-radius:6px;font-size:.9rem;color:#64ffda;font-family:Courier New,monospace}.modal-close{background:#ffffff1a;border:none;width:40px;height:40px;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:all .2s ease}.modal-close:hover{background:#f003;transform:scale(1.05)}.modal-close svg{width:24px;height:24px}.modal-body{flex:1;overflow:auto;padding:0}.structure-tabs{display:flex;flex-direction:column;height:100%}.tab-buttons{display:flex;gap:.5rem;padding:1rem 2rem 0;border-bottom:1px solid rgba(255,255,255,.1)}.tab-button{background:transparent;border:none;padding:.75rem 1.5rem;color:#fff9;font-size:1rem;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s ease}.tab-button:hover{color:#fff}.tab-button.active{color:#64ffda;border-bottom-color:#64ffda}.tab-content{display:none;padding:2rem;flex:1;overflow:auto}.tab-content.active{display:block}.viewer-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding:1rem;background:#ffffff0d;border-radius:8px}.control-group{display:flex;align-items:center;gap:.75rem}.control-group label{color:#fffc;font-size:.95rem}.control-select{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:6px;font-size:.95rem;cursor:pointer;outline:none;transition:all .2s ease}.control-select:hover{background:#ffffff26}.control-select:focus{border-color:#64ffda}.download-buttons{display:flex;gap:.75rem}.btn-small{padding:.5rem 1rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.btn-secondary{background:#ffffff1a;color:#fff;border:1px solid rgba(255,255,255,.2)}.btn-secondary:hover{background:#fff3;transform:translateY(-2px)}.image-2d-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.structure-2d-image{max-width:100%;max-height:500px;background:#fff;padding:2rem;border-radius:8px;box-shadow:0 4px 12px #0000004d}.download-image-btn{display:flex;align-items:center;gap:.5rem}.download-image-btn svg{width:20px;height:20px}.metadata-container{display:flex;flex-direction:column;gap:2rem}.metadata-section h3{color:#64ffda;margin:0 0 1rem;font-size:1.1rem}.metadata-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.metadata-item{background:#ffffff0d;padding:1rem;border-radius:8px;display:flex;flex-direction:column;gap:.5rem}.metadata-label{color:#fff9;font-size:.85rem;text-transform:uppercase;letter-spacing:.5px}.metadata-value{color:#fff;font-size:1.1rem;font-weight:600}.metadata-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.metadata-badge.cached{background:#64ffda33;color:#64ffda}.metadata-badge.fresh{background:#8a2be233;color:#bb86fc}@media (max-width: 768px){.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0}.viewer-controls{flex-direction:column;gap:1rem;align-items:stretch}.download-buttons{width:100%;justify-content:center}.metadata-grid{grid-template-columns:1fr}}.search-page{min-height:100vh;padding-bottom:4rem}.search-header{text-align:center;margin-bottom:3rem}.search-header h1{font-size:2.5rem;font-weight:800;color:var(--text-primary);margin-bottom:.5rem}.search-header p{font-size:1.125rem;color:var(--text-secondary)}.search-form-container{background:var(--bg-card);border-radius:16px;padding:2rem;margin-bottom:3rem;border:1px solid var(--border);box-shadow:0 4px 12px var(--shadow)}.search-form{max-width:800px;margin:0 auto}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.5rem;font-size:.95rem}.form-group label strong{color:var(--primary-light)}.form-group textarea{width:100%;padding:1rem;background:var(--bg-primary);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-family:Courier New,monospace;font-size:1rem;resize:vertical;transition:all .2s ease}.form-group textarea:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #3b82f61a}.form-hint{display:block;margin-top:.5rem;color:var(--text-muted);font-size:.875rem}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem}.form-group input[type=range]{width:100%;height:6px;background:var(--bg-primary);border-radius:3px;outline:none;-webkit-appearance:none}.form-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:20px;height:20px;background:var(--primary-light);border-radius:50%;cursor:pointer;transition:all .2s ease}.form-group input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 8px #3b82f61a}.form-group input[type=range]::-moz-range-thumb{width:20px;height:20px;background:var(--primary-light);border-radius:50%;cursor:pointer;border:none;transition:all .2s ease}.form-group input[type=range]::-moz-range-thumb:hover{transform:scale(1.2);box-shadow:0 0 0 8px #3b82f61a}.range-labels{display:flex;justify-content:space-between;margin-top:.5rem;font-size:.875rem;color:var(--text-muted)}.btn-submit{width:100%;margin-top:1rem;padding:1rem 2rem;font-size:1.125rem;display:flex;align-items:center;justify-content:center;gap:.75rem}.btn-submit svg{width:20px;height:20px}.spinner-small{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.error-message{background:#ef44441a;border:1px solid var(--error);border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;align-items:flex-start;gap:1rem}.error-message svg{width:24px;height:24px;color:var(--error);flex-shrink:0;margin-top:2px}.error-message h3{color:var(--error);margin:0 0 .5rem;font-size:1.125rem}.error-message p{color:var(--text-secondary);margin:0}.results-section{margin-top:3rem}.results-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.results-header h2{font-size:2rem;font-weight:700;color:var(--text-primary);margin:0}.results-meta{display:flex;gap:1rem;align-items:center}.result-count{background:var(--primary-light);color:#fff;padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.875rem}.result-time{color:var(--text-muted);font-size:.875rem}.results-chart{background:var(--bg-card);border-radius:12px;padding:2rem;margin-bottom:2rem;border:1px solid var(--border)}.results-chart h3{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:1.5rem}.results-grid{display:grid;gap:2rem}.result-card{background:var(--bg-card);border-radius:12px;padding:2rem;border:1px solid var(--border);transition:all .3s ease}.result-card:hover{box-shadow:0 8px 24px var(--shadow);transform:translateY(-2px)}.result-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;gap:1rem}.result-header-actions{display:flex;gap:.75rem;align-items:center;flex-shrink:0}.btn-small{padding:.5rem 1rem;font-size:.875rem;display:flex;align-items:center;gap:.5rem}.btn-small svg{width:16px;height:16px}.result-header h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin:0 0 .25rem}.drug-id{font-size:.875rem;color:var(--text-muted);margin:0}.grade-badge{padding:.5rem 1rem;border-radius:20px;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.grade-excellent{background:#10b98133;color:#10b981;border:1px solid #10b981}.grade-good{background:#3b82f633;color:#3b82f6;border:1px solid #3b82f6}.grade-fair{background:#f59e0b33;color:#f59e0b;border:1px solid #f59e0b}.grade-poor{background:#ef444433;color:#ef4444;border:1px solid #ef4444}.similarity-score{margin-bottom:1.5rem;padding:1.5rem;background:var(--bg-primary);border-radius:8px}.score-label{display:block;font-size:.875rem;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.score-value{display:block;font-size:2rem;font-weight:700;color:var(--primary-light);margin-bottom:1rem}.score-bar{width:100%;height:8px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.score-fill{height:100%;border-radius:4px;transition:width .3s ease}.result-details{display:flex;flex-direction:column;gap:1.5rem}.detail-section h4{font-size:1rem;font-weight:700;color:var(--text-primary);margin:0 0 1rem;text-transform:uppercase;letter-spacing:.5px;font-size:.875rem}.smiles-code{display:block;background:var(--bg-primary);color:var(--primary-light);padding:1rem;border-radius:6px;font-family:Courier New,monospace;font-size:.9rem;word-break:break-all;line-height:1.6}.properties-grid,.activity-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.property-item,.activity-item{background:var(--bg-primary);padding:1rem;border-radius:8px;text-align:center}.property-label,.activity-label{display:block;font-size:.75rem;color:var(--text-muted);margin-bottom:.5rem;text-transform:uppercase;font-weight:600;letter-spacing:.5px}.property-value,.activity-value{display:block;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.no-results{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.no-results svg{width:64px;height:64px;color:var(--text-muted);margin-bottom:1rem}.no-results h3{font-size:1.5rem;font-weight:700;color:var(--text-primary);margin-bottom:.5rem}@media (max-width: 768px){.search-header h1{font-size:2rem}.search-form-container{padding:1.5rem}.form-row{grid-template-columns:1fr}.results-header{flex-direction:column;align-items:flex-start}.results-meta{width:100%;justify-content:space-between}.result-header{flex-direction:column}.properties-grid,.activity-grid{grid-template-columns:repeat(2,1fr)}}.App{min-height:100vh;display:flex;flex-direction:column}:root{--primary: #1e3a8a;--primary-dark: #1e293b;--primary-light: #3b82f6;--secondary: #059669;--accent: #7c3aed;--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-card: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border: #475569;--success: #10b981;--warning: #f59e0b;--error: #ef4444;--shadow: rgba(0, 0, 0, .3)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:var(--bg-primary);color:var(--text-primary);line-height:1.6}code{font-family:Fira Code,Courier New,monospace;background:var(--bg-secondary);padding:2px 6px;border-radius:4px;font-size:.9em}#root{min-height:100vh}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--primary-light)}::selection{background:var(--primary-light);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.fade-in{animation:fadeIn .3s ease-out}.slide-in{animation:slideIn .3s ease-out}.container{max-width:1400px;margin:0 auto;padding:0 2rem}.grid{display:grid;gap:1.5rem}.flex{display:flex;gap:1rem}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.5rem;box-shadow:0 4px 6px var(--shadow);transition:all .3s ease}.card:hover{transform:translateY(-2px);box-shadow:0 8px 12px var(--shadow);border-color:var(--primary-light)}.btn{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background:var(--primary-light);color:#fff}.btn-primary:hover{background:var(--primary);transform:translateY(-2px);box-shadow:0 4px 8px var(--shadow)}.btn-secondary{background:var(--secondary);color:#fff}.btn-secondary:hover{background:#047857;transform:translateY(-2px)}.btn-outline{background:transparent;border:2px solid var(--border);color:var(--text-primary)}.btn-outline:hover{background:var(--bg-secondary);border-color:var(--primary-light)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:2px solid var(--border);border-radius:8px;color:var(--text-primary);font-size:1rem;transition:all .2s ease}.input:focus{outline:none;border-color:var(--primary-light);box-shadow:0 0 0 3px #3b82f61a}.input::placeholder{color:var(--text-muted)}.label{display:block;margin-bottom:.5rem;font-weight:600;color:var(--text-secondary)}.badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:600;display:inline-block}.badge-success{background:#10b98133;color:var(--success);border:1px solid var(--success)}.badge-warning{background:#f59e0b33;color:var(--warning);border:1px solid var(--warning)}.badge-error{background:#ef444433;color:var(--error);border:1px solid var(--error)}.badge-info{background:#3b82f633;color:var(--primary-light);border:1px solid var(--primary-light)}.loading{display:inline-block;width:20px;height:20px;border:3px solid var(--border);border-top-color:var(--primary-light);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{padding:1rem;background:#ef44441a;border:1px solid var(--error);border-radius:8px;color:var(--error);margin:1rem 0}.success-message{padding:1rem;background:#10b9811a;border:1px solid var(--success);border-radius:8px;color:var(--success);margin:1rem 0}@media (max-width: 768px){.container{padding:0 1rem}.grid{grid-template-columns:1fr!important}}
