/*
 * Мастерская — визуал 1:1 с docs/masterskaya-prototype.html
 * Исключено только: .proto-bar, переключатель «экранов», правило .screen
 * Всё селектором .masterskaya … — чтобы не ломать остальной сайт.
 */

.masterskaya {
  --bg: #F7F5F0;
  --ink: #2D3436;
  --ink-soft: #5C6063;
  --ink-mute: #8B8B82;
  --gold: #C5A065;
  --gold-soft: #DCBE89;
  --gold-deep: #A4814A;
  --line: rgba(45, 52, 54, 0.1);
  --line-strong: rgba(45, 52, 54, 0.18);
  --paper: rgba(255, 255, 255, 0.78);
  --paper-deep: rgba(255, 255, 255, 0.88);
  --paper-edge: rgba(197, 160, 101, 0.16);
  --serif: "Cormorant Garamond", "Times New Roman", serif;
  --sans: Manrope, system-ui, -apple-system, sans-serif;
  --r-sm: 6px;
  --r-md: 14px;
  --r-lg: 22px;
  --maxw: 1080px;
}

.masterskaya * {
  box-sizing: border-box;
}

/* как в прототипе: блок на всю ширину, без сжатия по центру из .panel */
.masterskaya.panel {
  align-items: stretch !important;
  width: 100%;
  max-width: none;
}

.masterskaya .section-hero h1,
.masterskaya .cat-hero h1,
.masterskaya .card h3 {
  text-shadow: none !important;
}

/* атмосферный фон-обложка — как в прототипе */
.masterskaya .site-bg {
  position: fixed;
  inset: 0;
  z-index: 0; /* внутри main: ниже .wrap (1), фон как в файле */
  background:
    radial-gradient(1100px 700px at 18% 12%, rgba(255, 228, 178, 0.55), transparent 60%),
    radial-gradient(900px 600px at 88% 18%, rgba(199, 217, 229, 0.45), transparent 65%),
    radial-gradient(1200px 900px at 50% 95%, rgba(80, 95, 90, 0.18), transparent 55%),
    linear-gradient(180deg, #ecdfc8 0%, #d7c6a8 38%, #91a097 65%, #4f5a5b 100%);
  pointer-events: none;
}

.masterskaya .site-bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='180' height='180'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' seed='4'/><feColorMatrix values='0 0 0 0 0.3  0 0 0 0 0.25  0 0 0 0 0.18  0 0 0 .08 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
  mix-blend-mode: multiply;
  opacity: 0.35;
  pointer-events: none;
}

.masterskaya .wrap {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 36px 22px 160px;
  position: relative;
  z-index: 1;
}

.masterskaya .section-hero {
  background: var(--paper);
  border-radius: var(--r-lg);
  padding: 56px 64px 48px;
  text-align: center;
  position: relative;
  border: 1px solid var(--paper-edge);
  box-shadow:
    0 1px 0 rgba(255, 255, 255, 0.6) inset,
    0 20px 60px -30px rgba(45, 52, 54, 0.25);
}

.masterskaya .eyebrow {
  display: inline-block;
  font: 500 11px/1 var(--sans);
  letter-spacing: 0.32em;
  text-transform: uppercase;
  color: var(--gold-deep);
  padding-bottom: 12px;
  border-bottom: 1px solid var(--gold);
  margin-bottom: 22px;
}

.masterskaya .section-hero h1 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(48px, 7vw, 86px);
  line-height: 1;
  letter-spacing: -0.01em;
  margin: 0 0 22px;
  color: var(--ink);
}

.masterskaya .section-hero h1 em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
}

.masterskaya .section-hero p.lead {
  font-family: var(--serif);
  font-size: 22px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 auto;
  font-weight: 400;
  font-style: italic;
}

.masterskaya .hero-meta {
  margin-top: 26px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font: 500 12px/1 var(--sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--ink-mute);
}

.masterskaya .hero-meta .dot {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--gold);
}

.masterskaya .section-label {
  display: flex;
  align-items: center;
  gap: 18px;
  margin: 56px 8px 24px;
}

