*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background-color:#f5f5f5;color:#333}.container{max-width:1200px;margin:0 auto;padding:20px}.layout{display:flex;min-height:100vh}.sidebar{width:250px;background-color:#1a1a2e;color:#fff;padding:20px}.sidebar h2{margin-bottom:30px;font-size:1.2rem}.sidebar-nav{list-style:none}.sidebar-nav li{margin-bottom:10px}.sidebar-nav a,.sidebar-nav button{display:block;width:100%;padding:12px 15px;color:#ccc;text-decoration:none;border-radius:8px;transition:all .2s;background:none;border:none;text-align:left;font-size:1rem;cursor:pointer}.sidebar-nav a:hover,.sidebar-nav button:hover,.sidebar-nav a.active{background-color:#16213e;color:#fff}.main-content{flex:1;padding:30px;overflow-y:auto}.card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:1.25rem;font-weight:600}.feature-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px}.feature-card{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 8px #0000001a;cursor:pointer;transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.feature-card-icon{font-size:2.5rem;margin-bottom:15px}.feature-card-title{font-size:1.1rem;font-weight:600;margin-bottom:8px}.feature-card-desc{color:#666;font-size:.9rem}.btn{padding:10px 20px;border-radius:8px;border:none;cursor:pointer;font-size:1rem;transition:all .2s}.btn-primary{background-color:#4361ee;color:#fff}.btn-primary:hover{background-color:#3651d4}.btn-secondary{background-color:#e0e0e0;color:#333}.btn-danger{background-color:#dc3545;color:#fff}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500}.form-group input,.form-group select,.form-group textarea{width:100%;padding:12px;border:1px solid #ddd;border-radius:8px;font-size:1rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:#4361ee}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e)}.login-box{background:#fff;padding:40px;border-radius:12px;width:100%;max-width:400px;box-shadow:0 4px 20px #0003}.login-box h1{text-align:center;margin-bottom:30px;color:#1a1a2e}.login-error{background-color:#fee2e2;color:#dc2626;padding:12px;border-radius:8px;margin-bottom:20px}table{width:100%;border-collapse:collapse}th,td{padding:12px;text-align:left;border-bottom:1px solid #eee}th{background-color:#f9f9f9;font-weight:600}.map-builder{display:grid;grid-template-columns:1fr 300px;grid-template-rows:auto 1fr;gap:20px;height:calc(100vh - 150px);min-height:600px}.map-builder>div:first-child{grid-column:1 / -1}.map-canvas-container{background:#fff;border-radius:12px;padding:20px;overflow:hidden;position:relative;display:flex;flex-direction:column;min-height:400px;box-shadow:0 2px 8px #0000001a}.map-canvas{flex:1;width:100%;min-height:350px;position:relative;background-color:#f0f0f0;border-radius:8px;overflow:auto}.map-background{display:block}.section-overlay{position:absolute;border:2px dashed rgba(67,97,238,.5);background-color:#4361ee1a;cursor:pointer;transition:all .2s}.section-overlay:hover{background-color:#4361ee33;border-style:solid}.section-overlay.selected{border-color:#4361ee;background-color:#4361ee4d}.site-marker{position:absolute;width:24px;height:24px;background-color:#4361ee;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;font-size:.7rem;font-weight:700}.map-sidebar{background:#fff;border-radius:12px;padding:20px;overflow-y:auto}.map-sidebar h3{margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}.tool-button{display:flex;align-items:center;gap:10px;width:100%;padding:12px;margin-bottom:8px;background:#f5f5f5;border:1px solid #ddd;border-radius:8px;cursor:pointer;transition:all .2s}.tool-button:hover{background:#e8e8e8}.tool-button.active{background:#4361ee;color:#fff;border-color:#4361ee}.section-list,.site-list{margin-top:20px}.section-item,.site-item{padding:10px;background:#f9f9f9;border-radius:8px;margin-bottom:8px;cursor:pointer}.section-item:hover,.site-item:hover{background:#f0f0f0}
