:root {
  --engelhard-pink: #e96fa6;
  --engelhard-pink-dark: #c84683;
  --engelhard-soft: #fff3f8;
  --engelhard-ink: #2d2730;
  --engelhard-muted: #6f6771;
}

body {
  color: var(--engelhard-ink);
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  line-height: 1.65;
}

a { color: var(--engelhard-pink-dark); text-decoration: none; }
a:hover { color: var(--engelhard-pink); }

.topbar {
  background: var(--engelhard-soft);
}

.brand-mark {
  display: inline-grid;
  place-items: center;
  width: 2.25rem;
  height: 2.25rem;
  border-radius: 999px;
  background: var(--engelhard-pink);
  color: #fff;
  margin-right: .35rem;
}


.navbar-brand {
  display: inline-flex;
  align-items: center;
  padding-top: .25rem;
  padding-bottom: .25rem;
}

.navbar-logo {
  display: block;
  width: 200px;
  height: auto;
  max-height: 100px;
}

@media (max-width: 575.98px) {
  .navbar-logo {
    width: 150px;
  }
}



/* Shrink sticky navigation on scroll */
.topbar,
.navbar,
.navbar-brand,
.navbar-logo,
.navbar .nav-link,
.navbar .btn {
  transition:
    max-height .28s ease,
    padding .28s ease,
    width .28s ease,
    opacity .28s ease,
    box-shadow .28s ease;
}

.navbar {
  min-height: 0;
}

body.nav-is-scrolled .topbar {
  max-height: 0;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
  overflow: hidden;
  opacity: 0;
}

body.nav-is-scrolled .navbar-brand {
  padding-top: .05rem;
  padding-bottom: .05rem;
}

body.nav-is-scrolled .navbar-logo {
  width: 120px;
  max-height: 60px;
}

body.nav-is-scrolled .navbar .nav-link {
  padding-top: .35rem;
  padding-bottom: .35rem;
}

body.nav-is-scrolled .navbar .btn {
  padding-top: .25rem;
  padding-bottom: .25rem;
}

@media (max-width: 575.98px) {
  body.nav-is-scrolled .navbar-logo {
    width: 105px;
    max-height: 60px;
  }
}

.nav-link.active,
.dropdown-item.active {
  color: var(--engelhard-pink-dark) !important;
  font-weight: 700;
  background: transparent;
}

.btn-primary {
  --bs-btn-bg: var(--engelhard-pink);
  --bs-btn-border-color: var(--engelhard-pink);
  --bs-btn-hover-bg: var(--engelhard-pink-dark);
  --bs-btn-hover-border-color: var(--engelhard-pink-dark);
  --bs-btn-active-bg: var(--engelhard-pink-dark);
  --bs-btn-active-border-color: var(--engelhard-pink-dark);
  --bs-btn-active-color: #fff;
  --bs-btn-focus-shadow-rgb: 200, 70, 131;
}

.btn-primary:active,
.btn-primary.active,
.btn-primary.show,
.btn-primary:focus-visible {
  background-color: var(--engelhard-pink-dark) !important;
  border-color: var(--engelhard-pink-dark) !important;
  color: #fff !important;
}

.btn-outline-primary {
  --bs-btn-color: var(--engelhard-pink-dark);
  --bs-btn-border-color: var(--engelhard-pink);
  --bs-btn-hover-bg: var(--engelhard-pink);
  --bs-btn-hover-border-color: var(--engelhard-pink);
}

.hero {
  --hero-image: url("/static/img/hero/home-hero.webp");
  background:
    linear-gradient(90deg, rgba(255,243,248,.96), rgba(255,255,255,.80)),
    var(--hero-image) right center / cover no-repeat;
  padding: clamp(4rem, 8vw, 8rem) 0;
}

.hero-special {
  min-height: clamp(28rem, 62vw, 42rem);
  display: flex;
  align-items: center;
}

