/* ==========================================================================
   MUA Salon — main.css
   Design tokens, base reset, layout, components.
   Mobile-first. No framework. Variables + logical properties.
   ========================================================================== */

:root {
  /* Colors */
  --c-ink: #0a0a0a;
  --c-ink-soft: #1a1a1a;
  --c-text: #1f1d1c;
  --c-muted: #6b6463;
  --c-line: #e9e3e1;
  --c-bg: #ffffff;
  --c-cream: #f6ebe7;
  --c-cream-deep: #efe1da;
  --c-pink: #f0b4c4;
  --c-pink-mid: #ebc7cf;
  --c-pink-soft: #fdf2f5;
  --c-gold: #c9a063;

  /* Type */
  --ff-display: "Playfair Display", "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --ff-body: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  --ff-accent: "EB Garamond", Georgia, serif;

  /* Type scale (fluid) */
  --fs-xxl: clamp(2.4rem, 1.4rem + 4.6vw, 5rem);
  --fs-xl:  clamp(1.9rem, 1.3rem + 2.4vw, 3.2rem);
  --fs-lg:  clamp(1.5rem, 1.2rem + 1.2vw, 2.1rem);
  --fs-md:  clamp(1.15rem, 1.05rem + 0.4vw, 1.3rem);
  --fs-base: 1rem;
  --fs-sm: 0.875rem;
  --fs-xs: 0.78rem;

  /* Layout */
  --container: 1200px;
  --container-narrow: 880px;
  --gap: clamp(1rem, 0.6rem + 1.4vw, 2rem);
  --gap-lg: clamp(2rem, 1rem + 4vw, 5rem);
  --radius: 4px;
  --radius-lg: 14px;
  --shadow: 0 12px 32px -16px rgba(15, 10, 10, 0.18);

  /* Motion */
  --ease: cubic-bezier(.2,.7,.2,1);
}

/* Reset (modern, minimal) */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
body {
  font-family: var(--ff-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  color: var(--c-text);
  background: var(--c-bg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img, picture, video, svg { max-width: 100%; height: auto; display: block; }
input, button, textarea, select { font: inherit; color: inherit; }
button { border: 0; cursor: pointer; background: transparent; }
a { color: inherit; text-decoration-color: var(--c-pink); text-underline-offset: 3px; }
a:hover { text-decoration-thickness: 2px; }
:focus-visible { outline: 2px solid var(--c-pink); outline-offset: 3px; border-radius: 2px; }

/* Typography */
h1, h2, h3, h4, h5 {
  font-family: var(--ff-display);
  font-weight: 500;
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--c-ink);
}
h1 { font-size: var(--fs-xxl); letter-spacing: -0.02em; }
h2 { font-size: var(--fs-xl); }
h3 { font-size: var(--fs-lg); }
h4 { font-size: var(--fs-md); font-family: var(--ff-body); font-weight: 600; letter-spacing: 0.01em; }
p { max-width: 70ch; }
.lede { font-size: var(--fs-md); color: var(--c-muted); max-width: 60ch; }
.eyebrow {
  font-family: var(--ff-body);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--c-muted);
  display: inline-block;
  margin-block-end: 1rem;
}
.eyebrow::before { content: ""; display: inline-block; width: 28px; height: 1px; background: var(--c-pink); vertical-align: middle; margin-inline-end: 10px; }

/* Skip link */
.skip-link {
  position: absolute; left: -9999px; top: 0;
  background: var(--c-ink); color: #fff; padding: .75rem 1rem; z-index: 100;
}
.skip-link:focus { left: 1rem; top: 1rem; }

/* Container */
.container { width: min(100% - 2rem, var(--container)); margin-inline: auto; }
.container-narrow { width: min(100% - 2rem, var(--container-narrow)); margin-inline: auto; }
.section { padding-block: clamp(3rem, 2rem + 4vw, 6rem); }
.section--cream { background: var(--c-cream); }
.section--pink { background: var(--c-pink-soft); }
.section--ink { background: var(--c-ink); color: #f0eae7; }
.section--ink h1, .section--ink h2, .section--ink h3 { color: #fff; }
.section--ink .eyebrow { color: var(--c-pink); }

/* Header / Nav */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255,255,255,0.92);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-block-end: 1px solid var(--c-line);
}
.site-header__inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding-block: 1rem;
}
.brand {
  display: inline-block;
  width: 88px;
  height: 40px;
  background: url('/assets/img/mua-black-5-1.webp') left center / contain no-repeat;
  text-indent: -9999px;
  overflow: hidden;
  white-space: nowrap;
  text-decoration: none;
  color: transparent;
}
.no-webp .brand { background-image: url('/assets/img/mua-black-5-1.png'); }
.brand strong { font-weight: 600; }
@media (min-width: 768px) {
  .brand { width: 110px; height: 50px; }
}
.nav { display: none; }
.nav ul { list-style: none; padding: 0; display: flex; gap: 1.6rem; }
.nav a { text-decoration: none; font-size: 0.94rem; color: var(--c-ink-soft); }
.nav a:hover { color: var(--c-pink); }
.nav__cta {
  background: var(--c-ink); color: #fff !important;
  padding: 0.6rem 1.1rem; border-radius: 999px; font-weight: 500;
  transition: background .2s var(--ease);
}
.nav__cta:hover { background: var(--c-pink); color: var(--c-ink) !important; }
.nav-toggle {
  width: 44px; height: 44px; display: grid; place-items: center;
  border: 1px solid var(--c-line); border-radius: 999px;
}
.nav-toggle span { width: 18px; height: 2px; background: var(--c-ink); display: block; position: relative; }
.nav-toggle span::before, .nav-toggle span::after {
  content: ""; position: absolute; left: 0; width: 100%; height: 2px; background: var(--c-ink);
}
.nav-toggle span::before { top: -6px; }
.nav-toggle span::after { top: 6px; }

