/* Pitbull Suomi 2026 — brand theme + static interactivity styling */
:root {
  --pit-red: #1e293b;
  --pit-red-d: #0f172a;
  --pit-gold: #f5b21a;
  --pit-black: #0b0b0c;
}

/* ---- recolor key accents from the original theme to Pitbull palette ---- */
.bg-\[\#1e293b\] { background-color: var(--pit-red) !important; } /* nav pill + dark CTAs */
a.group:hover { border-color: var(--pit-red) !important; box-shadow: 0 8px 24px rgba(30, 41, 59, .15) !important; }
/* "Alkaen … €" price highlight on cards */
.text-\[\#1e293b\].text-\[1\.15em\] { color: var(--pit-red) !important; }

/* section heading accent underline */
#tickets > h2::after {
  content: ""; display: block; width: 64px; height: 4px;
  margin: 12px auto 0; border-radius: 99px;
  background: linear-gradient(90deg, var(--pit-red), var(--pit-gold));
}

/* nav buttons clickable */
header nav button, header button[aria-label="Menu"] { cursor: pointer; }

/* ---- hero band (branded gradient until banner image is supplied) ---- */
.pit-hero {
  position: relative; min-height: 460px; overflow: hidden;
  background: #0b1220 !important;
}
.pit-hero img {
  opacity: 1 !important; position: absolute; inset: 0;
  width: 100%; height: 100%; object-fit: cover; object-position: center 20%;
}
.pit-hero::after {
  content: ""; position: absolute; inset: 0; z-index: 1;
  background: linear-gradient(90deg, rgba(8,12,22,.94) 0%, rgba(8,12,22,.62) 42%, rgba(8,12,22,.14) 100%);
}
.pit-hero-ov {
  position: absolute; inset: 0; z-index: 2; display: flex; align-items: center;
  justify-content: flex-start; padding: 0 6vw;
}
.pit-hero-in { color: #fff; max-width: 720px; }
.pit-hero-in .pit-eyebrow {
  display: inline-block; font-size: 12px; letter-spacing: .18em;
  text-transform: uppercase; padding: 6px 12px; border-radius: 999px;
  background: rgba(255, 255, 255, .12); border: 1px solid rgba(255, 255, 255, .22);
}
.pit-hero-in h1 {
  font-size: clamp(48px, 9vw, 120px); line-height: .95; margin: 14px 0 8px;
  font-weight: 900; letter-spacing: -.02em;
  text-shadow: 0 6px 30px rgba(0, 0, 0, .45);
}
.pit-hero-in p { font-size: clamp(16px, 2.4vw, 22px); color: #cbd5e1; margin: 0 0 22px; }

/* ---- shared button ---- */
.pit-btn {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--pit-red); color: #fff; font-weight: 700;
  padding: 13px 22px; border-radius: 999px; border: 0; cursor: pointer;
  text-decoration: none; font-size: 15px;
  box-shadow: 0 12px 28px rgba(30, 41, 59, .32);
  transition: transform .12s ease, background .15s ease;
}
.pit-btn:hover { background: var(--pit-red-d); transform: translateY(-1px); }
.pit-block { width: 100%; justify-content: center; margin-top: 16px; padding: 15px; }

/* ---- cart badge ---- */
.pit-badge {
  position: absolute; top: -8px; right: -10px;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--pit-red); color: #fff; font-size: 11px; font-weight: 800;
  border-radius: 999px; display: none; align-items: center; justify-content: center;
  box-shadow: 0 0 0 2px #fff;
}

/* ---- accordion states (product page tiers) ---- */
.pit-tier-active { border-color: var(--pit-red) !important; box-shadow: 0 6px 20px rgba(30, 41, 59, .12) !important; }
.pit-chev-open { transform: rotate(180deg); transition: transform .3s ease; }
.pit-qty-active { background: var(--pit-black) !important; border-color: var(--pit-black) !important; color: #fff !important; }

/* ---- toast ---- */
#pit-toast {
  position: fixed; bottom: 24px; right: 24px; z-index: 1000;
  background: var(--pit-black); color: #fff; padding: 14px 18px;
  border-radius: 12px; font-weight: 600; font-size: 14px;
  box-shadow: 0 18px 50px rgba(0, 0, 0, .3);
  opacity: 0; transform: translateY(12px); pointer-events: none;
  transition: opacity .2s ease, transform .2s ease;
}
#pit-toast.show { opacity: 1; transform: translateY(0); }

/* ---- mobile menu ---- */
#pit-menu {
  position: fixed; top: 64px; left: 0; right: 0; z-index: 999;
  background: #fff; border-bottom: 1px solid #e2e8f0;
  box-shadow: 0 18px 40px rgba(0, 0, 0, .12);
  display: flex; flex-direction: column; padding: 10px 18px;
}
#pit-menu a { padding: 13px 6px; font-weight: 600; color: #1e293b; text-decoration: none; border-bottom: 1px solid #f1f5f9; }
#pit-menu a:last-child { border-bottom: 0; color: var(--pit-red); }

