/*
Theme Name:   Monaco Cut Child
Theme URI:    https://monaco-cut.de
Description:  Child Theme für Monaco Cut – basiert auf GeneratePress
Author:        Monaco Cut
Template:     generatepress
Version:      1.0.0
Text Domain:  monaco-cut-child
*/

/* ════════════════════════════════════════
   CSS VARIABLEN
════════════════════════════════════════ */
:root {
  --red:        #B33030;
  --red-hover:  #922626;
  --red-light:  #F9ECEC;
  --bg:         #F7F4F1;
  --bg-card:    #FFFFFF;
  --bg-section: #F0EBE6;
  --text:       #1C1C1C;
  --text-mid:   #4A4A4A;
  --text-light: #7A7A7A;
  --border:     #E2DAD4;
  --radius:     16px;
  --radius-sm:  10px;
  --shadow:     0 4px 24px rgba(0,0,0,0.07);
  --shadow-lg:  0 12px 48px rgba(0,0,0,0.12);
}

/* ════════════════════════════════════════
   RESET & BASE
════════════════════════════════════════ */
*, *::before, *::after { box-sizing: border-box; }

body {
  font-family: 'Montserrat', sans-serif;
  background: var(--bg);
  color: var(--text);
  overflow-x: hidden;
  line-height: 1.6;
  margin: 0;
  padding: 0;
}

img { display: block; max-width: 100%; height: auto; }
a   { text-decoration: none; color: inherit; }

/* GeneratePress Reset – eigene Header/Footer deaktivieren */
.site-header,
.site-footer,
#site-navigation,
.main-navigation {
  display: none !important;
}

.site-content,
.content-area,
#primary {
  padding: 0 !important;
  margin: 0 !important;
  max-width: 100% !important;
  width: 100% !important;
  float: none !important;
}

.site-main > article,
.hentry {
  margin: 0 !important;
  padding: 0 !important;
}

/* ════════════════════════════════════════
   HEADER
════════════════════════════════════════ */
.mc-header {
  background: #fff;
  position: sticky;
  top: 0;
  z-index: 200;
  box-shadow: 0 2px 12px rgba(0,0,0,0.06);
}

.mc-header-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 2rem;
  height: 72px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 2rem;
}

.mc-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--text);
}

.mc-logo svg { color: var(--red); flex-shrink: 0; }

.mc-nav {
  display: flex;
  align-items: center;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.mc-nav a {
  font-size: 0.88rem;
  font-weight: 500;
  color: var(--text-mid);
  transition: color 0.2s;
}

.mc-nav a:hover { color: var(--red); }

/* Hamburger (mobile) */
.mc-hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
  padding: 4px;
  background: none;
  border: none;
}

.mc-hamburger span {
  display: block;
  width: 24px;
  height: 2px;
  background: var(--text);
  border-radius: 2px;
  transition: all 0.3s;
}

.mc-mobile-nav {
  display: none;
  background: #fff;
  border-top: 1px solid var(--border);
  padding: 1rem 2rem;
}

.mc-mobile-nav.open { display: block; }

.mc-mobile-nav a {
  display: block;
  padding: 0.6rem 0;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text-mid);
  border-bottom: 1px solid var(--border);
}

.mc-mobile-nav a:last-child { border-bottom: none; }

/* ════════════════════════════════════════
   BUTTONS
════════════════════════════════════════ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.4rem;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.03em;
  border: none;
  cursor: pointer;
  transition: background 0.2s, transform 0.15s, box-shadow 0.2s;
  text-decoration: none;
}

.btn-red {
  background: var(--red);
  color: #fff !important;
  padding: 0.75rem 1.6rem;
  border-radius: 40px;
}

.btn-red:hover {
  background: var(--red-hover);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(179,48,48,0.3);
}

.btn-outline {
  background: transparent;
  color: var(--red) !important;
  border: 2px solid var(--red);
  padding: 0.7rem 1.5rem;
  border-radius: 40px;
}

.btn-outline:hover { background: var(--red-light); }

.btn-white {
  background: #fff;
  color: var(--red) !important;
  padding: 0.9rem 2rem;
  border-radius: 40px;
}

.btn-white:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15);
}

/* ════════════════════════════════════════
   HERO
════════════════════════════════════════ */
.mc-hero {
  background: #EDE8E3;
  overflow: hidden;
  position: relative;
}

