*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;height:100vh;overflow:hidden;background-color:#f5f5f5}.app-container{display:flex;flex-direction:column;height:100vh}.header{background:linear-gradient(135deg,#d32f2f,#f44336);color:#fff;padding:10px 20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 4px #0000001a;z-index:1000}.header-left{display:flex;align-items:center;gap:15px}.logo{height:50px;width:auto;background:#fff;padding:5px;border-radius:8px}.header h1{font-size:24px;font-weight:600}.header-right{display:flex;gap:10px}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:all .2s ease}.btn-primary{background:#2196f3;color:#fff}.btn-primary:hover{background:#1976d2;transform:translateY(-1px)}.btn-secondary{background:#757575;color:#fff}.btn-secondary:hover{background:#616161;transform:translateY(-1px)}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover{background:#d32f2f;transform:translateY(-1px)}.main-content{display:flex;flex:1;height:calc(100vh - 70px)}.sidebar{width:300px;background:#fff;border-right:1px solid #e0e0e0;display:flex;flex-direction:column;box-shadow:0 2px 8px #0000001a}.left-sidebar{border-right:1px solid #e0e0e0}.right-sidebar{border-left:1px solid #e0e0e0}.sidebar-header{padding:20px;border-bottom:1px solid #e0e0e0;background:#fafafa}.sidebar-header h3{margin-bottom:15px;color:#333;font-size:18px}.search-input{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:14px}.search-input:focus{outline:none;border-color:#2196f3;box-shadow:0 0 0 2px #2196f333}.symbol-categories{flex:1;overflow-y:auto;padding:10px}.category{margin-bottom:20px}.category-header{background:#f0f0f0;padding:12px;cursor:pointer;border-radius:6px;font-weight:600;color:#333;display:flex;justify-content:space-between;align-items:center;transition:background .2s ease}.category-header:hover{background:#e8e8e8}.category-header.active{background:#2196f3;color:#fff}.category-symbols{display:none;padding:10px 0;display:grid;grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:8px}.category.active .category-symbols{display:grid}.symbol-item{width:60px;height:60px;border:2px solid #e0e0e0;border-radius:8px;cursor:grab;display:flex;align-items:center;justify-content:center;background:#fff;transition:all .2s ease;position:relative;overflow:hidden}.symbol-item:hover{border-color:#2196f3;transform:scale(1.05);box-shadow:0 4px 12px #00000026}.symbol-item:active{cursor:grabbing}.symbol-item img{max-width:40px;max-height:40px;object-fit:contain}.map-container{flex:1;position:relative;display:flex;flex-direction:column}.map{flex:1;z-index:1}.map-controls{position:absolute;top:10px;right:10px;z-index:1000}.tool-section{padding:20px;border-bottom:1px solid #e0e0e0}.tool-section h4{margin-bottom:15px;color:#333;font-size:16px}.tool-buttons{display:grid;grid-template-columns:1fr 1fr;gap:8px}.tool-btn{padding:10px;border:2px solid #e0e0e0;background:#fff;border-radius:6px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s ease}.tool-btn:hover{border-color:#2196f3;background:#f3f9ff}.tool-btn.active{border-color:#2196f3;background:#2196f3;color:#fff}.property-controls{display:flex;flex-direction:column;gap:15px}.property-controls label{font-size:14px;font-weight:500;color:#333}.property-controls input[type=color]{width:100%;height:40px;border:none;border-radius:6px;cursor:pointer}.property-controls input[type=range]{width:100%}.property-controls input[type=checkbox]{margin-right:8px}.modal{display:none;position:fixed;z-index:2000;left:0;top:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background-color:#fff;margin:15% auto;padding:30px;border-radius:12px;width:400px;box-shadow:0 8px 32px #0003}.modal-content h3{margin-bottom:20px;color:#333}.modal-content input{width:100%;padding:12px;border:1px solid #ddd;border-radius:6px;font-size:14px;margin-bottom:20px}.modal-buttons{display:flex;gap:10px;justify-content:flex-end}.leaflet-control-layers{background:#fff;border-radius:8px;box-shadow:0 2px 8px #00000026}.leaflet-popup-content-wrapper{border-radius:8px;box-shadow:0 4px 16px #0003}.placed-symbol{cursor:pointer;transition:all .2s ease;border:2px solid transparent;border-radius:4px}.placed-symbol:hover{border-color:#2196f3;box-shadow:0 2px 8px #2196f34d}.placed-symbol.selected{border-color:#ff9800;box-shadow:0 2px 8px #ff980080}@media (max-width: 1200px){.sidebar{width:250px}}@media (max-width: 768px){.main-content{flex-direction:column}.sidebar{width:100%;height:200px}.header-left h1{font-size:18px}.logo{height:40px}}.fade-in{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.bounce{animation:bounce .5s ease}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a8a8a8}
