/**
 * @file
 * Subtheme specific CSS — Festival Travel (Kreyol Konnekxon)
 * Visual design: premium Caribbean festival travel brand.
 */


/* ============================================================
   Header / branding
   ============================================================ */
#navbar-main,
.navbar {
  min-height: 76px;
  padding-top: .5rem;
  padding-bottom: .5rem;
  background: linear-gradient(180deg, #0D1422 0%, #1C2A40 100%);
}

.navbar-brand,
.site-branding,
.site-branding__logo {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: #E06000;
  text-decoration: none;
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  text-shadow: 0 2px 8px rgba(224, 96, 0, .3);
}

.navbar-brand:hover,
.site-branding:hover {
  color: #f5b400;
}

.navbar-brand img,
.site-branding__logo img,
.site-logo img,
.logo img {
  display: block;
  width: auto;
  max-width: 96px;
  max-height: 68px;
  object-fit: contain;
}

.site-branding__name,
.navbar-brand .site-title {
  font-weight: 800;
  font-size: 1.2rem;
  letter-spacing: -0.02em;
  color: #E06000;
  text-decoration: none;
  text-shadow: 0 2px 8px rgba(224, 96, 0, .3);
}

.navbar-collapse {
  align-items: center;
}

.navbar-nav .nav-link {
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: .03em;
  padding: .6rem 1.1rem;
  border-radius: 6px;
  color: rgba(255, 255, 255, .8);
  text-decoration: none;
  transition: all .25s ease;
  position: relative;
}

.navbar-nav .nav-link::after {
  content: "";
  position: absolute;
  bottom: 8px;
  left: 50%;
  width: 0;
  height: 2px;
  background: linear-gradient(90deg, #E06000, #f5b400);
  transform: translateX(-50%);
  transition: width .3s ease;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
  color: #fff;
  background: rgba(224, 96, 0, .15);
}

.navbar-nav .nav-link:hover::after,
.navbar-nav .nav-link:focus::after {
  width: 28px;
}

.navbar-nav .nav-link.active {
  color: #E06000;
  background: rgba(224, 96, 0, .18);
  font-weight: 700;
}

.navbar-nav .nav-link.active::after {
  width: 36px;
}

.navbar-toggler {
  border-color: rgba(255, 255, 255, .25);
}


/* ============================================================
   ft-btn — shared button/link component
   ============================================================ */
.ft-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  border: 1px solid transparent;
  border-radius: 6px;
  padding: .85rem 2rem;
  background: linear-gradient(135deg, #E06000 0%, #B84E00 100%);
  color: #fff;
  font-family: inherit;
  font-size: .95rem;
  font-weight: 700;
  letter-spacing: .05em;
  line-height: 1.3;
  text-align: center;
  text-decoration: none;
  cursor: pointer;
  transition: all .25s ease;
  white-space: nowrap;
  box-shadow: 0 4px 14px rgba(224, 96, 0, .3);
  position: relative;
  overflow: hidden;
}

.ft-btn::before {
  content: "";
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, .25), transparent);
  transition: left .6s ease;
}

.ft-btn:hover,
.ft-btn:focus {
  background: linear-gradient(135deg, #B84E00 0%, #8a3800 100%);
  color: #fff;
  text-decoration: none;
  transform: translateY(-3px);
  box-shadow: 0 8px 22px rgba(224, 96, 0, .4);
}

.ft-btn:hover::before {
  left: 100%;
}

.ft-btn:active {
  transform: translateY(-1px);
}

.ft-btn--light {
  background: transparent;
  border-color: rgba(255, 255, 255, .4);
  color: #fff;
}

.ft-btn--light:hover,
.ft-btn--light:focus {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .65);
  color: #fff;
  box-shadow: none;
}


/* ============================================================
   Artist lineup — mobile-first defaults
   ============================================================ */
.view-artists .view-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

.ft-artist-card {
  height: 100%;
  overflow: hidden;
  border-radius: 12px;
  background: linear-gradient(135deg, #0D1422 0%, #1C2A40 100%);
  color: #fff;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .2), 0 12px 32px rgba(0, 0, 0, .18);
  transition: all .35s cubic-bezier(0.34, 1.56, 0.64, 1);
  border: 1px solid rgba(255, 255, 255, .08);
  position: relative;
  display: flex;
  flex-direction: column;
}

.ft-artist-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: radial-gradient(ellipse at 30% 40%, rgba(224, 96, 0, .08) 0%, transparent 50%);
  pointer-events: none;
  z-index: 1;
}

.ft-artist-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .25), 0 20px 48px rgba(224, 96, 0, .15);
}

.ft-artist-card__image-link {
  display: block;
  width: 100%;
  color: inherit;
  text-decoration: none;
}

.ft-artist-card__image {
  position: relative;
  width: 100%;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: linear-gradient(160deg, #1C2A40, #0D1422);
}

.ft-artist-card__image .field,
.ft-artist-card__image .field__items,
.ft-artist-card__image .field__item {
  width: 100%;
  height: 100%;
}

.ft-artist-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.ft-artist-card:hover .ft-artist-card__image img {
  transform: scale(1.05);
}

.ft-artist-card__image--placeholder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
}

.ft-artist-card__image--placeholder span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 5.5rem;
  height: 5.5rem;
  border-radius: 50%;
  background: rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .85);
  font-size: 3.2rem;
  line-height: 1;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: -0.04em;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .15), 0 8px 16px rgba(0, 0, 0, .2);
}

.ft-artist-card__body {
  padding: 1.5rem;
  flex: 1;
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 2;
}

.ft-artist-card__title {
  margin: 0 0 .75rem;
  font-size: 1.25rem;
  font-weight: 800;
  line-height: 1.2;
  letter-spacing: -0.01em;
}

