/* ============ ВОЛГА РЯДОМ — общий стиль ============ */
:root{
  --green-900:#1f3d2b;
  --green-700:#2f5d43;
  --green-500:#4a7c59;
  --sand:#f4f1ea;
  --sand-dark:#e8e2d4;
  --wood:#b5793a;
  --ink:#23211c;
  --muted:#6b6457;
  --white:#ffffff;
  --busy:#c2563f;
  --radius:16px;
  --shadow:0 10px 30px rgba(31,61,43,.12);
  --maxw:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Manrope',system-ui,sans-serif;
  color:var(--ink);
  background:var(--sand);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.material-symbols-outlined{font-family:'Material Symbols Outlined';font-weight:normal;font-style:normal;line-height:1;vertical-align:middle}

h1,h2,h3,h4{font-family:'Playfair Display',Georgia,serif;font-weight:600;line-height:1.15;color:var(--green-900);margin:0}
.eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:700;color:var(--green-500);margin:0 0 10px}
.eyebrow-light{color:#cfe3d3}
.section-title{font-size:clamp(1.8rem,4vw,2.6rem);margin-bottom:10px}
.section-lead{color:var(--muted);max-width:620px;margin:0 0 36px}

/* Кнопки */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:'Manrope';font-weight:600;font-size:.95rem;padding:12px 22px;border-radius:999px;border:1.5px solid transparent;cursor:pointer;transition:.2s;white-space:nowrap}
.btn-primary{background:var(--green-700);color:#fff}
.btn-primary:hover{background:var(--green-900)}
.btn-outline{background:transparent;border-color:var(--green-700);color:var(--green-700)}
.btn-outline:hover{background:var(--green-700);color:#fff}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(4px)}
.btn-ghost:hover{background:rgba(255,255,255,.25)}
.btn-sm{padding:9px 18px;font-size:.88rem}
.btn-lg{padding:15px 30px;font-size:1.02rem}
.btn-block{width:100%}

/* ============ ШАПКА ============ */
.site-header{position:sticky;top:0;z-index:50;background:rgba(244,241,234,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--sand-dark)}
.header-inner{display:flex;align-items:center;justify-content:space-between;min-height:74px}
.brand{display:flex;align-items:center}
.brand-logo{height:52px;width:auto}
.nav-desktop{display:flex;align-items:center;gap:28px}
.nav-desktop a{font-weight:600;font-size:.95rem;color:var(--ink);transition:.2s}
.nav-desktop a:hover{color:var(--green-700)}
.nav-desktop a.btn{color:#fff}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;color:var(--green-900);font-size:0}
.nav-toggle .material-symbols-outlined{font-size:30px}
.nav-mobile{display:none;flex-direction:column;gap:4px;padding:12px 20px 20px;background:var(--sand);border-bottom:1px solid var(--sand-dark)}
.nav-mobile a{padding:12px 8px;font-weight:600;border-radius:10px}
.nav-mobile a:not(.btn):hover{background:var(--sand-dark)}
.nav-mobile .btn{margin-top:8px}

/* ============ HERO ============ */
.hero{position:relative;min-height:84vh;display:flex;align-items:center;color:#fff;overflow:hidden}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.05)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,35,25,.45),rgba(20,35,25,.75))}
.hero-content{position:relative;max-width:760px;padding-top:40px;padding-bottom:60px}
.hero h1{color:#fff;font-size:clamp(2.2rem,6vw,4rem);margin-bottom:18px}
.hero-sub{font-size:clamp(1rem,2.2vw,1.25rem);color:#eef3ee;max-width:560px;margin:0 0 30px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}

/* ============ СЕКЦИИ ============ */
.section{padding:80px 0}
.section-alt{background:var(--white)}
@media(max-width:640px){.section{padding:56px 0}}

/* ============ КАРУСЕЛЬ ============ */
.carousel{position:relative;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.carousel-track{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;scroll-behavior:smooth;padding-bottom:14px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.carousel-track::-webkit-scrollbar{display:none}
.slide{flex:0 0 auto;width:min(420px,82vw);scroll-snap-align:center;margin:0;position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);background:#000}
.slide img{width:100%;height:520px;object-fit:cover}
.slide figcaption{position:absolute;left:0;right:0;bottom:0;padding:30px 18px 14px;color:#fff;font-size:.92rem;font-weight:500;background:linear-gradient(transparent,rgba(0,0,0,.7))}
@media(max-width:640px){.slide img{height:62vh;max-height:480px}}
.carousel-btn{position:absolute;top:calc(50% - 28px);transform:translateY(-50%);width:48px;height:48px;border-radius:50%;border:none;background:rgba(255,255,255,.95);color:var(--green-900);cursor:pointer;box-shadow:var(--shadow);display:flex;align-items:center;justify-content:center;z-index:2;transition:.2s}
.carousel-btn:hover{background:#fff;transform:translateY(-50%) scale(1.06)}
.carousel-btn .material-symbols-outlined{font-size:28px}
.carousel-btn.prev{left:26px}
.carousel-btn.next{right:26px}
@media(max-width:640px){.carousel-btn{display:none}}
.carousel-dots{display:flex;gap:8px;justify-content:center;margin-top:18px}
.carousel-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--sand-dark);cursor:pointer;padding:0;transition:.2s}
.carousel-dots button.active{background:var(--green-700);width:26px;border-radius:5px}

/* ============ КАРТОЧКИ ============ */
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media(max-width:900px){.cards-3{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.cards-3{grid-template-columns:1fr}}
.card{background:var(--white);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);display:flex;flex-direction:column}
.section-alt .card{background:var(--sand)}
.card-img{height:230px;overflow:hidden}
.card-img img{width:100%;height:100%;object-fit:cover;transition:.4s}
.card:hover .card-img img{transform:scale(1.05)}
.card-body{padding:22px;display:flex;flex-direction:column;gap:10px;flex:1}
.price-tag{align-self:flex-start;background:var(--sand-dark);color:var(--green-900);font-weight:700;font-size:.8rem;padding:5px 12px;border-radius:999px}
.card-body h3{font-size:1.3rem}
.card-body p{color:var(--muted);margin:0;flex:1}
.amenities{display:flex;gap:14px;color:var(--green-500)}
.amenities .material-symbols-outlined{font-size:22px}

/* ============ РАЗВЛЕЧЕНИЯ ============ */
.features{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
@media(max-width:900px){.features{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.features{grid-template-columns:1fr}}
.feature{background:var(--white);border:1px solid var(--sand-dark);border-radius:var(--radius);padding:26px 22px;transition:.2s}
.feature:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.feature .material-symbols-outlined{font-size:34px;color:var(--green-500)}
.feature h3{font-size:1.2rem;margin:12px 0 6px}
.feature p{color:var(--muted);margin:0;font-size:.94rem}
.feature-hot{border-color:var(--wood);position:relative}
.feature-hot .material-symbols-outlined{color:var(--wood)}

/* ============ БРОНИРОВАНИЕ ============ */
.section-booking{background:var(--green-900);color:#fff}
.section-booking .section-title,.section-booking .eyebrow{color:#fff}
.section-booking .eyebrow{color:#bcd6c2}
.section-booking .section-lead{color:#cfe0d2}
.booking-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:46px;align-items:start}
@media(max-width:900px){.booking-grid{grid-template-columns:1fr;gap:32px}}
.booking-points{list-style:none;padding:0;margin:24px 0 0;display:flex;flex-direction:column;gap:12px}
.booking-points li{display:flex;align-items:center;gap:10px;color:#e7f0e9}
.booking-points .material-symbols-outlined{color:#8fd6a3}
.booking-card{background:var(--white);border-radius:20px;padding:24px;box-shadow:var(--shadow);color:var(--ink)}

/* Календарь */
.cal{margin-bottom:22px}
.cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.cal-title{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:600;color:var(--green-900);text-transform:capitalize}
.cal-nav{width:38px;height:38px;border-radius:10px;border:1px solid var(--sand-dark);background:var(--sand);cursor:pointer;color:var(--green-900);display:flex;align-items:center;justify-content:center}
.cal-nav:hover{background:var(--sand-dark)}
.cal-nav:disabled{opacity:.35;cursor:not-allowed}
.cal-weekdays,.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal-weekdays span{text-align:center;font-size:.72rem;font-weight:700;color:var(--muted);text-transform:uppercase;padding-bottom:4px}
.cal-grid{margin-top:2px}
.cal-cell{aspect-ratio:1;border:none;background:var(--sand);border-radius:10px;font-family:'Manrope';font-weight:600;font-size:.92rem;color:var(--ink);cursor:pointer;transition:.15s;position:relative}
.cal-cell.empty{background:transparent;cursor:default}
.cal-cell:not(.empty):not(.busy):not(.past):hover{background:var(--green-500);color:#fff}
.cal-cell.busy{background:#f5d9d2;color:var(--busy);cursor:not-allowed;text-decoration:line-through}
.cal-cell.past{color:#bdb7aa;cursor:not-allowed;background:transparent}
.cal-cell.sel{background:var(--green-700);color:#fff}
.cal-cell.in-range{background:#cfe3d3;color:var(--green-900)}
.cal-legend{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-size:.78rem;color:var(--muted);margin:14px 0 4px}
.cal-legend .dot{width:11px;height:11px;border-radius:50%;display:inline-block;margin-left:10px}
.cal-legend .dot:first-child{margin-left:0}
.dot-free{background:var(--sand-dark)}
.dot-busy{background:#f5d9d2;border:1px solid var(--busy)}
.dot-sel{background:var(--green-700)}
.cal-status{font-size:.82rem;color:var(--muted);margin:6px 0 0;min-height:1.2em}

/* Форма */
.booking-form{display:flex;flex-direction:column;gap:14px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field{display:flex;flex-direction:column;gap:6px;font-size:.86rem;font-weight:600;color:var(--green-900)}
.field small{font-weight:400;color:var(--muted)}
.field input,.field select,.field textarea{font-family:'Manrope';font-size:.96rem;font-weight:500;padding:12px 14px;border:1.5px solid var(--sand-dark);border-radius:12px;background:var(--sand);color:var(--ink);transition:.15s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--green-500);background:#fff}
.field input[readonly]{cursor:default;color:var(--green-900)}
.form-note{font-size:.9rem;margin:4px 0 0;min-height:1.2em;font-weight:600}
.form-note.ok{color:var(--green-700)}
.form-note.err{color:var(--busy)}

/* ============ ОТЗЫВЫ ============ */
.star{color:var(--wood)}
.review{background:var(--white);border-radius:var(--radius);padding:26px;margin:0;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px}
.section-alt .review{background:var(--sand)}
.review .stars{color:var(--wood);letter-spacing:2px}
.review p{margin:0;color:var(--ink)}
.review footer{display:flex;align-items:center;gap:10px;color:var(--muted);font-size:.88rem;font-weight:600}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--green-500);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}

/* ============ ПОДВАЛ ============ */
.site-footer{background:var(--green-900);color:#cfe0d2;padding:56px 0 26px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:34px}
@media(max-width:760px){.footer-grid{grid-template-columns:1fr;gap:26px}}
.footer-logo{height:74px;width:auto;background:#fff;border-radius:12px;padding:8px;margin-bottom:14px}
.footer-brand p{margin:0;max-width:340px}
.footer-col h4{color:#fff;font-size:1.05rem;margin-bottom:14px}
.footer-col a{display:flex;align-items:center;gap:8px;padding:5px 0;color:#cfe0d2;transition:.2s}
.footer-col a:hover{color:#fff}
.footer-col .material-symbols-outlined{font-size:19px;color:#8fb89a}
.footer-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:34px;padding-top:20px;font-size:.84rem;color:#9db7a4}

/* ============ АДАПТИВ ШАПКИ ============ */
@media(max-width:880px){
  .nav-desktop{display:none}
  .nav-toggle{display:block}
}

/* доступность */
:focus-visible{outline:3px solid var(--green-500);outline-offset:2px}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto!important;transition:none!important}}