.mc-hero-inner {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 2rem;
  min-height: 520px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  gap: 2rem;
}

.mc-hero-text { padding: 4rem 0; }

.mc-hero-eyebrow {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 0.8rem;
}

.mc-hero-title {
  font-size: clamp(2.2rem, 4vw, 3.2rem);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.01em;
  margin-bottom: 0.5rem;
}

.mc-hero-subtitle {
  font-family: 'Lora', serif;
  font-size: 1.1rem;
  color: var(--text-mid);
  margin-bottom: 2rem;
  line-height: 1.5;
}

.mc-hero-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

.mc-hero-image {
  position: relative;
  display: flex;
  justify-content: flex-end;
  align-items: flex-end;
}

.mc-hero-blob {
  position: absolute;
  top: 0; right: -40px; bottom: 0;
  width: 110%;
  background: #D9D2CB;
  border-radius: 60% 40% 50% 50% / 60% 60% 40% 40%;
  z-index: 0;
}

.mc-hero-photo {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 480px;
  height: 420px;
  border-radius: var(--radius) var(--radius) 0 0;
  object-fit: cover;
  object-position: center top;
}

/* ════════════════════════════════════════
   WAVE
════════════════════════════════════════ */
.mc-wave {
  line-height: 0;
  overflow: hidden;
}
.mc-wave svg { display: block; width: 100%; }

/* ════════════════════════════════════════
   SECTION BASE
════════════════════════════════════════ */
.mc-section { padding: 5rem 2rem; }
.mc-container { max-width: 1140px; margin: 0 auto; }

.mc-tag {
  display: inline-block;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--red);
  margin-bottom: 0.5rem;
}

.mc-heading {
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  font-weight: 800;
  line-height: 1.2;
  margin-bottom: 1rem;
}

.mc-heading em {
  font-family: 'Lora', serif;
  font-style: italic;
  font-weight: 600;
  color: var(--red);
}

.mc-body {
  font-size: 0.95rem;
  color: var(--text-mid);
  line-height: 1.8;
  max-width: 520px;
}

/* ════════════════════════════════════════
   LEISTUNGEN
════════════════════════════════════════ */
.mc-leistungen { background: var(--bg); }

.mc-leistungen-grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 4rem;
  align-items: center;
  margin-top: 0.5rem;
}

.mc-salon-photo {
  width: 100%;
  height: 260px;
  border-radius: var(--radius);
  object-fit: cover;
  margin-top: 2rem;
}

.mc-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.mc-card {
  background: var(--bg-card);
  border-radius: var(--radius);
  padding: 1.6rem 1.2rem;
  box-shadow: var(--shadow);
  text-align: center;
  transition: box-shadow 0.25s, transform 0.25s;
}

.mc-card:hover {
  box-shadow: var(--shadow-lg);
  transform: translateY(-3px);
}

.mc-card-icon {
  width: 44px;
  height: 44px;
  margin: 0 auto 1rem;
  color: var(--red);
}

.mc-card-name {
  font-size: 0.88rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
  line-height: 1.3;
}

.mc-card-desc {
  font-size: 0.78rem;
  color: var(--text-light);
  line-height: 1.6;
  margin-bottom: 1rem;
}

.mc-card-link {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--red);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  transition: gap 0.2s;
}

.mc-card-link:hover { gap: 0.5rem; }

/* ════════════════════════════════════════
   TEAM
════════════════════════════════════════ */
.mc-team-section { background: var(--bg-section); }

.mc-team-grid {
  display: grid;
  grid-template-columns: 1fr 1.6fr;
  gap: 4rem;
  align-items: center;
}

.mc-team-photos {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
}

.mc-member { text-align: center; }

.mc-member-photo {
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: var(--radius-sm);
  object-fit: cover;
  margin-bottom: 0.6rem;
  display: block;
}

.mc-member-name { font-size: 0.9rem; font-weight: 700; }
.mc-member-role { font-size: 0.78rem; color: var(--text-light); }

/* ════════════════════════════════════════
   GALERIE + REVIEWS
════════════════════════════════════════ */
.mc-bottom { background: var(--bg); }