.masterskaya .section-label .line {
  flex: 1;
  height: 1px;
  background: rgba(45, 52, 54, 0.18);
}

.masterskaya .section-label .ttl {
  font: 500 12px/1 var(--sans);
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--gold-deep);
}

.masterskaya .cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.masterskaya .card {
  position: relative;
  background: var(--paper);
  border-radius: var(--r-lg);
  padding: 22px 22px 28px;
  border: 1px solid var(--paper-edge);
  overflow: hidden;
  cursor: pointer;
  transition:
    transform 0.35s cubic-bezier(0.2, 0.7, 0.2, 1),
    box-shadow 0.35s ease;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
}

.masterskaya .card:hover {
  transform: translateY(-4px);
  box-shadow: 0 24px 50px -28px rgba(45, 52, 54, 0.45);
}

.masterskaya .card-img {
  position: relative;
  aspect-ratio: 4 / 3;
  border-radius: var(--r-md);
  overflow: hidden;
  background: #b8a584;
}

.masterskaya .card-img img {
  width: 100%;
  height: 100%;
  max-width: none;
  object-fit: cover;
  display: block;
  transition: transform 0.8s ease;
}

.masterskaya .card:hover .card-img img {
  transform: scale(1.05);
}

.masterskaya .card-img .frame {
  position: absolute;
  inset: 10px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  border-radius: calc(var(--r-md) - 4px);
  pointer-events: none;
}

.masterskaya .card-img .corner {
  position: absolute;
  width: 14px;
  height: 14px;
  border: 1px solid var(--gold-soft);
  z-index: 2;
}

.masterskaya .card-img .corner.tl {
  top: 6px;
  left: 6px;
  border-right: 0;
  border-bottom: 0;
}

.masterskaya .card-img .corner.tr {
  top: 6px;
  right: 6px;
  border-left: 0;
  border-bottom: 0;
}

.masterskaya .card-img .corner.bl {
  bottom: 6px;
  left: 6px;
  border-right: 0;
  border-top: 0;
}

.masterskaya .card-img .corner.br {
  bottom: 6px;
  right: 6px;
  border-left: 0;
  border-top: 0;
}

.masterskaya .card-meta {
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(20, 18, 14, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  color: #f4e9cf;
  padding: 6px 12px;
  border-radius: 999px;
  font: 500 11px/1 var(--sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border: 1px solid rgba(220, 190, 137, 0.4);
  z-index: 2;
}

.masterskaya .card-body {
  padding-top: 22px;
  text-align: center;
}

.masterskaya .card-eyebrow {
  font: 500 10px/1 var(--sans);
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 8px;
  display: block;
}

.masterskaya .card h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 30px;
  line-height: 1.15;
  margin: 0 0 12px;
  color: var(--ink);
}

.masterskaya .card h3 em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
}

.masterskaya .card p.desc {
  font: 400 14px/1.55 var(--sans);
  color: var(--ink-soft);
  margin: 0 0 18px;
  min-height: 44px;
}

.masterskaya .card-action {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font: 500 12px/1 var(--sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold-deep);
  align-self: center;
}

.masterskaya .card-action svg {
  transition: transform 0.3s ease;
}

.masterskaya .card:hover .card-action svg {
  transform: translateX(4px);
}

.masterskaya .note {
  margin-top: 56px;
  padding: 28px 32px;
  background: var(--paper);
  border-radius: var(--r-lg);
  border: 1px solid var(--paper-edge);
  display: flex;
  align-items: center;
  gap: 24px;
}

.masterskaya .note .icon {
  flex: 0 0 56px;
  height: 56px;
  border-radius: 50%;
  border: 1px solid var(--gold);
  display: grid;
  place-items: center;
  color: var(--gold-deep);
}

.masterskaya .note .text {
  font: 400 15px/1.6 var(--sans);
  color: var(--ink-soft);
}

.masterskaya .note .text strong {
  font-weight: 600;
  color: var(--ink);
}

/* Детальная страница */
.masterskaya .back-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font: 500 11px/1 var(--sans);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--ink-soft);
  text-decoration: none;
  margin-bottom: 26px;
  padding: 8px 0;
}

