*{box-sizing:border-box;padding:0;margin:0}body,html{max-width:100vw;overflow-x:hidden;overflow-y:auto;font-family:-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}a{color:inherit;text-decoration:none}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.navbar{justify-content:space-between;padding:1rem 2rem;background-color:#fff;border-bottom:2px solid #e0e0e0;box-shadow:0 2px 4px rgba(0,0,0,.1)}.navbar,.navbar-left{display:flex;align-items:center}.navbar-left{gap:2rem}.navbar-brand{margin:0;font-size:2rem;font-weight:700}.navbar-brand a.main{color:#900;text-decoration:none;transition:color .3s ease}.navbar-brand a.main:hover{color:#c00}.navbar-tabs{display:flex;align-items:center;gap:0}.nav-tab{padding:.8rem 1.5rem;font-size:1rem;font-weight:500;background-color:transparent;color:#333;cursor:pointer;transition:all .3s ease;border:none;border-bottom:3px solid transparent;text-decoration:none;display:inline-block}.nav-tab:hover{color:#900;background-color:#f5f5f5}.nav-tab.active{color:#900;border-bottom-color:#900;font-weight:600}.usc-logo{height:50px;width:auto}.container{max-width:1400px;margin:0 auto;padding:2rem}.search-section{background-color:#f9f9f9;border-radius:10px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.container>.search-section:first-of-type{background:linear-gradient(135deg,#fff,#f8f9fa);border-radius:16px;padding:2.5rem;box-shadow:0 4px 20px rgba(0,0,0,.08);border:1px solid rgba(153,0,0,.1);position:relative;overflow:hidden}.container>.search-section:first-of-type:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#900,#c00,#900)}.container>.search-section:first-of-type h2{margin-bottom:.5rem;font-size:1.9rem;font-weight:700}.container>.search-section:first-of-type>p{color:#666;font-size:.95rem;margin-bottom:2rem;font-style:italic}.search-section h2{margin-bottom:1.5rem;color:#333;font-size:1.8rem}.search-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-bottom:1.5rem}.container>.search-section:first-of-type .input-group{position:relative}.container>.search-section:first-of-type .input-group label{margin-bottom:.6rem;font-weight:600;color:#333;font-size:.95rem;display:flex;align-items:center;gap:.5rem}.container>.search-section:first-of-type .input-group label:before{content:"";width:4px;height:16px;background:linear-gradient(135deg,#900,#c00);border-radius:2px}.container>.search-section:first-of-type .input-group input{padding:.9rem 1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:.95rem;font-family:Courier New,monospace;transition:all .3s ease;background-color:#fff;width:100%}.container>.search-section:first-of-type .input-group input:focus{outline:none;border-color:#900;box-shadow:0 0 0 4px rgba(153,0,0,.1);transform:translateY(-1px)}.container>.search-section:first-of-type .input-group input::placeholder{color:#999;font-style:italic}.container>.search-section:first-of-type .input-group input:hover:not(:focus){border-color:#ccc}.input-group{display:flex;flex-direction:column}.input-group label{margin-bottom:.5rem;font-weight:600;color:#555}.input-group textarea{padding:.8rem;border:1px solid #ddd;border-radius:5px;font-size:.95rem;font-family:Courier New,monospace;resize:vertical;min-height:100px}.input-group textarea:focus{outline:none;border-color:#900;box-shadow:0 0 0 2px rgba(153,0,0,.1)}.search-button{padding:.8rem 2rem;font-size:1.1rem;font-weight:600;background-color:#900;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease}.search-button:hover{background-color:#c00}.container>.search-section:first-of-type .search-button{padding:.9rem 2.2rem;font-size:1rem;background:linear-gradient(135deg,#900,#c00);border-radius:8px;box-shadow:0 2px 8px rgba(153,0,0,.2);position:relative;overflow:hidden;display:inline-flex;align-items:center;gap:.5rem;transition:all .3s ease}.container>.search-section:first-of-type .search-button:before{content:"";position:absolute;top:50%;left:50%;width:0;height:0;border-radius:50%;background:hsla(0,0%,100%,.3);transform:translate(-50%,-50%);transition:width .6s,height .6s}.container>.search-section:first-of-type .search-button:hover:not(:disabled){background:linear-gradient(135deg,#c00,#f33);transform:translateY(-2px);box-shadow:0 4px 12px rgba(153,0,0,.3)}.container>.search-section:first-of-type .search-button:hover:not(:disabled):before{width:300px;height:300px}.container>.search-section:first-of-type .search-button:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 6px rgba(153,0,0,.2)}.container>.search-section:first-of-type .search-button:disabled{background:#ccc;box-shadow:none;transform:none}.filter-actions{display:flex;gap:1rem;margin-top:1.5rem;flex-wrap:wrap;align-items:center}.filter-actions .search-button.secondary{background:#fff;color:#666;border:2px solid #ddd;box-shadow:0 2px 4px rgba(0,0,0,.05)}.filter-actions .search-button.secondary:hover{background:#f5f5f5;border-color:#999;color:#333;transform:translateY(-1px);box-shadow:0 2px 8px rgba(0,0,0,.1)}.search-button .spinner{display:inline-block;width:16px;height:16px;border:2px solid hsla(0,0%,100%,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite;margin-right:.5rem}.table-section{background-color:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.table-section h2{margin-bottom:1.5rem;color:#333;font-size:1.8rem}.table-wrapper{overflow-x:auto;overflow-y:visible;margin-bottom:1.5rem;width:100%;max-width:100%}table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:auto}thead{background-color:#900;color:#fff}th{padding:1rem .8rem;text-align:left;font-weight:600;white-space:nowrap}td{padding:.8rem;border-bottom:1px solid #eee;word-wrap:break-word;overflow-wrap:break-word}tbody tr:hover{background-color:#f5f5f5}.smiles-cell{max-width:none;overflow:visible;text-overflow:clip;white-space:normal;word-break:break-all;font-family:Courier New,monospace;font-size:.85rem;min-width:200px}.pagination{display:flex;justify-content:center;align-items:center;gap:1rem;margin-top:1.5rem}.pagination button{padding:.5rem 1rem;background-color:#900;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:background-color .3s ease}.pagination button:hover:not(:disabled){background-color:#c00}.pagination button:disabled{background-color:#ccc;cursor:not-allowed}.pagination-info{font-size:.95rem;color:#666}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.error{background-color:#ffe6e6;border:1px solid red;color:#c00;padding:1rem;border-radius:5px;margin-bottom:1rem}.footer{background-color:#f5f5f5;border-top:1px solid #e0e0e0;padding:2rem;text-align:center;margin-top:3rem}.footer p{margin:0;color:#666;font-size:.95rem;line-height:1.6}.footer a{color:#900;text-decoration:none;font-weight:600;transition:color .3s ease}.footer a:hover{color:#c00;text-decoration:underline}.similarity-tab{max-width:100%;width:100%;margin:0 auto}.similarity-header{margin-bottom:2rem;text-align:center}.similarity-header h2{color:#900;font-size:2rem;margin-bottom:.5rem}.similarity-header .subtitle{color:#666;font-size:1rem}.similarity-form{background-color:#f9f9f9;border-radius:10px;padding:2rem;margin-bottom:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1)}.similarity-form .input-group{margin-bottom:1.5rem}.similarity-form .input-group:last-of-type{margin-bottom:0}.similarity-input{width:100%;padding:.8rem;border:2px solid #ddd;border-radius:5px;font-size:1rem;font-family:Courier New,monospace;resize:vertical;transition:border-color .3s ease,box-shadow .3s ease;background-color:#fff}.similarity-input:focus{outline:none;border-color:#900;box-shadow:0 0 0 3px rgba(153,0,0,.1)}.similarity-input:hover:not(:focus){border-color:#ccc}.similarity-input::placeholder{color:#999;font-style:italic}.similarity-slider{width:100%;height:8px;border-radius:5px;background:linear-gradient(90deg,#fcc,#900);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.similarity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:#900;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.2)}.similarity-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:#900;cursor:pointer;border:2px solid #fff;box-shadow:0 2px 4px rgba(0,0,0,.2)}.help-text{margin-top:.5rem;font-size:.9rem;color:#666;font-style:italic}.button-group{display:flex;gap:1rem;margin-top:1.5rem}.search-button.primary{flex:1 1;padding:1rem 2rem;font-size:1.1rem;font-weight:600;background-color:#900;color:#fff;border:none;border-radius:5px;cursor:pointer;transition:all .3s ease}.search-button.primary:hover:not(:disabled){background-color:#c00;transform:translateY(-2px);box-shadow:0 4px 8px rgba(153,0,0,.3)}.search-button.secondary{padding:1rem 2rem;font-size:1.1rem;font-weight:600;background-color:#fff;color:#900;border:2px solid #900;border-radius:5px;cursor:pointer;transition:all .3s ease}.search-button.secondary:hover:not(:disabled){background-color:#900;color:#fff}.search-button:disabled{background-color:#ccc;color:#999;border-color:#ccc;cursor:not-allowed;transform:none}.error-box{background-color:#ffe6e6;border-left:4px solid red;color:#c00;padding:1rem 1.5rem;border-radius:5px;margin-bottom:2rem}.error-box strong{display:block;margin-bottom:.3rem}.results-section{background-color:#fff;border-radius:10px;padding:2rem;box-shadow:0 2px 8px rgba(0,0,0,.1);width:100%;max-width:100%;overflow-x:visible}.results-section h3{margin-bottom:1rem;color:#333;font-size:1.5rem}.query-smiles{background-color:#f5f5f5;padding:.3rem .6rem;border-radius:3px;font-family:Courier New,monospace;font-size:.95rem;color:#900}.results-summary{margin-bottom:1.5rem;color:#666;font-size:1rem}.results-summary strong{color:#900;font-weight:700}.similarity-table{width:100%;border-collapse:collapse;font-size:.95rem;table-layout:auto}.similarity-table th{background-color:#900;color:#fff;padding:1rem;text-align:left;font-weight:600;white-space:nowrap}.similarity-table td{padding:1rem;border-bottom:1px solid #eee;word-wrap:break-word;overflow-wrap:break-word}.similarity-table tbody tr:hover{background-color:#f5f5f5;transition:background-color .2s ease}.similarity-badge{display:inline-block;padding:.4rem .8rem;border-radius:20px;font-weight:600;font-size:.95rem}.similarity-badge.high{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.similarity-badge.medium{background-color:#fff3cd;color:#856404;border:1px solid #ffeaa7}.similarity-badge.low{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.loading-box{text-align:center;padding:3rem;background-color:#fff;border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.1)}.loading-box p{margin-top:1rem;color:#666;font-size:1.1rem}.spinner{display:inline-block;width:50px;height:50px;border:5px solid #f3f3f3;border-top-color:#900;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.visualize-button{padding:.4rem .8rem;font-size:.85rem;font-weight:500;background-color:#900;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:all .3s ease;white-space:nowrap;display:inline-flex;align-items:center;gap:.3rem}.visualize-button:hover{background-color:#c00;transform:translateY(-1px);box-shadow:0 2px 4px rgba(153,0,0,.3)}.visualize-button:active{transform:translateY(0)}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:#fff;border-radius:12px;box-shadow:0 10px 40px rgba(0,0,0,.3);max-width:650px;width:90%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e0e0e0;background-color:#f9f9f9;border-radius:12px 12px 0 0}.modal-header h3{margin:0;color:#900;font-size:1.5rem;font-weight:700}.modal-close{background:none;border:none;font-size:2rem;color:#666;cursor:pointer;transition:all .2s ease;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%}.modal-close:hover{color:#900;background-color:#ffe6e6;transform:rotate(90deg)}.modal-body{padding:2rem}.molecule-name{margin-bottom:1rem;padding:.8rem;background-color:#f5f5f5;border-radius:5px;font-size:1rem}.molecule-name strong{color:#900;margin-right:.5rem}.smiles-display{margin-bottom:1.5rem;padding:.8rem;background-color:#f5f5f5;border-radius:5px;word-break:break-all}.smiles-display strong{color:#900;margin-right:.5rem}.smiles-display code{font-family:Courier New,monospace;font-size:.9rem;color:#333}.canvas-container{display:flex;justify-content:center;align-items:center;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;padding:1rem;min-height:400px}.canvas-container canvas{max-width:100%;height:auto}.loading-spinner{text-align:center;padding:2rem}.loading-spinner .spinner{display:inline-block;width:50px;height:50px;border:5px solid #f3f3f3;border-top-color:#900;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.loading-spinner p{color:#666;font-size:1rem}.error-message{text-align:center;padding:2rem;color:#c00}.error-message p{margin:0;font-size:1rem}.modal-footer{display:flex;justify-content:center;gap:1rem;padding:1.5rem;border-top:2px solid #e0e0e0;background-color:#f9f9f9;border-radius:0 0 12px 12px}.modal-button{padding:.8rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:5px;cursor:pointer;transition:all .3s ease}.modal-button.primary{background-color:#900;color:#fff}.modal-button.primary:hover{background-color:#c00;transform:translateY(-2px);box-shadow:0 4px 8px rgba(153,0,0,.3)}.modal-button.secondary{background-color:#fff;color:#900;border:2px solid #900}.modal-button.secondary:hover{background-color:#900;color:#fff}@media (max-width:768px){.search-inputs{grid-template-columns:1fr}.navbar{gap:1rem}.navbar,.navbar-left{flex-direction:column}.navbar-left{gap:.5rem}.navbar-tabs{flex-wrap:wrap}.nav-tab{padding:.6rem 1rem;font-size:.9rem}.table-wrapper{font-size:.8rem}.button-group{flex-direction:column}.search-button.primary,.search-button.secondary{width:100%}.similarity-header h2{font-size:1.5rem}.modal-content{width:95%;max-height:95vh}.modal-body{padding:1rem}.canvas-container{min-height:300px}.modal-footer{flex-direction:column}.modal-button{width:100%}.hero-welcome{padding:2rem 1rem}.hero-content h1{font-size:2rem}.hero-description{font-size:1rem}.hero-features{grid-template-columns:1fr}}.hero-welcome{background:linear-gradient(135deg,#900,#c00);border-radius:16px;padding:3rem 2rem;margin-bottom:3rem;color:#fff;box-shadow:0 4px 20px rgba(153,0,0,.3)}.hero-content{max-width:1200px;margin:0 auto;text-align:center}.hero-content h1{font-size:2.5rem;margin-bottom:1rem;font-weight:700}.hero-description{font-size:1.2rem;margin-bottom:2.5rem;opacity:.95;line-height:1.6;max-width:800px;margin-left:auto;margin-right:auto}.hero-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));grid-gap:1.5rem;gap:1.5rem;margin-top:2rem}.feature-card{background:hsla(0,0%,100%,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:2rem;transition:all .3s ease;border:1px solid hsla(0,0%,100%,.2)}.feature-card:hover{background:hsla(0,0%,100%,.15);transform:translateY(-5px);box-shadow:0 8px 20px rgba(0,0,0,.2)}.feature-link{text-decoration:none;color:#fff;display:block}.feature-icon{font-size:2.5rem;margin-bottom:1rem;opacity:.9;line-height:1;font-weight:300;filter:grayscale(100%) brightness(0) invert(1)}.feature-card h3{font-size:1.3rem;margin-bottom:.5rem;font-weight:600}.feature-card p{font-size:.95rem;opacity:.9;line-height:1.5}