.hero-high-tea { --hero-image: url("/static/img/hero/high-tea.webp"); }
.hero-high-wine { --hero-image: url("/static/img/hero/high-wine.webp"); }
.hero-baby-shower { --hero-image: url("/static/img/hero/baby-shower.webp"); }
.hero-gender-reveal { --hero-image: url("/static/img/hero/gender-reveal.webp"); }
.hero-party { --hero-image: url("/static/img/hero/party.webp"); }
.hero-catering { --hero-image: url("/static/img/hero/catering.webp"); }

.hero .eyebrow,
.eyebrow {
  color: var(--engelhard-pink-dark);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
  font-size: .78rem;
}

.section-soft {
  background: var(--engelhard-soft);
}


/* Menu and drinks page headers */
.page-header {
  position: relative;
  overflow: hidden;
  color: #fff;
  background-color: var(--engelhard-pink);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
}

.page-header > .container {
  position: relative;
  z-index: 2;
}

.page-header::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background:
    linear-gradient(
      90deg,
      rgba(45, 39, 48, .62) 0%,
      rgba(45, 39, 48, .44) 42%,
      rgba(233, 111, 166, .28) 100%
    );
}

.page-header--menu {
  background-image: url("../img/page-headers/menu-header.webp");
}

.page-header--dranken {
  background-image: url("../img/page-headers/dranken-header.webp");
}

.page-header .eyebrow,
.page-header h1,
.page-header .lead {
  color: #fff;
  text-shadow: 0 .35rem 1.5rem rgba(0, 0, 0, .28);
}

.page-header .btn-outline-primary {
  --bs-btn-color: #fff;
  --bs-btn-border-color: rgba(255, 255, 255, .75);
  --bs-btn-hover-bg: #fff;
  --bs-btn-hover-border-color: #fff;
  --bs-btn-hover-color: var(--engelhard-pink-dark);
}

.page-header .btn-primary {
  box-shadow: 0 .75rem 1.75rem rgba(0, 0, 0, .18);
}

.card {
  border: 0;
  border-radius: 1.25rem;
  box-shadow: 0 1rem 2.5rem rgba(45,39,48,.08);
}

.service-card {
  height: 100%;
  transition: transform .2s ease, box-shadow .2s ease;
}

.service-card:hover {
  transform: translateY(-.25rem);
  box-shadow: 0 1.25rem 3rem rgba(45,39,48,.12);
}

.icon-circle {
  width: 3rem;
  height: 3rem;
  display: inline-grid;
  place-items: center;
  border-radius: 999px;
  color: #fff;
  background: var(--engelhard-pink);
}

.cta-band {
  background: linear-gradient(135deg, var(--engelhard-pink), var(--engelhard-pink-dark));
  color: #fff;
  border-radius: 1.5rem;
}

