/* =============================================================
   MAPLE HEAD SPA — SERVICES PAGE STYLES
============================================================= */

/* Services page uses paper background */
body { background: var(--paper); }

/* === PAGE HEADER === */
.page-head {
  background: var(--paper); text-align: center;
  padding: 140px 24px 30px; position: relative;
}
.page-eyebrow {
  font-family: var(--sans); font-weight: 400;
  font-size: 12px; letter-spacing: .5em; text-transform: uppercase;
  color: var(--text-soft); margin-bottom: 18px;
  opacity: 0; transform: translateY(8px);
  animation: rise .9s .1s ease-out forwards;
}
.page-title {
  display: block; margin: 0 auto; width: 180px; height: auto;
  opacity: 0; transform: translateY(12px);
  animation: rise 1.1s .25s ease-out forwards;
}
.page-mark {
  margin: 18px auto 0; width: 28px; height: 28px;
  opacity: 0; animation: fade 1s .8s ease-out forwards;
}
.page-mark svg { width: 100%; height: 100%; display: block; color: var(--mauve); }
@keyframes rise { to { opacity: 1; transform: translateY(0); } }
@keyframes fade { to { opacity: 1; } }

/* === SERVICE MENU CARD === */
.menu-wrap { position: relative; padding: 30px 24px 80px; overflow: hidden; }
.leaf { position: absolute; top: 60px; width: 200px; height: auto; color: var(--beige); opacity: .55; pointer-events: none; z-index: 0; }
.leaf-l { left: -30px; transform: scaleX(-1); }
.leaf-r { right: -30px; }
.menu-card {
  position: relative; max-width: 880px; margin: 0 auto;
  background: var(--paper); padding: 20px 0 30px; z-index: 1;
}
.section-head { text-align: center; margin: 20px 0 40px; }
.section-head h2 {
  font-family: var(--sans); font-weight: 400;
  font-size: 16px; letter-spacing: .42em; text-transform: uppercase; color: var(--deep-brown);
}
.section-head .sub {
  margin-top: 10px; font-family: var(--sans); font-weight: 300;
  font-size: 11px; letter-spacing: .34em; text-transform: uppercase; color: var(--text-soft);
}
.section-head .rule {
  width: 100%; max-width: 720px; margin: 22px auto 0;
  display: flex; align-items: center; gap: 12px; color: var(--line);
}
.section-head .rule::before,
.section-head .rule::after { content: ""; flex: 1; height: 1px; background: currentColor; }
.section-head .rule .dot { width: 4px; height: 4px; border-radius: 50%; background: var(--mauve); }
.service-list { list-style: none; padding: 0 20px; }
.service {
  position: relative;
  display: grid; grid-template-columns: 1fr auto auto;
  align-items: start; gap: 32px;
  padding: 26px 0; border-bottom: 1px solid var(--line-soft);
  opacity: 0; transform: translateY(8px);
  animation: rise .8s ease-out forwards;
  cursor: pointer; transition: background .35s ease, padding-left .35s ease;
}
.service:hover { background: rgba(201,184,155,.10); padding-left: 12px; }
.service:last-child { border-bottom: none; }
.service-main { min-width: 0; }
.service-name {
  font-family: var(--serif); font-weight: 500;
  font-size: clamp(22px,2.4vw,28px); letter-spacing: .04em;
  color: var(--deep-brown); text-transform: uppercase; line-height: 1.1;
  display: flex; align-items: center; flex-wrap: wrap; gap: 12px;
}
.service-desc {
  margin-top: 8px; font-family: var(--sans); font-weight: 300;
  font-size: 14px; line-height: 1.6; color: var(--text-soft); max-width: 460px;
}
.service-hint {
  margin-top: 10px;
  font-family: var(--sans); font-size: 10px;
  letter-spacing: .28em; text-transform: uppercase;
  color: var(--bronze); opacity: 0;
  transition: opacity .25s ease;
}
.service:hover .service-hint { opacity: 1; }
.service-duration {
  font-family: var(--sans); font-weight: 400;
  font-size: 12px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--text-soft); white-space: nowrap; padding-top: 8px;
}
.service-price {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(24px,2.6vw,30px);
  color: var(--deep-brown); white-space: nowrap; text-align: right; line-height: 1; padding-top: 4px;
}
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--sans); font-weight: 400;
  font-size: 9px; letter-spacing: .28em; text-transform: uppercase;
  color: var(--deep-brown); border: 1px solid var(--line);
  padding: 4px 10px; border-radius: 2px; background: var(--ivory); vertical-align: middle;
}
.badge.popular { background: transparent; }
.badge.popular .star { width: 10px; height: 10px; color: var(--mauve); }
.badge.new    { background: var(--deep-brown); color: var(--ivory); border-color: var(--deep-brown); }
.badge.female { background: rgba(180,160,170,.12); color: var(--mauve); border-color: rgba(180,160,170,.4); }
.section-divider { margin-top: 50px; }

