/*-----------------------------------*\
  #PREMIUM.CSS
  High-quality visual polish:
  - Section improvements
  - Card upgrades
  - Button polish
  - Typography rhythm
  - Hover microinteractions
  - Premium details
\*-----------------------------------*/

/* ── GLOBAL PREMIUM BASE ───────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* ── PREMIUM TOPBAR ─────────────────────────────────── */
.topbar {
  background: var(--smoky-black-1) !important;
  border-bottom: 1px solid var(--border-subtle) !important;
  padding-block: 10px !important;
  font-size: var(--fontSize-label-2);
  letter-spacing: 0.04em;
}
.topbar-item { transition: color 0.2s ease; }
.topbar-item.link:hover { color: var(--gold-crayola) !important; }
.topbar .separator {
  background: var(--border-subtle) !important;
  height: 16px !important;
}

/* ── PREMIUM HEADER ─────────────────────────────────── */
.header {
  transition: background-color 0.4s ease, box-shadow 0.4s ease, padding-block 0.4s ease !important;
  border-bottom: 1px solid transparent;
}
.header.active {
  box-shadow: 0 4px 32px rgba(0,0,0,0.6) !important;
  border-bottom-color: var(--border-subtle) !important;
}
.navbar-link .span {
  letter-spacing: 0.12em;
  font-size: 1.15rem;
}
.navbar-link:hover .span { color: var(--gold-crayola); }

/* ── PREMIUM SECTION STRUCTURE ──────────────────────── */
.section {
  position: relative;
  overflow: hidden;
}
.section::before {
  content: none; /* override any template artifacts */
}

.section-subtitle {
  color: var(--gold-crayola);
  font-size: 1.2rem !important;
  letter-spacing: 0.28em !important;
  font-family: var(--fontFamily-dm_sans) !important;
  font-weight: var(--weight-bold) !important;
  text-transform: uppercase;
  margin-block-end: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
}
.section-subtitle::before,
.section-subtitle::after {
  content: "";
  display: block;
  width: 28px;
  height: 1px;
  background: var(--gold-crayola);
  opacity: 0.55;
}

.section-title {
  line-height: 1.15 !important;
  margin-block-end: 20px;
}

/* Left-aligned variants */
.section-title.left { text-align: left; }
.section-subtitle.left { justify-content: flex-start; }
.section-subtitle.left::before { display: none; }

/* ── PREMIUM SERVICE CARDS ──────────────────────────── */
.service-card {
  background: var(--surface-2);
  border: 1px solid var(--border-subtle);
  transition: transform 0.35s var(--ease-smooth), box-shadow 0.35s var(--ease-smooth), border-color 0.35s ease !important;
  overflow: hidden;
}
.service-card:hover {
  transform: translateY(-8px) !important;
  box-shadow: var(--shadow-lg) !important;
  border-color: var(--border-medium) !important;
}
.service .card-title {
  font-family: var(--fontFamily-forum);
  font-size: 2.2rem;
  color: var(--white);
  transition: color 0.2s ease;
}
.service-card:hover .card-title { color: var(--gold-crayola); }
.service .btn-text {
  color: var(--gold-crayola);
  font-size: 1.15rem;
  font-weight: var(--weight-bold);
  letter-spacing: 0.2em;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: gap 0.2s ease;
}
.service .btn-text:hover { gap: 14px; }
.service .btn-text::after {
  content: "→";
  font-size: 1.4rem;
  line-height: 1;
}

/* ── PREMIUM MENU CARDS ─────────────────────────────── */
.menu-card {
  border-bottom: 1px solid var(--border-subtle);
  padding-block: 18px !important;
  transition: background 0.2s ease !important;
}
.menu-card:hover { background: hsla(38,61%,73%,0.03); }

.menu-card .card-banner {
  border: 2px solid var(--border-subtle);
  transition: border-color 0.2s ease;
}
.menu-card:hover .card-banner { border-color: var(--border-medium); }

.menu-card .card-title {
  font-family: var(--fontFamily-forum);
  font-size: 2rem !important;
  color: var(--white);
  transition: color 0.2s ease;
  text-decoration: none;
}
.menu-card .card-title:hover { color: var(--gold-crayola); }

.menu-card .span {
  font-size: var(--fontSize-body-3) !important;
  color: var(--gold-crayola) !important;
  font-weight: var(--weight-bold) !important;
  font-family: var(--fontFamily-dm_sans) !important;
}

