*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;color:#333;line-height:1.6}.app-container{display:flex;flex-direction:column;min-height:100vh;max-width:1000px;margin:0 auto;background:rgba(255,255,255,.95);box-shadow:0 20px 40px rgba(0,0,0,.1);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.main-content{flex:1 1;padding:2rem;display:flex;flex-direction:column;gap:1.5rem}.header{text-align:center;margin-bottom:1rem}.header h1{font-size:2.5rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:.5rem;font-weight:700}.header p{color:#666;font-size:1.1rem}.model-info{font-size:.9rem!important;color:#888!important;font-family:Monaco,Menlo,monospace;margin-top:.5rem!important}.status-box{background:#f8f9fa;border:1px solid #e9ecef;border-radius:12px;padding:1rem;font-size:.95rem}.status-content{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.5rem}.clear-button{padding:.4rem .8rem;background:#6c757d;color:white;border:none;border-radius:6px;font-size:.85rem;cursor:pointer;transition:background-color .2s ease}.clear-button:hover{background:#5a6268}.progress-container{display:flex;align-items:center;gap:1rem;margin-top:.75rem}.progress-bar-container{flex:1 1;height:8px;background-color:#e9ecef;border-radius:4px;overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);transition:width .3s ease;border-radius:4px}.progress-text{font-weight:600;color:#667eea;min-width:40px;text-align:right;font-size:.9rem}.chat-area{flex:1 1;background:#ffffff;border:1px solid #e9ecef;border-radius:12px;padding:1.5rem;min-height:200px;overflow-y:auto;position:relative}.placeholder-text{color:#999;font-style:italic;text-align:center;margin-top:2rem}.response-container{display:flex;flex-direction:column;gap:.75rem}.response-header{font-weight:600;color:#667eea;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.response-text{line-height:1.7;color:#333;white-space:pre-wrap;word-wrap:break-word}.generating-indicator{display:flex;align-items:center;gap:1rem;color:#667eea;font-weight:500}.spinner{width:20px;height:20px;border:2px solid #f3f3f3;border-top-color:#667eea;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.input-area{display:flex;gap:1rem;padding:1.5rem 2rem;background:#f8f9fa;border-top:1px solid #e9ecef;align-items:flex-end}.text-input{flex:1 1;padding:.75rem 1rem;border:2px solid #e9ecef;border-radius:8px;font-size:1rem;resize:vertical;min-height:44px;max-height:120px;font-family:inherit;transition:border-color .2s ease}.text-input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.text-input:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.run-button{padding:.75rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:white;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;min-width:100px;height:44px}.run-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px rgba(102,126,234,.3)}.run-button:active:not(:disabled){transform:translateY(0)}.run-button:disabled{background:#6c757d;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width:768px){.app-container{margin:0;min-height:100vh;border-radius:0}.input-area,.main-content{padding:1rem}.input-area{flex-direction:column}.text-input{margin-bottom:.5rem}.header h1{font-size:2rem}}