/* ============================================================
   ZÉFIR — студия косметологии. Перенос дизайна Claude Design.
   ============================================================ */

:root {
	--z-bg: #C6B2EE;
	--z-purple: #8B4DEE;
	--z-purple-2: #B07BF5;
	--z-ink: #34215C;
	--z-ink-2: #4A357A;
	--z-ink-3: #5B3FA0;
	--z-ink-4: #6B5A93;
	--z-muted: #9788BC;
	--z-lime: #C7EA46;
	--z-pink: #FF82C2;
	--z-berry: #E94B7B;
	--z-soft: #F2ECFF;
	--font-display: 'Unbounded', sans-serif;
	--font-body: 'Golos Text', sans-serif;
	--wrap: 1240px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
	margin: 0;
	background: var(--z-bg);
	font-family: var(--font-body);
	color: var(--z-ink);
	-webkit-font-smoothing: antialiased;
	overflow-x: hidden;
}

::selection { background: var(--z-lime); color: var(--z-ink); }

img { max-width: 100%; display: block; }
a { color: inherit; }

/* ---------- Keyframes ---------- */
@keyframes pageIn { from { opacity: 0; transform: translateY(14px); } to { opacity: 1; transform: none; } }
@keyframes floatY { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-18px); } }
@keyframes floatY2 { 0%,100% { transform: translateY(0); } 50% { transform: translateY(14px); } }
@keyframes rise { from { opacity: 0; transform: translateY(28px); } to { opacity: 1; transform: none; } }
@keyframes pop { from { opacity: 0; transform: scale(.92); } to { opacity: 1; transform: none; } }
@keyframes toastIn { from { opacity: 0; transform: translate(-50%, 24px); } to { opacity: 1; transform: translate(-50%, 0); } }

.zefir-float { animation: floatY 6s ease-in-out infinite; }

/* ---------- Layout ---------- */
.zefir-page { position: relative; min-height: 100vh; }

