/* =========================
   Festly UI System (Bootstrap-friendly)
   ========================= */

:root{
  --festly-bg: #12001f;
  --festly-card-radius: 1.25rem;
  --festly-btn-radius: .9rem;
  --festly-shadow: 0 .5rem 1.5rem rgba(0,0,0,.08);
  --festly-shadow-hover: 0 1rem 2.2rem rgba(0,0,0,.14);
}

/* Make pages look less "boxed" */
main.container{
  max-width: 1140px;
}

/* ---------- Navbar ---------- */
.festly-navbar{
  background: var(--festly-bg);
  box-shadow: 0 .5rem 1.2rem rgba(0,0,0,.20);
}

.festly-navbar .navbar-brand img{
  height: 36px;
}

.festly-navbar .nav-link{
  color: rgba(255,255,255,.85);
  font-weight: 600;
  padding: .55rem .9rem;
  border-radius: 999px;
  transition: background.15s ease, color .15s ease, transform .15s ease;
}

.festly-navbar .nav-link:hover{
  color: #fff;
  background: rgba(255,255,255,.10);
  transform: translateY(-1px);
}

/* Optional: highlight active link if you add 'active' class in templates later */
.festly-navbar .nav-link.active{
  color: #fff;
  background: rgba(255,255,255,.16);
}

/* ---------- Festly Cards (Specials + Listings) ---------- */
.festly-card{
  border: 0;
  border-radius: var(--festly-card-radius);
  overflow: hidden;
  background: #fff;
  transition: transform .18s ease, box-shadow .18s ease;
  box-shadow: var(--festly-shadow);
}

.festly-card:hover{
  transform: translateY(-4px);
  box-shadow: var(--festly-shadow-hover);
}

.festly-media{
  position: relative;
  aspect-ratio: 16 / 10;
  background: #f2f3f5;
}

.festly-media img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.festly-media::after{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 45%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
}

.festly-badge{
  position: absolute;
  top: .75rem;
  left: .75rem;
  z-index: 2;
  border-radius: 999px;
  padding: .35rem .6rem;
  font-size: .8rem;
  backdrop-filter: blur(6px);
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(0,0,0,.06);
}

.festly-pill{
  position:absolute;
  bottom:.75rem;
  left:.75rem;
  z-index:2;
  border-radius:999px;
  padding:.4rem .7rem;
  font-weight:700;
  font-size:.85rem;
  background: rgba(0,0,0,.72);
  color:#fff;
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
}

.festly-title{
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.festly-desc{
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  min-height: 2.6em;
}

.btn-festly{
  border-radius: var(--festly-btn-radius);
  padding: .75rem 1rem;
  font-weight: 800;
  letter-spacing: .2px;
}

.festly-meta{
  font-size: .85rem;
}

/* Small screens: nicer spacing */
@media (max-width: 575.98px){
  .festly-navbar .nav-link{
    border-radius: .75rem;
  }
}


/* ---------- Detail Pages ---------- */
.festly-hero {
  border-radius: var(--festly-card-radius);
  overflow: hidden;
  background: #f2f3f5;
  box-shadow: var(--festly-shadow);
}

.festly-hero img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.festly-section-card{
  border: 0;
  border-radius: var(--festly-card-radius);
  box-shadow: var(--festly-shadow);
  background:#fff;
}

.festly-input .form-control,
.festly-input textarea.form-control,
.festly-input select.form-select{
  border-radius: .9rem;
  padding: .75rem .95rem;
}

.festly-input .form-control:focus,
.festly-input textarea.form-control:focus,
.festly-input select.form-select:focus{
  box-shadow: 0 0 0 .25rem rgba(13,110,253,.12);
}

.festly-trust{
  border: 1px solid rgba(0,0,0,.06);
  border-radius: 999px;
  padding: .45rem .7rem;
  background: rgba(255,255,255,.85);
}

/* Sticky CTA for mobile */
.festly-sticky-cta{
  position: sticky;
  bottom: 0;
  z-index: 1030;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);
  border-top: 1px solid rgba(0,0,0,.08);
}

@media (min-width: 992px){
  .festly-sticky-cta{ display:none; }
}