.cta-band a { color: #fff; }

.footer {
  background: #2d2730;
  color: #fff;
}

.footer a { color: #ffd4e5; }

.footer-links {
  display: grid;
  gap: .4rem;
}

.menu-section {
  scroll-margin-top: 7rem;
}

.menu-table {
  width: 100%;
  border-collapse: collapse;
}

.menu-table-row td {
  padding: .7rem 0 .15rem;
  vertical-align: top;
  border-top: 1px solid rgba(45,39,48,.08);
}

.menu-table-row:first-child td {
  border-top: 0;
  padding-top: 0;
}

.menu-dish {
  padding-right: 1rem;
}

.menu-price {
  width: 5.75rem;
  text-align: right;
  white-space: nowrap;
  color: var(--engelhard-pink-dark);
  font-weight: 800;
}

.menu-description-row td {
  padding: 0 0 .7rem;
  color: var(--engelhard-muted);
  font-size: .95rem;
  line-height: 1.45;
}

@media (max-width: 991px) {
  .hero {
    background:
      linear-gradient(180deg, rgba(255,243,248,.98), rgba(255,255,255,.88)),
      var(--hero-image) center bottom / cover no-repeat;
    padding-bottom: 12rem;
  }

  .hero-special {
    min-height: 34rem;
  }
}


/* Homepage review carousel controls */
.review-slider {
  position: relative;
  padding: 0 3.75rem 2.25rem;
}

.review-slider blockquote {
  min-height: 8.75rem;
  margin-bottom: 0;
  display: flex !important;
  align-items: center;
}

.review-slider .slick-list {
  overflow: hidden;
}

.review-slider .slick-track {
  display: flex;
  align-items: stretch;
}

.review-slider .slick-slide {
  height: auto;
}

.review-slider .slick-slide > div,
.review-slider .slick-slide blockquote {
  height: 100%;
}

.review-slider .slick-control {
  position: absolute;
  top: 50%;
  z-index: 2;
  display: inline-grid;
  place-items: center;
  width: 2.75rem;
  height: 2.75rem;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: var(--engelhard-pink);
  color: #fff;
  box-shadow: 0 .75rem 1.75rem rgba(45,39,48,.16);
  transform: translateY(-50%);
  transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
}

.review-slider .slick-control:hover,
.review-slider .slick-control:focus {
  background: var(--engelhard-pink-dark);
  color: #fff;
  transform: translateY(-50%) scale(1.04);
  box-shadow: 0 1rem 2rem rgba(45,39,48,.22);
}

.review-slider .slick-control:focus {
  outline: .2rem solid rgba(233,111,166,.35);
  outline-offset: .15rem;
}

.review-slider .slick-prev-custom {
  left: 0;
}

.review-slider .slick-next-custom {
  right: 0;
}

.review-slider .slick-dots {
  bottom: 0;
}

.review-slider .slick-dots li {
  width: .75rem;
  height: .75rem;
  margin: 0 .25rem;
}

.review-slider .slick-dots li button {
  width: .75rem;
  height: .75rem;
  padding: 0;
}

.review-slider .slick-dots li button:before {
  width: .75rem;
  height: .75rem;
  color: var(--engelhard-pink);
  font-size: .7rem;
  line-height: .75rem;
  opacity: .35;
}

.review-slider .slick-dots li.slick-active button:before {
  color: var(--engelhard-pink-dark);
  opacity: 1;
}

@media (max-width: 575.98px) {
  .review-slider {
    padding-right: 0;
    padding-left: 0;
    padding-bottom: 3rem;
  }

  .review-slider blockquote {
    min-height: 12rem;
  }

  .review-slider .slick-control {
    top: auto;
    bottom: -.3rem;
    transform: none;
  }

  .review-slider .slick-control:hover,
  .review-slider .slick-control:focus {
    transform: scale(1.04);
  }

  .review-slider .slick-prev-custom {
    left: 0;
  }

  .review-slider .slick-next-custom {
    right: 0;
  }
}


/* Structured menu pages */
.menu-section {
  scroll-margin-top: 7rem;
}

.menu-items {
  display: grid;
  gap: 1rem;
}

.menu-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 1rem;
  align-items: start;
  padding-bottom: 1rem;
  border-bottom: 1px solid rgba(45,39,48,.09);
}

.menu-item:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}

.menu-item-main p {
  color: var(--engelhard-muted);
  font-size: .95rem;
}

.menu-price {
  color: var(--engelhard-pink-dark);
  white-space: nowrap;
  font-size: 1rem;
}

@media (max-width: 575.98px) {
  .menu-item {
    grid-template-columns: 1fr;
    gap: .25rem;
  }
}


/* Homepage notice modal */
.engelhard-notice-modal .modal-content {
  border: 0;
  border-radius: 1.25rem;
  box-shadow: 0 1.5rem 4rem rgba(45,39,48,.24);
}

.engelhard-notice-modal .modal-header {
  border-bottom-color: rgba(45,39,48,.08);
}

.engelhard-notice-modal .modal-title {
  color: var(--engelhard-pink-dark);
  font-weight: 800;
}

.engelhard-notice-modal .modal-body a {
  font-weight: 700;
}