/* ---- cart page ---- */
.pit-cart { max-width: 1100px; margin: 0 auto; padding: 40px 20px 80px; }
.pit-cart-title { font-size: clamp(26px, 4vw, 38px); margin: 0 0 24px; letter-spacing: -.02em; color: #0f172a; }
.pit-cart-grid { display: grid; grid-template-columns: 1.6fr 1fr; gap: 30px; align-items: start; }
.pit-list { display: grid; gap: 12px; }
.pit-ci {
  display: grid; grid-template-columns: 70px 1fr auto auto; gap: 16px; align-items: center;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 14px; padding: 14px;
}
.pit-th {
  width: 70px; height: 70px; border-radius: 10px; display: grid; place-items: center;
  color: #fff; font-weight: 900; letter-spacing: .04em;
  background: linear-gradient(135deg, var(--pit-black), var(--pit-red-d));
}
.pit-cinfo h3 { margin: 0 0 3px; font-size: 16px; color: #0f172a; }
.pit-cinfo p { margin: 0; font-size: 13px; color: #64748b; }
.pit-rm { background: none; border: 0; color: #94a3b8; font-size: 12px; text-decoration: underline; cursor: pointer; margin-top: 6px; padding: 0; }
.pit-q { display: inline-flex; align-items: center; gap: 6px; background: #f1f5f9; border-radius: 999px; padding: 4px; }
.pit-q button { width: 28px; height: 28px; border: 0; border-radius: 999px; background: #fff; font-weight: 800; cursor: pointer; }
.pit-q span { min-width: 22px; text-align: center; font-weight: 700; }
.pit-lt { font-weight: 800; font-size: 17px; color: #0f172a; }
.pit-sum { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; padding: 22px; position: sticky; top: 90px; }
.pit-sum h2 { margin: 0 0 16px; font-size: 19px; }
.pit-sum .r { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 8px; color: #475569; }
.pit-sum .r.tot { font-size: 20px; font-weight: 800; color: #0f172a; padding-top: 12px; margin-top: 6px; border-top: 1px solid #e2e8f0; }
.pit-empty { text-align: center; padding: 60px 20px; border: 1px dashed #e2e8f0; border-radius: 16px; background: #f8fafc; }
.pit-empty h2 { margin: 0 0 8px; }
.pit-empty p { margin: 0 0 18px; color: #64748b; }

@media (max-width: 820px) {
  .pit-cart-grid { grid-template-columns: 1fr; }
  .pit-ci { grid-template-columns: 56px 1fr auto; }
  .pit-ci .pit-lt { grid-column: 2 / 4; text-align: right; }
  .pit-hero-ov { justify-content: center; text-align: center; }
}

/* ===== legal pages (privacy / terms / refunds) ===== */
.pit-lh {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, .9); backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid #eef2f7;
}
.pit-lh-in {
  position: relative; max-width: 1200px; margin: 0 auto; height: 68px;
  display: flex; align-items: center; justify-content: space-between; padding: 0 20px;
}
.pit-lh-nav { display: flex; gap: 22px; }
.pit-lh-nav a { color: #1e293b; font-weight: 600; font-size: 14px; text-decoration: none; }
.pit-lh-nav a:hover { color: #0b0b0c; }
.pit-lh-cart { color: #1e293b; display: inline-flex; }
@media (max-width: 640px) { .pit-lh-nav { display: none; } }

.pit-legal { background: #fff; }
.pit-legal-in { max-width: 820px; margin: 0 auto; padding: 48px 22px 72px; }
.pit-legal h1 { font-size: clamp(28px, 4.5vw, 40px); letter-spacing: -.02em; margin: 0 0 18px; color: #0f172a; }
.pit-legal-lead { font-size: 17px; color: #475569; line-height: 1.7; margin: 0 0 28px;
  padding-bottom: 24px; border-bottom: 1px solid #eef2f7; }
.pit-legal h2 { font-size: 20px; margin: 32px 0 10px; color: #0f172a; }
.pit-legal p { font-size: 15px; line-height: 1.75; color: #334155; margin: 0 0 12px; }
.pit-legal ul { margin: 0 0 12px; padding-left: 20px; }
.pit-legal li { font-size: 15px; line-height: 1.7; color: #334155; margin-bottom: 6px; }
.pit-legal a { color: #1e293b; text-decoration: underline; }
.pit-legal-card { margin: 28px 0 8px; padding: 20px 22px; background: #f8fafc;
  border: 1px solid #e2e8f0; border-radius: 14px; }
.pit-legal-card h2 { margin: 0 0 8px; font-size: 17px; }
.pit-legal-card p { margin: 0; font-size: 14px; color: #475569; line-height: 1.7; }
.pit-legal-upd { margin-top: 24px !important; font-size: 13px !important; color: #94a3b8 !important; }

.pit-lf { background: #0b0b0c; color: #cfd2dc; }
.pit-lf-in { max-width: 1100px; margin: 0 auto; padding: 44px 22px 30px; }
.pit-lf-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 26px;
  padding-bottom: 26px; border-bottom: 1px solid rgba(255, 255, 255, .1); }
.pit-lf-cols div { font-size: 14px; line-height: 1.8; color: #98a0b2; }
.pit-lf-cols strong { color: #fff; }
.pit-lf-cols a { color: #cfd2dc; }
.pit-lf-links { display: flex; flex-wrap: wrap; gap: 20px; padding: 22px 0 16px; }
.pit-lf-links a { color: #cfd2dc; font-size: 14px; font-weight: 600; text-decoration: none; }
.pit-lf-links a:hover { color: #fff; }
.pit-lf-copy { font-size: 13px; color: #6b7280; margin: 0; line-height: 1.7; }
@media (max-width: 640px) { .pit-lf-cols { grid-template-columns: 1fr; } }

/* hide the duplicate (second) partners marquee row that was baked into the
   original template — leaves a big empty band under the visible logos */
.relative.-mt-4.h-44.w-full.overflow-hidden { display: none !important; }

/* ===== reduce excessive vertical gap on mobile (gallery → details) ===== */
@media (max-width: 1023px) {
  .grid.gap-y-12 { row-gap: 14px !important; gap-y: 14px !important; }
  .max-w-\[1400px\].grid.gap-y-12 { row-gap: 14px !important; }
}

/* ===== interactive seat map ===== */
.seat-map {
  position: relative;
  display: block;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  padding: 22px 22px 18px;
  margin-top: 6px;
  /* Break out of the constrained gallery parent to take full page width */
  width: calc(100vw - 32px);
  max-width: 1100px;
  margin-left: 50%;
  transform: translateX(-50%);
}
.seat-map svg {
  width: 100% !important; height: auto !important;
  max-width: 100% !important; display: block !important;
}
.seat-map g[data-category] { transition: filter .15s ease, opacity .15s ease; }
.seat-map-legend {
  display: flex; flex-wrap: wrap; gap: 6px 8px;
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid #e2e8f0;
}
.lm-chip {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 5px 11px;
  background: #ffffff;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  font-size: 12.5px; font-weight: 600; color: #334155;
  transition: border-color .12s ease, color .12s ease, background .12s ease;
}
.lm-chip.lm-clickable { cursor: pointer; }
.lm-chip.lm-clickable:hover {
  border-color: #1e293b; color: #0f172a; background: #f8fafc;
}
.lm-chip.lm-clickable:focus-visible {
  outline: 2px solid #1e293b; outline-offset: 2px;
}
.lm-chip.lm-static { opacity: 0.55; background: transparent; }

.lm-sw {
  flex-shrink: 0;
  width: 11px; height: 11px;
  background: var(--c);
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.2);
}
.lm-sw-circle { border-radius: 999px; }
.lm-sw-square { border-radius: 2px; }

.lm-text { line-height: 1; }
.lm-text b { font-weight: 600; font-size: 12.5px; }
.lm-text small { display: none; }
@media (max-width: 640px) {
  .seat-map { width: calc(100vw - 16px); padding: 14px 12px; }
}

/* ===== centered, enlarged logo ===== */
header a[aria-label$="Home"] {
  position: absolute; left: 50%; top: 50%;
  transform: translate(-50%, -50%); z-index: 3;
}
header a[aria-label$="Home"] img { height: 52px !important; width: auto !important; }

/* ===== header nav: hide the broken glass pill, use the hamburger only ===== */
header nav[aria-label="Main navigation"] { display: none !important; }
header button[aria-label="Menu"] {
  display: inline-flex !important;
  align-items: center; justify-content: center;
  width: 40px; height: 40px; padding: 0 !important;
  color: #1e293b !important; cursor: pointer;
  background: transparent; border: 1px solid transparent;
  border-radius: 10px; transition: background .15s ease, border-color .15s ease;
}
header button[aria-label="Menu"]:hover { background: #f1f5f9; border-color: #e2e8f0; }
header button[aria-label="Menu"] svg { width: 22px; height: 22px; }

/* ===== cleaner cart icon (replaces the bag with a real cart) ===== */
header a[aria-label="Cart"] svg { display: none; }
header a[aria-label="Cart"] {
  width: 40px; height: 40px; border-radius: 10px;
  display: inline-flex !important; align-items: center; justify-content: center;
  color: #1e293b !important; background: transparent;
  border: 1px solid transparent; transition: background .15s ease, border-color .15s ease;
}
header a[aria-label="Cart"]:hover { background: #f1f5f9; border-color: #e2e8f0; }
header a[aria-label="Cart"]::before {
  content: ""; width: 22px; height: 22px;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231e293b' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'><path d='M6 2 3 6v14a2 2 0 0 0 2 2h14a2 2 0 0 0 2-2V6l-3-4Z'/><path d='M3 6h18'/><path d='M16 10a4 4 0 0 1-8 0'/></svg>");
  background-repeat: no-repeat; background-size: contain; background-position: center;
}

/* ===== checkout button loading spinner ===== */
.pit-spinner {
  display: inline-block; width: 17px; height: 17px;
  border: 2px solid rgba(255, 255, 255, .35);
  border-top-color: #fff; border-radius: 50%;
  animation: pit-spin .6s linear infinite;
  vertical-align: -3px; margin-right: 8px;
}
@keyframes pit-spin { to { transform: rotate(360deg); } }
.pit-btn.pit-loading { opacity: .9; cursor: progress; pointer-events: none; }

/* ===== product page "Add to cart" button ===== */
.pit-add {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  width: 100%; margin: 18px 0 4px;
  padding: 16px; border: 0; border-radius: 12px;
  background: #1e293b; color: #fff; font-weight: 800; font-size: 16px;
  cursor: pointer; transition: background .15s ease, opacity .15s ease;
}
.pit-add svg { flex-shrink: 0; }
.pit-add:hover { background: #0f172a; }
.pit-add:disabled { opacity: .45; cursor: not-allowed; }

/* ===== cart / order page ===== */
.pit-order { max-width: 640px; margin: 0 auto; padding: 36px 20px 70px; }
.pit-order-title { font-size: clamp(26px, 4vw, 34px); margin: 0 0 22px; letter-spacing: -.02em; color: #0f172a; }

.pit-ic { display: inline-flex; align-items: center; justify-content: center; }
.pit-ic svg { width: 20px; height: 20px; }
.pit-ic.sm svg { width: 15px; height: 15px; }

.pit-timer {
  display: flex; align-items: center; gap: 11px;
  background: linear-gradient(120deg, #1e293b, #0f172a); color: #fff; border-radius: 14px;
  padding: 15px 20px; font-size: 15px; font-weight: 600; margin-bottom: 24px;
  box-shadow: 0 10px 26px rgba(15, 23, 42, .16);
}
.pit-timer .pit-ic { color: #f5b21a; flex-shrink: 0; }
.pit-timer b { font-variant-numeric: tabular-nums; color: #f5b21a; }

.pit-order-item {
  display: flex; gap: 16px; align-items: stretch;
  background: #fff; border: 1px solid #e2e8f0; border-radius: 16px;
  padding: 14px; margin-bottom: 16px;
  transition: box-shadow .15s ease, border-color .15s ease;
}
.pit-order-item:hover { box-shadow: 0 8px 24px rgba(15, 23, 42, .08); border-color: #cbd5e1; }
.pit-thumb { width: 92px; height: 92px; border-radius: 12px; object-fit: cover; flex-shrink: 0; background: #0b1220; }
.pit-item-body { position: relative; flex: 1; min-width: 0; padding: 4px 2px; }
.pit-order-item h3 { margin: 0 0 4px; font-size: 17px; color: #0f172a; padding-right: 28px; }
.pit-order-item p { margin: 0 0 12px; font-size: 13px; color: #64748b; line-height: 1.5; }
.pit-order-row { display: flex; align-items: center; justify-content: space-between; }
.pit-order-row > span { color: #64748b; font-size: 14px; }
.pit-order-row b { font-size: 18px; color: #0f172a; }
.pit-cnt { display: inline-flex; align-items: center; gap: 6px; font-weight: 600; color: #475569; }
.pit-cnt .pit-ic { color: #16a34a; }
.pit-x {
  position: absolute; top: 0; right: 0;
  width: 30px; height: 30px; border: 1px solid #e2e8f0; border-radius: 9px;
  background: #fff; color: #94a3b8; cursor: pointer; padding: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  transition: color .15s ease, border-color .15s ease;
}
.pit-x svg { width: 16px; height: 16px; }
.pit-x:hover { color: #1e293b; border-color: #cbd5e1; }

.pit-order-total { background: #fff; border: 1px solid #e2e8f0; border-radius: 16px; padding: 22px; margin-bottom: 16px; }
.pit-order-row + .pit-order-row { margin-top: 10px; }
.pit-order-row b.muted { font-size: 15px; color: #64748b; font-weight: 600; }
.pit-order-row.big { padding-top: 14px; margin-top: 14px; border-top: 1px solid #eef2f7; }
.pit-order-row.big span { font-size: 16px; color: #0f172a; font-weight: 700; }
.pit-order-row.big b { font-size: 26px; }
.pit-order-total .pit-btn svg { width: 18px; height: 18px; }

.pit-pay { display: flex; gap: 10px; justify-content: center; margin: 18px 0 12px; }
.pm {
  height: 38px; min-width: 60px; padding: 0 12px; border: 1px solid #e2e8f0;
  border-radius: 8px; display: inline-flex; align-items: center; justify-content: center;
  background: #fff; box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}
.pm svg, .pm img { display: block; height: 22px; width: auto; max-width: 100%; }
.pit-pay .pm:nth-child(3) img,
.pit-pay .pm:nth-child(3) svg { height: 18px; }
.pit-secure { display: flex; align-items: center; justify-content: center; gap: 6px; text-align: center; font-size: 13px; color: #94a3b8; margin: 0; }
.pit-secure .pit-ic { color: #94a3b8; }

.pit-guarantee { background: #f8fafc; border: 1px solid #e2e8f0; border-radius: 16px; padding: 20px 22px; }
.pit-guarantee h3 { display: flex; align-items: center; gap: 9px; margin: 0 0 16px; font-size: 16px; color: #0f172a; }
.pit-guarantee h3 .pit-ic { color: #1e293b; }
.pit-guarantee .g { display: flex; align-items: center; gap: 12px; font-size: 14px; font-weight: 600; color: #1e293b; margin-bottom: 12px; }
.pit-guarantee .g:last-child { margin-bottom: 0; }
.pit-guarantee .gic {
  width: 32px; height: 32px; border-radius: 9px; flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  background: #ecfdf5; color: #16a34a;
}
.pit-guarantee .gic svg { width: 17px; height: 17px; }
