/* ========================================
   INNER PAGES — Shared + Page-specific CSS
   Events | Catering & Venue | Visit Us | Contact Us
   ======================================== */

/* ========================================
   SHARED: INNER HERO BANNERS
   ======================================== */
.inner-hero {
  position: relative;
  min-height: 280px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.inner-hero-bg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.inner-hero-overlay {
  position: absolute;
  inset: 0;
  background: rgba(var(--color-primary-rgb), 0.55);
  z-index: 1;
}

.inner-hero-content {
  position: relative;
  z-index: 2;
  text-align: center;
  padding: var(--sp-16) var(--padding-page);
}

.inner-hero-title {
  color: var(--color-white);
  font-size: var(--text-hero);
  text-transform: uppercase;
  max-width: 800px;
  margin: 0 auto;
}

.inner-hero-subtitle {
  color: rgba(255, 255, 255, 0.9);
  font-size: var(--text-lg);
  max-width: 600px;
  margin: var(--sp-4) auto 0;
  line-height: 1.6;
}

.inner-hero-illustration {
  position: absolute;
  width: 120px;
  height: auto;
  opacity: 0.2;
  pointer-events: none;
}

.inner-hero-actions {
  display: flex;
  gap: var(--sp-4);
  justify-content: center;
  margin-top: var(--sp-8);
  flex-wrap: wrap;
}

.inner-hero-actions .catering-hero-btn-outline {
  color: var(--color-white);
  border-color: var(--color-white);
}

.inner-hero-actions .catering-hero-btn-outline:hover {
  background: var(--color-white);
  color: var(--color-primary);
}

/* ========================================
   SHARED: SECTION HEADINGS
   ======================================== */
.section-heading {
  font-family: var(--font-heading);
  font-size: var(--text-section);
  font-weight: var(--heading-weight);
  text-transform: uppercase;
  letter-spacing: var(--heading-letter-spacing);
  color: var(--color-primary);
  text-align: center;
  margin-bottom: var(--sp-10);
}

/* ========================================
   SHARED: FORM STYLES
   ======================================== */
.form-section {
  max-width: 800px;
  margin: 0 auto;
  background: var(--color-white);
  border-radius: var(--rounded-card);
  padding: var(--sp-10) var(--sp-8);
  box-shadow: var(--shadow-card);
}

.form-intro {
  text-align: center;
  margin-bottom: var(--sp-8);
}

.form-intro h2 {
  font-size: var(--text-3xl);
  margin-bottom: var(--sp-3);
}

.form-intro p {
  color: var(--color-text-light);
  font-size: var(--text-lg);
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-bottom: var(--sp-5);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}

.form-group label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
}

.form-group .required {
  color: var(--color-error);
}

.form-group input,
.form-group select,
.form-group textarea {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg-page);
  border: 1.5px solid rgba(var(--color-primary-rgb), 0.2);
  border-radius: var(--rounded-lg);
  padding: var(--sp-3) var(--sp-4);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  width: 100%;
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

.form-group input::placeholder,
.form-group textarea::placeholder {
  color: rgba(var(--color-primary-rgb), 0.4);
}

.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23115E32' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--sp-4) center;
  padding-right: var(--sp-10);
}

.form-group textarea {
  resize: vertical;
  min-height: 120px;
}

.form-group-full {
  margin-bottom: var(--sp-5);
}

.form-submit {
  width: 100%;
  font-size: var(--text-base);
}

/* Form validation styles */
.form-group input:invalid:not(:placeholder-shown),
.form-group textarea:invalid:not(:placeholder-shown) {
  border-color: var(--color-error);
}

/* ========================================
   SHARED: PILL BUTTONS (Maps/Waze)
   ======================================== */
.btn-pill {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  padding: var(--sp-2d5) var(--sp-5);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border-radius: var(--rounded-button);
  transition: all var(--transition-base);
  text-decoration: none;
  min-height: 40px;
}

.btn-maps {
  background: var(--color-primary);
  color: var(--color-white);
  border: 2px solid var(--color-primary);
}

.btn-maps:hover {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-primary);
}

.btn-waze {
  background: transparent;
  color: var(--color-primary);
  border: 2px solid var(--color-primary);
}

.btn-waze:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

/* ========================================
   EVENTS PAGE
   ======================================== */

/* Events Hero */
.events-hero {
  min-height: 360px;
}

.events-hero-illustration {
  top: var(--sp-4);
  right: var(--sp-4);
  width: 100px;
  opacity: 0.15;
}

/* Upcoming Events */
.events-upcoming {
  position: relative;
  overflow: hidden;
}

.events-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}

