/* ===== Trip explorer — editorial / warm-paper aesthetic ===== */
:root{
  --paper:#f4efe6; --ink:#211d17; --muted:#6f685c;
  --line:#ddd4c4; --card:#fbf8f1; --accent:#b4471f;
  --shadow:0 1px 2px rgba(40,32,20,.06),0 8px 24px rgba(40,32,20,.08);
}
*{box-sizing:border-box}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:Inter,system-ui,sans-serif;line-height:1.55;
  background-image:radial-gradient(rgba(40,32,20,.025) 1px,transparent 1px);
  background-size:22px 22px;
}
.wrap{max-width:1180px;margin:0 auto;padding:clamp(20px,4vw,52px)}

.hero{margin-bottom:28px;border-bottom:2px solid var(--ink);padding-bottom:20px}
.hero-kicker{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:600}
.hero h1{font-family:Fraunces,Georgia,serif;font-weight:900;
  font-size:clamp(2rem,5vw,3.6rem);line-height:1.02;margin:.18em 0 .12em;
  letter-spacing:-.01em}
.hero-sub{color:var(--muted);font-size:1.05rem;margin:0;max-width:60ch}

/* ---- day buttons ---- */
.daybar{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:22px}
.day-btn{flex:1 1 220px;text-align:left;cursor:pointer;background:var(--card);
  border:1.5px solid var(--line);border-radius:14px;padding:12px 16px;
  font-family:inherit;color:var(--ink);transition:.18s;display:block}
.day-btn span{font-family:Fraunces,serif;font-weight:700;font-size:1.15rem;display:block}
.day-btn small{color:var(--muted);font-size:.82rem}
.day-btn:hover{border-color:var(--ink);transform:translateY(-1px)}
.day-btn.is-active{background:var(--ink);border-color:var(--ink)}
.day-btn.is-active span,.day-btn.is-active small{color:var(--paper)}

/* ---- explorer split ---- */
.explorer{display:grid;grid-template-columns:minmax(320px,420px) 1fr;
  gap:20px;align-items:start}
@media(max-width:840px){.explorer{grid-template-columns:1fr}}

.panel{max-height:78vh;overflow-y:auto;padding-right:6px;scrollbar-width:thin}
.panel-head{position:sticky;top:0;background:linear-gradient(var(--paper) 75%,transparent);
  padding-bottom:8px;z-index:2}
.panel-head h2{font-family:Fraunces,serif;font-size:1.5rem;margin:0}
.panel-head p{color:var(--muted);margin:.1em 0 0;font-size:.9rem}

.card{position:relative;display:flex;gap:12px;cursor:pointer;
  background:var(--card);border:1.5px solid var(--line);border-radius:14px;
  padding:13px 15px 13px 13px;margin-bottom:11px;transition:.16s}
.card:hover{border-color:var(--ink);box-shadow:var(--shadow)}
.card.is-active{border-color:var(--ink);box-shadow:var(--shadow);
  outline:2px solid var(--ink);outline-offset:-2px}
.card-num{flex:0 0 28px;height:28px;border-radius:50%;color:#fff;
  font-weight:700;font-size:.9rem;display:grid;place-items:center}
.card-main{min-width:0}
.card-top{display:flex;align-items:center;gap:8px;margin-bottom:2px}
.card-time{font-size:.82rem;color:var(--muted);font-weight:600}
.card-dur{font-size:.72rem;background:rgba(40,32,20,.07);border-radius:6px;
  padding:1px 7px;color:var(--muted)}
.card h3{font-family:Fraunces,serif;font-size:1.08rem;margin:.05em 0 .2em;line-height:1.2}
.card p{font-size:.86rem;color:var(--muted);margin:0 0 6px}
.card-img{width:100%;height:120px;object-fit:cover;border-radius:9px;
  margin-top:4px;background:var(--line)}

/* ---- map ---- */
.map-col{position:sticky;top:18px}
#map{height:78vh;min-height:460px;border-radius:16px;border:1.5px solid var(--line);
  box-shadow:var(--shadow);background:var(--line)}
.map-note{font-size:.84rem;color:var(--muted);margin-top:10px;font-style:italic;
  padding:0 4px}

.pin-dot{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;
  color:#fff;font-weight:700;font-size:.85rem;border:2.5px solid #fff;
  box-shadow:0 1px 5px rgba(0,0,0,.35)}
.pop{font-family:Inter,sans-serif;width:240px}
.pop-img{width:100%;height:120px;object-fit:cover;border-radius:8px;margin-bottom:7px}
.pop-time{font-size:.78rem;color:#b4471f;font-weight:600}
.pop-name{font-family:Fraunces,serif;font-weight:700;font-size:1.02rem;margin:1px 0 3px}
.pop-note{font-size:.82rem;color:#555;line-height:1.45}
.leaflet-popup-content{margin:11px 13px}
.leaflet-popup-content-wrapper{border-radius:12px}

/* ---- empty image placeholder ---- */
.img-ph{display:grid;place-items:center;background:repeating-linear-gradient(
  45deg,var(--line),var(--line) 10px,#e8dfce 10px,#e8dfce 20px);
  color:var(--muted);font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;
  font-weight:600;border-radius:9px}
.card-img.img-ph{height:120px;margin-top:4px}
.pop-img.img-ph{height:96px;margin-bottom:7px}

/* ---- restored content below the widget ---- */
.block{margin-top:42px;padding-top:30px;border-top:2px solid var(--ink)}
.block h2{font-family:Fraunces,serif;font-size:1.7rem;margin:0 0 18px}
.cl-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px}
.cl-group{background:var(--card);border:1.5px solid var(--line);border-radius:14px;
  padding:16px 18px}
.cl-group h4{font-family:Fraunces,serif;font-size:1.05rem;margin:0 0 10px;
  color:var(--accent)}
.cl{list-style:none;margin:0;padding:0}
.cl li{margin:7px 0}
.cl label{display:flex;gap:9px;align-items:flex-start;cursor:pointer;font-size:.88rem}
.cl input{margin-top:3px;flex:0 0 auto;width:15px;height:15px;accent-color:var(--ink)}
.cl input:checked + span{color:var(--muted);text-decoration:line-through}
.reminders{list-style:none;margin:0;padding:0;display:grid;gap:10px;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.reminders li{background:var(--card);border:1.5px solid var(--line);
  border-left:4px solid var(--accent);border-radius:10px;padding:11px 15px;
  font-size:.88rem;color:var(--ink)}
.foot{margin-top:40px;padding-top:20px;border-top:1.5px solid var(--line);
  color:var(--muted);font-size:.85rem}
.foot span{display:block;margin-top:4px;font-size:.78rem}
.foot code{background:rgba(40,32,20,.07);padding:1px 6px;border-radius:5px}
