/* ============================================================
   pages.css — секции главной и внутренних страниц
   (подключается после styles.css)
   ============================================================ */

/* ---- общая обёртка изображения с object-fit ---- */
.media { background: var(--color-placeholder); overflow: hidden; }
.media img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* ===================== ВНУТРЕННИЙ ЗАГОЛОВОК СТРАНИЦЫ ===================== */
.page-hero { background: var(--color-surface); border-bottom: var(--hair); padding-block: var(--space-5) var(--space-4); }
.breadcrumb { display: flex; gap: 8px; align-items: center; font-size: 11px;
  text-transform: uppercase; letter-spacing: 0.14em; color: var(--color-stone); margin-bottom: var(--space-2); }
.breadcrumb a { color: var(--color-stone); transition: color var(--t-base); }
.breadcrumb a:hover { color: var(--color-gold); }
.breadcrumb span { color: rgba(74,69,64,0.4); }
.page-hero h1 { font-size: clamp(38px, 5vw, 58px); }
.page-hero p { max-width: 60ch; margin-top: var(--space-2); }

/* ===================== ГЛАВНАЯ: HERO ===================== */
.hero {
  position: relative; min-height: 100vh; min-height: 100svh;
  display: flex; align-items: center; color: var(--color-bg);
  overflow: hidden; background: var(--color-dark);
}
.hero__bg { position: absolute; inset: 0; z-index: 0; }
.hero__bg img { width: 100%; height: 100%; object-fit: cover; opacity: 0.9; }
.hero__bg::after { content: ""; position: absolute; inset: 0; background: rgba(28,26,24,0.55); }
.hero__inner { position: relative; z-index: 1; text-align: center; width: 100%; padding-block: var(--space-6); }
.hero__logo { width: min(330px, 66vw); margin: 0 auto var(--space-3); }
.hero h1 { color: var(--color-bg); font-weight: 300; font-style: italic; max-width: 16ch; margin-inline: auto; }
.hero__sub { color: #BDB7AF; margin-top: var(--space-2); font-size: 15px; }
.hero__cta { margin-top: var(--space-4); display: flex; gap: var(--space-2); justify-content: center; flex-wrap: wrap; }
.hero__scroll { position: absolute; left: 50%; bottom: 26px; transform: translateX(-50%); z-index: 1;
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.2em; color: #8E887F;
  display: flex; flex-direction: column; align-items: center; gap: 10px; }
.hero__scroll i { width: 1px; height: 34px; background: linear-gradient(var(--color-gold), transparent); display: block; }

/* ===================== ПОЛОСА ДОВЕРИЯ ===================== */
.trust { background: var(--color-surface); border-bottom: var(--hair); }
.trust__row { display: grid; grid-template-columns: repeat(4, 1fr); }
.trust__item { display: flex; align-items: center; gap: 14px; padding: 28px var(--space-3); }
.trust__item + .trust__item { border-left: var(--hair); }
.trust__item svg { width: 26px; height: 26px; stroke: var(--color-gold); fill: none; flex: none; }
.trust__item span { font-size: 13px; color: var(--color-text); line-height: 1.35; }
@media (max-width: 880px){ .trust__row{ grid-template-columns:1fr 1fr; } .trust__item:nth-child(odd){border-left:none;} .trust__item:nth-child(n+3){border-top:var(--hair);} }
@media (max-width: 480px){ .trust__row{ grid-template-columns:1fr; } .trust__item{border-left:none!important;} .trust__item+.trust__item{border-top:var(--hair);} }

/* ===================== КАТЕГОРИИ / НАПРАВЛЕНИЯ ===================== */
.cat-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.cat { display: block; position: relative; }
.cat .card__media { aspect-ratio: 3/4; }
.cat .card__media::after { content:""; position:absolute; inset:0; background: linear-gradient(180deg, transparent 42%, rgba(20,18,16,0.72) 100%); }
.cat__cap { position: absolute; left:0; right:0; bottom:0; z-index:1; padding: var(--space-3); color: var(--color-bg); }
.cat__cap h3 { color: var(--color-bg); font-weight: 400; }
.cat__cap .from { font-size: 12px; letter-spacing: 0.06em; color: #D9D4CC; margin-top: 6px; }
@media (max-width:900px){ .cat-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:560px){ .cat-grid{ grid-template-columns:1fr; } }

/* ===================== О КОМПАНИИ (блок на главной) ===================== */
.about { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); align-items: center; }
.about__media { aspect-ratio: 5/4; border-radius: var(--radius); }
.about .caption { display: block; margin-bottom: var(--space-2); }
.about h2 { margin-bottom: var(--space-3); }
.about .stats { display: flex; gap: var(--space-4); margin-top: var(--space-4); flex-wrap: wrap; }
.about .stats b { font-family: var(--font-display); font-size: 40px; font-weight: 400; color: var(--color-text); display: block; line-height: 1; }
.about .stats span { font-size: 12px; color: var(--color-stone); text-transform: uppercase; letter-spacing: 0.1em; }
@media (max-width:820px){ .about{ grid-template-columns:1fr; gap:var(--space-3);} .about__media{order:-1;} }

/* ===================== ПРОЦЕСС ===================== */
.process { background: var(--color-surface); }
.process__track { display: grid; grid-template-columns: repeat(5,1fr); position: relative; gap: var(--space-2); }
.process__track::before { content:""; position:absolute; top:19px; left:10%; right:10%; height:1px; background: rgba(74,69,64,0.18); }
.step { text-align: center; position: relative; }
.step__dot { width: 40px; height: 40px; border-radius: 50%; margin: 0 auto var(--space-2);
  background: var(--color-bg); border: 1px solid var(--color-gold);
  display: flex; align-items: center; justify-content: center; position: relative; z-index: 1; }
.step__dot::after { content:""; width:6px; height:6px; border-radius:50%; background: var(--color-gold); }
.step h4 { font-family: var(--font-display); font-size: 21px; font-weight: 400; margin: 0 0 6px; color: var(--color-text); }
.step p { font-size: 13px; margin: 0; }
@media (max-width:760px){ .process__track{ grid-template-columns:1fr; gap:var(--space-3);} .process__track::before{display:none;}
  .step{display:grid; grid-template-columns:40px 1fr; gap:var(--space-2); text-align:left; align-items:start;} .step__dot{margin:0;} }

/* ===================== МАТЕРИАЛЫ (карточки) ===================== */
.mat-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: var(--space-3); max-width: 800px; margin: 0 auto; }
.mat .card__media { aspect-ratio: 16/10; }
.mat .card__body p { font-size: 14px; margin: 8px 0 0; }
@media (max-width:820px){ .mat-grid{ grid-template-columns:1fr; } }

