/*-----------------------------------*\
  #SECTIONS.CSS
  (service · about · special-dish ·
   menu · testimonials · reservation ·
   features · event)
\*-----------------------------------*/

/* ── SERVICE ─────────────────────── */
.service .section-title  { margin-block-end: 16px; }
.service .section-text   { margin-block-end: 40px; }
.service-card            { overflow: hidden; }

.service-card .has-before {
  padding-block: 30px;
  margin-block-end: 26px;
  z-index: 1;
}
.service-card .has-before::before {
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 140px;
  height: 100%;
  background-image: url('../assets/images/img-pattern.svg');
  background-position: center;
  background-size: cover;
  background-repeat: repeat;
  transition: var(--transition-2);
  z-index: -1;
  will-change: transform;
}
.service-card:is(:hover, :focus-within) .has-before::before {
  transform: rotateY(0.5turn) translateX(50%);
  transition-delay: 300ms;
}
.service-card .card-banner { transition: var(--transition-2); }
.service-card:is(:hover, :focus-within) .card-banner { transform: scale(1.05); }
.service .card-title { margin-block-end: 12px; }

@media (min-width: 575px) {
  :is(.service, .about) .section-text { max-width: 420px; margin-inline: auto; }
  .service .container { max-width: 420px; margin-inline: auto; }
}
@media (min-width: 992px) {
  :is(.service, .event) .container { max-width: unset; }
  :is(.service, .event) .grid-list { grid-template-columns: repeat(3, 1fr); }
  :is(.service, .event) .grid-list li:last-child { grid-column: auto; width: 100%; }
  .service .shape { display: block; }
  .service .shape-1 { bottom: 0; left: 0; }
  .service .shape-2 { top: 0; right: 0; }
}
@media (min-width: 1200px) {
  .service .grid-list { gap: 150px; }
  .service .grid-list li:nth-child(2n+1) { transform: translateY(-160px); }
  .service .section-text { margin-block-end: 75px; }
}


/* ── ABOUT ───────────────────────── */
.about .section-text        { margin-block: 15px 30px; }
.about .btn                 { margin-inline: auto; margin-block-start: 26px; }
.about .container           { display: grid; gap: 120px; }

.about-banner               { position: relative; margin-block-end: 120px; }
.about-banner > .w-100      { padding-inline-start: 50px; }
.about .abs-img             { position: absolute; }
.about .abs-img::before     { z-index: -1; }

.about .abs-img-1 { bottom: -120px; left: 0; width: 150px; padding-block: 50px; }
.about .abs-img-2 { top: -65px; right: 0; overflow: hidden; }

.about .abs-img-1::before {
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 140px;
  background-image: url('../assets/images/img-pattern.svg');
  background-repeat: repeat;
}
.about .abs-img-2::before {
  inset: 0;
  background-image: url('../assets/images/badge-2-bg.png');
  background-repeat: no-repeat;
  background-size: contain;
  animation: rotate360 15s linear infinite;
}

@media (min-width: 575px) {
  .about .container    { gap: 80px; }
  .about-banner > .w-100 { padding-inline-start: 90px; }
  .about .abs-img-1    { width: 285px; }
  .about .contact-number { --fontSize-body-1: 2.4rem; }
}
@media (min-width: 992px) {
  .about .container { grid-template-columns: 0.7fr 1fr; gap: 30px; }
}
@media (min-width: 1200px) {
  .about { padding-block: 170px 100px; }
}
@media (min-width: 1400px) {
  .about-content { padding-inline-end: 90px; }
  .about .shape  { display: block; top: 46%; left: 0; }
}


/* ── SPECIAL DISH ────────────────── */
.special-dish-content { padding-block: 70px; }
.special-dish .abs-img { margin-inline: auto; margin-block-end: 12px; }
.special-dish .section-text { margin-block: 16px 40px; }
.special-dish-content .wrapper {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin-block-end: 40px;
}
.special-dish-content .del  { text-decoration: none; color: var(--davys-grey); }
.special-dish-content .span { color: var(--gold-crayola); }
.special-dish .btn          { margin-inline: auto; }