.ft-artist-card__title a {
  color: #fff;
  text-decoration: none;
  transition: color .25s ease;
}

.ft-artist-card__title a:hover,
.ft-artist-card__title a:focus {
  color: #E06000;
}

.ft-artist-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1.1rem;
  color: rgba(255, 255, 255, .68);
  font-size: .9rem;
  font-weight: 500;
}

.ft-artist-card__meta span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  padding: .3rem .55rem;
  background: rgba(255, 255, 255, .08);
}

.ft-artist-card__meta span .field,
.ft-artist-card__meta span .field__items,
.ft-artist-card__meta span .field__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  padding: .6em 0 .6em;
}

.ft-artist-card__meta span + span::before {
  display: none;
}

.ft-artist-card__social {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-top: auto;
}

.ft-artist-card__social-link a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 6px;
  background: rgba(224, 96, 0, .9);
  color: #fff;
  font-size: .82rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .25s ease;
  border: 1px solid rgba(224, 96, 0, .5);
}

.ft-artist-card__social-link a svg {
  width: 18px;
  height: 18px;
}

.ft-artist-card__social-link a:hover,
.ft-artist-card__social-link a:focus {
  background: linear-gradient(135deg, #E06000, #B84E00);
  border-color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(224, 96, 0, .4);
}


/* ============================================================
   Package cards — mobile-first defaults
   ============================================================ */
.view-travel-packages .view-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

.ft-package-card {
  height: 100%;
  overflow: hidden;
  border-radius: 12px;
  background: #FDFAF6;
  color: #1A2132;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06), 0 4px 16px rgba(0, 0, 0, 0.08);
  border: 1px solid rgba(0, 0, 0, 0.06);
  transition: transform .2s ease, box-shadow .2s ease;
}

.ft-package-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.07), 0 12px 32px rgba(0, 0, 0, 0.12);
}

.ft-package-card__media-link {
  display: block;
  text-decoration: none;
}

.ft-package-card__image {
  aspect-ratio: 16 / 10;
  overflow: hidden;
  background: linear-gradient(135deg, #1C2A40, #0D1422);
}

.ft-package-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.ft-package-card:hover .ft-package-card__image img {
  transform: scale(1.04);
}

.ft-package-card__body {
  padding: 1.35rem;
}

.ft-package-card__badge {
  display: inline-block;
  margin-bottom: .75rem;
  border-radius: 3px;
  padding: .2rem .5rem;
  background: transparent;
  color: #B84E00;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.ft-package-card__title {
  margin: 0 0 .75rem;
  font-size: 1.2rem;
  line-height: 1.2;
  font-weight: 700;
}

.ft-package-card__title a {
  color: #1A2132;
  text-decoration: none;
}

.ft-package-card__title a:hover,
.ft-package-card__title a:focus {
  color: #E06000;
}

.ft-package-card__dates {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: .75rem;
  color: #B84E00;
  font-size: .88rem;
  font-weight: 600;
}

.ft-package-card__dates span + span::before {
  content: "→";
  margin-right: .4rem;
  color: #6B7A95;
}

.ft-package-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  margin-bottom: 1.1rem;
  color: #6B7A95;
  font-size: .88rem;
}

.ft-package-card__meta span {
  display: inline-flex;
  border-radius: 4px;
  padding: .25rem .55rem;
  background: #F7F3EC;
  border: 1px solid #EDE7DC;
}

.ft-package-card__button {
  margin-top: .25rem;
}


/* ============================================================
   Travel Package detail page
   ============================================================ */
.ft-package-hero {
  margin-top: 3rem;
  padding: 5rem 0 3.5rem;
  background: #0D1422;
  color: #fff;
}

.ft-package-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
  align-items: center;
}

.ft-package-hero__eyebrow {
  display: inline-block;
  margin-bottom: 1rem;
  border-radius: 3px;
  padding: .25rem .55rem;
  background: rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .78);
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.ft-package-hero h1 {
  margin: 0 0 1rem;
  font-size: clamp(2rem, 7vw, 3.75rem);
  line-height: 1;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.ft-package-hero__dates {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin-bottom: 1rem;
  font-weight: 600;
  color: rgba(255, 255, 255, .78);
}

.ft-package-hero__dates span + span::before {
  content: "→";
  margin-right: .6rem;
  color: rgba(255, 255, 255, .4);
}

.ft-package-hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-bottom: 1.5rem;
}

.ft-package-hero__badges span {
  display: inline-flex;
  border-radius: 4px;
  padding: .3rem .65rem;
  background: rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .88);
  font-weight: 600;
  font-size: .88rem;
}

.ft-package-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.ft-package-hero__media {
  overflow: hidden;
  border-radius: 12px;
  background: linear-gradient(135deg, #1C2A40, #0D1422);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.22);
}

.ft-package-hero__media img {
  width: 100%;
  height: 100%;
  min-height: 260px;
  object-fit: cover;
}

.ft-package-hero__placeholder {
  min-height: 320px;
  background: linear-gradient(135deg, #1C2A40, #0D1422);
}

.ft-package-content {
  padding: 3rem 0;
  background: #FDFAF6;
}

.ft-package-content__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2rem;
}

/* Content sections: clean dividers, no boxes */
.ft-package-section {
  margin-bottom: 2rem;
  padding: 0 0 2rem;
  border-bottom: 1px solid #EDE7DC;
  background: transparent;
}

.ft-package-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
}

.ft-package-section h2 {
  margin-top: 0;
  margin-bottom: 1rem;
  font-weight: 700;
  font-size: 1.3rem;
  color: #1A2132;
}

/* Booking card — refined dark */
.ft-package-booking__card {
  position: sticky;
  top: 1.5rem;
  padding: 1.75rem;
  border-radius: 12px;
  background: #0D1422;
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-top: 3px solid #E06000;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.18), 0 1px 4px rgba(0, 0, 0, 0.1);
}

