*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --moss:#2d4a2f;
  --fern:#4a7c4e;
  --sage:#8aad8c;
  --mist:#c8ddc9;
  --cream:#f5f0e8;
  --soil:#3a2e1e;
  --amber:#c8921a;
  --cyan:#6bd2d6;
  --rose:#d98bdc;
  --glass:rgba(200,221,201,.12);
  --glass-border:rgba(138,173,140,.28);
  --nav:92px;
}

body{
  background:#061009;
  color:var(--cream);
  font-family:'Cormorant Garamond',serif;
  overflow:hidden;
  min-height:100vh;
}

body::before{
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 25% 20%,rgba(74,124,78,.18),transparent 35%),
    radial-gradient(circle at 80% 75%,rgba(74,124,78,.12),transparent 40%);
  pointer-events:none;
  z-index:0;
}

body::after{
  content:'';
  position:fixed;
  inset:0;
  z-index:1;
  pointer-events:none;
  background:
    linear-gradient(90deg,rgba(0,0,0,.28),transparent 24%,transparent 74%,rgba(0,0,0,.36)),
    radial-gradient(circle at 30% 52%,rgba(120,180,115,.12),transparent 34%);
}

.hidden{display:none!important}

/* Sidebar is loaded from sidebar.html. Map only reserves/floats around it. */
#sidebar-root{
  position:fixed;
  inset:0 auto 0 0;
  width:var(--nav);
  z-index:10000;
}

/* MAP LAYOUT */
.map-shell{
  position:relative;
  height:100vh;
  width:100vw;
  overflow:hidden;
  z-index:2;
  background:#061009;
}

.map-stage{
  position:absolute;
  inset:0;
  overflow:hidden;
  background:#061009;
  border:0;
}

.map-viewport{
  position:absolute;
  inset:0;
  padding:0;
  overflow:hidden;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:grab;
}

.map-viewport.dragging{cursor:grabbing}

.map-frame{
  position:relative;
  width:min(100vw,100vh);
  max-width:none;
  aspect-ratio:1/1;
  transform-origin:center center;
  user-select:none;
  box-shadow:none;
  --label-scale:1;
  --marker-scale:.80;
}

.base-map,.zone-layer{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:contain;
  user-select:none;
  pointer-events:none;
}

.base-map{filter:saturate(.98) contrast(1.06) brightness(.88)}

.zone-layer{
  opacity:.48;
  mix-blend-mode:screen;
  transition:opacity .25s,filter .25s;
}

.zone-layer.hidden{opacity:0}

.map-grid{
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(90deg,transparent 0 11.11%,rgba(200,221,201,.055) 11.11% calc(11.11% + 1px)),
    repeating-linear-gradient(0deg,transparent 0 11.11%,rgba(200,221,201,.055) 11.11% calc(11.11% + 1px));
  pointer-events:none;
  mix-blend-mode:screen;
  opacity:.62;
}

.labels-layer,.friends-layer,.heat-layer{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.labels-layer.hidden,.friends-layer.hidden,.heat-layer.hidden{display:none!important}

/* MAP LABELS */
.map-label{
  position:absolute;
  transform:translate(-50%,-50%) scale(var(--label-scale));
  transform-origin:center center;
  font-family:'DM Mono',monospace;
  font-size:.62rem;
  letter-spacing:.07em;
  line-height:1;
  white-space:nowrap;
  background:rgba(10,17,10,.82);
  border:1px solid rgba(245,240,232,.18);
  color:#f5f0e8;
  padding:.28rem .52rem;
  border-radius:2px;
  text-shadow:0 1px 3px rgba(0,0,0,1);
  box-shadow:0 2px 8px rgba(0,0,0,.35);
  opacity:.95;
  transition:opacity .18s,transform .18s;
}

.map-label.regions{
  background:rgba(13,44,22,.88);
  border-color:rgba(138,173,140,.35);
  font-size:.68rem;
}

.map-label.outposts{
  background:rgba(50,37,13,.88);
  border-color:rgba(200,146,26,.45);
  color:#f8e0a1;
}

.map-label.landmarks{
  background:rgba(43,23,47,.88);
  border-color:rgba(217,139,220,.42);
  color:#f1c6f3;
}

.map-label.lakes{
  background:rgba(9,44,48,.88);
  border-color:rgba(107,210,214,.44);
  color:#c6fbff;
}

/* HEAT + FRIEND DOTS */
.heat-dot{
  position:absolute;
  transform:translate(-50%,-50%);
  width:110px;
  height:110px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(255,226,0,.78) 0%,rgba(68,228,166,.42) 42%,rgba(68,228,166,.14) 70%,transparent 100%);
  filter:blur(2px);
  mix-blend-mode:screen;
  opacity:.72;
}

