/* ====== Базовые стили (светлая тема) ====== */
:root{
  --bg:#f8f7f4;
  --bg-alt:#ffffff;
  --text:#1f1f1f;
  --muted:#6b6b6b;
  --brand:#c59a6a;
  --brand-2:#e7d3b5;
  --shadow:0 10px 25px rgba(0,0,0,.08);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,Helvetica,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.6;
}
h1,h2,h3{
  font-family:"Playfair Display", Georgia, serif;
  line-height:1.2;
  margin:0 0 .6rem;
}
h2{font-size:clamp(28px,3.2vw,40px)}
h3{font-size:clamp(18px,2.2vw,22px)}
.lead{color:var(--muted);max-width:70ch;margin:.4rem auto 2rem;text-align:center}
.container{width:min(1100px,92%);margin-inline:auto}
.narrow{width:min(850px,92%)}
.section{padding:64px 0}
.section--alt{background:var(--bg-alt)}

.topbar{
  position:sticky;top:0;z-index:20;
  background:#fff;border-bottom:1px solid #eee;
}
.topbar__inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{font-weight:700;color:#3b3b3b}
.contacts{display:flex;gap:10px;align-items:center}
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 12px;border:1px solid #e1e1e1;border-radius:999px;
  background:#fff;color:#333;text-decoration:none;font-weight:500;
  box-shadow:var(--shadow);
}
.btn:hover{transform:translateY(-1px);}
/*
.hero{position:relative;height:min(78vh,820px);display:grid;place-items:center;overflow:hidden}
.hero__img{width:100%;height:100%;object-fit:cover;object-position: center top;display:block;}
.hero__overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35) 0%, rgba(0,0,0,.55) 70%)}
.hero__content{position:relative;color:#fff;text-align:left;padding:0 8px}
.hero h1{font-size:clamp(36px,6vw,70px);max-width:13ch}
.hero h1 span{color:var(--brand-2)}
.hero p{max-width:55ch;margin:.6rem 0 1.2rem;color:#e6e6e6}
.cta{
  display:inline-block;background:var(--brand);color:#1b1205;text-decoration:none;
  padding:12px 18px;border-radius:999px;font-weight:700;box-shadow:var(--shadow)
}
*/
.hero{
  position: relative;
  overflow: hidden;
  /* высота экрана; 100dvh точнее на iOS */
  min-height: 100vh;
}
@supports (height: 100dvh){
  .hero{ min-height: 100dvh; }
}

/* картинка внутри <picture> занимает весь hero */
.hero picture{
  position: absolute;
  inset: 0;
}
.hero__img{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  /* фокус на лице — верх кадра */
  object-position: center top;
}

/* затемнение поверх фото */
.hero__overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg,rgba(0,0,0,.35) 0%, rgba(0,0,0,.55) 70%);
}

/* контент поверх фото */
.hero__content{
  position: relative;     /* можно absolute + inset:0; если хотите */
  z-index: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: flex-start;
  gap: 1rem;
  height: 100%;
  padding: clamp(16px, 5vw, 64px);
  color: #fff;
  text-align: left;
}

.hero h1{
  font-size: clamp(28px, 5vw, 70px);
  line-height: 1.15;
  max-width: 13ch;
}
.hero h1 span{ color: var(--brand-2); }

.hero p{
  max-width: 55ch;
  margin: .6rem 0 1.2rem;
  color: #e6e6e6;
}

/* кнопка как было */
.cta{
  display:inline-block;background:var(--brand);color:#1b1205;text-decoration:none;
  padding:12px 18px;border-radius:999px;font-weight:700;box-shadow:var(--shadow)
}

/* мобильные правки: сместить видимую область вверх и выровнять текст */
@media (max-width: 768px){
  .hero__img{ object-position: center 20%; }
  .hero__content{
    align-items: center;
    text-align: center;
    max-width: 92%;
    padding-top: clamp(24px, 8vh, 80px); /* запас под липкую шапку */
  }
}
.cta:hover{filter:brightness(.95)}

