/* ==========================================================================
   ThermometerGuru — adventure.css
   Centerpiece dashboard, kit catalog, planner map, live ticker.
   ========================================================================== */

/* ---------- ADVENTURE / DASHBOARD ---------- */
.tmg-adventure { min-height: 720px; padding: 96px 0 96px; position: relative; }
.tmg-adv-sky, .tmg-adv-particles { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.tmg-adv-progress {
	max-width: 760px; margin: 0 auto 32px;
	height: 6px; background: rgba(255,255,255,.08); border-radius: 999px; overflow: hidden;
}
.tmg-adv-progress-bar {
	height: 100%; background: linear-gradient(90deg, var(--tmg-primary), var(--tmg-cta), var(--tmg-accent));
	background-size: 200% 100%;
	animation: tmg-shimmer 3s linear infinite;
	transition: width .6s ease;
}
.tmg-adv-stages {
	display: grid; gap: 20px;
	grid-template-columns: repeat(4, 1fr);
	margin: 0 0 32px;
}
.tmg-adv-stage {
	position: relative;
	background: rgba(255,255,255,.04);
	border: 1px solid rgba(255,255,255,.08);
	border-radius: var(--tmg-radius);
	padding: 20px;
	min-height: 220px;
	transition: border-color .3s ease, box-shadow .3s ease, background .3s ease;
}
.tmg-adv-stage.is-next {
	border-color: var(--tmg-primary);
	box-shadow: 0 0 0 4px rgba(14,165,233,.12), 0 24px 60px -28px rgba(14,165,233,.3);
	background: rgba(14,165,233,.06);
}
.tmg-adv-stage.is-done .tmg-adv-chip {
	background: linear-gradient(135deg, var(--tmg-cta), #fb923c);
	transform: scale(1.05);
}
.tmg-adv-stage.is-done {
	border-color: rgba(20,184,166,.4);
}
.tmg-adv-chip {
	display: inline-flex; align-items: center; gap: 6px;
	background: rgba(255,255,255,.08);
	color: #fff; padding: 4px 10px; border-radius: 999px;
	font-weight: 700; font-size: .82rem;
	margin-bottom: 12px;
	transition: transform .3s ease, background .3s ease;
}
.tmg-adv-chip span { font-family: var(--tmg-h-font); font-size: 1rem; }
.tmg-adv-stage-title { color: #fff; margin: 0 0 12px; font-size: 1.1rem; }
.tmg-adv-stage-body { color: #c5d2e6; font-size: .92rem; }
.tmg-adv-empty { font-style: italic; opacity: .8; }
.tmg-adv-saved { display: grid; gap: 6px; }
.tmg-adv-saved strong { color: #fff; }
.tmg-adv-saved .tmg-adv-saved-pill { display: inline-block; background: rgba(14,165,233,.18); padding: 4px 8px; border-radius: 8px; font-size: .82rem; color: #c5d2e6; }
.tmg-adv-connector {
	position: absolute;
	right: -10px; top: 50%; width: 20px; height: 2px;
	background: rgba(255,255,255,.18);
}
.tmg-adv-stage.is-done + .tmg-adv-stage .tmg-adv-connector,
.tmg-adv-stage.is-done .tmg-adv-connector {
	background: linear-gradient(90deg, var(--tmg-cta), var(--tmg-primary));
}

@media (max-width: 1080px) {
	.tmg-adv-stages { grid-template-columns: repeat(2, 1fr); }
	.tmg-adv-connector { display: none; }
}
@media (max-width: 600px) {
	.tmg-adv-stages { grid-template-columns: 1fr; }
}

.tmg-adv-cta-row { display: flex; gap: 16px; justify-content: center; flex-wrap: wrap; }

/* ---------- TRIP PLANNER MAP ---------- */
.tmg-planner { padding: 80px 0; }
.tmg-planner-controls {
	display: flex; gap: 12px; justify-content: center; margin: 0 0 24px; flex-wrap: wrap;
}
.tmg-planner-pills { display: flex; gap: 8px; flex-wrap: wrap; justify-content: center; }
.tmg-planner-pill {
	background: rgba(255,255,255,.06); color: #cfd8e7;
	border: 1px solid rgba(255,255,255,.1);
	padding: 8px 14px; border-radius: 999px; font-size: .85rem;
}
.tmg-planner-pill.is-active { background: linear-gradient(135deg, var(--tmg-primary), var(--tmg-accent)); color: #fff; border-color: transparent; }

.tmg-planner-stage { display: grid; gap: 24px; grid-template-columns: 2fr 1fr; align-items: stretch; }
.tmg-planner-mapwrap {
	background: #0a1426;
	border: 1px solid rgba(255,255,255,.06);
	border-radius: var(--tmg-radius);
	overflow: hidden;
	min-height: 480px;
	position: relative;
}
.tmg-planner-map { width: 100%; height: 100%; min-height: 480px; cursor: crosshair; display: block; }
.tmg-planner-pin { cursor: pointer; transition: transform .2s ease; }
.tmg-planner-pin:hover { transform: scale(1.2); }
.tmg-planner-pin.is-on circle:nth-child(2) { fill: var(--tmg-cta); }
.tmg-planner-pin-label { fill: #fff; font-size: 11px; font-family: var(--tmg-b-font); pointer-events: none; opacity: 0; transition: opacity .2s; }
.tmg-planner-pin:hover .tmg-planner-pin-label,
.tmg-planner-pin.is-on .tmg-planner-pin-label { opacity: 1; }

.tmg-planner-panel { padding: 20px; max-height: 600px; overflow-y: auto; }
.tmg-planner-panel header { margin-bottom: 12px; }
.tmg-planner-list { list-style: none; padding: 0; margin: 0 0 16px; display: grid; gap: 8px; }
.tmg-planner-list li {
	display: grid; grid-template-columns: 1fr auto; gap: 8px; align-items: center;
	padding: 10px 12px; background: rgba(255,255,255,.06); border-radius: 10px;
	color: #eef2f7;
}
.tmg-planner-empty { color: #93a3bb; font-style: italic; font-size: .9rem; }
.tmg-planner-list .tmg-planner-remove { background: transparent; border: 0; color: #fca5a5; cursor: pointer; padding: 0 4px; }
.tmg-planner-route-stats {
	display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
	background: rgba(249,115,22,.12); padding: 10px 14px; border-radius: 10px;
	color: #fed7aa; font-size: .9rem; margin-bottom: 16px;
}
.tmg-planner-route-stats strong { color: #fff; }
.tmg-planner-route-text { color: #fed7aa; opacity: .8; }
.tmg-planner-meta { display: grid; gap: 10px; margin-bottom: 16px; }
.tmg-planner-meta label { display: grid; gap: 4px; color: #c5d2e6; font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; }
.tmg-planner-meta input { padding: 8px 12px; background: rgba(255,255,255,.06); border: 1px solid rgba(255,255,255,.1); color: #fff; border-radius: 8px; outline: none; font: inherit; }
.tmg-planner-actions { display: flex; gap: 8px; flex-wrap: wrap; }

@media (max-width: 880px) {
	.tmg-planner-stage { grid-template-columns: 1fr; }
}

/* ---------- KIT CATALOG ---------- */
.tmg-kit-grid {
	display: grid; gap: 20px;
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.tmg-kit-card { display: flex; flex-direction: column; }
.tmg-kit-card-art { position: relative; aspect-ratio: 16/6; }
.tmg-kit-card-art svg { position: absolute; inset: 0; width: 100%; height: 100%; }
.tmg-kit-icon-badge {
	position: absolute; left: 16px; bottom: -22px;
	display: inline-grid; place-items: center;
	width: 48px; height: 48px;
	background: var(--tmg-surface);
	border: 1px solid var(--tmg-line);
	color: var(--tmg-primary);
	border-radius: 12px;
	box-shadow: var(--tmg-shadow-2);
}
.tmg-kit-count-chip {
	position: absolute; right: 16px; top: 16px;
	background: rgba(0,0,0,.55); color: #fff;
	padding: 4px 10px; border-radius: 999px; font-size: .8rem; font-weight: 600;
}
.tmg-kit-card-body { padding: 36px 20px 20px; }
.tmg-kit-card-name { margin: 0 0 6px; font-size: 1.15rem; }
.tmg-kit-card-summary { color: var(--tmg-muted); font-size: .92rem; margin: 0 0 14px; }
.tmg-kit-card-items { list-style: none; padding: 0; margin: 0 0 14px; display: grid; gap: 6px; font-size: .9rem; }
.tmg-kit-card-items svg { color: var(--tmg-accent); }
.tmg-kit-card-items a { color: var(--tmg-text); }
.tmg-kit-card-items a:hover { color: var(--tmg-cta); }

/* ---------- TODAY DETAILS / PLANNER MOBILE ---------- */
@media (max-width: 600px) {
	.tmg-adv-cta-row .tmg-btn { width: 100%; justify-content: center; }
}