.ft-package-booking__card h2 {
  margin-top: 0;
  font-weight: 700;
  font-size: 1.15rem;
  color: #fff;
}

.ft-package-booking__deposit {
  color: rgba(255, 255, 255, .68);
  font-weight: 500;
  font-size: .9rem;
}

.ft-package-booking__card label {
  color: rgba(255, 255, 255, .82);
  font-weight: 600;
  font-size: .88rem;
}

.ft-package-booking__card input,
.ft-package-booking__card select,
.ft-package-booking__card textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .15);
  color: #fff;
  border-radius: 6px;
}

.ft-package-booking__card input:focus,
.ft-package-booking__card select:focus,
.ft-package-booking__card textarea:focus {
  border-color: rgba(224, 96, 0, .7);
  outline: none;
  box-shadow: 0 0 0 3px rgba(224, 96, 0, .2);
}

.ft-package-booking__whatsapp {
  display: block;
  margin-top: 1rem;
  border-radius: 6px;
  padding: .75rem 1rem;
  background: #25d366;
  color: #fff;
  text-align: center;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .03em;
  text-decoration: none;
  transition: background .18s ease;
}

.ft-package-booking__whatsapp:hover,
.ft-package-booking__whatsapp:focus {
  color: #fff;
  background: #1db155;
}

.ft-package-booking__form {
  margin-top: 1rem;
}

.ft-package-booking__form .form-actions {
  margin-top: 1rem;
}

.ft-package-booking__form .button,
.ft-package-booking__form input[type="submit"] {
  width: 100%;
  border: 0;
  border-radius: 6px;
  padding: .85rem 1rem;
  background: #E06000;
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .18s ease;
}

.ft-package-booking__form .button:hover,
.ft-package-booking__form .button:focus,
.ft-package-booking__form input[type="submit"]:hover,
.ft-package-booking__form input[type="submit"]:focus {
  background: #B84E00;
  color: #fff;
}


/* ============================================================
   Add-to-cart: variation price + availability
   ============================================================ */
.festival-variation-price {
  display: flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: .35rem;
  margin: .75rem 0 .25rem;
}

.festival-variation-price__label {
  color: rgba(255, 255, 255, .62);
  font-weight: 500;
  font-size: .9rem;
}

.festival-variation-price__value {
  color: #f5b400;
  font-size: 1.3rem;
  font-weight: 700;
}

.festival-availability {
  margin: .35rem 0;
  font-size: .88rem;
  font-weight: 600;
  border-radius: 4px;
  padding: .3rem .6rem;
}

.festival-availability--available {
  color: #a7f3d0;
  background: rgba(167, 243, 208, .1);
}

.festival-availability--limited {
  color: #fcd34d;
  background: rgba(252, 211, 77, .1);
}

.festival-availability--sold-out {
  color: #fca5a5;
  background: rgba(252, 165, 165, .1);
}


/* ============================================================
   Commerce cart
   ============================================================ */
.path-cart .cart-form {
  margin-top: 1.5rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.path-cart table {
  overflow: hidden;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06), 0 4px 16px rgba(0, 0, 0, 0.06);
}

.path-cart table th {
  background: #0D1422;
  color: rgba(255, 255, 255, .85);
  font-weight: 600;
  font-size: .85rem;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.path-cart table td {
  vertical-align: middle;
}

.path-cart .form-actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  margin-top: 1rem;
}

.path-cart .form-actions .button,
.path-cart input[type="submit"] {
  border: 0;
  border-radius: 6px;
  padding: .8rem 1.4rem;
  background: #E06000;
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .18s ease;
}

.path-cart .form-actions .button:hover,
.path-cart input[type="submit"]:hover {
  background: #B84E00;
  color: #fff;
}

.ft-deposit-notice,
.block-cart-deposit-notice {
  margin: 1.5rem 0;
  padding: 1rem 1.25rem;
  border-left: 3px solid #E06000;
  border-radius: 6px;
  background: #F7F3EC;
  color: #1A2132;
  font-weight: 600;
}

.festival-deposit-summary {
  background: #F7F3EC;
  border: 1px solid #EDE7DC;
  border-radius: 8px;
  padding: 1.25rem;
  margin: 1.5rem 0;
}

.festival-deposit-summary h3 {
  margin-top: 0;
  margin-bottom: 1rem;
  font-size: 1.3rem;
  font-weight: 700;
}

.festival-deposit-summary__rows {
  display: grid;
  gap: 0.65rem;
}

.festival-deposit-summary__row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  border-bottom: 1px solid rgba(0, 0, 0, 0.07);
  padding-bottom: 0.65rem;
}

.festival-deposit-summary__row--deposit {
  font-size: 1.05rem;
}

.festival-deposit-summary__note {
  margin: 1rem 0 0;
  font-size: .92rem;
  color: #3D4B62;
}

.checkout-pane,
.layout-checkout-form {
  margin-bottom: 2rem;
}

.festival-deposit-summary {
  clear: both;
  position: relative;
  z-index: 1;
  margin-top: 2rem;
  margin-bottom: 2rem;
}


/* ============================================================
   Homepage (page--front) — mobile-first defaults
   ============================================================ */
.ft-home-hero {
  padding: 4rem 0 3.5rem;
  background: #0D1422;
  color: #fff;
}

/* Hero with video/image background */
.ft-home-hero--media {
  position: relative;
  overflow: hidden;
  min-height: 68vh;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding-bottom: 3.5rem;
}

.ft-home-hero--media .container {
  position: relative;
  z-index: 2;
}

.ft-home-hero__bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

