
:root{
  --blue:#063F74;
  --blue-2:#0355A4;
  --text:#0f172a;
  --muted:#475569;
  --bg:#ffffff;
  --card:#ffffff;
  --accent:#FF308B;
  --border:rgba(15,23,42,.12);
  --shadow:0 10px 25px rgba(15,23,42,.10);
  --radius:14px;
  --max:1300px;
  --divider-pattern-url: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none' overflow='visible' viewBox='0 0 24 24' fill='none' stroke='%23063F74' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M0,6c6,0,0.9,11.1,6.9,11.1S18,6,24,6'/%3E%3C/svg%3E");
  --divider-border-width: 1px;
  --divider-border-style: solid;
  --divider-color:#063F74;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:Roboto,system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  line-height:1.5;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
.container{max-width:var(--max); margin:0 auto; padding:0 16px}

.site-header{
  background:
    linear-gradient(180deg, rgba(6,63,116,.65), rgba(6,63,116,.15)),
    var(--header-bg) center/cover no-repeat;
}

/* Topbar + nav */
.topbar{background:rgba(3,85,164,.92); color:#fff;}
.topbar-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; padding:10px 0;
}
.phone{    font-weight: 500;
  letter-spacing: 1px;
  text-transform: uppercase;
  font-size: 15px;
}
.email{    text-transform: unset;}
.nav-toggle{
  border:1px solid rgba(255,255,255,.35);
  background:transparent; color:#fff;
  padding:8px 10px; border-radius:10px;
  cursor:pointer; font-weight:600;
  display:none;
}
.nav-wrap{background:rgba(255,255,255,.92); backdrop-filter: blur(8px);}
.nav-row{display:flex; align-items:center; justify-content:space-between; gap:14px; padding:12px 0;}
.brand{
  font-family:Montserrat,Roboto,sans-serif;
  font-weight:800; letter-spacing:.4px; text-transform:uppercase;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  color: var(--blue);

}
.logo-img{
  max-width: 100px;
  height: auto;
  box-shadow: 0px 0px 5px #0957a063;
  border-radius: 8px;
}
.nav .menu{
  list-style:none; margin:0; padding:0;
  display:flex; gap:18px; align-items:center;
}
.nav .menu > li > a{
  font-weight:700; padding:8px 10px;
  border-radius:10px; display:inline-block;
}
.nav .menu > li > a:hover{background:rgba(6,63,116,.08); text-decoration:none}
.nav .has-sub{position:relative}
.nav .sub{
  display:none; position:absolute; top:100%; left:0;
  min-width:260px;
  background:#fff; border:1px solid var(--border);
  border-radius:12px; padding:8px;
  box-shadow:var(--shadow); z-index:10;
}
.nav .sub li{list-style:none}
.nav .sub a{
  display:block; padding:9px 10px; border-radius:10px;
  font-weight:600; color:var(--text);
}
.nav .sub a:hover{background:rgba(6,63,116,.08); text-decoration:none}
@media (hover:hover){ .nav .has-sub:hover > .sub{display:block} }

/* Hero */
.hero{padding:18px 0 34px}
.booking-widget{
  background:rgba(6,63,116,.85);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 14px 35px rgba(0,0,0,.12);
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.15fr 1fr;
  gap:18px;
  margin-top:16px;
  align-items:stretch;
}
.hero-text{
  background:rgba(255,255,255,.92);
  border:1px solid rgba(255,255,255,.35);
  border-radius:var(--radius);
  padding:18px 18px 20px;
  box-shadow:0 10px 25px rgba(15,23,42,.10);
}
.hero-text h1{margin:0 0 10px; font-family:Montserrat,Roboto,sans-serif; font-weight:900;}
.lead{margin:0 0 16px; color:var(--muted)}
.actions{display:flex; flex-wrap:wrap; gap:10px}

.btn{
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 14px;
  border-radius:12px;
  background:var(--blue); color:#fff;
  font-weight:800;
  border:1px solid rgba(255,255,255,0);
  text-decoration:none !important;
}
.btn:hover{opacity:.95}
.btn-outline{background:transparent; color:var(--blue); border:1px solid rgba(6,63,116,.35);}

/* Sections */
.section{padding:52px 0}
.section h2{
  margin:0 0 12px;
  letter-spacing:.3px;
  text-transform:uppercase;
  text-align: center;

  color: #063F74;
  font-family: "Montserrat", Sans-serif;
  font-size: 40px;
  font-weight: 900;
}
.subhead{margin:0 0 20px; color:var(--accent); font-weight:700}

.split{display:grid; grid-template-columns: 1.3fr .9fr; gap:18px; align-items:stretch;}
.media{
  border-radius:var(--radius);
  background:center/cover no-repeat;
  box-shadow:var(--shadow);
  border:1px solid var(--border);
  min-height:320px;
}
.text{color:var(--muted)}

/* Offers */
.offer-grid{display:grid; grid-template-columns: repeat(3, 1fr); gap:14px;}
.offer-card{
  background:var(--card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  box-shadow:var(--shadow);
}
.offer-media{min-height:170px; background:center/cover no-repeat;}
.offer-body{padding:14px 14px 16px}
.offer-body h3{margin:0 0 8px; font-family:Montserrat,Roboto,sans-serif}
.offer-tariff{margin:0 0 10px; font-weight:800; color:var(--blue)}
.offer-details{margin:0 0 10px; color:var(--muted)}
.offer-price{margin:0; font-weight:900}

/* Rooms */
.room-grid{display:grid; grid-template-columns: repeat(4, 1fr); gap:12px;}
.room-card{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  min-height:210px;
}
.room-card img{
  width:100%; height:100%;
  object-fit:cover;
  transform:scale(1.02);
  transition:transform .35s ease;
}
.room-card:hover img{transform:scale(1.08)}
.room-title{
  position:absolute; left:10px; right:10px; bottom:10px;
  background:rgba(6,63,116,.75); color:#fff;
  padding:10px 10px;
  border-radius:14px;
  font-weight:900;
  font-family:Montserrat,Roboto,sans-serif;
  min-height: 68px;
  text-align: center;
}

/* Stats */
.stats{
  color:#fff;
  background:center/cover no-repeat;
  position:relative;
}
.stats::before{content:""; position:absolute; inset:0; background:rgba(6,63,116,.65);}
.stats .container{position:relative}
.stat-grid{display:grid; grid-template-columns: repeat(2, 1fr); gap:14px;}
.stat{
  background:rgba(255,255,255,.72);
  border:1px solid rgba(255,255,255,.22);
  border-radius:18px;
  padding:18px;
  text-align:center;
}
.stat-value{
  font-size:44px;
  font-weight:1000;
  font-family:Montserrat,Roboto,sans-serif;
  line-height:1.05;
  color: var(--accent);
}
.stat-label{font-weight:800; opacity:.95;     color: #063F74;}

/* FAQ */
.faq-list{display:grid; gap:10px; }
.faq-item{
  border:1px solid var(--border);
  border-radius:16px;
  background:#fff;
  box-shadow:0 10px 25px rgba(15,23,42,.06);
  overflow:hidden;
}
.faq-item summary{
  cursor:pointer;
  padding:14px 16px;
  font-weight:900;
  font-family:Montserrat,Roboto,sans-serif;
  list-style:none;
  position:relative;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+";
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  width:28px;height:28px;
  display:grid; place-items:center;
  border-radius:999px;
  background:rgba(6,63,116,.08);
  color:var(--blue);
  font-weight:1000;
}
.faq-item[open] summary::after{content:"–"}
.faq-content{padding:0 16px 14px; color:var(--muted)}
.faq-content p{margin:0}

/* Reviews */
.reviews .center{text-align:center; margin-top:14px}

/* Map */
.map-grid{display:grid; grid-template-columns: 1.3fr .7fr; gap:14px;}
.map-frame{
  border-radius:16px; overflow:hidden;
  border:1px solid var(--border);
  box-shadow:var(--shadow);
  background:#f8fafc;
}
.map-frame iframe{width:100%; height:400px; border:0; display:block;}
.contact-card{
  border-radius:16px;
  border:1px solid var(--border);
  background:#fff;
  box-shadow:var(--shadow);
  padding:14px 14px 16px;
  text-align: center;
  padding: 30px;
}
.contact-title{margin:0 0 8px; font-weight:1000; font-family:Montserrat,Roboto,sans-serif;    font-size: 22px; color: var(--accent);}
.socials{display:flex; flex-wrap:wrap; gap:8px; margin-top:12px; justify-content: center;padding-top: 20px;}
.social{
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: #ffffff30;
  font-weight: 800;
  text-decoration: none !important;
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 100px;
}
.social:hover{background:rgba(6,63,116,.06)}
.social.is-disabled{opacity:.45}

/* Footer */
.site-footer{
  color:#fff;
  background:
    linear-gradient(180deg, rgba(6,63,116,.88), rgba(6,63,116,.92)),
    center/cover no-repeat;
  padding:34px 0 18px;
}
.footer-row{display:grid; grid-template-columns: 1fr 1fr 1fr; gap:14px;}
.footer-brand{margin:0 0 10px; font-weight:1000; font-family:Montserrat,Roboto,sans-serif;}
.footer-socials{display:flex; flex-wrap:wrap; gap:8px; justify-content:flex-end}
.footer-bottom{margin-top:18px; opacity:.9}
.site-footer a{color:#fff}
.site-footer a:hover{text-decoration:underline}

/* Carousel */
.carousel{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  border:1px solid rgba(255,255,255,.25);
  box-shadow:0 10px 25px rgba(15,23,42,.15);
  background:#000;
  min-height:360px;
}
.carousel.small{min-height:210px; background:#fff; border:1px solid var(--border); box-shadow:var(--shadow);     display: grid; grid-template-columns: 1fr 1fr;padding: 40px; overflow: hidden}
.carousel .track{display:flex; height:100%; transition:transform .5s ease;}
.carousel .slide{min-width:100%; height:100%;    max-width: 100px !important;}
.carousel:not(.small) img{width:100%; height:360px; object-fit:cover;}
.carousel.small .slide{padding:14px}
.review{
  margin:0;
  border-radius:16px;
  border:1px solid var(--border);
  padding:14px 14px 12px;
  height: 100%;
}
.review p{margin:0 0 8px; color:var(--muted)}
.review footer{font-weight:900; color:var(--text)}

.car-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:40px; height:40px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.35);
  background:rgba(0,0,0,.25);
  color:#fff;
  cursor:pointer;
  display:grid;
  place-items:center;
  font-size:24px;
  font-weight:900;
}
.carousel.small .car-btn{border:1px solid var(--border); background:rgba(15,23,42,.04); color:var(--text);}
.car-btn.prev{left:10px}
.car-btn.next{right:10px}
.dots{
  position:absolute; left:10px; right:10px; bottom:10px;
  display:flex; gap:6px; justify-content:center;
}
.dot{
  width:8px; height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.55);
  border:1px solid rgba(255,255,255,.4);
}
.carousel.small .dot{background:rgba(15,23,42,.25); border:1px solid rgba(15,23,42,.15);}
.dot.is-active{background:#fff}
.carousel.small .dot.is-active{background:rgba(6,63,116,.85)}
.divider{
  height: 24px;                 /* высота линии */
  background-image: var(--divider-pattern-url);
  background-repeat: repeat-x;  /* повтор по ширине */
  background-size: 24px 24px;   /* шаг повторения (длина “волны”) */
  background-position: center;
  color: blue;
  width: 25%;
  display: flex;
  box-sizing: border-box;
  direction: ltr;
  margin: 20px auto 40px auto;
}

/* Responsive */
@media (max-width:1340px){
  .nav-row,
  .topbar-row{padding-right: 20px; padding-left: 20px}
}
@media (max-width:1100px){
  .offer-grid{grid-template-columns: repeat(2, 1fr)}
  .room-grid{grid-template-columns: repeat(3, 1fr)}
  .split{grid-template-columns:1fr}
  .media{min-height:260px}
  .hero-grid{grid-template-columns:1fr}
  .carousel{min-height:320px}
  .carousel:not(.small) img{height:320px}
}
@media (max-width:760px){
  .nav-toggle{display:inline-flex}
  .nav{display:none}
  .nav.is-open{display:block}
  .nav .menu{flex-direction:column; align-items:stretch; gap:6px}
  .nav .menu > li > a{padding:12px 12px}
  .nav .sub{position:static; display:none; box-shadow:none; border:none; padding:0}
  .nav .has-sub.is-open > .sub{display:block}
  .offer-grid{grid-template-columns:1fr}
  .room-grid{grid-template-columns:1fr 1fr}
  .map-grid{grid-template-columns:1fr}
  .footer-row{grid-template-columns:1fr; text-align:left}
  .footer-socials{justify-content:flex-start}
  .email{display: none}
}
@media (max-width:640px){
  .carousel .slide {
    max-width: 50px !important;
  }
}
@media (max-width:420px){
  .room-grid{grid-template-columns:1fr}
}