.masterskaya .back-link:hover {
  color: var(--gold-deep);
}

.masterskaya .back-link svg {
  transition: transform 0.2s ease;
}

.masterskaya .back-link:hover svg {
  transform: translateX(-4px);
}

.masterskaya .cat-hero {
  background: var(--paper);
  border-radius: var(--r-lg);
  padding: 50px 56px 44px;
  border: 1px solid var(--paper-edge);
  text-align: center;
  position: relative;
}

.masterskaya .cat-hero > .card-img {
  max-width: 520px;
  margin: 0 auto 24px;
}

.masterskaya .cat-hero h1 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: clamp(40px, 6vw, 72px);
  line-height: 1.05;
  margin: 0 0 18px;
  color: var(--ink);
}

.masterskaya .cat-hero h1 em {
  font-style: italic;
  color: var(--gold-deep);
  font-weight: 500;
}

.masterskaya .cat-hero .ornament {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 24px;
}

.masterskaya .cat-hero .ornament .line {
  width: 60px;
  height: 1px;
  background: var(--gold);
}

.masterskaya .cat-hero .ornament .dot {
  width: 6px;
  height: 6px;
  background: var(--gold);
  transform: rotate(45deg);
}

.masterskaya .cat-hero .lead {
  font-family: var(--serif);
  font-style: italic;
  font-size: 20px;
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 580px;
  margin: 0 auto 26px;
}

.masterskaya .cat-hero .stats {
  display: inline-flex;
  gap: 38px;
  padding: 14px 30px;
  background: rgba(197, 160, 101, 0.08);
  border-radius: 999px;
}

/* полное описание из админки — внутри cat-hero под заголовком */
.masterskaya .cat-hero .cat-desc-inner {
  margin-top: 18px;
  margin-bottom: 26px;
  text-align: left;
  font: 400 15px/1.6 var(--sans);
  color: var(--ink-soft);
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.masterskaya .cat-hero .cat-desc-inner h1,
.masterskaya .cat-hero .cat-desc-inner h2,
.masterskaya .cat-hero .cat-desc-inner h3 {
  font-family: var(--serif);
  color: var(--ink);
  text-shadow: none !important;
  font-weight: 500;
}

.masterskaya .stat-item {
  font: 500 11px/1.2 var(--sans);
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-mute);
  text-align: center;
}

.masterskaya .stat-item strong {
  display: block;
  font-family: var(--serif);
  font-weight: 600;
  font-style: normal;
  font-size: 26px;
  color: var(--gold-deep);
  letter-spacing: 0;
  text-transform: none;
  margin-bottom: 4px;
}

.masterskaya .gallery {
  margin-top: 40px;
  column-count: 3;
  column-gap: 18px;
}

.masterskaya .gallery-item {
  break-inside: avoid;
  margin-bottom: 18px;
  position: relative;
  border-radius: var(--r-md);
  overflow: hidden;
  background: #ddd0b3;
  cursor: zoom-in;
  display: block;
  border: 1px solid var(--paper-edge);
  transition: transform 0.4s cubic-bezier(0.2, 0.7, 0.2, 1);
}

.masterskaya .gallery-item:hover {
  transform: translateY(-3px);
}

.masterskaya .gallery-item img {
  display: block;
  width: 100%;
  height: auto;
}

.masterskaya .gallery-item .caption {
  position: absolute;
  inset: auto 0 0 0;
  padding: 22px 16px 14px;
  color: #f6ecd5;
  background: linear-gradient(to top, rgba(20, 18, 14, 0.78), rgba(20, 18, 14, 0));
  font: 500 12px/1.4 var(--sans);
  letter-spacing: 0.04em;
  opacity: 0;
  transform: translateY(8px);
  transition:
    opacity 0.25s,
    transform 0.25s;
}

.masterskaya .gallery-item:hover .caption {
  opacity: 1;
  transform: translateY(0);
}

.masterskaya .master-cta {
  margin-top: 64px;
  background: var(--paper-deep);
  border-radius: var(--r-lg);
  padding: 48px 56px;
  display: grid;
  grid-template-columns: 180px 1fr;
  gap: 36px;
  align-items: center;
  border: 1px solid var(--paper-edge);
  position: relative;
  overflow: hidden;
}