.bullets{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:8px 18px;padding:0;margin:16px 0 0}
.bullets li{list-style:"—  ";padding-left:4px;color:#3e3e3e}

/* Cards */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:22px;margin-top:20px}
.card{background:#fff;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);position:relative}
.card img{width:100%;height:200px;object-fit:cover;display:block}
.card__body{padding:14px 16px}
.badge{
  position:absolute;top:12px;right:12px;background:rgba(255,255,255,.92);border:1px solid #eee;
  padding:6px 10px;border-radius:999px;font-size:12px;font-weight:600;color:#5a4a36
}

/* Gallery */
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px}
.gallery img{width:100%;height:160px;object-fit:cover;border-radius:12px;cursor:zoom-in;box-shadow:var(--shadow)}

/* Video */
.video-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:18px;margin-top:14px}
.video-card{aspect-ratio:16/9;border-radius:12px;overflow:hidden;box-shadow:var(--shadow);background:#000}
.video-card iframe{width:100%;height:100%;border:0}

/* Testimonials + форма */
.testimonials{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:18px;margin-top:10px}
.quote{background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.quote blockquote{margin:0 0 8px;font-size:18px}
.quote figcaption{color:var(--muted);font-size:14px}

.review-form{margin-top:28px;background:#fff;border-radius:16px;padding:18px;box-shadow:var(--shadow)}
.form-title{margin:0 0 10px}
.form-grid{display:grid;grid-template-columns:1fr;gap:12px}
.form-grid label{display:grid;gap:6px}
.form-grid input, .form-grid textarea{
  width:100%;padding:10px 12px;border:1px solid #e1e1e1;border-radius:12px;
  font:inherit;background:#fcfcfb
}
.form-grid .wide{grid-column:1/-1}
.form-note{color:var(--muted);font-size:13px;margin:.6rem 0 0}

/* Footer */
.footer{background:#111;color:#e9e9e9;padding:42px 0 22px}
.footer__grid{display:grid;grid-template-columns:1.3fr .7fr;gap:20px}
.contact-list{list-style:none;margin:6px 0 0;padding:0;display:grid;gap:6px}
.contact-list a{color:#e9e9e9;text-decoration:none}
.contact-list a:hover{text-decoration:underline}
.copyright{align-self:end;color:#979797;text-align:right}

@media (max-width:760px){
  .footer__grid{grid-template-columns:1fr}
  .copyright{text-align:left}
}
@media (max-width: 768px) {
   .hero__img{
     object-position: center 20%;
}
}
/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.8);display:none;align-items:center;justify-content:center;padding:20px;z-index:50}
.lightbox.open{display:flex}
.lightbox__img{max-width:95vw;max-height:85vh;border-radius:12px;box-shadow:var(--shadow)}
.lightbox__close{
  position:absolute;top:14px;right:14px;border:0;background:transparent;color:#fff;
  font-size:40px;line-height:1;cursor:pointer
}
/* === СВЕРТЫВАНИЕ ДЛИННЫХ ОТЗЫВОВ === */
.quote__text{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 5;     /* показывать 5 строк */
  overflow: hidden;
  position: relative;
}

.quote--clamped .quote__text::after{
  content: "";
  position: absolute;
  left: 0; right: 0; bottom: 0;
  height: 2.5rem;              /* высота градиента */
  background: linear-gradient(to bottom, rgba(255,255,255,0), rgba(255,255,255,1));
  pointer-events: none;
}

.quote--expanded .quote__text{
  -webkit-line-clamp: unset;
  overflow: visible;
}

.show-more{
  background: none;
  border: 0;
  padding: 6px 0 0;
  color: var(--brand);
  font-weight: 600;
  cursor: pointer;
}
.show-more:hover{ text-decoration: underline; }
