/* ============================================================
 * Tower Speakers · elite.css
 * Article + room + scorecard radar + monthly chart + storytelling.
 * Swipeable carousels, badges, comparison slider modal.
 * ============================================================ */

/* Article hero */
.tsp-article__hero { padding: 80px 0 30px; position: relative; }
.tsp-article__meta-top { display: flex; gap: 14px; align-items: center; font-size: 13px; color: var(--tsp-c-ink-3); margin-bottom: 14px; }
.tsp-article__category { color: var(--tsp-c-primary); font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; font-size: 11px; }
.tsp-article__reading { display: inline-flex; align-items: center; gap: 6px; }
.tsp-article__title { font-size: clamp(2rem, 4.5vw, 3.4rem); }
.tsp-article__lede { color: var(--tsp-c-ink-2); font-size: 19px; max-width: 760px; margin-top: 10px; }
.tsp-article__thumb { margin: 30px 0 0; max-height: 580px; overflow: hidden; border-radius: var(--tsp-radius); }
.tsp-article__thumb img { width: 100%; height: auto; }

.tsp-article__shell { display: grid; grid-template-columns: 1fr 320px; gap: 50px; padding: 40px 24px; }
@media (max-width: 1000px) { .tsp-article__shell { grid-template-columns: 1fr; } .tsp-article__aside { display: none; } }

/* Author byline + badges */
.tsp-byline { display: flex; align-items: center; gap: 12px; margin: 14px 0; }
.tsp-byline__avatar { width: 44px; height: 44px; border-radius: 50%; overflow: hidden; }
.tsp-byline__name { font-weight: 600; color: var(--tsp-c-ink); }
.tsp-byline__role { font-size: 13px; color: var(--tsp-c-ink-3); }
.tsp-badges { display: flex; gap: 8px; flex-wrap: wrap; margin: 14px 0; }
.tsp-badge { display: inline-flex; align-items: center; gap: 6px; padding: 6px 12px; border-radius: 999px; background: rgba(212,175,55,0.10); color: var(--tsp-c-primary); font-size: 12px; font-weight: 600; border: 1px solid rgba(212,175,55,0.30); }

/* Sidebar TOC */
.tsp-toc { padding: 22px; background: rgba(255,255,255,0.03); border: 1px solid var(--tsp-c-line); border-radius: var(--tsp-radius); }
.tsp-toc h4 { font-size: 12px; text-transform: uppercase; color: var(--tsp-c-primary); letter-spacing: 0.12em; margin: 0 0 12px; }
.tsp-toc ol { list-style: none; padding: 0; margin: 0; counter-reset: tsp-toc; display: grid; gap: 6px; font-size: 14px; }
.tsp-toc li { counter-increment: tsp-toc; }
.tsp-toc li::before { content: counter(tsp-toc, decimal-leading-zero); margin-right: 8px; color: var(--tsp-c-primary); font-weight: 700; }
.tsp-toc a { color: var(--tsp-c-ink-2); }
.tsp-toc a:hover { color: var(--tsp-c-primary); }

/* Article tags + author bio */
.tsp-tags { display: flex; gap: 8px; flex-wrap: wrap; margin: 30px 0; }
.tsp-tags a { padding: 4px 10px; background: rgba(255,255,255,0.04); border: 1px solid var(--tsp-c-line); border-radius: 999px; color: var(--tsp-c-ink-2); font-size: 12px; }
.tsp-author-bio { display: grid; grid-template-columns: 80px 1fr; gap: 20px; padding: 24px; background: rgba(255,255,255,0.03); border-radius: var(--tsp-radius); border: 1px solid var(--tsp-c-line); margin: 30px 0; }
.tsp-author-bio__avatar img { width: 80px; height: 80px; border-radius: 50%; object-fit: cover; }
.tsp-author-bio__name { font-family: var(--tsp-font-h); font-size: 1.2rem; }
.tsp-author-bio__certs { font-size: 13px; color: var(--tsp-c-primary); margin: 4px 0 8px; }
.tsp-author-bio__stats { display: flex; gap: 16px; font-size: 13px; color: var(--tsp-c-ink-3); margin-top: 10px; }

/* Related posts */
.tsp-related-posts { margin: 50px 0; }
.tsp-related-posts h3 { color: var(--tsp-c-ink); margin: 0 0 18px; }
.tsp-related-posts__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
@media (max-width: 800px) { .tsp-related-posts__grid { grid-template-columns: 1fr; } }

/* Single room */
.tsp-room-hero { padding: 80px 0 40px; position: relative; overflow: hidden; }
.tsp-room-hero__inner { display: grid; grid-template-columns: 1.5fr 1fr; gap: 40px; align-items: center; }
.tsp-room-hero__title { font-size: clamp(2.4rem, 5vw, 3.8rem); }
.tsp-room-hero__tag { color: var(--tsp-c-ink-2); font-size: 18px; }
.tsp-room-hero__stats { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin: 20px 0; padding: 0; }
.tsp-room-hero__stats div { padding: 12px 14px; background: rgba(255,255,255,0.04); border: 1px solid var(--tsp-c-line); border-radius: 10px; }
.tsp-room-hero__stats dt { font-size: 11px; color: var(--tsp-c-ink-3); letter-spacing: 0.1em; text-transform: uppercase; margin: 0; }
.tsp-room-hero__stats dd { margin: 4px 0 0; color: var(--tsp-c-ink); font-weight: 600; }
.tsp-room-hero__art { aspect-ratio: 1.2/1; border-radius: var(--tsp-radius); overflow: hidden; }
@media (max-width: 1000px) { .tsp-room-hero__inner { grid-template-columns: 1fr; } }

