*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;background:#f7fafc;color:#2d3748}#root{width:100%;min-height:100vh}a{text-decoration:none;color:inherit}button,input,textarea,select{font-family:inherit}.sidebar{width:280px;height:100vh;background:linear-gradient(180deg,#2d3748,#1a202c);color:#fff;display:flex;flex-direction:column;position:fixed;left:0;top:0;box-shadow:4px 0 12px #0000001a;z-index:1000}.sidebar-header{padding:2rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1);text-align:center}.logo{font-size:3rem;margin-bottom:.5rem;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.sidebar-title{margin:0;font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:2rem 0;overflow-y:auto}.nav-item{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;color:#ffffffb3;text-decoration:none;transition:all .3s ease;border-left:4px solid transparent;margin:.25rem 0}.nav-item:hover{background:#ffffff0d;color:#fff;padding-left:2rem}.nav-item.active{background:#667eea33;color:#fff;border-left-color:#667eea;font-weight:600}.nav-icon{font-size:1.5rem;min-width:24px}.nav-text{font-size:1rem}.sidebar-footer{padding:1.5rem;border-top:1px solid rgba(255,255,255,.1);text-align:center;color:#ffffff80;font-size:.85rem}.sidebar-footer p{margin:.25rem 0}@media(max-width:768px){.sidebar{width:100%;height:auto;position:relative}.sidebar-header{padding:1.5rem 1rem}.logo{font-size:2rem}.sidebar-title{font-size:1.2rem}.sidebar-nav{padding:1rem 0}.nav-item{padding:.875rem 1rem}.nav-item:hover{padding-left:1rem}}.home-container{padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.hero-section{text-align:center;padding:3rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;color:#fff;margin-bottom:3rem;box-shadow:0 10px 30px #667eea4d}.main-title{font-size:2.5rem;margin:0 0 1rem;font-weight:700}.subtitle{font-size:1.2rem;opacity:.95;margin:0}.overview-section,.ml-section{margin-bottom:3rem}.overview-section h2,.ml-section h2,.workflow-section h2{color:#2d3748;font-size:1.8rem;margin-bottom:1rem;font-weight:600}.overview-section p,.ml-section p{color:#4a5568;line-height:1.8;margin-bottom:1rem;font-size:1.05rem}.workflow-section{margin:3rem 0;padding:2rem;background:#f7fafc;border-radius:12px}.workflow-steps{display:flex;align-items:center;justify-content:space-between;margin-top:2rem;flex-wrap:wrap;gap:1rem}.workflow-step{flex:1;min-width:200px;background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;transition:transform .3s ease,box-shadow .3s ease}.workflow-step:hover{transform:translateY(-5px);box-shadow:0 4px 16px #667eea33}.step-number{width:50px;height:50px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;margin-bottom:1rem}.step-content h3{color:#2d3748;margin:0 0 .5rem;font-size:1.2rem}.step-content p{color:#718096;margin:0;font-size:.95rem}.workflow-arrow{font-size:2rem;color:#667eea;font-weight:700}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:3rem}.feature-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;text-align:center;transition:transform .3s ease,box-shadow .3s ease}.feature-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px #667eea33}.feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#2d3748;font-size:1.2rem;margin:0 0 .5rem}.feature-card p{color:#718096;margin:0;font-size:.95rem;line-height:1.6}@media(max-width:768px){.main-title{font-size:2rem}.subtitle{font-size:1rem}.workflow-steps{flex-direction:column}.workflow-arrow{transform:rotate(90deg);margin:1rem 0}.home-container{padding:1rem}}.about-container{padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .5s ease-in}.page-title{font-size:2.5rem;color:#2d3748;margin-bottom:2rem;font-weight:700;text-align:center}.section{margin-bottom:3rem;background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.section h2{color:#667eea;font-size:1.8rem;margin-bottom:1rem;font-weight:600;border-bottom:3px solid #667eea;padding-bottom:.5rem}.section h3{color:#2d3748;font-size:1.3rem;margin:1.5rem 0 .5rem;font-weight:600}.section p{color:#4a5568;line-height:1.8;margin-bottom:1rem;font-size:1.05rem}.species-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:1.5rem}.species-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1.5rem;border-radius:12px;text-align:center;transition:transform .3s ease}.species-card:hover{transform:translateY(-5px)}.species-card h3{color:#fff;margin:0 0 .5rem;font-size:1.3rem}.species-card p{color:#fffffff2;margin:0;font-size:.95rem}.features-list{display:grid;gap:1rem;margin-top:1.5rem}.feature-item{background:#f7fafc;padding:1.5rem;border-radius:8px;border-left:4px solid #667eea}.feature-label{font-weight:700;color:#667eea;font-size:1.1rem;margin-bottom:.5rem}.feature-item p{margin:0;color:#4a5568}.algorithms-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:1.5rem}.algorithm-card{background:#f7fafc;padding:1.5rem;border-radius:12px;border-top:4px solid #667eea;transition:transform .3s ease,box-shadow .3s ease}.algorithm-card:hover{transform:translateY(-5px);box-shadow:0 4px 16px #667eea33}.algorithm-card h3{color:#667eea;margin:0 0 1rem;font-size:1.2rem}.algorithm-card p{color:#4a5568;margin:0;font-size:.95rem;line-height:1.6}.tech-category{margin:1.5rem 0;padding:1.5rem;background:#f7fafc;border-radius:8px}.tech-category h3{color:#667eea;margin:0 0 1rem;font-size:1.2rem}.tech-category ul{list-style:none;padding:0;margin:0}.tech-category ul li{color:#4a5568;padding:.5rem 0 .5rem 1.5rem;position:relative;line-height:1.6}.tech-category ul li:before{content:"▸";position:absolute;left:0;color:#667eea;font-weight:700}.tech-category ul li strong{color:#2d3748}.applications-list{list-style:none;padding:0;margin:1.5rem 0}.applications-list li{color:#4a5568;padding:.75rem 0 .75rem 2rem;position:relative;line-height:1.6;font-size:1.05rem}.applications-list li:before{content:"✓";position:absolute;left:0;color:#48bb78;font-weight:700;font-size:1.2rem}.outcomes-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-top:1.5rem}.outcome-card{background:linear-gradient(135deg,#48bb78,#38a169);color:#fff;padding:1.5rem;border-radius:12px;transition:transform .3s ease}.outcome-card:hover{transform:translateY(-5px)}.outcome-card h4{color:#fff;margin:0 0 .5rem;font-size:1.2rem;font-weight:600}.outcome-card p{color:#fffffff2;margin:0;font-size:.95rem}@media(max-width:768px){.about-container{padding:1rem}.page-title{font-size:2rem}.section{padding:1.5rem}.section h2{font-size:1.5rem}}.model-config-container{padding:2rem;max-width:1200px;margin:0 auto;animation:fadeIn .5s ease-in}.info-card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.info-card h2{color:#667eea;font-size:1.8rem;margin:0 0 1.5rem;font-weight:600;border-bottom:3px solid #667eea;padding-bottom:.5rem}.info-card h3{color:#2d3748;font-size:1.3rem;margin:1.5rem 0 1rem;font-weight:600}.section-description{color:#4a5568;line-height:1.8;margin-bottom:1.5rem;font-size:1.05rem}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1rem}.info-item{display:flex;flex-direction:column;padding:1rem;background:#f7fafc;border-radius:8px;border-left:4px solid #667eea}.info-label{font-weight:600;color:#2d3748;font-size:.9rem;margin-bottom:.5rem}.info-value{color:#4a5568;font-size:1.1rem}.accuracy-high{color:#48bb78;font-weight:700;font-size:1.3rem}.features-table{background:#f7fafc;border-radius:8px;overflow:hidden}.table-header{display:grid;grid-template-columns:2fr 1fr 1.5fr 2fr;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:1rem;font-weight:600;gap:1rem}.table-row{display:grid;grid-template-columns:2fr 1fr 1.5fr 2fr;padding:1rem;border-bottom:1px solid #e2e8f0;gap:1rem;color:#4a5568;align-items:center}.table-row:last-child{border-bottom:none}.table-row:hover{background:#fff}.feature-name{font-weight:600;color:#2d3748}.api-section{background:#f7fafc;padding:1.5rem;border-radius:8px;margin-bottom:1.5rem}.api-detail{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.api-detail:last-child{margin-bottom:0}.api-label{font-weight:600;color:#2d3748;min-width:120px}.api-badge{padding:.5rem 1rem;border-radius:6px;font-weight:700;font-size:.9rem}.method-post{background:#48bb78;color:#fff}.api-code{background:#2d3748;color:#68d391;padding:.5rem 1rem;border-radius:6px;font-family:Courier New,monospace;font-size:.95rem}.api-subsection{margin:1.5rem 0}.code-block{background:#2d3748;color:#68d391;padding:1.5rem;border-radius:8px;overflow-x:auto;margin-top:1rem}.code-block pre{margin:0;font-family:Courier New,monospace;font-size:.95rem;line-height:1.6}.code-block.example{background:#2c5282;color:#90cdf4}.workflow-explanation{display:flex;flex-direction:column;gap:1.5rem}.workflow-step-detail{display:flex;gap:1.5rem;align-items:flex-start;padding:1.5rem;background:#f7fafc;border-radius:12px;transition:transform .3s ease}.workflow-step-detail:hover{transform:translate(10px);background:#edf2f7}.step-icon{min-width:60px;height:60px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.8rem;font-weight:700}.step-text h3{color:#2d3748;margin:0 0 .5rem;font-size:1.2rem}.step-text p{color:#4a5568;margin:0;line-height:1.6;font-size:1rem}.note-card{background:linear-gradient(135deg,#fef5e7,#fdebd0);border-left:5px solid #f39c12}.note-card h2{color:#d68910;border-bottom-color:#f39c12}.notes-list{list-style:none;padding:0;margin:0}.notes-list li{color:#4a5568;padding:.75rem 0 .75rem 2rem;position:relative;line-height:1.6;font-size:1.05rem}.notes-list li:before{content:"ℹ";position:absolute;left:0;color:#f39c12;font-weight:700;font-size:1.2rem}@media(max-width:768px){.model-config-container{padding:1rem}.info-card{padding:1.5rem}.table-header,.table-row{grid-template-columns:1fr;gap:.5rem}.table-header>div:not(:first-child),.table-row>div:not(:first-child){font-size:.9rem}.workflow-step-detail{flex-direction:column;align-items:center;text-align:center}.api-detail{flex-direction:column;align-items:flex-start}.api-label{min-width:auto}}.prediction-container{padding:2rem;max-width:1400px;margin:0 auto;animation:fadeIn .5s ease-in}.prediction-layout{display:grid;grid-template-columns:1fr 1fr;gap:2rem;margin-top:2rem}.card{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 8px #0000001a}.card h2{color:#2d3748;font-size:1.5rem;margin:0 0 1.5rem;font-weight:600}.image-upload-section{margin-bottom:2rem}.image-upload-label{display:block;color:#2d3748;font-weight:600;margin-bottom:.75rem}.image-upload-area{border:2px dashed #cbd5e0;border-radius:8px;overflow:hidden;transition:border-color .3s ease}.image-upload-area:hover{border-color:#667eea}.upload-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;cursor:pointer;transition:background .3s ease}.upload-placeholder:hover{background:#f7fafc}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-placeholder p{color:#2d3748;font-weight:600;margin:0 0 .5rem}.upload-hint{color:#718096;font-size:.9rem}.image-preview{position:relative;width:100%;max-height:300px;display:flex;align-items:center;justify-content:center;background:#f7fafc}.image-preview img{max-width:100%;max-height:300px;object-fit:contain}.remove-image{position:absolute;top:10px;right:10px;width:32px;height:32px;background:#e53e3e;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:1.5rem;display:flex;align-items:center;justify-content:center;transition:background .3s ease}.remove-image:hover{background:#c53030}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column}.form-group label{color:#2d3748;font-weight:600;margin-bottom:.5rem;font-size:.95rem}.required{color:#e53e3e}.form-group input{padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.error-message{background:#fed7d7;color:#c53030;padding:1rem;border-radius:8px;margin-bottom:1.5rem;display:flex;align-items:center;gap:.5rem}.error-icon{font-size:1.2rem}.button-group{display:flex;gap:1rem}.btn{flex:1;padding:.875rem 1.5rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.5rem}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#e2e8f0;color:#2d3748}.btn-secondary:hover{background:#cbd5e0}.spinner{width:16px;height:16px;border:2px solid #ffffff;border-top-color:transparent;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-card{animation:slideIn .5s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.result-content{display:flex;flex-direction:column;gap:2rem}.prediction-badge{padding:2rem;border-radius:12px;text-align:center;color:#fff}.species-icon{font-size:4rem;margin-bottom:1rem}.species-name{font-size:2rem;font-weight:700;text-transform:capitalize}.confidence-section h3,.probabilities-section h3{color:#2d3748;font-size:1.2rem;margin:0 0 1rem;font-weight:600}.confidence-bar-container{background:#e2e8f0;height:30px;border-radius:15px;overflow:hidden;margin-bottom:.5rem}.confidence-bar{height:100%;border-radius:15px;transition:width .8s ease;display:flex;align-items:center;justify-content:flex-end;padding-right:.5rem}.confidence-value{text-align:center;font-size:1.5rem;font-weight:700;color:#2d3748}.probability-list{display:flex;flex-direction:column;gap:1rem}.probability-item{display:grid;grid-template-columns:120px 1fr 60px;gap:1rem;align-items:center}.probability-label{display:flex;align-items:center;gap:.5rem;color:#2d3748;font-weight:600;font-size:.95rem}.species-dot{width:12px;height:12px;border-radius:50%}.probability-bar-container{background:#e2e8f0;height:20px;border-radius:10px;overflow:hidden}.probability-bar{height:100%;border-radius:10px;transition:width .8s ease}.probability-value{text-align:right;color:#4a5568;font-weight:600;font-size:.9rem}.placeholder-card{height:100%;display:flex;align-items:center;justify-content:center;min-height:400px}.placeholder-content{text-align:center;color:#718096}.placeholder-icon{font-size:4rem;margin-bottom:1rem;opacity:.5}.placeholder-content h3{color:#2d3748;margin:0 0 .5rem;font-size:1.3rem}.placeholder-content p{color:#718096;margin:0}@media(max-width:1024px){.prediction-layout{grid-template-columns:1fr}}@media(max-width:768px){.prediction-container{padding:1rem}.form-grid{grid-template-columns:1fr}.button-group{flex-direction:column}.probability-item{grid-template-columns:100px 1fr 50px;gap:.5rem}}.app-container{display:flex;min-height:100vh}.main-content{flex:1;margin-left:280px;background:#f7fafc;min-height:100vh}@media(max-width:768px){.main-content{margin-left:0;margin-top:0}}
