.message-type-tabs{display:flex;gap:.75rem;margin-bottom:1rem}.message-type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:1rem;cursor:pointer;font-size:.9375rem;transition:all .3s ease;color:#666}.message-type-tab:hover:not(:disabled){border-color:#2e7d32;background:#f1f8f4;color:#2e7d32}.quick-templates{background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #e8f5e9;border-radius:1.25rem;padding:1.25rem;margin-bottom:1rem;box-shadow:0 2px 8px #2e7d3214}.templates-header{display:flex;align-items:center;gap:.625rem;margin-bottom:1rem;padding-bottom:.875rem;border-bottom:2px solid #e8f5e9}.templates-icon{font-size:1.375rem;line-height:1}.templates-title{font-size:1rem;color:#2e7d32;font-weight:600}.templates-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.template-btn{display:flex;align-items:center;justify-content:center;padding:.875rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:1rem;cursor:pointer;transition:all .3s ease;font-size:.9375rem;color:#333;font-weight:500}.template-btn:hover:not(:disabled){border-color:#2e7d32;background:linear-gradient(135deg,#e8f5e9,#f1f8f4);transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3226}.template-btn:active:not(:disabled){transform:translateY(0)}.template-btn:disabled{opacity:.5;cursor:not-allowed}.template-icon{font-size:2rem;line-height:1}.template-text{font-weight:500;text-align:center}@media(max-width:768px){.chat-header{display:none}.chat-messages{padding:1rem}.message-content{max-width:85%}.chat-input-container{padding:1rem}.message-type-tabs{margin-bottom:.75rem}.message-type-tab{padding:.625rem 1rem;font-size:.875rem}.message-type-tab span{display:none}.chat-send-button{padding:.875rem 1.25rem}.image-upload-button{padding:1.5rem}.image-preview{max-width:150px;max-height:120px}.image-upload-hint{padding:.625rem .875rem}.hint-icon{font-size:1.125rem}.hint-text{font-size:.8125rem}.question-content{padding:1rem}.question-options{grid-template-columns:1fr}.question-actions{flex-direction:column}.question-action-btn{width:100%;justify-content:center}.image-input-options{grid-template-columns:1fr}.image-option-btn{padding:1.5rem 1rem}.camera-video{max-height:300px}.camera-controls{padding:1rem;flex-direction:column}.camera-control-btn{width:100%;justify-content:center}.quick-templates{padding:1rem;margin-bottom:.75rem}.templates-header{margin-bottom:.75rem;padding-bottom:.625rem}.templates-icon{font-size:1.125rem}.templates-title{font-size:.9375rem}.templates-grid{grid-template-columns:repeat(2,1fr);gap:.5rem}.template-btn{padding:.875rem .5rem;font-size:.8125rem}.template-icon{font-size:1.5rem}}/*! tailwindcss v4.1.3 | MIT License | https://tailwindcss.com */@layer properties{@supports (((-webkit-hyphens: none)) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color: rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x: rotateX(0);--tw-rotate-y: rotateY(0);--tw-rotate-z: rotateZ(0);--tw-skew-x: skewX(0);--tw-skew-y: skewY(0);--tw-blur: initial;--tw-brightness: initial;--tw-contrast: initial;--tw-grayscale: initial;--tw-hue-rotate: initial;--tw-invert: initial;--tw-opacity: initial;--tw-saturate: initial;--tw-sepia: initial;--tw-drop-shadow: initial;--tw-drop-shadow-color: initial;--tw-drop-shadow-alpha: 100%;--tw-drop-shadow-size: initial}}}@layer theme{:root,:host{--font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--default-font-family: var(--font-sans);--default-font-feature-settings: var(--font-sans--font-feature-settings);--default-font-variation-settings: var(--font-sans--font-variation-settings);--default-mono-font-family: var(--font-mono);--default-mono-font-feature-settings: var(--font-mono--font-feature-settings);--default-mono-font-variation-settings: var(--font-mono--font-variation-settings)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings, normal);font-variation-settings:var(--default-font-variation-settings, normal);-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings, normal);font-variation-settings:var(--default-mono-font-variation-settings, normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1;color:currentColor}@supports (color: color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentColor 50%,transparent)}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}body{background-color:var(--background);color:var(--foreground)}*{border-color:var(--border);outline-color:var(--ring)}@supports (color: color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring) 50%,transparent)}}body{background-color:var(--background);color:var(--foreground);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) h1{font-size:var(--text-2xl);font-weight:var(--font-weight-medium);line-height:1.5}:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) h2{font-size:var(--text-xl);font-weight:var(--font-weight-medium);line-height:1.5}:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) h3{font-size:var(--text-lg);font-weight:var(--font-weight-medium);line-height:1.5}:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) h4,:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) label,:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) button{font-size:var(--text-base);font-weight:var(--font-weight-medium);line-height:1.5}:where(:not(:has([class*=" text-"]),:not(:has([class^=text-])))) input{font-size:var(--text-base);font-weight:var(--font-weight-normal);line-height:1.5}}@layer utilities{.transform{transform:var(--tw-rotate-x) var(--tw-rotate-y) var(--tw-rotate-z) var(--tw-skew-x) var(--tw-skew-y)}.filter{filter:var(--tw-blur, ) var(--tw-brightness, ) var(--tw-contrast, ) var(--tw-grayscale, ) var(--tw-hue-rotate, ) var(--tw-invert, ) var(--tw-saturate, ) var(--tw-sepia, ) var(--tw-drop-shadow, )}}.chat-container{background:linear-gradient(135deg,#f5f7fa,#e8f5e9);flex-direction:column;height:100vh;display:flex;position:relative}.analysis-toast{z-index:1000;animation:.3s ease-out fadeInScale;position:fixed;top:50%;left:50%;transform:translate(-50%,-50%)}.analysis-toast-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #2e7d32;border-radius:1.25rem;align-items:center;gap:.875rem;min-width:280px;padding:1.25rem 2rem;display:flex;box-shadow:0 8px 24px #2e7d3240,0 4px 12px #0000001a}.analysis-spinner{color:#2e7d32;flex-shrink:0;animation:1s linear infinite spin}.analysis-text{color:#1a1a1a;white-space:nowrap;font-size:1rem;animation:1.5s ease-in-out infinite pulse}.chat-header{color:#fff;z-index:10;background:linear-gradient(135deg,#2e7d32,#388e3c);padding:1.5rem;box-shadow:0 2px 8px #0000001a}.chat-header-content{align-items:center;gap:1rem;display:flex}.back-button{cursor:pointer;color:#fff;background:#fff3;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;transition:all .3s;display:flex}.chat-header-title{align-items:center;gap:.75rem;margin:0;font-size:1.5rem;display:flex}.chat-header-subtitle{opacity:.9;margin:.25rem 0 0;font-size:.875rem}.test-question-button{color:#fff;cursor:pointer;background:#fff3;border:1px solid #ffffff4d;border-radius:8px;padding:.625rem 1.25rem;font-size:.875rem;transition:all .3s}.view-report-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#8b4513,#654321);border:1px solid #ffffff4d;border-radius:8px;align-items:center;gap:.5rem;padding:.625rem 1.25rem;font-size:.875rem;transition:all .3s;display:flex;box-shadow:0 2px 8px #0003}.chat-messages{flex-direction:column;flex:1;gap:1rem;padding:1.5rem;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar-track{background:none}.message-wrapper{align-items:flex-start;gap:.75rem;animation:.3s ease-out fadeInUp;display:flex}.message-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex;box-shadow:0 2px 4px #0000001a}.message-avatar.ai{color:#fff;background:linear-gradient(135deg,#2e7d32,#388e3c)}.message-avatar.user{color:#fff;background:linear-gradient(135deg,#1976d2,#2196f3)}.message-content{flex-direction:column;gap:.25rem;max-width:70%;display:flex}.message-bubble{word-wrap:break-word;border-radius:1rem;padding:.875rem 1.125rem;line-height:1.5;box-shadow:0 2px 4px #00000014}.message-bubble.ai{color:#1a1a1a;background:#fff;border-bottom-left-radius:.25rem}.message-bubble.user{color:#fff;background:linear-gradient(135deg,#1976d2,#2196f3);border-bottom-right-radius:.25rem}.message-time{color:#666;padding:0 .5rem;font-size:.75rem}.message-image{object-fit:cover;cursor:pointer;border-radius:.75rem;max-width:100%;max-height:300px;transition:transform .2s}.streaming-cursor{vertical-align:text-bottom;background-color:#2e7d32;width:2px;height:1em;margin-left:2px;animation:1s infinite blink;display:inline-block}.question-panel,.camera-panel{z-index:100;background:#fff;border-top:1px solid #e0e0e0;animation:.3s ease-out slideUp;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -4px 12px #0000001a}.camera-panel-header{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;display:flex}.camera-panel-title{color:#1976d2;align-items:center;gap:.75rem;display:flex}.camera-panel-close{cursor:pointer;color:#666;background:#fffc;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.5rem;transition:all .3s;display:flex}.camera-panel-close:hover{color:#1976d2;background:#fff;transform:rotate(90deg)}.camera-panel-body{justify-content:center;align-items:center;min-height:300px;padding:1.5rem;display:flex}.camera-start-icon{color:#1976d2;opacity:.7;justify-content:center;align-items:center;margin-bottom:1.5rem;display:flex}.camera-start-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#1976d2,#1565c0);border:none;border-radius:2rem;align-items:center;gap:.75rem;padding:1rem 2rem;font-size:1.0625rem;transition:all .3s;display:inline-flex;box-shadow:0 4px 12px #1976d24d}.camera-start-btn:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 6px 16px #1976d266}.question-header{align-items:center;gap:.75rem;margin-bottom:1rem;display:flex}.question-icon{background:linear-gradient(135deg,#2e7d32,#388e3c);border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex;box-shadow:0 2px 6px #2e7d324d}.question-title{color:#1a1a1a;font-size:1.125rem}.question-text{color:#2d4a2b;background:linear-gradient(135deg,#e8f5e9,#f1f8f4);border-left:4px solid #2e7d32;border-radius:.75rem;margin-bottom:1.25rem;padding:1rem 1.25rem;line-height:1.6}.question-options{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1.25rem;display:grid}.question-option{cursor:pointer;text-align:left;background:#f5f7fa;border:2px solid #e0e0e0;border-radius:.875rem;align-items:center;gap:.75rem;padding:.875rem 1.125rem;transition:all .3s;display:flex}.option-checkbox{color:#666;flex-shrink:0;transition:color .3s}.option-text{color:#1a1a1a;flex:1;font-size:.9375rem}.question-actions{justify-content:center;gap:.875rem;display:flex}.question-action-btn{cursor:pointer;border:none;border-radius:1.25rem;align-items:center;gap:.5rem;padding:.875rem 2rem;font-size:1rem;transition:all .3s;display:flex}.question-action-btn.skip{color:#666;background:#f5f5f5;border:2px solid #e0e0e0}.question-action-btn.submit{color:#fff;background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 2px 6px #2e7d324d}.chat-input-container{background:#fff;border-top:1px solid #e0e0e0;padding:1.25rem;box-shadow:0 -2px 8px #00000014}.message-type-tabs{background:#f5f7fa;border-radius:1rem;gap:.75rem;max-width:1200px;margin:0 auto 1rem;padding:.5rem;display:flex}.message-type-tab{cursor:pointer;color:#666;background:none;border:none;border-radius:.75rem;flex:1;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.25rem;font-size:.95rem;transition:all .3s;display:flex}.message-type-tab:hover:not(:disabled):not(.active){color:#2e7d32;background:#2e7d3214}.message-type-tab.active{color:#fff;background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 2px 6px #2e7d324d}.chat-input-wrapper{gap:.75rem;max-width:1200px;margin:0 auto;display:flex}.chat-input{background:#fafafa;border:2px solid #e0e0e0;border-radius:1.5rem;outline:none;flex:1;padding:.875rem 1.125rem;font-size:1rem;transition:all .3s}.chat-input:focus{background:#fff;border-color:#2e7d32;box-shadow:0 0 0 3px #2e7d321a}.image-upload-area{flex-direction:column;gap:1rem;width:100%;display:flex}.image-upload-hint{background:linear-gradient(135deg,#fff9e6,#fff5cc);border-left:4px solid #ffd666;border-radius:.75rem;align-items:center;gap:.75rem;padding:.875rem 1.125rem;display:flex;box-shadow:0 2px 6px #ffc10726}.hint-icon{flex-shrink:0;font-size:1.25rem}.image-upload-button{cursor:pointer;color:#2e7d32;background:linear-gradient(135deg,#f5f7fa,#e8f5e9);border:2px dashed #2e7d32;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem;transition:all .3s;display:flex}.image-input-options{grid-template-columns:1fr 1fr;gap:1rem;display:grid}.image-option-btn{cursor:pointer;color:#1a1a1a;background:#fff;border:2px solid #e0e0e0;border-radius:1rem;flex-direction:column;justify-content:center;align-items:center;gap:.75rem;padding:2rem 1rem;transition:all .3s;display:flex}.image-option-btn.upload{color:#2e7d32;border-color:#2e7d32}.image-option-btn.camera{color:#1976d2;border-color:#1976d2}.camera-preview-wrapper{background:#000;border-radius:1rem;position:relative;overflow:hidden}.camera-video{object-fit:cover;width:100%;height:auto;max-height:300px;display:block}.camera-controls{background:linear-gradient(to top,#000c,#0000);flex-direction:column;justify-content:center;gap:1rem;padding:1rem;display:flex;position:absolute;bottom:0;left:0;right:0}.camera-control-btn{cursor:pointer;border:none;border-radius:2rem;justify-content:center;align-items:center;gap:.5rem;width:100%;padding:.875rem 1.5rem;font-size:1rem;transition:all .3s;display:flex}.camera-control-btn.capture{color:#fff;background:linear-gradient(135deg,#2e7d32,#388e3c);box-shadow:0 2px 8px #2e7d3266}.camera-control-btn.capture:hover{transform:translateY(-2px)scale(1.05);box-shadow:0 4px 12px #2e7d3299}.camera-control-btn.close{color:#fff;background:#fff3;border:2px solid #fff6}.image-preview-container{background:#f5f7fa;border:2px dashed #2e7d32;border-radius:1.5rem;flex:1;justify-content:center;align-items:center;min-height:80px;padding:1rem;display:flex}.image-preview-wrapper{width:fit-content;max-width:100%;position:relative}.image-preview{object-fit:cover;border-radius:.75rem;max-width:250px;max-height:180px;display:block;box-shadow:0 4px 12px #00000026}.image-preview-close{color:#fff;cursor:pointer;background:#ef5350;border:none;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;transition:all .2s;display:flex;position:absolute;top:-8px;right:-8px;box-shadow:0 2px 6px #ef535066}.chat-image-button{color:#2e7d32;cursor:pointer;background:#fff;border:2px solid #2e7d32;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;padding:.875rem;transition:all .3s;display:flex}.chat-send-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2e7d32,#388e3c);border:none;border-radius:1.5rem;align-items:center;gap:.5rem;padding:.875rem 1.25rem;font-size:1rem;transition:all .3s;display:flex;box-shadow:0 2px 6px #2e7d324d}.typing-indicator{gap:4px;padding:1rem;display:flex}.typing-dot{background:#2e7d32;border-radius:50%;width:8px;height:8px;animation:1.4s infinite typing}.message-bubble.report-message{background:linear-gradient(135deg,#fff9e6,#fff5cc);border:2px solid #ffd666;padding:0;transition:all .3s;overflow:hidden}.message-bubble.report-message:hover{border-color:#ffab00;transform:translateY(-4px);box-shadow:0 6px 20px #ffc1074d}.report-message-content{flex-direction:column;min-width:320px;display:flex}.report-message-header{align-items:center;gap:1rem;padding:1.25rem;display:flex}.report-message-icon{color:#fff;background:linear-gradient(135deg,#8b4513,#654321);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:56px;height:56px;display:flex;box-shadow:0 4px 12px #8b45134d}.report-message-title{color:#8b4513;margin:0 0 .375rem;font-size:1.125rem}.report-message-description{color:#666;margin:0;font-size:.875rem;line-height:1.5}.report-message-footer{background:linear-gradient(135deg,#fff5cc,#ffe7ba);border-top:1px solid #ffd591;justify-content:flex-end;align-items:center;gap:.5rem;padding:.875rem 1.25rem;display:flex}.report-message-hint{color:#8b4513;font-size:.875rem;font-weight:500}@keyframes typing{0%,60%,to{opacity:.7;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%)scale(.9)}to{opacity:1;transform:translate(-50%,-50%)scale(1)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{50%{opacity:.5}}@media(width<=768px){.chat-header,.chat-messages{padding:1rem}.message-content{max-width:85%}.chat-input-container{padding:1rem}.message-type-tabs{margin-bottom:.75rem}.message-type-tab{padding:.625rem 1rem;font-size:.875rem}.message-type-tab span{display:none}.chat-send-button{padding:.875rem 1.25rem}.image-upload-button{padding:1.5rem}.image-preview{max-width:150px;max-height:120px}.image-upload-hint{padding:.625rem .875rem}.hint-icon{font-size:1.125rem}.hint-text{font-size:.8125rem}.question-content{padding:1rem}.question-options{grid-template-columns:1fr}.question-actions{flex-direction:column}.question-action-btn{justify-content:center;width:100%}.image-input-options{grid-template-columns:1fr}.image-option-btn{padding:1.5rem 1rem}.camera-video{max-height:300px}.camera-controls{flex-direction:column;padding:1rem}.camera-control-btn{justify-content:center;width:100%}}.loading-screen{background:linear-gradient(135deg,#667eea,#764ba2);justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.loading-logo{justify-content:center;align-items:center;margin-bottom:24px;display:flex}.loading-sparkles{color:gold;filter:drop-shadow(0 0 20px #ffd70080);animation:2s ease-in-out infinite pulse}.loading-title{opacity:.95;margin:0 0 40px}.loading-spinner-container{flex-direction:column;align-items:center;gap:16px;display:flex}.loading-spinner{animation:1s linear infinite spin}.loading-text{opacity:.9;margin:0}.report-container{background:linear-gradient(135deg,#f5f7fa,#e8eff5);flex-direction:column;height:100vh;display:flex;overflow:hidden}.report-header{color:#fff;z-index:10;background:linear-gradient(135deg,#8b4513,#654321);position:relative;box-shadow:0 4px 12px #00000026}.report-header-content{align-items:center;gap:1.5rem;max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex}.report-header .back-button{cursor:pointer;color:#fff;background:#fff3;border:none;border-radius:50%;justify-content:center;align-items:center;padding:.75rem;transition:all .3s;display:flex}.report-header-title{align-items:center;gap:.75rem;margin:0 0 .25rem;display:flex}.report-header-subtitle{opacity:.9;letter-spacing:.5px;margin:0;font-size:.875rem}.report-content{flex:1;width:100%;max-width:1200px;margin:0 auto;padding:2rem;overflow-y:auto}.report-card{background:#fff;border-radius:16px;margin-bottom:1.5rem;padding:2rem;transition:all .3s;box-shadow:0 4px 12px #00000014}.report-card:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0000001f}.card-header{color:#8b4513;border-bottom:2px solid #f0f0f0;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;display:flex}.patient-info-grid{grid-template-columns:repeat(3,1fr);gap:1.5rem;display:grid}.info-item{flex-direction:column;gap:.5rem;display:flex}.info-label{color:#8c6d1f;align-items:center;gap:.5rem;font-size:.875rem;display:flex}.info-value{color:#3d2b00;font-size:1.125rem}.diagnosis-content{grid-template-columns:280px 1fr;gap:2rem;display:grid}.diagnosis-image-section{flex-direction:column;gap:.75rem;display:flex}.diagnosis-image{aspect-ratio:1;object-fit:cover;border:3px solid #f0f0f0;border-radius:12px;width:100%;box-shadow:0 4px 12px #0000001a}.image-label{text-align:center;color:#666;font-size:.875rem;font-weight:500}.diagnosis-details{flex-direction:column;gap:1.25rem;display:flex}.detail-item{background:#fafafa;border-radius:8px;grid-template-columns:100px 1fr;gap:1rem;padding:1rem;transition:all .3s;display:grid}.detail-label{color:#8b4513;font-size:.9375rem;font-weight:600}.symptoms-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem;display:grid}.symptom-tag{color:#096dd9;background:linear-gradient(135deg,#e6f7ff,#bae7ff);border:1px solid #91d5ff;border-radius:12px;align-items:center;gap:.75rem;padding:1rem 1.25rem;font-weight:500;transition:all .3s;display:flex}.symptom-tag:hover{background:linear-gradient(135deg,#bae7ff,#91d5ff);transform:translateY(-2px);box-shadow:0 4px 12px #1890ff33}.symptom-dot{background:#1890ff;border-radius:50%;flex-shrink:0;width:8px;height:8px}.result-card{background:linear-gradient(#fff,#fff1f0);border:2px solid #ff7875}.result-content{flex-direction:column;gap:2rem;display:flex}.syndrome-section{background:linear-gradient(135deg,#fff2e8,#ffd8bf);border:2px solid #ffbb96;border-radius:12px;padding:2rem}.syndrome-badge{color:#fff;background:linear-gradient(135deg,#ff7a45,#fa541c);border-radius:20px;margin-bottom:1rem;padding:.5rem 1.25rem;font-size:.875rem;font-weight:600;display:inline-block;box-shadow:0 4px 12px #fa541c4d}.syndrome-name{color:#d4380d;margin:.75rem 0 1rem;font-size:1.75rem}.syndrome-description{color:#5c3317;margin:0;font-size:1.0625rem;line-height:1.8}.recommendations-section{flex-direction:column;gap:1.5rem;display:flex}.section-title{color:#8b4513;border-bottom:2px solid #f0f0f0;margin:0;padding-bottom:.75rem;font-size:1.25rem}.recommendation-group{background:#fafafa;border-left:4px solid #8b4513;border-radius:12px;padding:1.5rem}.recommendation-category{color:#8b4513;align-items:center;gap:.5rem;margin:0 0 1rem;font-size:1.0625rem;display:flex}.recommendation-list{flex-direction:column;gap:.75rem;margin:0;padding-left:1.5rem;display:flex}.recommendation-list li{color:#333;padding-left:.5rem;line-height:1.8}.precautions-section{background:linear-gradient(135deg,#fff7e6,#ffe7ba);border:2px solid #ffd591;border-radius:12px;padding:1.5rem}.precautions-header{color:#d46b08;align-items:center;gap:.5rem;margin-bottom:.75rem;font-size:1.0625rem;font-weight:600;display:flex}.precautions-text{color:#5c3317;margin:0;line-height:1.8}.report-footer{background:#fff;border-top:1px solid #e0e0e0;justify-content:flex-end;gap:1rem;padding:1.5rem 2rem;display:flex;box-shadow:0 -4px 12px #0000000d}.report-action-btn{cursor:pointer;font-size:1 rem;border:none;border-radius:8px;align-items:center;gap:.5rem;padding:.875rem 2rem;font-weight:500;transition:all .3s;display:flex}.report-action-btn.secondary{color:#333;background:#f0f0f0}.report-action-btn.primary{color:#fff;background:linear-gradient(135deg,#8b4513,#654321);box-shadow:0 4px 12px #8b45134d}@media(width<=1024px){.report-content{padding:1.5rem}.diagnosis-content{grid-template-columns:1fr}.diagnosis-image-section{max-width:300px;margin:0 auto}.patient-info-grid{grid-template-columns:repeat(2,1fr)}}@media(width<=768px){.report-header-content{padding:1rem 1.5rem}.report-content{padding:1rem}.report-card{padding:1.5rem}.patient-info-grid,.symptoms-grid,.detail-item{grid-template-columns:1fr}.syndrome-name{font-size:1.375rem}.report-footer{flex-direction:column}.report-action-btn{justify-content:center;width:100%}}.report-loading{background:linear-gradient(135deg,#f5f7fa,#e8eff5);flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.loading-content{text-align:center;background:#fff;border-radius:20px;width:100%;max-width:500px;padding:3rem;box-shadow:0 8px 32px #0000001a}.loading-icon{justify-content:center;margin-bottom:2rem;display:flex}.spinner{color:#8b4513;animation:1s linear infinite spin}.mini-spinner{animation:1s linear infinite spin}.loading-title{color:#8b4513;margin:0 0 .75rem;font-size:1.75rem;font-weight:600}.loading-subtitle{color:#666;margin:0 0 2.5rem;font-size:1rem;line-height:1.6}.loading-steps{text-align:left;flex-direction:column;align-items:flex-start;gap:1rem;display:flex}.loading-step{opacity:.5;background:#f5f5f5;border-radius:12px;align-items:center;gap:1rem;width:100%;padding:1rem 1.5rem;transition:all .3s;display:flex}.step-icon{color:#fff;background:linear-gradient(135deg,#8b4513,#654321);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1.125rem;font-weight:600;display:flex}.loading-step span{color:#333;font-size:1rem;font-weight:500}@media(width<=768px){.loading-content{padding:2rem 1.5rem}.loading-title{font-size:1.5rem}.loading-subtitle{font-size:.9375rem}.loading-steps{gap:.75rem}.loading-step{padding:.875rem 1rem}.step-icon{width:28px;height:28px}}.single-model-selector{flex-direction:column;gap:.75rem;display:flex}.single-model-label{color:#1a1a1a;font-size:1rem;display:block}.single-model-select{cursor:pointer;background:#fff;border:2px solid #e0e0e0;border-radius:1rem;outline:none;padding:.875rem 1.125rem;font-size:1rem;transition:all .3s}.start-container{background:linear-gradient(135deg,#f5f7fa,#e8f5e9);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.start-content{flex-direction:column;gap:2.5rem;width:100%;max-width:800px;animation:.6s ease-out fadeIn;display:flex}.start-header{text-align:center;flex-direction:column;align-items:center;gap:1rem;display:flex}.start-logo{color:#fff;background:linear-gradient(135deg,#2e7d32,#388e3c);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;animation:3s ease-in-out infinite float;display:flex;box-shadow:0 8px 24px #2e7d324d}.start-title{background:linear-gradient(135deg,#2e7d32,#388e3c);-webkit-text-fill-color:transparent;background-clip:text;margin:0;font-size:2.5rem}.start-subtitle{color:#666;margin:0;font-size:1.125rem}.start-features{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.feature-card{text-align:center;background:#fff;border-radius:1.5rem;flex-direction:column;align-items:center;gap:.75rem;padding:2rem;transition:all .3s;display:flex;box-shadow:0 4px 12px #00000014}.feature-card h3{color:#1a1a1a;margin:0;font-size:1.25rem}.feature-card p{color:#666;margin:0;font-size:.95rem}.start-model-section{background:#fff;border-radius:1.5rem;padding:2rem;box-shadow:0 4px 12px #00000014}.section-title{color:#1a1a1a;text-align:center;margin:0 0 1.5rem;font-size:1.5rem}.model-selectors{grid-template-columns:repeat(2,1fr);gap:1.5rem;display:grid}.start-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#2e7d32,#388e3c);border:none;border-radius:2rem;justify-content:center;align-self:center;align-items:center;gap:.75rem;min-width:200px;padding:1.25rem 2.5rem;font-size:1.125rem;transition:all .3s;display:flex;box-shadow:0 4px 16px #2e7d324d}.start-disclaimer{text-align:center;background:#fff3cd;border:2px solid #ffc107;border-radius:1rem;padding:1.25rem}.start-disclaimer p{color:#856404;margin:0;font-size:.95rem;line-height:1.6}@media(width<=768px){.start-container{padding:1.5rem}.start-content{gap:2rem}.start-title{font-size:2rem}.start-subtitle{font-size:1rem}.start-logo{width:80px;height:80px}.start-logo svg{width:36px;height:36px}.start-features{grid-template-columns:1fr;gap:1rem}.feature-card,.start-model-section{padding:1.5rem}.model-selectors{grid-template-columns:1fr;gap:1rem}.start-button{width:100%;padding:1rem 2rem;font-size:1rem}.start-disclaimer{padding:1rem}.start-disclaimer p{font-size:.875rem}}:root{--font-size: 16px;--background: #fff;--foreground: oklch(.145 0 0);--card: #fff;--card-foreground: oklch(.145 0 0);--popover: oklch(1 0 0);--popover-foreground: oklch(.145 0 0);--primary: #030213;--primary-foreground: oklch(1 0 0);--secondary: oklch(.95 .0058 264.53);--secondary-foreground: #030213;--muted: #ececf0;--muted-foreground: #717182;--accent: #e9ebef;--accent-foreground: #030213;--destructive: #d4183d;--destructive-foreground: #fff;--border: #0000001a;--input: transparent;--input-background: #f3f3f5;--switch-background: #cbced4;--font-weight-medium: 500;--font-weight-normal: 400;--ring: oklch(.708 0 0);--chart-1: oklch(.646 .222 41.116);--chart-2: oklch(.6 .118 184.704);--chart-3: oklch(.398 .07 227.392);--chart-4: oklch(.828 .189 84.429);--chart-5: oklch(.769 .188 70.08);--radius: .625rem;--sidebar: oklch(.985 0 0);--sidebar-foreground: oklch(.145 0 0);--sidebar-primary: #030213;--sidebar-primary-foreground: oklch(.985 0 0);--sidebar-accent: oklch(.97 0 0);--sidebar-accent-foreground: oklch(.205 0 0);--sidebar-border: oklch(.922 0 0);--sidebar-ring: oklch(.708 0 0)}.dark{--background: oklch(.145 0 0);--foreground: oklch(.985 0 0);--card: oklch(.145 0 0);--card-foreground: oklch(.985 0 0);--popover: oklch(.145 0 0);--popover-foreground: oklch(.985 0 0);--primary: oklch(.985 0 0);--primary-foreground: oklch(.205 0 0);--secondary: oklch(.269 0 0);--secondary-foreground: oklch(.985 0 0);--muted: oklch(.269 0 0);--muted-foreground: oklch(.708 0 0);--accent: oklch(.269 0 0);--accent-foreground: oklch(.985 0 0);--destructive: oklch(.396 .141 25.723);--destructive-foreground: oklch(.637 .237 25.331);--border: oklch(.269 0 0);--input: oklch(.269 0 0);--ring: oklch(.439 0 0);--font-weight-medium: 500;--font-weight-normal: 400;--chart-1: oklch(.488 .243 264.376);--chart-2: oklch(.696 .17 162.48);--chart-3: oklch(.769 .188 70.08);--chart-4: oklch(.627 .265 303.9);--chart-5: oklch(.645 .246 16.439);--sidebar: oklch(.205 0 0);--sidebar-foreground: oklch(.985 0 0);--sidebar-primary: oklch(.488 .243 264.376);--sidebar-primary-foreground: oklch(.985 0 0);--sidebar-accent: oklch(.269 0 0);--sidebar-accent-foreground: oklch(.985 0 0);--sidebar-border: oklch(.269 0 0);--sidebar-ring: oklch(.439 0 0)}html{font-size:var(--font-size)}@property --tw-rotate-x{syntax: "*"; inherits: false; initial-value: rotateX(0);}@property --tw-rotate-y{syntax: "*"; inherits: false; initial-value: rotateY(0);}@property --tw-rotate-z{syntax: "*"; inherits: false; initial-value: rotateZ(0);}@property --tw-skew-x{syntax: "*"; inherits: false; initial-value: skewX(0);}@property --tw-skew-y{syntax: "*"; inherits: false; initial-value: skewY(0);}@property --tw-blur{syntax: "*"; inherits: false}@property --tw-brightness{syntax: "*"; inherits: false}@property --tw-contrast{syntax: "*"; inherits: false}@property --tw-grayscale{syntax: "*"; inherits: false}@property --tw-hue-rotate{syntax: "*"; inherits: false}@property --tw-invert{syntax: "*"; inherits: false}@property --tw-opacity{syntax: "*"; inherits: false}@property --tw-saturate{syntax: "*"; inherits: false}@property --tw-sepia{syntax: "*"; inherits: false}@property --tw-drop-shadow{syntax: "*"; inherits: false}@property --tw-drop-shadow-color{syntax: "*"; inherits: false}@property --tw-drop-shadow-alpha{syntax: "<percentage>"; inherits: false; initial-value: 100%;}@property --tw-drop-shadow-size{syntax: "*"; inherits: false}.chat-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8f5e9);position:relative}.analysis-toast{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1000;animation:fadeInScale .3s ease-out}.analysis-toast-content{display:flex;align-items:center;gap:.875rem;padding:1.25rem 2rem;background:linear-gradient(135deg,#fff,#f8f9fa);border:2px solid #2e7d32;border-radius:1.25rem;box-shadow:0 8px 24px #2e7d3240,0 4px 12px #0000001a;backdrop-filter:blur(10px);min-width:280px}.analysis-spinner{color:#2e7d32;animation:spin 1s linear infinite;flex-shrink:0}.analysis-text{font-size:1rem;color:#1a1a1a;white-space:nowrap;animation:pulse 1.5s ease-in-out infinite}.chat-header{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;padding:1.5rem;box-shadow:0 2px 8px #0000001a;z-index:10}.chat-header-content{display:flex;align-items:center;gap:1rem}.back-button{background:#fff3;border:none;border-radius:50%;width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff;transition:all .3s ease;flex-shrink:0}.back-button:hover{background:#ffffff4d;transform:scale(1.05)}.back-button:active{transform:scale(.95)}.chat-header-text{flex:1}.chat-header-title{margin:0;font-size:1.5rem;display:flex;align-items:center;gap:.75rem}.chat-header-subtitle{margin:.25rem 0 0;opacity:.9;font-size:.875rem}.test-question-button{padding:.625rem 1.25rem;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;transition:all .3s ease}.test-question-button:hover{background:#ffffff4d;transform:translateY(-2px)}.view-report-button{display:flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;background:linear-gradient(135deg,#8b4513,#654321);border:1px solid rgba(255,255,255,.3);border-radius:8px;color:#fff;cursor:pointer;font-size:.875rem;transition:all .3s ease;box-shadow:0 2px 8px #0003}.view-report-button:hover{background:linear-gradient(135deg,sienna,#8b4513);transform:translateY(-2px);box-shadow:0 4px 12px #0000004d}.chat-messages{flex:1;overflow-y:auto;padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#0003;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#0000004d}.message-wrapper{display:flex;align-items:flex-start;gap:.75rem;animation:fadeInUp .3s ease-out}.message-wrapper.user{flex-direction:row-reverse}.message-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:1.25rem;box-shadow:0 2px 4px #0000001a}.message-avatar.ai{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff}.message-avatar.user{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff}.message-content{max-width:70%;display:flex;flex-direction:column;gap:.25rem}.message-bubble{padding:.875rem 1.125rem;border-radius:1rem;box-shadow:0 2px 4px #00000014;line-height:1.5;word-wrap:break-word}.message-bubble.ai{background:#fff;color:#1a1a1a;border-bottom-left-radius:.25rem}.message-bubble.user{background:linear-gradient(135deg,#1976d2,#2196f3);color:#fff;border-bottom-right-radius:.25rem}.message-time{font-size:.75rem;color:#666;padding:0 .5rem}.message-wrapper.user .message-time{text-align:right}.message-image-container{margin-bottom:.5rem}.message-image{max-width:100%;max-height:300px;border-radius:.75rem;object-fit:cover;cursor:pointer;transition:transform .2s ease}.message-image:hover{transform:scale(1.02)}.streaming-cursor{display:inline-block;width:2px;height:1em;background-color:#2e7d32;margin-left:2px;animation:blink 1s infinite;vertical-align:text-bottom}.question-panel,.camera-panel{position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid #e0e0e0;box-shadow:0 -4px 12px #0000001a;z-index:100;animation:slideUp .3s ease-out}.camera-panel-content{max-width:900px;margin:0 auto;padding:0}.camera-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #e0e0e0;background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.camera-panel-title{display:flex;align-items:center;gap:.75rem;color:#1976d2}.camera-panel-title span{font-size:1.125rem}.camera-panel-close{padding:.5rem;background:#fffc;border:none;border-radius:50%;cursor:pointer;color:#666;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.camera-panel-close:hover{background:#fff;color:#1976d2;transform:rotate(90deg)}.camera-panel-body{padding:1.5rem;min-height:300px;display:flex;align-items:center;justify-content:center}.camera-start-container{text-align:center;padding:2rem}.camera-start-icon{color:#1976d2;margin-bottom:1.5rem;display:flex;align-items:center;justify-content:center;opacity:.7}.camera-start-text{color:#666;margin-bottom:2rem;font-size:1rem}.camera-start-btn{display:inline-flex;align-items:center;gap:.75rem;padding:1rem 2rem;background:linear-gradient(135deg,#1976d2,#1565c0);color:#fff;border:none;border-radius:2rem;cursor:pointer;font-size:1.0625rem;transition:all .3s ease;box-shadow:0 4px 12px #1976d24d}.camera-start-btn:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 6px 16px #1976d266}.camera-start-btn:active{transform:translateY(0)}.question-content{max-width:1200px;margin:0 auto;padding:1.5rem}.question-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.question-icon{width:40px;height:40px;background:linear-gradient(135deg,#2e7d32,#388e3c);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:1.25rem;box-shadow:0 2px 6px #2e7d324d}.question-title{font-size:1.125rem;color:#1a1a1a}.question-text{background:linear-gradient(135deg,#e8f5e9,#f1f8f4);border-left:4px solid #2e7d32;padding:1rem 1.25rem;border-radius:.75rem;margin-bottom:1.25rem;color:#2d4a2b;line-height:1.6}.question-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem;margin-bottom:1.25rem}.question-option{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;background:#f5f7fa;border:2px solid #e0e0e0;border-radius:.875rem;cursor:pointer;transition:all .3s ease;text-align:left}.question-option:hover{background:#e8f5e9;border-color:#2e7d32;transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3226}.question-option.selected{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#2e7d32;box-shadow:0 2px 8px #2e7d3233}.option-checkbox{color:#666;flex-shrink:0;transition:color .3s ease}.question-option.selected .option-checkbox{color:#2e7d32}.option-text{flex:1;font-size:.9375rem;color:#1a1a1a}.question-actions{display:flex;gap:.875rem;justify-content:center}.question-action-btn{padding:.875rem 2rem;border:none;border-radius:1.25rem;cursor:pointer;font-size:1rem;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.question-action-btn.skip{background:#f5f5f5;color:#666;border:2px solid #e0e0e0}.question-action-btn.skip:hover{background:#eee;border-color:#bdbdbd;transform:translateY(-2px)}.question-action-btn.submit{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;box-shadow:0 2px 6px #2e7d324d}.question-action-btn.submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3266}.question-action-btn.submit:disabled{opacity:.5;cursor:not-allowed}.chat-input-container{background:#fff;padding:1.25rem;box-shadow:0 -2px 8px #00000014;border-top:1px solid #e0e0e0}.message-type-tabs{display:flex;gap:.75rem;max-width:1200px;margin:0 auto 1rem;background:#f5f7fa;padding:.5rem;border-radius:1rem}.message-type-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.25rem;background:transparent;border:none;border-radius:.75rem;cursor:pointer;transition:all .3s ease;color:#666;font-size:.95rem}.message-type-tab:hover:not(:disabled):not(.active){background:#2e7d3214;color:#2e7d32}.message-type-tab.active{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;box-shadow:0 2px 6px #2e7d324d}.message-type-tab:disabled{opacity:.5;cursor:not-allowed}.chat-input-wrapper{display:flex;gap:.75rem;max-width:1200px;margin:0 auto}.chat-input{flex:1;padding:.875rem 1.125rem;border:2px solid #e0e0e0;border-radius:1.5rem;font-size:1rem;outline:none;transition:all .3s ease;background:#fafafa}.chat-input:focus{border-color:#2e7d32;background:#fff;box-shadow:0 0 0 3px #2e7d321a}.chat-input::placeholder{color:#999}.image-upload-area{width:100%;display:flex;flex-direction:column;gap:1rem}.image-upload-hint{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.125rem;background:linear-gradient(135deg,#fff9e6,#fff5cc);border-left:4px solid #ffd666;border-radius:.75rem;box-shadow:0 2px 6px #ffc10726}.hint-icon{font-size:1.25rem;flex-shrink:0}.hint-text{color:#5c3317;font-size:.9375rem;line-height:1.5}.image-upload-button{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e8f5e9);border:2px dashed #2e7d32;border-radius:1rem;cursor:pointer;transition:all .3s ease;color:#2e7d32}.image-upload-button:hover:not(:disabled){background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#1b5e20;transform:translateY(-2px)}.image-upload-button:disabled{opacity:.5;cursor:not-allowed}.image-input-options{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.image-option-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:2rem 1rem;background:#fff;border:2px solid #e0e0e0;border-radius:1rem;cursor:pointer;transition:all .3s ease;color:#1a1a1a}.image-option-btn.upload{border-color:#2e7d32;color:#2e7d32}.image-option-btn.upload:hover:not(:disabled){background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-color:#1b5e20;transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3233}.image-option-btn.camera{border-color:#1976d2;color:#1976d2}.image-option-btn.camera:hover:not(:disabled){background:linear-gradient(135deg,#e3f2fd,#bbdefb);border-color:#0d47a1;transform:translateY(-2px);box-shadow:0 4px 12px #1976d233}.image-option-btn:disabled{opacity:.5;cursor:not-allowed}.image-option-btn span{font-size:1rem}.camera-preview-container{width:100%}.camera-preview-wrapper{position:relative;background:#000;border-radius:1rem;overflow:hidden}.camera-video{width:100%;height:auto;max-height:300px;object-fit:cover;display:block}.camera-controls{position:absolute;bottom:0;left:0;right:0;padding:1rem;flex-direction:column;background:linear-gradient(to top,rgba(0,0,0,.8),transparent);display:flex;gap:1rem;justify-content:center}.camera-control-btn{width:100%;justify-content:center;display:flex;align-items:center;gap:.5rem;padding:.875rem 1.5rem;border:none;border-radius:2rem;cursor:pointer;font-size:1rem;transition:all .3s ease}.camera-control-btn.capture{background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;box-shadow:0 2px 8px #2e7d3266}.camera-control-btn.capture:hover{transform:translateY(-2px) scale(1.05);box-shadow:0 4px 12px #2e7d3299}.camera-control-btn.close{background:#fff3;color:#fff;border:2px solid rgba(255,255,255,.4)}.camera-control-btn.close:hover{background:#ffffff4d;transform:translateY(-2px)}.image-preview-container{flex:1;display:flex;align-items:center;justify-content:center;background:#f5f7fa;border:2px dashed #2e7d32;border-radius:1.5rem;padding:1rem;min-height:80px}.image-preview-wrapper{position:relative;width:fit-content;max-width:100%}.image-preview{max-width:250px;max-height:180px;border-radius:.75rem;object-fit:cover;box-shadow:0 4px 12px #00000026;display:block}.image-preview-close{position:absolute;top:-8px;right:-8px;background:#ef5350;color:#fff;border:none;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 2px 6px #ef535066;transition:all .2s ease}.image-preview-close:hover{background:#e53935;transform:scale(1.1)}.chat-image-button{padding:.875rem;background:#fff;color:#2e7d32;border:2px solid #2e7d32;border-radius:50%;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:48px;height:48px}.chat-image-button:hover:not(:disabled){background:#e8f5e9;transform:scale(1.05)}.chat-image-button:disabled{opacity:.5;cursor:not-allowed}.chat-send-button{padding:.875rem 1.25rem;background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;border:none;border-radius:1.5rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:.5rem;font-size:1rem;box-shadow:0 2px 6px #2e7d324d}.chat-send-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #2e7d3266}.chat-send-button:active:not(:disabled){transform:translateY(0)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}.typing-indicator{display:flex;gap:4px;padding:1rem}.typing-dot{width:8px;height:8px;border-radius:50%;background:#2e7d32;animation:typing 1.4s infinite}.typing-dot:nth-child(2){animation-delay:.2s}.typing-dot:nth-child(3){animation-delay:.4s}.message-bubble.report-message{padding:0;background:linear-gradient(135deg,#fff9e6,#fff5cc);border:2px solid #ffd666;transition:all .3s ease;overflow:hidden}.message-bubble.report-message:hover{transform:translateY(-4px);box-shadow:0 6px 20px #ffc1074d;border-color:#ffab00}.report-message-content{display:flex;flex-direction:column;min-width:320px}.report-message-header{display:flex;align-items:center;gap:1rem;padding:1.25rem}.report-message-icon{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,#8b4513,#654321);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 4px 12px #8b45134d}.report-message-info{flex:1;min-width:0}.report-message-title{margin:0 0 .375rem;font-size:1.125rem;color:#8b4513}.report-message-description{margin:0;font-size:.875rem;color:#666;line-height:1.5}.report-message-footer{display:flex;align-items:center;justify-content:flex-end;gap:.5rem;padding:.875rem 1.25rem;background:linear-gradient(135deg,#fff5cc,#ffe7ba);border-top:1px solid #ffd591}.report-message-hint{font-size:.875rem;color:#8b4513;font-weight:500}.report-message-footer svg{color:#8b4513;flex-shrink:0}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.7}30%{transform:translateY(-10px);opacity:1}}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}@keyframes fadeInScale{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.05)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@media(max-width:768px){.chat-header,.chat-messages{padding:1rem}.message-content{max-width:85%}.chat-input-container{padding:1rem}.message-type-tabs{margin-bottom:.75rem}.message-type-tab{padding:.625rem 1rem;font-size:.875rem}.message-type-tab span{display:none}.chat-send-button{padding:.875rem 1.25rem}.image-upload-button{padding:1.5rem}.image-preview{max-width:150px;max-height:120px}.image-upload-hint{padding:.625rem .875rem}.hint-icon{font-size:1.125rem}.hint-text{font-size:.8125rem}.question-content{padding:1rem}.question-options{grid-template-columns:1fr}.question-actions{flex-direction:column}.question-action-btn{width:100%;justify-content:center}.image-input-options{grid-template-columns:1fr}.image-option-btn{padding:1.5rem 1rem}.camera-video{max-height:300px}.camera-controls{padding:1rem;flex-direction:column}.camera-control-btn{width:100%;justify-content:center}}.report-container{display:flex;flex-direction:column;height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8eff5);overflow:hidden}.report-header{background:linear-gradient(135deg,#8b4513,#654321);color:#fff;box-shadow:0 4px 12px #00000026;position:relative;z-index:10}.report-header-content{max-width:1200px;margin:0 auto;padding:1.5rem 2rem;display:flex;align-items:center;gap:1.5rem}.report-header .back-button{padding:.75rem;background:#fff3;border:none;border-radius:50%;cursor:pointer;color:#fff;transition:all .3s ease;display:flex;align-items:center;justify-content:center}.report-header .back-button:hover{background:#ffffff4d;transform:translate(-4px)}.report-header-text{flex:1}.report-header-title{display:flex;align-items:center;gap:.75rem;margin:0;margin-bottom:.25rem}.report-header-subtitle{margin:0;opacity:.9;font-size:.875rem;letter-spacing:.5px}.report-content{flex:1;overflow-y:auto;padding:2rem;max-width:1200px;width:100%;margin:0 auto}.report-card{background:#fff;border-radius:16px;padding:2rem;margin-bottom:1.5rem;box-shadow:0 4px 12px #00000014;transition:all .3s ease}.report-card:hover{box-shadow:0 8px 20px #0000001f;transform:translateY(-2px)}.card-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:2px solid #f0f0f0;color:#8b4513}.card-header.primary{color:#d4380d;border-bottom-color:#ffd8bf}.card-header h2{margin:0;font-size:1.375rem}.patient-info-card{background:linear-gradient(135deg,#fff9e6,#fff5cc);border:2px solid #ffd666}.patient-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item.full-width{grid-column:1 / -1}.info-label{font-size:.875rem;color:#8c6d1f;display:flex;align-items:center;gap:.5rem}.info-value{font-size:1.125rem;color:#3d2b00}.diagnosis-card{border-left:4px solid #8b4513}.diagnosis-content{display:grid;grid-template-columns:280px 1fr;gap:2rem}.diagnosis-image-section{display:flex;flex-direction:column;gap:.75rem}.diagnosis-image{width:100%;aspect-ratio:1;border-radius:12px;object-fit:cover;border:3px solid #f0f0f0;box-shadow:0 4px 12px #0000001a}.image-label{text-align:center;font-size:.875rem;color:#666;font-weight:500}.diagnosis-details{display:flex;flex-direction:column;gap:1.25rem}.detail-item{display:grid;grid-template-columns:100px 1fr;gap:1rem;padding:1rem;background:#fafafa;border-radius:8px;transition:all .3s ease}.detail-item:hover{background:#f5f5f5}.detail-item.overall{background:linear-gradient(135deg,#fff7e6,#ffe7ba);border:1px solid #ffd591}.detail-item.overall:hover{background:linear-gradient(135deg,#ffe7ba,#ffd591)}.detail-label{font-weight:600;color:#8b4513;font-size:.9375rem}.detail-text{color:#333;line-height:1.6}.symptoms-card{border-left:4px solid #1890ff}.symptoms-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.symptom-tag{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:linear-gradient(135deg,#e6f7ff,#bae7ff);border-radius:12px;border:1px solid #91d5ff;color:#096dd9;font-weight:500;transition:all .3s ease}.symptom-tag:hover{transform:translateY(-2px);box-shadow:0 4px 12px #1890ff33;background:linear-gradient(135deg,#bae7ff,#91d5ff)}.symptom-dot{width:8px;height:8px;background:#1890ff;border-radius:50%;flex-shrink:0}.result-card{border:2px solid #ff7875;background:linear-gradient(to bottom,#fff,#fff1f0)}.result-content{display:flex;flex-direction:column;gap:2rem}.syndrome-section{padding:2rem;background:linear-gradient(135deg,#fff2e8,#ffd8bf);border-radius:12px;border:2px solid #ffbb96}.syndrome-badge{display:inline-block;padding:.5rem 1.25rem;background:linear-gradient(135deg,#ff7a45,#fa541c);color:#fff;border-radius:20px;font-size:.875rem;font-weight:600;margin-bottom:1rem;box-shadow:0 4px 12px #fa541c4d}.syndrome-name{font-size:1.75rem;color:#d4380d;margin:.75rem 0 1rem}.syndrome-description{color:#5c3317;line-height:1.8;font-size:1.0625rem;margin:0}.recommendations-section{display:flex;flex-direction:column;gap:1.5rem}.section-title{font-size:1.25rem;color:#8b4513;margin:0;padding-bottom:.75rem;border-bottom:2px solid #f0f0f0}.recommendation-group{padding:1.5rem;background:#fafafa;border-radius:12px;border-left:4px solid #8b4513}.recommendation-category{font-size:1.0625rem;color:#8b4513;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.recommendation-category:before{content:"▸";color:#d4380d;font-size:1.25rem}.recommendation-list{margin:0;padding-left:1.5rem;display:flex;flex-direction:column;gap:.75rem}.recommendation-list li{color:#333;line-height:1.8;padding-left:.5rem}.recommendation-list li::marker{color:#8b4513}.precautions-section{padding:1.5rem;background:linear-gradient(135deg,#fff7e6,#ffe7ba);border-radius:12px;border:2px solid #ffd591}.precautions-header{display:flex;align-items:center;gap:.5rem;color:#d46b08;font-weight:600;margin-bottom:.75rem;font-size:1.0625rem}.precautions-text{color:#5c3317;line-height:1.8;margin:0}.report-footer{padding:1.5rem 2rem;background:#fff;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:1rem;box-shadow:0 -4px 12px #0000000d}.report-action-btn{padding:.875rem 2rem;border:none;border-radius:8px;cursor:pointer;font-size:1rem;font-weight:500;transition:all .3s ease;display:flex;align-items:center;gap:.5rem}.report-action-btn.secondary{background:#f0f0f0;color:#333}.report-action-btn.secondary:hover{background:#e0e0e0;transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.report-action-btn.primary{background:linear-gradient(135deg,#8b4513,#654321);color:#fff;box-shadow:0 4px 12px #8b45134d}.report-action-btn.primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px #8b451366}@media(max-width:1024px){.report-content{padding:1.5rem}.diagnosis-content{grid-template-columns:1fr}.diagnosis-image-section{max-width:300px;margin:0 auto}.patient-info-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.report-header-content{padding:1rem 1.5rem}.report-content{padding:1rem}.report-card{padding:1.5rem}.patient-info-grid,.symptoms-grid,.detail-item{grid-template-columns:1fr}.syndrome-name{font-size:1.375rem}.report-footer{flex-direction:column}.report-action-btn{width:100%;justify-content:center}}.report-loading{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem;background:linear-gradient(135deg,#f5f7fa,#e8eff5)}.loading-content{text-align:center;max-width:500px;width:100%;padding:3rem;background:#fff;border-radius:20px;box-shadow:0 8px 32px #0000001a}.loading-icon{display:flex;justify-content:center;margin-bottom:2rem}.spinner{color:#8b4513;animation:spin 1s linear infinite}.mini-spinner{animation:spin 1s linear infinite}.loading-title{font-size:1.75rem;color:#8b4513;margin:0 0 .75rem;font-weight:600}.loading-subtitle{color:#666;line-height:1.6;margin:0 0 2.5rem;font-size:1rem}.loading-steps{display:flex;flex-direction:column;gap:1rem;align-items:flex-start;text-align:left}.loading-step{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;background:#f5f5f5;border-radius:12px;width:100%;transition:all .3s ease;opacity:.5}.loading-step.active{opacity:1;background:linear-gradient(135deg,#fff7e6,#ffe7ba);border:2px solid #ffd591}.step-icon{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,#8b4513,#654321);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600;flex-shrink:0;font-size:1.125rem}.loading-step span{color:#333;font-weight:500;font-size:1rem}@media(max-width:768px){.loading-content{padding:2rem 1.5rem}.loading-title{font-size:1.5rem}.loading-subtitle{font-size:.9375rem}.loading-steps{gap:.75rem}.loading-step{padding:.875rem 1rem}.step-icon{width:28px;height:28px}}.single-model-selector{display:flex;flex-direction:column;gap:.75rem}.single-model-label{font-size:1rem;color:#1a1a1a;display:block}.single-model-select{padding:.875rem 1.125rem;border:2px solid #e0e0e0;border-radius:1rem;font-size:1rem;background:#fff;cursor:pointer;transition:all .3s ease;outline:none}.single-model-select:hover{border-color:#2e7d32}.single-model-select:focus{border-color:#2e7d32;box-shadow:0 0 0 3px #2e7d321a}.start-container{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e8f5e9);display:flex;align-items:center;justify-content:center;padding:2rem}.start-content{max-width:800px;width:100%;display:flex;flex-direction:column;gap:2.5rem;animation:fadeIn .6s ease-out}.start-header{text-align:center;display:flex;flex-direction:column;align-items:center;gap:1rem}.start-logo{width:100px;height:100px;background:linear-gradient(135deg,#2e7d32,#388e3c);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 8px 24px #2e7d324d;animation:float 3s ease-in-out infinite}.start-title{margin:0;font-size:2.5rem;background:linear-gradient(135deg,#2e7d32,#388e3c);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.start-subtitle{margin:0;font-size:1.125rem;color:#666}.start-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.feature-card{background:#fff;padding:2rem;border-radius:1.5rem;box-shadow:0 4px 12px #00000014;text-align:center;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;gap:.75rem}.feature-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.feature-card svg{color:#2e7d32}.feature-card h3{margin:0;font-size:1.25rem;color:#1a1a1a}.feature-card p{margin:0;font-size:.95rem;color:#666}.start-model-section{background:#fff;padding:2rem;border-radius:1.5rem;box-shadow:0 4px 12px #00000014}.section-title{margin:0 0 1.5rem;font-size:1.5rem;color:#1a1a1a;text-align:center}.model-selectors{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem}.start-button{padding:1.25rem 2.5rem;background:linear-gradient(135deg,#2e7d32,#388e3c);color:#fff;border:none;border-radius:2rem;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:.75rem;font-size:1.125rem;box-shadow:0 4px 16px #2e7d324d;align-self:center;min-width:200px}.start-button:hover{transform:translateY(-4px);box-shadow:0 8px 24px #2e7d3266}.start-button:active{transform:translateY(-2px)}.start-disclaimer{background:#fff3cd;border:2px solid #ffc107;border-radius:1rem;padding:1.25rem;text-align:center}.start-disclaimer p{margin:0;font-size:.95rem;color:#856404;line-height:1.6}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@media(max-width:768px){.start-container{padding:1.5rem}.start-content{gap:2rem}.start-title{font-size:2rem}.start-subtitle{font-size:1rem}.start-logo{width:80px;height:80px}.start-logo svg{width:36px;height:36px}.start-features{grid-template-columns:1fr;gap:1rem}.feature-card,.start-model-section{padding:1.5rem}.model-selectors{grid-template-columns:1fr;gap:1rem}.start-button{width:100%;padding:1rem 2rem;font-size:1rem}.start-disclaimer{padding:1rem}.start-disclaimer p{font-size:.875rem}}.loading-screen{position:fixed;inset:0;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-content{text-align:center;color:#fff}.loading-logo{margin-bottom:24px;display:flex;justify-content:center;align-items:center}.loading-sparkles{color:gold;filter:drop-shadow(0 0 20px rgba(255,215,0,.5));animation:pulse 2s ease-in-out infinite}.loading-title{margin:0 0 40px;opacity:.95}.loading-spinner-container{display:flex;flex-direction:column;align-items:center;gap:16px}.loading-spinner{animation:spin 1s linear infinite}.loading-text{margin:0;opacity:.9}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.1);opacity:.8}}