@media (min-width: 992px) {
  .special-dish {
    display: grid;
    grid-template-columns: 1fr 1fr;
    text-align: left;
  }
  .special-dish-content { padding-inline: 50px 25px; }
  .special-dish-content .container { position: relative; }
  .special-dish .section-subtitle::after,
  .special-dish .btn { margin-inline: 0; }
  .special-dish-content .wrapper { justify-content: flex-start; }
  .special-dish .abs-img {
    position: absolute;
    top: 10px;
    left: -40px;
    animation: move 5s linear infinite;
  }
}
@media (min-width: 1200px) {
  .special-dish-content { padding: 225px 120px; padding-inline-end: 0; }
  .special-dish-content .container { max-width: 460px; margin-inline: 0; }
}
@media (min-width: 1400px) {
  .special-dish { overflow: visible; position: relative; }
  .special-dish .shape  { display: block; right: 0; z-index: 1; }
  .special-dish .shape-1 { top: 45%; }
  .special-dish .shape-2 { bottom: 0; transform: translateY(50%); width: max-content; }
}


/* ── MENU ────────────────────────── */
.menu .section-title { margin-block-end: 40px; }
.menu .grid-list     { margin-block-end: 50px; }

.menu-card {
  display: flex;
  align-items: flex-start;
  gap: 20px;
}
.hover\:card .card-banner { background-color: var(--gold-crayola); }
.hover\:card .card-banner .img-cover {
  transition: transform 0.35s ease, opacity 0.35s ease;
  will-change: transform, opacity;
}
.hover\:card:is(:hover, :focus-within) .card-banner .img-cover { opacity: 0.7; transform: scale(1.05); }
.menu-card .card-banner   { flex-shrink: 0; width: 90px; aspect-ratio: 1/1; border-radius: 50%; overflow: hidden; }
.menu-card .card-title    { transition: var(--transition-1); }
.menu-card .card-title:is(:hover, :focus-visible) { color: var(--gold-crayola); }
.menu-card .badge {
  background-color: var(--gold-crayola);
  color: var(--eerie-black-1);
  font-family: var(--fontFamily-forum);
  max-width: max-content;
  line-height: var(--lineHeight-6);
  text-transform: uppercase;
  padding-inline: 10px;
  margin-block-start: 10px;
}
.menu-card .span      { color: var(--gold-crayola); margin-block: 10px; }
.menu-card .card-text { color: var(--quick-silver); line-height: var(--lineHeight-4); }
.menu-text .span      { display: inline-block; color: var(--gold-crayola); }
.menu .btn            { margin-inline: auto; margin-block-start: 26px; }
.menu .shape          { display: block; width: 70%; }
.menu .shape-2        { top: 0; left: 0; }
.menu .shape-3        { bottom: 0; right: 0; }

@media (min-width: 575px) {
  .menu-card .title-wrapper {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 15px;
  }
  .menu-card .badge { margin-block-start: 0; }
  .menu-card .span  {
    flex-grow: 1;
    display: flex;
    align-items: center;
    gap: 15px;
    position: relative;
  }
  .menu-card .span::before {
    content: "";
    height: 6px;
    flex-grow: 1;
    border-block: 1px solid var(--white-alpha-20);
  }
}
@media (min-width: 992px) {
  .menu .grid-list { position: relative; column-gap: 90px; }
  .menu .grid-list::before {
    content: "";
    position: absolute;
    top: 0;
    left: 50%;
    height: 100%;
    border-inline-start: 1px solid var(--white-alpha-20);
  }
}
@media (min-width: 1200px) {
  .menu .grid-list { gap: 55px 200px; margin-block-end: 55px; }
}


/* ── TESTIMONIALS ────────────────── */
.testi { padding-block-end: 340px; position: static; }
.testi .quote {
  font-size: 7rem;
  font-family: var(--fontFamily-forum);
  line-height: 0.7em;
}
.testi .wrapper {
  display: flex;
  justify-content: center;
  gap: 2px;
  margin-block: 40px 50px;
}
.testi .separator { animation: rotate360 15s linear infinite; }
.profile .img     { margin-inline: auto; border-radius: var(--radius-circle); margin-block-end: 15px; }
.testi .profile-name {
  color: var(--gold-crayola);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: var(--letterSpacing-3);
}

@media (min-width: 992px) {
  .testi-text { max-width: 910px; margin-inline: auto; }
}


/* ── RESERVATION ─────────────────── */
.reservation-form { margin-block-start: -270px; }
.form-text        { margin-block-end: 40px; }
.form-text .link  { display: inline; color: var(--gold-crayola); }