.mc-bottom-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

.mc-gallery-heading {
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 1.5rem;
}

.mc-gallery-heading span {
  font-family: 'Lora', serif;
  font-style: italic;
  font-weight: 400;
  color: var(--text-mid);
}

.mc-gallery-track { display: flex; gap: 0.75rem; }

.mc-gallery-item {
  flex: 1;
  aspect-ratio: 3/4;
  border-radius: var(--radius-sm);
  object-fit: cover;
  overflow: hidden;
}

.mc-gallery-nav {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
}

.mc-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--border);
  cursor: pointer;
  border: none;
  padding: 0;
  transition: background 0.2s;
}

.mc-dot.active,
.mc-dot:hover { background: var(--red); }

.mc-gallery-arrows { display: flex; gap: 0.5rem; margin-top: 1rem; }

.mc-arrow {
  width: 38px; height: 38px;
  border-radius: 50%;
  border: 2px solid var(--border);
  background: #fff;
  color: var(--text);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  font-size: 1rem;
  transition: all 0.2s;
}

.mc-arrow:hover { border-color: var(--red); color: var(--red); }

/* Review */
.mc-reviews-heading { font-size: 1.3rem; font-weight: 800; margin-bottom: 1.5rem; }

.mc-review {
  background: var(--bg-card);
  border-radius: var(--radius);
  padding: 1.5rem;
  box-shadow: var(--shadow);
  margin-bottom: 1.5rem;
}

