/* Base */
:root {
	--bg: #0f172a;
	--panel: #111827;
	--panel-alt: #0b1220;
	--text: #e5e7eb;
	--muted: #9ca3af;
	--brand: #00d4ff;
	--brand-2: #7c3aed;
	--accent: #22c55e;
	--danger: #ef4444;
	--card: #111827;
	--border: #1f2937;
	--shadow: 0 10px 30px rgba(0,0,0,0.35);
}
* { box-sizing: border-box; }
html, body { height: 100%; }
body {
	margin: 0;
	font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial, "Noto Sans", "Apple Color Emoji", "Segoe UI Emoji";
	background: radial-gradient(1200px 800px at 10% 10%, #0b1020 0%, #0a0f1e 35%, #070b15 100%);
	color: var(--text);
}

/* Header */
.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	background: linear-gradient(180deg, rgba(7,11,21,0.9), rgba(7,11,21,0.6) 70%, rgba(7,11,21,0));
	backdrop-filter: saturate(1.2) blur(8px);
	border-bottom: 1px solid var(--border);
}
.logo { font-weight: 800; letter-spacing: 0.3px; padding: 18px 24px; font-size: 20px; }
.top-nav { padding: 0 24px 14px; color: var(--muted); }

/* Layout */
.layout {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 24px;
	padding: 24px;
	max-width: 1200px;
	margin: 0 auto;
}
.content { display: grid; gap: 20px; }
.sidebar { display: grid; gap: 20px; align-content: start; }

@media (max-width: 980px) {
	.layout { grid-template-columns: 1fr; }
	.sidebar { order: -1; }
}

/* Panels */
.filters, .results, .carousel, .ad-slot {
	background: linear-gradient(180deg, var(--panel), var(--panel-alt));
	border: 1px solid var(--border);
	border-radius: 14px;
	box-shadow: var(--shadow);
}

/* Carousel */
.carousel { position: relative; overflow: hidden; }
.carousel-track { display: flex; scroll-behavior: smooth; overflow: hidden; }
.carousel-card {
	min-width: 100%;
	padding: 18px;
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 14px;
	align-items: center;
}
.carousel-card .route { font-size: 24px; font-weight: 700; }
.carousel-card .meta { color: var(--muted); }
.carousel-card .price { font-size: 22px; color: var(--accent); font-weight: 700; }
.carousel-card figure { margin: 0; }
.carousel-card img { width: 100%; height: 180px; object-fit: cover; border-radius: 10px; border: 1px solid var(--border); }