/* Font Awesome check lists */
.check-list {
  list-style: none;
  padding-left: 0;
}

.check-list li {
  position: relative;
  padding-left: 1.9rem;
  margin-bottom: .65rem;
}

.check-list li::before {
  content: "\f00c";
  position: absolute;
  left: 0;
  top: .08rem;
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  color: var(--engelhard-pink-dark);
}

.check-list li:last-child {
  margin-bottom: 0;
}


/* Parallax hero backgrounds */
.hero,
.page-header {
  background-attachment: scroll, fixed;
}

.page-header {
  background-attachment: fixed;
}

.hero,
.page-header {
  will-change: background-position;
}

/* Softer animated entry */
.wow {
  visibility: hidden;
}

.animate__animated {
  --animate-duration: .85s;
}

.service-card,
.card,
.cta-band,
.menu-section {
  transition:
    transform .24s ease,
    box-shadow .24s ease,
    opacity .24s ease;
}

.service-card:hover,
.card:hover {
  transform: translateY(-.25rem);
}

@media (max-width: 991.98px), (prefers-reduced-motion: reduce) {
  .hero,
  .page-header {
    background-attachment: scroll;
  }

  .wow {
    visibility: visible !important;
    animation: none !important;
  }
}


.breadcrumb-section {
  background: #fff;
  border-bottom: 1px solid rgba(0, 0, 0, .06);
  padding: .85rem 0;
}

.breadcrumb-section .breadcrumb {
  font-size: .95rem;
}

.breadcrumb-section .breadcrumb-item + .breadcrumb-item::before {
  color: var(--engelhard-muted);
}

.breadcrumb-section .breadcrumb-item.active {
  color: var(--engelhard-muted);
}

/* Final Bootstrap button state override: prevents default blue click/focus state */
.btn-primary,
.btn-primary:visited {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--engelhard-pink);
  --bs-btn-border-color: var(--engelhard-pink);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: var(--engelhard-pink-dark);
  --bs-btn-hover-border-color: var(--engelhard-pink-dark);
  --bs-btn-focus-shadow-rgb: 200, 70, 131;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: var(--engelhard-pink-dark);
  --bs-btn-active-border-color: var(--engelhard-pink-dark);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, .125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--engelhard-pink);
  --bs-btn-disabled-border-color: var(--engelhard-pink);
  -webkit-tap-highlight-color: rgba(200, 70, 131, .22);
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:focus-visible,
.btn-primary:active,
.btn-primary.active,
.btn-primary.show,
.btn-primary:first-child:active,
:not(.btn-check) + .btn-primary:active,
.btn-check:checked + .btn-primary,
.btn-check:active + .btn-primary,
.btn-check:focus + .btn-primary {
  color: #fff !important;
  background-color: var(--engelhard-pink-dark) !important;
  border-color: var(--engelhard-pink-dark) !important;
  box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25) !important;
}

.btn-primary:focus:not(:focus-visible) {
  box-shadow: none !important;
}



/* Button interaction color hard override.
   This intentionally also overrides Bootstrap's primary/focus variables and browser tap highlight. */
:root {
  --bs-primary: #e96fa6;
  --bs-primary-rgb: 233, 111, 166;
  --bs-link-color: #c84683;
  --bs-link-hover-color: #e96fa6;
  --bs-focus-ring-color: rgba(200, 70, 131, .25);
}

a,
button,
.btn,
.nav-link,
.dropdown-item {
  -webkit-tap-highlight-color: rgba(200, 70, 131, .22);
}

.btn {
  --bs-btn-focus-box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25);
}

