/* ============================================================
   TripMe.world — app pages (guide / live / watch)
   Reuses CSS variables defined in styles.css; loaded AFTER it.
   ============================================================ */

.app-shell{
  min-height:100vh;
  display:flex;flex-direction:column;
  background:linear-gradient(180deg,var(--sky-top,#eff5fc) 0%,var(--sky-bot,#d7e6f5) 100%);
  font-family:Inter,system-ui,-apple-system,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  color:var(--text,#0e1626);
}
.app-header{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 20px;background:#fff;border-bottom:1px solid #eef2f8;
}
.app-header .brand{font-weight:800;font-size:18px;color:#0e1626;text-decoration:none}
.app-header .brand em{font-style:normal;font-weight:500;color:#2563eb}
.app-header .header-actions{display:flex;align-items:center;gap:10px;font-size:13px;color:#51607a}
.app-header .btn-link{color:#2563eb;background:none;border:0;cursor:pointer;font-weight:600;font-size:13px;padding:6px 8px}

.app-main{flex:1;width:100%;max-width:820px;margin:0 auto;padding:24px 18px 56px}

.card{
  background:#fff;border-radius:18px;
  box-shadow:0 4px 28px rgba(15,23,42,.08);
  padding:24px;margin-bottom:18px;
}
.card h1{margin:0 0 6px;font-size:22px;font-weight:800;letter-spacing:-.3px}
.card h2{margin:0 0 6px;font-size:17px;font-weight:700}
.card p.lede{margin:0 0 18px;color:#51607a;font-size:14px;line-height:1.6}
.card .eyebrow{margin:0 0 8px;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:#2563eb}

.form-row{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.form-row label{font-size:12px;font-weight:600;color:#51607a}
.form-row input,.form-row textarea,.form-row select{
  width:100%;padding:11px 13px;border:1px solid #dde6f1;border-radius:10px;
  font:inherit;color:#0e1626;background:#fff;
}
.form-row input:focus,.form-row textarea:focus,.form-row select:focus{
  outline:none;border-color:#2563eb;box-shadow:0 0 0 3px rgba(37,99,235,.15)
}
.form-row textarea{min-height:84px;resize:vertical}
.form-row .hint{font-size:12px;color:#8694ac;margin-top:2px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:12px 22px;border-radius:999px;border:0;cursor:pointer;
  font:600 14px/1 Inter,sans-serif;letter-spacing:.02em;
  transition:transform .12s ease,box-shadow .15s ease,opacity .15s;
}
.btn-primary{background:linear-gradient(90deg,#2563eb 0%,#7c3aed 100%);color:#fff;box-shadow:0 4px 16px rgba(37,99,235,.25)}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 22px rgba(37,99,235,.32)}
.btn-secondary{background:#f4f8fd;color:#1d4ed8;border:1px solid #dde6f1}
.btn-danger{background:#ef4444;color:#fff}
.btn-ghost{background:transparent;color:#51607a;border:1px solid transparent}
.btn[disabled]{opacity:.55;cursor:not-allowed;transform:none;box-shadow:none}
.btn-full{width:100%}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

.alert{padding:10px 14px;border-radius:10px;font-size:13px;margin-bottom:12px}
.alert-error{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}
.alert-info {background:#dbeafe;color:#1e3a8a;border:1px solid #bfdbfe}
.alert-ok   {background:#dcfce7;color:#166534;border:1px solid #bbf7d0}

.hidden{display:none !important}

/* ── Guide live dashboard ────────────────────────────────── */
.video-wrap{
  position:relative;background:#0e1626;border-radius:16px;overflow:hidden;
  aspect-ratio:9/16;max-height:70vh;margin:0 auto;
}
.video-wrap video{width:100%;height:100%;object-fit:cover;display:block}
.live-badge{
  position:absolute;top:12px;left:12px;display:inline-flex;align-items:center;gap:6px;
  background:rgba(15,22,38,.78);color:#fff;border-radius:999px;
  padding:6px 12px;font-size:11px;font-weight:700;letter-spacing:.08em;
}
.live-dot{
  width:8px;height:8px;border-radius:50%;background:#ef4444;
  box-shadow:0 0 0 0 rgba(239,68,68,.7);animation:pulseDot 1.6s infinite;
}
@keyframes pulseDot{
  0%{box-shadow:0 0 0 0 rgba(239,68,68,.7)}
  70%{box-shadow:0 0 0 10px rgba(239,68,68,0)}
  100%{box-shadow:0 0 0 0 rgba(239,68,68,0)}
}
.stream-controls{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin-top:14px}
.stream-controls .btn{padding:10px 16px;font-size:13px}

/* ── Watch page ──────────────────────────────────────────── */
.watch-layout{display:grid;grid-template-columns:1fr;gap:18px}
@media (min-width:880px){.watch-layout{grid-template-columns:minmax(0,1.5fr) minmax(280px,1fr);max-width:1100px;margin:0 auto}.app-main.watch-main{max-width:1100px}}
.watch-video{background:#0e1626;border-radius:18px;overflow:hidden;aspect-ratio:16/9;position:relative}
.watch-video video{width:100%;height:100%;object-fit:contain;background:#0e1626}
.watch-video .placeholder{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:#94a3b8;font-size:14px}
.stream-meta{margin-top:10px}
.stream-meta h1{margin:0 0 4px;font-size:20px;font-weight:800}
.stream-meta .loc{color:#51607a;font-size:13px}

/* ── Chat panel ─────────────────────────────────────────── */
.chat{display:flex;flex-direction:column;background:#fff;border-radius:18px;box-shadow:0 4px 28px rgba(15,23,42,.08);min-height:360px;max-height:560px;overflow:hidden}
.chat-head{padding:14px 18px;border-bottom:1px solid #eef2f8;font-weight:700;font-size:14px;color:#0e1626;display:flex;align-items:center;justify-content:space-between}
.chat-head .who{font-size:11px;color:#8694ac;font-weight:500}
.chat-body{flex:1;overflow-y:auto;padding:14px 16px;display:flex;flex-direction:column;gap:8px;background:#f7fafd}
.chat-msg{max-width:80%;padding:8px 12px;border-radius:14px;font-size:13.5px;line-height:1.45;word-wrap:break-word}
.chat-msg .from{display:block;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:#7c3aed;margin-bottom:2px;opacity:.85}
.chat-msg.them{background:#fff;border:1px solid #eef2f8;align-self:flex-start}
.chat-msg.me{background:linear-gradient(90deg,#2563eb,#7c3aed);color:#fff;align-self:flex-end}
.chat-msg.me .from{color:#dbe6ff}
.chat-msg.guide.them .from{color:#ef4444}
.chat-msg.system{align-self:center;background:transparent;color:#8694ac;font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.chat-form{display:flex;gap:8px;padding:10px;border-top:1px solid #eef2f8;background:#fff}
.chat-form input{flex:1;padding:10px 12px;border:1px solid #dde6f1;border-radius:999px;font:inherit;color:#0e1626}
.chat-form input:focus{outline:none;border-color:#2563eb}
.chat-form button{padding:10px 18px;border:0;border-radius:999px;background:#2563eb;color:#fff;font-weight:700;cursor:pointer}

/* ── Live Now page (map) ────────────────────────────────── */
.live-hero{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.live-hero h1{margin:0;font-size:24px;font-weight:800;letter-spacing:-.3px}
.live-hero .live-dot{width:10px;height:10px}
.live-hero .count{margin-left:auto;font-size:13px;color:#51607a}
#map{height:480px;border-radius:18px;overflow:hidden;box-shadow:0 4px 28px rgba(15,23,42,.08);background:#cfe1f4}
.stream-list{list-style:none;margin:18px 0 0;padding:0;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(260px,1fr))}
.stream-list li{background:#fff;border-radius:14px;padding:14px;box-shadow:0 2px 12px rgba(15,23,42,.05);cursor:pointer;transition:transform .12s ease,box-shadow .15s ease;border:1px solid #eef2f8}
.stream-list li:hover{transform:translateY(-2px);box-shadow:0 6px 22px rgba(15,23,42,.1)}
.stream-list h3{margin:0 0 4px;font-size:15px;font-weight:700;display:flex;align-items:center;gap:6px}
.stream-list .badge-live{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;color:#ef4444;letter-spacing:.08em;text-transform:uppercase}
.stream-list .loc{color:#51607a;font-size:12.5px;margin:0}
.empty-state{padding:30px;text-align:center;color:#51607a;background:#fff;border-radius:18px;box-shadow:0 4px 28px rgba(15,23,42,.06)}
.empty-state strong{display:block;font-size:16px;color:#0e1626;margin-bottom:4px}

/* Custom Leaflet pin */
.leaflet-live-pin{position:relative;width:24px;height:24px}
.leaflet-live-pin .core{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;background:#ef4444;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 6px rgba(0,0,0,.3)}
.leaflet-live-pin .ring{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:14px;height:14px;border-radius:50%;background:rgba(239,68,68,.5);animation:pinPulse 1.8s infinite}
.leaflet-live-pin .label{position:absolute;left:50%;top:-20px;transform:translateX(-50%);background:#ef4444;color:#fff;font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 7px;border-radius:6px;white-space:nowrap}
@keyframes pinPulse{0%{transform:translate(-50%,-50%) scale(1);opacity:.6}100%{transform:translate(-50%,-50%) scale(3.5);opacity:0}}

/* ── Modal ───────────────────────────────────────────────── */
.modal-bg{position:fixed;inset:0;background:rgba(15,22,38,.55);display:flex;align-items:center;justify-content:center;z-index:9999;padding:20px}
.modal{background:#fff;border-radius:18px;max-width:420px;width:100%;padding:26px;box-shadow:0 18px 60px rgba(15,23,42,.3)}
.modal h2{margin:0 0 8px;font-size:20px;font-weight:800}
.modal .tab-row{display:flex;gap:6px;margin-bottom:16px;background:#f4f8fd;border-radius:999px;padding:4px}
.modal .tab-row button{flex:1;padding:8px;border:0;background:transparent;border-radius:999px;font-weight:600;font-size:13px;color:#51607a;cursor:pointer}
.modal .tab-row button.active{background:#fff;color:#0e1626;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.modal .close{background:none;border:0;font-size:22px;color:#8694ac;cursor:pointer;float:right;line-height:1;padding:0 4px}

/* ── Rating ─────────────────────────────────────────────── */
.rating{display:flex;gap:6px;justify-content:center;margin:10px 0 18px}
.rating button{background:none;border:0;font-size:32px;cursor:pointer;color:#d1d5db;line-height:1;padding:2px;transition:transform .1s}
.rating button:hover,.rating button.active{color:#fbbf24;transform:scale(1.08)}

@media (max-width:600px){
  .app-main{padding:14px 12px 40px}
  .card{padding:18px;border-radius:14px}
  .video-wrap{max-height:60vh;border-radius:12px}
  #map{height:380px}
}
