*{box-sizing:border-box}:root{--bg:#0a0a0a;--panel:#1f1f1f;--text:#fff;--muted:#b3b3b3;--green:#22c55e;--green2:#166534;--red:#ef4444;--red2:#991b1b}body{background:var(--bg);color:var(--text);font-family:Inter,system-ui,Arial,Helvetica,sans-serif;margin:0;padding:0}.app{height:100vh;overflow:hidden}.layout{height:100vh}.canvas{position:relative;overflow:visible;height:100vh;display:flex;align-items:center;justify-content:center}.toolbar{position:absolute;left:16px;top:16px;z-index:10;display:flex;gap:8px}.toolbtn{padding:8px 12px;border-radius:8px;background:#262626;color:#fff;border:none;cursor:pointer;font-weight:600}.mapwrap{position:relative;-webkit-user-select:none;user-select:none;width:100%;height:100%}.mapwrap .overlay{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;z-index:2}.map-base{width:100%;height:100%;display:block;object-fit:contain}.mapwrap{will-change:transform}.mapwrap .overlay{backface-visibility:hidden}.overlay{contain:layout paint size;mix-blend-mode:normal}.overlay svg path:hover,.overlay svg polygon:hover,.overlay svg rect:hover,.overlay svg circle:hover,.overlay svg ellipse:hover,.overlay svg polyline:hover{fill-opacity:.6!important}.overlay svg .status-sold:hover{fill-opacity:1!important;filter:brightness(.9)}.floating-legend{position:absolute;bottom:20px;left:20px;background:#000c;color:#fff;padding:12px 16px;border-radius:8px;font-size:14px;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid rgba(255,255,255,.1)}.legend-item{display:flex;align-items:center;gap:8px;margin:4px 0}.legend-swatch{width:16px;height:16px;border-radius:3px;border:1px solid rgba(255,255,255,.2)}.watermark-center{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;padding:8px 12px;border-radius:6px;font-size:12px;z-index:5;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100vh;background:#f9fafb}.loading-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#6b7280;font-size:16px;margin:0}.admin-panel{position:relative;min-height:100vh;background:#f3f4f6;display:flex;flex-direction:column}.admin-header-fixed{position:fixed;top:0;left:0;right:0;height:64px;background:#fff;box-shadow:0 1px 2px #0000000d;z-index:50}.admin-header-content{max-width:100%;height:100%;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.header-left{display:flex;align-items:center;gap:1rem}.header-right{display:flex;align-items:center;gap:1.5rem}.user-badge{background:#eff6ff;color:#1d4ed8;padding:.25rem .75rem;border-radius:9999px;font-size:.875rem;font-weight:500}.admin-tabs-nav{display:flex;gap:.5rem;height:100%}.admin-tabs-nav button{background:transparent;border:none;border-bottom:2px solid transparent;padding:0 1rem;height:100%;color:#6b7280;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s}.admin-tabs-nav button:hover{color:#111827;background:#f9fafb}.admin-tabs-nav button.active{color:#2563eb;border-bottom-color:#2563eb}.admin-content-container{margin-top:64px;padding:2rem;flex:1;max-width:1400px;width:100%;margin-left:auto;margin-right:auto}.admin-map-wrapper{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;height:calc(100vh - 128px);overflow:hidden;position:relative}.admin-section{display:flex;flex-direction:column;gap:1.5rem}.admin-card{background:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem}.admin-card h3{margin-top:0;margin-bottom:1.5rem;font-size:1.125rem;color:#111827;border-bottom:1px solid #e5e7eb;padding-bottom:1rem}.table-responsive{overflow-x:auto}.admin-table{width:100%;border-collapse:collapse;text-align:left;font-size:.875rem}.admin-table th{background:#f9fafb;font-weight:600;color:#374151;padding:.75rem 1rem;border-bottom:1px solid #e5e7eb}.admin-table td{padding:.75rem 1rem;border-bottom:1px solid #e5e7eb;color:#4b5563}.admin-table tr:hover td{background:#f9fafb}.admin-form{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;align-items:end}.admin-form button{background:#2563eb;color:#fff;padding:.75rem 1.5rem;border:none;border-radius:.375rem;font-weight:500;cursor:pointer;transition:background .2s;height:42px}.admin-form button:hover{background:#1d4ed8}.admin-form button:disabled{background:#93c5fd;cursor:not-allowed}.form-buttons{display:flex;gap:1rem}.cancel-btn{background:#f3f4f6;color:#374151;padding:.75rem 1.5rem;border:1px solid #d1d5db;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s;height:42px}.cancel-btn:hover{background:#e5e7eb}.action-buttons{display:flex;gap:.5rem}.edit-btn{background:#dbeafe;color:#1e40af;border:none;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .2s}.edit-btn:hover{background:#bfdbfe}.edit-btn:disabled{opacity:.5;cursor:not-allowed}.delete-btn{background:#fee2e2;color:#991b1b;border:none;padding:.25rem .75rem;border-radius:.25rem;font-size:.75rem;font-weight:500;cursor:pointer;transition:background .2s}.delete-btn:hover{background:#fecaca}.delete-btn:disabled{opacity:.5;cursor:not-allowed}.modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .2s ease-out}.modal-content{background-color:#fff;border-radius:12px;padding:24px;width:90%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;position:relative;animation:slideUp .3s ease-out}.modal-header{text-align:center;margin-bottom:24px}.modal-icon{width:48px;height:48px;background-color:#eff6ff;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:#3b82f6}.modal-title{font-size:1.5rem;font-weight:700;color:#111827;margin:0 0 8px}.modal-subtitle{color:#6b7280;font-size:.875rem;margin:0}.modal-form-group{margin-bottom:20px}.modal-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:6px}.modal-input,.modal-textarea{width:100%;padding:10px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;transition:border-color .2s,box-shadow .2s;outline:none;font-family:inherit}.modal-input:focus,.modal-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.modal-helper-text{font-size:.75rem;color:#6b7280;margin-top:4px}.modal-info-box{background-color:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;padding:12px;margin-bottom:24px;display:flex;gap:12px}.modal-info-content h4{margin:0 0 4px;font-size:.875rem;color:#1e40af}.modal-info-content p{margin:0;font-size:.75rem;color:#1e3a8a}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:8px}.modal-btn{padding:10px 20px;border-radius:6px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s;border:none}.modal-btn-secondary{background-color:#fff;border:1px solid #d1d5db;color:#374151}.modal-btn-secondary:hover{background-color:#f9fafb;border-color:#9ca3af}.modal-btn-primary{background-color:#3b82f6;color:#fff;box-shadow:0 1px 2px #0000000d}.modal-btn-primary:hover{background-color:#2563eb}.modal-btn-primary:disabled{background-color:#93c5fd;cursor:not-allowed}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (max-width: 768px){.floating-legend{bottom:60px;left:10px;font-size:.8rem}.legend-item{margin-bottom:.3rem}.legend-swatch{width:10px;height:10px}.watermark-center{font-size:.7rem;bottom:5px}.toolbar{top:10px;left:10px}.toolbtn{width:35px;height:35px;font-size:16px}.login-form{margin:1rem;padding:1.5rem}.admin-header-content{padding:0 1rem}.admin-content-container{padding:1rem}.header-right .admin-stats{display:none}}