.carousel-btn {
	position: absolute; top: 50%; transform: translateY(-50%);
	background: rgba(0,0,0,0.4); color: #fff; border: 1px solid var(--border);
	width: 38px; height: 38px; border-radius: 50%; cursor: pointer;
}
.carousel-btn:hover { background: rgba(0,0,0,0.6); }
.carousel-btn.prev { left: 10px; }
.carousel-btn.next { right: 10px; }
.carousel-dots { display: flex; gap: 6px; justify-content: center; padding: 10px 0 14px; }
.carousel-dots button { width: 8px; height: 8px; border-radius: 50%; border: none; background: #334155; }
.carousel-dots button.active { background: var(--brand); }

@media (max-width: 640px) {
	.carousel-card { grid-template-columns: 1fr; }
}

/* Filters */
.filters { padding: 16px; display: grid; grid-template-columns: repeat(6, 1fr); gap: 12px; align-items: end; }
.filter-group { display: grid; gap: 6px; }
.filter-group label { color: var(--muted); font-size: 12px; }
.filters select, .filters input { background: #0b1220; color: var(--text); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; }
.filter-actions { display: flex; gap: 8px; }
button { background: linear-gradient(180deg, #1f2937, #0f172a); color: var(--text); border: 1px solid var(--border); border-radius: 10px; padding: 10px 14px; cursor: pointer; }
button.secondary { background: #0b1220; }
button:hover { border-color: #334155; }

@media (max-width: 980px) {
	.filters { grid-template-columns: repeat(2, 1fr); }
}

/* Results */
.results { padding: 10px 0 0; }
.results-header { display: flex; justify-content: space-between; align-items: center; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.muted { color: var(--muted); }
.results-list { list-style: none; margin: 0; padding: 0; }
.result-item { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr 1fr; gap: 10px; align-items: center; padding: 14px 16px; border-bottom: 1px solid var(--border); }
.result-item:hover { background: rgba(255,255,255,0.02); }
.badge { background: #0b1220; border: 1px solid var(--border); border-radius: 999px; padding: 4px 10px; font-size: 12px; color: var(--muted); }
.buy-btn { background: linear-gradient(180deg, var(--brand), var(--brand-2)); color: #000; font-weight: 700; border: none; }

@media (max-width: 780px) {
	.result-item { grid-template-columns: 1fr 1fr; grid-template-areas: "route price" "meta action"; }
}

/* Ads */
.ad-slot { min-height: 120px; padding: 10px; display: grid; place-items: center; }
.ad { width: 100%; height: 100%; display: block; border-radius: 12px; overflow: hidden; border: 1px solid var(--border); }
.ad img { display: block; width: 100%; height: auto; }
.ad.html { background: #0b1220; color: var(--text); padding: 14px; }
.ad a { color: inherit; text-decoration: none; display: block; height: 100%; }

/* Footer */
.site-footer { padding: 18px 24px; color: var(--muted); border-top: 1px solid var(--border); margin-top: 20px; } 

/* Sponsored / Ad labels
   -------------------------------------------------- */
.result-item[data-sponsored="true"],
.ad-slot,
.carousel-card[data-sponsored="true"] {
  position: relative; /* anchor pseudo-badges */
}

/* Results list: "Sponsored" pill (top-right) */
.result-item[data-sponsored="true"]::before,
.carousel-card[data-sponsored="true"]::before {
  content: "Sponsored";
  position: absolute;
  top: 8px;
  left: 12px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 2px 6px;
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-alt);
  border: 1px solid var(--border);
  pointer-events: none;
}

/* Ad slots: "Ad" pill (top-left) */
.ad-slot::before {
  content: "Ad";
  position: absolute;
  top: 6px;
  left: 10px;
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .04em;
  padding: 2px 6px;
  border-radius: 999px;
  color: var(--muted);
  background: var(--panel-alt);
  border: 1px solid var(--border);
  pointer-events: none;
}

/* Top banner sizing — keep proportion, cap height */
#ad-slot-top { --top-banner-max: clamp(90px, 20vh, 220px); }

#ad-slot-top .ad .ad { aspect-ratio: 970 / 250; }

#ad-slot-top .ad a { display: block; width: 100%; }

#ad-slot-top .ad img { width: 100%; height: 100%; object-fit: cover; }

@media (max-width: 640px) {
  #ad-slot-top { --top-banner-max: clamp(60px, 16vh, 140px); }
}

/* Pagination row under results */
.results .pagination {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  border-top: 1px solid var(--border);
}
.results .pagination .page-info { color: var(--muted); }
.results .pagination .page-btn[disabled] { opacity: .5; pointer-events: none; }

/* Carousel CTA area */
.carousel-card .actions { margin-top: 10px; text-align: right; }

/* Make anchor CTAs look like buttons */
a.buy-btn {
  display: inline-block;
  padding: 10px 14px;
  border-radius: 10px;
  text-decoration: none;
}

/* Row container */
.result-item {
  position: relative;
  display: grid;
  grid-template-columns: 1fr auto auto auto; /* route | times | price | CTA */
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  border-radius: 14px;
  background: var(--card, #0f1621);
  border: 1px solid rgba(255,255,255,0.06);
}

/* Columns */
.result-item .col-route { min-width: 0; } /* allow text to wrap */
.result-item .route { font-weight: 600; }
.result-item .muted { opacity: .75; margin-top: 4px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.result-item .col-times { display: flex; gap: 12px; justify-content: center; }
.result-item .col-price { font-weight: 700; font-size: 1.1rem; text-align: right; min-width: 72px; }
.result-item .col-cta { text-align: right; }

/* Time chips */
.chip {
  display: inline-block;
  padding: 6px 10px;
  border-radius: 9999px;
  border: 1px solid rgba(255,255,255,0.12);
  background: rgba(255,255,255,0.05);
  font-weight: 600;
  line-height: 1;
}

/* CTA */
.buy-btn {
  display: inline-block;
  padding: 10px 16px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 700;
  background: linear-gradient(135deg, #38bdf8, #a78bfa);
  color: #000;
  box-shadow: 0 2px 10px rgba(0,0,0,.25);
}

/* Sponsored pill (top-left, unobtrusive) */
.result-item[data-sponsored="true"]::before {
  content: "SPONSORED";
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 8px;
  font-size: 12px;
  letter-spacing: .06em;
  border-radius: 9999px;
  border: 1px solid rgba(255,255,255,0.16);
  background: rgba(255,255,255,0.06);
  color: rgba(255,255,255,0.8);
  pointer-events: none;
}

/* Responsive: collapse to 2 rows on narrow screens */
@media (max-width: 800px) {
  .result-item {
    grid-template-columns: 1fr auto;        /* route | price */
    grid-template-rows: auto auto;          /* times | CTA on row 2 */
    grid-template-areas:
      "route price"
      "times cta";
    gap: 10px 16px;
  }
  .result-item .col-route { grid-area: route; }
  .result-item .col-times { grid-area: times; justify-content: flex-start; }
  .result-item .col-price { grid-area: price; }
  .result-item .col-cta   { grid-area: cta; text-align: right; }
}