.friend-marker{
  position:absolute;
  transform:translate(-50%,-50%) scale(var(--marker-scale));
  transform-origin:center center;
  display:flex;
  align-items:center;
  gap:.45rem;
  filter:drop-shadow(0 6px 12px rgba(0,0,0,.45));
  pointer-events:auto;
}

.friend-dot{
  width:13px;
  height:13px;
  border-radius:50%;
  background:#5fe7ff;
  border:2px solid rgba(245,240,232,.9);
  box-shadow:
    0 0 0 7px rgba(95,231,255,.16),
    0 0 14px rgba(95,231,255,.45);
  cursor:help;
  flex:none;
}

.friend-marker.you .friend-dot{
  background:#ff73d6;
  box-shadow:
    0 0 0 7px rgba(255,115,214,.16),
    0 0 14px rgba(255,115,214,.45);
}

.friend-tag{
  font-family:'DM Mono',monospace;
  font-size:.50rem;
  letter-spacing:.15em;
  text-transform:uppercase;
  background:rgba(9,23,12,.92);
  border:1px solid rgba(138,173,140,.35);
  color:var(--cream);
  padding:.34rem .50rem;
  white-space:nowrap;
  opacity:0;
  visibility:hidden;
  transform:translateX(-4px);
  transition:opacity .16s,visibility .16s,transform .16s;
  pointer-events:none;
}

.friend-marker:hover .friend-tag{
  opacity:1;
  visibility:visible;
  transform:translateX(0);
}

/* LEFT PANEL */
.panel.left{
  position:absolute;
  left:var(--nav);
  top:0;
  bottom:0;
  width:390px;
  z-index:40;
  padding:2.8rem 2.4rem;
  background:linear-gradient(180deg,rgba(4,14,9,.58),rgba(2,10,6,.50));
  border:0;
  border-right:1px solid rgba(138,173,140,.18);
  box-shadow:14px 0 42px rgba(0,0,0,.22);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  overflow:auto;
}

.panel.left::before{
  content:'';
  position:absolute;
  inset:0;
  border:1px solid rgba(138,173,140,.12);
  pointer-events:none;
}

.panel-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:1rem;
  margin-bottom:1.25rem;
}

.panel-header::after{
  content:'◇';
  display:block;
  color:rgba(138,173,140,.42);
  font-size:.65rem;
  text-align:center;
  margin:.8rem 0 0;
  border-top:1px solid rgba(138,173,140,.13);
  line-height:0;
}

.panel-title{
  font-family:'Playfair Display',serif;
  font-size:2.8rem;
  color:var(--cream);
  line-height:.95;
}

.panel-eyebrow,.section-label{
  font-family:'DM Mono',monospace;
  color:#78c46d;
  letter-spacing:.36em;
  font-size:.62rem;
  text-transform:uppercase;
}

.intro{
  font-size:1.10rem;
  line-height:1.65;
  color:var(--cream);
  opacity:.82;
  margin-bottom:2rem;
}

.control-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.05rem 0;
  border-top:1px solid rgba(138,173,140,.10);
}

.control-row:last-child{border-bottom:1px solid rgba(138,173,140,.10)}

.control-label{
  font-family:'DM Mono',monospace;
  font-size:.68rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--mist);
}

.toggle{
  position:relative;
  width:50px;
  height:26px;
  border-radius:999px;
  border:1px solid rgba(133,213,128,.65);
  background:rgba(8,25,13,.76);
  cursor:pointer;
}