/* ===================== ПОРТФОЛИО (сетка) ===================== */
.work-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-2); }
.work { aspect-ratio: 1; border-radius: var(--radius); overflow: hidden; position: relative; cursor: pointer; background: var(--color-placeholder); }
.work img { width:100%; height:100%; object-fit: cover; transition: transform var(--t-slow) var(--ease); }
.work:hover img { transform: scale(1.05); }
.work::after { content:""; position:absolute; inset:0; background: rgba(28,26,24,0); transition: background var(--t-base); }
.work:hover::after { background: rgba(28,26,24,0.12); }
@media (max-width:820px){ .work-grid{ grid-template-columns:1fr 1fr; } }

/* ===================== ФОРМА CTA ===================== */
.contact-cta { background: var(--color-surface); }
.contact-cta__inner { background: var(--color-white); border: var(--hair); border-radius: var(--radius); display: grid; grid-template-columns: 1fr 1fr; overflow: hidden; }
.contact-cta__text { padding: var(--space-5); }
.contact-cta__text h2 { margin-bottom: var(--space-2); }
.contact-cta__form { padding: var(--space-5); background: var(--color-surface); border-left: var(--hair); }
.contact-cta__note { font-size: 12px; color: var(--color-stone); margin-top: var(--space-2); }
@media (max-width:820px){ .contact-cta__inner{ grid-template-columns:1fr; } .contact-cta__form{ border-left:none; border-top:var(--hair);} }

/* ===================== КАТАЛОГ ===================== */
.catalog-layout { display: grid; grid-template-columns: 260px 1fr; gap: var(--space-5); align-items: start; }
.filters { position: sticky; top: 98px; }
.filters__group { padding-block: var(--space-3); border-bottom: var(--hair); }
.filters__group:first-child { padding-top: 0; }
.filters__group h4 { font-family: var(--font-body); font-size: 11px; font-weight: 500; text-transform: uppercase; letter-spacing: 0.14em; color: var(--color-stone); margin: 0 0 var(--space-2); }
.check { display: flex; align-items: center; gap: 10px; padding: 6px 0; font-size: 14px; color: var(--color-text-muted); cursor: pointer; }
.check input { appearance: none; width: 16px; height: 16px; border: 1px solid rgba(74,69,64,0.35); border-radius: 2px; display: grid; place-content: center; cursor: pointer; transition: var(--t-base); }
.check input::after { content:""; width:8px; height:8px; background: var(--color-gold); transform: scale(0); transition: transform var(--t-fast); }
.check input:checked { border-color: var(--color-gold); }
.check input:checked::after { transform: scale(1); }
.check:hover { color: var(--color-text); }
.range-row { display: flex; justify-content: space-between; font-size: 13px; color: var(--color-text-muted); margin-bottom: 8px; }
input[type=range] { width: 100%; accent-color: var(--color-gold); }
.filters__reset { margin-top: var(--space-3); font-size: 12px; color: var(--color-gold); background: none; border: none; padding: 0; text-transform: uppercase; letter-spacing: 0.1em; cursor: pointer; }

.catalog-toolbar { display: flex; justify-content: space-between; align-items: center; gap: var(--space-2); margin-bottom: var(--space-3); flex-wrap: wrap; }
.catalog-count { font-size: 13px; color: var(--color-stone); }
.sort select { font-family: var(--font-body); font-size: 13px; color: var(--color-text); padding: 10px 14px; background: var(--color-white); border: var(--hair); border-radius: var(--radius); cursor: pointer; }

.product-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-3); }
.product-grid .card__media { aspect-ratio: 4/5; }
.product-grid .card__body { display: flex; flex-direction: column; gap: 4px; }
.pcard__row { display: flex; justify-content: space-between; align-items: flex-end; margin-top: 10px; gap: 8px 12px; flex-wrap: wrap; }
.pcard__price { font-family: var(--font-display); font-size: 22px; color: var(--color-text); white-space: nowrap; }
.pcard__btn { font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; color: var(--color-accent); border-bottom: 1px solid var(--color-gold); padding-bottom: 3px; white-space: nowrap; transition: gap var(--t-base); }
@media (max-width:1100px){ .product-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:920px){ .catalog-layout{ grid-template-columns:1fr; } .filters{ position:static; } }
@media (max-width:560px){ .product-grid{ grid-template-columns:1fr; } }

.pagination { display: flex; gap: 6px; justify-content: center; margin-top: var(--space-5); }
.pagination a, .pagination .pag-btn { width: 40px; height: 40px; display: grid; place-content: center;
  font-size: 13px; border: var(--hair); border-radius: var(--radius); color: var(--color-text-muted);
  transition: var(--t-base); background:none; font-family:var(--font-body); cursor:pointer; padding:0; }
.pagination a[aria-current="page"], .pagination a:hover,
.pagination .pag-btn[aria-current="page"], .pagination .pag-btn:hover { border-color: var(--color-gold); color: var(--color-text); }
.pagination .pag-btn[aria-current="page"] { background:var(--color-dark); color:var(--color-bg); }

