*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.chat-app{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;align-items:center;padding:20px}.chat-container{width:100%;max-width:480px;height:90vh;background-color:#f5f5f5;border-radius:20px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden}.chat-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:18px 20px;text-align:center;box-shadow:0 2px 10px #667eea4d}.chat-header h1{font-size:18px;font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:15px;display:flex;flex-direction:column;gap:12px}.message{display:flex;flex-direction:column}.user-message{align-items:flex-end}.system-message,.job-message{align-items:flex-start}.message-content{background:#fff;padding:12px 16px;border-radius:18px;box-shadow:0 2px 8px #00000014;max-width:85%;line-height:1.6;color:#333;font-size:14px}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.loading-message{background:#fff;padding:14px 20px;border-radius:18px;box-shadow:0 2px 8px #00000014;display:flex;align-items:center;gap:6px}.loading-dot{color:#667eea;font-size:12px;animation:bounce 1.4s infinite ease-in-out both}.loading-dot:nth-child(1){animation-delay:-.32s}.loading-dot:nth-child(2){animation-delay:-.16s}.loading-dot:nth-child(3){animation-delay:0}@keyframes bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.loading-text{margin-left:8px;color:#666;font-size:14px}.job-card{background:#fff;border-radius:16px;box-shadow:0 4px 16px #0000001a;overflow:hidden;width:100%;max-width:100%}.card-header{background:linear-gradient(135deg,#f8f9fa,#e9ecef);padding:12px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee}.brand-tag{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600}.brand-qx{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.brand-jd{background:linear-gradient(135deg,#f56565,#e53e3e);color:#fff}.match-location{font-size:12px;color:#888}.card-body{padding:16px}.job-title-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.job-title{font-size:18px;font-weight:700;color:#1a1a1a}.age-requirement{background:#f0f0f0;padding:4px 10px;border-radius:8px;font-size:12px;color:#666}.salary-section{margin-bottom:12px}.salary-main{background:linear-gradient(135deg,#fff5f5,#fed7d7);border-left:4px solid #f56565;padding:10px 14px;border-radius:8px;margin-bottom:8px}.salary-secondary{background:#fafafa;border-left:4px solid #ddd;padding:8px 14px;border-radius:8px}.salary-label{font-size:11px;color:#999;display:block;margin-bottom:2px}.salary-value{font-size:18px;font-weight:700;color:#f56565}.unit-price{font-size:14px;color:#666}.info-section{border-top:1px solid #f0f0f0;padding-top:12px}.info-row{display:flex;margin-bottom:8px;font-size:13px}.info-label{color:#888;min-width:60px}.info-value{color:#333;flex:1}.dorm-info{word-break:break-all}.card-footer{display:flex;gap:8px;padding:12px 16px;background:#fafafa;border-top:1px solid #eee}.copy-speech-button,.area-button,.guide-button{flex:1;padding:10px 12px;border-radius:10px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease;border:none;display:flex;align-items:center;justify-content:center;gap:6px}.copy-speech-button{background:linear-gradient(135deg,#11998e,#38ef7d);color:#fff;border:none;white-space:nowrap}.copy-speech-button:hover{opacity:.9;transform:translateY(-1px)}.area-button{background:#fff;border:2px solid #ddd;color:#333}.area-button:hover{border-color:#667eea;color:#667eea}.guide-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none}.guide-button:hover{opacity:.9;transform:translateY(-1px)}.input-container{padding:15px;background:#fff;display:flex;gap:10px;border-top:1px solid #eee}.chat-input{flex:1;padding:12px 16px;border:2px solid #eee;border-radius:25px;font-size:14px;outline:none;transition:border-color .2s}.chat-input:focus{border-color:#667eea}.send-button{padding:12px 24px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:25px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.send-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.send-button:disabled{opacity:.6;cursor:not-allowed}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:80vh;overflow:hidden;box-shadow:0 20px 60px #0000004d}.modal-content h3{padding:16px 20px;border-bottom:1px solid #eee;font-size:16px;font-weight:600;color:#333}.modal-close{position:absolute;top:12px;right:12px;width:32px;height:32px;border-radius:50%;border:none;background:#f5f5f5;font-size:20px;color:#666;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.modal-close:hover{background:#eee;color:#333}.modal-content{position:relative}.image-gallery{padding:20px;display:flex;flex-direction:column;gap:16px;max-height:60vh;overflow-y:auto}.image-item{text-align:center}.image-item img{max-width:100%;max-height:400px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.waiting-message{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;color:#999;font-size:14px;text-align:center}.waiting-message:before{content:"⏳";font-size:48px;margin-bottom:16px;opacity:.5}.area-modal .area-content{padding:20px}.area-image{width:100%;background:#f9f9f9;border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center;min-height:200px;margin-bottom:16px}.area-image img{max-width:100%;max-height:300px;object-fit:contain}.image-fallback{display:flex;justify-content:center;align-items:center;width:100%;height:200px;background-color:#f3f4f6;color:#6b7280;font-size:14px;text-align:center;border-radius:8px}.area-text{font-size:14px;line-height:1.8;color:#444}.area-text p{margin-bottom:8px}.jd-area-text p{white-space:pre-wrap;line-height:1.8;color:#444}.auth-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#667eea4d;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);display:flex;justify-content:center;align-items:center;z-index:2000}.auth-card{background:#ffffffd9;backdrop-filter:blur(30px);-webkit-backdrop-filter:blur(30px);border-radius:24px;padding:48px 40px;width:90%;max-width:400px;text-align:center;box-shadow:0 25px 80px #667eea66;border:1px solid rgba(255,255,255,.5)}.auth-icon{font-size:64px;margin-bottom:24px;opacity:.8}.auth-card h2{font-size:24px;font-weight:700;color:#333;margin-bottom:12px}.auth-subtitle{font-size:14px;color:#666;margin-bottom:32px}.auth-input-container{display:flex;flex-direction:column;gap:16px}.auth-input{padding:16px;border:2px solid #ddd;border-radius:12px;font-size:16px;outline:none;transition:border-color .2s;background:#fff}.auth-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.auth-button{padding:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #667eea4d}.auth-button:hover{transform:translateY(-2px);box-shadow:0 6px 16px #667eea66}.auth-button:active{transform:scale(.98)}@media (max-width: 480px){.chat-app{padding:0}.chat-container{height:100vh;border-radius:0;max-width:100%}.job-title-row{flex-direction:column;align-items:flex-start;gap:8px}.card-footer{flex-direction:column}.auth-card{width:95%;padding:32px 24px}}