/* Directional overlay: stronger left for text legibility */
.ft-home-hero--media::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(
    to right,
    rgba(13, 20, 34, 0.78) 0%,
    rgba(13, 20, 34, 0.52) 60%,
    rgba(13, 20, 34, 0.3) 100%
  );
}

/* Fallback: no media → simple dark hero without flex override */
.ft-home-hero:not(.ft-home-hero--media) {
  display: block;
}

.ft-home-hero__eyebrow {
  display: inline-block;
  margin-bottom: 1.25rem;
  border-radius: 3px;
  padding: .28rem .6rem;
  background: rgba(255, 255, 255, .1);
  color: rgba(255, 255, 255, .82);
  font-weight: 600;
  font-size: .75rem;
  letter-spacing: .1em;
  text-transform: uppercase;
}

.ft-home-hero__title {
  margin: 0 0 1.25rem;
  font-size: clamp(2.5rem, 7vw, 4.75rem);
  line-height: .97;
  font-weight: 700;
  letter-spacing: -0.02em;
}

.ft-home-hero__lead {
  max-width: 44ch;
  margin: 0 0 2rem;
  color: rgba(255, 255, 255, .75);
  font-size: 1.05rem;
  line-height: 1.65;
}

.ft-home-hero__actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  align-items: flex-start;
}

.ft-home-hero__actions .ft-btn {
  width: 100%;
  max-width: 260px;
}


/* ── Section shell ─────────────────────────────────────── */
.ft-home-section {
  padding: 3rem 0;
}

.ft-home-section__head {
  margin-bottom: 2rem;
  text-align: center;
}

.ft-home-section__head h2 {
  margin: 0 0 .5rem;
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.ft-home-section__head p {
  margin: 0;
  color: #6B7A95;
}

.ft-home-section__cta {
  margin-top: 2rem;
  text-align: center;
}

.ft-home-packages {
  background: #F7F3EC;
}


/* ── Why book with us — editorial, not boxed ───────────── */
.ft-home-why__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
  counter-reset: why-count;
}

.ft-home-why__item {
  padding: 1.5rem 0 1.25rem;
  border-top: 1px solid #EDE7DC;
  background: transparent;
  counter-increment: why-count;
}

.ft-home-why__item::before {
  content: "0" counter(why-count);
  display: block;
  margin-bottom: .5rem;
  font-size: .78rem;
  font-weight: 700;
  color: #E06000;
  letter-spacing: .08em;
}

.ft-home-why__item h3 {
  margin: 0 0 .4rem;
  font-size: 1.1rem;
  font-weight: 700;
  color: #1A2132;
}

.ft-home-why__item p {
  margin: 0;
  color: #3D4B62;
  font-size: .96rem;
  line-height: 1.6;
}


/* ── Event teaser ──────────────────────────────────────── */
.ft-home-events {
  background: #0D1422;
  color: #fff;
}

.ft-home-events__inner {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
  align-items: flex-start;
}

