/* v7.1: stable, no fancy */
:root{
  --bg:#0b1220;
  --panel:#0f1a2d;
  --panel2:#0c1526;
  --line:#1f2a44;
  --txt:#e5e7eb;
  --muted:#9ca3af;
  --blue:#1e3a8a;
  --blue2:#1d4ed8;
  --chip:#12203a;
  --chipOn:#1f3b78;
}

*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Apple SD Gothic Neo,Noto Sans KR;background:var(--bg);color:var(--txt)}

.topbar{
  position:sticky;top:0;z-index:50;
  display:flex;gap:12px;align-items:center;justify-content:space-between;
  padding:10px 12px;border-bottom:1px solid var(--line);
  background:rgba(11,18,32,0.92);backdrop-filter:saturate(140%) blur(8px);
}
.brand{font-weight:950;letter-spacing:.3px}
.metaLine{display:flex;gap:8px;align-items:center;color:var(--muted);font-size:12px}
.metaLine.sub{margin-top:4px;flex-wrap:wrap}
.metaTitle{color:#fff;font-weight:900}
.dot{opacity:.5}
.pill{display:inline-flex;align-items:center;gap:6px;padding:5px 9px;border-radius:999px;border:1px solid rgba(31,42,68,0.9);background:rgba(15,26,45,0.9);font-size:12px;color:#dbeafe;font-weight:850}

.topbar__right{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.search,.select{
  border:1px solid rgba(31,42,68,0.9);
  background:rgba(15,26,45,0.9);color:var(--txt);
  border-radius:10px;padding:9px 10px;font-size:13px;outline:none;
}
.search{min-width:220px}
.btn{
  cursor:pointer;border-radius:10px;border:1px solid rgba(31,42,68,0.9);
  background:rgba(15,26,45,0.9);color:var(--txt);
  padding:9px 12px;font-weight:900;font-size:13px;
}
.btn:hover{border-color:rgba(59,130,246,0.9)}
.btn--mini{padding:7px 10px;font-size:12px}

.app{display:grid;grid-template-columns:360px 1fr 380px;height:calc(100vh - 54px)}

.sidebar{border-right:1px solid var(--line);overflow:auto;background:rgba(15,26,45,0.55);padding:12px}
.mapWrap{border-right:1px solid var(--line);display:flex;flex-direction:column}
#map{flex:1;min-height:260px}
.overview{border-top:1px solid var(--line);background:rgba(12,21,38,0.85);padding:12px}
.overview__title{font-weight:950;font-size:13px;margin-bottom:6px;color:#dbeafe}
#overview{font-size:12px;color:#cbd5f5;line-height:1.45}

.detail{overflow:auto;background:rgba(12,21,38,0.85);padding:12px}
.detail__head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.detail h3{margin:0;font-size:14px;font-weight:950}
.detail__content{margin-top:10px;font-size:13px;line-height:1.5;color:#e5e7eb}
.kv{margin:8px 0 0;color:#cbd5f5;font-size:12px}
.kv b{color:#fff}

.dayTabs{display:flex;gap:8px;flex-wrap:wrap;padding:8px 0 12px}
.dayTabs.sticky{
  position:sticky; top:0; z-index:90;
  background:rgba(11,18,32,1);
  border-bottom:1px solid rgba(31,42,68,0.8);
  padding:10px 0 12px;
}
.dayBtn{
  user-select:none;
  padding:8px 10px;border-radius:999px;border:1px solid rgba(31,42,68,0.9);
  background:var(--chip);color:var(--muted);
  cursor:pointer;font-size:12px;font-weight:950;
}
.dayBtn.active{background:var(--chipOn);border-color:rgba(59,130,246,0.9);color:#fff}

.section{margin:10px 0 8px;padding:8px 10px;border:1px solid rgba(31,42,68,0.9);border-radius:12px;background:rgba(15,26,45,0.72)}
.sectionTitle{font-weight:950}
.sectionSub{color:var(--muted);font-size:12px;margin-top:3px}

.card{
  border:1px solid rgba(31,42,68,0.9);border-radius:14px;padding:10px;margin-bottom:10px;
  background:rgba(15,26,45,0.9);
}
.card.dim{opacity:.35}
.time{font-size:12px;color:var(--muted);font-weight:850}
.name{font-weight:950;margin-top:3px}
.note{font-size:12px;margin-top:6px;color:#cbd5f5;line-height:1.35}
.badges{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}
.badge{font-size:11px;padding:4px 8px;border-radius:999px;border:1px solid rgba(31,42,68,0.9);background:rgba(7,11,18,0.55);color:#dbeafe;font-weight:900}

.cardBtns{margin-top:10px;display:flex;gap:8px;flex-wrap:wrap}
.btnMini{
  cursor:pointer;font-size:12px;padding:7px 10px;border-radius:10px;border:1px solid rgba(31,42,68,0.9);
  background:rgba(7,11,18,0.55);color:var(--txt);font-weight:900;
}
.btnMini:active{transform:translateY(1px)}

.drawer{display:none;margin-top:10px;padding:10px;border-radius:12px;border:1px solid rgba(31,42,68,0.9);background:rgba(7,11,18,0.65)}
.drawer .label{font-size:12px;font-weight:950;color:#93c5fd;margin-bottom:4px}
.drawer .text{font-size:12px;color:#d1d5db;line-height:1.35}

.memo{width:100%;margin-top:10px;background:#020617;color:#e5e7eb;border:1px solid rgba(31,42,68,0.9);border-radius:10px;padding:8px;font-size:12px}
.ratingRow{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.stars{display:flex;gap:6px}
.star{
  cursor:pointer;user-select:none;
  width:26px;height:26px;border-radius:8px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid rgba(31,42,68,0.9);background:rgba(7,11,18,0.55);
  font-weight:950;color:#93c5fd;
}
.star.on{background:rgba(31,59,120,0.9);border-color:rgba(59,130,246,0.9);color:#fff}

.dragHint{margin-top:8px;color:#94a3b8;font-size:12px}

@media (max-width: 900px){
  /* Mobile layout (release): map + day tabs fixed, list scrolls */
  html, body { height:100%; }

  .topbar{ position:sticky; top:0; z-index:80; }

  .app{
    display:block;
    height:calc(100vh - 54px);
  }

  /* Fix map under topbar */
  .mapWrap{
    position:fixed;
    top:54px; left:0; right:0;
    height:42vh;
    z-index:60;
    border-right:none;
    border-bottom:1px solid var(--line);
    background:var(--panel2);
  }
  #map{ height:42vh; min-height:42vh; }

  /* Sidebar becomes the only scroll area */
  .sidebar{
    position:fixed;
    top:calc(54px + 42vh);
    left:0; right:0;
    bottom:0;
    overflow:auto;
    -webkit-overflow-scrolling:touch;
    border-right:none;
    border-top:1px solid var(--line);
    background:rgba(15,26,45,0.55);
    padding-bottom:18px;
  }

  /* Detail side panel hidden on mobile; use modal instead */
  .detail{ display:none; }

  .search{ min-width:150px; }
}



/* Modal */
.modal{position:fixed;inset:0;z-index:200;display:flex;align-items:flex-end;justify-content:center}
.modal.hidden{display:none}
.modal__backdrop{position:absolute;inset:0;background:rgba(0,0,0,0.55)}
.modal__panel{
  position:relative;
  width:min(720px, 100%);
  max-height:85vh;
  margin:0 12px 12px;
  background:linear-gradient(180deg, rgba(15,26,45,0.98), rgba(12,21,38,0.98));
  border:1px solid rgba(31,42,68,0.95);
  border-radius:16px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.35);
}
.modal__head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 12px 10px;border-bottom:1px solid rgba(31,42,68,0.8)}
.modal__title{font-weight:900}
.modal__actions{display:flex;gap:8px;align-items:center}
.modal__body{padding:12px;font-size:13px;line-height:1.55;color:#e5e7eb;overflow:auto;max-height:calc(85vh - 54px)}


body.modalOpen{overflow:hidden;}


/* Custom map pin (no external image dependency) */
.miomi-pin{
  position:relative;
  width:18px;height:18px;border-radius:50%;
  background:#3b82f6; border:2px solid rgba(255,255,255,0.9);
  box-shadow:0 10px 18px rgba(0,0,0,0.35);
}
.miomi-pin::after{
  content:''; position:absolute; left:50%; top:18px;
  width:0;height:0; transform:translateX(-50%);
  border-left:6px solid transparent;
  border-right:6px solid transparent;
  border-top:10px solid #3b82f6;
  filter:drop-shadow(0 6px 6px rgba(0,0,0,0.25));
}
.leaflet-div-icon{background:transparent;border:none}