.masterskaya .master-cta::before {
  content: "";
  position: absolute;
  top: -60px;
  right: -60px;
  width: 220px;
  height: 220px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(197, 160, 101, 0.18), transparent 70%);
  pointer-events: none;
}

.masterskaya .master-avatar {
  width: 180px;
  height: 180px;
  border-radius: 50%;
  overflow: hidden;
  border: 1px solid var(--gold);
  padding: 6px;
  background: var(--paper);
  position: relative;
  z-index: 1;
}

.masterskaya .master-avatar img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}

.masterskaya .master-avatar > div {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background: linear-gradient(135deg, #5a6b5e, #8a8062);
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.65);
  font-family: var(--serif);
  font-style: italic;
  font-size: 16px;
  text-align: center;
  padding: 8px;
}

.masterskaya .master-cta h3 {
  font-family: var(--serif);
  font-weight: 500;
  font-size: 38px;
  line-height: 1.1;
  margin: 0 0 6px;
  color: var(--ink);
  text-shadow: none !important;
}

.masterskaya .master-cta .role {
  font: 500 11px/1 var(--sans);
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-bottom: 16px;
  display: block;
}

.masterskaya .master-cta p.about {
  font: 400 15px/1.6 var(--sans);
  color: var(--ink-soft);
  margin: 0 0 22px;
  max-width: 540px;
}

.masterskaya .master-cta .links {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
}

.masterskaya .master-cta a.link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 12px 22px;
  border-radius: 999px;
  text-decoration: none;
  font: 500 12px/1 var(--sans);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  transition: all 0.25s ease;
}

.masterskaya .master-cta a.link.primary {
  background: var(--gold);
  color: #fff;
}

.masterskaya .master-cta a.link.primary:hover {
  background: var(--gold-deep);
}

/* лайтбокс — классы как в прототипе (.lightbox) */
.masterskaya .lightbox {
  position: fixed;
  inset: 0;
  background: rgba(15, 13, 10, 0.92);
  z-index: 100;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 40px;
  cursor: zoom-out;
}

.masterskaya .lightbox.open {
  display: flex;
}

.masterskaya .lightbox img {
  max-width: 90vw;
  max-height: 85vh;
  border-radius: var(--r-md);
  border: 1px solid var(--gold);
  padding: 6px;
  background: var(--bg);
}

.masterskaya .lightbox .lb-caption {
  position: fixed;
  bottom: 24px;
  left: 0;
  right: 0;
  text-align: center;
  color: var(--gold-soft);
  font: 500 13px/1.5 var(--sans);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.masterskaya .lightbox .lb-close {
  position: fixed;
  top: 24px;
  right: 24px;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid var(--gold);
  background: transparent;
  color: var(--gold-soft);
  cursor: pointer;
  font-size: 24px;
  display: grid;
  place-items: center;
}

@media (max-width: 760px) {
  .masterskaya .wrap {
    padding: 22px 14px 140px;
  }

  .masterskaya .section-hero {
    padding: 36px 24px 32px;
  }

  .masterskaya .section-hero h1 {
    font-size: 44px;
  }

  .masterskaya .section-hero p.lead {
    font-size: 18px;
  }

  .masterskaya .cards {
    grid-template-columns: 1fr;
    gap: 18px;
  }

  .masterskaya .cat-hero {
    padding: 32px 22px;
  }

  .masterskaya .gallery {
    column-count: 2;
    column-gap: 12px;
  }

  .masterskaya .gallery-item {
    margin-bottom: 12px;
  }

  .masterskaya .master-cta {
    grid-template-columns: 1fr;
    padding: 32px 24px;
    text-align: center;
  }

  .masterskaya .master-avatar {
    margin: 0 auto;
    width: 140px;
    height: 140px;
  }

  .masterskaya .master-cta p.about {
    margin-left: auto;
    margin-right: auto;
  }

  .masterskaya .master-cta .links {
    justify-content: center;
  }

  .masterskaya .note {
    flex-direction: column;
    text-align: center;
    padding: 24px;
  }
}
