*{margin:0;padding:0;box-sizing:border-box}body{font-family:Microsoft YaHei,Arial,sans-serif;background-color:#f5f5f5}.app-container{display:flex;flex-direction:column;height:100vh;overflow:hidden}.top-toolbar{display:flex;align-items:center;justify-content:space-between;background:white;border-bottom:1px solid #ddd;padding:12px 20px;box-shadow:0 2px 4px #0000001a}.toolbar-left{display:flex;align-items:center;gap:20px}.toolbar-left h3{color:#333;font-size:18px}.upload-section{display:flex;align-items:center;gap:10px}.upload-section label{font-size:14px;color:#666;white-space:nowrap}.upload-section input[type=file]{font-size:12px}.toolbar-center{display:flex;align-items:center;gap:20px}.mode-switcher{display:flex;background:#f8f9fa;border-radius:6px;padding:2px}.mode-btn{padding:8px 16px;border:none;background:transparent;border-radius:4px;cursor:pointer;font-size:14px;color:#666;transition:all .2s}.mode-btn.active{background:#007bff;color:#fff;box-shadow:0 2px 4px #007bff4d}.calibrate-controls{display:flex;align-items:center;gap:10px}.distance-input{width:150px;padding:6px 10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.ratio-display{font-size:12px;color:#28a745;font-weight:700}.calculate-controls{display:flex;align-items:center;gap:20px}.draw-controls{display:flex;gap:8px}.draw-btn{padding:8px 16px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:14px;color:#666;transition:all .2s}.draw-btn.active{background:#28a745;color:#fff;border-color:#28a745}.draw-btn:hover{border-color:#007bff;color:#007bff}.draw-btn.active:hover{background:#218838}.type-selector{display:flex;align-items:center;gap:10px}.type-label{font-size:14px;color:#666;white-space:nowrap}.type-buttons{display:flex;gap:4px}.type-btn{width:28px;height:28px;border:2px solid white;border-radius:50%;color:#fff;font-weight:700;font-size:12px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.type-btn:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.type-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.last-type-display{font-size:12px;color:#28a745;white-space:nowrap;font-weight:700}.main-layout{display:flex;flex:1;overflow:hidden;gap:1px;background:#ddd;position:relative}.left-panel{width:320px;min-width:280px;max-width:400px;background:white;display:flex;flex-direction:column;overflow:hidden;box-shadow:2px 0 4px #0000001a;z-index:10}.canvas-area{flex:1;min-width:600px;display:flex;flex-direction:column;background:white}.canvas-container{flex:1;position:relative;overflow:hidden;background:#f8f9fa}.right-panel{width:320px;min-width:280px;max-width:400px;background:white;display:flex;flex-direction:column;overflow:hidden;box-shadow:-2px 0 4px #0000001a;z-index:10}.panel-section{padding:20px;border-bottom:1px solid #eee;flex-shrink:0}.panel-section:last-child{border-bottom:none;flex:1;display:flex;flex-direction:column;overflow:hidden}.panel-section h4{margin-bottom:12px;color:#333;font-size:16px}.type-grid{display:flex;flex-direction:column;gap:8px}.type-card{border:1px solid #e0e0e0;border-radius:6px;padding:10px;background:#fafafa;transition:all .2s}.type-card:hover{border-color:#007bff;background:#f8f9ff}.type-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.type-number{background:#007bff;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.type-name{font-weight:700;color:#333;flex:1}.type-color{width:16px;height:16px;border-radius:3px;border:1px solid #ccc}.type-formula{font-size:12px;color:#666;margin-bottom:2px}.type-description{font-size:11px;color:#999;line-height:1.3}.type-reference{flex:1;overflow-y:auto;padding-right:8px}.type-reference::-webkit-scrollbar{width:6px}.type-reference::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.type-reference::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.type-reference::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.type-ref-item{border:1px solid #e0e0e0;border-radius:8px;padding:12px;margin-bottom:10px;background:#fafafa;font-size:12px;transition:all .2s ease;box-shadow:0 1px 3px #00000014}.type-ref-item:hover{border-color:#007bff;background:white;box-shadow:0 3px 8px #007bff26;transform:translateY(-1px)}.type-ref-header{display:flex;align-items:center;gap:8px;margin-bottom:4px}.type-ref-item .type-number{width:20px;height:20px;font-size:11px;font-weight:700;background:#007bff;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 1px 3px #007bff4d}.type-ref-item .type-name{font-size:13px;font-weight:700;color:#333;flex:1}.type-ref-item .type-color{width:18px;height:18px;border-radius:4px;border:2px solid white;box-shadow:0 0 0 1px #ccc,0 1px 3px #0003}.type-ref-item .type-formula{font-size:11px;color:#666;margin-bottom:3px;font-weight:500;background:#f8f9fa;padding:2px 6px;border-radius:3px;display:inline-block}.type-ref-item .type-description{font-size:11px;color:#777;line-height:1.3}.area-list{overflow-y:auto;padding-right:8px}.area-list::-webkit-scrollbar{width:6px}.area-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.area-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.area-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.area-item{padding:14px;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:10px;cursor:pointer;transition:all .2s ease;background:#fafafa}.area-item:hover{border-color:#007bff;background:white;box-shadow:0 3px 8px #007bff26;transform:translateY(-1px)}.area-item.selected{border-color:#007bff;background:#f8f9ff;box-shadow:0 4px 12px #007bff33;transform:translateY(-1px)}.area-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.area-type{display:flex;align-items:center;gap:8px}.area-color{width:16px;height:16px;border-radius:3px;border:2px solid white;box-shadow:0 0 0 1px #ccc,0 1px 3px #0003}.area-info{font-size:13px;color:#666}.device-count{font-weight:700;color:#28a745;margin-top:2px}.empty-state{text-align:center;color:#999;font-style:italic;padding:20px}.btn{width:100%;padding:10px;margin:5px 0;border:none;border-radius:4px;cursor:pointer;font-size:14px}.btn-primary{background:#007bff;color:#fff}.btn-secondary{background:#6c757d;color:#fff}.btn-success{background:#28a745;color:#fff}.btn:hover{opacity:.8}.btn:disabled{opacity:.5;cursor:not-allowed}.form-group{margin:10px 0}.form-group label{display:block;margin-bottom:5px;font-weight:700}.form-group input{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px}.area-list{overflow-y:auto;border:1px solid #ddd;border-radius:4px;margin:10px 0}.area-item{padding:10px;border-bottom:1px solid #eee;cursor:pointer}.area-item:hover{background:#f8f9fa}.area-item.selected{background:#e3f2fd}.area-header{display:flex;justify-content:space-between;align-items:center}.delete-btn{background:#dc3545;color:#fff;border:none;border-radius:50%;width:20px;height:20px;cursor:pointer;font-size:12px;line-height:1}.delete-btn:hover{background:#c82333}.type-item{display:flex;align-items:center;margin:5px 0;padding:5px;border:1px solid #ddd;border-radius:4px}.type-number{background:#007bff;color:#fff;border-radius:50%;width:20px;height:20px;display:flex;align-items:center;justify-content:center;font-size:12px;margin-right:8px}.type-name{flex:1;font-size:14px}.type-color{width:20px;height:20px;border-radius:4px;border:1px solid #ccc}.konva-container{width:100%;height:100%;background:#f8f9fa}.highlight-text{color:#28a745;font-weight:700;animation:pulse 2s infinite}.warning-text{color:#dc3545;font-weight:700;animation:pulse 2s infinite;background:rgba(220,53,69,.1);padding:4px 8px;border-radius:4px;border:1px solid rgba(220,53,69,.3)}@keyframes pulse{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.last-type-hint{background:#e8f5e8;padding:8px;border-radius:4px;margin-bottom:10px;font-size:12px}.shortcut-hint{color:#666;font-style:italic;margin-left:10px}.status-bar{height:30px;background:#343a40;color:#fff;display:flex;align-items:center;padding:0 15px;font-size:12px}.mode-indicator{margin-right:20px;padding:2px 8px;background:#007bff;border-radius:3px}.area-number{background:#007bff;color:#fff;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;margin-right:8px;box-shadow:0 2px 4px #007bff4d}@media (max-width: 1200px){.left-panel,.right-panel{width:180px;min-width:260px}.canvas-area{min-width:500px}}@media (max-width: 1024px){.main-layout{flex-direction:column}.left-panel,.right-panel{width:100%;max-width:none;min-width:auto}.canvas-area{min-width:auto;flex:1}}@media (max-width: 768px){.top-toolbar{flex-direction:column;gap:10px;padding:10px}.toolbar-left,.toolbar-center,.toolbar-right{width:100%;justify-content:center}.left-panel,.right-panel{height:150px}.panel-section{padding:15px}}.left-panel,.right-panel{resize:horizontal;overflow:auto}.status-bar{height:32px;background:linear-gradient(135deg,#343a40 0%,#495057 100%);color:#fff;display:flex;align-items:center;padding:0 20px;font-size:13px;gap:20px;box-shadow:0 -1px 3px #0000001a}.mode-indicator{padding:4px 10px;background:rgba(0,123,255,.8);border-radius:4px;font-weight:500;box-shadow:0 1px 3px #0003}.empty-state{text-align:center;color:#999;font-style:italic;padding:40px 20px;background:#f8f9fa;border-radius:8px;margin:10px 0;border:2px dashed #ddd}.btn{padding:10px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.btn:hover{transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.btn:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.btn-success{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#218838 0%,#1ea080 100%)}.btn-primary{background:linear-gradient(135deg,#007bff 0%,#0056b3 100%);color:#fff}.btn-primary:hover{background:linear-gradient(135deg,#0056b3 0%,#004085 100%)}.left-panel-toggle,.right-panel-toggle{position:fixed;top:50%;transform:translateY(-50%);width:24px;height:60px;background:#007bff;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:1000;transition:all .3s ease;box-shadow:0 2px 8px #007bff4d;overflow:visible}.left-panel-toggle{border-radius:0 8px 8px 0}.right-panel-toggle{border-radius:8px 0 0 8px}.left-panel-toggle:hover,.right-panel-toggle:hover{background:#0056b3;box-shadow:0 4px 12px #007bff66;transform:translateY(-50%);width:26px;height:64px}.toggle-icon{color:#fff;font-size:14px;font-weight:700;-webkit-user-select:none;user-select:none;transition:font-size .3s ease}.left-panel-toggle:hover .toggle-icon,.right-panel-toggle:hover .toggle-icon{font-size:16px}.toolbar-right{display:flex;align-items:center;gap:10px}.base-station-btn{background:linear-gradient(135deg,#ff6b35 0%,#f7931e 100%);color:#fff;border:1px solid #ff6b35}.base-station-btn.active{background:linear-gradient(135deg,#e55a2b 0%,#d4821a 100%);box-shadow:0 2px 8px #ff6b3566}.base-station-btn:hover{background:linear-gradient(135deg,#e55a2b 0%,#d4821a 100%);border-color:#e55a2b;color:#fff}/ * 基站和信标列表样式 */ .station-list,.beacon-list{margin:10px 0}.station-item,.beacon-item{padding:10px;border-bottom:1px solid #eee;background:#f8f9fa;margin-bottom:5px;border-radius:4px}.station-item:hover,.beacon-item:hover{background:#e9ecef}.station-header,.beacon-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:5px}.station-info,.beacon-info{display:flex;align-items:center;gap:8px}.station-icon,.beacon-icon{font-size:16px}.station-position,.beacon-position{font-size:12px;color:#666}.station-item{border-left:4px solid #0096ff}.beacon-item{border-left:4px solid #FF6B35}