.event-card {
  background: var(--color-white);
  border-radius: var(--rounded-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: box-shadow var(--transition-base);
}

.event-card:hover {
  box-shadow: var(--shadow-card-hover);
}

.event-card-image {
  padding: var(--sp-6);
  background: var(--color-bg-page);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}

.event-card-image img {
  max-height: 180px;
  width: auto;
  object-fit: contain;
}

.event-card-body {
  padding: var(--sp-6);
}

.event-badges {
  display: flex;
  gap: var(--sp-2);
  flex-wrap: wrap;
  margin-bottom: var(--sp-3);
}

.event-badge {
  display: inline-block;
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--rounded-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.event-badge-date {
  background: var(--color-primary);
  color: var(--color-white);
}

.event-badge-free {
  background: var(--color-gold);
  color: var(--color-primary);
}

.event-card-title {
  font-size: var(--text-2xl);
  margin-bottom: var(--sp-1);
}

.event-card-subtitle {
  font-size: var(--text-lg);
  color: var(--color-text-light);
  font-weight: var(--weight-medium);
  margin-bottom: var(--sp-3);
}

.event-card-desc {
  font-size: var(--text-base);
  line-height: 1.6;
  margin-bottom: var(--sp-4);
}

.event-card-details {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2d5);
  margin-bottom: var(--sp-4);
}

.event-detail {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2);
  font-size: var(--text-sm);
  color: var(--color-text-light);
}

.event-detail svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--color-primary);
}

.event-detail a {
  color: var(--color-primary);
  font-weight: var(--weight-medium);
}

.event-detail a:hover {
  color: var(--color-gold);
}

.event-card-note {
  font-size: var(--text-sm);
  font-style: italic;
  color: var(--color-text-light);
  margin-bottom: var(--sp-5);
  padding: var(--sp-3);
  background: rgba(var(--color-gold-rgb), 0.1);
  border-radius: var(--rounded-md);
  border-left: 3px solid var(--color-gold);
}

.event-cta {
  width: 100%;
  text-align: center;
}

/* Decorative illustrations (events) */
.events-deco {
  position: absolute;
  width: 100px;
  opacity: 0.08;
  pointer-events: none;
  z-index: 0;
}

.events-deco-1 {
  bottom: -20px;
  left: -20px;
  transform: rotate(-15deg);
}

.events-deco-2 {
  top: 40px;
  right: -10px;
  transform: rotate(10deg);
}

/* Past Events */
.events-past {
  background: var(--color-white);
}

.past-events-cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
  margin-bottom: var(--sp-10);
}

.past-event-card {
  border-radius: var(--rounded-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

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

.past-event-card-img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.past-event-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.past-event-card:hover .past-event-card-img img {
  transform: scale(1.05);
}

.past-event-card-info {
  padding: var(--sp-4) var(--sp-5);
  background: var(--color-bg-page);
}

.past-event-date {
  display: block;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-light);
  margin-bottom: var(--sp-1);
}

.past-event-card-info h3 {
  font-size: var(--text-card-title);
}

/* Events Gallery */
.events-gallery {
  position: relative;
  margin-top: var(--sp-8);
}

.events-gallery-track {
  display: flex;
  gap: var(--sp-4);
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--sp-4);
  scrollbar-width: thin;
  scrollbar-color: var(--color-primary) transparent;
}

.events-gallery-track::-webkit-scrollbar {
  height: 6px;
}

.events-gallery-track::-webkit-scrollbar-track {
  background: transparent;
}

.events-gallery-track::-webkit-scrollbar-thumb {
  background: var(--color-primary);
  border-radius: 3px;
}

.gallery-item {
  flex: 0 0 280px;
  scroll-snap-align: start;
  border-radius: var(--rounded-card);
  overflow: hidden;
}

.gallery-item img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.gallery-item:hover img {
  transform: scale(1.05);
}

.gallery-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--color-white);
  color: var(--color-primary);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all var(--transition-fast);
  z-index: 2;
  border: none;
}

.gallery-nav:hover {
  background: var(--color-primary);
  color: var(--color-white);
}

.gallery-nav-prev {
  left: -22px;
}

.gallery-nav-next {
  right: -22px;
}

/* Event Inquiry */
.events-inquiry {
  background: var(--color-bg-page);
}

.inquiry-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
  align-items: center;
}

.inquiry-image {
  border-radius: var(--rounded-card);
  overflow: hidden;
}

.inquiry-image img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.inquiry-content h2 {
  font-size: var(--text-3xl);
  margin-bottom: var(--sp-4);
}

.inquiry-content p {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text);
}

.inquiry-capacity {
  font-weight: var(--weight-semibold);
  color: var(--color-primary) !important;
  margin-top: var(--sp-2);
  padding: var(--sp-3) var(--sp-4);
  background: rgba(var(--color-gold-rgb), 0.1);
  border-radius: var(--rounded-md);
  border-left: 3px solid var(--color-gold);
}

.inquiry-actions {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
  margin-top: var(--sp-6);
}

/* ========================================
   CATERING & VENUE PAGE
   ======================================== */

/* Catering Hero */
.catering-hero {
  min-height: 400px;
}

/* Service Cards */
.services-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}

.service-card {
  background: var(--color-white);
  border-radius: var(--rounded-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

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

.service-card-img {
  aspect-ratio: 16 / 10;
  overflow: hidden;
}

.service-card-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-slow);
}