/* ===================== КАРТОЧКА ТОВАРА ===================== */
.product { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--space-5); align-items: start; }
.gallery__main { aspect-ratio: 4/5; border: var(--hair); border-radius: var(--radius); background: var(--color-placeholder); overflow: hidden; }
.gallery__main img { width:100%; height:100%; object-fit: cover; }
.gallery__thumbs { display: flex; gap: 10px; margin-top: 12px; }
.gallery__thumbs button { width: 72px; height: 88px; border: var(--hair); border-radius: var(--radius); overflow: hidden; padding: 0; background: var(--color-placeholder); cursor: pointer; opacity: 0.7; transition: var(--t-base); }
.gallery__thumbs button img { width:100%; height:100%; object-fit: cover; }
.gallery__thumbs button[aria-current="true"], .gallery__thumbs button:hover { opacity: 1; border-color: var(--color-gold); }
.product__info .caption { display: block; margin-bottom: var(--space-2); }
.product__info h1 { font-size: clamp(32px, 4vw, 46px); }
.product__art { font-size: 12px; color: var(--color-stone); text-transform: uppercase; letter-spacing: 0.1em; margin-top: 8px; }
.product__price { font-family: var(--font-display); font-size: 40px; color: var(--color-text); margin: var(--space-3) 0; }
.product__price span { font-size: 14px; color: var(--color-stone); font-family: var(--font-body); }
.spec-list { list-style: none; margin: 0 0 var(--space-3); padding: 0; display: grid; gap: 10px; }
.spec-list li { display: flex; justify-content: space-between; gap: 16px; font-size: 14px; border-bottom: 1px dashed rgba(74,69,64,0.18); padding-bottom: 10px; }
.spec-list li span:first-child { color: var(--color-stone); }
.includes { list-style: none; margin: var(--space-2) 0 var(--space-4); padding: 0; display: grid; gap: 10px; }
.includes li { display: flex; gap: 12px; font-size: 14px; color: var(--color-text-muted); }
.includes svg { width: 18px; height: 18px; stroke: var(--color-gold); fill: none; flex: none; margin-top: 2px; }
.product__actions { display: flex; gap: 12px; flex-wrap: wrap; }
.product__custom { margin-top: var(--space-4); padding: var(--space-3); background: var(--color-surface); border: var(--hair); border-radius: var(--radius); font-size: 14px; }
.product__custom a { color: var(--color-gold); border-bottom: 1px solid var(--color-gold); }
@media (max-width:820px){ .product{ grid-template-columns:1fr; gap:var(--space-4);} }

.tabs { display: flex; gap: var(--space-3); border-bottom: var(--hair); margin-bottom: var(--space-3); }
.tabs button { background: none; border: none; padding: 14px 0; font-family: var(--font-body); font-size: 13px; text-transform: uppercase; letter-spacing: 0.1em; color: var(--color-stone); border-bottom: 2px solid transparent; cursor: pointer; transition: var(--t-base); }
.tabs button[aria-selected="true"] { color: var(--color-text); border-bottom-color: var(--color-gold); }
.spec-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.spec-table td { padding: 12px 0; border-bottom: var(--hair); }
.spec-table td:first-child { color: var(--color-stone); width: 40%; }

/* ===================== УСЛУГИ ===================== */
.svc-list { display: grid; gap: var(--space-3); }
.svc { display: grid; grid-template-columns: 72px 1fr; gap: var(--space-3); align-items: center;
  padding: var(--space-4); background: var(--color-white); border: var(--hair); border-radius: var(--radius);
  border-left: 2px solid var(--color-gold); transition: var(--t-base); position: relative; overflow: hidden; }
.svc::after { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(181,152,106,.05), transparent 30%); opacity: 0; transition: var(--t-base); pointer-events: none; }
.svc:hover { box-shadow: var(--shadow-md); transform: translateY(-3px); border-left-color: var(--color-dark); }
.svc:hover::after { opacity: 1; }
.svc__icon { width: 64px; height: 64px; border-radius: 50%; background: var(--color-dark);
  display: grid; place-content: center; transition: var(--t-base); }
.svc:hover .svc__icon { background: var(--color-accent); }
.svc__icon svg { width: 28px; height: 28px; stroke: var(--color-gold-soft); fill: none; }
.svc__body h3 { font-size: 24px; }
.svc__body p { font-size: 14px; margin: 7px 0 0; max-width: 64ch; color: var(--color-text-muted); }
@media (max-width:680px){ .svc{ grid-template-columns:52px 1fr; gap:var(--space-2); padding:var(--space-3);} .svc__icon{width:52px;height:52px;} .svc__icon svg{width:24px;height:24px;} }

/* ===================== МАТЕРИАЛЫ (страница) ===================== */
.mat-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-5); align-items: center; padding-block: var(--space-5); border-bottom: var(--hair); }
.mat-row:nth-child(even) .mat-row__media { order: 2; }
.mat-row__media { aspect-ratio: 4/3; border-radius: var(--radius); }
.mat-row h2 { margin-bottom: var(--space-2); }
.mat-row .props { list-style: none; margin: var(--space-3) 0 0; padding: 0; display: grid; gap: 10px; }
.mat-row .props li { display: flex; gap: 12px; font-size: 14px; color: var(--color-text-muted); }
.mat-row .props svg { width: 18px; height: 18px; stroke: var(--color-gold); fill: none; flex: none; margin-top: 2px; }
@media (max-width:820px){ .mat-row{ grid-template-columns:1fr; gap:var(--space-3);} .mat-row:nth-child(even) .mat-row__media{ order:-1; } }

