.image-upload-container{flex:1}.upload-area{border:3px dashed rgba(255,255,255,.5);border-radius:12px;padding:2rem;background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);cursor:pointer;transition:all .3s ease;min-height:300px;display:flex;align-items:center;justify-content:center}.upload-area:hover,.upload-area.drag-active{border-color:#fffc;background:#ffffff26;transform:scale(1.02)}.file-input{display:none}.upload-placeholder{text-align:center;color:#fff}.upload-placeholder svg{margin-bottom:1rem;opacity:.7}.upload-placeholder p{font-size:1.1rem;margin-bottom:.5rem}.upload-hint{font-size:.9rem;opacity:.7}.preview-container{position:relative;width:100%;max-width:500px;border-radius:8px;overflow:hidden}.preview-image{width:100%;height:auto;display:block}.preview-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s ease}.preview-container:hover .preview-overlay{opacity:1}.preview-overlay p{color:#fff;font-size:1.1rem}.file-info{margin-top:1rem;padding:1rem;background:#ffffff1a;border-radius:8px;color:#fff}.file-info p{margin:.25rem 0;font-size:.9rem}.analysis-container{flex:1;background:#fffffff2;border-radius:12px;padding:2rem;box-shadow:0 8px 32px #0000001a}.analysis-container h2{color:#333;margin-bottom:1.5rem;font-size:1.8rem}.loading-state{text-align:center;padding:3rem 0}.spinner{width:50px;height:50px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-state p{color:#666;font-size:1.1rem}.analysis-result{display:flex;flex-direction:column;gap:1.5rem}.result-section{padding-bottom:1.5rem;border-bottom:1px solid #eee}.result-section:last-child{border-bottom:none}.result-section h3{color:#667eea;margin-bottom:.75rem;font-size:1.2rem}.description{color:#333;line-height:1.6;font-size:1rem}.quality-levels-container{display:flex;flex-direction:row;flex-wrap:wrap;gap:.75rem;align-items:center}.quality-badge{display:inline-block;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;color:#fff;text-align:center;background:#9ca3af;transition:all .3s ease;cursor:default}.quality-badge.active{background:linear-gradient(135deg,#3b82f6,#2563eb);transform:scale(1.1);box-shadow:0 4px 12px #3b82f666}.severity-badge{display:inline-block;padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;color:#fff;text-align:center;background:#9ca3af;transition:all .3s ease;cursor:default}.severity-badge.active{background:linear-gradient(135deg,#3b82f6,#2563eb);transform:scale(1.1);box-shadow:0 4px 12px #3b82f666}.tongue-diagnosis-status{display:flex;align-items:center}.tongue-diagnosis-badge{display:inline-block;padding:.75rem 1.5rem;border-radius:8px;font-size:1.1rem;font-weight:600;color:#fff;text-align:center;transition:all .3s ease}.tongue-diagnosis-badge.suitable{background:linear-gradient(135deg,#10b981,#059669);box-shadow:0 4px 12px #10b9814d}.tongue-diagnosis-badge.not-suitable{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 4px 12px #ef44444d}.quality-description{color:#666;font-size:.95rem;line-height:1.5;margin:0}.empty-state{text-align:center;padding:3rem 0;color:#999;font-size:1rem}.model-selector{background:#fffffff2;border-radius:12px;padding:1.5rem;box-shadow:0 8px 32px #0000001a;margin-bottom:2rem}.selector-header h3{color:#333;margin:0 0 1.5rem;font-size:1.3rem}.selector-content{display:flex;flex-direction:column;gap:1.5rem}.section-label{display:block;color:#667eea;font-weight:600;margin-bottom:.75rem;font-size:.95rem}.provider-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.provider-btn{padding:.75rem 1.5rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;color:#333;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.provider-btn:hover{border-color:#667eea;background:#f5f3ff;transform:translateY(-2px)}.provider-btn.active{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px #667eea4d}.model-dropdown{position:relative}.model-select-btn{width:100%;padding:1rem;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;transition:all .3s ease}.model-select-btn:hover{border-color:#667eea;background:#f5f3ff}.model-name{font-weight:600;color:#333;font-size:1rem}.model-desc{font-size:.85rem;color:#666}.dropdown-arrow{position:absolute;right:1rem;top:50%;transform:translateY(-50%);color:#667eea;font-size:.8rem}.model-dropdown-menu{position:absolute;top:100%;left:0;right:0;margin-top:.5rem;background:#fff;border:2px solid #e0e0e0;border-radius:8px;box-shadow:0 8px 24px #00000026;z-index:100;max-height:300px;overflow-y:auto}.model-option{width:100%;padding:1rem;border:none;background:#fff;text-align:left;cursor:pointer;transition:background .2s ease;border-bottom:1px solid #f0f0f0}.model-option:last-child{border-bottom:none}.model-option:hover{background:#f5f3ff}.model-option.selected{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.model-option.selected .model-option-name,.model-option.selected .model-option-desc{color:#fff}.model-option-name{font-weight:600;color:#333;margin-bottom:.25rem}.model-option-desc{font-size:.85rem;color:#666}.current-selection{padding:1rem;background:#f8f9fa;border-radius:8px;display:flex;flex-direction:column;gap:.5rem}.selection-item{display:flex;justify-content:space-between;align-items:center}.selection-label{color:#666;font-size:.9rem}.selection-value{color:#333;font-weight:600;font-size:.95rem}@media (max-width: 768px){.provider-buttons{flex-direction:column}.provider-btn{width:100%}}.history-list-container{margin-top:3rem;padding:2rem;background:#fffffff2;border-radius:12px;box-shadow:0 8px 32px #0000001a}.history-title{color:#333;margin:0 0 1.5rem;font-size:1.8rem;border-bottom:2px solid #667eea;padding-bottom:.5rem}.history-items{display:flex;flex-direction:column;gap:1rem;max-height:600px;overflow-y:auto}.history-item{border:1px solid #e0e0e0;border-radius:8px;padding:1rem;background:#fafafa;transition:all .3s ease}.history-item:hover{border-color:#667eea;background:#f5f3ff;box-shadow:0 4px 12px #667eea26}.history-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid #e0e0e0}.history-image-name{font-weight:600;color:#333;font-size:1rem;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-right:1rem}.history-time{color:#666;font-size:.85rem;white-space:nowrap}.history-item-content{display:flex;flex-direction:column}.history-indicators{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.history-indicator{display:flex;flex-direction:column;gap:.25rem}.indicator-label{color:#666;font-size:.85rem;font-weight:500}.indicator-value{color:#333;font-size:.95rem;font-weight:600}.indicator-value.suitable{color:#10b981}.indicator-value.not-suitable{color:#ef4444}@media (max-width: 768px){.history-indicators{grid-template-columns:1fr}.history-item-header{flex-direction:column;align-items:flex-start;gap:.5rem}.history-image-name{margin-right:0}}.app{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.app-header{text-align:center;color:#fff;margin-bottom:3rem}.app-header h1{font-size:2.5rem;margin-bottom:.5rem;font-weight:700}.app-header p{font-size:1.1rem;opacity:.9}.app-main{max-width:1400px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.app>.history-list-container{max-width:1400px;margin:3rem auto 0;width:100%}.left-panel{display:flex;flex-direction:column;gap:2rem}.analyze-button-container{display:flex;justify-content:center;padding:1rem 0}.analyze-button{padding:1rem 2rem;font-size:1.1rem;font-weight:600;color:#fff;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #667eea4d;min-width:150px}.analyze-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.analyze-button:active:not(:disabled){transform:translateY(0)}.analyze-button:disabled{opacity:.6;cursor:not-allowed}@media (min-width: 768px){.app-main{flex-direction:row;align-items:flex-start}.left-panel{flex:0 0 400px}}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}