.ft-home-events__text h2 {
  margin: 0 0 .5rem;
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.ft-home-events__text p {
  margin: 0;
  color: rgba(255, 255, 255, .72);
  line-height: 1.65;
}

.ft-home-events__cta {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}


/* ── Final CTA — dark navy, not orange gradient ────────── */
.ft-home-cta__inner {
  padding: 3rem 2rem;
  border-radius: 12px;
  background: #0D1422;
  color: #fff;
  text-align: center;
  border: 1px solid rgba(255, 255, 255, .08);
}

.ft-home-cta__inner h2 {
  margin: 0 0 .6rem;
  font-size: clamp(1.5rem, 4vw, 2.1rem);
  font-weight: 700;
  letter-spacing: -0.01em;
}

.ft-home-cta__inner p {
  margin: 0 0 1.5rem;
  color: rgba(255, 255, 255, .7);
  line-height: 1.65;
}

.ft-home-cta__actions {
  display: flex;
  flex-direction: column;
  gap: .75rem;
  align-items: center;
}

.ft-home-cta__actions .ft-btn {
  width: 100%;
  max-width: 260px;
}

.ft-home-cta__actions .ft-btn--light {
  background: transparent;
  border-color: rgba(255, 255, 255, .35);
}


/* ============================================================
   Footer — mobile-first defaults
   ============================================================ */
.site-footer {
  padding: 5rem 0 2rem;
  color: rgba(255, 255, 255, .72);
  background: linear-gradient(180deg, #0D1422 0%, #1C2A40 100%);
}

.site-footer__top {
  display: grid;
  grid-template-columns: minmax(200px, 2fr) minmax(200px, 1.5fr) minmax(200px, 2fr);
  gap: 4rem;
  align-items: flex-start;
}

.site-footer__top > section {
  align-self: flex-start;
  min-width: 200px !important;
}

.region-footer-first,
.region-footer-second,
.region-footer-third {
  min-width: 200px !important;
  align-self: flex-start;
}

.site-footer a {
  color: rgba(255, 255, 255, .85);
  text-decoration: none;
}

.site-footer a:hover,
.site-footer a:focus {
  color: #f5b400;
  text-decoration: underline;
}

.site-footer img {
  max-width: 180px;
  height: auto;
}

.ft-footer-brand__name {
  margin: 0 0 .5rem;
  font-size: 1.2rem;
  font-weight: 700;
  color: #fff;
}

.ft-footer-brand__tagline {
  margin: 0;
  max-width: 42ch;
  font-size: .9rem;
  color: rgba(255, 255, 255, .58);
}

.ft-footer-contact__title,
.site-footer .block h2,
.site-footer h2.block-title {
  margin: 0 0 1.5rem;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255, 255, 255, .65);
}

.region-footer-second .visually-hidden,
.region-footer-second h2 {
  position: static;
  width: auto;
  height: auto;
  overflow: visible;
  clip: auto;
  margin: 0 0 1.8rem;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .12em;
  color: rgba(255, 255, 255, .65);
  white-space: nowrap;
}

.region-footer-second ul {
  display: flex;
  flex-direction: column !important;
}

.ft-footer-contact p {
  margin: .35rem 0;
  font-weight: 500;
  font-size: .92rem;
}

.site-footer__bottom {
  margin-top: 2.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(255, 255, 255, .1);
}

.ft-footer-bottom {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  font-size: .82rem;
  color: rgba(255, 255, 255, .42);
}

.site-footer .menu {
  list-style: none;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: .8rem !important;
}

.region-footer-second .menu {
  display: flex !important;
  flex-direction: column !important;
}

.site-footer .menu li {
  margin-bottom: 0;
}

.site-footer .menu a {
  font-size: .9rem;
  color: rgba(255, 255, 255, .85);
  transition: color .25s ease;
  white-space: nowrap !important;
  display: inline-block;
}

.site-footer .menu a:hover {
  color: #E06000;
}

.ft-footer-contact__item-text a {
  white-space: nowrap !important;
}

.region-footer-second .menu li a,
.region-footer-second .nav-link {
  white-space: nowrap !important;
}

/* Bootstrap Barrio wraps each block in a .block div that can inherit
   or receive white backgrounds from base Bootstrap styles.
   Override everything inside the footer to be transparent. */
.site-footer .block,
.site-footer .block-content,
.site-footer .block-inner,
.site-footer [class*="block-block"] {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

/* Ensure main content area always ends with enough room before footer */
#main-wrapper {
  padding-bottom: 0;
}


/* ============================================================
   Contact page: map + webform
   ============================================================ */
.field--name-field-map-address {
  margin: 1.5rem 0;
}

.field--name-field-map-address iframe {
  width: 100%;
  max-width: 100%;
  border-radius: 8px;
}

.webform-submission-form {
  max-width: 620px;
  margin-top: 1rem;
}

.webform-submission-form .form-item {
  margin-bottom: 1rem;
}

.webform-submission-form input[type="text"],
.webform-submission-form input[type="email"],
.webform-submission-form textarea {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  border-radius: 6px;
  border: 1px solid #EDE7DC;
  padding: .65rem .85rem;
  font-family: inherit;
  font-size: .95rem;
  color: #1A2132;
  background: #fff;
  transition: border-color .15s ease, box-shadow .15s ease;
}

.webform-submission-form input[type="text"]:focus,
.webform-submission-form input[type="email"]:focus,
.webform-submission-form textarea:focus {
  border-color: #E06000;
  outline: none;
  box-shadow: 0 0 0 3px rgba(224, 96, 0, 0.15);
}

.webform-submission-form .form-actions input[type="submit"],
.webform-submission-form .webform-button--submit {
  border: 0;
  border-radius: 6px;
  padding: .8rem 1.75rem;
  background: #E06000;
  color: #fff;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .04em;
  cursor: pointer;
  transition: background .18s ease;
}

.webform-submission-form .form-actions input[type="submit"]:hover,
.webform-submission-form .webform-button--submit:hover {
  background: #B84E00;
}


/* ============================================================
   Checkout: "Go back" secondary link
   ============================================================ */
.layout-checkout-form .form-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .75rem;
  margin-top: 1rem;
}

a.link--previous {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  padding: .72rem 1.4rem;
  border: 1px solid #d1d5db;
  background: #fff;
  color: #3D4B62;
  font-weight: 500;
  font-size: .9rem;
  letter-spacing: .03em;
  line-height: 1.2;
  text-decoration: none;
  transition: border-color .15s ease, color .15s ease;
}

a.link--previous:hover,
a.link--previous:focus {
  border-color: #E06000;
  color: #B84E00;
  text-decoration: none;
}


/* ============================================================
   Inner pages: page header + content readability
   ============================================================ */
.block-page-title-block {
  margin: 2rem 0 1.5rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid #EDE7DC;
}

.block-page-title-block .title {
  margin: 0;
  font-size: clamp(1.75rem, 4vw, 2.5rem);
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: #1A2132;
}

/* Hide duplicate product title — package template renders its own hero h1 */
.path-product .block-page-title-block {
  display: none;
}

/* Hide "Submitted by …" meta on public content pages */
.node--type-page .node__meta,
.node--type-event-festival .node__meta,
.node--type-artist .node__meta,
.node--type-webform .node__meta {
  display: none;
}

/* Readable text column for text-heavy node pages */
.node--type-page.node--view-mode-full,
.node--type-event-festival.node--view-mode-full,
.node--type-artist.node--view-mode-full,
.node--type-webform.node--view-mode-full {
  max-width: 820px;
}

/* Body typography for content pages */
.node--view-mode-full .field--name-body {
  font-size: 1.02rem;
  line-height: 1.75;
  color: #3D4B62;
}

.node--view-mode-full .field--name-body h2 {
  margin: 2rem 0 .65rem;
  font-size: 1.45rem;
  font-weight: 700;
  line-height: 1.2;
  color: #1A2132;
}

.node--view-mode-full .field--name-body h3 {
  margin: 1.5rem 0 .5rem;
  font-size: 1.15rem;
  font-weight: 700;
  color: #1A2132;
}

.node--view-mode-full .field--name-body p {
  margin: 0 0 1.1rem;
}

.node--view-mode-full .field--name-body ul,
.node--view-mode-full .field--name-body ol {
  margin: 0 0 1.1rem 1.25rem;
  padding: 0;
}

.node--view-mode-full .field--name-body li {
  margin-bottom: .45rem;
}

.node--view-mode-full .field--name-body a {
  color: #C05000;
  font-weight: 600;
}

.node--view-mode-full .field--name-body a:hover,
.node--view-mode-full .field--name-body a:focus {
  color: #E06000;
}