.service-card:hover .service-card-img img {
  transform: scale(1.05);
}

.service-card-body {
  padding: var(--sp-6);
}

.service-card-body h3 {
  font-size: var(--text-card-title);
  margin-bottom: var(--sp-3);
}

.service-card-body p {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text-light);
}

.services-cta {
  text-align: center;
  margin-top: var(--sp-10);
}

/* Testimonials */
.catering-testimonials {
  background: var(--color-white);
}

.testimonials-header {
  position: relative;
  text-align: center;
  margin-bottom: var(--sp-10);
}

.testimonials-deco {
  position: absolute;
  top: -30px;
  right: 10%;
  width: 80px;
  opacity: 0.1;
  pointer-events: none;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-6);
}

.testimonial-card {
  background: var(--color-bg-page);
  border-radius: var(--rounded-card);
  padding: var(--sp-8) var(--sp-6);
  text-align: center;
  position: relative;
  border: none;
  margin: 0;
}

.testimonial-quote svg {
  margin-bottom: var(--sp-3);
}

.testimonial-quote p {
  font-family: var(--font-heading);
  font-size: var(--text-lg);
  font-style: italic;
  line-height: 1.6;
  color: var(--color-text);
}

.testimonial-author {
  display: block;
  margin-top: var(--sp-4);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-light);
  font-style: normal;
}

/* Catering Form */
.catering-form {
  background: var(--color-bg-page);
}

/* ========================================
   VISIT US PAGE
   ======================================== */

/* Visit Hero */
.visit-hero {
  min-height: 300px;
}

.visit-hero-illustration {
  top: var(--sp-4);
  left: var(--sp-4);
  width: 100px;
  opacity: 0.15;
}

/* Locations Grid */
.locations-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
}

.location-card {
  background: var(--color-white);
  border-radius: var(--rounded-card);
  padding: var(--sp-8) var(--sp-6);
  box-shadow: var(--shadow-card);
}

.location-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-3);
  margin-bottom: var(--sp-5);
  flex-wrap: wrap;
}

.location-card-header h2 {
  font-size: var(--text-2xl);
}

.location-status {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-1d5);
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--rounded-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.location-status.is-open {
  background: rgba(77, 124, 15, 0.15);
  color: var(--color-success);
}

.location-status.is-open::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-success);
  animation: pulse-dot 2s infinite;
}

.location-status.is-closed {
  background: rgba(190, 18, 60, 0.15);
  color: var(--color-error);
}

.location-status.is-closed::before {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--color-error);
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.location-card-feature-img {
  margin-bottom: var(--sp-5);
  border-radius: var(--rounded-md);
  overflow: hidden;
}

.location-card-feature-img img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

.location-address {
  font-size: var(--text-base);
  line-height: 1.6;
  color: var(--color-text);
  margin-bottom: var(--sp-5);
  padding-bottom: var(--sp-5);
  border-bottom: 1px solid rgba(var(--color-primary-rgb), 0.1);
}

.location-info-block {
  margin-bottom: var(--sp-5);
}

.location-info-label {
  display: flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
  margin-bottom: var(--sp-2);
}

.location-info-label svg {
  flex-shrink: 0;
}

.location-hours p {
  font-size: var(--text-base);
  color: var(--color-text-light);
  margin-bottom: var(--sp-1);
}

.location-phone {
  font-size: var(--text-base);
  font-weight: var(--weight-medium);
  color: var(--color-primary);
  transition: color var(--transition-fast);
}

.location-phone:hover {
  color: var(--color-gold);
}

/* Parking Info */
.parking-info {
  display: flex;
  flex-direction: column;
  gap: var(--sp-3);
}

.parking-info li {
  display: flex;
  align-items: flex-start;
  gap: var(--sp-2d5);
  font-size: var(--text-sm);
  color: var(--color-text-light);
  line-height: 1.5;
}

.parking-info li svg {
  flex-shrink: 0;
  color: var(--color-primary);
  margin-top: 2px;
}

/* Location Actions */
.location-actions {
  display: flex;
  gap: var(--sp-3);
  flex-wrap: wrap;
  margin-top: var(--sp-6);
  padding-top: var(--sp-5);
  border-top: 1px solid rgba(var(--color-primary-rgb), 0.1);
}

/* Visit Decorations */
.visit-decorations {
  position: relative;
  height: 0;
  overflow: visible;
}

