/* ==========================================================================
   ThermometerGuru — components.css
   Hero, modules, product boxes, kit cards, gear finder, comparison.
   ========================================================================== */

/* ---------- HERO ---------- */
.tmg-hero {
	min-height: 720px;
	padding: 110px 0 96px;
	position: relative;
	overflow: hidden;
}
.tmg-hero-sky, .tmg-hero-layer { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.tmg-hero-l1 { transform: translateY(0); }
.tmg-hero-l2 { transform: translateY(0); }
.tmg-hero-l3 { transform: translateY(0); }
.tmg-hero-particles { position: absolute; inset: 0; width: 100%; height: 100%; pointer-events: none; }
.tmg-hero-grid {
	display: grid; gap: 40px;
	grid-template-columns: 1.4fr 1fr;
	align-items: center; position: relative; z-index: 2;
}
.tmg-hero-eyebrow { color: #5cd1c9; }
.tmg-hero-headline {
	font-size: clamp(2.4rem, 4.5vw + 1rem, 4rem);
	color: #f7fafc; margin: 12px 0 16px;
	letter-spacing: -.015em;
}
.tmg-hero-headline .tmg-word {
	display: inline-block; opacity: 0; transform: translateY(.3em);
	transition: opacity .8s ease, transform .8s ease;
}
.tmg-hero-headline.is-revealed .tmg-word { opacity: 1; transform: none; }
.tmg-hero-sub {
	color: #c5d2e6; font-size: 1.15rem; max-width: 620px;
}
.tmg-hero-ctas { display: flex; gap: 16px; align-items: center; flex-wrap: wrap; margin: 24px 0 18px; }
.tmg-hero-cta2 { color: #c5d2e6; font-weight: 500; }
.tmg-hero-cta2:hover { color: var(--tmg-cta); }
.tmg-hero-trust { display: flex; gap: 22px; flex-wrap: wrap; color: #93a3bb; font-size: .88rem; }
.tmg-hero-trust span { display: inline-flex; align-items: center; gap: 6px; }

.tmg-hero-card {
	padding: 24px;
	max-width: 380px;
	margin-left: auto;
}
.tmg-hero-card-eyebrow { font-size: 11px; text-transform: uppercase; letter-spacing: .14em; color: #5cd1c9; }
.tmg-hero-card-name { color: #f7fafc; margin: 8px 0 4px; font-size: 1.6rem; }
.tmg-hero-card-tag { color: #c5d2e6; font-size: .92rem; margin: 0 0 16px; }
.tmg-hero-card-stats {
	display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
	margin: 0 0 16px;
}
.tmg-hero-card-stats > div { background: rgba(255,255,255,.05); padding: 10px 12px; border-radius: 12px; }
.tmg-hero-card-stats dt { font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: #93a3bb; }
.tmg-hero-card-stats dd { margin: 4px 0 0; color: #f7fafc; font-weight: 600; }
.tmg-hero-card-link { color: var(--tmg-cta); font-weight: 600; }

.tmg-hero-ticker {
	position: absolute; left: 0; right: 0; bottom: 0; z-index: 2;
	border-top: 1px solid rgba(255,255,255,.08);
	background: rgba(7,16,30,.55);
	padding: 12px 0; overflow: hidden;
}
.tmg-hero-ticker-track {
	display: inline-flex; gap: 28px;
	animation: tmg-marquee 32s linear infinite;
	white-space: nowrap;
}
.tmg-hero-tick { display: inline-flex; align-items: center; gap: 8px; color: #c5d2e6; font-size: .85rem; }
.tmg-hero-tick strong { color: #f7fafc; }
.tmg-tick-dot { width: 8px; height: 8px; border-radius: 50%; }
.tmg-tick-temp { color: var(--tmg-cta); }

@keyframes tmg-marquee {
	0% { transform: translateX(0); }
	100% { transform: translateX(-50%); }
}

/* ---------- QUICK START ---------- */
.tmg-quick-grid {
	display: grid; gap: 16px;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}
.tmg-quick-card {
	display: grid; gap: 8px;
	background: var(--tmg-surface); border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius);
	padding: 22px;
	text-align: left; cursor: pointer;
	transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
	color: var(--tmg-text);
}
.tmg-quick-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--tmg-shadow-3);
	border-color: var(--tmg-primary);
}
.tmg-quick-glyph {
	display: inline-grid; place-items: center;
	width: 48px; height: 48px;
	background: linear-gradient(135deg, var(--tmg-primary), var(--tmg-accent));
	color: #fff; border-radius: 12px;
}
.tmg-quick-title { font-size: 1.1rem; font-weight: 600; }
.tmg-quick-desc { color: var(--tmg-muted); font-size: .92rem; }
.tmg-quick-arrow { color: var(--tmg-cta); align-self: flex-end; }

/* ---------- CONTINUE PLANNING ---------- */
.tmg-continue { padding: 24px 0; }
.tmg-continue-card { padding: 28px; color: var(--tmg-text); }
.tmg-mode-dark .tmg-continue-card { color: var(--tmg-glass-text); }
.tmg-continue-head { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.tmg-continue-title { font-size: 1.6rem; margin: 0; }
.tmg-continue-chips { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 16px; }
.tmg-continue-chip {
	background: var(--tmg-surface-2); padding: 6px 12px; border-radius: 999px; font-size: .85rem;
	display: inline-flex; align-items: center; gap: 6px;
}
.tmg-continue-board { margin-bottom: 16px; }
.tmg-continue-board-label { color: var(--tmg-muted); font-size: .82rem; text-transform: uppercase; letter-spacing: .1em; }
.tmg-continue-board-list { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.tmg-continue-board-list a {
	background: var(--tmg-surface-2); padding: 4px 10px; border-radius: 8px;
	font-size: .85rem; color: var(--tmg-text);
}
.tmg-continue-progress { margin-bottom: 16px; }
.tmg-progress { height: 6px; border-radius: 999px; background: var(--tmg-surface-2); overflow: hidden; margin: 8px 0; }
.tmg-progress-bar {
	height: 100%; width: 0%;
	background: linear-gradient(90deg, var(--tmg-primary), var(--tmg-cta));
	transition: width .6s ease;
}
.tmg-continue-ctas { display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- PRODUCT BOXES ---------- */
.tmg-pbox {
	display: grid; grid-template-columns: 120px 1fr; gap: 18px;
	background: var(--tmg-surface); border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius);
	padding: 18px;
	position: relative;
	box-shadow: var(--tmg-shadow-2);
}
.tmg-pbox-art {
	background: linear-gradient(135deg, rgba(14,165,233,.1), rgba(20,184,166,.06));
	border-radius: 12px;
	display: grid; place-items: center;
	min-height: 120px;
}
.tmg-pbox-glyph { color: var(--tmg-primary); }
.tmg-pbox-name { margin: 0 0 6px; font-size: 1.1rem; }
.tmg-pbox-rating { display: flex; align-items: center; gap: 8px; font-size: .85rem; color: var(--tmg-muted); margin-bottom: 8px; }
.tmg-stars {
	display: inline-block; width: 80px; height: 14px;
	background:
		linear-gradient(90deg, var(--tmg-cta) var(--p, 0%), rgba(0,0,0,.1) var(--p, 0%));
	mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 14'><g fill='black'><polygon points='7,1 9,5 13,5 10,8 11,12 7,10 3,12 4,8 1,5 5,5'/><polygon points='23,1 25,5 29,5 26,8 27,12 23,10 19,12 20,8 17,5 21,5'/><polygon points='39,1 41,5 45,5 42,8 43,12 39,10 35,12 36,8 33,5 37,5'/><polygon points='55,1 57,5 61,5 58,8 59,12 55,10 51,12 52,8 49,5 53,5'/><polygon points='71,1 73,5 77,5 74,8 75,12 71,10 67,12 68,8 65,5 69,5'/></g></svg>") no-repeat;
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 14'><g fill='black'><polygon points='7,1 9,5 13,5 10,8 11,12 7,10 3,12 4,8 1,5 5,5'/><polygon points='23,1 25,5 29,5 26,8 27,12 23,10 19,12 20,8 17,5 21,5'/><polygon points='39,1 41,5 45,5 42,8 43,12 39,10 35,12 36,8 33,5 37,5'/><polygon points='55,1 57,5 61,5 58,8 59,12 55,10 51,12 52,8 49,5 53,5'/><polygon points='71,1 73,5 77,5 74,8 75,12 71,10 67,12 68,8 65,5 69,5'/></g></svg>") no-repeat;
}
.tmg-pbox-price { margin-left: auto; color: var(--tmg-cta); font-weight: 600; }
.tmg-pbox-specs { list-style: none; padding: 0; margin: 0 0 10px; display: grid; gap: 4px; font-size: .85rem; }
.tmg-pbox-specs li { display: flex; justify-content: space-between; gap: 8px; color: var(--tmg-muted); }
.tmg-pbox-specs strong { color: var(--tmg-text); }
.tmg-pbox-pros { list-style: none; padding: 0; margin: 0 0 12px; display: grid; gap: 4px; font-size: .9rem; }
.tmg-pbox-pros li { display: flex; align-items: center; gap: 6px; color: var(--tmg-muted); }
.tmg-pbox-pros svg { color: var(--tmg-accent); }
.tmg-pbox-verdict { font-size: .92rem; color: var(--tmg-text); margin: 0 0 12px; }
.tmg-pbox-badge {
	position: absolute; top: 12px; right: 12px;
	background: linear-gradient(135deg, var(--tmg-cta), #fb923c); color: #fff;
	font-size: .72rem; padding: 4px 10px; border-radius: 999px; font-weight: 600;
}
.tmg-pbox-compact { grid-template-columns: 1fr; }
.tmg-pbox-compact .tmg-pbox-art { min-height: 100px; }

/* ---------- KIT CARDS ---------- */
.tmg-kit { display: grid; grid-template-columns: 96px 1fr; gap: 16px; padding: 16px; background: var(--tmg-surface); border: 1px solid var(--tmg-line); border-radius: var(--tmg-radius); }
.tmg-kit-art { background: linear-gradient(135deg, var(--tmg-primary), var(--tmg-accent)); border-radius: 12px; display: grid; place-items: center; color: #fff; position: relative; }
.tmg-kit-glyph { color: #fff; }
.tmg-kit-count {
	position: absolute; bottom: 6px; left: 6px;
	background: rgba(255,255,255,.2); color: #fff;
	font-size: 11px; padding: 2px 6px; border-radius: 6px;
}
.tmg-kit-name { margin: 0 0 4px; font-size: 1.1rem; }
.tmg-kit-summary { color: var(--tmg-muted); font-size: .9rem; margin: 0 0 8px; }
.tmg-kit-items { list-style: none; padding: 0; margin: 0 0 12px; display: grid; gap: 4px; font-size: .9rem; }
.tmg-kit-items li { display: flex; align-items: center; gap: 6px; }
.tmg-kit-items svg { color: var(--tmg-accent); }

/* ---------- GEAR FINDER ---------- */
.tmg-gear-tabs {
	display: flex; gap: 8px; flex-wrap: wrap;
	margin: 0 0 28px; justify-content: center;
}
.tmg-gear-tab {
	background: var(--tmg-surface); border: 1px solid var(--tmg-line);
	padding: 10px 16px; border-radius: 999px;
	display: inline-flex; align-items: center; gap: 8px;
	font-weight: 500; color: var(--tmg-text);
	transition: background .2s ease, border-color .2s ease, color .2s ease;
}
.tmg-gear-tab:hover { color: var(--tmg-cta); border-color: var(--tmg-cta); }
.tmg-gear-tab.is-active {
	background: linear-gradient(135deg, var(--tmg-primary), var(--tmg-accent)); color: #fff; border-color: transparent;
}
.tmg-gear-panel { display: none; }
.tmg-gear-panel.is-active { display: block; animation: tmg-fadein .4s ease; }

@keyframes tmg-fadein { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }

/* ---------- COMPARISON ---------- */
.tmg-compare-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin: 0 0 16px; justify-content: center; }
.tmg-compare-tab {
	background: var(--tmg-surface); border: 1px solid var(--tmg-line);
	padding: 8px 14px; border-radius: 999px; color: var(--tmg-text);
}
.tmg-compare-tab.is-active { background: var(--tmg-dark); color: #fff; border-color: var(--tmg-dark); }
.tmg-compare-panel { display: none; }
.tmg-compare-panel.is-active { display: block; animation: tmg-fadein .4s ease; }
.tmg-compare-table {
	width: 100%; border-collapse: collapse; background: var(--tmg-surface);
	border-radius: var(--tmg-radius); overflow: hidden; box-shadow: var(--tmg-shadow-2);
}
.tmg-compare-table th, .tmg-compare-table td {
	padding: 14px 12px; text-align: left; border-bottom: 1px solid var(--tmg-line);
	font-size: .92rem;
}
.tmg-compare-table th { background: var(--tmg-surface-2); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; color: var(--tmg-muted); }
.tmg-compare-table tr.is-editor {
	background: linear-gradient(90deg, rgba(249,115,22,.06), rgba(14,165,233,.04));
}
.tmg-compare-table tr.is-editor td { font-weight: 600; }
.tmg-compare-add {
	background: transparent; border: 1px solid var(--tmg-line);
	padding: 6px 10px; border-radius: 999px; font-size: .8rem; color: var(--tmg-text);
}
.tmg-compare-add:hover { background: var(--tmg-surface-2); }
.tmg-compare-add.is-on { background: var(--tmg-primary); color: #fff; border-color: transparent; }

.tmg-compare-rail {
	position: fixed; top: 120px; right: 16px;
	width: 260px; padding: 16px;
	background: var(--tmg-surface); border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius); box-shadow: var(--tmg-shadow-3);
	z-index: 30;
	display: none;
	opacity: 0;
	transform: translateY(-6px);
	transition: opacity .25s ease, transform .25s ease;
}
@media (min-width: 1280px) {
	/* Show only after the user has actually saved at least one item — otherwise
	 * the empty rail crowds the hero. JS toggles `.is-active` from the
	 * comparison engine in theme.js. */
	.tmg-compare-rail.is-active {
		display: block;
		opacity: 1;
		transform: none;
	}
}
.tmg-compare-rail header { display: flex; align-items: center; gap: 8px; margin-bottom: 12px; }
.tmg-compare-rail ul { list-style: none; padding: 0; margin: 0 0 12px; display: grid; gap: 6px; font-size: .85rem; }
.tmg-compare-rail li { display: flex; justify-content: space-between; gap: 8px; padding: 6px 8px; background: var(--tmg-surface-2); border-radius: 8px; }
.tmg-compare-empty { color: var(--tmg-muted); font-style: italic; }

/* Refined compare drawer — non-blocking, dismissible.
   Desktop: bottom-right slide-in panel.
   Mobile : bottom sheet (full width). */
.tmg-compare-drawer {
	position: fixed;
	right: 16px; bottom: 16px;
	left: auto;
	width: min(360px, calc(100vw - 32px));
	background: var(--tmg-surface);
	border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius);
	padding: 14px 16px;
	box-shadow: var(--tmg-shadow-3);
	z-index: 40;
	transform: translateY(20px);
	opacity: 0;
	transition: transform .3s ease, opacity .3s ease;
	pointer-events: none;
}
.tmg-compare-drawer:not([hidden]) {
	transform: translateY(0);
	opacity: 1;
	pointer-events: auto;
}
.tmg-compare-drawer header {
	display: flex; align-items: center; justify-content: space-between; gap: 8px;
	margin-bottom: 10px;
}
.tmg-compare-drawer header strong { display: inline-flex; align-items: center; gap: 6px; font-size: .92rem; }
.tmg-compare-drawer-close {
	background: transparent; border: 0; color: var(--tmg-muted);
	font-size: 1.4rem; line-height: 1; cursor: pointer;
	padding: 4px 8px; border-radius: 8px;
}
.tmg-compare-drawer-close:hover { background: var(--tmg-surface-2); color: var(--tmg-text); }
.tmg-compare-drawer ul {
	list-style: none; padding: 0; margin: 0 0 10px;
	display: flex; gap: 6px; flex-wrap: wrap; font-size: .8rem;
}
.tmg-compare-drawer li {
	background: var(--tmg-surface-2); padding: 4px 8px 4px 10px;
	border-radius: 999px; display: inline-flex; align-items: center; gap: 4px;
}
.tmg-compare-drawer li button {
	background: transparent; border: 0; cursor: pointer;
	color: var(--tmg-muted); font-size: 1rem; padding: 0 4px; border-radius: 999px;
}
.tmg-compare-drawer li button:hover { color: var(--tmg-cta); }

@media (max-width: 600px) {
	.tmg-compare-drawer {
		right: 8px; left: 8px; bottom: 8px;
		width: auto;
		border-radius: 14px 14px var(--tmg-radius) var(--tmg-radius);
	}
}
@media (max-width: 800px) {
	/* Don't double up with the article sticky CTA. */
	body.single .tmg-compare-drawer { display: none; }
}

/* Inline visual comparison — replaces the old modal. Lives in-flow. */
.tmg-compare-inline {
	margin-top: 32px;
	background: var(--tmg-surface);
	border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius);
	box-shadow: var(--tmg-shadow-2);
	overflow: hidden;
	animation: tmg-fadein .3s ease;
}
.tmg-compare-inline-head {
	display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
	padding: 18px 22px;
	border-bottom: 1px solid var(--tmg-line);
	background: linear-gradient(180deg, var(--tmg-surface), transparent);
}
.tmg-compare-inline-head h3 { margin: 0; font-size: 1.25rem; flex: 1; }
.tmg-compare-inline-close {
	background: transparent; border: 1px solid var(--tmg-line);
	padding: 6px 12px; border-radius: 999px; cursor: pointer;
	font-size: .82rem; color: var(--tmg-muted);
}
.tmg-compare-inline-close:hover { color: var(--tmg-text); border-color: var(--tmg-text); }
.tmg-compare-inline-body { padding: 22px; }
.tmg-cmp-grid {
	display: grid;
	grid-template-columns: repeat(var(--cols, 2), minmax(0, 1fr));
	gap: 16px;
}
.tmg-cmp-col {
	background: var(--tmg-surface-2);
	border-radius: 14px;
	padding: 16px;
	display: flex; flex-direction: column; gap: 12px;
}
.tmg-cmp-col header { display: flex; align-items: flex-start; justify-content: space-between; gap: 8px; }
.tmg-cmp-col h4 { margin: 0; font-size: 1.05rem; line-height: 1.3; }
.tmg-cmp-col-rm {
	background: transparent; border: 0; cursor: pointer;
	color: var(--tmg-muted); font-size: 1.2rem; line-height: 1;
	padding: 2px 8px; border-radius: 8px;
}
.tmg-cmp-col-rm:hover { color: var(--tmg-cta); background: rgba(0,0,0,.04); }
.tmg-cmp-col-rows { display: grid; gap: 8px; }
.tmg-cmp-row {
	display: grid; gap: 4px;
	padding: 8px 10px;
	background: var(--tmg-surface);
	border-radius: 10px;
}
.tmg-cmp-row > span {
	font-size: .72rem; text-transform: uppercase; letter-spacing: .12em;
	color: var(--tmg-muted);
}
.tmg-cmp-row > div { font-size: .92rem; }

@media (max-width: 720px) {
	.tmg-cmp-grid { grid-template-columns: 1fr; }
}

/* ---------- CARDS / EMPTY ---------- */
.tmg-empty { text-align: center; padding: 40px 0; color: var(--tmg-muted); }
.tmg-pagination { display: flex; justify-content: center; padding: 32px 0; }

/* ---------- WIDGETS ---------- */
.tmg-widget { padding: 16px; background: var(--tmg-surface); border: 1px solid var(--tmg-line); border-radius: var(--tmg-radius); margin-bottom: 16px; }
.tmg-widget .widget-title { margin: 0 0 12px; font-size: 1rem; }

/* ---------- TAGS ---------- */
.tmg-tags { display: flex; flex-wrap: wrap; gap: 6px; margin: 24px 0; }
.tmg-tag { background: var(--tmg-surface-2); padding: 4px 10px; border-radius: 999px; font-size: .8rem; color: var(--tmg-muted); }

/* ---------- AUTHOR / BYLINE ---------- */
.tmg-byline { display: grid; gap: 12px; margin-top: 18px; }
.tmg-byline-author { display: flex; align-items: center; gap: 12px; }
.tmg-avatar, .tmg-avatar-lg { border-radius: 50%; }
.tmg-byline-role { color: var(--tmg-muted); font-size: .85rem; display: block; }
.tmg-byline-meta { list-style: none; padding: 0; margin: 0; display: flex; gap: 14px; flex-wrap: wrap; color: var(--tmg-muted); font-size: .85rem; }
.tmg-byline-meta li { display: inline-flex; align-items: center; gap: 4px; }
.tmg-byline-trust {
	display: flex; gap: 16px; flex-wrap: wrap;
	font-size: .85rem; color: var(--tmg-muted);
	border-top: 1px dashed var(--tmg-line); padding-top: 12px;
}
.tmg-author-bio {
	display: grid; grid-template-columns: 96px 1fr; gap: 24px;
	background: var(--tmg-surface-2); padding: 24px;
	border-radius: var(--tmg-radius); margin: 32px 0;
}
.tmg-author-stats { list-style: none; padding: 0; margin: 8px 0; display: flex; gap: 18px; flex-wrap: wrap; font-size: .9rem; color: var(--tmg-muted); }
.tmg-author-stats strong { color: var(--tmg-text); }
.tmg-author-link { color: var(--tmg-cta); font-weight: 600; }

/* ---------- SAFETY ---------- */
.tmg-safety {
	display: grid; grid-template-columns: 32px 1fr; gap: 12px;
	background: linear-gradient(135deg, rgba(14,165,233,.06), rgba(249,115,22,.05));
	border: 1px solid rgba(14,165,233,.2);
	border-radius: 12px; padding: 14px 16px; margin: 24px 0;
	font-size: .92rem;
}
.tmg-safety-glyph { color: var(--tmg-primary); }
.tmg-safety-body strong { color: var(--tmg-cta); }

/* ---------- INTERNAL CALLOUT ---------- */
.tmg-keepreading {
	border-left: 4px solid var(--tmg-primary);
	background: linear-gradient(90deg, rgba(14,165,233,.06), transparent);
	padding: 14px 18px; border-radius: 0 12px 12px 0;
	margin: 32px 0; display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
}
.tmg-kr-eyebrow { font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; color: var(--tmg-muted); }
.tmg-kr-link { color: var(--tmg-primary); font-weight: 600; }

.tmg-internal { color: var(--tmg-primary); border-bottom: 1px dashed currentColor; }

/* ---------- TOC ---------- */
.tmg-toc { background: var(--tmg-surface-2); padding: 16px; border-radius: 12px; position: sticky; top: 96px; }
.tmg-toc-eyebrow { font-size: .78rem; text-transform: uppercase; letter-spacing: .12em; color: var(--tmg-muted); display: block; margin-bottom: 8px; }
.tmg-toc-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; font-size: .9rem; }
.tmg-toc-list a { color: var(--tmg-text); }
.tmg-toc-list a.is-active { color: var(--tmg-primary); font-weight: 600; }

/* ---------- SIDEPICK ---------- */
.tmg-sidepick {
	background: linear-gradient(160deg, rgba(14,165,233,.08), rgba(20,184,166,.05));
	border: 1px solid var(--tmg-line);
	padding: 18px; border-radius: var(--tmg-radius);
	margin-top: 16px;
	text-align: center;
}
.tmg-sidepick-eyebrow { font-size: .72rem; letter-spacing: .14em; text-transform: uppercase; color: var(--tmg-cta); }
.tmg-sidepick-name { margin: 6px 0 12px; font-size: 1.05rem; }
.tmg-sidepick-glyph { color: var(--tmg-primary); display: grid; place-items: center; padding: 12px; }
.tmg-sidepick-line { font-size: .85rem; color: var(--tmg-muted); }

/* ---------- 404 ---------- */
.tmg-404-card { max-width: 560px; margin: 80px auto; text-align: center; padding: 40px; background: var(--tmg-surface); border-radius: var(--tmg-radius); box-shadow: var(--tmg-shadow-3); }
.tmg-404-glyph { color: var(--tmg-primary); display: inline-grid; place-items: center; }
.tmg-404-title { margin: 12px 0; }
.tmg-404-sub { color: var(--tmg-muted); margin-bottom: 16px; }
.tmg-404-links { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; margin-top: 16px; }

/* ---------- COMMENTS ---------- */
.tmg-comments { margin-top: 48px; padding-top: 32px; border-top: 1px solid var(--tmg-line); }
.tmg-comments-title { margin: 0 0 16px; }
.tmg-commentlist { list-style: none; padding: 0; margin: 0; display: grid; gap: 16px; }
.tmg-commentlist .comment { background: var(--tmg-surface); padding: 16px; border-radius: 12px; border: 1px solid var(--tmg-line); }

/* ---------- ARCHIVE HEAD ---------- */
.tmg-archive-head { text-align: center; max-width: 720px; margin: 0 auto 32px; }
.tmg-archive-title { font-size: clamp(2rem, 4vw + .5rem, 3rem); }
.tmg-archive-sub { color: var(--tmg-muted); }

/* ---------- CARD-POST ---------- */
.tmg-card-post {
	background: var(--tmg-surface);
	border: 1px solid var(--tmg-line);
	border-radius: var(--tmg-radius);
	overflow: hidden;
	transition: transform .2s ease, box-shadow .2s ease;
}
.tmg-card-post:hover { transform: translateY(-3px); box-shadow: var(--tmg-shadow-3); }
.tmg-card-link { display: block; color: var(--tmg-text); }
.tmg-card-media { position: relative; aspect-ratio: 4/3; background: linear-gradient(135deg, rgba(14,165,233,.15), rgba(20,184,166,.1)); display: grid; place-items: center; overflow: hidden; }
.tmg-card-img { width: 100%; height: 100%; object-fit: cover; transition: transform .4s ease; }
.tmg-card-post:hover .tmg-card-img { transform: scale(1.05); }
.tmg-card-glyph { color: var(--tmg-primary); }
.tmg-card-tag { position: absolute; top: 12px; left: 12px; background: rgba(0,0,0,.55); color: #fff; padding: 4px 10px; border-radius: 999px; font-size: .75rem; }
.tmg-card-body { padding: 18px; }
.tmg-card-title { margin: 0 0 8px; font-size: 1.15rem; }
.tmg-card-dek { color: var(--tmg-muted); font-size: .92rem; margin: 0 0 12px; }
.tmg-card-meta { display: flex; gap: 12px; color: var(--tmg-muted); font-size: .82rem; }
.tmg-card-meta span { display: inline-flex; align-items: center; gap: 4px; }

/* ---------- BADGES ---------- */
.tmg-badges { list-style: none; padding: 0; margin: 16px 0; display: flex; gap: 8px; flex-wrap: wrap; }
.tmg-badge {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 12px; border-radius: 999px;
	background: var(--tmg-surface-2); color: var(--tmg-text);
	font-size: .82rem; font-weight: 500;
	border: 1px solid var(--tmg-line);
}
.tmg-badge-glyph { color: var(--tmg-cta); display: inline-grid; place-items: center; }
.tmg-section-cinematic .tmg-badge { background: rgba(255,255,255,.06); color: #eef2f7; border-color: rgba(255,255,255,.1); }

/* ---------- ENV CARD MINI (shortcode) ---------- */
.tmg-env-card-mini {
	display: grid; gap: 4px;
	background: var(--tmg-surface-2);
	padding: 14px; border-radius: 12px;
	border-left: 4px solid var(--tmg-primary);
	margin: 16px 0;
}
.tmg-env-temp { color: var(--tmg-cta); font-weight: 600; }