.toggle::after{
  content:'';
  position:absolute;
  top:3px;
  left:3px;
  width:18px;
  height:18px;
  border-radius:50%;
  background:#bce3b7;
  transition:.25s;
}

.toggle.on{background:rgba(72,131,60,.45)}

.toggle.on::after{
  left:27px;
  box-shadow:0 0 14px rgba(188,227,183,.45);
}

.section-block{margin-top:1.7rem}

.coord-input{
  width:100%;
  height:46px;
  background:rgba(0,0,0,.18);
  border:1px solid rgba(138,173,140,.16);
  color:var(--cream);
  padding:.9rem 1rem;
  font-family:'DM Mono',monospace;
  font-size:.72rem;
  margin:.75rem 0;
}

.coord-feedback{
  font-family:'DM Mono',monospace;
  font-size:.58rem;
  color:var(--mist);
  opacity:.55;
  margin-top:.7rem;
}

.dino-btn{
  font-family:'DM Mono',monospace;
  font-size:.62rem;
  letter-spacing:.17em;
  text-transform:uppercase;
  padding:.75rem 1rem;
  border:1px solid rgba(133,213,128,.55);
  background:rgba(7,22,11,.34);
  color:var(--cream);
  cursor:pointer;
  transition:.25s;
}

.dino-btn:hover{
  border-color:var(--sage);
  background:rgba(138,173,140,.08);
}

.pill-grid{
  display:flex;
  flex-wrap:wrap;
  gap:.55rem;
  margin:1rem 0 1.5rem;
}

.pill{
  font-family:'DM Mono',monospace;
  font-size:.62rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  border:1px solid var(--glass-border);
  background:rgba(0,0,0,.19);
  color:var(--cream);
  padding:.68rem .86rem;
  cursor:pointer;
  border-radius:3px;
  opacity:1;
}

.pill.regions.active{border-color:#85d580}
.pill.outposts.active{border-color:#e0b12d}
.pill.landmarks.active{border-color:#c77ee3}
.pill.lakes.active{border-color:#65d4ef}

.pill.patrol.active{
  background:rgba(255,230,0,.72);
  border:1px solid #fff000;
  color:#111;
  box-shadow:0 0 14px rgba(255,230,0,.55), inset 0 0 10px rgba(255,255,255,.18);
}

.pill.migration.active{
  background:rgba(94,255,0,.72);
  border:1px solid #62ff00;
  color:#081106;
  box-shadow:0 0 14px rgba(98,255,0,.55), inset 0 0 10px rgba(255,255,255,.18);
}

.pill.sanctuary.active{
  background:rgba(244,139,245,.72);
  border:1px solid #f48bf5;
  color:#140914;
  box-shadow:0 0 14px rgba(244,139,245,.55), inset 0 0 10px rgba(255,255,255,.18);
}

.pill.spawns.active{
  background:rgba(0,235,178,.72);
  border:1px solid #00ebb2;
  color:#041210;
  box-shadow:0 0 14px rgba(0,235,178,.55), inset 0 0 10px rgba(255,255,255,.18);
}

.label-list{
  max-height:210px;
  overflow:auto;
  border:1px solid rgba(138,173,140,.12);
  background:rgba(0,0,0,.14);
  padding:.55rem;
  margin-top:.75rem;
}

.label-list button{
  width:100%;
  text-align:left;
  background:transparent;
  border:0;
  color:var(--mist);
  font-family:'DM Mono',monospace;
  font-size:.6rem;
  letter-spacing:.1em;
  text-transform:uppercase;
  padding:.55rem;
  cursor:pointer;
  opacity:.7;
}

.label-list button:hover{
  opacity:1;
  background:rgba(138,173,140,.08);
}

#visibleCount{
  float:right;
  color:var(--mist);
  letter-spacing:.1em;
}

/* RIGHT FRIENDS PANEL */
.panel.right{
  position:absolute;
  top:1.15rem;
  right:1.15rem;
  width:260px;
  padding:0;
  background:transparent;
  border:0;
  box-shadow:none;
  overflow:visible;
  z-index:45;
}

.right-card{
  background:rgba(3,13,8,.56);
  border:1px solid rgba(138,173,140,.18);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}

.friends-head{
  padding:1.25rem 1.25rem 1.05rem;
  margin-bottom:.9rem;
  cursor:pointer;
}

.friends-head-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid rgba(138,173,140,.10);
  padding-bottom:.95rem;
}

.right-title{
  font-family:'DM Mono',monospace;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--cream);
}

.chevron{
  color:var(--sage);
  font-family:'DM Mono',monospace;
  transition:transform .2s ease;
}

.panel.right.friends-collapsed .chevron{transform:rotate(-90deg)}

.online-row{
  display:flex;
  align-items:center;
  gap:.55rem;
  margin-top:1rem;
  font-family:'DM Mono',monospace;
  font-size:.66rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--mist);
}