/* ============================================================
   Events & Festivals listing
   ============================================================ */
.view-events-festivals .view-content {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.25rem;
}

.view-events-festivals .views-row {
  padding: 1.5rem;
  border-radius: 10px;
  background: #FDFAF6;
  border: 1px solid rgba(0, 0, 0, 0.05);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05), 0 4px 12px rgba(0, 0, 0, 0.07);
  transition: transform .2s ease, box-shadow .2s ease;
}

.view-events-festivals .views-row:hover {
  transform: translateY(-2px);
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.07), 0 8px 24px rgba(0, 0, 0, 0.1);
}

.view-events-festivals .views-field-title {
  margin: 0 0 1rem;
}

.view-events-festivals .views-field-title a {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.2;
  color: #1A2132;
  text-decoration: none;
}

.view-events-festivals .views-field-title a:hover,
.view-events-festivals .views-field-title a:focus {
  color: #E06000;
}

.view-events-festivals .views-row .views-field {
  margin-bottom: .6rem;
}

.view-events-festivals .views-label {
  display: block;
  margin-bottom: .1rem;
  font-size: .7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: #9ca3af;
}

.view-events-festivals .views-field .field-content,
.view-events-festivals .views-field time {
  color: #1A2132;
  font-weight: 600;
  font-size: .95rem;
}

.view-events-festivals .views-field-field-event-venue .field-content {
  font-weight: 500;
  color: #3D4B62;
}


/* ============================================================
   Contact page: contact info block
   ============================================================ */
.node--type-webform .field--name-body {
  padding: 1.25rem 1.5rem;
  border-radius: 8px;
  background: #F7F3EC;
  border: 1px solid #EDE7DC;
}

.node--type-webform .field--name-body ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.node--type-webform .field--name-body li {
  margin-bottom: .5rem;
}


/* ============================================================
   Pass 2: Visual refinements — image placeholders, spacing,
   event/artist detail, contact page, footer icons
   ============================================================ */

/* ── Bottom spacing before footer on all listing pages ──── */
.view-travel-packages,
.view-events-festivals,
.view-artists {
  margin-bottom: 4rem;
}

/* ── Package card: improved placeholder ─────────────────── */
.ft-package-card__image--placeholder {
  aspect-ratio: 16 / 10;
  background: linear-gradient(140deg, #0D1422 0%, #1C2A40 55%, #0D1A2E 100%);
  position: relative;
  overflow: hidden;
}

.ft-package-card__image--placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 18% 78%, rgba(224, 96, 0, 0.24) 0%, transparent 52%),
    radial-gradient(ellipse at 84% 22%, rgba(192, 139, 16, 0.16) 0%, transparent 48%);
}

/* ── Booking card: legible select/dropdown on dark bg ───── */
.ft-package-booking__card select,
.ft-package-booking__card .form-select,
.ft-package-booking__card select.form-control {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: rgba(255, 255, 255, 0.1) !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23ffffff' fill-opacity='.6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right .9rem center;
  background-size: 10px 6px;
  padding-right: 2.5rem !important;
  border: 1px solid rgba(255, 255, 255, 0.25) !important;
  border-radius: 6px;
  color: #fff !important;
  font-family: inherit;
  font-size: .92rem;
  line-height: 1.4;
  cursor: pointer;
}

.ft-package-booking__card select:focus,
.ft-package-booking__card .form-select:focus {
  border-color: #E06000 !important;
  outline: none;
  box-shadow: 0 0 0 3px rgba(224, 96, 0, 0.25);
  background-color: rgba(255, 255, 255, 0.14) !important;
}

.ft-package-booking__card select option {
  background: #1C2A40;
  color: #fff;
}


/* ============================================================
   Event cards (node--event-festival--event-card view mode)
   ============================================================ */
.ft-event-card {
  display: flex;
  flex-direction: column;
  height: 100%;
}

.ft-event-card__media {
  border-radius: 8px 8px 0 0;
  overflow: hidden;
  margin: -1.5rem -1.5rem 1.25rem;
  flex-shrink: 0;
}

.ft-event-card__image {
  height: 165px;
  overflow: hidden;
}

.ft-event-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .35s ease;
}

.view-events-festivals .views-row:hover .ft-event-card__image img {
  transform: scale(1.04);
}

.ft-event-card__image-placeholder {
  height: 165px;
  background: linear-gradient(140deg, #0D1422 0%, #1C2A40 60%, #0D1A2E 100%);
  position: relative;
  overflow: hidden;
}

.ft-event-card__image-placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 72%, rgba(224, 96, 0, 0.22) 0%, transparent 52%),
    radial-gradient(ellipse at 82% 28%, rgba(192, 139, 16, 0.16) 0%, transparent 46%);
}

