:root{
  --map-navy:#071f4f;
  --map-navy2:#123f8f;
  --map-blue:#2563eb;
  --map-cyan:#32b8d8;
  --map-bg:#edf8ff;
  --map-card:rgba(255,255,255,.92);
  --map-card-solid:#ffffff;
  --map-border:rgba(142,202,238,.48);
  --map-text:#061a44;
  --map-muted:#607098;
  --map-shadow:0 24px 70px rgba(6,31,74,.14);
  --map-shadow-soft:0 14px 36px rgba(6,31,74,.10);
}

body.page-map{background:linear-gradient(180deg,#e7f7ff 0%,#f6fbff 55%,#edf8ff 100%)}

.map-glass-card,
.map-side-card,
.map-main-card,
.map-detail-float{
  border:1px solid var(--map-border);
  background:var(--map-card);
  box-shadow:var(--map-shadow);
  backdrop-filter:blur(14px);
}

.map-page-head{
  max-width:1720px;
  margin:18px auto 18px;
  padding:26px 30px;
  border-radius:30px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  background:
    radial-gradient(circle at 95% 0%,rgba(74,210,230,.22) 0 130px,transparent 132px),
    linear-gradient(135deg,#fff 0%,#effcff 100%);
}
.map-page-head h1{margin:.1rem 0 .25rem;font-size:clamp(2.2rem,4vw,4.5rem);line-height:.95;color:var(--map-text);letter-spacing:-.045em}
.map-page-head p{margin:0;max-width:880px;color:#29406d;font-size:1.04rem;line-height:1.55}
.map-page-head .eyebrow{font-size:.82rem;font-weight:950;text-transform:uppercase;letter-spacing:.08em;color:#194b9c;margin:0 0 8px}
.map-head-actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.map-pro-shell{
  max-width:1720px;
  margin:0 auto 46px;
  padding:0 18px;
  display:grid;
  grid-template-columns:260px minmax(0,1fr);
  gap:18px;
  align-items:stretch;
}

.map-side-card{
  border-radius:28px;
  padding:18px;
  align-self:start;
  position:sticky;
  top:92px;
  max-height:calc(100vh - 112px);
  overflow:auto;
}
.map-side-title{display:flex;gap:12px;align-items:flex-start;margin-bottom:16px}.map-side-title>span{display:grid;place-items:center;width:42px;height:42px;border-radius:15px;background:linear-gradient(135deg,#eaf7ff,#d7f4ff);font-size:1.25rem}.map-side-title h2{margin:0;color:var(--map-text);font-size:1.35rem}.map-side-title p{margin:4px 0 0;color:var(--map-muted);font-size:.9rem;line-height:1.35}
.map-filter-list{display:grid;gap:8px}.map-filter{display:flex;align-items:center;gap:10px;text-decoration:none;color:#1d3766;border:1px solid #d8eaff;border-radius:16px;background:rgba(255,255,255,.86);padding:12px 13px;font-weight:900;transition:.18s ease;box-shadow:0 8px 18px rgba(6,31,74,.04)}.map-filter:hover{transform:translateY(-1px);border-color:#9bd8ff;box-shadow:0 12px 26px rgba(6,31,74,.09)}.map-filter .filter-ico{display:grid;place-items:center;width:28px;height:28px;border-radius:10px;background:color-mix(in srgb,var(--c,#2563eb) 13%,#fff);color:var(--c,#2563eb)}.map-filter.active{background:linear-gradient(135deg,#1f5bd8,#35b5dc);color:#fff;border-color:transparent;box-shadow:0 16px 34px rgba(31,91,216,.23)}.map-filter.active .filter-ico{background:rgba(255,255,255,.20);color:#fff}.map-side-divider{height:1px;background:linear-gradient(90deg,transparent,#d7eaff,transparent);margin:16px 0}.map-place-list{display:grid;gap:9px}.map-place-button{width:100%;display:flex;align-items:center;gap:11px;text-align:left;border:1px solid #d7eaff;background:linear-gradient(180deg,#fff,#f8fcff);border-radius:18px;padding:12px 13px;cursor:pointer;color:var(--map-text);transition:.18s ease}.map-place-button:hover,.map-place-button.is-selected{border-color:#87cfff;transform:translateY(-1px);box-shadow:0 12px 24px rgba(6,31,74,.08)}.map-place-button .pin-dot{display:grid;place-items:center;min-width:34px;width:34px;height:34px;border-radius:13px;background:color-mix(in srgb,var(--c,#2563eb) 14%,#fff);color:var(--c,#2563eb);font-size:1.05rem}.map-place-button strong{display:block;font-weight:950;line-height:1.16}.map-place-button small{display:block;color:var(--map-muted);font-weight:800;margin-top:2px}.map-empty-mini{border:1px dashed #bddcf7;border-radius:16px;padding:14px;color:var(--map-muted);font-weight:800;background:#f8fcff}

.map-main-card{position:relative;border-radius:30px;overflow:hidden;min-height:720px;background:linear-gradient(135deg,#bff0ff,#efffe4);}
.map-main-card:fullscreen{width:100vw;height:100vh;border-radius:0}.map-main-card:fullscreen .map-viewport{height:100vh}.map-viewport{height:min(72vh,760px);min-height:620px;overflow:hidden;touch-action:none;cursor:grab;position:relative;background:linear-gradient(135deg,#b9efff,#f6ffe5)}.map-viewport:active{cursor:grabbing}.map-world{position:absolute;left:0;top:0;width:100%;height:100%;transform-origin:0 0;will-change:transform}.map-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;user-select:none;pointer-events:none}.map-svg{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}.map-svg polygon,.map-svg polyline{fill:color-mix(in srgb,var(--c,#2563eb) 22%,transparent);stroke:var(--c,#2563eb);stroke-width:.42;vector-effect:non-scaling-stroke;filter:drop-shadow(0 2px 5px rgba(1,15,45,.22));cursor:pointer;pointer-events:auto}.map-svg polyline{fill:none;stroke-width:.65}.map-svg polygon:hover,.map-svg polyline:hover,.map-svg .is-selected{filter:drop-shadow(0 0 10px rgba(37,99,235,.65));}

.map-floating-controls{position:absolute;left:18px;top:18px;z-index:18;display:grid;gap:8px}.map-floating-controls button{width:44px;height:44px;border:1px solid rgba(190,220,244,.9);border-radius:14px;background:rgba(255,255,255,.93);font-size:1.4rem;font-weight:950;color:#0a2a67;box-shadow:0 12px 28px rgba(6,31,74,.14);cursor:pointer;transition:.18s ease}.map-floating-controls button:hover{transform:translateY(-1px);background:#fff}.map-mini-label{position:absolute;z-index:16;background:rgba(255,255,255,.86);border:1px solid var(--map-border);border-radius:18px;padding:10px 14px;color:#3e5985;font-weight:850;font-size:.9rem;box-shadow:var(--map-shadow-soft);backdrop-filter:blur(12px)}.map-mini-label-top{right:22px;bottom:22px;}

.map-marker{position:absolute;transform:translate(-50%,-50%) scale(calc(1 / min(var(--map-scale, 1), 1.8)));transform-origin:center;z-index:8;border:3px solid var(--c,#2563eb);background:rgba(255,255,255,.96);color:#061b45;border-radius:999px;box-shadow:0 14px 30px rgba(2,18,55,.23);padding:7px 12px;display:flex;align-items:center;gap:8px;white-space:nowrap;font-weight:950;cursor:pointer;max-width:260px;transition:.16s ease}.map-marker span{display:grid;place-items:center;width:30px;height:30px;border-radius:999px;background:var(--c,#2563eb);color:#fff}.map-marker b{overflow:hidden;text-overflow:ellipsis}.map-marker:hover,.map-marker.is-selected{transform:translate(-50%,-50%) scale(calc(1.06 / min(var(--map-scale, 1), 1.8)));box-shadow:0 18px 40px rgba(2,18,55,.28);z-index:30}.map-marker.area{background:rgba(255,255,255,.9)}

.map-detail-float{position:absolute;right:18px;top:18px;bottom:18px;width:min(365px,32vw);z-index:20;border-radius:26px;padding:18px;overflow:auto;opacity:0;pointer-events:none;transform:translateX(14px);transition:.22s ease}.map-detail-float.open{opacity:1;pointer-events:auto;transform:translateX(0)}.map-close{position:absolute;right:14px;top:14px;border:0;width:40px;height:40px;border-radius:999px;background:#edf7ff;color:#0a2a67;font-size:1.6rem;line-height:1;cursor:pointer}.detail-empty{padding:54px 10px 10px;text-align:center}.detail-icon{font-size:2.4rem;margin-bottom:12px}.detail-empty h2,.map-detail h2{color:var(--map-text);margin:8px 0}.detail-empty p,.map-detail p{color:#43587f;line-height:1.55}.map-detail[hidden]{display:none}.map-detail img{width:100%;height:160px;object-fit:cover;border-radius:20px;margin-bottom:14px;background:#e0f7ff}.detail-chip{display:inline-flex;align-items:center;gap:8px;background:color-mix(in srgb,var(--c,#2563eb) 13%,#fff);color:var(--c,#2563eb);font-weight:950;padding:8px 12px;border-radius:999px;margin:4px 0 8px}.detail-actions{display:grid;gap:10px;margin-top:18px}

.map-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #cfe6fb;border-radius:16px;padding:12px 16px;background:#fff;color:#123b8c;text-decoration:none;font-weight:950;cursor:pointer;box-shadow:0 9px 20px rgba(6,31,74,.06)}.map-btn.primary{background:linear-gradient(135deg,#1e5ed7,#34b3da);border-color:transparent;color:#fff;box-shadow:0 15px 30px rgba(31,94,215,.24)}.map-btn.ghost{background:rgba(255,255,255,.78)}

.map-admin-dock{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:22;display:flex;gap:12px;align-items:center;background:rgba(255,255,255,.9);border:1px solid rgba(199,226,247,.95);border-radius:24px;padding:12px;box-shadow:0 18px 50px rgba(6,31,74,.18);backdrop-filter:blur(14px)}.map-admin-dock a{text-decoration:none;color:#173563;border:1px solid #e0effc;background:#fff;border-radius:17px;display:grid;grid-template-columns:auto 1fr;grid-template-rows:auto auto;column-gap:8px;padding:10px 14px;min-width:118px;box-shadow:0 8px 18px rgba(6,31,74,.05)}.map-admin-dock span{grid-row:1/3;font-size:1.25rem;align-self:center}.map-admin-dock b{font-size:.92rem}.map-admin-dock small{font-weight:800;color:#63769a;font-size:.72rem}.map-admin-dock a:hover{border-color:#9bd8ff;transform:translateY(-1px)}

/* Admin editor remains usable with the same visual system */
.admin-map-upload,.map-admin-grid{max-width:1720px;margin-left:auto;margin-right:auto}.admin-map-upload{padding:22px;margin-bottom:18px}.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.map-admin-grid{padding:0 18px 48px;display:grid;grid-template-columns:minmax(0,1fr) 390px;gap:18px}.admin-map-stage-card,.admin-map-form{border:1px solid var(--map-border);background:var(--map-card);border-radius:28px;box-shadow:var(--map-shadow);overflow:hidden}.admin-map-tools{display:flex;gap:8px;flex-wrap:wrap;padding:14px;border-bottom:1px solid var(--map-border);background:rgba(255,255,255,.92)}.admin-map-tools .active{background:linear-gradient(135deg,#1e5ed7,#34b3da);border-color:transparent;color:#fff}.admin-editor{height:650px}.saved-shape{opacity:.82}.draft-shape{fill:none;stroke:#061b45;stroke-width:.6;stroke-dasharray:1.3 1.3;vector-effect:non-scaling-stroke}.admin-marker{font-size:.82rem}.map-help{margin:0;padding:12px 16px;color:#64748b}.admin-map-form{padding:20px;align-self:start;position:sticky;top:92px}.admin-map-form h2{margin-top:0}.admin-map-form label{display:block;margin:11px 0;color:#233a67;font-weight:850}.admin-map-form input,.admin-map-form select,.admin-map-form textarea{width:100%;box-sizing:border-box;border:1px solid #d6eafa;border-radius:14px;padding:11px 12px;font:inherit;background:#fff;color:#061b45;margin-top:6px}.two-cols{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-actions{display:flex;gap:10px;margin-top:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid #cfe6fb;border-radius:16px;padding:12px 15px;background:#fff;color:#123b8c;text-decoration:none;font-weight:950;cursor:pointer}.btn.primary{background:linear-gradient(135deg,#1e5ed7,#34b3da);border-color:transparent;color:#fff}.btn.danger{background:#fff1f2;border-color:#fecdd3;color:#be123c}.btn.small{padding:9px 12px;border-radius:14px}.delete-form{margin-top:12px}.admin-object-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:10px}.admin-object-list button{border:1px solid #d6eafa;background:#fff;border-radius:16px;padding:12px;text-align:left;cursor:pointer}.admin-object-list span{font-size:1.35rem}.admin-object-list strong{display:block;color:#061b45}.admin-object-list small{color:#64748b}.notice.err{background:#fff1f2;border:1px solid #fecdd3;color:#be123c;border-radius:16px;padding:14px}.notice.ok{background:#ecfdf5;border:1px solid #bbf7d0;color:#047857;border-radius:16px;padding:14px}

@media (max-width:1200px){
  .map-pro-shell{grid-template-columns:1fr}.map-side-card{position:static;max-height:none}.map-side-title{margin-bottom:10px}.map-filter-list{display:flex;flex-wrap:wrap}.map-filter{width:auto}.map-place-list{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));display:grid}.map-detail-float{position:relative;right:auto;top:auto;bottom:auto;width:auto;margin:12px;border-radius:24px;opacity:1;pointer-events:auto;transform:none}.map-detail-float:not(.open) .detail-empty{display:block}.map-detail-float:not(.open) .map-close{display:none}.map-admin-grid{grid-template-columns:1fr}.admin-map-form{position:static}.map-admin-dock{position:relative;left:auto;bottom:auto;transform:none;margin:12px;overflow:auto;justify-content:flex-start}.map-mini-label-top{display:none}
}
@media (max-width:700px){
  .map-page-head{margin:12px;padding:22px 18px;border-radius:24px;display:block}.map-page-head h1{font-size:2.45rem}.map-head-actions{justify-content:flex-start;margin-top:14px}.map-pro-shell{padding:0 10px;margin-bottom:92px;gap:12px}.map-side-card{border-radius:22px;padding:13px}.map-filter{padding:10px 12px}.map-place-list{display:none}.map-main-card{border-radius:22px;min-height:560px}.map-viewport{height:560px;min-height:560px}.map-floating-controls{left:10px;top:10px}.map-floating-controls button{width:38px;height:38px;border-radius:13px}.map-marker{font-size:.78rem;padding:5px 8px}.map-marker span{width:24px;height:24px}.map-detail-float{margin:10px;padding:16px}.map-admin-dock{display:none}.map-admin-grid{padding:0 10px 90px}.admin-editor{height:560px}.two-cols{grid-template-columns:1fr}.form-actions,.inline-form{display:grid}.map-side-title h2{font-size:1.15rem}
}