/* ===================== КОНТАКТЫ ===================== */
.contacts-grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: var(--space-5); align-items: start; }
.contact-block + .contact-block { margin-top: var(--space-4); }
.contact-block h3 { font-size: 22px; margin-bottom: 10px; }
.contact-block a, .contact-block p { font-size: 15px; color: var(--color-text-muted); margin: 4px 0; }
.contact-block a:hover { color: var(--color-gold); }
.hours-table { width: 100%; border-collapse: collapse; font-size: 14px; margin-top: 8px; }
.hours-table td { padding: 10px 0; border-bottom: var(--hair); }
.hours-table td:last-child { text-align: right; color: var(--color-text); }
.hours-table td:first-child { color: var(--color-stone); }
.map { width: 100%; aspect-ratio: 16/11; border: var(--hair); border-radius: var(--radius); overflow: hidden; background: var(--color-surface); }
.map iframe { width: 100%; height: 100%; border: 0; filter: grayscale(0.3) contrast(0.95); }
@media (max-width:820px){ .contacts-grid{ grid-template-columns:1fr; } }

/* ===================== FAQ ===================== */
.faq { max-width: 820px; margin: 0 auto; }
.acc { border-bottom: var(--hair); }
.acc__q { width: 100%; text-align: left; background: none; border: none; padding: var(--space-3) 0; display: flex; justify-content: space-between; align-items: center; gap: var(--space-2);
  font-family: var(--font-display); font-size: clamp(19px, 2.2vw, 24px); font-weight: 400; color: var(--color-text); cursor: pointer; }
.acc__q .ico { width: 22px; height: 22px; flex: none; position: relative; }
.acc__q .ico::before, .acc__q .ico::after { content:""; position:absolute; top:50%; left:50%; width:14px; height:1.5px; background: var(--color-gold); transform: translate(-50%,-50%); transition: var(--t-base); }
.acc__q .ico::after { transform: translate(-50%,-50%) rotate(90deg); }
.acc[open] .acc__q .ico::after { transform: translate(-50%,-50%) rotate(0); opacity: 0; }
.acc__a { overflow: hidden; max-height: 0; transition: max-height var(--t-base) var(--ease); }
.acc[open] .acc__a { max-height: 400px; }
.acc__a p { padding: 0 0 var(--space-3); max-width: 70ch; font-size: 15px; }

/* ===================== ВЕХИ / ИСТОРИЯ (о компании) ===================== */
.timeline { display: grid; gap: 0; max-width: 760px; margin: 0 auto; }
.tl { display: grid; grid-template-columns: 110px 1fr; gap: var(--space-3); padding-block: var(--space-3); border-bottom: var(--hair); }
.tl__year { font-family: var(--font-display); font-size: 30px; color: var(--color-gold); line-height: 1; }
.tl__body h3 { font-size: 21px; margin-bottom: 6px; }
.tl__body p { font-size: 14px; margin: 0; }
@media (max-width:560px){ .tl{ grid-template-columns:1fr; gap:6px; } }

.values-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: var(--space-3); }
.value { padding: var(--space-3); border: var(--hair); border-radius: var(--radius); background: var(--color-white); }
.value svg { width: 30px; height: 30px; stroke: var(--color-gold); fill: none; margin-bottom: var(--space-2); }
.value h3 { font-size: 22px; margin-bottom: 8px; }
.value p { font-size: 14px; margin: 0; }
@media (max-width:820px){ .values-grid{ grid-template-columns:1fr; } }

/* ===================== ЛАЙТБОКС ===================== */
.lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(20,18,16,0.92); display: none; align-items: center; justify-content: center; padding: var(--space-4); }
.lightbox.is-open { display: flex; }
.lightbox img { max-width: 92vw; max-height: 88vh; border-radius: var(--radius); box-shadow: var(--shadow-lg); }
.lightbox__close { position: absolute; top: 24px; right: 28px; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,0.3); background: none; color: #fff; border-radius: 50%; font-size: 20px; cursor: pointer; }

/* ===================== ПОЛЕЗНОЕ ===================== */
.lead { font-size: clamp(18px, 2.2vw, 22px); line-height: 1.6; color: var(--color-text); font-family: var(--font-display); font-weight: 300; max-width: 64ch; }
.prose p { max-width: 70ch; }
.center { text-align: center; }
.mt-4 { margin-top: var(--space-4); }

/* ===================== ФОРМА (премиальная, underline-стиль) ===================== */
.hform { width: 100%; }
.hform__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-4); }
@media (max-width:560px){ .hform__row{ grid-template-columns:1fr; gap:0; } }
.hform .field { margin-top: var(--space-4); }
.hform .field:first-child, .hform__row .field { margin-top: 0; }
@media (max-width:560px){ .hform__row .field + .field { margin-top: var(--space-4); } }

.field label, .field__label {
  display:block; font-size:10.5px; text-transform:uppercase; letter-spacing:.2em;
  color:var(--color-stone); margin-bottom:14px;
}
.field label i { color:var(--color-gold); font-style:normal; }