.menu-card .badge {
  background: hsla(38,61%,73%,0.12);
  color: var(--gold-crayola);
  border: 1px solid var(--border-medium);
  font-size: 1rem;
  letter-spacing: 0.1em;
  padding: 3px 10px;
}

/* ── PREMIUM FEATURE CARDS ──────────────────────────── */
.feature-card {
  border: 1px solid var(--border-subtle);
  background: var(--surface-2);
  transition: transform 0.3s var(--ease-smooth), border-color 0.3s ease, box-shadow 0.3s ease !important;
}
.feature-card:hover {
  transform: translateY(-6px) !important;
  border-color: var(--border-medium) !important;
  box-shadow: var(--shadow-gold-sm) !important;
}
.feature-card .card-icon {
  width: 70px; height: 70px;
  background: hsla(38,61%,73%,0.08);
  border: 1px solid var(--border-medium);
  margin-inline: auto;
  display: flex; align-items: center; justify-content: center;
  transition: background 0.3s ease, transform 0.3s var(--ease-bounce);
}
.feature-card:hover .card-icon {
  background: hsla(38,61%,73%,0.15);
  transform: scale(1.08) rotate(3deg);
}

/* ── PREMIUM EVENT CARDS ────────────────────────────── */
.event-card {
  border: 1px solid var(--border-subtle);
  overflow: hidden;
  transition: transform 0.35s var(--ease-smooth), box-shadow 0.35s ease, border-color 0.35s ease !important;
}
.event-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--shadow-md) !important;
  border-color: var(--border-medium) !important;
}
.event-card .card-content {
  padding: 20px 18px;
  background: var(--surface-2);
}
.event-card .card-subtitle { color: var(--gold-crayola); letter-spacing: 0.15em; }
.event-card .card-title {
  font-family: var(--fontFamily-forum);
  color: var(--white);
  line-height: 1.3;
  transition: color 0.2s;
}
.event-card:hover .card-title { color: var(--gold-crayola); }

/* ── PREMIUM BUTTONS ────────────────────────────────── */
.btn {
  position: relative;
  overflow: hidden;
  transition: all 0.3s var(--ease-smooth) !important;
  letter-spacing: 0.12em;
  font-size: 1.2rem !important;
}
.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(255,255,255,0.05) 0%, transparent 60%);
  pointer-events: none;
}
.btn:active { transform: scale(0.97); }

.btn-primary {
  background: var(--gold-crayola) !important;
  color: var(--smoky-black-1) !important;
  border: none !important;
}
.btn-primary:hover {
  background: var(--gold-crayola-light) !important;
  box-shadow: var(--shadow-gold-md) !important;
}
.btn-secondary {
  border: 1px solid var(--gold-crayola) !important;
  color: var(--gold-crayola) !important;
  background: transparent !important;
}
.btn-secondary:hover {
  background: var(--gold-crayola) !important;
  color: var(--smoky-black-1) !important;
  box-shadow: var(--shadow-gold-sm) !important;
}

/* Add-to-cart button */
.add-to-cart-btn {
  position: relative;
  overflow: hidden;
  letter-spacing: 0.1em;
}
.add-to-cart-btn::before {
  content: "";
  position: absolute;
  left: -100%;
  top: 0; bottom: 0;
  width: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.07), transparent);
  transition: left 0.5s ease;
}
.add-to-cart-btn:hover::before { left: 100%; }

/* ── PREMIUM ABOUT SECTION ──────────────────────────── */
.about { overflow: hidden; }
.about-content .section-text {
  max-width: 500px;
  line-height: 1.8;
  color: var(--text-secondary);
}
.about-banner {
  box-shadow: var(--shadow-lg);
}
.about-banner::before, .about-banner::after {
  border-color: var(--gold-crayola) !important;
  opacity: 0.6;
}

/* ── PREMIUM SPECIAL DISH ───────────────────────────── */
.special-dish {
  background: var(--surface-1);
  border-top: 1px solid var(--border-subtle);
  border-bottom: 1px solid var(--border-subtle);
}
.special-dish-content .badge { 
  background: var(--gold-crayola);
  color: var(--smoky-black-1);
  font-weight: var(--weight-bold);
  letter-spacing: 0.2em;
  font-size: 1rem;
  padding: 5px 16px;
  display: inline-block;
  margin-block-end: 16px;
}
.special-dish-content .section-text { 
  color: var(--text-secondary);
  line-height: 1.8;
  max-width: 440px;
}