.ft-event-card__body {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.ft-event-card__eyebrow {
  display: inline-block;
  margin-bottom: .6rem;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #B84E00;
}

.ft-event-card__title {
  margin: 0 0 .75rem;
  font-size: 1.15rem;
  font-weight: 700;
  line-height: 1.2;
}

.ft-event-card__title a {
  color: #1A2132;
  text-decoration: none;
}

.ft-event-card__title a:hover,
.ft-event-card__title a:focus {
  color: #E06000;
}

.ft-event-card__meta {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  margin-bottom: 1rem;
  flex: 1;
}

.ft-event-card__dates {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .4rem;
  color: #3D4B62;
  font-size: .88rem;
  font-weight: 600;
}

.ft-event-card__dates .sep {
  color: #9ca3af;
  font-weight: 400;
  margin: 0 .1rem;
}

.ft-event-card__venue {
  color: #6B7A95;
  font-size: .85rem;
  font-weight: 500;
}


/* ============================================================
   Event detail page layout
   ============================================================ */
.ft-event-hero {
  padding: 4.5rem 0 3.5rem;
  background: linear-gradient(135deg, #0D1422 0%, #1C2A40 50%, #0D1422 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.ft-event-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 15% 60%, rgba(224, 96, 0, 0.12) 0%, transparent 50%),
    radial-gradient(ellipse at 85% 40%, rgba(192, 139, 16, 0.08) 0%, transparent 50%);
  pointer-events: none;
}

.ft-event-hero > .container {
  position: relative;
  z-index: 1;
}

.ft-event-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: center;
}

.ft-event-hero__eyebrow {
  display: inline-block;
  margin-bottom: 1.2rem;
  border-radius: 4px;
  padding: .35rem .75rem;
  background: rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .82);
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.ft-event-hero__title {
  margin: 0 0 1.5rem;
  font-size: clamp(2.2rem, 6.5vw, 3.5rem);
  font-weight: 800;
  line-height: 1.08;
  letter-spacing: -0.025em;
}

.ft-event-hero__badges {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: 1.75rem;
}

.ft-event-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  border-radius: 6px;
  padding: .4rem .85rem;
  background: rgba(255, 255, 255, .15);
  color: rgba(255, 255, 255, .92);
  font-size: .9rem;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, .1);
  backdrop-filter: blur(8px);
}

.ft-event-hero__media {
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .22);
}

.ft-event-hero__media img {
  width: 100%;
  height: auto;
  min-height: 240px;
  object-fit: cover;
  display: block;
}

.ft-event-hero__placeholder {
  min-height: 280px;
  background: linear-gradient(140deg, #1C2A40, #0D1422);
  position: relative;
  overflow: hidden;
}

.ft-event-hero__placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 30% 60%, rgba(224, 96, 0, 0.18) 0%, transparent 55%);
}

.ft-event-content {
  padding: 3.5rem 0 4rem;
  background: #FDFAF6;
}

.ft-event-section {
  margin-bottom: 3.5rem;
  padding-bottom: 3rem;
  border-bottom: 2px solid #EDE7DC;
  position: relative;
}

.ft-event-section::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, #E06000, transparent);
}

.ft-event-section:last-child {
  border-bottom: none;
  margin-bottom: 0;
  padding-bottom: 0;
}

.ft-event-section:last-child::after {
  display: none;
}

.ft-event-section__heading {
  margin: 0 0 1.25rem;
  font-size: 1.5rem;
  font-weight: 800;
  color: #1A2132;
  letter-spacing: -0.015em;
}

.ft-event-section__body {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #3D4B62;
}

.ft-event-artists {
  display: flex;
  flex-wrap: wrap;
  gap: .8rem;
}

.ft-event-artist-tag {
  display: inline-flex;
  align-items: center;
  border-radius: 6px;
  padding: .5rem 1rem;
  background: rgba(255, 255, 255, .95);
  border: 1.5px solid rgba(255, 255, 255, .2);
  color: #1A2132;
  font-size: .92rem;
  font-weight: 700;
  text-decoration: none;
  transition: all .25s ease;
  box-shadow: 0 4px 12px rgba(0, 0, 0, .1);
}

.ft-event-artist-tag:hover,
.ft-event-artist-tag:focus {
  background: #fff;
  border-color: #E06000;
  color: #B84E00;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(224, 96, 0, .2);
}

.ft-event-artist-tag__country {
  margin-left: .5rem;
  color: #9ca3af;
  font-weight: 500;
  font-size: .82rem;
}


/* ============================================================
   Artist detail page layout
   ============================================================ */
.ft-artist-hero {
  padding: 4.5rem 0 3.5rem;
  background: linear-gradient(120deg, #0D1422 0%, #1C2A40 45%, #0D1422 100%);
  color: #fff;
  position: relative;
  overflow: hidden;
}

.ft-artist-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 55%, rgba(224, 96, 0, 0.14) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 70%, rgba(192, 139, 16, 0.1) 0%, transparent 50%);
  pointer-events: none;
}

.ft-artist-hero > .container {
  position: relative;
  z-index: 1;
}

.ft-artist-hero__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  align-items: center;
}

.ft-artist-photo {
  overflow: hidden;
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, .22);
}

.ft-artist-photo img {
  width: 100%;
  height: auto;
  aspect-ratio: 4/5;
  object-fit: cover;
  display: block;
}

.ft-artist-photo-placeholder {
  aspect-ratio: 4/5;
  background: linear-gradient(135deg, #0D1422 0%, #1C2A40 50%, #0D1422 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  border-radius: 12px;
  box-shadow: inset 0 0 30px rgba(0, 0, 0, .4);
}

.ft-artist-photo-placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 35% 50%, rgba(224, 96, 0, 0.2) 0%, transparent 50%),
    radial-gradient(ellipse at 70% 70%, rgba(192, 139, 16, 0.12) 0%, transparent 50%);
  pointer-events: none;
}

.ft-artist-photo-placeholder__initial {
  font-size: 5.5rem;
  font-weight: 800;
  color: rgba(255, 255, 255, .15);
  position: relative;
  z-index: 1;
  text-transform: uppercase;
  letter-spacing: -0.05em;
}

.ft-artist-hero__eyebrow {
  display: inline-block;
  margin-bottom: 1.2rem;
  border-radius: 4px;
  padding: .35rem .75rem;
  background: rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .82);
  font-weight: 700;
  font-size: .7rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  backdrop-filter: blur(10px);
}

.ft-artist-hero__name {
  margin: 0 0 1.5rem;
  font-size: clamp(2.3rem, 7vw, 3.75rem);
  font-weight: 900;
  line-height: 1.06;
  letter-spacing: -0.03em;
  text-shadow: 0 2px 10px rgba(0, 0, 0, .2);
}

