:root{font-family:Microsoft YaHei,Hiragino Sans GB,WenQuanYi Micro Hei,sans-serif;line-height:1.6;font-weight:400;color-scheme:light dark;color:#000000de;background-color:#f5f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;--primary-color: #4a69bd;--primary-dark: #0c2461;--accent-color: #63b3ed;--text-color: rgba(0, 0, 0, .87);--background-color: #f5f7fa;--card-background: #ffffff;--shadow-sm: 0 2px 5px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .12);--border-radius: 12px}.dark-mode{--text-color: #e2e8f0;--background-color: #121212;--card-background: #2d3748;--primary-color: #63b3ed;--primary-dark: #90cdf4;--shadow-sm: 0 2px 5px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .3)}*{box-sizing:border-box;margin:0;padding:0}a{color:var(--primary-color);text-decoration:none;transition:color .2s ease}a:hover{color:var(--primary-dark)}body{margin:0;padding:0;min-width:320px;min-height:100vh;overflow-x:hidden}#root{width:100%;min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2}button{background:none;border:none;cursor:pointer}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 1rem}.text-center{text-align:center}.flex{display:flex}.flex-column{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.mt-2{margin-top:1rem}.mb-2{margin-bottom:1rem}.navbar{background-color:#fff;box-shadow:0 2px 10px #0000001a;padding:.8rem 1rem;position:sticky;top:0;z-index:100;transition:all .3s ease}.navbar.dark{background-color:#1a202c}.navbar-container{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto}.navbar-logo{font-size:1.5rem;font-weight:700;color:var(--primary-color);text-decoration:none}.navbar-menu{display:flex;gap:1.5rem}.navbar-menu a{color:#4a5568;text-decoration:none;font-weight:500;padding:.5rem;border-radius:4px;transition:all .2s ease}.navbar.dark .navbar-menu a{color:#e2e8f0}.navbar-menu a:hover{color:var(--primary-color)}.navbar-menu a.active{color:var(--primary-color);font-weight:600;position:relative}.navbar-menu a.active:after{content:"";position:absolute;bottom:-3px;left:0;width:100%;height:2px;background-color:var(--primary-color);border-radius:1px}.theme-toggle{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.4rem;border-radius:50%;display:flex;justify-content:center;align-items:center;transition:all .3s ease}.theme-toggle:hover{background-color:#f1f5f9}.theme-toggle.dark:hover{background-color:#2d3748}@media (max-width: 768px){.navbar-container{flex-direction:column;gap:1rem}.navbar-menu{width:100%;justify-content:center;flex-wrap:wrap;gap:1rem}}.dashboard{padding:1rem;max-width:1200px;margin:0 auto}.dashboard-title{text-align:center;font-size:1.8rem;margin-bottom:2rem;color:#2c3e50}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.sensor-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000014;transition:transform .3s ease,box-shadow .3s ease}.sensor-card:hover{transform:translateY(-5px);box-shadow:0 8px 16px #0000001f}.sensor-card h3{font-size:1.1rem;margin-top:0;margin-bottom:1rem;color:#4a69bd;text-align:center}.sensor-values{display:flex;flex-direction:column;gap:.8rem}.sensor-value{font-size:1.2rem;font-weight:500;text-align:center}.sensor-value.temp{font-size:2rem;font-weight:600}.axis{font-weight:700;margin-right:.5rem}.x-axis{color:#4a69bd}.y-axis{color:#6ab04c}.z-axis{color:#eb3b5a}.charts-container{display:flex;flex-direction:column;gap:2rem}.chart{background:#fff;border-radius:12px;padding:1.2rem;box-shadow:0 4px 12px #00000014}.connection-panel{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000014;margin-bottom:1.5rem}.connection-form{display:flex;gap:1rem;margin-bottom:1rem}.connection-form input{flex:1;padding:.75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:1rem}.connect-button,.disconnect-button{padding:.75rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:background-color .3s ease;border:none;color:#fff}.connect-button{background-color:#4a69bd}.connect-button:hover{background-color:#3c5aa9}.connect-button.connecting{background-color:#a0aec0;cursor:not-allowed}.disconnect-button{background-color:#e53e3e}.disconnect-button:hover{background-color:#c53030}.connection-error{color:#e53e3e;margin:.5rem 0;font-weight:500}.connection-status{font-size:.9rem;color:#4a5568}.status-connected{color:#48bb78;font-weight:600}.status-disconnected{color:#a0aec0;font-weight:600}@media (max-width: 768px){.dashboard-cards{grid-template-columns:1fr}}.dark-mode .dashboard-title{color:#e2e8f0}.dark-mode .sensor-card{background:#2d3748;color:#e2e8f0}.dark-mode .sensor-card h3{color:#63b3ed}.dark-mode .chart,.dark-mode .connection-panel{background:#2d3748}.dark-mode .connection-form input{background:#1a202c;border-color:#4a5568;color:#e2e8f0}.dark-mode .connection-status{color:#e2e8f0}.motor-control-panel{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 4px 12px #00000014;margin-bottom:1.5rem}.motor-control-panel h3{text-align:center;margin-bottom:1rem;color:#4a69bd}.motor-controls{display:flex;flex-direction:column;align-items:center;gap:1rem}.motor-controls-row{display:flex;gap:1rem}.control-button{padding:1rem 2rem;border:none;border-radius:8px;background-color:#4a69bd;color:#fff;font-weight:600;cursor:pointer;transition:all .3s ease}.control-button:hover:not(:disabled){background-color:#3c5aa9;transform:translateY(-2px)}.control-button:disabled{background-color:#a0aec0;cursor:not-allowed}.control-button.stop{background-color:#e53e3e}.control-button.stop:hover:not(:disabled){background-color:#c53030}.motor-speeds{display:flex;justify-content:space-around;margin-top:1rem;font-weight:500}.dark-mode .motor-control-panel{background:#2d3748;color:#e2e8f0}.dark-mode .motor-control-panel h3{color:#63b3ed}.charts-toggle-button{margin:1rem 0;padding:.5rem 1rem;background-color:#4a69bd;color:#fff;border:none;border-radius:4px;cursor:pointer}.charts-toggle-button:hover{background-color:#3c559c}.speed-control{margin:1rem 0;display:flex;flex-direction:column;gap:.5rem}.speed-control input[type=range]{width:100%;max-width:300px}.speed-control label{font-size:.9rem;color:#666}.switch{position:relative;display:inline-block;width:60px;height:34px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.4s;border-radius:34px}.slider:before{position:absolute;content:"";height:26px;width:26px;left:4px;bottom:4px;background-color:#fff;transition:.4s;border-radius:50%}input:checked+.slider{background-color:#4a69bd}input:checked+.slider:before{transform:translate(26px)}.chart-control{display:flex;align-items:center;gap:1rem;margin:1rem 0;padding:1rem;background-color:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a}.chart-control label{font-size:1rem;color:#2d3748}.chart-control.center{justify-content:center;margin:1.5rem auto;max-width:300px}.speed-controls{display:flex;gap:2rem;margin:1rem 0}.speed-control{flex:1}.speed-value{text-align:center;font-weight:700;color:#4a69bd;margin-top:.5rem}.ip-page{padding:1rem;max-width:900px;margin:0 auto;animation:fadeIn .4s ease-out forwards}.ip-title{text-align:center;font-size:1.8rem;margin-bottom:2rem;color:#2c3e50}.ip-content{background-color:#fff;border-radius:12px;padding:2rem;box-shadow:0 4px 12px #00000014}.ip-details{display:grid;grid-template-columns:1fr;gap:1rem}.ip-details p{display:flex;justify-content:space-between;padding:1rem;background-color:#f8f9fa;border-radius:8px;margin:0;transition:transform .2s ease,background-color .2s ease}.ip-details p:hover{transform:translate(5px);background-color:#edf2f7}.ip-details strong{color:#4a69bd;font-weight:600}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem;border-radius:8px}.dark-mode .ip-title{color:#e2e8f0}.dark-mode .ip-content{background-color:#2d3748;color:#e2e8f0}.dark-mode .ip-details p{background-color:#1a202c}.dark-mode .ip-details p:hover{background-color:#2d3748}.dark-mode .ip-details strong{color:#63b3ed}.dark-mode .loading{background-color:#2d3748;color:#e2e8f0}@media (min-width: 768px){.ip-details{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.ip-content{padding:1.5rem}.ip-details p{flex-direction:column;gap:.5rem}}.camera-container{display:flex;flex-direction:column;align-items:center;max-width:100%;margin:0 auto;padding:1rem;background-color:var(--card-background);border-radius:var(--border-radius);box-shadow:var(--shadow-md)}.camera-container h2{margin-bottom:1.5rem;color:var(--text-color)}.video-wrapper{position:relative;width:100%;max-width:640px;margin-bottom:1.5rem;border-radius:8px;overflow:hidden;box-shadow:var(--shadow-sm)}video,canvas{width:100%;max-width:640px;height:auto;display:block;background-color:#000}.controls{width:100%;max-width:640px;display:flex;flex-wrap:wrap;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.control-group{flex:1;min-width:250px}.control-group h3{margin-bottom:.5rem;font-size:1rem;color:var(--text-color)}.effect-buttons{display:flex;flex-wrap:wrap;gap:.5rem}.effect-buttons button{padding:.5rem 1rem;background-color:var(--background-color);color:var(--text-color);border:2px solid var(--primary-color);border-radius:var(--border-radius);font-weight:600;cursor:pointer;transition:all .2s ease}.effect-buttons button:hover,.effect-buttons button.active{background-color:var(--primary-color);color:#fff}.effect-buttons button:disabled{opacity:.5;cursor:not-allowed}.settings{padding:.5rem;background-color:var(--background-color);border-radius:var(--border-radius)}.settings label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px}.loading-spinner{width:40px;height:40px;border:4px solid rgba(0,0,0,.1);border-left-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.info{width:100%;max-width:640px;margin-top:1rem;padding:1rem;background-color:var(--background-color);border-left:4px solid var(--primary-color);border-radius:var(--border-radius)}.info p{margin:0;font-size:.9rem;color:var(--text-color)}.info p.warning{color:#e53e3e;margin-top:.5rem;font-weight:600}.warning button{margin-left:10px;padding:2px 8px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:.8rem}@keyframes spin{to{transform:rotate(360deg)}}.dark-mode .loading-spinner{border:4px solid rgba(255,255,255,.1);border-left-color:var(--primary-color)}@media (max-width: 768px){.controls{flex-direction:column}.video-wrapper{margin-bottom:1rem}.effect-buttons{flex-direction:column}}.app-container.dark-mode{background-color:#121212;color:#e2e8f0}.main-content{flex:1;padding:1rem 0;animation:fadeIn .4s ease-out forwards}.dark-mode footer{background-color:#1a202c;color:#e2e8f0;box-shadow:0 -2px 10px #0003}.chat-container{margin:0 auto}.messages-container{height:70vh;overflow-y:auto;border:1px solid #ccc;padding:20px;margin-bottom:20px;margin-left:40px;border-radius:8px;background-color:#fff;display:flow-root}.message{padding:10px 10px 40px;border-radius:8px;display:inline-block;max-width:70%;position:relative;margin-bottom:35px}.message.user{background-color:#f4f4f4;float:right;text-align:left;clear:both}.message.assistant{background-color:#fff;float:left;text-align:left;clear:both}.input-form{display:flex;gap:10px}.input-form input{flex:1;padding:10px;border:1px solid #ccc;border-radius:4px}.input-form button{padding:10px 20px;background-color:#1976d2;color:#fff;border:none;border-radius:4px;cursor:pointer}.input-form button:disabled{background-color:#ccc}.markdown-table{border-collapse:collapse;margin:1em 0;width:100%}.markdown-table th,.markdown-table td{border:1px solid #ddd;padding:8px;text-align:left}.markdown-table th{background-color:#f5f5f5}.code-block-wrapper{position:relative;margin:1em 0}.copy-button{position:absolute;top:5px;right:5px;padding:4px 8px;background-color:#444;color:#fff;border:none;border-radius:4px;cursor:pointer;opacity:.7;transition:opacity .2s}.copy-button:hover{opacity:1}.model-selector{margin-bottom:1rem;padding:.5rem}.model-selector select{padding:.5rem;border-radius:4px;border:1px solid #ccc}.thinking-box{background-color:#f0f0f0;border-left:3px solid #007bff;padding:.5rem;margin:.5rem 0;border-radius:4px}.chat-container{max-width:100%;box-sizing:border-box}.messages-container{margin:0;padding:10px}.input-form{position:fixed;bottom:0;left:0;right:0;padding:10px;background:#fff;display:flex;gap:8px}.input-form input{flex:1;min-width:0}.clear-button{margin-left:10px;padding:5px 10px;border-radius:4px}.copy-message{position:absolute;right:10px;bottom:40px;top:auto;padding:4px 8px;border-radius:4px;opacity:0;transition:opacity .2s;background-color:#f0f0f0;border:1px solid #ddd}.copy-message-container{position:absolute;bottom:-30px;right:0;width:100%;text-align:right}.copy-message:hover{background-color:#e0e0e0}.copy-message.success{background-color:#4caf50;color:#fff;border-color:#43a047}.message:hover .copy-message{opacity:1}.copy-button.success,.copy-message.success{background-color:#4caf50;color:#fff}.message{position:relative}.thinking-header{font-weight:700;margin-bottom:8px;color:#666}.thinking-content{color:#444;line-height:1.5}@media (max-width: 768px){.messages-container{margin-bottom:60px;padding:5px}.input-form{padding:8px}.message{margin-bottom:10px;padding:10px;border-radius:8px;display:inline-block;max-width:100%}}#root{margin:0 auto;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}.app-container{max-width:100%;width:100%;min-height:100vh;display:flex;flex-direction:column;overflow-x:hidden;background-color:#f5f7fa;transition:background-color .3s ease,color .3s ease}header{padding:2rem 1rem;background-color:#4a69bd;background-image:linear-gradient(to right,#4a69bd,#0c2461);color:#fff;text-align:center;box-shadow:0 4px 12px #0000001a}header h1{margin:0;font-size:2.5rem;font-weight:700;letter-spacing:1px;text-shadow:0 1px 3px rgba(0,0,0,.15)}.content{flex:1;display:flex;flex-direction:column;padding:3rem 1.5rem;align-items:center;justify-content:center}.map-container{width:100%;height:400px;border-radius:8px;overflow:hidden;box-shadow:0 4px 6px #0000001a}.controls{display:flex;justify-content:center;margin:1rem 0}.locate-button{padding:.75rem 1.5rem;background-color:#3498db;color:#fff;border:none;border-radius:4px;font-weight:600;cursor:pointer;transition:background-color .3s ease}.locate-button:hover{background-color:#2980b9}.locate-button.active{background-color:#95a5a6;cursor:not-allowed}.ip-info-container{background-color:#fff;border-radius:16px;padding:2.5rem;box-shadow:0 10px 30px #0000001f;width:100%;max-width:700px;transition:transform .3s ease,box-shadow .3s ease;position:relative;overflow:hidden}.ip-info-container:hover{transform:translateY(-5px);box-shadow:0 15px 35px #00000026}.ip-info-container:before{content:"";position:absolute;top:0;left:0;width:100%;height:5px;background-image:linear-gradient(to right,#4a69bd,#0c2461)}.ip-info-container h2{margin-top:0;margin-bottom:2rem;color:#2c3e50;font-size:2rem;text-align:center;font-weight:700;position:relative;padding-bottom:12px}.ip-info-container h2:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:60px;height:4px;background-color:#4a69bd;border-radius:2px}.ip-details{padding:1rem;animation:fadeIn .5s ease-out forwards}.ip-details p{margin:1.2rem 0;font-size:1.2rem;padding:1rem 1.2rem;border:none;border-radius:8px;background-color:#f8f9fa;display:flex;justify-content:space-between;transition:all .2s ease}.ip-details p:hover{background-color:#edf2f7;transform:translate(5px)}.ip-details strong{color:#4a69bd;font-weight:600;margin-right:10px}.ip-content{width:100%}.loading,.error{text-align:center;padding:2rem;font-size:1.2rem;border-radius:8px;margin:1rem 0}.loading{background-color:#edf2f7;color:#4a5568}.error{background-color:#fee2e2;color:#e53e3e}footer{background-color:#fff;color:#4a5568;text-align:center;padding:1.2rem;margin-top:auto;box-shadow:0 -2px 10px #0000000d;transition:background-color .3s ease,color .3s ease}footer p{margin:0;font-size:.9rem;font-weight:500;letter-spacing:.5px}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.content{padding:2rem 1rem}.ip-details{grid-template-columns:1fr}.map-container{height:300px}.ip-info-container{padding:1.8rem 1.2rem}.ip-details p{flex-direction:column;padding:.8rem}.ip-details strong{margin-bottom:.3rem}header h1{font-size:2rem}.main-content{padding:.5rem 0}}@media (prefers-color-scheme: dark){.app-container{background:linear-gradient(135deg,#1a202c,#2d3748)}.ip-info-container{background-color:#2d3748;color:#e2e8f0}.ip-info-container h2{color:#e2e8f0}.ip-details p{background-color:#1a202c;border:1px solid #4a5568}.ip-details p:hover{background-color:#2d3748}.loading{background-color:#2d3748;color:#e2e8f0}.ip-details strong{color:#63b3ed}}