.mc-stars { color: #F5A623; font-size: 1rem; margin-bottom: 0.5rem; }
.mc-review-text { font-size: 0.88rem; color: var(--text-mid); line-height: 1.7; margin-bottom: 0.6rem; }
.mc-review-author { font-size: 0.78rem; font-weight: 700; color: var(--text-light); }

/* Info Card */
.mc-info-card {
  background: var(--bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  overflow: hidden;
}

.mc-map {
  width: 100%;
  height: 150px;
  border: none;
  display: block;
}

.mc-hours { padding: 1rem 1.5rem; }

.mc-hours-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.82rem;
  padding: 0.3rem 0;
  border-bottom: 1px solid var(--border);
  color: var(--text-mid);
}

.mc-hours-row:last-child { border-bottom: none; }
.mc-hours-row .time { font-weight: 600; color: var(--text); }
.mc-hours-row .closed { color: var(--text-light); }

/* ════════════════════════════════════════
   CTA SECTION
════════════════════════════════════════ */
.mc-cta {
  background: var(--red);
  padding: 4rem 2rem;
  text-align: center;
}

.mc-cta h2 { font-size: clamp(1.6rem, 3vw, 2.2rem); font-weight: 800; color: #fff; margin-bottom: 0.5rem; }
.mc-cta p  { color: rgba(255,255,255,0.75); margin-bottom: 2rem; font-size: 0.95rem; }
.mc-cta-btns { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; }

.btn-white-outline {
  background: transparent;
  color: #fff !important;
  border: 2px solid rgba(255,255,255,0.5);
  padding: 0.85rem 2rem;
  border-radius: 40px;
  font-family: 'Montserrat', sans-serif;
  font-weight: 700;
  font-size: 0.85rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  transition: border-color 0.2s, background 0.2s;
  text-decoration: none;
}

.btn-white-outline:hover { border-color: #fff; background: rgba(255,255,255,0.1); }

/* ════════════════════════════════════════
   JOBS BAR
════════════════════════════════════════ */
.mc-jobs {
  background: #1C1C1C;
  padding: 1.5rem 2rem;
}

.mc-jobs-inner {
  max-width: 1140px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  flex-wrap: wrap;
}

.mc-jobs-badge {
  display: inline-block;
  background: var(--red);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 0.25rem 0.7rem;
  border-radius: 4px;
  margin-bottom: 0.3rem;
}

.mc-jobs-title { font-size: 0.95rem; font-weight: 700; color: #fff; }
.mc-jobs-sub   { font-size: 0.8rem; color: rgba(255,255,255,0.45); margin-top: 0.2rem; }

/* ════════════════════════════════════════
   FOOTER
════════════════════════════════════════ */
.mc-footer {
  background: #111;
  padding: 3.5rem 2rem 2rem;
}

.mc-footer-top {
  max-width: 1140px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: 3rem;
  padding-bottom: 2.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

.mc-footer-logo {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.1rem;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 0.8rem;
}

.mc-footer-logo svg { color: var(--red); }

.mc-footer-tagline {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 0.85rem;
  color: rgba(255,255,255,0.4);
  line-height: 1.6;
}

.mc-footer-col-title {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.3);
  margin-bottom: 1rem;
}

.mc-footer-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.5rem; }
.mc-footer-links a { font-size: 0.85rem; color: rgba(255,255,255,0.55); transition: color 0.2s; }
.mc-footer-links a:hover { color: var(--red); }

.mc-footer-hours-row {
  display: flex;
  justify-content: space-between;
  font-size: 0.8rem;
  color: rgba(255,255,255,0.55);
  padding: 0.25rem 0;
}

.mc-footer-hours-row .day { color: rgba(255,255,255,0.3); }

.mc-social { display: flex; gap: 0.75rem; margin-top: 1.2rem; }

.mc-social-btn {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.55);
  font-size: 0.72rem;
  font-weight: 700;
  transition: background 0.2s, color 0.2s;
  text-decoration: none;
}

.mc-social-btn:hover { background: var(--red); color: #fff; }

.mc-footer-bottom {
  max-width: 1140px;
  margin: 0 auto;
  padding-top: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
}

.mc-copy  { font-size: 0.75rem; color: rgba(255,255,255,0.2); }

.mc-legal { display: flex; gap: 1.5rem; list-style: none; margin: 0; padding: 0; }
.mc-legal a { font-size: 0.75rem; color: rgba(255,255,255,0.2); transition: color 0.2s; }
.mc-legal a:hover { color: rgba(255,255,255,0.6); }

/* ════════════════════════════════════════
   RESPONSIVE
════════════════════════════════════════ */
@media (max-width: 900px) {
  .mc-nav { display: none; }
  .mc-hamburger { display: flex; }

  .mc-hero-inner       { grid-template-columns: 1fr; }
  .mc-hero-text        { padding: 3rem 0 1.5rem; }
  .mc-hero-image       { justify-content: center; }
  .mc-hero-blob        { display: none; }
  .mc-hero-photo       { max-width: 100%; height: 300px; }

  .mc-leistungen-grid  { grid-template-columns: 1fr; gap: 2rem; }
  .mc-cards            { grid-template-columns: 1fr; }
  .mc-team-grid        { grid-template-columns: 1fr; gap: 2rem; }
  .mc-bottom-grid      { grid-template-columns: 1fr; }
  .mc-footer-top       { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .mc-jobs-inner       { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 540px) {
  .mc-footer-top       { grid-template-columns: 1fr; }
  .mc-team-photos      { grid-template-columns: repeat(3, 1fr); }
}

/* ════════════════════════════════════════
   TEAM-SEITE
════════════════════════════════════════ */
.mc-team-group {
  margin-bottom: 4rem;
}

.mc-team-group-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 2rem;
}

.mc-team-group-label span {
  font-family: 'Barlow Condensed', 'Montserrat', sans-serif;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--red);
  white-space: nowrap;
}

.mc-team-group-label::after {
  content: '';
  display: block;
  flex: 1;
  height: 1px;
  background: var(--border);
}

.mc-team-full-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}

.mc-team-card {
  background: var(--bg-card);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--shadow);
  transition: transform 0.25s, box-shadow 0.25s;
}

.mc-team-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
}

.mc-team-card-photo {
  width: 100%;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  position: relative;
}

.mc-team-card-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.4s ease;
}

.mc-team-card:hover .mc-team-card-photo img {
  transform: scale(1.04);
}

.mc-team-card-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mc-team-card-initials {
  font-family: 'Montserrat', sans-serif;
  font-size: 3rem;
  font-weight: 800;
  color: rgba(255,255,255,0.6);
  line-height: 1;
  user-select: none;
}

.mc-team-card-info {
  padding: 1rem 1.1rem 1.2rem;
}

.mc-team-card-name {
  font-size: 1rem;
  font-weight: 700;
  margin-bottom: 0.2rem;
  color: var(--text);
}