.visit-deco {
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.visit-deco-flower {
  width: 120px;
  opacity: 0.08;
  bottom: -200px;
  right: 0;
}

/* ========================================
   CONTACT US PAGE
   ======================================== */

/* Contact Hero */
.contact-hero {
  min-height: 340px;
}

.contact-hero-pattern {
  position: absolute;
  inset: 0;
  z-index: 0;
  opacity: 0.04;
  background-image:
    repeating-linear-gradient(
      0deg,
      transparent,
      transparent 40px,
      var(--color-white) 40px,
      var(--color-white) 41px
    ),
    repeating-linear-gradient(
      90deg,
      transparent,
      transparent 40px,
      var(--color-white) 40px,
      var(--color-white) 41px
    );
  background-size: 41px 41px;
}

.contact-hero-overlay {
  background: rgba(var(--color-primary-rgb), 0.7);
}

.contact-hero-illustration {
  top: var(--sp-6);
  right: var(--sp-6);
  width: 100px;
  opacity: 0.15;
}

/* WhatsApp CTA */
.contact-whatsapp {
  background: var(--color-white);
}

.whatsapp-cta-block {
  text-align: center;
  max-width: 500px;
  margin: 0 auto;
}

.whatsapp-cta-block h2 {
  font-size: var(--text-3xl);
  margin-bottom: var(--sp-3);
}

.whatsapp-cta-block p {
  color: var(--color-text-light);
  font-size: var(--text-base);
  margin-bottom: var(--sp-6);
}

.btn-whatsapp {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-10);
  background: #25D366;
  color: var(--color-white);
  font-family: var(--font-body);
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  border-radius: var(--rounded-button);
  text-decoration: none;
  transition: all var(--transition-base);
  min-height: 56px;
  box-shadow: 0 4px 16px rgba(37, 211, 102, 0.3);
}

.btn-whatsapp:hover {
  background: #1DA851;
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(37, 211, 102, 0.4);
}

/* Contact Info Grid */
.contact-info {
  background: var(--color-bg-page);
}

.contact-info-intro {
  text-align: center;
  max-width: 700px;
  margin: 0 auto var(--sp-10);
  margin-top: calc(-1 * var(--sp-6));
  color: var(--color-text-light);
  font-size: var(--text-base);
  line-height: 1.7;
}

.contact-cards-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}

.contact-info-card {
  background: var(--color-white);
  border-radius: var(--rounded-card);
  padding: var(--sp-6) var(--sp-5);
  text-align: center;
  box-shadow: var(--shadow-card);
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.contact-info-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-card-hover);
}

.contact-info-icon {
  margin-bottom: var(--sp-4);
}

.contact-info-icon img {
  margin: 0 auto;
  width: 40px;
  height: 40px;
}

.contact-info-card h3 {
  font-size: var(--text-base);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: var(--sp-3);
}

.contact-info-card a,
.contact-info-card p {
  font-size: var(--text-sm);
  color: var(--color-text-light);
  line-height: 1.6;
  transition: color var(--transition-fast);
}

.contact-info-card a:hover {
  color: var(--color-gold);
}

/* Contact Form */
.contact-form-section {
  background: var(--color-white);
}

/* CF7 form styling */
.contact-form-section .wpcf7-form label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-primary);
}

.contact-form-section .wpcf7-form input[type="text"],
.contact-form-section .wpcf7-form input[type="email"],
.contact-form-section .wpcf7-form input[type="tel"],
.contact-form-section .wpcf7-form textarea,
.contact-form-section .wpcf7-form select {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-bg-page);
  border: 1.5px solid rgba(var(--color-primary-rgb), 0.2);
  border-radius: var(--rounded-lg);
  padding: var(--sp-3) var(--sp-4);
  width: 100%;
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}

.contact-form-section .wpcf7-form input:focus,
.contact-form-section .wpcf7-form textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

.contact-form-section .wpcf7-form input[type="submit"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-3) var(--sp-8);
  font-family: var(--font-body);
  font-size: var(--text-button);
  font-weight: var(--weight-medium);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-btn-primary-text);
  background: var(--color-btn-primary-bg);
  border: 2px solid var(--color-primary);
  border-radius: var(--rounded-button);
  cursor: pointer;
  transition: all var(--transition-base);
  min-height: 48px;
  width: 100%;
}

.contact-form-section .wpcf7-form input[type="submit"]:hover {
  background: var(--color-gold);
  border-color: var(--color-gold);
  color: var(--color-primary);
}

/* Host an Event CTA */
.contact-event-cta {
  background: var(--color-bg-page);
}

.event-cta-split {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-8);
  align-items: center;
}

.event-cta-images {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--sp-4);
}

.event-cta-img {
  border-radius: var(--rounded-card);
  overflow: hidden;
  width: 100%;
  height: auto;
  object-fit: cover;
  aspect-ratio: 3/4;
}

.event-cta-img-2 {
  margin-top: var(--sp-8);
}

.event-cta-content {
  position: relative;
}

.event-cta-illustration {
  position: absolute;
  top: -40px;
  right: 0;
  width: 80px;
  opacity: 0.1;
  pointer-events: none;
}

.event-cta-content h2 {
  font-size: var(--text-3xl);
  margin-bottom: var(--sp-4);
}

.event-cta-content p {
  font-size: var(--text-base);
  line-height: 1.7;
  color: var(--color-text-light);
  margin-bottom: var(--sp-6);
}

.event-cta-actions {
  display: flex;
  gap: var(--sp-4);
  flex-wrap: wrap;
}

/* ========================================
   SHARED: FORM VALIDATION + SUCCESS
   ======================================== */