.online-dot{
  width:8px;
  height:8px;
  border-radius:50%;
  background:#77d968;
  box-shadow:0 0 10px rgba(119,217,104,.5);
}

.friend-stack{
  padding:1.1rem 1.2rem;
  transition:all .22s ease;
}

.panel.right.friends-collapsed .friend-stack,
.panel.right.friends-collapsed .map-legend-card{
  display:none;
}

.friend-list-card{
  padding:.9rem 0;
  border-bottom:1px solid rgba(138,173,140,.08);
}

.friend-list-card:last-of-type{border-bottom:0}

.friend-card-top{
  display:flex;
  align-items:center;
  gap:.62rem;
  color:var(--cream);
}

.friend-card-top strong{
  font-family:'Playfair Display',serif;
  font-size:1.1rem;
  font-weight:700;
}

.friend-list-card p{
  margin:.32rem 0 0 1.45rem;
  color:rgba(245,240,232,.70);
  font-size:.88rem;
  line-height:1.2;
}

.friend-list-card .coords{
  font-family:'DM Mono',monospace;
  font-size:.58rem;
  letter-spacing:.07em;
  color:rgba(200,221,201,.68);
}

.friend-color{
  width:10px;
  height:10px;
  border-radius:50%;
  flex:none;
  box-shadow:0 0 6px currentColor;
}