/* Mobile Book button — always visible in the top bar (sibling of .nav-toggle) */
.nav__cta--mobile {
  display: inline-flex;
  align-items: center;
  text-decoration: none;
  background: var(--c-ink);
  color: #fff !important;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  font-weight: 600;
  font-size: 0.9rem;
  margin-right: 0.5rem;
  transition: background .2s;
}
.nav__cta--mobile:hover { background: var(--c-pink); color: var(--c-ink) !important; }

/* Mobile cart icon — always visible in the top bar */
.cart-link--mobile {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  position: relative;
  width: 40px;
  height: 40px;
  color: var(--c-ink);
  text-decoration: none;
  margin-right: 0.4rem;
}
.cart-link--mobile .cart-link__count {
  position: absolute;
  top: 0;
  right: 0;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  border-radius: 9px;
  background: var(--c-pink-deep, #d97a91);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (min-width: 880px) {
  .nav { display: block; }
  .nav-toggle { display: none; }
  .nav__cta--mobile { display: none !important; }  /* desktop already has Book inside .nav */
  .cart-link--mobile { display: none !important; }  /* desktop has cart inside .nav */
}

/* ---- Chair Rental pages ---- */
.rental-price-card {
  background: var(--c-pink-soft, #fbe9ee);
  border: 2px solid var(--c-pink, #d97a91);
  border-radius: 14px;
  padding: 1.4rem 1.6rem;
  text-align: center;
}
.rental-price-card__amount {
  font-family: var(--ff-display);
  font-size: 2.6rem;
  font-weight: 600;
  color: var(--c-ink);
  line-height: 1;
}
.rental-price-card__amount span {
  font-size: 1rem;
  font-weight: 400;
  color: var(--c-ink-soft);
  margin-left: 4px;
}
.rental-price-card__period {
  margin-top: 0.6rem;
  color: var(--c-ink);
  font-weight: 500;
}
.rental-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.2rem;
}
.rental-card {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 12px;
  padding: 1.4rem 1.4rem 1.6rem;
}
.rental-card h3 {
  margin: 0 0 0.4rem;
  font-size: 1.25rem;
}
.rental-card p {
  color: var(--c-ink-soft);
  margin-bottom: 0.9rem;
  font-size: 0.95rem;
  line-height: 1.4;
}
.rental-card__price {
  font-weight: 600;
  font-size: 1.15rem;
  margin-bottom: 1rem;
  color: var(--c-pink-deep, #d97a91);
}
.rental-card__price span {
  font-size: 0.82rem;
  color: var(--c-ink-soft);
  font-weight: 400;
}
.rental-list {
  list-style: disc;
  padding-left: 1.4rem;
}
.rental-list li {
  margin-bottom: 0.55rem;
  line-height: 1.5;
}

/* Application form */
.apply-form { display: block; }
.apply-form .form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.4rem;
}
@media (max-width: 600px) {
  .apply-form .form-grid { grid-template-columns: 1fr; }
}
.apply-form .field { display: flex; flex-direction: column; gap: 6px; }
.apply-form .field label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--c-ink);
}
.apply-form .field label em {
  color: var(--c-pink-deep, #d97a91);
  font-style: normal;
  margin-left: 2px;
}
.apply-form input,
.apply-form select,
.apply-form textarea {
  font: inherit;
  padding: 0.6rem 0.85rem;
  border: 1px solid var(--c-line);
  border-radius: 8px;
  background: #fff;
  color: var(--c-ink);
}
.apply-form input:focus,
.apply-form select:focus,
.apply-form textarea:focus {
  outline: none;
  border-color: var(--c-pink-deep, #d97a91);
  box-shadow: 0 0 0 3px rgba(217, 122, 145, 0.18);
}
.apply-form textarea { resize: vertical; min-height: 80px; }

/* ---- Contact form (premium styling) ---- */
.contact-form {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: 16px;
  padding: 2rem;
  box-shadow: 0 1px 3px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.04);
}
@media (max-width: 600px) {
  .contact-form { padding: 1.25rem; border-radius: 12px; }
}
.contact-form__honeypot {
  position: absolute; left: -10000px; width: 1px; height: 1px; overflow: hidden;
}
.contact-form__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.1rem 1.4rem;
}
@media (max-width: 640px) {
  .contact-form__grid { grid-template-columns: 1fr; }
}
.contact-form .field { display: flex; flex-direction: column; gap: 6px; }
.contact-form .field--full { grid-column: 1 / -1; }
.contact-form label {
  font-size: 0.85rem; font-weight: 600;
  color: var(--c-ink); letter-spacing: 0.01em;
}
.contact-form label .req {
  color: var(--c-pink-deep, #d97a91); margin-left: 2px;
}
.contact-form input,
.contact-form select,
.contact-form textarea {
  font: inherit;
  padding: 0.7rem 0.9rem;
  border: 1.5px solid var(--c-line);
  border-radius: 8px;
  background: #fff;
  color: var(--c-ink);
  transition: border-color .15s, box-shadow .15s;
}
.contact-form input::placeholder,
.contact-form textarea::placeholder {
  color: var(--c-ink-soft); opacity: 0.65;
}
.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: var(--c-pink-deep, #d97a91);
  box-shadow: 0 0 0 4px rgba(217, 122, 145, 0.13);
}
.contact-form textarea { resize: vertical; min-height: 110px; }
.contact-form__footer {
  margin-top: 1.5rem;
  display: flex; align-items: center; gap: 1.2rem;
  flex-wrap: wrap;
}
.contact-form__footer .btn--primary {
  padding: 0.85rem 2rem; font-size: 1rem;
}
.contact-form__footer .muted {
  font-size: 0.88rem; color: var(--c-ink-soft);
}
.contact-form__privacy {
  margin-top: 1rem; font-size: 0.78rem;
  color: var(--c-ink-soft); line-height: 1.4;
}

.contact-thanks {
  background: linear-gradient(135deg, var(--c-pink-soft, #fbe9ee), #fff);
  border: 2px solid var(--c-pink, #f4c4cf);
  border-radius: 16px; padding: 2.5rem 2rem;
  text-align: center; margin-bottom: 2rem;
}
.contact-thanks__icon {
  width: 56px; height: 56px;
  border-radius: 50%; background: #1f8a4f; color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 2rem; margin-bottom: 1rem; line-height: 1;
}
.contact-thanks h2 { margin: 0 0 0.5rem; }
.contact-thanks p { margin: 0; color: var(--c-ink-soft); }

.contact-error {
  background: #fcdada; color: #9b2226; border: 1px solid #f1b6b6;
  padding: 0.9rem 1.1rem; border-radius: 8px;
  margin-bottom: 1rem; font-size: 0.92rem;
}

/* Mobile menu */
.mobile-nav { display: none; padding: 1rem 0 1.5rem; border-block-start: 1px solid var(--c-line); }
.mobile-nav[data-open="true"] { display: block; }
.mobile-nav ul { list-style: none; padding: 0; display: grid; gap: 0.5rem; }
.mobile-nav a { display: block; padding: 0.6rem 0; text-decoration: none; color: var(--c-ink-soft); border-block-end: 1px solid var(--c-line); }

/* Buttons */
.btn {
  display: inline-flex; align-items: center; gap: 0.55rem;
  padding: 0.95rem 1.5rem; border-radius: 999px;
  font-weight: 500; font-size: 0.95rem; letter-spacing: 0.01em;
  text-decoration: none;
  transition: transform .2s var(--ease), background .2s var(--ease), color .2s var(--ease), box-shadow .25s var(--ease);
}
.btn--primary { background: var(--c-ink); color: #fff; }
.btn--primary:hover { background: var(--c-pink); color: var(--c-ink); transform: translateY(-1px); }
.btn--ghost { background: transparent; border: 1px solid var(--c-ink); color: var(--c-ink); }
.btn--ghost:hover { background: var(--c-ink); color: #fff; }
.btn--pink { background: var(--c-pink); color: var(--c-ink); }
.btn--pink:hover { background: var(--c-ink); color: #fff; }
.btn--lg { padding: 1.1rem 1.8rem; font-size: 1rem; }
.btn::after { content: "\2192"; transition: transform .2s var(--ease); }
.btn:hover::after { transform: translateX(3px); }

/* Hero */
.hero {
  position: relative;
  padding-block: clamp(3rem, 2rem + 6vw, 7rem);
  background:
    radial-gradient(60% 80% at 90% 10%, rgba(240, 180, 196, 0.25), transparent 70%),
    radial-gradient(40% 60% at 0% 100%, rgba(246, 235, 231, 0.7), transparent 70%),
    #fff;
  overflow: hidden;
}
.hero__grid {
  display: grid; gap: var(--gap-lg);
  grid-template-columns: 1fr;
  align-items: center;
}
.hero__title { font-size: clamp(2.6rem, 1.4rem + 5.4vw, 5.6rem); }
.hero__title em { font-style: italic; color: var(--c-pink); font-weight: 400; }
.hero__lede { font-size: var(--fs-md); color: var(--c-muted); margin-block: 1.2rem 1.8rem; max-width: 52ch; }
.hero__ctas { display: flex; gap: 0.8rem; flex-wrap: wrap; }
.hero__meta { display: flex; gap: 1.4rem; flex-wrap: wrap; margin-block-start: 2.2rem; font-size: 0.92rem; color: var(--c-muted); }
.hero__meta strong { color: var(--c-ink); font-weight: 600; }
.hero__media {
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background: var(--c-cream);
}
.hero__media img { width: 100%; height: 100%; object-fit: cover; }

@media (min-width: 980px) {
  .hero__grid { grid-template-columns: 1.05fr 0.95fr; }
}

/* Cards / grids */
.grid { display: grid; gap: var(--gap); }
.grid--2 { grid-template-columns: 1fr; }
.grid--3 { grid-template-columns: 1fr; }
.grid--4 { grid-template-columns: 1fr; }
@media (min-width: 640px) {
  .grid--2 { grid-template-columns: repeat(2, 1fr); }
  .grid--3 { grid-template-columns: repeat(2, 1fr); }
  .grid--4 { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 980px) {
  .grid--3 { grid-template-columns: repeat(3, 1fr); }
  .grid--4 { grid-template-columns: repeat(4, 1fr); }
}

/* Service card */
.s-card {
  position: relative;
  padding: 1.6rem 1.6rem 1.8rem;
  border-radius: var(--radius-lg);
  background: #fff;
  border: 1px solid var(--c-line);
  transition: border-color .2s var(--ease), transform .2s var(--ease), box-shadow .2s var(--ease);
  display: flex; flex-direction: column; gap: 0.7rem;
}
.s-card:hover { border-color: var(--c-pink); transform: translateY(-2px); box-shadow: var(--shadow); }
.s-card h3 { font-size: 1.35rem; }
.s-card .price { font-family: var(--ff-display); color: var(--c-pink); font-size: 1.05rem; }
.s-card .meta { font-size: 0.85rem; color: var(--c-muted); }
.s-card a { text-decoration: none; }
.s-card__link { margin-block-start: auto; font-weight: 500; font-size: 0.9rem; }

/* Service menu (price list) */
.menu { display: grid; gap: 2.6rem; }
.menu__group h3 {
  font-size: 1.6rem;
  padding-block-end: 0.6rem;
  border-block-end: 1px solid var(--c-line);
  margin-block-end: 1rem;
}
.menu__items { list-style: none; padding: 0; display: grid; gap: 0.4rem; }
.menu__item {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-areas:
    "info  price"
    "action price";
  gap: 0.5rem 1.2rem;
  align-items: start;
  padding-block: 0.9rem;
  border-block-end: 1px dashed var(--c-line);
}
.menu__item > div:first-of-type { grid-area: info; }
.menu__item > div:nth-of-type(2) { grid-area: price; text-align: right; align-self: start; }
.menu__item > .menu__book { grid-area: action; justify-self: start; }
.menu__item:last-child { border: 0; }
.menu__name { font-weight: 500; color: var(--c-ink); }
.menu__desc { display: block; font-size: 0.85rem; color: var(--c-muted); margin-block-start: 0.15rem; font-weight: 400; }
.menu__price { font-family: var(--ff-display); color: var(--c-ink); white-space: nowrap; font-size: 1.05rem; }
.menu__duration { font-size: 0.78rem; color: var(--c-muted); display: block; text-align: right; }

/* FAQ */
.faq { display: grid; gap: 0.6rem; }
.faq details {
  background: #fff;
  border: 1px solid var(--c-line);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.4rem;
  transition: border-color .2s var(--ease);
}
.faq details[open] { border-color: var(--c-pink); }
.faq summary {
  list-style: none; cursor: pointer;
  display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  font-weight: 500; font-size: 1.05rem; color: var(--c-ink);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after {
  content: "+"; font-family: var(--ff-display); font-size: 1.6rem; line-height: 1;
  transition: transform .2s var(--ease);
}
.faq details[open] summary::after { content: "\2013"; }
.faq__answer { padding-block-start: 0.9rem; color: var(--c-muted); }
.faq__answer p + p { margin-block-start: 0.7rem; }

/* Testimonials */
.quote {
  background: var(--c-cream);
  padding: 2rem 1.6rem;
  border-radius: var(--radius-lg);
  display: flex; flex-direction: column; gap: 1rem;
  position: relative;
}
.quote::before {
  content: "\201C"; font-family: var(--ff-display); font-size: 4rem; line-height: 0.6;
  color: var(--c-pink); position: absolute; top: 1rem; left: 1.4rem;
}
.quote blockquote { padding-inline-start: 2rem; font-style: italic; color: var(--c-text); }
.quote cite { font-style: normal; font-weight: 600; color: var(--c-ink); }
.quote cite span { display: block; font-weight: 400; color: var(--c-muted); font-size: 0.85rem; margin-block-start: 0.2rem; }
.stars { color: var(--c-gold); letter-spacing: 0.1em; }

/* Featured / signature */
.signature {
  background: linear-gradient(135deg, var(--c-pink-soft), var(--c-cream));
  border-radius: var(--radius-lg);
  padding: clamp(1.6rem, 1rem + 2vw, 2.6rem);
}
.signature__price { font-family: var(--ff-display); font-size: var(--fs-lg); color: var(--c-ink); }
.signature .price-line { color: var(--c-pink); }

/* CTA strip */
.cta-strip {
  background: var(--c-ink); color: #fff;
  padding: clamp(2.4rem, 1.6rem + 3vw, 4rem) 0;
}
.cta-strip__inner {
  display: flex; flex-direction: column; gap: 1.4rem; align-items: flex-start;
}
.cta-strip h2 { color: #fff; }
.cta-strip .btn--primary { background: var(--c-pink); color: var(--c-ink); }
.cta-strip .btn--primary:hover { background: #fff; }
@media (min-width: 880px) {
  .cta-strip__inner { flex-direction: row; align-items: center; justify-content: space-between; }
}

/* Footer */
.site-footer { background: var(--c-ink); color: #d8d2cf; padding-block: 4rem 2rem; }
.site-footer h4 { color: #fff; font-family: var(--ff-display); font-size: 1.05rem; margin-block-end: 0.9rem; font-weight: 500; }
.site-footer a { color: #d8d2cf; text-decoration: none; }
.site-footer a:hover { color: var(--c-pink); }
.site-footer ul { list-style: none; padding: 0; display: grid; gap: 0.4rem; }
.site-footer__grid {
  display: grid; gap: 2.4rem;
  grid-template-columns: 1fr;
}
@media (min-width: 700px) { .site-footer__grid { grid-template-columns: 1.4fr 1fr 1fr 1fr; } }
.site-footer__legal {
  margin-block-start: 3rem; padding-block-start: 1.6rem; border-block-start: 1px solid #2a2a2a;
  display: flex; flex-direction: column; gap: 0.6rem; font-size: 0.85rem; color: #8b8482;
}
@media (min-width: 700px) { .site-footer__legal { flex-direction: row; justify-content: space-between; } }
.site-footer__brand { font-family: var(--ff-display); color: #fff; font-size: 1.5rem; margin-block-end: 0.8rem; display: inline-block; }

/* Breadcrumbs */
.breadcrumbs { font-size: 0.85rem; color: var(--c-muted); padding-block: 1.2rem 0.4rem; }
.breadcrumbs a { color: var(--c-muted); text-decoration: none; }
.breadcrumbs a:hover { color: var(--c-pink); }
.breadcrumbs ol { list-style: none; padding: 0; display: flex; gap: 0.5rem; flex-wrap: wrap; }
.breadcrumbs li + li::before { content: "/"; padding-inline-end: 0.5rem; color: var(--c-line); }
.breadcrumbs [aria-current="page"] { color: var(--c-ink); }

/* Definition table for AI/structured info */
.fact-list {
  display: grid; gap: 1rem;
  grid-template-columns: 1fr;
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius-lg);
  padding: 1.4rem 1.6rem;
}
.fact-list dt { font-weight: 600; color: var(--c-ink); font-size: 0.85rem; letter-spacing: 0.04em; text-transform: uppercase; }
.fact-list dd { margin: 0; color: var(--c-text); }
@media (min-width: 640px) {
  .fact-list { grid-template-columns: 220px 1fr; gap: 1.4rem 2rem; align-items: baseline; }
}

/* Forms */
.form { display: grid; gap: 1.1rem; max-width: 560px; }
.form label { display: grid; gap: 0.4rem; font-size: 0.88rem; font-weight: 500; }
.form input, .form textarea, .form select {
  background: #fff; border: 1px solid var(--c-line); border-radius: var(--radius);
  padding: 0.85rem 1rem; font-size: 1rem; transition: border-color .2s var(--ease);
}
.form input:focus, .form textarea:focus, .form select:focus { border-color: var(--c-pink); outline: none; }
.form textarea { min-height: 140px; resize: vertical; }

/* Helpers */
.text-center { text-align: center; }
.mt-0 { margin-top: 0; }
.mt-1 { margin-top: 0.5rem; }
.mt-2 { margin-top: 1rem; }
.mt-3 { margin-top: 1.5rem; }
.mt-4 { margin-top: 2rem; }
.mt-5 { margin-top: 3rem; }
.muted { color: var(--c-muted); }
.pink { color: var(--c-pink); }
.serif { font-family: var(--ff-display); }
.divider { border: 0; height: 1px; background: var(--c-line); margin-block: 2rem; }
.tag {
  display: inline-block; font-size: 0.75rem; letter-spacing: 0.06em; text-transform: uppercase;
  background: var(--c-pink-soft); color: var(--c-ink-soft);
  padding: 0.3rem 0.7rem; border-radius: 999px;
}
.visually-hidden { position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

/* Anchor offset for sticky header */
:is(h2, h3, section)[id] { scroll-margin-top: 90px; }

/* Print niceties */
@media print {
  .site-header, .nav, .cta-strip, .site-footer { display: none; }
  body { color: #000; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation: none !important; transition: none !important; scroll-behavior: auto !important; }
}

/* Inline "Book" link inside menu items */
.menu__book {
  display: inline-flex;
  align-items: center;
  width: max-content;
  margin-top: 0.1rem;
  padding: 0.35rem 0.9rem;
  background: var(--c-pink-soft);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--c-ink);
  text-decoration: none;
  letter-spacing: 0.02em;
  transition: background .15s var(--ease), color .15s var(--ease);
}
.menu__book:hover { background: var(--c-pink); color: var(--c-ink); }
.menu__item { position: relative; }


/* ==========================================================================
   RTL language support (Farsi, Arabic, Hebrew)
   Auto-applied via [dir="rtl"] on <html> tag.
   ========================================================================== */
[dir="rtl"] body {
  font-family: "Vazirmatn", "Noto Sans Arabic", "Noto Sans Hebrew", var(--ff-body);
  letter-spacing: 0;
}
[dir="rtl"] h1, [dir="rtl"] h2, [dir="rtl"] h3, [dir="rtl"] h4, [dir="rtl"] h5 {
  font-family: "Vazirmatn", "Noto Sans Arabic", "Noto Sans Hebrew", var(--ff-display);
  letter-spacing: 0;
}
[dir="rtl"] .eyebrow::before { margin-inline-end: 0; margin-inline-start: 10px; }
[dir="rtl"] .btn::after { content: "\2190"; transition: transform .2s var(--ease); }
[dir="rtl"] .btn:hover::after { transform: translateX(-3px); }
[dir="rtl"] .breadcrumbs li + li::before { content: "\\"; }
[dir="rtl"] .nav ul, [dir="rtl"] .site-footer ul { padding-inline: 0; }
[dir="rtl"] .s-card__link::after, [dir="rtl"] .menu__book {
  /* keep arrows correct direction */
}

/* Armenian / Russian / Turkish / Spanish use Latin or Cyrillic with default fonts */
[lang="hy"] body { font-family: "Noto Sans Armenian", var(--ff-body); }
[lang="ru"] body { font-family: var(--ff-body); }

/* ==========================================================================
   Campaigns: promo strip, hub cards, service-page badges
   Appended by /admin/inc/campaign-regen.php instructions.
   ========================================================================== */
.promo-strip {
  background: var(--c-pink);
  color: var(--c-ink);
  padding: 0.75rem 1rem;
  text-align: center;
  font-weight: 500;
}
.promo-strip a { text-decoration: underline; }
.promo-strip__code {
  background: var(--c-ink);
  color: #fff;
  padding: 0.15rem 0.5rem;
  border-radius: 4px;
  font-family: monospace;
}

/* Campaign card (used on /campaigns/ hub) */
.campaign-card {
  background: var(--c-cream);
  border: 1px solid var(--c-pink);
  border-radius: var(--radius-lg);
  padding: 1.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.7rem;
}
.campaign-card__media img {
  width: 100%;
  height: auto;
  border-radius: calc(var(--radius-lg) - 4px);
  display: block;
}
.campaign-card__discount {
  font-family: var(--ff-display);
  font-size: 1.6rem;
  color: var(--c-pink);
  margin: 0;
}
.campaign-card__code {
  background: var(--c-ink);
  color: #fff;
  font-family: monospace;
  padding: 0.3rem 0.7rem;
  border-radius: 4px;
  display: inline-block;
  font-size: 0.9rem;
}

/* Service-page badge (linked) */
.campaign-badge {
  display: inline-block;
  background: var(--c-pink);
  color: var(--c-ink);
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  font-size: 0.85rem;
  font-weight: 600;
  margin-block-start: 0.5rem;
  text-decoration: none;
}
.campaign-badge:hover { background: var(--c-ink); color: #fff; }

/* =====================================================
   Careers / Hiring pages
   ===================================================== */

.careers-page main { padding: 60px 0 80px; }
.careers-hub .hub-header { text-align: center; margin: 30px 0 40px; }
.careers-hub .hub-header h1 { font-size: clamp(28px, 4vw, 44px); margin: 0 0 16px; }
.careers-hub .hub-header .lede { max-width: 720px; margin: 0 auto; color: var(--c-soft); font-size: 16px; line-height: 1.6; }
.job-grid { display: grid; gap: 18px; grid-template-columns: 1fr; margin: 0 0 60px; }
@media (min-width: 760px) { .job-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .job-grid { grid-template-columns: repeat(3, 1fr); } }
.job-card { background: #fff; border: 1px solid var(--c-line); border-radius: 12px; overflow: hidden; transition: transform .15s ease, box-shadow .15s ease; }
.job-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(26,18,19,.08); }
.job-card.is-active { border-color: var(--c-pink-deep); }
.job-card__inner { display: block; padding: 22px; text-decoration: none; color: inherit; }
.job-card__status { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700;
  padding: 3px 10px; border-radius: 999px; background: var(--c-cream); color: var(--c-soft); margin: 0 0 12px; }
.job-card.is-active .job-card__status { background: #2e7d4f; color: #fff; }
.job-card.is-passive .job-card__status { background: var(--c-pink-soft); color: var(--c-pink-deep); }
.job-card.is-closed .job-card__status { background: #eee; color: #666; }
.job-card h3 { margin: 0 0 8px; font-size: 22px; line-height: 1.2; }
.job-card p { margin: 0 0 14px; color: var(--c-soft); font-size: 14px; line-height: 1.55; min-height: 4.5em; }
.job-card__meta { display: flex; align-items: center; justify-content: space-between; font-size: 13px; }
.job-card__cta { color: var(--c-pink-deep); font-weight: 600; }
.job-pay { font-weight: 600; color: var(--c-ink); }

.hub-faq { margin: 60px 0 40px; max-width: 760px; }
.hub-faq h2 { font-size: 24px; margin: 0 0 20px; }
.hub-faq details { border-bottom: 1px solid var(--c-line); padding: 14px 0; }
.hub-faq summary { cursor: pointer; font-weight: 600; font-size: 16px; padding: 4px 0; }
.hub-faq summary::-webkit-details-marker { color: var(--c-pink-deep); }
.hub-faq details[open] summary { color: var(--c-pink-deep); }
.hub-faq p { margin: 10px 0 0; color: var(--c-soft); }

.hub-cta { text-align: center; padding: 30px 20px; background: var(--c-cream); border-radius: 12px; margin: 30px 0 0; }
.hub-cta h2 { margin: 0 0 8px; font-size: 22px; }
.hub-cta p { margin: 0; color: var(--c-soft); }

/* Single job posting */
.careers-detail .job-posting { max-width: 820px; margin: 0 auto; }
.job-header { margin: 0 0 28px; }
.job-status { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700;
  padding: 4px 12px; border-radius: 999px; margin: 0 0 16px; }
.job-status.is-active   { background: #2e7d4f; color: #fff; }
.job-status.is-passive  { background: var(--c-pink-soft); color: var(--c-pink-deep); }
.job-status.is-closed   { background: #eee; color: #666; }
.job-posting h1 { font-size: clamp(28px, 4vw, 42px); margin: 0 0 14px; }
.job-posting .lede { font-size: 17px; line-height: 1.65; color: var(--c-ink); max-width: 720px; margin: 0 0 20px; }
.job-facts { display: grid; grid-template-columns: 1fr; gap: 0; margin: 0; padding: 18px 0;
  border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
@media (min-width: 600px) { .job-facts { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .job-facts { grid-template-columns: 1fr 1fr 1fr; } }
.job-facts > div { padding: 8px 0; }
.job-facts dt { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--c-soft); margin: 0 0 4px; font-weight: 600; }
.job-facts dd { margin: 0; font-size: 14.5px; color: var(--c-ink); }
.job-pay-note { background: var(--c-pink-soft); border-left: 3px solid var(--c-pink-deep); padding: 12px 18px; border-radius: 0 8px 8px 0; margin: 20px 0; font-size: 14.5px; }
.job-section { margin: 36px 0; }
.job-section h2 { font-size: 22px; margin: 0 0 14px; padding-bottom: 8px; border-bottom: 2px solid var(--c-pink); }
.job-section p { line-height: 1.7; color: var(--c-ink); margin: 0 0 14px; }
.job-section ul { padding-left: 20px; margin: 10px 0; }
.job-section li { margin: 6px 0; line-height: 1.6; }

/* Apply form */
.job-apply { background: var(--c-cream); padding: 30px; border-radius: 12px; }
.job-apply h2 { border-bottom: none; }
.apply-form { display: flex; flex-direction: column; gap: 14px; max-width: 540px; }
.apply-row label { display: block; font-weight: 600; font-size: 14px; margin: 0 0 6px; }
.apply-row input, .apply-row textarea { width: 100%; padding: 12px 14px; font: inherit;
  border: 1px solid var(--c-line); border-radius: 8px; background: #fff; box-sizing: border-box; }
.apply-row input:focus, .apply-row textarea:focus { outline: none; border-color: var(--c-pink-deep); box-shadow: 0 0 0 3px var(--c-pink-soft); }
.apply-row textarea { resize: vertical; min-height: 70px; }
.apply-row .hint { display: block; margin: 4px 0 0; font-size: 12.5px; color: var(--c-soft); }
.apply-submit { background: var(--c-ink); color: var(--c-cream); border: none; padding: 14px 28px; font: inherit; letter-spacing: 2px; cursor: pointer; border-radius: 999px; align-self: flex-start; }
.apply-submit:hover { background: var(--c-pink-deep); }
.apply-promise { font-size: 12.5px; color: var(--c-soft); margin: 8px 0 0; }

/* Homepage "We're hiring" badge */
.hiring-badge { display: inline-flex; align-items: center; gap: 8px; background: var(--c-pink-soft);
  color: var(--c-pink-deep); padding: 6px 14px; border-radius: 999px; text-decoration: none;
  font-size: 13px; font-weight: 600; letter-spacing: .3px; border: 1px solid var(--c-pink); }
.hiring-badge::before { content: "●"; color: #2e7d4f; animation: hire-pulse 2s ease infinite; }
.hiring-badge:hover { background: var(--c-pink); color: var(--c-ink); }
@keyframes hire-pulse { 0%, 100% { opacity: 1 } 50% { opacity: .35 } }

/* =====================================================
   Academy / Courses pages
   ===================================================== */

.academy-page main { padding: 60px 0 80px; }
.academy-hub .hub-header { text-align: center; margin: 30px 0 40px; }
.academy-hub .hub-header h1 { font-size: clamp(28px, 4vw, 44px); margin: 0 0 16px; }
.academy-hub .hub-header .lede { max-width: 720px; margin: 0 auto; color: var(--c-muted); font-size: 16px; line-height: 1.6; }

.course-grid { display: grid; gap: 18px; grid-template-columns: 1fr; margin: 0 0 60px; }
@media (min-width: 760px) { .course-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1100px) { .course-grid { grid-template-columns: repeat(3, 1fr); } }

.course-card { background: #fff; border: 1px solid var(--c-line); border-radius: 12px; overflow: hidden; transition: transform .15s ease, box-shadow .15s ease; }
.course-card:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(26,18,19,.08); }
.course-card.is-active { border-color: var(--c-pink); }
.course-card__inner { display: block; padding: 22px; text-decoration: none; color: inherit; }
.course-card__status { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700;
  padding: 3px 10px; border-radius: 999px; background: var(--c-cream); color: var(--c-muted); margin: 0 8px 12px 0; }
.course-card.is-active .course-card__status { background: #2e7d4f; color: #fff; }
.course-card.is-passive .course-card__status { background: var(--c-pink-soft); color: #b3325f; }
.course-card.is-closed .course-card__status { background: #eee; color: #666; }
.course-card__category { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600;
  padding: 3px 10px; border-radius: 999px; background: var(--c-cream-deep); color: var(--c-ink); margin: 0 0 12px; }
.course-card h3 { margin: 0 0 8px; font-size: 22px; line-height: 1.2; font-family: var(--ff-display); }
.course-card p { margin: 0 0 14px; color: var(--c-muted); font-size: 14px; line-height: 1.55; min-height: 4.5em; }
.course-card__meta { display: flex; align-items: center; justify-content: space-between; font-size: 13px; margin: 0 0 12px; flex-wrap: wrap; gap: 6px; }
.course-card__price { font-weight: 600; color: var(--c-ink); }
.course-card__duration { color: var(--c-muted); }
.course-card__cta { color: #b3325f; font-weight: 600; font-size: 13.5px; }

.academy-faq { margin: 60px 0 40px; max-width: 760px; }

/* Single course detail */
.course-detail .course { max-width: 860px; margin: 0 auto; }
.course-header { margin: 0 0 28px; }
.course-status { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 700;
  padding: 4px 12px; border-radius: 999px; margin: 0 8px 16px 0; }
.course-status.is-active   { background: #2e7d4f; color: #fff; }
.course-status.is-passive  { background: var(--c-pink-soft); color: #b3325f; }
.course-status.is-closed   { background: #eee; color: #666; }
.course-category { display: inline-block; font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600;
  padding: 4px 12px; border-radius: 999px; margin: 0 0 16px; background: var(--c-cream-deep); color: var(--c-ink); }
.course h1 { font-size: clamp(28px, 4vw, 42px); margin: 0 0 14px; font-family: var(--ff-display); }
.course .lede { font-size: 17px; line-height: 1.65; color: var(--c-ink); max-width: 720px; margin: 0 0 20px; }

.course-facts { display: grid; grid-template-columns: 1fr; gap: 0; margin: 0; padding: 18px 0;
  border-top: 1px solid var(--c-line); border-bottom: 1px solid var(--c-line); }
@media (min-width: 600px) { .course-facts { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .course-facts { grid-template-columns: 1fr 1fr 1fr; } }
.course-facts > div { padding: 8px 0; }
.course-facts dt { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--c-muted); margin: 0 0 4px; font-weight: 600; }
.course-facts dd { margin: 0; font-size: 14.5px; color: var(--c-ink); }

.course-section { margin: 36px 0; }
.course-section h2 { font-size: 22px; margin: 0 0 14px; padding-bottom: 8px; border-bottom: 2px solid var(--c-pink); font-family: var(--ff-display); }
.course-section p { line-height: 1.7; color: var(--c-ink); margin: 0 0 14px; }
.course-section ul { padding-left: 20px; margin: 10px 0; }
.course-section li { margin: 6px 0; line-height: 1.6; }

.course-quote { background: var(--c-pink-soft); border-left: 3px solid var(--c-pink); padding: 16px 22px; border-radius: 0 8px 8px 0; margin: 20px 0 28px; font-size: 15.5px; line-height: 1.65; color: var(--c-ink); }
.course-quote p { margin: 0 0 10px; }
.course-quote p:last-child { margin: 0; }

/* Pricing offer cards */
.course-pricing .course-offers { display: grid; grid-template-columns: 1fr; gap: 16px; margin: 14px 0 0; }
@media (min-width: 700px) { .course-pricing .course-offers { grid-template-columns: 1fr 1fr; } }
.course-offer { background: #fff; border: 1px solid var(--c-line); border-radius: 12px; padding: 22px; }
.course-offer--private { border-color: var(--c-ink); }
.course-offer--group { border-color: var(--c-pink); }
.course-offer h3 { margin: 0 0 10px; font-size: 18px; font-family: var(--ff-display); }
.course-offer__price { font-size: 28px; font-weight: 700; color: var(--c-ink); margin: 0 0 14px; line-height: 1.1; }
.course-offer__per { font-size: 13px; font-weight: 500; color: var(--c-muted); letter-spacing: .04em; }
.course-offer__bullets { padding-left: 18px; margin: 0; }
.course-offer__bullets li { margin: 6px 0; font-size: 14px; color: var(--c-text); line-height: 1.55; }
.course-deposit { margin: 16px 0 0; font-size: 13.5px; color: var(--c-muted); padding: 10px 14px; background: var(--c-cream); border-radius: 8px; }

/* Enrollment form */
.course-enroll { background: var(--c-cream); padding: 30px; border-radius: 12px; }
.course-enroll h2 { border-bottom: none; }
.enroll-form { display: flex; flex-direction: column; gap: 14px; max-width: 540px; }
.enroll-row label, .enroll-row legend { display: block; font-weight: 600; font-size: 14px; margin: 0 0 6px; }
.enroll-row input, .enroll-row textarea, .enroll-row select { width: 100%; padding: 12px 14px; font: inherit;
  border: 1px solid var(--c-line); border-radius: 8px; background: #fff; box-sizing: border-box; }
.enroll-row input:focus, .enroll-row textarea:focus, .enroll-row select:focus { outline: none; border-color: var(--c-pink); box-shadow: 0 0 0 3px var(--c-pink-soft); }
.enroll-row textarea { resize: vertical; min-height: 70px; }
.enroll-row .hint { display: block; margin: 4px 0 0; font-size: 12.5px; color: var(--c-muted); }
.enroll-radio { border: none; padding: 0; margin: 0; }
.enroll-radio label { display: inline-flex; align-items: center; gap: 8px; font-weight: 500; margin: 0 16px 6px 0; cursor: pointer; }
.enroll-radio input[type="radio"] { width: auto; margin: 0; }
.enroll-submit { background: var(--c-ink); color: var(--c-cream); border: none; padding: 14px 28px; font: inherit; letter-spacing: 2px; cursor: pointer; border-radius: 999px; align-self: flex-start; }
.enroll-submit:hover { background: var(--c-pink); color: var(--c-ink); }
.enroll-promise { font-size: 12.5px; color: var(--c-muted); margin: 8px 0 0; }


/* =====================================================
   Mua Icons (hand-illustrated set)
   Usage: <img src="/assets/img/icons/clock.png" class="mua-icon" alt="">
   ===================================================== */
.mua-icon { display: inline-block; width: 32px; height: 32px;
  vertical-align: middle; object-fit: contain; }
.mua-icon--sm { width: 20px; height: 20px; }
.mua-icon--md { width: 40px; height: 40px; }
.mua-icon--lg { width: 56px; height: 56px; }
.mua-icon--xl { width: 80px; height: 80px; }

/* Icon + label inline */
.mua-icon-line { display: inline-flex; align-items: center; gap: 8px;
  vertical-align: middle; }
.mua-icon-line .mua-icon { flex-shrink: 0; }

/* Icon as feature on cards */
.mua-icon-feature { display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 10px; }
.mua-icon-feature .mua-icon--xl { margin-bottom: 4px; }


/* ============================================================
   Product Detail Page (PDP) — Davines individual product pages
   ============================================================ */
.pdp {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr);
  gap: clamp(1.5rem, 1rem + 3vw, 4rem);
  align-items: start;
}
@media (max-width: 760px) {
  .pdp { grid-template-columns: 1fr; }
}
.pdp__media {
  background: var(--c-cream);
  border-radius: var(--radius-lg);
  padding: clamp(1rem, 0.5rem + 3vw, 2.5rem);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pdp__media img {
  width: 100%;
  height: auto;
  max-width: 480px;
  object-fit: contain;
  mix-blend-mode: multiply;
}
.pdp__line {
  font-family: var(--ff-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--c-gold);
  font-weight: 600;
  margin-bottom: 0.5rem;
}
.pdp__info h1 {
  font-size: var(--fs-xl);
  line-height: 1.1;
  margin: 0 0 0.6rem;
}
.pdp__price {
  font-family: var(--ff-display);
  font-size: var(--fs-lg);
  color: var(--c-ink);
  margin-bottom: 1rem;
}
.pdp__desc {
  color: var(--c-muted);
  font-size: var(--fs-md);
  line-height: 1.7;
  margin-bottom: 1.5rem;
}
.pdp__variants {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
  margin-bottom: 1.25rem;
}
.pdp-variant {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 1rem;
  width: 100%;
  text-align: left;
  background: var(--c-bg);
  border: 1px solid var(--c-line);
  border-radius: var(--radius);
  padding: 0.85rem 1.1rem;
  cursor: pointer;
  font-family: var(--ff-body);
  transition: border-color .2s var(--ease), background .2s var(--ease), box-shadow .2s var(--ease);
}
.pdp-variant:hover {
  border-color: var(--c-pink);
  box-shadow: var(--shadow);
}
.pdp-variant__size {
  font-weight: 500;
  color: var(--c-ink);
  font-size: var(--fs-base);
}
.pdp-variant__price {
  font-weight: 600;
  color: var(--c-ink);
}
.pdp-variant__add {
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-bg);
  background: var(--c-ink);
  padding: 0.5rem 0.9rem;
  border-radius: 999px;
  white-space: nowrap;
}
.pdp-variant:hover .pdp-variant__add { background: var(--c-pink); color: var(--c-ink); }
.pdp-variant.is-added .pdp-variant__add { background: var(--c-gold); color: var(--c-bg); }
.pdp__note {
  font-size: var(--fs-sm);
  color: var(--c-muted);
  line-height: 1.6;
  border-top: 1px solid var(--c-line);
  padding-top: 1rem;
  margin-bottom: 1rem;
}
.pdp__back {
  display: inline-block;
  font-size: var(--fs-sm);
  color: var(--c-muted);
  text-decoration: none;
}
.pdp__back:hover { color: var(--c-ink); }

/* Related products */
.pdp-related { margin-top: clamp(2.5rem, 1.5rem + 4vw, 5rem); }
.pdp-related h2 { font-size: var(--fs-lg); margin-bottom: 1.25rem; }
.pdp-rel-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--gap);
}
@media (max-width: 760px) {
  .pdp-rel-grid { grid-template-columns: repeat(2, 1fr); }
}
.pdp-rel {
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
}
.pdp-rel img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: contain;
  background: var(--c-cream);
  border-radius: var(--radius);
  padding: 0.75rem;
  mix-blend-mode: multiply;
  margin-bottom: 0.6rem;
}
.pdp-rel__name {
  font-size: var(--fs-sm);
  line-height: 1.4;
  color: var(--c-ink);
}
.pdp-rel__price {
  font-size: var(--fs-sm);
  font-weight: 600;
  color: var(--c-muted);
  margin-top: 0.2rem;
}
.pdp-rel:hover .pdp-rel__name { color: var(--c-pink); }