.form-right .headline-1    { margin-block-end: 40px; }
.form-right .contact-label { margin-block-end: 5px; }
.form-right .separator     { margin: 20px auto; }
.form-right .body-4        { color: var(--quick-silver); line-height: var(--lineHeight-3); }
.form-right .body-4:not(:last-child) { margin-block-end: 25px; }

.form-left,
.form-right { padding: 40px 20px 30px; }

.input-field[type="date"] { text-transform: uppercase; padding-inline-end: 10px; }
.input-field[type="date"]::-webkit-calendar-picker-indicator { opacity: 0; }

.form-left .btn   { max-width: 100%; width: 100%; }
.form-right       { background-repeat: repeat; background-position: top left; }

/* Feedback messages */
.form-feedback {
  padding: 12px 16px;
  margin-block-end: 16px;
  font-size: var(--fontSize-label-1);
  font-weight: var(--weight-bold);
  text-transform: uppercase;
  letter-spacing: 1px;
  display: none;
}
.form-feedback.success { background-color: hsla(140,50%,30%,0.3); color: #81c784; border: 1px solid #81c784; display: block; }
.form-feedback.error   { background-color: hsla(0,50%,30%,0.3);   color: #e57373; border: 1px solid #e57373; display: block; }

@media (min-width: 768px) {
  .reservation .input-wrapper { display: grid; grid-template-columns: 1fr 1fr; column-gap: 20px; }
  .reservation .input-wrapper:nth-child(4) { grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 992px) {
  .reservation-form { display: grid; grid-template-columns: 1fr 0.5fr; }
}
@media (min-width: 1200px) {
  .form-left, .form-right { padding: 75px 60px; }
}


/* ── FEATURES ────────────────────── */
.features .section-title { margin-block-end: 40px; }
.feature-card            { padding: 30px 20px 40px; }

.feature-item:nth-child(2n+1) .feature-card { background-color: var(--eerie-black-3); }
.feature-item:nth-child(2n)   .feature-card { background-color: var(--smoky-black-3); }

.feature-card .card-icon {
  max-width: max-content;
  margin-inline: auto;
  transition: var(--transition-2);
}
.feature-card:hover .card-icon { transform: scale(-1) rotate(180deg); }
.feature-card .card-title      { margin-block: 20px; }
.feature-card .card-text       { color: var(--quick-silver); line-height: var(--lineHeight-6); }

@media (min-width: 1200px) {
  .features .grid-list { grid-template-columns: repeat(4, 1fr); }
}
@media (min-width: 1400px) {
  .features           { overflow: visible; }
  .features .shape    { display: block; }
  .features .shape-1  { top: -100px; right: 0; }
  .features .shape-2  { bottom: 80px; left: 0; }
}


/* ── EVENT ───────────────────────── */
.event .section-title { margin-block-end: 40px; }
.event-card           { position: relative; overflow: hidden; }

.event-card .card-content {
  background-image: var(--gradient-1);
  position: absolute;
  bottom: 0;
  width: 100%;
  padding: 35px 35px 25px;
}
.event-card .publish-date {
  position: absolute;
  top: 30px;
  left: 25px;
  padding: 5px 10px;
  color: var(--gold-crayola);
  background-color: var(--black);
  font-weight: var(--weight-bold);
  letter-spacing: var(--letterSpacing-1);
  line-height: 14px;
}
.event-card .card-subtitle {
  color: var(--gold-crayola);
  text-transform: uppercase;
  font-weight: var(--weight-bold);
  letter-spacing: var(--letterSpacing-2);
  margin-block-end: 5px;
}
.event-card .card-banner .img-cover { transition: var(--transition-2); }
.event-card:is(:hover, :focus-within) .img-cover { transform: scale(1.05); }
.event .btn { margin-inline: auto; margin-block-start: 40px; }

@media (min-width: 575px) {
  .event .container { max-width: 420px; margin-inline: auto; }
}
@media (min-width: 768px) {
  :is(.service, .event) .container { max-width: 820px; }
  :is(.service, .event) .grid-list li:last-child {
    grid-column: 1 / 3;
    width: calc(50% - 20px);
    margin-inline: auto;
  }
}


/* ── MEDIA shared ────────────────── */
@media (min-width: 768px) {
  .grid-list { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 992px) {
  :root { --section-space: 100px; }
}
@media (min-width: 1200px) {
  .container,
  :is(.service, .event) .container {
    max-width: 1200px;
    width: 100%;
    margin-inline: auto;
  }
}