.mc-team-card-role {
  font-size: 0.78rem;
  color: var(--text-light);
  line-height: 1.4;
}

@media (max-width: 1000px) {
  .mc-team-full-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 700px) {
  .mc-team-full-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
}

@media (max-width: 400px) {
  .mc-team-full-grid { grid-template-columns: 1fr; }
}

/* ════════════════════════════════════════
   PREISSEITE
════════════════════════════════════════ */

/* Size Legend */
.mc-size-legend {
  display: flex;
  gap: 0.75rem;
  margin-bottom: 2.5rem;
  justify-content: flex-end;
}

.mc-size-pill {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text-mid);
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 40px;
  padding: 0.3rem 0.9rem;
}

.mc-size-pill span {
  font-weight: 800;
  color: var(--red);
}

/* Price Block */
.mc-price-block {
  background: var(--bg-card);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  margin-bottom: 1.5rem;
  overflow: hidden;
}

.mc-price-block-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.4rem 1.8rem;
  background: var(--bg-section);
  border-bottom: 1px solid var(--border);
}

.mc-price-block-icon {
  width: 44px;
  height: 44px;
  background: var(--red);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: #fff;
}

.mc-price-block-icon svg {
  width: 22px;
  height: 22px;
}

.mc-price-block-title {
  font-size: 1.15rem;
  font-weight: 800;
  color: var(--text);
  line-height: 1.2;
}

.mc-price-block-sub {
  font-size: 0.75rem;
  color: var(--text-light);
  margin-top: 0.15rem;
}

/* Price Table */
.mc-price-table {
  padding: 0 1.8rem 1rem;
}

.mc-price-table-head {
  display: grid;
  grid-template-columns: 1fr 80px 80px 80px;
  gap: 0;
  padding: 0.8rem 0 0.5rem;
  border-bottom: 2px solid var(--border);
  margin-bottom: 0.25rem;
}

.mc-price-table-head > div {
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--text-light);
  text-align: center;
}

.mc-price-table-head > div:first-child {
  text-align: left;
}

.mc-price-row {
  display: grid;
  grid-template-columns: 1fr 80px 80px 80px;
  gap: 0;
  padding: 0.7rem 0;
  border-bottom: 1px solid var(--border);
  align-items: center;
  transition: background 0.15s;
}

.mc-price-row:last-child {
  border-bottom: none;
}

.mc-price-row:hover {
  background: var(--red-light);
  margin: 0 -1.8rem;
  padding-left: 1.8rem;
  padding-right: 1.8rem;
  border-radius: 4px;
}

/* Single-price rows (Gentlemen / Kids) */
.mc-price-row-single {
  grid-template-columns: 1fr 240px;
}

.mc-price-col-single {
  text-align: center;
  font-size: 1rem;
  font-weight: 700;
  color: var(--red);
}

.mc-price-col-service {
  font-size: 0.9rem;
  color: var(--text);
  font-weight: 500;
  padding-right: 1rem;
}

.mc-price-col {
  text-align: center;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text);
}

.mc-price-val {
  color: var(--text);
}

.mc-price-highlight {
  color: var(--red);
  font-weight: 800;
  font-size: 1rem;
}

.mc-price-empty {
  color: var(--border);
  font-weight: 400;
}

/* Notice */
.mc-price-notice {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  background: #FFF8F0;
  border: 1px solid #F5D9B0;
  border-left: 4px solid #E8A84C;
  border-radius: var(--radius-sm);
  padding: 1rem 1.25rem;
  font-size: 0.85rem;
  color: var(--text-mid);
  line-height: 1.6;
  margin: 2rem 0;
}

.mc-price-notice svg {
  color: #E8A84C;
  flex-shrink: 0;
  margin-top: 1px;
}

/* Service on Top */
.mc-service-top {
  margin-top: 1rem;
}

.mc-service-top-label {
  display: flex;
  align-items: center;
  gap: 1rem;
  margin-bottom: 1.5rem;
}

.mc-service-top-label span {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--red);
  white-space: nowrap;
}

.mc-service-top-label::after {
  content: '';
  display: block;
  flex: 1;
  height: 1px;
  background: var(--border);
}