.field-error {
  border-color: var(--color-error) !important;
  box-shadow: 0 0 0 3px rgba(190, 18, 60, 0.1) !important;
}

.field-error-msg {
  font-size: var(--text-xs);
  color: var(--color-error);
  margin-top: var(--sp-1);
}

.form-success-banner {
  background: rgba(77, 124, 15, 0.1);
  border: 1px solid var(--color-success);
  border-radius: var(--rounded-md);
  padding: var(--sp-4) var(--sp-6);
  margin-bottom: var(--sp-6);
  text-align: center;
}

.form-success-banner p {
  color: var(--color-success);
  font-weight: var(--weight-semibold);
  font-size: var(--text-base);
}

/* ========================================
   RESPONSIVE: MOBILE (max-width: 767px)
   ======================================== */
@media (max-width: 767px) {
  /* --- Inner Heroes: cinematic, immersive --- */
  .inner-hero {
    min-height: 50vh;
    max-height: 400px;
  }

  .events-hero {
    min-height: 50vh;
  }

  .catering-hero {
    min-height: 50vh;
  }

  .visit-hero {
    min-height: 45vh;
  }

  .contact-hero {
    min-height: 50vh;
  }

  .inner-hero-content {
    padding: var(--sp-10) 16px;
  }

  .inner-hero-title {
    font-size: clamp(1.75rem, 6vw, 2.5rem);
    letter-spacing: 0.05em;
  }

  .inner-hero-subtitle {
    font-size: var(--text-base);
    margin-top: var(--sp-3);
  }

  .inner-hero-illustration {
    width: 70px;
    opacity: 0.12;
  }

  .inner-hero-actions {
    margin-top: var(--sp-5);
    gap: var(--sp-3);
  }

  .inner-hero-actions .btn-primary,
  .inner-hero-actions .btn-secondary,
  .inner-hero-actions .btn-gold,
  .inner-hero-actions .catering-hero-btn-outline {
    width: 100%;
    min-height: 48px;
    justify-content: center;
    font-size: var(--text-sm);
  }

  /* --- Section spacing: mobile-tighter --- */
  .events-upcoming,
  .events-past,
  .events-inquiry,
  .catering-testimonials,
  .catering-form,
  .contact-whatsapp,
  .contact-info,
  .contact-form-section,
  .contact-event-cta {
    padding-top: 48px;
    padding-bottom: 48px;
  }

  /* --- Events Page --- */
  .events-grid {
    gap: var(--sp-5);
  }

  .event-card-image {
    padding: var(--sp-4);
    min-height: 160px;
  }

  .event-card-image img {
    max-height: 140px;
  }

  .event-card-body {
    padding: var(--sp-4);
  }

  .event-card-title {
    font-size: var(--text-xl);
  }

  .event-card-subtitle {
    font-size: var(--text-base);
  }

  .event-cta {
    width: 100%;
  }

  .event-cta .btn-primary,
  .event-cta .btn-gold {
    width: 100%;
    min-height: 48px;
  }

  .events-deco {
    display: none;
  }

  /* --- Events Gallery: 2-column grid on mobile --- */
  .events-gallery-track {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-2);
    overflow-x: visible;
    scroll-snap-type: none;
    padding-bottom: 0;
  }

  .gallery-item {
    flex: none;
    width: 100%;
  }

  .gallery-item img {
    height: 140px;
    width: 100%;
    border-radius: var(--rounded-md);
  }

  .gallery-nav {
    display: none;
  }

  /* Past Events: 2-col */
  .past-events-cards {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-3);
  }

  .past-event-card-img {
    aspect-ratio: 1 / 1;
  }

  .past-event-card-info {
    padding: var(--sp-3);
  }

  .past-event-card-info h3 {
    font-size: var(--text-sm);
  }

  .past-event-date {
    font-size: 0.625rem;
  }

  /* Inquiry section */
  .inquiry-split {
    gap: var(--sp-6);
  }

  .inquiry-content h2 {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
  }

  .inquiry-actions {
    flex-direction: column;
    gap: var(--sp-3);
  }

  .inquiry-actions .btn-primary,
  .inquiry-actions .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  /* --- Catering & Venue --- */
  .services-grid {
    gap: 16px;
  }

  .service-card-body {
    padding: var(--sp-4);
  }

  .service-card-body h3 {
    font-size: var(--text-base);
    margin-bottom: var(--sp-2);
  }

  .service-card-body p {
    font-size: var(--text-sm);
  }

  .service-card-img {
    aspect-ratio: 16 / 10;
  }

  .services-cta {
    margin-top: var(--sp-6);
  }

  .services-cta .btn-primary {
    width: 100%;
  }

  /* Testimonials */
  .testimonials-grid {
    gap: 16px;
  }

  .testimonial-card {
    padding: var(--sp-5) var(--sp-4);
  }

  .testimonial-quote p {
    font-size: var(--text-base);
  }

  /* --- Visit Us --- */
  .locations-grid {
    gap: var(--sp-5);
  }

  .location-card {
    padding: var(--sp-5) var(--sp-4);
  }

  .location-card-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--sp-2);
  }

  .location-card-header h2 {
    font-size: var(--text-xl);
  }

  .location-actions {
    flex-direction: column;
    gap: var(--sp-2);
  }

  .location-actions .btn-pill,
  .location-actions .btn-maps,
  .location-actions .btn-waze {
    width: 100%;
    justify-content: center;
    min-height: 44px;
  }

  /* --- Contact Us --- */
  .whatsapp-cta-block h2 {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
  }

  .btn-whatsapp {
    width: 100%;
    justify-content: center;
    font-size: var(--text-base);
    padding: var(--sp-3) var(--sp-6);
    min-height: 52px;
  }

  .contact-cards-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-3);
  }

  .contact-info-card {
    padding: var(--sp-4);
  }

  .contact-info-card h3 {
    font-size: var(--text-xs);
    margin-bottom: var(--sp-2);
  }

  .contact-info-card a,
  .contact-info-card p {
    font-size: var(--text-xs);
  }

  .contact-info-icon img {
    width: 32px;
    height: 32px;
  }

  /* Event CTA */
  .event-cta-split {
    gap: var(--sp-6);
  }

  .event-cta-content h2 {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
  }

  .event-cta-actions {
    flex-direction: column;
    gap: var(--sp-3);
  }

  .event-cta-actions .btn-primary,
  .event-cta-actions .btn-secondary {
    width: 100%;
    justify-content: center;
  }

  /* --- Forms: mobile-friendly --- */
  .form-section {
    padding: var(--sp-6) var(--sp-4);
    border-radius: var(--rounded-lg);
  }

  .form-intro h2 {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
  }

  .form-intro p {
    font-size: var(--text-base);
  }

  .form-grid {
    gap: var(--sp-4);
  }

  .form-submit {
    width: 100%;
    min-height: 48px;
  }

  /* CF7 form mobile */
  .contact-form-section .wpcf7-form input[type="submit"] {
    width: 100%;
    min-height: 48px;
    font-size: 16px;
  }

  /* Contact form grid: single column on mobile */
  .bartolo-form-grid {
    grid-template-columns: 1fr !important;
    gap: var(--sp-4);
  }

  /* Section headings */
  .section-heading {
    font-size: clamp(1.25rem, 4vw, 1.75rem);
    margin-bottom: var(--sp-6);
    letter-spacing: 0.05em;
  }

  /* Decorations: reduce on mobile */
  .visit-deco,
  .testimonials-deco,
  .event-cta-illustration {
    display: none;
  }
}