.btn-primary,
.btn-primary:visited,
.btn-primary:link {
  --bs-btn-color: #fff;
  --bs-btn-bg: #e96fa6;
  --bs-btn-border-color: #e96fa6;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #c84683;
  --bs-btn-hover-border-color: #c84683;
  --bs-btn-focus-shadow-rgb: 200, 70, 131;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #c84683;
  --bs-btn-active-border-color: #c84683;
  --bs-btn-active-shadow: none;
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #e96fa6;
  --bs-btn-disabled-border-color: #e96fa6;
  color: #fff !important;
  background-color: #e96fa6 !important;
  border-color: #e96fa6 !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:focus-visible,
.btn-primary:active,
.btn-primary.active,
.btn-primary.show,
.btn-primary:target,
.btn-primary:first-child:active,
.btn-primary:not(:disabled):not(.disabled):active,
.btn-primary:not(:disabled):not(.disabled).active,
.show > .btn-primary.dropdown-toggle,
:not(.btn-check) + .btn-primary:active,
.btn-check:checked + .btn-primary,
.btn-check:active + .btn-primary,
.btn-check:focus + .btn-primary {
  color: #fff !important;
  background-color: #c84683 !important;
  border-color: #c84683 !important;
  box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25) !important;
  outline: 0 !important;
}

.btn-primary:focus:not(:focus-visible),
.btn-primary:active:focus {
  box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25) !important;
  outline: 0 !important;
}

/* Generic focus override for buttons that are not .btn-primary but still receive Bootstrap/browser blue */
.btn:focus,
.btn:focus-visible,
.btn:active:focus,
button:focus,
button:focus-visible,
a:focus,
a:focus-visible {
  outline-color: #c84683 !important;
  box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25) !important;
}

.btn-outline-primary,
.btn-outline-primary:visited {
  --bs-btn-color: #c84683;
  --bs-btn-border-color: #e96fa6;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #c84683;
  --bs-btn-hover-border-color: #c84683;
  --bs-btn-focus-shadow-rgb: 200, 70, 131;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #c84683;
  --bs-btn-active-border-color: #c84683;
}

.footer-credit {
  color: inherit;
  text-decoration: none;
  font-weight: 600;
}

.footer-credit:hover,
.footer-credit:focus {
  color: var(--engelhard-pink, #d94f8c);
  text-decoration: none;
}


/* Accessibility pass */
.skip-link {
  position: absolute;
  top: .75rem;
  left: .75rem;
  z-index: 1100;
  padding: .65rem 1rem;
  border-radius: .5rem;
  background: #fff;
  color: var(--engelhard-pink-dark);
  font-weight: 800;
  box-shadow: 0 .75rem 1.75rem rgba(45, 39, 48, .18);
  transform: translateY(-150%);
  transition: transform .2s ease;
}

.skip-link:focus,
.skip-link:focus-visible {
  transform: translateY(0);
  outline: .2rem solid var(--engelhard-pink-dark);
  outline-offset: .15rem;
}

#main-content:focus {
  outline: none;
}

a:focus-visible,
button:focus-visible,
.btn:focus-visible,
.nav-link:focus-visible,
.dropdown-item:focus-visible,
.form-control:focus-visible,
.form-select:focus-visible,
.btn-close:focus-visible {
  outline: .2rem solid var(--engelhard-pink-dark);
  outline-offset: .15rem;
  box-shadow: 0 0 0 .25rem rgba(200, 70, 131, .25) !important;
}

.dropdown-item:focus,
.dropdown-item:hover {
  background-color: var(--engelhard-soft);
  color: var(--engelhard-pink-dark);
}

.icon-circle i,
.check-list li::before {
  pointer-events: none;
}

.form-label .text-danger {
  color: #b00020 !important;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }

  .hero,
  .page-header {
    background-attachment: scroll !important;
    will-change: auto;
  }

  .wow {
    visibility: visible !important;
    animation: none !important;
  }

  .service-card:hover,
  .card:hover {
    transform: none;
  }
}


.legal-content h2 {
  margin-top: 2rem;
  margin-bottom: .85rem;
  font-size: clamp(1.35rem, 2.5vw, 1.75rem);
  font-weight: 800;
}

.legal-content h2:first-child {
  margin-top: 0;
}

.legal-content p:last-child {
  margin-bottom: 0;
}