/* Scorecard radar */
.tsp-scorecard { padding: 30px; }
.tsp-scorecard__h { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
.tsp-scorecard__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 30px; align-items: center; }
.tsp-scorecard__radar { aspect-ratio: 1; }
.tsp-scorecard__radar svg { width: 100%; height: 100%; }
.tsp-scorecard__bars { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.tsp-scorecard__bars li { display: grid; grid-template-columns: 100px 1fr 50px; gap: 10px; align-items: center; font-size: 13px; }
.tsp-scorecard__label { color: var(--tsp-c-ink-2); }
.tsp-scorecard__bar  { height: 6px; background: rgba(255,255,255,0.06); border-radius: 999px; overflow: hidden; }
.tsp-scorecard__bar-fill { height: 100%; background: var(--tsp-grad-gold); width: 0; transition: width 1s ease; box-shadow: 0 0 8px rgba(212,175,55,0.4); }
.tsp-scorecard__val { color: var(--tsp-c-primary); font-weight: 700; text-align: right; }
@media (max-width: 800px) { .tsp-scorecard__grid { grid-template-columns: 1fr; } }

/* Monthly chart */
.tsp-chart { padding: 30px; }
.tsp-chart__h { display: flex; justify-content: space-between; align-items: center; margin-bottom: 18px; }
.tsp-chart__bars { display: grid; grid-template-columns: repeat(12, 1fr); gap: 10px; align-items: end; height: 180px; padding-bottom: 24px; border-bottom: 1px solid var(--tsp-c-line); }
.tsp-chart__bar { height: 0; background: linear-gradient(180deg, var(--tsp-c-primary), var(--tsp-c-cta)); border-radius: 4px 4px 0 0; position: relative; transition: height 1s cubic-bezier(0.16, 1, 0.3, 1); }
.tsp-chart__bar.is-peak { box-shadow: 0 0 16px rgba(255,107,61,0.6); }
.tsp-chart__bar small { position: absolute; left: 50%; bottom: -22px; transform: translateX(-50%); font-size: 11px; color: var(--tsp-c-ink-3); }
.tsp-chart__legend { display: flex; justify-content: space-between; margin-top: 6px; font-size: 12px; color: var(--tsp-c-ink-3); }

/* Storytelling */
.tsp-story { padding: 30px; display: grid; gap: 30px; }
.tsp-story__quote { padding: 24px; background: rgba(0,0,0,0.30); border-left: 3px solid var(--tsp-c-primary); border-radius: 12px; }
.tsp-story__quote p { font-family: var(--tsp-font-h); font-size: 1.4rem; color: var(--tsp-c-ink); font-style: italic; line-height: 1.4; margin: 0 0 12px; }
.tsp-story__cite { font-size: 14px; color: var(--tsp-c-ink-3); }
.tsp-story__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.tsp-story__cell { padding: 18px; background: rgba(255,255,255,0.03); border: 1px solid var(--tsp-c-line); border-radius: 12px; }
.tsp-story__cell h4 { font-size: 13px; color: var(--tsp-c-primary); text-transform: uppercase; letter-spacing: 0.1em; margin: 0 0 8px; }
.tsp-story__tips { list-style: none; padding: 0; margin: 0; display: grid; gap: 6px; font-size: 14px; }
.tsp-story__tips li { display: flex; align-items: flex-start; gap: 8px; color: var(--tsp-c-ink); }
.tsp-story__tips svg { color: var(--tsp-c-primary); flex-shrink: 0; }
@media (max-width: 800px) { .tsp-story__grid { grid-template-columns: 1fr; } }

/* Travel logistics 6-up */
.tsp-logistics { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; padding: 0; }
.tsp-logistics div { padding: 16px 18px; background: rgba(255,255,255,0.04); border: 1px solid var(--tsp-c-line); border-radius: 10px; }
.tsp-logistics dt { font-size: 11px; color: var(--tsp-c-ink-3); text-transform: uppercase; letter-spacing: 0.1em; margin: 0; }
.tsp-logistics dd { margin: 4px 0 0; color: var(--tsp-c-ink); font-weight: 600; font-size: 14px; }
@media (max-width: 700px) { .tsp-logistics { grid-template-columns: 1fr 1fr; } }

/* Comparison modal slider */
.tsp-compare__modal-stage > div { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 18px; }
.tsp-compare__card { padding: 22px; background: var(--tsp-glass); border: 1px solid var(--tsp-glass-bd); border-radius: var(--tsp-radius); }

/* Swipeable carousel for mobile */
@media (max-width: 800px) {
	.tsp-swipe { display: flex; overflow-x: auto; scroll-snap-type: x mandatory; gap: 14px; padding-bottom: 16px; -webkit-overflow-scrolling: touch; }
	.tsp-swipe > * { flex: 0 0 84%; scroll-snap-align: start; }
	.tsp-swipe-dots { display: flex; gap: 6px; justify-content: center; margin-top: 10px; }
	.tsp-swipe-dots span { width: 8px; height: 8px; border-radius: 50%; background: var(--tsp-c-line); transition: all .3s; }
	.tsp-swipe-dots span.is-active { background: var(--tsp-c-primary); width: 24px; border-radius: 999px; }
}