.mc-service-items {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1rem;
}

.mc-service-item {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 1.2rem 1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.6rem;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text-mid);
  transition: border-color 0.2s, box-shadow 0.2s;
}

.mc-service-item svg {
  color: var(--red);
}

.mc-service-item:hover {
  border-color: var(--red);
  box-shadow: var(--shadow);
}

/* Responsive */
@media (max-width: 700px) {
  .mc-price-table-head,
  .mc-price-row { grid-template-columns: 1fr 60px 60px 60px; }
  .mc-price-row-single { grid-template-columns: 1fr 120px; }
  .mc-price-col-service { font-size: 0.82rem; }
  .mc-service-items { grid-template-columns: 1fr 1fr; }
  .mc-size-legend { justify-content: flex-start; }
}

@media (max-width: 480px) {
  .mc-price-table { padding: 0 1rem 1rem; }
  .mc-price-block-header { padding: 1.2rem 1rem; }
  .mc-price-row:hover { margin: 0 -1rem; padding-left: 1rem; padding-right: 1rem; }
  .mc-service-items { grid-template-columns: 1fr; }
}
/* ════════════════════════════════════════
   GALERIE SLIDER (Bilder + Videos)
════════════════════════════════════════ */
.mc-slider { position:relative; border-radius:var(--radius); overflow:hidden; background:#111; aspect-ratio:4/5; max-height:440px; }
.mc-slider-track { position:relative; width:100%; height:100%; }
.mc-slide { position:absolute; inset:0; opacity:0; transition:opacity 0.45s ease; display:flex; align-items:center; justify-content:center; pointer-events:none; }
.mc-slide.active { opacity:1; pointer-events:auto; }
.mc-slide-img, .mc-slide-video { width:100%; height:100%; object-fit:cover; display:block; }
.mc-slide-label { position:absolute; bottom:0; left:0; right:0; padding:0.45rem 0.75rem; background:rgba(0,0,0,0.45); font-size:0.68rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:rgba(255,255,255,0.85); text-align:center; }
.mc-slide-zoom { position:absolute; top:0.75rem; right:0.75rem; width:34px; height:34px; background:rgba(0,0,0,0.5); border:none; border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; opacity:0; transition:opacity 0.2s; }
.mc-slide.active:hover .mc-slide-zoom { opacity:1; }
.mc-slide-play { position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); width:60px; height:60px; background:rgba(179,48,48,0.85); border:3px solid rgba(255,255,255,0.6); border-radius:50%; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:transform 0.2s, background 0.2s; }
.mc-slide-play:hover { background:var(--red); transform:translate(-50%,-50%) scale(1.08); }
.mc-slider-arrow { position:absolute; top:50%; transform:translateY(-50%); width:38px; height:38px; background:rgba(255,255,255,0.9); border:none; border-radius:50%; cursor:pointer; font-size:1rem; display:flex; align-items:center; justify-content:center; color:var(--text); box-shadow:0 2px 12px rgba(0,0,0,0.15); transition:background 0.2s, color 0.2s; z-index:10; }
.mc-slider-arrow:hover { background:var(--red); color:#fff; }
.mc-slider-prev { left:0.75rem; }
.mc-slider-next { right:0.75rem; }
.mc-thumb-strip { display:flex; gap:0.5rem; margin-top:0.75rem; overflow-x:auto; padding-bottom:2px; }
.mc-thumb { flex-shrink:0; width:52px; height:52px; border-radius:6px; overflow:hidden; border:2px solid transparent; cursor:pointer; background:var(--bg-section); padding:0; transition:border-color 0.2s; }
.mc-thumb img { width:100%; height:100%; object-fit:cover; display:block; }
.mc-thumb.active, .mc-thumb:hover { border-color:var(--red); }
.mc-thumb-video-icon { width:100%; height:100%; background:#333; display:flex; align-items:center; justify-content:center; }

/* LIGHTBOX */
.mc-lightbox { position:fixed; inset:0; background:rgba(0,0,0,0.92); z-index:9999; display:flex; align-items:center; justify-content:center; opacity:0; pointer-events:none; transition:opacity 0.3s; backdrop-filter:blur(6px); }
.mc-lightbox.open { opacity:1; pointer-events:auto; }
.mc-lightbox-close { position:absolute; top:1.25rem; right:1.5rem; font-size:2rem; color:rgba(255,255,255,0.7); background:none; border:none; cursor:pointer; line-height:1; transition:color 0.2s; }
.mc-lightbox-close:hover { color:#fff; }
.mc-lightbox-content { display:flex; align-items:center; justify-content:center; }

.mc-map-link { text-decoration: none; display: block; }

.mc-map-placeholder {
  width: 100%;
  height: 150px;
  background: var(--bg-section);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-bottom: 1px solid var(--border);
  transition: background 0.2s;
}

.mc-map-placeholder:hover { background: var(--red-light); }

.mc-map-placeholder span {
  font-size: 0.88rem;
  font-weight: 700;
  color: var(--red);
}

.mc-map-placeholder small {
  font-size: 0.72rem;
  color: var(--text-light);
}
/* ════════════════════════════════════════
   SALON GALERIE
════════════════════════════════════════ */
.mc-salon-gallery {
  margin-top: 1.5rem;
}

.mc-salon-main {
  width: 100%;
  border-radius: var(--radius);
  overflow: hidden;
  margin-bottom: 0.5rem;
}

.mc-salon-main img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  display: block;
  transition: opacity 0.3s;
}

.mc-salon-thumbs {
  display: flex;
  gap: 0.5rem;
}

.mc-salon-thumb {
  flex: 1;
  border: 2px solid transparent;
  border-radius: var(--radius-sm);
  overflow: hidden;
  cursor: pointer;
  padding: 0;
  background: none;
  transition: border-color 0.2s;
}

.mc-salon-thumb img {
  width: 100%;
  height: 60px;
  object-fit: cover;
  display: block;
}

.mc-salon-thumb.active,
.mc-salon-thumb:hover {
  border-color: var(--red);
}
/* ════════════════════════════════════════
   HEADER MOBIL FIX
════════════════════════════════════════ */
@media (max-width: 900px) {
  .mc-header-inner {
    padding: 0 1rem;
    height: 60px;
  }

  /* Termin-Button auf Mobil ausblenden */
  .mc-header-cta {
    display: none;
  }

  /* Hamburger näher am Rand */
  .mc-hamburger {
    margin-left: auto;
    padding: 4px;
  }

  /* Logo etwas kleiner */
  .mc-logo {
    font-size: 1rem;
  }

  .mc-logo img {
    height: 30px !important;
  }
}
/* ════════════════════════════════════════
   PREISE TABELLE MOBIL – KOMPLETT NEU
════════════════════════════════════════ */
@media (max-width: 700px) {

  /* Tabelle scrollbar machen */
  .mc-price-table {
    padding: 0 0.75rem 0.75rem;
    overflow-x: auto;
  }

  .mc-price-table-head,
  .mc-price-row {
    min-width: 320px;
    grid-template-columns: 1fr 56px 56px 56px;
  }

  .mc-price-row-single {
    min-width: 320px;
    grid-template-columns: 1fr 110px;
  }

  .mc-price-col-service {
    font-size: 0.8rem;
    padding-right: 0.5rem;
    word-break: normal;
    hyphens: auto;
    lang: de;
  }

  .mc-price-col {
    font-size: 0.8rem;
    padding: 0 2px;
  }

  .mc-price-highlight {
    font-size: 0.88rem;
  }

  /* Block Header kompakter */
  .mc-price-block-header {
    padding: 1rem;
    gap: 0.75rem;
  }

  .mc-price-block-icon {
    width: 38px;
    height: 38px;
    flex-shrink: 0;
  }

  .mc-price-block-title { font-size: 1rem; }
  .mc-price-block-sub   { font-size: 0.7rem; }

  /* Row hover anpassen */
  .mc-price-row:hover {
    margin: 0 -0.75rem;
    padding-left: 0.75rem;
    padding-right: 0.75rem;
  }

  /* Service on Top */
  .mc-service-items { grid-template-columns: 1fr 1fr; }

  /* Size Legend */
  .mc-size-legend { justify-content: flex-start; }

  /* Notice Box */
  .mc-price-notice { 
	font-size: 0.8rem;
	display:block;
	line-height: 1.7;}
}