body{font-family:'Arial',sans-serif;margin:0;padding:20px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;color:#333;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-touch-callout:none;-webkit-tap-highlight-color:transparent}.container{max-width:900px;margin:0 auto;background:rgba(255,255,255,0.95);border-radius:15px;padding:20px;box-shadow:0 10px 30px rgba(0,0,0,0.3)}h1{text-align:center;color:#2c3e50;margin-bottom:20px;font-size:2.5em;text-shadow:2px 2px 4px rgba(0,0,0,0.1)}.info-panel{background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;padding:15px;margin-bottom:20px}.info-panel p{margin:5px 0;font-size:14px}.controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:10px}button{background:linear-gradient(45deg,#3498db,#2980b9);color:white;border:0;padding:10px 20px;border-radius:5px;cursor:pointer;font-size:14px;transition:all .3s ease;box-shadow:0 4px 8px rgba(0,0,0,0.2)}button:hover{transform:translateY(-2px);box-shadow:0 6px 12px rgba(0,0,0,0.3)}button:active{transform:translateY(0)}#connectionCounter{background:#34495e;color:white;padding:8px 15px;border-radius:20px;font-weight:bold;font-size:14px}#gameBoard{display:flex;justify-content:center;margin:30px 0}svg{border:2px solid #e9ecef;border-radius:10px;background:white;box-shadow:0 4px 8px rgba(0,0,0,0.1);max-width:100%;height:auto}.house,.utility{cursor:pointer;transition:all .3s ease}.house circle,.utility circle{fill:#3498db;stroke:#2980b9;stroke-width:2}.house:hover circle,.utility:hover circle{fill:#2980b9;stroke:#1f5a7a;filter:drop-shadow(0 0 8px rgba(52,152,219,0.6))}.house.selected circle{fill:#f39c12;stroke:#d68910;filter:drop-shadow(0 0 12px rgba(243,156,18,0.8))}.house text,.utility text{font-size:12px;font-weight:bold;fill:white;pointer-events:none;text-anchor:middle;dominant-baseline:middle;text-shadow:0 1px 2px rgba(0,0,0,0.3)}.connection-line{cursor:pointer;fill:none;stroke:#3498db;stroke-width:3;stroke-linecap:round;stroke-linejoin:round}.connection-line:hover{stroke:#e74c3c;stroke-width:4;filter:drop-shadow(0 0 4px rgba(231,76,60,0.6))}.drawing-line{fill:none;stroke:#f39c12;stroke-width:3;stroke-linecap:round;stroke-linejoin:round;opacity:.7;pointer-events:none}.instructions{background:#f8f9fa;border-radius:8px;padding:20px;margin-top:20px;border-left:4px solid #3498db}.instructions h3{margin-top:0;color:#2c3e50}.instructions ul{padding-left:20px}.instructions li{margin:8px 0;line-height:1.4}@media(max-width:768px){body{padding:10px}.container{margin:5px;padding:10px;max-width:100%}h1{font-size:1.8em;margin-bottom:15px}.info-panel{padding:10px;margin-bottom:15px;font-size:13px}.controls{justify-content:center;text-align:center;gap:8px;margin-bottom:15px}button{padding:8px 12px;font-size:12px;margin:2px}#connectionCounter{padding:6px 10px;font-size:12px}svg{max-width:90%}.instructions{padding:15px;font-size:13px}.instructions li{margin:6px 0;line-height:1.3}}@media(max-width:480px){.container{margin:2px;padding:8px}h1{font-size:1.5em;margin-bottom:10px}.info-panel{padding:8px;margin-bottom:10px;font-size:12px}.controls{flex-direction:column;gap:5px;margin-bottom:10px}button{width:100%;max-width:200px;padding:10px;font-size:12px}svg{max-width:100%}.instructions{padding:10px;font-size:12px}}