/* ==========================================================================
   Tools page-specific styles + small enhancements for engagement micro-apps.
   ========================================================================== */

.stg-tools-page__hero { padding: 80px 0 32px; background: linear-gradient(180deg, var(--stg-bg-soft), #fff); text-align: center; }
.stg-tools-page__hero h1 { margin: 8px 0 12px; }
.stg-tools-page__hero p  { color: var(--stg-text-2); max-width: 720px; margin: 0 auto; }

.stg-tools-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: 18px; padding: 48px 0; }
.stg-tools-card {
	background: #fff; border: 1px solid var(--stg-line); border-radius: var(--stg-radius);
	padding: 22px; display: flex; flex-direction: column; gap: 10px;
	transition: transform .2s var(--stg-easing), box-shadow .2s var(--stg-easing), border-color .2s var(--stg-easing);
}
.stg-tools-card:hover { transform: translateY(-3px); border-color: var(--stg-primary); box-shadow: var(--stg-shadow-2); }
.stg-tools-card__icon { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; background: linear-gradient(135deg, var(--stg-primary), var(--stg-secondary)); color: #fff; }
.stg-tools-card h3 { margin: 0; font-size: 1.05rem; }
.stg-tools-card p { color: var(--stg-text-2); font-size: .92rem; margin: 0 0 8px; }
.stg-tools-card a { font-weight: 600; color: var(--stg-primary); margin-top: auto; }

/* Compare drawer (used by the comparison widget) */
.stg-compare-drawer {
	position: fixed; bottom: 16px; left: 50%; transform: translate(-50%, calc(100% + 32px));
	background: #fff; border-radius: 999px; padding: 10px 18px; box-shadow: var(--stg-shadow-3);
	display: flex; align-items: center; gap: 14px; z-index: 70; transition: transform .25s var(--stg-easing);
	border: 1px solid var(--stg-line);
}
.stg-compare-drawer.is-open { transform: translate(-50%, 0); }
.stg-compare-drawer__count { background: var(--stg-primary); color: #fff; padding: 4px 10px; border-radius: 999px; font-size: .82rem; font-weight: 700; }

/* Resort visualizer pin pop */
.stg-vis-pin-tooltip {
	position: absolute;
	background: #fff; padding: 10px 12px; border-radius: 12px; box-shadow: var(--stg-shadow-2); border: 1px solid var(--stg-line);
	font-size: .82rem; line-height: 1.4; pointer-events: none; z-index: 5; max-width: 220px;
}
.stg-vis-pin-tooltip strong { display: block; font-size: .9rem; }

/* Quiz result palette by archetype */
.stg-quiz__result[data-archetype="powder"]      .stg-quiz__result-icon { background: linear-gradient(135deg, #5cd1c9, #1f6feb); }
.stg-quiz__result[data-archetype="park"]        .stg-quiz__result-icon { background: linear-gradient(135deg, #ff6b3d, #fbbf24); }
.stg-quiz__result[data-archetype="all-mountain"].stg-quiz__result-icon { background: linear-gradient(135deg, #1f6feb, #6c5ce7); }
.stg-quiz__result[data-archetype="backcountry"] .stg-quiz__result-icon { background: linear-gradient(135deg, #0b1f3a, #5cd1c9); }
.stg-quiz__result[data-archetype="beginner"]    .stg-quiz__result-icon { background: linear-gradient(135deg, #5cd1c9, #34d399); }

/* Toast */
.stg-toast { position: fixed; left: 50%; bottom: 28px; transform: translate(-50%, 80px); background: var(--stg-dark); color: #fff; padding: 12px 20px; border-radius: 999px; font-size: .9rem; box-shadow: var(--stg-shadow-3); z-index: 90; transition: transform .25s var(--stg-easing); }
.stg-toast.is-on { transform: translate(-50%, 0); }

/* Save state on snow card */
.stg-snow__card.is-watching .stg-snow__powder-bar span { background: linear-gradient(90deg, var(--stg-accent), #fff); }
.stg-snow__card.is-watching [data-snow-watch] { background: var(--stg-accent); border-color: var(--stg-accent); color: #fff; }
