*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background-color:#e8edf3;color:#333;-webkit-font-smoothing:antialiased}#app{max-width:100%;min-height:100vh}.chat-container{display:flex;flex-direction:column;height:100vh;max-width:600px;margin:0 auto;background-color:#fff;box-shadow:0 0 20px #0000000d}.chat-header{padding:16px 20px;background-color:#fff;color:#1a73e8;text-align:center;font-size:18px;font-weight:700;border-bottom:1px solid #eef1f5;letter-spacing:.5px;display:flex;justify-content:space-between;align-items:center}.header-right{display:flex;align-items:center;gap:8px}.header-status{font-size:11px;color:#94a3b8;font-weight:400;background:#f1f4f9;padding:3px 10px;border-radius:10px}.header-right .icon-btn{width:34px;height:34px;font-size:16px;background:transparent}.icon-btn{width:32px;height:32px;border-radius:50%;border:none;background:#f1f3f5;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.icon-btn:hover{background:#e0e7ff;color:#1a73e8}.chat-messages{flex:1;overflow-y:auto;padding:20px 16px;background:linear-gradient(135deg,#f5f7fa,#eef2f7)}.message{margin-bottom:20px;display:flex;align-items:flex-start;gap:10px}.message.user{flex-direction:row-reverse}.message.assistant{flex-direction:row}.avatar{width:36px;height:36px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:16px;color:#fff;font-weight:600}.avatar.user{background-color:#1a73e8}.avatar.assistant{background-color:#94a3b8;font-size:14px}.message-content{max-width:75%;padding:12px 16px;border-radius:18px;word-wrap:break-word;line-height:1.6;font-size:15px;position:relative}.message.user .message-content{background-color:#1a73e8;color:#fff;border-bottom-right-radius:4px;box-shadow:0 2px 8px #1a73e826}.message.assistant .message-content{background-color:#fff;color:#333;border-bottom-left-radius:4px;box-shadow:0 1px 4px #0000000f}.message-image{max-width:200px;border-radius:12px;margin-top:6px}.loading{display:flex;align-items:center;gap:12px;padding:8px 4px}.loading-dots{display:flex;gap:5px;padding:4px 0}.loading-dots span{width:10px;height:10px;background-color:#1a73e8;border-radius:50%;animation:breathe 1.5s ease-in-out infinite}.loading-dots span:nth-child(1){animation-delay:0s}.loading-dots span:nth-child(2){animation-delay:.3s}.loading-dots span:nth-child(3){animation-delay:.6s}@keyframes breathe{0%,to{transform:scale(.6);opacity:.4}50%{transform:scale(1.2);opacity:1}}.data-preview{background-color:#f8faff;border-radius:16px;padding:16px;margin-top:4px;border:1px solid #e8edf5}.data-preview h4{margin-bottom:14px;color:#1a73e8;font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}.data-preview h4:before{content:"";width:3px;height:16px;background-color:#1a73e8;border-radius:2px}.data-field{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #eef1f5}.data-field:last-of-type{border-bottom:none}.data-field label{font-weight:500;color:#64748b;font-size:14px}.data-field span{color:#1e293b;font-weight:500;font-size:14px}.data-actions{display:flex;gap:10px;margin-top:16px;padding-top:12px;border-top:1px solid #eef1f5}.btn{flex:1;padding:12px;border:none;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s}.btn-primary{background-color:#1a73e8;color:#fff}.btn-primary:hover{background-color:#1557b0;transform:translateY(-1px);box-shadow:0 4px 12px #1a73e84d}.btn-primary:active{transform:translateY(0)}.btn-secondary{background-color:#f1f3f5;color:#64748b}.btn-secondary:hover{background-color:#e2e6ea}.chat-input{padding:10px 12px;padding-bottom:max(10px,env(safe-area-inset-bottom));background-color:#fff;border-top:1px solid #eef1f5}.input-row{display:flex;align-items:flex-end;gap:8px}.image-preview{position:relative;display:inline-block;margin-bottom:8px}.image-preview img{max-width:72px;max-height:72px;border-radius:10px;border:1.5px solid #e2e8f0}.image-preview button{position:absolute;top:-8px;right:-8px;width:22px;height:22px;border-radius:50%;border:none;background-color:#ef4444;color:#fff;cursor:pointer;font-size:13px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #ef44444d}.input-row textarea{flex:1;padding:10px 16px;border:1.5px solid #e2e8f0;border-radius:22px;resize:none;font-size:15px;outline:none;transition:border-color .2s,box-shadow .2s;line-height:1.5;max-height:80px;background-color:#f8fafc;color:#1e293b}.input-row textarea:focus{border-color:#1a73e8;box-shadow:0 0 0 3px #1a73e814;background-color:#fff}.input-row textarea::placeholder{color:#94a3b8;font-size:14px}.input-actions{display:flex;gap:8px;justify-content:flex-end;padding:0 2px}.action-btn{width:44px;height:44px;border-radius:50%;border:none;background-color:#f1f4f9;color:#64748b;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.action-btn:hover{background-color:#e0e7ff;color:#1a73e8}.action-btn:active{transform:scale(.94)}.action-btn.recording{background-color:#fee2e2;color:#dc2626;animation:pulse-red 1s infinite}@keyframes pulse-red{0%,to{box-shadow:0 0 #dc26264d}50%{box-shadow:0 0 0 8px #dc262600}}.send-btn{width:44px;height:44px;border-radius:50%;border:none;background-color:#1a73e8;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;box-shadow:0 2px 8px #1a73e840;flex-shrink:0}.send-btn:hover{background-color:#1557b0;box-shadow:0 4px 14px #1a73e859}.send-btn:active{transform:scale(.94)}.send-btn:disabled{background-color:#e2e8f0;color:#94a3b8;box-shadow:none;cursor:not-allowed;transform:none}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px}.settings-modal{background:#fff;border-radius:16px;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid #eef1f5}.settings-header h3{font-size:17px;font-weight:600;color:#1e293b}.settings-header .icon-btn{width:32px;height:32px;font-size:14px;background:#f1f3f5}.settings-body{padding:20px}.settings-tabs{display:flex;gap:6px;margin-bottom:20px;background:#f1f4f9;padding:4px;border-radius:10px}.tab-btn{flex:1;padding:8px 12px;border:none;border-radius:8px;font-size:13px;font-weight:500;cursor:pointer;background:transparent;color:#64748b;transition:all .2s}.tab-btn.active{background:#fff;color:#1a73e8;font-weight:600;box-shadow:0 1px 3px #00000014}.config-form{display:flex;flex-direction:column;gap:14px}.config-field{display:flex;flex-direction:column;gap:6px}.config-field label{font-size:13px;font-weight:500;color:#475569}.config-hint{font-weight:400;color:#94a3b8;font-size:12px}.config-field input{padding:10px 14px;border:1.5px solid #e2e6ea;border-radius:10px;font-size:14px;outline:none;transition:border-color .2s;background:#f8fafc}.config-field input:focus{border-color:#1a73e8;background:#fff;box-shadow:0 0 0 3px #1a73e814}.radio-group{display:flex;gap:12px;padding:4px 0}.radio-item{display:flex;align-items:center;gap:6px;cursor:pointer;padding:8px 16px;border:1.5px solid #e2e8f0;border-radius:10px;transition:all .2s;font-size:14px;color:#475569}.radio-item:has(input:checked){border-color:#1a73e8;background:#eef4ff;color:#1a73e8;font-weight:500}.radio-item input[type=radio]{accent-color:#1a73e8;width:16px;height:16px}.config-tip{font-size:12px;color:#94a3b8;margin-top:4px;line-height:1.5}.config-actions{display:flex;align-items:center;gap:12px;margin-top:16px;padding-top:16px;border-top:1px solid #eef1f5}.config-actions .btn{flex:0 1 auto;padding:10px 24px}.config-message{font-size:13px;font-weight:500}.config-message.success{color:#16a34a}.config-message.error{color:#dc2626}.config-status{margin-top:20px;padding-top:16px;border-top:1px solid #eef1f5}.config-status h4{font-size:14px;font-weight:600;color:#475569;margin-bottom:12px}.status-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0}.status-row span:first-child{font-size:13px;color:#64748b}.status-badge{font-size:12px;padding:3px 10px;border-radius:8px;font-weight:500}.status-badge.on{background:#dcfce7;color:#16a34a}.status-badge.off{background:#f1f3f5;color:#94a3b8}.modify-card{background:#fff8f0;border-radius:16px;padding:16px;margin-top:4px;border:1px solid #fde68a}.modify-card h4{margin-bottom:14px;color:#d97706;font-size:15px;font-weight:600;display:flex;align-items:center;gap:6px}.modify-detail{background:#fff;border-radius:10px;padding:4px 0}.modify-summary{background:#eef4ff;color:#1a73e8;font-size:14px;font-weight:500;padding:10px 14px;border-radius:8px;margin-bottom:10px;line-height:1.5}.modify-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid #fef3c7}.modify-row:last-of-type{border-bottom:none}.modify-row label{font-weight:500;color:#92400e;font-size:13px}.modify-row span{color:#1e293b;font-weight:500;font-size:14px}.modify-row .old-value{color:#dc2626;text-decoration:line-through;font-weight:400}.modify-row .new-value{color:#16a34a;font-weight:600}.modify-actions{display:flex;gap:10px;margin-top:16px;padding-top:12px;border-top:1px solid #fde68a}.save-success{display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;color:#16a34a;font-weight:500;font-size:14px}.field-missing{color:#f59e0b;font-size:13px;margin-top:8px;padding:8px 12px;background-color:#fffbeb;border-radius:8px;border:1px solid #fde68a}.idcard-error{font-size:11px;color:#dc2626;background:#fef2f2;padding:2px 6px;border-radius:4px;margin-left:6px;white-space:nowrap}@media (max-width: 480px){.chat-header{padding:14px 16px;font-size:16px}.chat-messages{padding:14px 12px}.message{margin-bottom:16px;gap:8px}.message-content{max-width:82%;padding:10px 14px;font-size:14px}.avatar{width:32px;height:32px;font-size:14px}.chat-input{padding:8px 10px}.input-row textarea{padding:10px 14px;font-size:16px}.action-btn,.send-btn{width:44px;height:44px}}