/* === ADD-ONS === */
.addons {
  margin: 60px 20px 0; border: 1px solid var(--line);
  padding: 28px 32px 26px; position: relative;
  background: rgba(246,241,230,.5);
}
.addons-title {
  position: absolute; top: -11px; left: 50%; transform: translateX(-50%);
  background: var(--paper); padding: 0 16px;
  font-family: var(--sans); font-weight: 400;
  font-size: 12px; letter-spacing: .42em; text-transform: uppercase; color: var(--deep-brown);
}
.addon-list { list-style: none; padding: 0; margin: 6px 0 0; }
.addon {
  display: grid; grid-template-columns: 1fr auto auto;
  align-items: center; gap: 14px; padding: 10px 0;
  font-family: var(--sans); font-weight: 300;
  font-size: 13px; letter-spacing: .16em; text-transform: uppercase; color: var(--text-dark);
}
.addon + .addon { border-top: 1px solid var(--line-soft); }
.addon-name  { flex: 1; }
.addon-dur   { font-family: var(--sans); font-size: 11px; letter-spacing: .2em; color: var(--text-soft); white-space: nowrap; }
.addon-price { font-family: var(--serif); font-weight: 400; font-size: 18px; color: var(--deep-brown); letter-spacing: .04em; }

/* === CTA === */
.cta {
  position: relative; overflow: hidden; min-height: 320px;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  background: linear-gradient(135deg, #d9c7ae 0%, #c4ad8e 100%);
  padding: 70px 24px; margin-top: 40px;
}
.cta-inner { position: relative; z-index: 2; max-width: 560px; }
.cta-inner p {
  font-family: var(--sans); font-weight: 300;
  font-size: 15px; line-height: 1.85; color: var(--text-dark); margin-bottom: 22px;
}
.cta-divider { width: 36px; height: 1px; background: var(--deep-brown); margin: 0 auto 22px; }
.cta-title {
  font-family: var(--serif); font-weight: 400;
  font-size: 32px; letter-spacing: .22em; text-transform: uppercase;
  color: var(--deep-brown); margin-bottom: 30px;
}
.btn-book {
  display: inline-block;
  background: var(--deep-brown); color: var(--ivory);
  font-family: var(--sans); font-weight: 300;
  font-size: 13px; letter-spacing: .32em; text-transform: uppercase;
  padding: 16px 38px; border: 1px solid var(--deep-brown);
  transition: background .3s ease, color .3s ease, transform .3s ease;
}
.btn-book:hover { background: transparent; color: var(--deep-brown); transform: translateY(-1px); }

/* === TREATMENT MODAL === */
.modal-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(26,17,9,.75);
  -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
  display: flex; align-items: center; justify-content: center;
  padding: 24px;
  opacity: 0; visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
}
.modal-overlay.active { opacity: 1; visibility: visible; }
.modal-card {
  position: relative; background: var(--paper);
  max-width: 600px; width: 100%;
  padding: 52px 48px 44px;
  transform: translateY(18px);
  transition: transform .35s ease;
}
.modal-overlay.active .modal-card { transform: translateY(0); }
.modal-close {
  position: absolute; top: 18px; right: 18px;
  width: 32px; height: 32px; border: none; background: none; cursor: pointer;
  color: var(--text-soft); display: flex; align-items: center; justify-content: center;
  padding: 0; transition: color .25s ease;
}
.modal-close:hover { color: var(--deep-brown); }
.modal-close svg {
  width: 20px; height: 20px;
  stroke: currentColor; stroke-width: 1.5;
  fill: none; stroke-linecap: round;
}
.modal-tag {
  font-family: var(--sans); font-size: 10px;
  letter-spacing: .42em; text-transform: uppercase;
  color: var(--bronze); margin-bottom: 14px;
}
.modal-title {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(26px,3vw,38px);
  color: var(--deep-brown); text-transform: uppercase;
  letter-spacing: .06em; line-height: 1.1; margin-bottom: 22px;
}
.modal-meta {
  display: flex; align-items: baseline; gap: 20px;
  border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
  padding: 14px 0; margin-bottom: 26px;
}
.modal-duration {
  font-family: var(--sans); font-size: 12px;
  letter-spacing: .26em; text-transform: uppercase;
  color: var(--text-soft); flex: 1;
}
.modal-price {
  font-family: var(--serif); font-size: 34px;
  color: var(--deep-brown); letter-spacing: .04em;
}
.modal-desc {
  font-family: var(--sans); font-weight: 300;
  font-size: 15px; line-height: 1.85;
  color: var(--text-dark); margin-bottom: 34px;
}
.modal-book {
  display: inline-block;
  background: var(--deep-brown); color: var(--ivory);
  font-family: var(--sans); font-weight: 300;
  font-size: 11px; letter-spacing: .36em; text-transform: uppercase;
  padding: 14px 34px; border: 1px solid var(--deep-brown);
  transition: background .3s ease, color .3s ease;
}
.modal-book:hover { background: transparent; color: var(--deep-brown); }

/* === RESPONSIVE === */
@media (max-width: 760px) {
  .page-head { padding: 120px 20px 20px; }
  .menu-wrap { padding: 20px 16px 60px; }
  .leaf { width: 110px; opacity: .4; }
  .service {
    grid-template-columns: 1fr auto;
    grid-template-areas: "name price" "desc desc" "dur dur";
    gap: 10px 16px; padding: 22px 0;
  }
  .service:hover { padding-left: 8px; }
  .service-main  { grid-area: name; }
  .service-desc  { grid-area: desc; }
  .service-duration { grid-area: dur; padding-top: 2px; }
  .service-price { grid-area: price; }
  .service-list  { padding: 0 4px; }
  .addons { margin: 50px 4px 0; padding: 26px 18px; }
  .addon { grid-template-columns: 1fr auto; font-size: 12px; letter-spacing: .12em; }
  .addon-dur { display: none; }
  .cta-title { font-size: 22px; letter-spacing: .18em; }
  .modal-card { padding: 44px 24px 36px; }
  .modal-title { font-size: 26px; }
  .modal-price { font-size: 28px; }
}
@media (max-width: 560px) {
  .footer-container { padding: 0 24px; }
}