.friend-color.gold{background:#ff73d6;color:#ff73d6}
.friend-color.purple{background:#c084ff;color:#c084ff}
.friend-color.green{background:#5fe7ff;color:#5fe7ff}
.friend-color.blue{background:#7fdcff;color:#7fdcff}

.crown{
  margin-left:auto;
  color:#e8b72f;
}

.add-friend-btn{
  width:100%;
  display:flex;
  align-items:center;
  gap:.65rem;
  padding:1rem 0 .2rem;
  background:transparent;
  border:0;
  color:var(--cream);
  font-family:'DM Mono',monospace;
  font-size:.65rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  cursor:pointer;
}

.add-friend-btn span{
  font-size:1rem;
  color:var(--sage);
}

.map-legend-card{
  margin-top:.9rem;
  padding:1.25rem 1.25rem;
}

.legend-title{
  padding-bottom:.9rem;
  border-bottom:1px solid rgba(138,173,140,.10);
  margin-bottom:.9rem;
}

.legend-line{
  display:flex;
  align-items:center;
  gap:.8rem;
  margin:.85rem 0;
  font-family:'DM Mono',monospace;
  font-size:.64rem;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--mist);
}

.legend-diamond{
  width:13px;
  height:13px;
  transform:rotate(45deg);
  border:2px solid #85d580;
}

.legend-diamond.outpost{border-color:#e0b12d}
.legend-diamond.landmark{border-color:#c77ee3}
.legend-diamond.water{border-color:#65d4ef}

/* ZOOM */
.zoom-controls{
  position:absolute;
  left:calc(var(--nav) + 405px);
  bottom:1rem;
  display:flex;
  flex-direction:column;
  z-index:35;
  background:rgba(3,13,8,.60);
  border:1px solid rgba(138,173,140,.18);
  box-shadow:0 10px 28px rgba(0,0,0,.18);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  overflow:hidden;
}

.zoom-btn{
  font-family:'DM Mono',monospace;
  font-size:1rem;
  width:38px;
  height:38px;
  border:0;
  border-bottom:1px solid rgba(138,173,140,.18);
  background:transparent;
  color:var(--sage);
  cursor:pointer;
}

.zoom-btn:last-child{border-bottom:0}

.zoom-btn:hover{
  color:var(--cream);
  background:rgba(138,173,140,.12);
}

.zoom-label{
  display:block;
  width:38px;
  height:38px;
  line-height:38px;
  text-align:center;
  font-family:'DM Mono',monospace;
  font-size:.65rem;
  color:var(--cream);
  border-bottom:1px solid rgba(138,173,140,.18);
}

/* REOPEN */
.reopen{
  position:fixed;
  top:1rem;
  z-index:70;
  border:1px solid var(--glass-border);
  background:rgba(9,22,11,.92);
  color:var(--sage);
  font-family:'DM Mono',monospace;
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:.75rem 1rem;
  cursor:pointer;
  display:none;
}

.reopen.left{left:calc(var(--nav) + 1rem)}
.reopen.show{display:block}

/* MODAL */
.modal-overlay{
  position:fixed;
  inset:0;
  background:rgba(2,8,4,.88);
  z-index:20000;
  display:flex;
  align-items:center;
  justify-content:center;
  opacity:0;
  pointer-events:none;
  transition:opacity .25s;
  backdrop-filter:blur(12px);
}

.modal-overlay.open{
  opacity:1;
  pointer-events:all;
}

.add-friend-modal{
  background:rgba(4,16,9,.95);
  border:1px solid rgba(138,173,140,.28);
  width:min(420px,90vw);
  padding:2.5rem;
  position:relative;
  transform:translateY(16px);
  transition:transform .3s;
}

.modal-overlay.open .add-friend-modal{transform:translateY(0)}

.modal-eyebrow{
  font-family:'DM Mono',monospace;
  font-size:.6rem;
  letter-spacing:.35em;
  text-transform:uppercase;
  color:#78c46d;
  margin-bottom:.5rem;
}

.modal-heading{
  font-family:'Playfair Display',serif;
  font-size:2rem;
  color:var(--cream);
  margin-bottom:.5rem;
}

.modal-sub{
  font-size:.95rem;
  color:var(--mist);
  opacity:.6;
  margin-bottom:2rem;
  line-height:1.6;
}

.modal-input{
  width:100%;
  background:rgba(0,0,0,.3);
  border:1px solid rgba(138,173,140,.25);
  color:var(--cream);
  padding:1rem 1.2rem;
  font-family:'DM Mono',monospace;
  font-size:.72rem;
  margin-bottom:1rem;
  outline:none;
}

.modal-actions{
  display:flex;
  gap:.75rem;
}

.modal-submit,.modal-cancel{
  font-family:'DM Mono',monospace;
  font-size:.65rem;
  letter-spacing:.2em;
  text-transform:uppercase;
  padding:.9rem 1.2rem;
  cursor:pointer;
}

.modal-submit{
  flex:1;
  border:1px solid rgba(133,213,128,.55);
  background:rgba(72,131,60,.25);
  color:var(--cream);
}

.modal-cancel,.modal-close-x{
  border:1px solid rgba(138,173,140,.2);
  background:transparent;
  color:var(--sage);
}

.modal-close-x{
  position:absolute;
  top:1rem;
  right:1rem;
  width:28px;
  height:28px;
}

.modal-note{
  margin-top:1.5rem;
  padding:1rem;
  border:1px dashed rgba(138,173,140,.2);
  font-family:'DM Mono',monospace;
  font-size:.58rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--mist);
  opacity:.5;
  line-height:1.6;
}

@media(max-width:1100px){
  :root{--nav:72px}
  .panel.left{
    width:min(340px,calc(100vw - 72px));
    padding:1.5rem;
  }
  .panel.right{display:none}
  .zoom-controls{left:1rem}
}

@media(max-width:760px){
  .panel.left{
    width:min(340px,calc(100vw - 72px));
  }
}