/* ========================================
   RESPONSIVE: TABLET (768px+)
   ======================================== */
@media (min-width: 768px) {
  .inner-hero {
    min-height: 340px;
  }

  .inner-hero-content {
    padding: var(--sp-20) var(--padding-page-md);
  }

  .inner-hero-illustration {
    width: 160px;
  }

  /* Forms */
  .form-grid {
    grid-template-columns: 1fr 1fr;
  }

  .form-section {
    padding: var(--sp-12) var(--sp-10);
  }

  .form-submit {
    width: auto;
    min-width: 200px;
  }

  /* Events */
  .events-grid {
    grid-template-columns: 1fr 1fr;
  }

  .event-card {
    display: flex;
    flex-direction: column;
  }

  .past-events-cards {
    grid-template-columns: repeat(3, 1fr);
  }

  .gallery-item {
    flex: 0 0 320px;
  }

  .gallery-item img {
    height: 240px;
  }

  .gallery-nav {
    display: flex;
  }

  .events-deco {
    width: 140px;
  }

  /* Inquiry split */
  .inquiry-split {
    grid-template-columns: 1fr 1fr;
  }

  /* Catering */
  .services-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .testimonials-grid {
    grid-template-columns: repeat(3, 1fr);
  }

  /* Visit Us */
  .locations-grid {
    grid-template-columns: 1fr 1fr;
  }

  /* Contact */
  .contact-cards-grid {
    grid-template-columns: 1fr 1fr;
  }

  .event-cta-split {
    grid-template-columns: 1fr 1fr;
  }
}

/* ========================================
   RESPONSIVE: DESKTOP (1024px+)
   ======================================== */
@media (min-width: 1024px) {
  .inner-hero {
    min-height: 380px;
  }

  .events-hero {
    min-height: 420px;
  }

  .catering-hero {
    min-height: 450px;
  }

  .inner-hero-content {
    padding: var(--sp-24) var(--padding-page-lg);
  }

  /* Contact cards 4-col */
  .contact-cards-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  /* Gallery */
  .gallery-item {
    flex: 0 0 360px;
  }

  .gallery-item img {
    height: 260px;
  }
}

/* ========================================
   RESPONSIVE: LARGE DESKTOP (1280px+)
   ======================================== */
@media (min-width: 1280px) {
  .inner-hero-illustration {
    width: 200px;
    opacity: 0.2;
  }

  .events-deco {
    width: 180px;
  }
}

