:root{
  --bg:#FFFFFF;
  --bg-soft:#F5F5F5;
  --ink:#222222;
  --muted:#6b7280;
  --primary:#2C7DA0;   /* море */
  --accent:#F4A261;    /* песок/рассвет */
  --accent-strong:#E76F51;
  --radius:16px;
  --radius-sm:12px;
  --shadow:0 10px 30px rgba(0,0,0,.06);
  --container:1180px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--ink); background:var(--bg);
}

.container{max-width:var(--container); margin:0 auto; padding:0 20px}

/* Header */
.header{
  position:sticky; top:0; z-index:20; background:rgba(255,255,255,.9); backdrop-filter:saturate(1.2) blur(10px);
  border-bottom:1px solid #eee;
}
.header__row{display:flex; align-items:center; gap:24px; height:72px}
.logo{font-weight:700; font-size:22px; color:var(--primary); text-decoration:none; letter-spacing:.5px}
.logo--footer{font-weight:700; font-size:20px; color:var(--primary); margin-bottom:6px}
.header__cta{margin-left:auto; display:flex; gap:8px}
.header__cta .btn i{font-size:14px}

/* Nav */
.nav{margin-left:auto; position:relative}
.nav__toggle{display:none}
.nav__list{display:flex; gap:18px; list-style:none; margin:0; padding:0}
.nav__link{display:inline-block; padding:8px 10px; color:#333; text-decoration:none; border-radius:10px}
.nav__link:hover{background:var(--bg-soft)}
.nav__link.is-active{color:var(--primary); font-weight:600}

/* Buttons */
.btn{display:inline-flex; align-items:center; justify-content:center; gap:8px; height:42px; padding:0 16px; border-radius:12px; text-decoration:none; font-weight:600; transition:.2s; border:0}
.btn--accent{background:var(--primary); color:#fff}
.btn--accent:hover{background:#256b86}
.btn--ghost{border:1px solid #e5e7eb; color:#111; background:#fff}
.btn--ghost:hover{border-color:#cbd5e1; background:#f9fafb}
.btn--block{width:100%}

/* Hero */
.hero{padding:56px 0 24px}
.hero__card{
  display:grid; grid-template-columns:1.15fr .85fr; gap:28px; align-items:stretch;
  background:linear-gradient(180deg,#fff, #f9fcfd);
  border:1px solid #eef2f7; border-radius:var(--radius); box-shadow:var(--shadow); overflow:hidden;
}
.hero__media{position:relative; background:var(--bg-soft)}
.hero__content{padding:36px}
.kicker{color:var(--primary); font-weight:600; letter-spacing:.06em; text-transform:uppercase; font-size:12px}
.h1{font-size:42px; line-height:1.1; margin:10px 0 12px}
.lead{font-size:18px; color:#374151; margin:0 0 18px}
.hero__cta{display:flex; gap:12px; flex-wrap:wrap}

/* Placeholder media */
.ph{position:relative; width:100%; background:linear-gradient(135deg,#eaf6fb,#f6fbff); border:1px dashed #d1e4ee}
.ph::before{content:""; display:block; padding-top:62.5%}
.ph--tall::before{padding-top:100%}
.ph--wide::before{padding-top:50%}
.ph__label{position:absolute; inset:auto 12px 12px auto; background:#fff; border:1px solid #e5e7eb; color:#111; padding:6px 10px; border-radius:10px; font-size:12px}

/* Badges */
.badges{display:flex; flex-wrap:wrap; gap:10px; margin:14px 0 0}
.badge{display:inline-flex; align-items:center; gap:8px; height:34px; padding:0 12px; border-radius:999px; background:#f3f6f9; color:#0f172a; border:1px solid #e2e8f0; font-size:14px}
.badge i{font-size:14px}

/* Section */
.section{padding:56px 0}
.section--soft{background:var(--bg-soft)}
.section__head{display:flex; align-items:end; justify-content:space-between; gap:16px; margin-bottom:22px}
.h2{font-size:28px; margin:0}
.muted{color:var(--muted)}

/* Features */
.features{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.card{background:#fff; border:1px solid #eef2f7; border-radius:var(--radius-sm); padding:18px; box-shadow:var(--shadow)}
.card__title{font-weight:700; margin:0 0 6px}
.card__desc{margin:0; color:#4b5563}

/* Rooms */
.grid-3{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.room__media{border-radius:12px; overflow:hidden; margin-bottom:12px}
.room__row{display:flex; align-items:center; justify-content:space-between; gap:12px}
.price{font-weight:700; color:#0f172a}

/* Steps */
.steps{display:grid; grid-template-columns:repeat(3,1fr); gap:18px}
.step{background:#fff; border:1px solid #eef2f7; border-radius:12px; padding:16px}
.step b{display:block; margin-bottom:6px}

/* Gallery */
.gallery{column-count:3; column-gap:16px}
.gallery__item{break-inside:avoid; margin-bottom:16px; border-radius:12px; overflow:hidden; border:1px solid #eef2f7; background:#fff}

/* FAQ */
.faq{display:grid; grid-template-columns:1fr; gap:12px}
.faq__item{border:1px solid #e5e7eb; border-radius:12px; padding:14px 16px; background:#fff}
.faq__q{margin:0; font-weight:700}
.faq__a{margin:8px 0 0; color:#374151}

/* Footer */
.footer{background:#0b1220; color:#dae1ea; padding:40px 0 18px}
.footer a{color:#e7edf5}
.footer__grid{display:grid; grid-template-columns:2fr 1fr 1fr 1.2fr; gap:24px}
.footer h4{margin:0 0 10px}
.list{list-style:none; padding:0; margin:0; display:grid; gap:6px}
.list--cols{grid-template-columns:1fr}
.footer .booking-mini label{display:block; font-size:13px; color:#cbd5e1; margin-bottom:10px}
.footer .booking-mini input{width:100%; height:40px; border-radius:10px; border:1px solid #334155; background:#0e1729; color:#e5e7eb; padding:0 10px}
.footer .booking-mini__row{display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:10px}

/* Breadcrumbs */
.breadcrumbs{border-top:1px solid #f0f0f0; border-bottom:1px solid #f0f0f0; background:#fff}
.crumbs{display:flex; gap:10px; padding:10px 0; margin:0; list-style:none}
.crumb a{color:#334155; text-decoration:none}
.crumb a:hover{color:#0f172a}

/* jQuery UI тонкая подстройка */
.ui-datepicker{
  font-size:14px !important;
  border:1px solid #e5e7eb !important;
  border-radius:12px !important;
  box-shadow:var(--shadow);
}
.ui-datepicker .ui-datepicker-header{
  background:#f6fafc !important; border:0 !important; color:#0f172a !important; border-radius:12px 12px 0 0 !important;
}
.ui-state-active, .ui-widget-content .ui-state-active{
  background:var(--primary) !important; color:#fff !important; border:0 !important;
}
.ui-widget.ui-widget-content{border-radius:12px !important}

/* Responsive */
@media (max-width:1024px){
  .hero__card{grid-template-columns:1fr}
  .features,.grid-3,.steps{grid-template-columns:1fr 1fr}
  .gallery{column-count:2}
  .header__row{height:64px}
}
@media (max-width:720px){
  .nav__toggle{display:inline-flex; align-items:center; justify-content:center; height:40px; padding:0 12px; border-radius:10px; border:1px solid #e5e7eb; background:#fff}
  .nav__list{display:none; position:absolute; right:20px; top:68px; background:#fff; border:1px solid #e5e7eb; border-radius:12px; padding:10px; flex-direction:column; width:min(88vw,320px); box-shadow:var(--shadow)}
  .nav__list.is-open{display:flex}
  .header__cta{display:none}
  .features,.grid-3,.steps{grid-template-columns:1fr}
  .gallery{column-count:1}
  .h1{font-size:34px}
  .footer .booking-mini__row{grid-template-columns:1fr}
}