.hform input[type=text], .hform input[type=tel], .hform textarea {
  width:100%; font-family:var(--font-body); font-size:16px; font-weight:300; color:var(--color-text);
  background:transparent; border:0; border-bottom:1px solid rgba(74,69,64,.25); border-radius:0;
  padding:6px 0 12px; transition:border-color .4s var(--ease), box-shadow .4s var(--ease);
}
.hform textarea { resize:vertical; min-height:58px; line-height:1.65; }
.hform input::placeholder, .hform textarea::placeholder { color:rgba(74,69,64,.3); font-weight:300; }
.hform input:focus, .hform textarea:focus {
  outline:none; border-bottom-color:var(--color-gold); box-shadow:0 1px 0 0 var(--color-gold);
}
.hform input.is-invalid, .hform textarea.is-invalid { border-bottom-color:#b0695d; box-shadow:0 1px 0 0 #b0695d; }
.field__err { display:none; font-size:12px; color:#b0695d; margin-top:8px; letter-spacing:0; text-transform:none; }
.field__err.is-show { display:block; }

/* способ связи — деликатные капсулы с золотым акцентом */
.chips { display:flex; flex-wrap:wrap; gap:8px; }
.chip { position:relative; }
.chip input { position:absolute; opacity:0; inset:0; cursor:pointer; }
.chip span {
  display:block; padding:9px 18px; font-size:13px; letter-spacing:.02em; color:var(--color-text-muted);
  background:transparent; border:1px solid rgba(74,69,64,.2); border-radius:999px; cursor:pointer;
  transition:color .25s var(--ease), border-color .25s var(--ease), background .25s var(--ease);
}
.chip:hover span { border-color:rgba(181,152,106,.55); color:var(--color-text); }
.chip input:checked + span { color:var(--color-accent); border-color:var(--color-gold); background:rgba(181,152,106,.09); }
.chip input:focus-visible + span { box-shadow:0 0 0 3px rgba(181,152,106,.2); }

/* согласие */
.consent { display:flex; gap:11px; align-items:flex-start; margin-top:var(--space-4);
  font-size:12.5px; color:var(--color-stone); line-height:1.55; cursor:pointer; }
.consent input { appearance:none; width:17px; height:17px; flex:none; margin-top:1px;
  border:1px solid rgba(74,69,64,.3); border-radius:2px; display:grid; place-content:center; cursor:pointer; transition:var(--t-base); }
.consent input::after { content:""; width:9px; height:9px; background:var(--color-gold); transform:scale(0); transition:transform var(--t-fast); }
.consent input:checked { border-color:var(--color-gold); }
.consent input:checked::after { transform:scale(1); }
.consent.is-invalid input { border-color:#b0695d; }
.consent a { color:var(--color-accent); border-bottom:1px solid rgba(181,152,106,.4); }

.hform__submit { margin-top:var(--space-5); }
@media (max-width:560px){ .hform__submit{ width:100%; justify-content:center; } }
.contact-cta__note { font-size:12px; color:var(--color-stone); margin-top:var(--space-3); }

/* состояние «успех» */
.form-success { text-align:center; padding:var(--space-5) var(--space-2); }
.form-success__icon { width:60px; height:60px; border-radius:50%; margin:0 auto var(--space-3);
  display:grid; place-content:center; border:1px solid var(--color-gold); }
.form-success__icon svg { width:28px; height:28px; stroke:var(--color-gold); fill:none; }
.form-success h3 { font-size:28px; margin-bottom:10px; }
.form-success p { font-size:14px; color:var(--color-text-muted); margin:0 auto; max-width:38ch; line-height:1.65; }

/* перки рядом с CTA */
.cta-perks { list-style:none; margin:var(--space-4) 0 0; padding:0; display:grid; gap:16px; }
.cta-perks li { display:flex; gap:14px; align-items:center; font-size:14px; color:var(--color-text-muted); }
.cta-perks svg { width:20px; height:20px; stroke:var(--color-gold); fill:none; flex:none; }

/* мессенджеры на странице контактов */
.msg-links { display:flex; flex-wrap:wrap; gap:10px; }
.msg-link { display:inline-flex; align-items:center; gap:8px; padding:10px 16px; border:var(--hair);
  border-radius:999px; font-size:14px; color:var(--color-text-muted); transition:var(--t-base); }
.msg-link svg { width:17px; height:17px; stroke:var(--color-gold); fill:none; }
.msg-link:hover { border-color:var(--color-gold); color:var(--color-text); transform:translateY(-1px); }

/* панель формы под картой */
.form-panel { background:var(--color-white); border:var(--hair); border-top:none;
  border-radius:0 0 var(--radius) var(--radius); padding:var(--space-5); }
.form-panel__title { font-size:26px; margin-bottom:var(--space-4); }

/* ============================================================
   ДОРАБОТКИ — новые компоненты и UX-полировка
   ============================================================ */

/* ---- HERO: вторичный CTA, подпись, микро-доверие, появление ---- */
.hero__line { color:#CFC9C0; margin-top:var(--space-2); font-style:italic;
  font-family:var(--font-display); font-size:clamp(17px,2vw,21px); font-weight:300; }
.hero__trust { display:flex; flex-wrap:wrap; gap:10px 0; justify-content:center; align-items:center;
  margin-top:var(--space-3); font-size:12px; letter-spacing:.06em; color:#B6B0A7; }
.hero__trust span { padding:0 16px; position:relative; }
.hero__trust span + span::before { content:"◆"; position:absolute; left:-3px; top:50%;
  transform:translateY(-50%); font-size:5px; color:var(--color-gold); }
.btn--outline-light { border-color:rgba(255,255,255,.4); color:var(--color-bg); }
.btn--outline-light:hover { background:rgba(255,255,255,.1); border-color:rgba(255,255,255,.7); color:#fff; }
.hero__phone { font-family:var(--font-display); font-size:20px; letter-spacing:.04em; }

.fade-seq > * { opacity:0; transform:translateY(16px); }
.fade-seq.is-in > * { opacity:1; transform:none;
  transition:opacity .7s var(--ease), transform .7s var(--ease); }
.fade-seq.is-in > *:nth-child(1){transition-delay:.05s}
.fade-seq.is-in > *:nth-child(2){transition-delay:.15s}
.fade-seq.is-in > *:nth-child(3){transition-delay:.25s}
.fade-seq.is-in > *:nth-child(4){transition-delay:.35s}
.fade-seq.is-in > *:nth-child(5){transition-delay:.45s}
.fade-seq.is-in > *:nth-child(6){transition-delay:.55s}

/* ---- ОТЗЫВЫ (сдержанный редакционный стиль) ---- */
.reviews-band { background: var(--color-surface); }
.reviews-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-4) var(--space-3); }
@media (max-width:900px){ .reviews-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:620px){ .reviews-grid{ grid-template-columns:1fr; } }
.review { display:flex; flex-direction:column; gap:var(--space-2); padding:var(--space-3) var(--space-3) var(--space-3) 0;
  border-top:1px solid rgba(74,69,64,.16); }
.review__stars { display:flex; gap:4px; }
.review__stars svg { width:14px; height:14px; fill:var(--color-gold); stroke:none; opacity:.9; }
.review__text { font-family:var(--font-display); font-size:20px; font-weight:300; line-height:1.5;
  color:var(--color-text); margin:0; flex:1; font-style:italic; }
.review__meta { display:flex; flex-direction:column; gap:2px; margin-top:var(--space-2); }
.review__name { font-size:12px; letter-spacing:.14em; text-transform:uppercase; color:var(--color-accent); }
.review__loc { font-size:13px; color:var(--color-stone); }

/* ---- ДОКУМЕНТЫ / ГАРАНТИИ ---- */
.docs-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:var(--space-3); }
@media (max-width:860px){ .docs-grid{ grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .docs-grid{ grid-template-columns:1fr; } }
.doc { display:flex; flex-direction:column; gap:14px; padding:var(--space-3);
  background:var(--color-white); border:var(--hair); border-radius:var(--radius); cursor:pointer;
  text-align:left; transition:transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease); }
.doc:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.doc__ico { width:46px; height:46px; border-radius:50%; background:var(--color-surface);
  display:grid; place-content:center; }
.doc__ico svg { width:22px; height:22px; stroke:var(--color-gold); fill:none; }
.doc h3 { font-size:19px; }
.doc p { font-size:13px; margin:0; }
.doc__view { font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--color-accent);
  margin-top:auto; display:inline-flex; align-items:center; gap:6px; }

/* ---- СЧЁТЧИК (count-up) ---- */
.about .stats b[data-count]{ font-variant-numeric:tabular-nums; }

/* ---- КАТАЛОГ: активные фильтры ---- */
.active-filters { display:flex; flex-wrap:wrap; gap:8px; align-items:center; margin-bottom:var(--space-3); }
.active-filters:empty { display:none; }
.afilter { display:inline-flex; align-items:center; gap:8px; padding:7px 8px 7px 14px;
  font-size:12.5px; color:var(--color-accent); background:rgba(181,152,106,.09);
  border:1px solid var(--color-gold); border-radius:999px; }
.afilter button { background:none; border:none; width:18px; height:18px; border-radius:50%;
  display:grid; place-content:center; color:var(--color-accent); font-size:15px; line-height:1; cursor:pointer; }
.afilter button:hover { background:rgba(181,152,106,.2); }
.afilter--clear { color:var(--color-gold); background:none; border:none; cursor:pointer;
  font-size:12px; text-transform:uppercase; letter-spacing:.1em; padding:0 6px; }

/* ---- КАТАЛОГ: двойной ползунок цены ---- */
.range-dual { position:relative; height:30px; margin-top:6px; }
.range-dual input[type=range]{ position:absolute; top:0; left:0; width:100%; margin:0;
  -webkit-appearance:none; appearance:none; background:none; pointer-events:none; height:30px; }
.range-dual input[type=range]::-webkit-slider-thumb{ -webkit-appearance:none; pointer-events:auto;
  width:16px; height:16px; border-radius:50%; background:var(--color-white); border:1px solid var(--color-gold);
  box-shadow:var(--shadow-sm); cursor:pointer; margin-top:-7px; }
.range-dual input[type=range]::-moz-range-thumb{ pointer-events:auto; width:16px; height:16px; border-radius:50%;
  background:var(--color-white); border:1px solid var(--color-gold); cursor:pointer; }
.range-dual .track { position:absolute; top:14px; left:0; right:0; height:2px; background:rgba(74,69,64,.18); border-radius:2px; }
.range-dual .track-fill { position:absolute; top:14px; height:2px; background:var(--color-gold); border-radius:2px; }

/* ---- КАТАЛОГ: скелетон загрузки ---- */
.skel { border:var(--hair); border-radius:var(--radius); overflow:hidden; background:var(--color-white); }
.skel__media { aspect-ratio:4/5; background:linear-gradient(100deg,#eceae6 30%,#f4f2ef 50%,#eceae6 70%);
  background-size:200% 100%; animation:shimmer 1.2s infinite; }
.skel__body { padding:var(--space-3); display:grid; gap:10px; }
.skel__line { height:12px; border-radius:3px; background:linear-gradient(100deg,#eceae6 30%,#f4f2ef 50%,#eceae6 70%);
  background-size:200% 100%; animation:shimmer 1.2s infinite; }
.skel__line.w60{ width:60%; } .skel__line.w40{ width:40%; } .skel__line.w80{ width:80%; }
@keyframes shimmer { from{background-position:200% 0} to{background-position:-200% 0} }

/* ---- КАРТОЧКА: кнопка быстрого просмотра ---- */
.card { position:relative; }
.qv-btn { position:absolute; top:12px; right:12px; z-index:2; width:38px; height:38px; border-radius:50%;
  background:rgba(245,243,240,.92); border:1px solid rgba(74,69,64,.15); display:grid; place-content:center;
  opacity:0; transform:translateY(-4px); transition:var(--t-base); cursor:pointer; }
.card:hover .qv-btn, .qv-btn:focus-visible { opacity:1; transform:none; }
.qv-btn svg { width:18px; height:18px; stroke:var(--color-accent); fill:none; }
.qv-btn:hover { background:#fff; border-color:var(--color-gold); }

/* ---- БЫСТРЫЙ ПРОСМОТР (модалка) ---- */
.qv { position:fixed; inset:0; z-index:120; background:rgba(20,18,16,.6); backdrop-filter:blur(3px);
  display:none; align-items:center; justify-content:center; padding:var(--space-3); }
.qv.is-open { display:flex; }
.qv__card { background:var(--color-bg); border-radius:var(--radius); max-width:840px; width:100%;
  display:grid; grid-template-columns:1fr 1fr; overflow:hidden; box-shadow:var(--shadow-lg);
  max-height:90vh; }
.qv__media { background:var(--color-placeholder); }
.qv__media img { width:100%; height:100%; object-fit:cover; }
.qv__body { padding:var(--space-4); overflow:auto; }
.qv__close { position:absolute; top:18px; right:20px; width:42px; height:42px; border-radius:50%;
  border:1px solid rgba(255,255,255,.3); background:rgba(20,18,16,.4); color:#fff; font-size:20px; cursor:pointer; }
.qv__body h3 { font-size:30px; margin-bottom:6px; }
.qv__body .pmeta { font-size:13px; color:var(--color-stone); margin-bottom:var(--space-2); }
.qv__body .pprice { font-family:var(--font-display); font-size:30px; color:var(--color-text); margin:var(--space-2) 0; }
.qv__specs { list-style:none; margin:0 0 var(--space-3); padding:0; display:grid; gap:8px; font-size:14px; }
.qv__specs li { display:flex; justify-content:space-between; gap:14px; border-bottom:1px dashed rgba(74,69,64,.18); padding-bottom:7px; }
.qv__specs li span:first-child{ color:var(--color-stone); }
@media (max-width:680px){ .qv__card{ grid-template-columns:1fr; } .qv__media{ aspect-ratio:4/3; } }

/* ---- ПОРТФОЛИО: подпись поверх ---- */
.work__cap { position:absolute; left:0; right:0; bottom:0; z-index:1; padding:16px;
  background:linear-gradient(transparent, rgba(20,18,16,.82)); color:var(--color-bg);
  opacity:0; transform:translateY(8px); transition:var(--t-base); }
.work:hover .work__cap, .work:focus-visible .work__cap { opacity:1; transform:none; }
.work__cap b { display:block; font-family:var(--font-display); font-size:18px; font-weight:400; }
.work__cap span { font-size:12px; color:#D9D4CC; letter-spacing:.04em; }
.work { outline-offset:2px; }

/* ---- ЛАЙТБОКС: счётчик и стрелки ---- */
.lightbox__counter { position:absolute; top:28px; left:0; right:0; text-align:center; color:#C7C2BB;
  font-size:13px; letter-spacing:.1em; }
.lightbox__nav { position:absolute; top:50%; transform:translateY(-50%); width:52px; height:52px;
  border-radius:50%; border:1px solid rgba(255,255,255,.25); background:rgba(20,18,16,.35); color:#fff;
  font-size:22px; cursor:pointer; display:grid; place-content:center; transition:var(--t-base); }
.lightbox__nav:hover { background:rgba(20,18,16,.7); border-color:var(--color-gold); }
.lightbox__nav--prev { left:24px; } .lightbox__nav--next { right:24px; }
.lightbox__figure { display:flex; flex-direction:column; align-items:center; gap:14px; max-width:92vw; }
.lightbox__cap { color:#C7C2BB; font-size:13px; text-align:center; max-width:60ch; }
@media (max-width:560px){ .lightbox__nav{ width:44px; height:44px; } .lightbox__nav--prev{left:8px} .lightbox__nav--next{right:8px} }

/* ---- КАЛЬКУЛЯТОР СТОИМОСТИ (карточка товара) ---- */
.calc { margin-top:var(--space-4); padding:var(--space-4); background:var(--color-surface);
  border:var(--hair); border-radius:var(--radius); }
.calc__head { display:flex; align-items:center; gap:10px; margin-bottom:var(--space-3); }
.calc__head svg { width:20px; height:20px; stroke:var(--color-gold); fill:none; }
.calc__head h3 { font-size:22px; }
.calc__row { display:grid; grid-template-columns:1fr auto; gap:14px; align-items:center;
  padding:12px 0; border-bottom:var(--hair); }
.calc__row > label { font-size:14px; color:var(--color-text-muted); }
.calc select, .calc__check { font-family:var(--font-body); }
.calc select { font-size:14px; color:var(--color-text); padding:9px 12px; background:var(--color-white);
  border:var(--hair); border-radius:var(--radius); cursor:pointer; min-width:170px; }
.calc__toggle { display:inline-flex; align-items:center; gap:10px; cursor:pointer; font-size:14px; color:var(--color-text-muted); }
.calc__toggle input { appearance:none; width:42px; height:24px; border-radius:999px; background:rgba(74,69,64,.2);
  position:relative; cursor:pointer; transition:var(--t-base); flex:none; }
.calc__toggle input::after { content:""; position:absolute; top:3px; left:3px; width:18px; height:18px;
  border-radius:50%; background:#fff; transition:var(--t-base); box-shadow:var(--shadow-sm); }
.calc__toggle input:checked { background:var(--color-gold); }
.calc__toggle input:checked::after { left:21px; }
.calc__total { display:flex; justify-content:space-between; align-items:baseline; margin-top:var(--space-3); }
.calc__total span { font-size:13px; color:var(--color-stone); text-transform:uppercase; letter-spacing:.1em; }
.calc__total b { font-family:var(--font-display); font-size:38px; font-weight:500; color:var(--color-text); }
.calc__note { font-size:12px; color:var(--color-stone); margin-top:10px; }
@media (max-width:480px){ .calc__row{ grid-template-columns:1fr; gap:8px; } .calc select{ width:100%; } }

/* ---- КНОПКА «НАВЕРХ» ---- */
.to-top { position:fixed; right:24px; bottom:24px; z-index:60; width:48px; height:48px; border-radius:50%;
  background:var(--color-dark); color:var(--color-bg); border:1px solid rgba(181,152,106,.4);
  display:grid; place-content:center; cursor:pointer; opacity:0; transform:translateY(12px) scale(.9);
  pointer-events:none; transition:var(--t-base) var(--ease); box-shadow:var(--shadow-md); }
.to-top.is-show { opacity:1; transform:none; pointer-events:auto; }
.to-top:hover { background:var(--color-accent); border-color:var(--color-gold); }
.to-top svg { width:20px; height:20px; stroke:var(--color-gold-soft); fill:none; }
@media (max-width:560px){ .to-top{ right:16px; bottom:16px; } }

/* ---- aria-live статус формы ---- */
.form-status { position:absolute; width:1px; height:1px; overflow:hidden; clip:rect(0 0 0 0); }
.form-success__again { margin-top:var(--space-3); font-size:12px; text-transform:uppercase; letter-spacing:.12em;
  color:var(--color-gold); background:none; border:none; cursor:pointer; border-bottom:1px solid var(--color-gold); padding-bottom:3px; }

/* reduced-motion для новых анимаций */
@media (prefers-reduced-motion: reduce){
  .fade-seq > *{ opacity:1 !important; transform:none !important; }
  .skel__media, .skel__line{ animation:none !important; }
}

/* подгруппа фильтров (Оформления) */
.filters__sub { margin-top:10px; padding-top:10px; padding-left:12px; border-top:1px dashed rgba(74,69,64,.18); border-left:2px solid rgba(181,152,106,.4); }
.filters__sublabel { display:block; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:var(--color-stone); margin-bottom:8px; }

/* галерея на странице услуг */
.svc-gallery { display:grid; grid-template-columns:repeat(3,1fr); gap:var(--space-3); }
@media (max-width:760px){ .svc-gallery{ grid-template-columns:1fr 1fr; } }
@media (max-width:460px){ .svc-gallery{ grid-template-columns:1fr; } }
.svc-shot { position:relative; aspect-ratio:4/3; overflow:hidden; border-radius:var(--radius); cursor:pointer; background:var(--color-placeholder); }
.svc-shot img { width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease); }
.svc-shot:hover img { transform:scale(1.04); }
.svc-shot__cap { position:absolute; left:0; right:0; bottom:0; padding:14px 16px; color:var(--color-bg);
  font-size:13px; letter-spacing:.04em; background:linear-gradient(transparent,rgba(20,18,16,.8)); }

/* ---- HERO: две большие плитки-кнопки ---- */
.hero__tiles { display:grid; grid-template-columns:1fr 1fr; gap:var(--space-3); max-width:760px; margin:var(--space-4) auto 0; width:100%; }
@media (max-width:560px){ .hero__tiles{ grid-template-columns:1fr; } }
.hero-tile { position:relative; display:flex; flex-direction:column; justify-content:flex-end;
  min-height:260px; padding:24px; border-radius:var(--radius); overflow:hidden; isolation:isolate;
  border:1px solid rgba(255,255,255,.16); color:var(--color-bg); text-align:left;
  background-size:cover; background-position:center;
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease); }
.hero-tile::after { content:""; position:absolute; inset:0; z-index:-1;
  background:linear-gradient(180deg, rgba(20,18,16,0) 0%, rgba(20,18,16,.08) 50%, rgba(20,18,16,.66) 100%); }
.hero-tile:hover { transform:translateY(-4px); border-color:var(--color-gold); }
.hero-tile__k { font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--color-gold-soft); margin-bottom:6px; }
.hero-tile__t { font-family:var(--font-display); font-size:30px; line-height:1.1; color:#fff; }
.hero-tile__go { margin-top:12px; font-size:12.5px; letter-spacing:.04em; color:#E7E2D9; display:inline-flex; align-items:center; gap:8px; }
.hero-tile__go .arrow { transition:transform var(--t-base) var(--ease); }
.hero-tile:hover .hero-tile__go .arrow { transform:translateX(4px); }
.hero__cta--single { margin-top:var(--space-3); }

/* ---- пагинация (button вместо a) ---- */
.pag-btn { background:none; border:var(--hair); border-radius:var(--radius);
  padding:8px 14px; font-family:var(--font-body); font-size:14px; color:var(--color-accent);
  cursor:pointer; transition:var(--t-base); }
.pag-btn:hover { background:var(--color-surface); border-color:var(--color-gold); }
.pag-btn[aria-current="page"] { background:var(--color-dark); color:var(--color-bg); border-color:var(--color-dark); }

/* ---- МОДАЛКА ЗАКАЗА ---- */
.order-modal { position:fixed; inset:0; z-index:120; display:none; align-items:flex-start; justify-content:center;
  padding:max(20px,5vh) 16px; background:rgba(20,18,16,.66); backdrop-filter:blur(3px); overflow-y:auto; }
.order-modal.is-open { display:flex; animation:omFade .25s var(--ease); }
@keyframes omFade { from{opacity:0} to{opacity:1} }
.order-modal__card { position:relative; width:100%; max-width:560px; background:var(--color-bg);
  border:1px solid var(--color-line); border-radius:var(--radius); padding:var(--space-5) var(--space-4) var(--space-4);
  box-shadow:0 30px 80px rgba(0,0,0,.4); margin:auto; }
.order-modal__close { position:absolute; top:12px; right:14px; width:36px; height:36px; border:none; background:none;
  font-size:26px; line-height:1; color:var(--color-stone); cursor:pointer; border-radius:50%; transition:var(--t-base); }
.order-modal__close:hover { background:var(--color-surface); color:var(--color-text); }
.order-modal__head { margin-bottom:var(--space-3); }
.order-modal__head h3 { font-size:26px; margin:4px 0 0; }
.order-modal__prod { margin:10px 0 0; padding:10px 14px; background:var(--color-surface); border-left:2px solid var(--color-gold);
  border-radius:2px; font-size:14px; color:var(--color-accent); }
.checks { display:flex; flex-direction:column; gap:8px; }
.checkbox { display:flex; align-items:center; gap:10px; cursor:pointer; font-size:14px; color:var(--color-text); }
.checkbox input { width:18px; height:18px; accent-color:var(--color-gold); flex:none; cursor:pointer; }
.field textarea { width:100%; padding:12px 14px; border:var(--hair); border-radius:var(--radius); background:var(--color-bg);
  font-family:var(--font-body); font-size:15px; color:var(--color-text); resize:vertical; min-height:70px; transition:var(--t-base); }
.field textarea:focus { outline:none; border-color:var(--color-gold); }
.form-errnote { margin:10px 0 0; font-size:13px; color:#9a3b34; }
body.no-scroll { overflow:hidden; }
@media (max-width:560px){ .order-modal__card{ padding:var(--space-4) var(--space-3) var(--space-3);} .order-modal__head h3{font-size:22px;} }