/* ── PREMIUM TESTIMONIALS ───────────────────────────── */
.testi-card {
  border: 1px solid var(--border-subtle);
  background: var(--surface-2);
  padding: 28px;
  position: relative;
}
.testi-card::before {
  content: "\201C";
  position: absolute;
  top: 12px; left: 20px;
  font-family: var(--fontFamily-forum);
  font-size: 5rem;
  color: var(--gold-crayola);
  opacity: 0.2;
  line-height: 1;
}

/* ── PREMIUM HERO ───────────────────────────────────── */
.hero-text .span {
  text-shadow: 0 2px 20px rgba(0,0,0,0.5);
  letter-spacing: 0.25em;
}
.hero-title {
  text-shadow: 0 4px 30px rgba(0,0,0,0.5);
}
.hero-text .body-1 {
  text-shadow: 0 2px 16px rgba(0,0,0,0.5);
  color: var(--text-secondary) !important;
  max-width: 480px;
}

/* ── PREMIUM FORM INPUTS ────────────────────────────── */
.input-field, .co-input, .lm-form input {
  border-radius: 0 !important;
  font-size: 1.4rem !important;
  transition: border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.input-field:focus, .co-input:focus {
  border-color: var(--gold-crayola) !important;
  box-shadow: 0 0 0 3px hsla(38,61%,73%,0.15) !important;
  outline: none !important;
}

/* ── PREMIUM LOGIN MODAL ────────────────────────────── */
.login-modal {
  box-shadow: 0 40px 100px rgba(0,0,0,0.9), 0 0 0 1px var(--border-subtle) !important;
}
.lm-form h2 {
  font-size: 2.8rem;
  margin-block-end: 4px;
}
.lm-form input {
  border-color: var(--border-medium) !important;
  background: var(--surface-1) !important;
}
.lm-form input::placeholder { color: var(--text-muted); }
.lm-form input:focus {
  border-color: var(--gold-crayola) !important;
  box-shadow: 0 0 0 3px var(--gold-glow, hsla(38,61%,73%,0.15)) !important;
}

/* ── PREMIUM FOOTER ─────────────────────────────────── */
.footer {
  border-top: 1px solid var(--border-subtle);
}
.footer-logo img {
  filter: brightness(0.9);
  transition: filter 0.2s ease;
}
.footer-logo:hover img { filter: brightness(1.1); }
.footer-link {
  color: var(--text-secondary) !important;
  transition: color 0.2s ease, padding-left 0.2s ease !important;
  display: block;
  padding-block: 4px;
}
.footer-link:hover {
  color: var(--gold-crayola) !important;
  padding-left: 6px;
}
.footer-text { color: var(--text-secondary); line-height: 1.7; }
.footer-item {
  display: flex; align-items: flex-start; gap: 10px;
  color: var(--text-secondary);
  font-size: 1.4rem;
  padding-block: 5px;
}
.footer-item ion-icon { color: var(--gold-crayola); flex-shrink: 0; margin-top: 2px; }

.copyright {
  border-top: 1px solid var(--border-subtle) !important;
  padding-block: 20px !important;
}
.copyright .span { color: var(--text-muted); font-size: 1.3rem; }
.copyright .gold { color: var(--gold-crayola); }

/* ── PREMIUM NEWSLETTER ─────────────────────────────── */
.newsletter-form .input-wrapper {
  border: 1px solid var(--border-medium);
  transition: border-color 0.2s ease;
}
.newsletter-form .input-wrapper:focus-within { border-color: var(--gold-crayola); }
.input-field[name="email_address"] {
  background: transparent !important;
  border: none !important;
}
.input-field[name="email_address"]:focus { box-shadow: none !important; }

/* ── PREMIUM PRELOADER ──────────────────────────────── */
.preload {
  background: var(--smoky-black-1) !important;
}
.preload .circle {
  border-color: var(--border-subtle) !important;
  border-top-color: var(--gold-crayola) !important;
  width: 50px !important; height: 50px !important;
  border-width: 2px !important;
}
.preload .text {
  font-family: var(--fontFamily-forum) !important;
  font-size: 2.2rem !important;
  color: var(--gold-crayola) !important;
  letter-spacing: 0.2em !important;
  margin-top: 16px !important;
}

/* ── PREMIUM CART DRAWER ────────────────────────────── */
.cart-drawer {
  box-shadow: -16px 0 60px rgba(0,0,0,0.7) !important;
  border-left-color: var(--border-medium) !important;
}
.cart-header { border-bottom-color: var(--border-medium) !important; }
.cart-item { border-bottom-color: var(--border-subtle) !important; }
.cart-footer { border-top-color: var(--border-medium) !important; }
.cart-checkout-btn {
  letter-spacing: 0.15em !important;
  transition: background 0.2s ease, box-shadow 0.2s ease !important;
}
.cart-checkout-btn:hover { box-shadow: var(--shadow-gold-md) !important; }

/* ── PREMIUM FLOOR PLAN ─────────────────────────────── */
.floor-plan-wrap {
  border: 1px solid var(--border-subtle);
  background: var(--surface-1);
}
.booking-modal {
  border: 1px solid var(--border-medium) !important;
  box-shadow: 0 40px 80px rgba(0,0,0,0.9) !important;
}

/* ── PREMIUM BACK-TO-TOP ────────────────────────────── */
.back-top-btn {
  border: 1px solid var(--border-medium) !important;
  background: var(--surface-2) !important;
  transition: all 0.3s var(--ease-smooth) !important;
}
.back-top-btn:hover {
  background: var(--gold-crayola) !important;
  color: var(--smoky-black-1) !important;
  border-color: var(--gold-crayola) !important;
  box-shadow: var(--shadow-gold-md) !important;
  transform: translateY(-4px) !important;
}

/* ── PREMIUM SEPARATOR DECORATIONS ─────────────────── */
.separator {
  background: var(--gold-crayola) !important;
  opacity: 0.5;
}

/* ── PREMIUM TRACKING PAGE ──────────────────────────── */
.status-hero { border-color: var(--border-medium) !important; }
.status-icon { border-color: var(--gold-crayola) !important; }
.step-circle { transition: all 0.4s var(--ease-bounce) !important; }
.step-item.active .step-circle { box-shadow: 0 0 0 8px hsla(38,61%,73%,0.1) !important; }

/* ── PREMIUM CHECKOUT ───────────────────────────────── */
.checkout-panel {
  border-color: var(--border-subtle) !important;
  box-shadow: var(--shadow-sm);
}
.delivery-card, .payment-card {
  transition: all 0.25s var(--ease-smooth) !important;
}
.delivery-card.selected, .payment-card.selected {
  box-shadow: var(--shadow-gold-sm) !important;
}

/* ── PREMIUM HOVER:CARD ─────────────────────────────── */
.hover\:card {
  transition: transform 0.3s var(--ease-smooth), box-shadow 0.3s ease !important;
}
.hover\:card:hover {
  transform: translateY(-4px) !important;
  box-shadow: var(--shadow-md) !important;
}

/* ── CHEF CARDS (chefs page) ────────────────────────── */
.chef-card {
  overflow: hidden;
  border: 1px solid var(--border-subtle);
  background: var(--surface-2);
  transition: transform 0.3s var(--ease-smooth), border-color 0.3s ease, box-shadow 0.3s ease !important;
}
.chef-card:hover {
  transform: translateY(-6px) !important;
  border-color: var(--border-medium) !important;
  box-shadow: var(--shadow-md) !important;
}
.chef-card .card-content { padding: 20px 18px; }
.chef-card .card-name {
  font-family: var(--fontFamily-forum);
  color: var(--white);
  margin-block-end: 4px;
  transition: color 0.2s;
}
.chef-card:hover .card-name { color: var(--gold-crayola); }
.chef-card .social-list { margin-block-start: 14px; }
.chef-card .social-link {
  width: 34px; height: 34px;
  border: 1px solid var(--border-medium);
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text-secondary);
  transition: all 0.2s ease;
}
.chef-card .social-link:hover {
  border-color: var(--gold-crayola);
  color: var(--gold-crayola);
  background: hsla(38,61%,73%,0.08);
}

/* ── CONTACT CARDS ──────────────────────────────────── */
.contact-card {
  border: 1px solid var(--border-subtle) !important;
  background: var(--surface-2);
  transition: transform 0.3s var(--ease-smooth), box-shadow 0.3s ease, border-color 0.3s ease !important;
}
.contact-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--shadow-gold-sm) !important;
  border-color: var(--border-medium) !important;
}

/* ── RESPONSIVE PREMIUM ─────────────────────────────── */
@media (max-width: 768px) {
  .section-title { font-size: calc(2rem + 2vw) !important; }
  .btn { padding-block: 12px !important; }
  .topbar .separator { display: none !important; }
  .topbar .item-2 { display: none !important; }
}

@media (max-width: 480px) {
  .service-card:hover,
  .feature-card:hover,
  .event-card:hover { transform: none !important; }
}