.ft-artist-hero__meta {
  display: flex;
  flex-wrap: wrap;
  gap: .65rem;
  margin-bottom: 1.75rem;
}

.ft-artist-hero__meta-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  padding: .45rem .85rem;
  background: rgba(255, 255, 255, .15);
  color: rgba(255, 255, 255, .92);
  font-size: .9rem;
  font-weight: 600;
  border: 1px solid rgba(255, 255, 255, .1);
  backdrop-filter: blur(8px);
}

.ft-artist-hero__meta-item .field,
.ft-artist-hero__meta-item .field__items,
.ft-artist-hero__meta-item .field__item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.field--type-entity-reference {
  margin: 0;
}

.ft-artist-hero__social {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  margin-top: 1.75rem;
}

.ft-artist-hero__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #E06000;
  border: 2px solid transparent;
  color: #fff;
  text-decoration: none;
  transition: all .3s ease;
  box-shadow: 0 4px 12px rgba(224, 96, 0, .3);
}

.ft-artist-hero__social-link svg {
  width: 22px;
  height: 22px;
}

.ft-artist-hero__social-link:hover,
.ft-artist-hero__social-link:focus {
  background: linear-gradient(135deg, #E06000, #B84E00);
  transform: translateY(-4px) scale(1.1);
  box-shadow: 0 10px 25px rgba(224, 96, 0, .4);
}

.ft-artist-content {
  padding: 3.5rem 0 4rem;
  background: #FDFAF6;
}

.ft-artist-content__bio {
  font-size: 1.05rem;
  line-height: 1.8;
  color: #3D4B62;
  margin-bottom: 3.5rem;
  padding-bottom: 3rem;
  border-bottom: 2px solid #EDE7DC;
  max-width: 720px;
  position: relative;
}

.ft-artist-content__bio::after {
  content: "";
  position: absolute;
  bottom: -2px;
  left: 0;
  width: 60px;
  height: 2px;
  background: linear-gradient(90deg, #E06000, transparent);
}

.ft-artist-content__section-heading {
  margin: 0 0 1.5rem;
  font-size: 1.4rem;
  font-weight: 800;
  color: #1A2132;
  letter-spacing: -0.015em;
}

.ft-artist-event-link {
  display: inline-flex;
  align-items: center;
  gap: .6rem;
  border-radius: 6px;
  padding: .55rem 1.15rem;
  background: linear-gradient(135deg, #F7F3EC, #FDFAF6);
  border: 2px solid #E06000;
  color: #B84E00;
  font-weight: 700;
  font-size: .95rem;
  text-decoration: none;
  transition: all .25s ease;
  box-shadow: 0 2px 8px rgba(224, 96, 0, .1);
}

.ft-artist-event-link:hover,
.ft-artist-event-link:focus {
  background: #E06000;
  border-color: #B84E00;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 6px 16px rgba(224, 96, 0, .25);
}

/* Artist card placeholder: richer gradient behind the initial letter */
.ft-artist-card__image--placeholder {
  background: linear-gradient(160deg, #1C2A40 0%, #0D1422 100%);
  position: relative;
}

.ft-artist-card__image--placeholder::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 35% 55%, rgba(224, 96, 0, 0.14) 0%, transparent 55%);
  pointer-events: none;
}


/* ============================================================
   Contact page redesign
   ============================================================ */
.ft-contact-page {
  padding: 2rem 0 4.5rem;
}

.ft-contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3rem;
  align-items: start;
}

.ft-contact-info-card {
  padding: 2rem;
  background: #0D1422;
  border-radius: 12px;
  color: #fff;
  border-top: 3px solid #E06000;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .15);
}

.ft-contact-info-card__heading {
  margin: 0 0 .65rem;
  font-size: 1.15rem;
  font-weight: 700;
  color: #fff;
}

.ft-contact-info-card__intro {
  margin: 0 0 1.75rem;
  color: rgba(255, 255, 255, .62);
  font-size: .92rem;
  line-height: 1.6;
}

.ft-contact-info-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.1rem;
}

.ft-contact-info-item {
  display: flex;
  align-items: flex-start;
  gap: .85rem;
}

.ft-contact-info-item__icon {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 6px;
  background: rgba(255, 255, 255, .1);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: .05rem;
}

.ft-contact-info-item__icon svg {
  width: 18px;
  height: 18px;
  fill: rgba(255, 255, 255, .72);
}

.ft-contact-info-item__text {
  flex: 1;
}

.ft-contact-info-item__label {
  display: block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .4);
  margin-bottom: .25rem;
}

.ft-contact-info-item__value {
  font-size: .95rem;
  font-weight: 500;
  color: rgba(255, 255, 255, .88);
  word-break: break-word;
  line-height: 1.45;
}

.ft-contact-info-item__value a {
  color: rgba(255, 255, 255, .88);
  text-decoration: none;
}

.ft-contact-info-item__value a:hover,
.ft-contact-info-item__value a:focus {
  color: #f5b400;
  text-decoration: underline;
}

.ft-contact-map {
  margin-top: 3rem;
  border-radius: 10px;
  overflow: hidden;
}

.ft-contact-map iframe {
  width: 100%;
  border-radius: 10px;
  display: block;
}


/* ============================================================
   Footer: icon-enhanced contact column
   ============================================================ */
.ft-footer-contact__item {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.ft-footer-contact__item-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  fill: #E06000;
  margin-top: .1rem;
  opacity: 0.9;
}

.ft-footer-contact__item-text {
  font-size: .9rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, .75);
}

.ft-footer-contact__item-text a {
  color: rgba(255, 255, 255, .82);
  text-decoration: none;
}

.ft-footer-contact__item-text a:hover,
.ft-footer-contact__item-text a:focus {
  color: #f5b400;
  text-decoration: underline;
}
