.header{background:var(--color-surface);z-index:100;justify-content:space-between;align-items:center;height:50px;padding:0 20px;display:flex;position:relative;overflow:hidden;box-shadow:0 2px 8px #0000001a}.header:before{content:"";opacity:.6;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 80'%3E%3Cpath d='M20,40 L60,30 L100,40 L140,30 L180,40 L180,50 L140,45 L100,50 L60,45 L20,50 Z' fill='rgba(128,128,128,0.05)'/%3E%3Cellipse cx='100' cy='40' rx='30' ry='8' fill='rgba(128,128,128,0.08)'/%3E%3Cpath d='M70,40 L80,35 L100,40 L120,35 L130,40' stroke='rgba(128,128,128,0.1)' stroke-width='2' fill='none'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:contain;width:200px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.header-left,.header-right{z-index:1;align-items:center;gap:20px;display:flex}.header-center{z-index:1;position:absolute;left:50%;transform:translate(-50%)}.project-title{color:var(--color-text);letter-spacing:2px;font-size:28px;font-weight:600}.header-widget{color:var(--color-text);background:0 0;border-radius:20px;align-items:center;gap:8px;padding:8px 16px;font-size:14px;display:flex}.theme-toggle{color:var(--color-text);cursor:pointer;background:0 0;border:none;border-radius:20px;padding:8px 12px;font-size:18px;transition:background .3s}.theme-toggle:hover{background:#8080801a}@media (width<=768px){.header{padding:0 12px}.project-title{letter-spacing:1px;font-size:16px}.header-left,.header-right{gap:8px}.header-widget{gap:4px;padding:6px 10px;font-size:12px}.weather-widget span:not(:first-child):not(.weather-temp),.user-widget .user-name{display:none}.theme-toggle{padding:6px 8px;font-size:16px}}@media (width<=480px){.project-title{font-size:14px}.header-widget{padding:4px 8px;font-size:11px}}.main-layout{flex-direction:column;width:100%;height:100%;display:flex;position:relative}.scene-container{flex:1;position:relative;overflow:hidden}.scene-canvas{width:100%;height:100%}.scene-controls{z-index:10;gap:8px;display:flex;position:absolute;bottom:30px;left:50%;transform:translate(-50%)}.control-button{background:var(--color-surface);width:40px;height:40px;color:var(--color-text);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex;box-shadow:0 2px 8px #00000026}.control-button:hover{background:var(--color-surface);transform:scale(1.1);box-shadow:0 4px 12px #0003}.control-button:active{transform:scale(.95)}.detail-card{z-index:50;background:#fffffff2;border-radius:8px;width:200px;font-size:12px;position:absolute;overflow:hidden;box-shadow:0 4px 16px #0003}.card-header{background:#f5f5f5;border-bottom:1px solid #e0e0e0;justify-content:space-between;align-items:flex-start;padding:12px;display:flex}.card-title-section{flex:1}.card-equipment-type{color:#333;margin-bottom:2px;font-size:14px;font-weight:600}.card-equipment-id{color:#666;font-size:11px}.card-close{color:#999;cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;padding:0;font-size:20px;transition:all .2s;display:flex}.card-close:hover{color:#333;background:#0000000d}.card-content{padding:12px}.card-readings{margin-bottom:12px}.reading-row{border-bottom:1px solid #f0f0f0;justify-content:space-between;align-items:center;padding:6px 0;display:flex}.reading-row:last-child{border-bottom:none}.reading-label{color:#666;font-size:12px}.reading-value{color:#333;font-size:13px;font-weight:600}.card-alert{text-align:center;border-top:1px solid #e0e0e0;padding-top:8px}.detail-button{color:#1976d2;cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:12px;transition:color .2s}.detail-button:hover{color:#1565c0;text-decoration:underline}.console-controls{z-index:100;flex-direction:column;gap:8px;display:flex;position:absolute;top:20px;right:20px}.console-control-button{cursor:pointer;color:var(--color-text);background:0 0;border:none;flex-direction:column;align-items:center;gap:6px;padding:0;transition:all .2s;display:flex}.console-control-button svg{width:48px;height:48px;color:var(--color-textSecondary);background:#fff;border-radius:50%;padding:12px;transition:all .2s}.console-control-button:hover svg{transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.console-control-button.active svg{background:var(--color-primary);color:#fff}.console-control-button.active:hover svg{box-shadow:0 4px 12px #1976d24d}.console-control-label{color:var(--color-textSecondary);font-size:12px}.console-card{background:var(--color-surface);border:1px solid var(--color-border);z-index:1000;border-radius:12px;width:360px;max-height:calc(100vh - 140px);animation:.3s slideIn;position:absolute;top:100px;right:100px;overflow:hidden;box-shadow:0 8px 32px #0000001a}.console-card .card-header{background:var(--color-surface);color:var(--color-text);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:20px;display:flex}.console-card .card-close{color:var(--color-textSecondary);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;padding:0;font-size:24px;transition:background .2s;display:flex}.console-card .card-close:hover{background:var(--color-background)}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.console-section{border-bottom:1px solid var(--color-border);padding:16px}.console-mode{align-items:center;gap:12px;display:flex}.mode-label{color:var(--color-textSecondary);font-size:14px}.mode-value{color:var(--color-text);font-size:14px}.mode-toggle{background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;border-radius:6px;margin-left:auto;padding:6px 16px;font-size:13px;transition:all .2s}.mode-toggle:hover{background:var(--color-border)}.console-item{background:var(--color-background);cursor:pointer;border-radius:8px;margin-bottom:12px;padding:16px;transition:all .2s}.console-item:hover{background:var(--color-border)}.console-item:last-child{margin-bottom:0}.console-item-header{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.console-item-title{color:var(--color-text);font-size:15px;font-weight:500}.console-item-stats{color:var(--color-textSecondary);gap:24px;font-size:13px;display:flex}@media (width<=768px){.console-controls{top:10px;right:10px}.console-control-button svg{width:40px;height:40px;padding:10px}.console-control-label{font-size:11px}.console-card{width:auto;max-height:calc(100vh - 90px);top:70px;left:10px;right:10px}.console-card .card-header{padding:16px}.console-card .card-title{font-size:16px}.console-section{padding:12px}.console-mode{flex-wrap:wrap;gap:8px}.mode-toggle{padding:6px 12px;font-size:12px}.console-item{margin-bottom:10px;padding:12px}.console-item-title{font-size:14px}.console-item-stats{gap:16px;font-size:12px}}@media (width<=480px){.console-card{max-height:calc(100vh - 70px);top:60px}.console-card .card-title{font-size:14px}.console-item-stats{gap:12px;font-size:11px}}:root{--color-background:#f5f5f5;--color-surface:#fff;--color-text:#212121;--color-textSecondary:#757575;--color-border:#e0e0e0;--color-primary:#1976d2;--color-accent:#2196f3;--color-scene-background:#d5dde4;--color-grid-primary:#ccc;--color-grid-secondary:#ccc}[data-theme=dark]{--color-background:#0a0a0a;--color-surface:#1a1a1a;--color-text:#fff;--color-textSecondary:#b0b0b0;--color-border:#333;--color-primary:#90caf9;--color-accent:#64b5f6}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;overflow:hidden}body{background-color:var(--color-background);color:var(--color-text);transition:background-color .3s,color .3s}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-surface)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-textSecondary)}