/* ========================================
   EV-* CLASS OVERRIDES (Events page inline PHP styles)
   Mobile premium overhaul
   ======================================== */
@media (max-width: 767px) {
  /* --- Events Hero: keep immersive but ensure text readable --- */
  .ev-hero {
    min-height: 55vh !important;
    max-height: 500px !important;
  }

  .ev-hero-content {
    padding: 0 16px !important;
  }

  .ev-hero-title {
    font-size: clamp(1.75rem, 5vw, 2.5rem) !important;
    letter-spacing: 0.05em;
  }

  .ev-hero-sub {
    font-size: 0.9375rem !important;
  }

  /* --- Section spacing: tighter --- */
  .ev-section {
    padding: 40px 16px !important;
  }

  .ev-section-heading {
    font-size: clamp(1.25rem, 4vw, 1.75rem) !important;
    letter-spacing: 0.05em;
  }

  .ev-section-sub {
    font-size: 0.875rem !important;
  }

  .ev-section-label {
    font-size: 0.6875rem !important;
  }

  /* --- Event Cards: full-width, compact --- */
  .ev-events-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .ev-event-card {
    border-radius: 0.75rem !important;
  }

  .ev-event-card-img {
    aspect-ratio: 16 / 10 !important;
    max-height: 220px !important;
  }

  .ev-event-card-body {
    padding: 1rem !important;
  }

  .ev-event-card-title {
    font-size: 1.125rem !important;
  }

  .ev-event-card-subtitle {
    font-size: 0.875rem !important;
  }

  .ev-event-card-desc {
    font-size: 0.8125rem !important;
  }

  .ev-event-card-schedule {
    font-size: 0.8125rem !important;
  }

  .ev-btn-whatsapp,
  .ev-btn-gold {
    width: 100% !important;
    justify-content: center !important;
    min-height: 48px !important;
    font-size: 0.875rem !important;
  }

  .ev-badge {
    font-size: 0.625rem !important;
    padding: 0.125rem 0.5rem !important;
  }

  /* --- Gallery: 2-column grid --- */
  .ev-masonry {
    columns: 2 !important;
    column-gap: 8px !important;
  }

  .ev-masonry-item {
    margin-bottom: 8px !important;
    border-radius: 0.5rem !important;
  }

  /* --- Atmosphere section --- */
  .ev-atm-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .ev-atm-pullquote {
    font-size: 1rem !important;
    padding: 1rem !important;
  }

  /* --- Host an event section --- */
  .ev-host-grid {
    grid-template-columns: 1fr !important;
    gap: 1.25rem !important;
  }

  .ev-host-features {
    grid-template-columns: 1fr 1fr !important;
    gap: 0.75rem !important;
  }

  .ev-host-feature {
    padding: 0.75rem !important;
  }

  .ev-host-feature-label {
    font-size: 0.75rem !important;
  }

  .ev-host-desc {
    font-size: 0.875rem !important;
  }

  /* --- Fallback cards --- */
  .ev-fallback-card {
    border-radius: 0.75rem !important;
  }

  .ev-fallback-card-body {
    padding: 1rem !important;
  }

  /* --- Scroll indicator --- */
  .ev-scroll-indicator {
    display: none !important;
  }

  /* --- Lightbox: full viewport on mobile --- */
  .ev-lightbox-img {
    max-width: 95vw !important;
    max-height: 80vh !important;
  }

  .ev-lightbox-close {
    top: 12px !important;
    right: 12px !important;
  }

  .ev-lightbox-prev {
    left: 8px !important;
  }

  .ev-lightbox-next {
    right: 8px !important;
  }
}

/* Tablet overrides for ev-* */
@media (min-width: 768px) and (max-width: 1023px) {
  .ev-hero {
    min-height: 50vh !important;
  }

  .ev-events-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 20px !important;
  }

  .ev-masonry {
    columns: 3 !important;
  }

  .ev-host-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

/* ========================================
   MOBILE REDESIGN — INNER PAGES
   2026-03-27 | 375px target
   ======================================== */