.zefir-blobs { position: fixed; inset: 0; pointer-events: none; z-index: 0; overflow: hidden; }
.zefir-blob { position: absolute; display: block; }
.zefir-blob--1 { top: -8%; left: -6%; width: 480px; height: 480px; background: radial-gradient(circle at 40% 40%, #fff, rgba(255,255,255,0)); filter: blur(8px); border-radius: 60% 40% 55% 45%; opacity: .55; }
.zefir-blob--2 { bottom: 4%; right: -8%; width: 560px; height: 560px; background: radial-gradient(circle at 60% 40%, #fff, rgba(255,255,255,0)); filter: blur(10px); border-radius: 45% 55% 40% 60%; opacity: .5; }
.zefir-blob--3 { top: 38%; left: 42%; width: 360px; height: 360px; background: radial-gradient(circle, rgba(199,234,70,.45), rgba(199,234,70,0)); filter: blur(20px); border-radius: 50%; opacity: .6; }

.zefir-main { position: relative; z-index: 1; }
.zefir-section { max-width: var(--wrap); margin: 0 auto; padding: 50px 24px; }

.zefir-section__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 36px; }
.zefir-section__head--center { text-align: center; flex-direction: column; align-items: center; margin-bottom: 40px; }

.zefir-grid { display: grid; gap: 20px; }
.zefir-grid--3 { grid-template-columns: repeat(3, 1fr); }
.zefir-grid--4 { grid-template-columns: repeat(4, 1fr); }

.zefir-ph { background: linear-gradient(135deg, #E8DEFB, #F2ECFF); }

/* ---------- Typography bits ---------- */
.zefir-eyebrow { font-weight: 700; font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase; }
.zefir-eyebrow--purple { color: var(--z-purple); }
.zefir-eyebrow--lime { color: var(--z-lime); }

.zefir-h2 { font-family: var(--font-display); font-weight: 700; font-size: clamp(30px, 3.4vw, 46px); line-height: 1.05; letter-spacing: -1.5px; margin: 12px 0 0; color: var(--z-ink); }

.zefir-grad { background: linear-gradient(120deg, var(--z-purple), var(--z-pink)); -webkit-background-clip: text; background-clip: text; color: transparent; }

.zefir-badge { display: inline-flex; align-items: center; gap: 8px; padding: 9px 18px; background: rgba(255,255,255,.6); border: 1px solid rgba(255,255,255,.8); border-radius: 999px; font-weight: 600; font-size: 14px; color: var(--z-ink-3); }

.zefir-tags { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 26px; }
.zefir-tag { padding: 10px 18px; background: var(--z-soft); border-radius: 999px; font-weight: 600; font-size: 15px; color: var(--z-ink-3); }

/* ---------- Buttons ---------- */
.zefir-btn { font-family: var(--font-body); font-weight: 700; font-size: 15px; border: none; cursor: pointer; padding: 15px 30px; border-radius: 999px; transition: transform .2s, box-shadow .2s, background .2s, color .2s; text-decoration: none; display: inline-flex; align-items: center; justify-content: center; line-height: 1; }
.zefir-btn--sm { padding: 12px 24px; }
.zefir-btn--lg { font-size: 17px; padding: 17px 36px; }
.zefir-btn--pill { padding: 13px 26px; font-size: 16px; }
.zefir-btn--block { width: 100%; padding: 17px; font-size: 17px; border-radius: 14px; }

.zefir-btn--primary { color: #fff; background: linear-gradient(135deg, var(--z-purple), var(--z-purple-2)); box-shadow: 0 10px 24px rgba(139,77,238,.45); }
.zefir-btn--primary:hover { transform: translateY(-2px); box-shadow: 0 16px 30px rgba(139,77,238,.55); }
.zefir-btn--white { color: var(--z-ink); background: #fff; box-shadow: 0 14px 30px rgba(74,45,122,.14); }
.zefir-btn--white:hover { transform: translateY(-2px); }
.zefir-btn--dark { color: #fff; background: var(--z-ink); box-shadow: 0 16px 36px rgba(52,33,92,.3); }
.zefir-btn--dark:hover { transform: translateY(-2px); }
.zefir-btn--ghostwhite { align-self: flex-start; background: rgba(255,255,255,.95); color: var(--z-ink); padding: 12px 24px; }
.zefir-btn--ghostwhite:hover { transform: translateY(-2px); }

/* ---------- Navigation ---------- */
.zefir-nav { position: fixed; top: 18px; left: 50%; transform: translateX(-50%); z-index: 60; width: min(1240px, calc(100% - 32px)); display: flex; align-items: center; justify-content: space-between; gap: 20px; padding: 12px 14px 12px 26px; background: rgba(255,255,255,.72); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border: 1px solid rgba(255,255,255,.7); border-radius: 999px; box-shadow: 0 14px 40px rgba(74,45,122,.16); }
.zefir-nav__brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.zefir-nav__dot { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--z-purple), var(--z-lime)); box-shadow: 0 4px 12px rgba(139,77,238,.4); }
.zefir-nav__name { font-family: var(--font-display); font-weight: 800; font-size: 22px; letter-spacing: -.5px; color: var(--z-ink); }
.zefir-nav__links { display: flex; align-items: center; gap: 6px; }
.zefir-nav__link { font-size: 15px; font-weight: 600; color: var(--z-ink-2); padding: 9px 15px; border-radius: 999px; text-decoration: none; transition: background .2s, color .2s; }
.zefir-nav__link:hover { background: rgba(139,77,238,.12); color: var(--z-ink); }
.zefir-nav__cta { display: flex; align-items: center; gap: 14px; }
.zefir-nav__burger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 8px; }
.zefir-nav__burger span { width: 22px; height: 2px; background: var(--z-ink); border-radius: 2px; transition: transform .2s, opacity .2s; }

/* ---------- Hero (editorial split) ---------- */
.zefir-hero { position: relative; padding: 150px 24px 60px; max-width: var(--wrap); margin: 0 auto; display: grid; grid-template-columns: 1.05fr .95fr; gap: 50px; align-items: center; animation: pageIn .5s ease both; }
.zefir-hero__title { font-family: var(--font-display); font-weight: 800; font-size: clamp(46px, 6vw, 92px); line-height: .98; letter-spacing: -2.5px; margin: 22px 0 0; color: var(--z-ink); }
.zefir-hero__text { max-width: 460px; margin: 22px 0 0; font-size: 19px; line-height: 1.55; color: var(--z-ink-2); font-weight: 500; }
.zefir-hero__actions { display: flex; gap: 14px; flex-wrap: wrap; margin-top: 30px; }
.zefir-hero__stats { display: flex; gap: 36px; margin-top: 40px; flex-wrap: wrap; }
.zefir-hero__statnum { font-family: var(--font-display); font-weight: 700; font-size: 34px; color: var(--z-ink); }
.zefir-hero__statlabel { font-size: 14px; color: var(--z-ink-4); font-weight: 600; }
.zefir-hero__media { position: relative; }
.zefir-hero__glow { position: absolute; inset: -30px; background: radial-gradient(circle at 50% 40%, #fff, rgba(255,255,255,0) 70%); filter: blur(6px); }
.zefir-hero__img { position: relative; width: 100%; height: 560px; object-fit: cover; border-radius: 120px 120px 24px 24px; }
.zefir-hero__chip { position: absolute; bottom: 28px; left: -18px; padding: 16px 20px; background: #fff; border-radius: 20px; box-shadow: 0 18px 40px rgba(74,45,122,.22); display: flex; align-items: center; gap: 12px; }
.zefir-hero__chipico { width: 42px; height: 42px; border-radius: 50%; background: var(--z-lime); display: flex; align-items: center; justify-content: center; font-size: 20px; }
.zefir-hero__chiptitle { font-weight: 800; font-size: 15px; color: var(--z-ink); }
.zefir-hero__chipsub { font-size: 13px; color: var(--z-ink-4); }

/* ---------- About / stats ---------- */
.zefir-about__card { background: #fff; border-radius: 36px; padding: 50px; box-shadow: 0 24px 60px rgba(74,45,122,.16); display: grid; grid-template-columns: 1fr 1fr; gap: 50px; align-items: center; }
.zefir-about__text { font-size: 18px; line-height: 1.6; color: var(--z-ink-2); margin: 20px 0 0; max-width: 480px; }
.zefir-about__stats { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.zefir-statcard { background: linear-gradient(160deg, #F7F2FF, #FBF8FF); border: 1px solid #EFE7FF; border-radius: 24px; padding: 26px; }
.zefir-statcard__num { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 3vw, 44px); color: var(--z-purple); line-height: 1; }
.zefir-statcard__label { font-size: 15px; font-weight: 600; color: var(--z-ink-4); margin-top: 8px; }

/* ---------- Service cards ---------- */
.zefir-service { background: #fff; border-radius: 28px; padding: 28px; box-shadow: 0 16px 40px rgba(74,45,122,.12); display: flex; flex-direction: column; gap: 14px; transition: transform .2s; }
.zefir-service:hover { transform: translateY(-6px); }
.zefir-service__top { display: flex; align-items: center; justify-content: space-between; }
.zefir-service__icon { width: 46px; height: 46px; border-radius: 14px; display: inline-block; }
.zefir-service__cat { font-size: 13px; font-weight: 700; color: #fff; background: var(--z-ink); padding: 6px 12px; border-radius: 999px; }
.zefir-service__name { font-weight: 700; font-size: 21px; color: var(--z-ink); margin: 6px 0 0; line-height: 1.2; }
.zefir-service__desc { font-size: 15px; line-height: 1.5; color: var(--z-ink-4); margin: 0; flex: 1; }
.zefir-service__foot { display: flex; align-items: center; justify-content: space-between; padding-top: 8px; border-top: 1px solid #F0EAFB; }
.zefir-service__price { font-family: var(--font-display); font-weight: 700; font-size: 22px; color: var(--z-ink); }
.zefir-service__dur { font-size: 14px; color: var(--z-muted); font-weight: 600; margin-left: 8px; }
.zefir-service__go { background: var(--z-soft); border: none; cursor: pointer; width: 42px; height: 42px; border-radius: 50%; font-size: 20px; color: var(--z-purple); font-weight: 700; transition: background .2s, color .2s; }
.zefir-service__go:hover { background: var(--z-purple); color: #fff; }

/* ---------- Masters ---------- */
.zefir-master { background: #fff; border-radius: 28px; padding: 16px 16px 24px; box-shadow: 0 16px 40px rgba(74,45,122,.12); transition: transform .2s; }
.zefir-master:hover { transform: translateY(-6px); }
.zefir-master__media { position: relative; border-radius: 22px; overflow: hidden; }
.zefir-master__img { width: 100%; height: 240px; object-fit: cover; }
.zefir-master__exp { position: absolute; top: 12px; left: 12px; padding: 7px 13px; border-radius: 999px; font-size: 13px; font-weight: 700; color: #fff; }
.zefir-master__name { font-weight: 700; font-size: 20px; color: var(--z-ink); margin: 18px 0 4px; }
.zefir-master__role { font-size: 14px; color: var(--z-ink-4); margin: 0; font-weight: 600; }

/* ---------- Promos ---------- */
.zefir-promo { border-radius: 28px; padding: 32px; min-height: 240px; display: flex; flex-direction: column; justify-content: space-between; box-shadow: 0 18px 44px rgba(74,45,122,.2); position: relative; overflow: hidden; gap: 14px; }
.zefir-promo__tag { align-self: flex-start; padding: 7px 14px; background: rgba(255,255,255,.28); border-radius: 999px; font-size: 13px; font-weight: 700; }
.zefir-promo__title { font-family: var(--font-display); font-weight: 700; font-size: 28px; margin: 0 0 10px; letter-spacing: -.5px; }
.zefir-promo__desc { font-size: 16px; line-height: 1.45; margin: 0; opacity: .92; }

/* ---------- Gallery ---------- */
.zefir-gallery { display: grid; grid-template-columns: repeat(4, 1fr); grid-auto-rows: 200px; gap: 16px; }
.zefir-gallery__tile { border-radius: 26px; overflow: hidden; }
.zefir-gallery__tile--tall { grid-row: span 2; }
.zefir-gallery__tile--wide { grid-column: span 2; }
.zefir-gallery__img { width: 100%; height: 100%; object-fit: cover; }

/* ---------- Reviews ---------- */
.zefir-review { background: #fff; border-radius: 26px; padding: 26px; box-shadow: 0 16px 40px rgba(74,45,122,.12); display: flex; flex-direction: column; gap: 16px; }
.zefir-review__stars { color: #FFB800; font-size: 17px; letter-spacing: 2px; }
.zefir-review__text { font-size: 15px; line-height: 1.55; color: var(--z-ink-2); margin: 0; flex: 1; }
.zefir-review__author { display: flex; align-items: center; gap: 12px; }
.zefir-review__avatar { width: 44px; height: 44px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #fff; font-weight: 800; font-size: 17px; flex-shrink: 0; }
.zefir-review__name { font-weight: 700; font-size: 15px; color: var(--z-ink); }
.zefir-review__age { font-size: 13px; color: var(--z-muted); }

/* ---------- Contacts ---------- */
.zefir-contacts { padding-bottom: 90px; }
.zefir-contacts__card { background: linear-gradient(150deg, #34215C, #5B3FA0); border-radius: 40px; padding: 56px; display: grid; grid-template-columns: 1fr 1fr; gap: 50px; box-shadow: 0 30px 70px rgba(52,33,92,.35); position: relative; overflow: hidden; }
.zefir-contacts__glow { position: absolute; top: -60px; right: -40px; width: 280px; height: 280px; background: radial-gradient(circle, rgba(199,234,70,.4), transparent 70%); filter: blur(10px); }
.zefir-contacts__info { position: relative; }
.zefir-contacts__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(32px, 3.6vw, 50px); letter-spacing: -1.5px; margin: 14px 0 0; color: #fff; line-height: 1.02; }
.zefir-contacts__text { font-size: 17px; line-height: 1.6; color: rgba(255,255,255,.8); margin: 20px 0 30px; max-width: 380px; }
.zefir-contacts__rows { display: flex; flex-direction: column; gap: 16px; }
.zefir-contacts__row { display: flex; align-items: center; gap: 14px; color: #fff; text-decoration: none; }
.zefir-contacts__ico { width: 44px; height: 44px; border-radius: 12px; background: rgba(255,255,255,.14); display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
.zefir-contacts__rowtitle { font-weight: 700; font-size: 16px; }
.zefir-contacts__rowsub { font-size: 14px; color: rgba(255,255,255,.65); }
.zefir-contacts__formwrap { position: relative; background: #fff; border-radius: 28px; padding: 32px; }
.zefir-contacts__formtitle { font-weight: 700; font-size: 22px; color: var(--z-ink); margin: 0 0 20px; }

/* ---------- Form ---------- */
.zefir-form { display: flex; flex-direction: column; gap: 14px; }
.zefir-field { display: flex; flex-direction: column; }
.zefir-input { width: 100%; padding: 15px 18px; border: 1.5px solid #ECE4FB; border-radius: 14px; font-family: var(--font-body); font-size: 16px; color: var(--z-ink); outline: none; transition: border-color .2s; background: #fff; }
.zefir-input:focus { border-color: var(--z-purple); }
.zefir-input.is-invalid { border-color: var(--z-berry); }
.zefir-error { font-size: 13px; color: var(--z-berry); font-weight: 600; margin-top: 5px; min-height: 16px; }
.zefir-form__consent { font-size: 12px; color: var(--z-muted); text-align: center; margin: 2px 0 0; }

/* ---------- Footer ---------- */
.zefir-footer { position: relative; z-index: 1; max-width: var(--wrap); margin: 0 auto; padding: 0 24px 50px; }
.zefir-footer__inner { display: flex; align-items: center; justify-content: space-between; gap: 24px; flex-wrap: wrap; padding-top: 30px; border-top: 1px solid rgba(52,33,92,.14); }
.zefir-footer__brand { display: flex; align-items: center; gap: 10px; text-decoration: none; }
.zefir-footer__dot { width: 28px; height: 28px; border-radius: 50%; background: linear-gradient(135deg, var(--z-purple), var(--z-lime)); }
.zefir-footer__name { font-family: var(--font-display); font-weight: 800; font-size: 20px; color: var(--z-ink); }
.zefir-footer__copy { font-size: 14px; color: var(--z-ink-3); font-weight: 600; }
.zefir-footer__social { display: flex; gap: 10px; }
.zefir-footer__soc { width: 40px; height: 40px; border-radius: 50%; background: rgba(255,255,255,.6); display: flex; align-items: center; justify-content: center; font-weight: 700; color: var(--z-ink); text-decoration: none; transition: background .2s; }
.zefir-footer__soc:hover { background: #fff; }

/* ---------- Modal ---------- */
.zefir-modal { position: fixed; inset: 0; z-index: 90; display: flex; align-items: center; justify-content: center; padding: 20px; }
.zefir-modal[hidden] { display: none; }
.zefir-modal__backdrop { position: absolute; inset: 0; background: rgba(52,33,92,.45); backdrop-filter: blur(8px); -webkit-backdrop-filter: blur(8px); }
.zefir-modal__card { position: relative; width: min(460px, 100%); background: #fff; border-radius: 32px; padding: 38px; box-shadow: 0 40px 90px rgba(52,33,92,.4); animation: pop .3s ease both; }
.zefir-modal__close { position: absolute; top: 20px; right: 20px; width: 38px; height: 38px; border-radius: 50%; border: none; cursor: pointer; background: var(--z-soft); color: var(--z-ink-3); font-size: 20px; font-weight: 700; transition: background .2s; }
.zefir-modal__close:hover { background: #E8DEFB; }
.zefir-modal__title { font-family: var(--font-display); font-weight: 700; font-size: 26px; color: var(--z-ink); margin: 8px 0 22px; letter-spacing: -.5px; }
.zefir-modal__success { text-align: center; padding: 20px 0; }
.zefir-modal__success[hidden] { display: none; }
.zefir-modal__form[hidden] { display: none; }
.zefir-modal__check { width: 80px; height: 80px; border-radius: 50%; background: linear-gradient(135deg, var(--z-lime), #A8D838); display: flex; align-items: center; justify-content: center; font-size: 38px; margin: 0 auto 20px; }
.zefir-modal__success .zefir-modal__title { margin: 0 0 10px; }
.zefir-modal__sub { font-size: 16px; line-height: 1.5; color: var(--z-ink-4); margin: 0; }

/* ---------- Toast ---------- */
.zefir-toast { position: fixed; bottom: 90px; left: 50%; transform: translateX(-50%); z-index: 95; display: flex; align-items: center; gap: 12px; padding: 16px 24px; background: var(--z-ink); color: #fff; border-radius: 999px; box-shadow: 0 18px 44px rgba(52,33,92,.45); animation: toastIn .35s ease both; }
.zefir-toast[hidden] { display: none; }
.zefir-toast__check { width: 28px; height: 28px; border-radius: 50%; background: var(--z-lime); color: var(--z-ink); display: flex; align-items: center; justify-content: center; font-weight: 800; }

/* ============================================================
   Services page
   ============================================================ */
.zefir-main--services .zefir-svc-intro { padding-top: 140px; padding-bottom: 30px; }
.zefir-svc-intro__head { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; flex-wrap: wrap; }
.zefir-pill-back { display: inline-block; background: rgba(255,255,255,.6); font-weight: 600; font-size: 14px; color: var(--z-ink-3); padding: 8px 16px; border-radius: 999px; margin-bottom: 18px; text-decoration: none; transition: background .2s; }
.zefir-pill-back:hover { background: #fff; }
.zefir-svc-intro__title { font-family: var(--font-display); font-weight: 800; font-size: clamp(40px, 6vw, 80px); letter-spacing: -2.5px; margin: 0; color: var(--z-ink); line-height: .96; }
.zefir-svc-intro__text { font-size: 18px; line-height: 1.55; color: var(--z-ink-2); margin: 20px 0 0; max-width: 500px; font-weight: 500; }
.zefir-promo-banner { background: #fff; border-radius: 24px; padding: 24px 28px; box-shadow: 0 16px 40px rgba(74,45,122,.14); text-align: center; }
.zefir-promo-banner__num { font-family: var(--font-display); font-weight: 700; font-size: 30px; color: var(--z-purple); }
.zefir-promo-banner__text { font-size: 14px; color: var(--z-ink-4); font-weight: 600; max-width: 160px; margin-top: 4px; }

.zefir-svc-tabs-wrap { padding-top: 20px; padding-bottom: 20px; }
.zefir-svc-tabs { display: flex; gap: 10px; flex-wrap: wrap; }
.zefir-tab { font-family: var(--font-body); font-weight: 600; font-size: 15px; background: #fff; color: var(--z-ink-2); border: none; cursor: pointer; padding: 13px 24px; border-radius: 999px; box-shadow: 0 8px 20px rgba(74,45,122,.1); transition: background .2s, color .2s; }
.zefir-tab.is-active { background: var(--z-ink); color: #fff; }

.zefir-svc-rows-wrap { padding-top: 24px; padding-bottom: 60px; }
.zefir-svc-rows { display: flex; flex-direction: column; gap: 14px; }
.zefir-svc-row { background: #fff; border-radius: 24px; padding: 24px 28px; box-shadow: 0 12px 32px rgba(74,45,122,.1); display: grid; grid-template-columns: 56px 1fr auto auto; gap: 22px; align-items: center; transition: transform .18s; }
.zefir-svc-row:hover { transform: translateX(6px); }
.zefir-svc-row[hidden] { display: none; }
.zefir-svc-row__icon { width: 56px; height: 56px; border-radius: 16px; display: inline-block; }
.zefir-svc-row__heading { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.zefir-svc-row__name { font-weight: 700; font-size: 21px; color: var(--z-ink); margin: 0; }
.zefir-svc-row__cat { font-size: 12px; font-weight: 700; color: var(--z-ink-3); background: var(--z-soft); padding: 4px 10px; border-radius: 999px; }
.zefir-svc-row__desc { font-size: 15px; color: var(--z-ink-4); margin: 6px 0 0; line-height: 1.45; }
.zefir-svc-row__price { text-align: right; }
.zefir-svc-row__amount { font-family: var(--font-display); font-weight: 700; font-size: 24px; color: var(--z-ink); white-space: nowrap; }
.zefir-svc-row__dur { font-size: 14px; color: var(--z-muted); font-weight: 600; }
.zefir-svc-empty { background: #fff; border-radius: 24px; padding: 40px; text-align: center; color: var(--z-ink-4); font-weight: 600; box-shadow: 0 12px 32px rgba(74,45,122,.1); }
.zefir-svc-empty[hidden] { display: none; }

/* ---------- FAQ ---------- */
.zefir-faq-wrap { max-width: 880px; padding-top: 30px; padding-bottom: 60px; }
.zefir-faq__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.2vw, 42px); letter-spacing: -1.5px; margin: 0 0 28px; color: var(--z-ink); text-align: center; }
.zefir-faq { display: flex; flex-direction: column; gap: 12px; }
.zefir-faq__item { background: #fff; border-radius: 22px; padding: 6px 28px; box-shadow: 0 12px 30px rgba(74,45,122,.1); }
.zefir-faq__q { width: 100%; background: none; border: none; cursor: pointer; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 22px 0; text-align: left; }
.zefir-faq__q > span:first-child { font-family: var(--font-body); font-weight: 700; font-size: 18px; color: var(--z-ink); }
.zefir-faq__sign { flex-shrink: 0; width: 34px; height: 34px; border-radius: 50%; background: var(--z-soft); color: var(--z-purple); font-size: 22px; font-weight: 700; display: flex; align-items: center; justify-content: center; }
.zefir-faq__a { max-height: 0; opacity: 0; overflow: hidden; transition: max-height .35s ease, opacity .35s ease; }
.zefir-faq__item.is-open .zefir-faq__a { max-height: 400px; opacity: 1; }
.zefir-faq__atext { font-size: 16px; line-height: 1.6; color: var(--z-ink-4); padding: 0 0 24px; }
.zefir-faq__atext p { margin: 0; }

/* ---------- Services CTA ---------- */
.zefir-svc-cta-wrap { padding-top: 10px; padding-bottom: 90px; }
.zefir-svc-cta { background: linear-gradient(135deg, var(--z-lime), #A8D838); border-radius: 36px; padding: 50px; text-align: center; box-shadow: 0 24px 60px rgba(120,150,20,.25); }
.zefir-svc-cta__title { font-family: var(--font-display); font-weight: 700; font-size: clamp(28px, 3.4vw, 46px); letter-spacing: -1.5px; margin: 0; color: var(--z-ink); }
.zefir-svc-cta__text { font-size: 18px; color: #3E5410; margin: 14px auto 28px; max-width: 480px; font-weight: 500; }

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 1024px) {
	.zefir-hero { grid-template-columns: 1fr; gap: 36px; padding-top: 130px; }
	.zefir-hero__media { max-width: 480px; }
	.zefir-about__card { grid-template-columns: 1fr; gap: 36px; padding: 40px; }
	.zefir-contacts__card { grid-template-columns: 1fr; gap: 36px; padding: 40px; }
	.zefir-grid--4 { grid-template-columns: repeat(2, 1fr); }
	.zefir-grid--3 { grid-template-columns: repeat(2, 1fr); }
	.zefir-gallery { grid-template-columns: repeat(2, 1fr); }
	/* Even gallery grid on narrow screens — drop bento spans so tiles tile cleanly with no gaps. */
	.zefir-gallery__tile--tall, .zefir-gallery__tile--wide { grid-row: auto; grid-column: auto; }
	/* Keep faces in frame on portrait photos when containers get wide/short. */
	.zefir-master__img { object-position: center 22%; }
	.zefir-hero__img { object-position: center 28%; }
}

@media (max-width: 760px) {
	.zefir-nav { padding: 10px 12px 10px 18px; }
	.zefir-nav__links { position: absolute; top: calc(100% + 10px); right: 0; left: 0; flex-direction: column; align-items: stretch; gap: 4px; background: rgba(255,255,255,.96); backdrop-filter: blur(18px); -webkit-backdrop-filter: blur(18px); border-radius: 22px; padding: 12px; box-shadow: 0 18px 44px rgba(74,45,122,.2); display: none; }
	.zefir-nav__links.is-open { display: flex; }
	.zefir-nav__link { padding: 12px 16px; font-size: 16px; }
	.zefir-nav__burger { display: flex; order: 3; }
	.zefir-nav__cta { order: 2; }
	.zefir-nav__cta .zefir-btn { padding: 11px 18px; font-size: 14px; }
}

@media (max-width: 640px) {
	.zefir-section { padding: 40px 18px; }
	.zefir-hero { padding: 120px 18px 40px; }
	.zefir-grid--3, .zefir-grid--4 { grid-template-columns: 1fr; }
	/* Taller cards so full-width portraits show the face comfortably. */
	.zefir-master__img { height: 360px; }
	.zefir-gallery { grid-template-columns: 1fr 1fr; grid-auto-rows: 150px; }
	.zefir-about__stats { gap: 12px; }
	.zefir-about__card, .zefir-contacts__card { padding: 28px; border-radius: 28px; }
	.zefir-hero__img { height: 440px; border-radius: 90px 90px 20px 20px; }
	.zefir-hero__stats { gap: 24px; }
	.zefir-section__head { flex-direction: column; align-items: flex-start; }
	.zefir-svc-row { grid-template-columns: 46px 1fr; grid-template-areas: 'icon body' 'price price' 'btn btn'; gap: 14px; }
	.zefir-svc-row__icon { grid-area: icon; width: 46px; height: 46px; }
	.zefir-svc-row__body { grid-area: body; }
	.zefir-svc-row__price { grid-area: price; text-align: left; }
	.zefir-svc-row .zefir-btn { grid-area: btn; }
	.zefir-contacts__card { padding-bottom: 32px; }
}

@media (prefers-reduced-motion: reduce) {
	* { animation: none !important; scroll-behavior: auto !important; }
}
