:root{--color-primary: #005eb8;--color-primary-dark: #003d7a;--color-primary-light: #41b6e6;--color-success: #007f3b;--color-warning: #ffb81c;--color-error: #da291c;--color-medical-safe: #00703c;--color-medical-caution: #f47738;--color-medical-urgent: #d4351c;--color-medical-info: #1d70b8;--color-ai-primary: #7c3aed;--color-ai-secondary: #8b5cf6;--color-ai-glow: rgba(124, 58, 237, .15);--color-ai-ring: linear-gradient(135deg, #7c3aed, #005eb8);--color-bg-primary: #f8fafc;--color-bg-secondary: #ffffff;--color-bg-tertiary: #f1f5f9;--color-bg-chat: linear-gradient(180deg, #f8fafc 0%, #ffffff 50%, #f8fafc 100%);--color-bg-question: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);--color-bg-answered: linear-gradient(135deg, #ecfdf5 0%, #d1fae5 100%);--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-text-muted: #94a3b8;--color-border: #e2e8f0;--color-border-light: rgba(226, 232, 240, .6);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-md: 1.0625rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--chat-message-font-size: 1.0625rem;--chat-message-line-height: 1.7;--chat-question-font-size: 1.125rem;--chat-option-font-size: 1rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1);--shadow-message: 0 2px 8px rgba(0, 0, 0, .06), 0 1px 3px rgba(0, 0, 0, .04);--shadow-user-message: 0 4px 12px rgba(102, 126, 234, .35);--shadow-ai-glow: 0 0 20px var(--color-ai-glow);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease;--transition-bounce: .3s cubic-bezier(.175, .885, .32, 1.275);--header-height: 64px;--footer-height: 80px;--max-width: 1200px;--chat-max-width: 1000px;--avatar-size: 48px;--avatar-size-mobile: 40px;--message-bubble-max-width: 88%}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary);min-height:100vh;overflow-x:hidden}.app-container{display:flex;flex-direction:column;min-height:100vh;background-color:var(--color-bg-secondary);transition:margin-right .3s ease}body.debug-panel-open .app-container{margin-right:420px}.app-header{height:var(--header-height);padding:0 var(--space-xl);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;display:flex;align-items:center;flex-shrink:0;box-shadow:0 2px 10px #0000001a;position:relative;z-index:50}.header-content{display:flex;align-items:baseline;gap:var(--space-md)}.header-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);letter-spacing:-.5px}.header-subtitle{font-size:var(--font-size-sm);opacity:.85;font-weight:var(--font-weight-normal)}.header-actions{margin-left:auto;display:flex;align-items:center;gap:var(--space-md)}.app-main{flex:1;display:flex;flex-direction:column;overflow:hidden;position:relative;background:var(--color-bg-primary)}.app-footer{flex-shrink:0;border-top:1px solid var(--color-border);background-color:var(--color-bg-secondary);padding:var(--space-lg) var(--space-xl);box-shadow:0 -2px 10px #00000008}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-text-muted);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}@keyframes progressBar{0%{width:0%}to{width:100%}}@keyframes checkDraw{0%{stroke-dashoffset:24}to{stroke-dashoffset:0}}.success-check{stroke-dasharray:24;animation:checkDraw .4s ease-out forwards}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,var(--color-bg-tertiary) 25%,var(--color-bg-secondary) 50%,var(--color-bg-tertiary) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (max-width: 900px){body.debug-panel-open .app-container{margin-right:0}.app-header{padding:0 var(--space-md)}.app-footer{padding:var(--space-md)}}.welcome-screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);z-index:10}.welcome-content{text-align:center;max-width:500px;padding:var(--space-2xl)}.welcome-icon{width:100px;height:100px;margin:0 auto var(--space-xl);padding:var(--space-lg);background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);border-radius:var(--radius-full);color:#fff;box-shadow:0 10px 40px #005eb84d}.welcome-icon svg{width:100%;height:100%}.welcome-title{font-size:2rem;font-weight:var(--font-weight-bold);margin-bottom:var(--space-md);color:var(--color-text-primary);letter-spacing:-.5px}.welcome-text{color:var(--color-text-secondary);margin-bottom:var(--space-xl);line-height:1.7;font-size:var(--font-size-lg)}.start-button{padding:var(--space-md) var(--space-2xl);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:#fff;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-normal);box-shadow:0 4px 15px #005eb84d}.start-button:hover{transform:translateY(-3px);box-shadow:0 8px 25px #005eb866}.start-button:active{transform:translateY(-1px)}.welcome-trust-indicators{display:flex;flex-wrap:wrap;justify-content:center;gap:var(--space-lg);margin-bottom:var(--space-xl)}.trust-item{display:flex;align-items:center;gap:var(--space-xs);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.trust-item svg{color:var(--color-success)}.welcome-icon.ai-glow{position:relative}.welcome-icon.ai-glow:after{content:"";position:absolute;top:-10px;right:-10px;bottom:-10px;left:-10px;border-radius:50%;background:linear-gradient(135deg,var(--color-ai-primary),var(--color-primary));opacity:.15;animation:aiWelcomeGlow 3s ease-in-out infinite;z-index:-1}@keyframes aiWelcomeGlow{0%,to{opacity:.15;transform:scale(1)}50%{opacity:.25;transform:scale(1.1)}}.nhs-trust-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#ffffff26;border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:#fff;font-weight:var(--font-weight-medium);letter-spacing:.3px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.nhs-trust-badge svg{flex-shrink:0}.chat-messages{flex:1;overflow-y:auto;padding:var(--space-xl) var(--space-xl);display:flex;flex-direction:column;gap:var(--space-xl);background:linear-gradient(180deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);scroll-behavior:smooth}.message{display:flex;gap:var(--space-md);max-width:var(--chat-max-width);width:100%;margin:0 auto;animation:messageSlide .3s ease-out}@keyframes messageSlide{0%{opacity:0;transform:translateY(15px)}to{opacity:1;transform:translateY(0)}}.message.user{flex-direction:row-reverse}.message.assistant{flex-direction:row}.message-avatar{width:var(--avatar-size);height:var(--avatar-size);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-message);position:relative}.message-avatar svg{width:28px;height:28px}.user-avatar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assistant-avatar{background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-primary) 100%);color:#fff}.assistant-avatar:after{content:"";position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;background:linear-gradient(135deg,var(--color-ai-primary),var(--color-primary));z-index:-1;opacity:.3;animation:aiGlowPulse 3s ease-in-out infinite}@keyframes aiGlowPulse{0%,to{opacity:.3;transform:scale(1)}50%{opacity:.5;transform:scale(1.05)}}.message-bubble{flex:1;max-width:var(--message-bubble-max-width)}.user-bubble .message-content{background:linear-gradient(135deg,#667eea,#5a67d8);color:#fff;padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-xl) var(--radius-xl) var(--radius-sm) var(--radius-xl);box-shadow:var(--shadow-user-message)}.assistant-bubble .message-content{background:linear-gradient(135deg,#fff,#f8fafc);color:var(--color-text-primary);padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-xl) var(--radius-xl) var(--radius-xl) 6px;box-shadow:var(--shadow-message);border:1px solid rgba(0,94,184,.08);position:relative}.assistant-bubble .message-content:before{content:"AI";position:absolute;top:-8px;left:var(--space-md);padding:2px 8px;background:linear-gradient(135deg,var(--color-ai-primary) 0%,var(--color-ai-secondary) 100%);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-bold);letter-spacing:.5px;box-shadow:0 2px 8px var(--color-ai-glow)}.message-content{line-height:var(--chat-message-line-height);font-size:var(--chat-message-font-size);letter-spacing:-.01em}.questions-section{margin-top:var(--space-lg);display:flex;flex-direction:column;gap:var(--space-sm)}.progress-tracker{display:flex;flex-direction:column;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#005eb808,#005eb80f);border-radius:var(--radius-md);margin-bottom:var(--space-sm);border:1px solid rgba(0,94,184,.1)}.progress-header{display:flex;justify-content:space-between;align-items:center}.progress-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.progress-count{font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);color:var(--color-primary)}.progress-bar{height:8px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-success) 100%);border-radius:var(--radius-full);transition:width .5s cubic-bezier(.4,0,.2,1)}.milestone-celebration{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:var(--radius-md);margin-top:var(--space-xs);animation:celebrationSlide .5s ease-out}@keyframes celebrationSlide{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.milestone-icon{font-size:1.25rem}.milestone-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#92400e}.inline-question{background:var(--color-bg-question);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);transition:all var(--transition-normal);cursor:pointer}.inline-question:hover:not(.answered){border-color:var(--color-primary-light)}.inline-question.active{padding:var(--space-md) var(--space-lg);border-color:var(--color-primary);box-shadow:0 0 0 3px #005eb81a;cursor:default;animation:questionExpand .3s ease-out}@keyframes questionExpand{0%{padding:var(--space-sm) var(--space-md)}to{padding:var(--space-md) var(--space-lg)}}.inline-question.answered{background:var(--color-bg-answered);border-color:var(--color-success);padding:var(--space-sm) var(--space-md)}.inline-question:not(.active) .options-container{display:none}.question-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:0}.inline-question.active .question-header{margin-bottom:var(--space-md)}.question-number{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);flex-shrink:0}.inline-question.answered .question-number{background:linear-gradient(135deg,var(--color-success) 0%,#047857 100%)}.question-text{flex:1;font-size:var(--chat-question-font-size);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);line-height:1.4}.inline-question:not(.active) .question-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.answer-preview{font-size:var(--font-size-sm);color:var(--color-success);font-weight:var(--font-weight-medium);margin-left:auto;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.answered-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 8px;background:var(--color-success);color:#fff;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.5px;animation:badgePop .4s var(--transition-bounce)}@keyframes badgePop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.expand-indicator{width:20px;height:20px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted);transition:transform var(--transition-fast);flex-shrink:0}.inline-question.active .expand-indicator{transform:rotate(180deg)}.inline-question.answered .expand-indicator{display:none}.options-container{display:flex;flex-direction:column;gap:var(--space-sm)}.option-btn{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background-color:#fff;border:2px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:left;font-size:var(--chat-option-font-size);font-family:var(--font-family)}.option-btn.active:hover{border-color:var(--color-primary);background-color:#005eb80d;transform:translate(4px)}.option-btn.active:active{background-color:#005eb81a}.option-btn.selected{border-color:var(--color-success);background:linear-gradient(135deg,#ecfdf5,#d1fae5);cursor:default;animation:selectPop .3s ease-out}@keyframes selectPop{0%{transform:scale(1)}50%{transform:scale(1.02)}to{transform:scale(1)}}.option-btn.disabled{opacity:.5;cursor:not-allowed;background-color:var(--color-bg-tertiary)}.option-indicator{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-bg-tertiary);color:var(--color-text-secondary);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);flex-shrink:0;transition:all var(--transition-fast)}.option-btn.active:hover .option-indicator{background:var(--color-primary);color:#fff}.option-btn.selected .option-indicator{background:var(--color-success);color:#fff}.option-text{flex:1;color:var(--color-text-primary);line-height:1.4}.option-btn.other-option{border-style:dashed}.other-icon{color:var(--color-text-muted);font-size:var(--font-size-lg)}.custom-badge{display:inline-flex;align-items:center;padding:2px 8px;background:var(--color-primary);color:#fff;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.other-input-container{background-color:#fff;border:2px solid var(--color-primary);border-radius:var(--radius-md);padding:var(--space-md);animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.other-input{width:100%;padding:var(--space-md);font-family:var(--font-family);font-size:var(--font-size-base);border:1px solid var(--color-border);border-radius:var(--radius-sm);margin-bottom:var(--space-sm);transition:border-color var(--transition-fast)}.other-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #005eb81a}.other-input-actions{display:flex;gap:var(--space-sm);justify-content:flex-end}.other-submit-btn{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast)}.other-submit-btn:hover{background:var(--color-primary-dark)}.other-submit-btn svg{width:16px;height:16px}.other-cancel-btn{padding:var(--space-sm) var(--space-md);background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.other-cancel-btn:hover{background:var(--color-bg-tertiary);color:var(--color-text-primary)}.submit-answers-container{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.submit-answers-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-xl);background:linear-gradient(135deg,var(--color-success) 0%,#047857 100%);color:#fff;border:none;border-radius:var(--radius-lg);font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 4px 15px #007f3b4d;width:100%;justify-content:center}.submit-answers-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #007f3b66}.submit-answers-btn:active{transform:translateY(0)}.submit-answers-btn svg{width:18px;height:18px}.answers-progress{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,#005eb80d,#005eb81a);border-radius:var(--radius-md);text-align:center}.progress-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary)}.input-area{width:100%;max-width:var(--chat-max-width);margin:0 auto}.input-wrapper{display:flex;gap:var(--space-sm);align-items:flex-end;background:#fff;padding:var(--space-sm);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);border:1px solid var(--color-border)}.message-textarea{flex:1;padding:var(--space-md) var(--space-lg);font-family:var(--font-family);font-size:var(--font-size-base);border:none;border-radius:var(--radius-lg);resize:none;background:transparent;min-height:24px;max-height:120px}.message-textarea:focus{outline:none}.message-textarea::placeholder{color:var(--color-text-muted)}.message-textarea:disabled{background-color:var(--color-bg-tertiary);cursor:not-allowed}.send-button{display:flex;align-items:center;justify-content:center;width:48px;height:48px;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:#fff;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);flex-shrink:0}.send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #005eb866}.send-button:disabled{opacity:.5;cursor:not-allowed}.send-button svg{width:20px;height:20px;transition:transform var(--transition-fast)}.send-button:hover:not(:disabled) svg{transform:translate(2px)}.loading-container{display:flex;gap:var(--space-md);max-width:var(--chat-max-width);width:100%;margin:0 auto;animation:messageSlide .3s ease-out}.loading-bubble{background:linear-gradient(135deg,#fff,#f0f9ff);padding:var(--space-lg) var(--space-xl);border-radius:var(--radius-xl) var(--radius-xl) var(--radius-xl) 6px;box-shadow:var(--shadow-message);border:1px solid rgba(0,94,184,.1);min-width:280px}.ai-thinking-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.ai-brain-icon{width:24px;height:24px;color:var(--color-ai-primary);animation:brainThink 1.5s ease-in-out infinite}@keyframes brainThink{0%,to{transform:scale(1);filter:brightness(1)}50%{transform:scale(1.1);filter:brightness(1.2)}}.thinking-text{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-ai-primary)}.ai-badge-small{padding:2px 6px;background:linear-gradient(135deg,var(--color-ai-primary) 0%,var(--color-ai-secondary) 100%);color:#fff;border-radius:var(--radius-full);font-size:9px;font-weight:var(--font-weight-bold);letter-spacing:.5px;margin-left:auto}.analysis-steps{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-md)}.analysis-step{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);transition:color var(--transition-fast)}.analysis-step.active{color:var(--color-primary)}.analysis-step.complete{color:var(--color-success)}.step-icon{width:16px;height:16px;flex-shrink:0}.step-icon.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.typing-indicator{display:flex;gap:6px;margin-bottom:var(--space-sm)}.typing-indicator span{width:10px;height:10px;background-color:var(--color-ai-primary);border-radius:var(--radius-full);animation:bounce 1.4s infinite ease-in-out both}.typing-indicator span:nth-child(1){animation-delay:-.32s}.typing-indicator span:nth-child(2){animation-delay:-.16s}@keyframes bounce{0%,80%,to{transform:scale(.6);opacity:.5}40%{transform:scale(1);opacity:1}}.loading-text{font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--space-xs)}.loading-tip{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;padding-top:var(--space-sm);border-top:1px dashed var(--color-border)}.error-container{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid var(--color-error);border-radius:var(--radius-lg);max-width:var(--chat-max-width);margin:0 auto;animation:messageSlide .3s ease-out}.error-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-error);color:#fff;border-radius:var(--radius-full);flex-shrink:0}.error-content{flex:1}.error-title{font-weight:var(--font-weight-semibold);color:var(--color-error);margin-bottom:var(--space-xs)}.error-message{color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5}.warning-container{display:flex;align-items:flex-start;gap:var(--space-md);padding:var(--space-lg);background:linear-gradient(135deg,#fffbeb,#fef3c7);border:1px solid var(--color-warning);border-radius:var(--radius-lg);max-width:var(--chat-max-width);margin:0 auto;animation:messageSlide .3s ease-out}.warning-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background-color:var(--color-warning);color:var(--color-text-primary);border-radius:var(--radius-full);flex-shrink:0}.warning-content{flex:1}.warning-title{font-weight:var(--font-weight-semibold);color:#92400e;margin-bottom:var(--space-xs)}.warning-message{color:var(--color-text-primary);font-size:var(--font-size-sm);line-height:1.5}@media (max-width: 900px){.app-container{max-width:100%;box-shadow:none}.chat-messages{padding:var(--space-md)}.message{max-width:100%}.message-bubble{max-width:88%}.message-avatar{width:var(--avatar-size-mobile);height:var(--avatar-size-mobile)}.message-avatar svg{width:22px;height:22px}.assistant-bubble .message-content:before{top:-6px;font-size:9px;padding:2px 6px}}@media (max-width: 600px){.header-content{flex-direction:column;gap:0}.header-subtitle{font-size:var(--font-size-xs)}.welcome-content{padding:var(--space-lg)}.welcome-icon{width:80px;height:80px;padding:var(--space-md)}.welcome-title{font-size:1.5rem}.welcome-text{font-size:var(--font-size-base)}.message-bubble{max-width:90%}.inline-question{padding:var(--space-md)}.option-btn{padding:var(--space-sm) var(--space-md)}.option-indicator{width:28px;height:28px}.input-wrapper{border-radius:var(--radius-lg)}.send-button{width:44px;height:44px}}.case-paper-section{margin-top:var(--space-xl);border:2px solid var(--color-primary);border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-md);animation:casePaperSlide .5s ease-out}@keyframes casePaperSlide{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.case-paper-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.case-paper-header svg{flex-shrink:0}.case-paper-title{flex:1;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:-.3px}.case-paper-download-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:#fff3;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast)}.case-paper-download-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.case-paper-content{padding:var(--space-lg) var(--space-xl);max-height:600px;overflow-y:auto;font-size:var(--font-size-sm);line-height:1.55;color:var(--color-text-primary)}.case-paper-content h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-dark);margin:0 0 var(--space-md) 0;padding-bottom:var(--space-xs);border-bottom:2px solid var(--color-primary)}.case-paper-content h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-lg) 0 var(--space-sm) 0;padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.case-paper-content h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin:var(--space-md) 0 var(--space-xs) 0}.case-paper-content p{margin:0 0 var(--space-sm) 0}.case-paper-content>*:last-child{margin-bottom:0}.case-paper-content strong{color:var(--color-text-primary);font-weight:var(--font-weight-semibold)}.case-paper-content blockquote{margin:var(--space-sm) 0;padding:var(--space-sm) var(--space-md);background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-left:4px solid var(--color-primary);border-radius:0 var(--radius-md) var(--radius-md) 0;font-style:italic;color:var(--color-text-secondary)}.case-paper-content hr{margin:var(--space-md) 0;border:none;border-top:1px solid var(--color-border)}.case-paper-content ul{margin:var(--space-xs) 0 var(--space-sm) 0;padding-left:var(--space-xl)}.case-paper-content li{margin-bottom:2px;position:relative}.case-paper-content li::marker{color:var(--color-primary)}.case-paper-table{width:100%;border-collapse:collapse;margin:var(--space-md) 0;font-size:var(--font-size-sm)}.case-paper-table th{background:linear-gradient(135deg,var(--color-bg-secondary) 0%,var(--color-bg-tertiary) 100%);padding:var(--space-sm) var(--space-md);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-primary);border:1px solid var(--color-border)}.case-paper-table td{padding:var(--space-sm) var(--space-md);border:1px solid var(--color-border);vertical-align:top}.case-paper-table tr:nth-child(2n) td{background-color:var(--color-bg-secondary)}.case-paper-table tr:hover td{background-color:#005eb80d}.case-paper-content::-webkit-scrollbar{width:8px}.case-paper-content::-webkit-scrollbar-track{background:var(--color-bg-secondary);border-radius:4px}.case-paper-content::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}.case-paper-content::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}@media (max-width: 600px){.case-paper-section{margin-top:var(--space-lg)}.case-paper-header{padding:var(--space-sm) var(--space-md)}.case-paper-title{font-size:var(--font-size-base)}.case-paper-content{padding:var(--space-sm) var(--space-md);max-height:400px}.case-paper-content h2{font-size:var(--font-size-lg)}.case-paper-content h3{font-size:var(--font-size-base)}.case-paper-table{font-size:var(--font-size-xs)}.case-paper-table th,.case-paper-table td{padding:var(--space-xs) var(--space-sm)}}.recommendation-text-section{margin-top:var(--space-xl);border:2px solid #22c55e;border-radius:var(--radius-lg);overflow:hidden;background:#fff;box-shadow:var(--shadow-md);animation:casePaperSlide .5s ease-out}.recommendation-text-header{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff}.recommendation-text-header svg{flex-shrink:0}.recommendation-text-title{flex:1;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);letter-spacing:-.3px}.recommendation-text-content{padding:var(--space-lg) var(--space-xl);max-height:600px;overflow-y:auto;font-size:var(--font-size-sm);line-height:1.55;color:var(--color-text-primary)}.recommendation-text-content h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:#16a34a;margin:0 0 var(--space-md) 0;padding-bottom:var(--space-xs);border-bottom:2px solid #22c55e}.recommendation-text-content h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-lg) 0 var(--space-sm) 0;padding-bottom:var(--space-xs);border-bottom:1px solid var(--color-border)}.recommendation-text-content h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:var(--space-md) 0 var(--space-xs) 0}.recommendation-text-content p{margin:0 0 var(--space-sm) 0}.recommendation-text-content>*:last-child{margin-bottom:0}.recommendation-text-content strong{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.recommendation-text-content ul{padding-left:var(--space-xl);margin:var(--space-xs) 0 var(--space-sm) 0}.recommendation-text-content li{margin-bottom:2px}.recommendation-download-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin-left:auto;background:#fff3;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;transition:all var(--transition-fast)}.recommendation-download-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.service-recommendations-section{margin-top:var(--space-xl);background:linear-gradient(135deg,#f8faff,#eef3ff);border-radius:var(--radius-lg);border:1px solid var(--color-border);overflow:hidden}.service-recommendations-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff}.service-recommendations-header svg{flex-shrink:0}.service-recommendations-title{font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.service-recommendations-message{padding:var(--space-md) var(--space-lg);color:var(--color-text-secondary);font-size:var(--font-size-sm);line-height:1.5;border-bottom:1px solid var(--color-border-light)}.service-urgency-note{padding:var(--space-sm) var(--space-lg);background:#fff8e6;color:#8a6d00;font-size:var(--font-size-sm);border-left:4px solid #ffc107}.service-urgency-warning{padding:var(--space-md) var(--space-lg);background:#ffe8e8;color:#b71c1c;font-size:var(--font-size-sm);border-radius:var(--radius-md);border-left:4px solid #ef5350;margin-top:var(--space-md)}.service-cards-container{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md);padding:var(--space-lg)}.service-card{background:#fff;border-radius:var(--radius-md);border:1px solid var(--color-border);overflow:hidden;transition:all var(--transition-fast);display:flex;flex-direction:column}.service-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:var(--color-primary-light)}.service-card-header{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--color-border-light)}.service-category-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-md);color:var(--color-primary);flex-shrink:0}.service-category-icon svg{width:20px;height:20px}.service-info{flex:1;min-width:0}.service-name{font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.3}.service-category-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:2px}.delivery-badge{display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-medium);white-space:nowrap;flex-shrink:0}.delivery-badge.online{background:#e3f2fd;color:#1565c0}.delivery-badge.home{background:#e8f5e9;color:#2e7d32}.delivery-badge.clinic{background:#fff3e0;color:#e65100}.delivery-badge.postal{background:#f3e5f5;color:#7b1fa2}.service-card-body{flex:1;padding:var(--space-md)}.service-reason{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.5;margin-bottom:var(--space-sm)}.service-price{display:flex;align-items:baseline;gap:var(--space-xs);flex-wrap:wrap}.price-from{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.price-amount{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-primary)}.price-label,.price-packages{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.service-card-footer{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--color-border-light);background:var(--color-bg-secondary)}.service-book-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.service-book-btn:hover{background:var(--color-primary-dark)}.service-book-btn svg{transition:transform var(--transition-fast)}.service-book-btn:hover svg{transform:translate(2px)}@media (max-width: 600px){.service-cards-container{grid-template-columns:1fr;padding:var(--space-md)}.service-recommendations-header{padding:var(--space-sm) var(--space-md)}.service-recommendations-title{font-size:var(--font-size-sm)}.service-recommendations-message{padding:var(--space-sm) var(--space-md);font-size:var(--font-size-xs)}}.debug-panel{position:fixed;top:0;right:0;width:420px;height:100vh;background:var(--color-bg-secondary);border-left:1px solid var(--color-border);display:flex;flex-direction:column;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);z-index:1000;box-shadow:-8px 0 30px #00000026}.debug-panel.open{transform:translate(0)}.debug-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:#fff;flex-shrink:0;min-height:var(--header-height)}.debug-panel-title{display:flex;align-items:center;gap:var(--space-sm);font-weight:var(--font-weight-semibold);font-size:var(--font-size-base)}.debug-icon{font-size:1.3em}.debug-collapse-btn{background:#ffffff26;border:none;color:#fff;width:36px;height:36px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1.4rem;font-weight:300;transition:all .2s ease}.debug-collapse-btn:hover{background:#ffffff40;transform:scale(1.05)}.debug-collapse-btn:active{transform:scale(.95)}.debug-panel-summary{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-md) var(--space-lg);background:linear-gradient(180deg,var(--color-bg-primary) 0%,var(--color-bg-secondary) 100%);border-bottom:1px solid var(--color-border);flex-shrink:0}.summary-item{display:flex;flex-direction:column;gap:2px}.summary-label{font-size:.65rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.8px;font-weight:var(--font-weight-medium)}.summary-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.clear-debug-btn{margin-left:auto;padding:var(--space-xs) var(--space-md);background:transparent;color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all .2s ease}.clear-debug-btn:hover{background:var(--color-error);color:#fff}.debug-entries-container{flex:1;overflow-y:auto;padding:var(--space-md);background:var(--color-bg-primary)}.debug-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:280px;color:var(--color-text-muted);text-align:center;padding:var(--space-xl)}.empty-icon{font-size:4rem;margin-bottom:var(--space-md);opacity:.4}.empty-text{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-xs)}.empty-hint{font-size:var(--font-size-sm);line-height:1.5}.debug-entry{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-md);overflow:hidden;transition:all .2s ease;animation:slideUp .3s ease-out}.debug-entry:hover{box-shadow:var(--shadow-md)}.debug-entry.expanded{border-color:var(--color-primary);box-shadow:0 4px 20px #005eb81a}.debug-entry-header{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--color-bg-secondary);cursor:pointer;transition:background .2s ease;-webkit-user-select:none;user-select:none}.debug-entry-header:hover{background:var(--color-bg-tertiary)}.entry-meta{display:flex;align-items:center;gap:var(--space-xs);flex:1;font-size:var(--font-size-sm)}.entry-turn{font-weight:var(--font-weight-bold);color:var(--color-primary);background:#005eb81a;padding:2px 8px;border-radius:var(--radius-sm)}.entry-separator{color:var(--color-text-muted);font-size:.5rem}.entry-duration,.entry-tokens{color:var(--color-text-secondary);font-size:var(--font-size-xs)}.entry-time{font-size:var(--font-size-xs);color:var(--color-text-muted);background:var(--color-bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm)}.expand-icon{font-size:.6rem;color:var(--color-text-muted);margin-left:var(--space-xs);transition:transform .2s ease}.debug-entry.expanded .expand-icon{transform:rotate(90deg)}.debug-entry-details{border-top:1px solid var(--color-border);animation:slideUp .2s ease-out}.detail-section{padding:var(--space-md);border-bottom:1px solid var(--color-border)}.detail-section:last-child{border-bottom:none}.section-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-sm);font-size:.7rem;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.8px;color:var(--color-text-muted)}.section-icon{font-size:1.1rem}.section-content{font-size:var(--font-size-sm);line-height:1.6;color:var(--color-text-primary)}.user-input-section{background:linear-gradient(135deg,#667eea14,#764ba20d)}.user-input-section .section-header{color:#667eea}.user-input-section .section-content{font-style:italic;color:var(--color-text-secondary)}.sent-section{background:linear-gradient(135deg,#fbbf2414,#f59e0b0d)}.sent-section .section-header{color:#d97706}.prompt-summary{margin-bottom:var(--space-sm);font-weight:var(--font-weight-medium)}.prompt-meta{display:flex;flex-wrap:wrap;gap:var(--space-sm);font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-sm)}.prompt-meta span{background:var(--color-bg-secondary);padding:2px 8px;border-radius:var(--radius-sm)}.response-section{background:linear-gradient(135deg,#10b98114,#0596690d)}.response-section .section-header{color:#059669}.response-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-sm)}.token-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.token-badge.input{background:#3b82f626;color:#2563eb}.token-badge.output{background:#10b98126;color:#059669}.status-badge{padding:4px 10px;border-radius:var(--radius-md);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.5px}.status-badge.success{background:#10b98126;color:#059669}.status-badge.error{background:#ef444426;color:var(--color-error)}.shown-section{background:linear-gradient(135deg,#8b5cf614,#7c3aed0d)}.shown-section .section-header{color:#7c3aed}.shown-message{background:var(--color-bg-secondary);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--color-border);font-size:var(--font-size-sm);line-height:1.6}.expandable-section{margin-top:var(--space-sm)}.expandable-section summary{cursor:pointer;color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:var(--space-xs) 0;transition:color .2s ease}.expandable-section summary:hover{color:var(--color-primary-dark)}.expandable-section summary::marker{color:var(--color-primary)}.code-block{background:#1e293b;color:#e2e8f0;border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-sm);font-family:Monaco,Menlo,Consolas,monospace;font-size:.75rem;line-height:1.5;overflow-x:auto;white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}.error-message{background:#ef44441a;color:var(--color-error);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-sm);border-left:3px solid var(--color-error)}.debug-toggle-btn{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:#ffffff26;border:1px solid rgba(255,255,255,.25);border-radius:var(--radius-lg);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#fff;transition:all .2s ease;font-family:var(--font-family)}.debug-toggle-btn:hover{background:#ffffff40;border-color:#fff6;transform:translateY(-1px)}.debug-toggle-btn.active{background:#fff;border-color:#fff;color:var(--color-primary)}.debug-toggle-btn.active:hover{background:var(--color-bg-primary)}.toggle-icon{font-size:1.1rem}.toggle-label{font-weight:var(--font-weight-semibold)}.toggle-badge{background:#ffffff40;color:#fff;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);min-width:22px;text-align:center}.debug-toggle-btn.active .toggle-badge{background:var(--color-primary);color:#fff}@media (max-width: 900px){.debug-panel{width:100%;max-width:420px}}@media (max-width: 600px){.debug-panel{max-width:100%}.debug-panel-summary{flex-wrap:wrap;gap:var(--space-md)}.summary-item{min-width:70px}.debug-toggle-btn .toggle-label{display:none}}