@media (max-width: 767px) {

  /* ============================================================
     EVENTS PAGE — Gallery, Hero, Cards, CTAs
     ============================================================ */

  /* Jazz Night / featured event hero: exactly 50vh */
  .ev-hero {
    min-height: 50vh !important;
    max-height: 50vh !important;
  }

  /* Gallery: force 2-column grid (override any flex/horizontal scroll) */
  .ev-masonry {
    columns: 2 !important;
    column-gap: 8px !important;
    gap: 0 !important;
  }

  .ev-masonry-item {
    break-inside: avoid !important;
    margin-bottom: 8px !important;
    border-radius: 8px !important;
    overflow: hidden !important;
  }

  /* Events grid: full-width single column */
  .ev-events-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  /* Event card: full width, compact */
  .ev-event-card {
    width: 100% !important;
    max-width: 100% !important;
  }

  /* CTA buttons in event cards: full-width stacked */
  .ev-event-card-actions {
    display: flex !important;
    flex-direction: column !important;
    gap: 10px !important;
    width: 100% !important;
  }

  .ev-btn-whatsapp,
  .ev-btn-gold,
  .ev-btn-primary,
  .ev-btn-secondary {
    width: 100% !important;
    justify-content: center !important;
    min-height: 48px !important;
    font-size: 0.875rem !important;
    text-align: center !important;
  }

  /* Section padding: tighter on mobile */
  .ev-section {
    padding: 40px 16px !important;
  }

  /* ============================================================
     CATERING PAGE — Service cards, Form, Buttons
     ============================================================ */

  /* Service cards: full-width single column */
  .services-grid {
    grid-template-columns: 1fr !important;
    gap: 16px !important;
  }

  .service-card {
    width: 100% !important;
  }

  /* Form: reduce horizontal padding to 16px */
  .form-section {
    padding: 32px 16px !important;
    border-radius: 12px !important;
  }

  /* Catering form wrapper (inline styles on the section) */
  #catering-form .form-section,
  .catering-form .form-section {
    padding: 32px 16px !important;
  }

  /* Form submit button: full-width */
  .form-submit,
  button[type="submit"].form-submit,
  .catering-form .form-submit {
    width: 100% !important;
    min-height: 52px !important;
    justify-content: center !important;
    font-size: 1rem !important;
  }

  /* Catering hero: reduce height */
  .catering-hero {
    min-height: 45vh !important;
    max-height: 400px !important;
  }

  /* ============================================================
     CONTACT PAGE — Cards, Form, WhatsApp CTA
     ============================================================ */

  /* Hero: reduce padding and height */
  #contact-hero {
    min-height: 45vh !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }

  /* Contact info section inner container: reduce side padding */
  #contact-info > div {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  /* Priority row (Phone + WhatsApp): ensure full-width stacked */
  #contact-info > div > div:first-of-type {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Secondary row (Location, Hours, Email): single column on mobile */
  #contact-info > div > div:last-of-type {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* Contact hero WhatsApp button: full-width */
  #contact-hero a[href*="wa.me"],
  #contact-hero a[href*="whatsapp"] {
    width: 100% !important;
    max-width: 320px !important;
    justify-content: center !important;
    text-align: center !important;
  }

  /* Contact hero content: tighter padding */
  #contact-hero > div {
    padding: 48px 16px !important;
  }

  /* Contact form section: reduce side padding */
  #contact-form > div {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  #contact-form {
    padding: 48px 0 !important;
  }

  /* CF7 form submit: full-width */
  #contact-form input[type="submit"],
  #contact-form button[type="submit"],
  .contact-form-section input[type="submit"] {
    width: 100% !important;
    min-height: 52px !important;
    font-size: 1rem !important;
  }

  /* Contact host-event section */
  #contact-host,
  .contact-event-cta {
    padding-top: 40px !important;
    padding-bottom: 40px !important;
  }

  /* ============================================================
     VISIT US PAGE — Handled in visit-us.css
     (Reinforcement rules for inherited classes)
     ============================================================ */

  /* Locations grid: force single column */
  .vu-locations-grid {
    grid-template-columns: 1fr !important;
  }

  /* Direction/action buttons: full-width stacked */
  .vu-card-actions {
    flex-direction: column !important;
    gap: 8px !important;
  }

  .vu-card-actions .vu-btn,
  .vu-card-actions a {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    min-height: 44px !important;
  }

  /* Getting Here grid: single column */
  .vu-getting-grid {
    grid-template-columns: 1fr !important;
    gap: 24px !important;
  }

  /* Hours table: compact on mobile */
  .vu-hours-table {
    width: 100% !important;
    font-size: 0.8125rem !important;
  }

  .vu-hours-table td {
    padding: 0.25rem 0 !important;
    font-size: 0.8125rem !important;
  }

  /* ============================================================
     SHARED: Section container padding on mobile
     ============================================================ */

  /* All inner-page sections: ensure 16px side gutters */
  .events-upcoming > .container,
  .events-past > .container,
  .events-gallery > .container,
  .events-inquiry > .container,
  .catering-services > .container,
  .catering-testimonials > .container,
  .catering-form > .container,
  .contact-whatsapp > .container,
  .contact-info > .container,
  .contact-form-section > .container,
  .contact-event-cta > .container {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* Extra narrow screens: 375px and below */
@media (max-width: 414px) {

  /* Events gallery: maintain 2-col but tighter gap */
  .ev-masonry {
    column-gap: 6px !important;
  }

  .ev-masonry-item {
    margin-bottom: 6px !important;
  }

  /* Event card body: tighter padding */
  .ev-event-card-body {
    padding: 0.875rem !important;
  }

  /* Contact info section heading: smaller */
  #contact-info h2 {
    font-size: 1.375rem !important;
    margin-bottom: 28px !important;
  }

  /* Form section: minimal padding */
  .form-section {
    padding: 24px 14px !important;
  }

  /* Contact form: force single-column on very narrow screens */
  .bartolo-form-grid {
    grid-template-columns: 1fr !important;
  }
}
