:root{
  --accent:#284f6e;
  --text:#13233a;
  --muted:#5d6f80;
  --bg:#f4f1ea;
  --card:#f8f7f3;
  --container:1240px;
  --radius-xl:34px;
  --radius-lg:28px;
  --shadow:0 18px 50px rgba(19,35,58,.08);
  --line:rgba(19,35,58,.12);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.45}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button,input,textarea{font:inherit}
.container{width:min(calc(100% - 40px),var(--container));margin:0 auto}
.section{padding:40px 0}
.button{display:inline-flex;align-items:center;justify-content:center;gap:10px;padding:16px 28px;border-radius:999px;border:1px solid transparent;font-weight:700;transition:.25s ease;cursor:pointer}
.button:hover{transform:translateY(-1px)}
.button-primary{background:var(--accent);color:#fff;box-shadow:0 14px 35px rgba(40,79,110,.18)}
.button-light{background:#fff;color:var(--text)}
.button-outline{border-color:rgba(255,255,255,.7);color:#fff;background:rgba(255,255,255,.06);backdrop-filter:blur(4px)}
.mini-chip,.chip{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;border:1px solid rgba(19,35,58,.25);padding:12px 20px;font-size:14px;line-height:1;color:var(--text);background:rgba(255,255,255,.55)}
.mini-chip{padding:8px 14px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.site-header{position:absolute;left:0;right:0;top:0;z-index:20;padding:28px 0;color:#fff}
.site-header.is-sticky{position:fixed;padding:16px 0;background:rgba(14,27,43,.78);backdrop-filter:blur(12px);box-shadow:0 12px 30px rgba(0,0,0,.18)}
.site-header__inner{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:24px}
.logo{display:inline-flex;align-items:center;min-width:210px}
.logo img{height:54px;width:auto}
.logo--dark img{height:54px}
.header-burger{display:none;width:54px;height:54px;border-radius:16px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.08);backdrop-filter:blur(10px);align-items:center;justify-content:center;flex-direction:column;gap:6px;cursor:pointer;padding:0;margin-left:auto}
.header-burger span{display:block;width:22px;height:2px;border-radius:999px;background:#fff;transition:.25s ease}
.header-panel{display:contents}
.header-backdrop{display:none}
body.menu-open{overflow:hidden}
.main-nav{display:flex;justify-content:center;gap:22px;flex-wrap:wrap}
.main-nav a{font-size:17px;font-weight:500;opacity:.95}
.main-nav a:hover{opacity:1}
.header-actions{display:flex;align-items:center;gap:26px}
.header-phone{display:inline-flex;align-items:center;gap:10px;font-size:18px;font-weight:700;white-space:nowrap}
.header-phone::before{content:'☎';font-size:14px;opacity:.88}
.hero{position:relative;color:#fff;background:#102233;overflow:hidden}
.hero__bg,.hero__overlay{position:absolute;inset:0}
.hero__bg img{width:100%;height:100%;object-fit:cover}
.hero__overlay{background:linear-gradient(180deg,rgba(25,41,56,.28) 0%,rgba(10,21,34,.38) 100%)}
.hero__content{position:relative;z-index:2;padding:150px 0 180px;min-height:760px}
.hero-grid{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(360px,.8fr);gap:64px;align-items:start}
.hero-title{margin:0;font-size:clamp(54px,6vw,84px);line-height:.96;font-weight:300;text-transform:uppercase;white-space:pre-line;letter-spacing:.02em;max-width:780px}
.hero-right{padding-top:58px;display:grid;grid-template-columns:1fr auto;gap:28px;align-items:start}
.hero-line{height:2px;background:rgba(255,255,255,.56);width:100%;margin-bottom:26px}
.hero-text{font-size:18px;line-height:1.55;max-width:460px;font-weight:500}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;margin-top:28px}
.social-stack{display:flex;flex-direction:column;gap:10px;padding-top:48px}
.social-circle{width:50px;height:50px;border-radius:18px;background:rgba(255,255,255,.12);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-weight:700;border:1px solid rgba(255,255,255,.14);color:inherit;padding:0}
.social-circle:hover{background:rgba(255,255,255,.22)}
.social-circle svg,.social-square svg{width:20px;height:20px;display:block}
.social-circle--solid{background:#fff;color:var(--accent);border-color:rgba(19,35,58,.08)}
.hero-card-wrap{position:relative;z-index:4;margin-top:-110px}
.hero-card{background:var(--card);border-radius:42px;padding:44px 44px 38px;box-shadow:var(--shadow);border:1px solid rgba(255,255,255,.45)}
.hero-card-grid{display:grid;grid-template-columns:minmax(0,.96fr) minmax(0,.92fr);gap:48px;align-items:start}
.hero-card-top{display:flex;flex-wrap:wrap;gap:12px}
.hero-card-title{position:relative;margin:54px 0 0;font-size:clamp(46px,4vw,66px);line-height:1.02;font-weight:300;text-transform:uppercase;white-space:pre-line;color:var(--accent);max-width:540px;padding-bottom:34px}
.hero-card-title::after{content:'';position:absolute;left:0;right:0;bottom:0;height:2px;background:rgba(19,35,58,.12)}
.hero-card-watermark{position:absolute;right:-40px;bottom:-20px;width:360px;opacity:.22;pointer-events:none}
.hero-card-about{position:relative}
.hero-gallery-label{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.08em;margin:0 0 18px;color:#4f6477}
.hero-gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.thumb-card{border-radius:18px;overflow:hidden;aspect-ratio:1/.86;background:#d8e2e8;border:1px solid rgba(19,35,58,.08);padding:0;appearance:none;cursor:pointer}
.thumb-card img{width:100%;height:100%;object-fit:cover}
.hero-copy-divider{height:1px;background:rgba(19,35,58,.12);margin:30px 0}
.hero-copy{font-size:19px;line-height:1.65;color:#35495e}
.hero-copy strong{display:block;color:var(--text);margin-top:18px;font-size:22px}
.features-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:20px;margin-top:18px}
.feature-card,.review-card,.property-card,.news-card,.contact-card,.booking-card,.cooperation-card,.question-card{background:var(--card);border-radius:34px;border:1px solid rgba(19,35,58,.08);box-shadow:0 10px 30px rgba(19,35,58,.03)}
.feature-card{padding:26px 28px 28px}
.feature-icon{width:56px;height:56px;border-radius:18px;background:#d8e5ee;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:700;margin-bottom:20px}
.feature-card h3{font-size:24px;line-height:1.08;margin:0 0 14px}
.feature-card p{margin:0;color:var(--muted);font-size:18px}
.about-grid{display:grid;grid-template-columns:minmax(380px,.84fr) minmax(0,1fr);gap:26px;align-items:stretch}
.about-visual,.about-copy{border-radius:38px;overflow:hidden;position:relative}
.about-visual{min-height:520px;background:#dfe8ee;border:1px solid rgba(19,35,58,.08)}
.about-visual img{width:100%;height:100%;object-fit:cover}
.about-copy{background:var(--card);padding:42px 42px 40px}
.about-copy h2{margin:0 0 18px;font-size:clamp(42px,4vw,66px);line-height:.95;font-weight:800;color:var(--text)}
.about-copy p{margin:0 0 18px;font-size:19px;color:#35495e;line-height:1.6}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:24px;margin-bottom:18px}
.section-head h2{margin:0;font-size:clamp(42px,5vw,74px);line-height:.95;font-weight:800}
.section-head p{margin:0;color:var(--muted);font-size:21px}
.reviews-wrap{position:relative}
.reviews-track{display:flex;gap:20px;overflow-x:auto;overflow-y:hidden;padding-bottom:2px;scrollbar-width:none;-ms-overflow-style:none;scroll-snap-type:x mandatory;cursor:grab;user-select:none;-webkit-user-select:none;touch-action:pan-x;overscroll-behavior-x:contain}
.reviews-track::-webkit-scrollbar{display:none}
.reviews-track.is-dragging{cursor:grabbing;scroll-snap-type:none}
.review-card{flex:0 0 min(380px,85vw);padding:28px 28px 30px;scroll-snap-align:start}
.review-head{display:grid;grid-template-columns:56px 1fr;gap:14px;align-items:start;margin-bottom:18px}
.review-avatar{width:56px;height:56px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:28px;overflow:hidden}
.review-avatar img{width:100%;height:100%;object-fit:cover}
.review-name{font-size:22px;font-weight:800;line-height:1.05;margin:0}
.review-property{font-size:15px;color:var(--muted);margin-top:6px}
.review-card p{margin:0;font-size:18px;color:#34485d}
.carousel-arrows{display:flex;gap:10px}
.carousel-arrow{width:48px;height:48px;border-radius:999px;border:1px solid rgba(19,35,58,.16);background:#fff;color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:22px;cursor:pointer}
.intro-center{text-align:center;max-width:920px;margin:0 auto 28px}
.intro-center h2{white-space:pre-line;margin:0;font-size:clamp(46px,5vw,76px);line-height:.92;font-weight:800}
.intro-center p{margin:12px 0 0;color:var(--muted);font-size:22px}
.properties-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:22px}
.property-card{overflow:hidden}
.property-media{position:relative;aspect-ratio:1.1/.76;background:#dce6eb;border:0;padding:0;cursor:pointer}
.property-media img{width:100%;height:100%;object-fit:cover}
.property-overlay{position:absolute;left:16px;top:16px;display:flex;gap:10px;flex-wrap:wrap}
.property-body{padding:24px}
.property-body h3{margin:0 0 8px;font-size:26px;line-height:1.05}
.property-meta{display:flex;gap:12px;flex-wrap:wrap;color:var(--muted);font-size:15px;margin-bottom:10px}
.property-price{font-size:20px;font-weight:800;color:var(--accent);margin-bottom:10px}
.property-description{color:#384d63;font-size:17px;margin:0 0 16px}
.property-features{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.property-features span{border-radius:999px;background:#e7eef3;padding:8px 12px;font-size:13px;color:#37536d}
.booking-layout{display:grid;grid-template-columns:minmax(0,.9fr) minmax(380px,.76fr);gap:24px;align-items:stretch}
.booking-copy,.booking-card,.cooperation-card,.question-card,.contact-card{padding:34px}
.booking-copy{background:linear-gradient(180deg,#284f6e 0%,#1e3d57 100%);color:#fff;border-radius:38px;box-shadow:var(--shadow)}
.booking-copy h2,.cooperation-card h2,.question-card h2{margin:0 0 16px;font-size:clamp(38px,4vw,60px);line-height:.98}
.booking-copy p,.cooperation-card p,.question-card p,.contact-card p{margin:0 0 16px;font-size:19px;line-height:1.6}
.booking-messengers{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}
.booking-messengers .social-circle{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.18)}
.form-grid{display:grid;gap:14px}
.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.input{width:100%;padding:18px 18px;border-radius:18px;border:1px solid rgba(19,35,58,.12);background:#fff;color:var(--text);transition:border-color .2s ease,box-shadow .2s ease}
.input:focus{outline:none;border-color:rgba(40,79,110,.42);box-shadow:0 0 0 4px rgba(40,79,110,.1)}
.input.is-error{border-color:#d45a5a;box-shadow:0 0 0 4px rgba(212,90,90,.1)}
textarea.input{min-height:130px;resize:vertical}
.form-note{color:var(--muted);font-size:14px}
.form-alert{display:block;padding:14px 16px;border-radius:16px;background:#fff0f0;border:1px solid rgba(212,90,90,.24);color:#9f2d2d;font-size:14px;font-weight:600;margin:0 0 14px}
.form-alert[hidden]{display:none!important}
.form-alert--server{margin-bottom:16px}
.news-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.news-media{aspect-ratio:1.45/.82;background:#e3eaef}
.news-media img{width:100%;height:100%;object-fit:cover}
.news-card{overflow:hidden}
.news-body{padding:24px}
.news-date{font-size:13px;color:#688094;text-transform:uppercase;font-weight:800;letter-spacing:.08em;margin-bottom:8px}
.news-card h3{margin:0 0 10px;font-size:28px;line-height:1.04}
.news-card p{margin:0 0 16px;color:#405367;font-size:18px}
.contacts-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px}
.contact-card h3{margin:0 0 10px;font-size:28px}
.contact-list{display:grid;gap:14px;margin-top:18px}
.contact-item{display:grid;gap:6px}
.contact-item span{font-size:14px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:800}
.contact-item strong,.contact-item a{font-size:22px}
.social-inline{display:flex;gap:12px;flex-wrap:wrap}
.cooperation-layout{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr);gap:22px;align-items:stretch}
.cooperation-card{display:flex;flex-direction:column;justify-content:center}
.cooperation-media{border-radius:36px;overflow:hidden;background:#dce6eb;border:1px solid rgba(19,35,58,.08)}
.cooperation-media img{width:100%;height:100%;object-fit:cover;min-height:420px}
.question-card{max-width:860px;margin:0 auto;text-align:center}
.question-card .form-row{grid-template-columns:1fr 1fr}
.contact-scene{position:relative;overflow:hidden;padding:110px 0 36px;margin-top:30px;color:#fff}
.contact-scene__bg,.contact-scene__fade{position:absolute;inset:0}
.contact-scene__bg img{width:100%;height:100%;object-fit:cover}
.contact-scene__fade{background:linear-gradient(180deg,rgba(244,241,234,.92) 0%,rgba(244,241,234,.82) 28%,rgba(244,241,234,.45) 48%,rgba(18,31,45,.08) 62%,rgba(12,22,33,.58) 82%,rgba(10,18,28,.86) 100%)}
.contact-scene__inner{position:relative;z-index:1}
.contact-scene__grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(360px,.72fr);gap:42px;align-items:start}
.contact-scene__left{display:grid;gap:28px;color:var(--text)}
.contact-scene__copy{padding-top:18px}
.contact-scene__copy h2{margin:0 0 30px;font-size:clamp(42px,4.5vw,64px);line-height:.98;font-weight:300;text-transform:uppercase;color:#24384e}
.contact-columns{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(250px,.9fr);gap:22px 34px;align-items:start}
.contact-scene__label,.contact-scene__meta span{display:block;margin-bottom:12px;font-size:16px;font-weight:700;color:#203246}
.contact-scene__phone{display:inline-block;font-size:clamp(28px,2.9vw,48px);line-height:1.04;font-weight:300;color:var(--accent);margin-bottom:12px;max-width:100%;white-space:normal;overflow-wrap:anywhere;letter-spacing:-.02em}
.contact-scene__hours{font-size:18px;color:#334a60}
.contact-scene__aside{display:grid;gap:20px;align-content:start;padding-top:8px;min-width:0}
.contact-scene__meta a{font-size:clamp(18px,1.7vw,28px);color:var(--accent);word-break:break-word}
.social-inline--footer{gap:12px;align-items:center;flex-wrap:wrap;max-width:100%}
.social-square{width:48px;height:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:rgba(255,255,255,.82);border:1px solid rgba(40,79,110,.12);color:var(--accent);font-size:13px;font-weight:800;backdrop-filter:blur(10px);box-shadow:0 10px 24px rgba(40,79,110,.08);flex:0 0 auto}
.footer-promo{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:24px;align-items:center;padding:24px 26px;background:rgba(255,255,255,.9);border:1px solid rgba(255,255,255,.92);border-radius:28px;box-shadow:0 24px 60px rgba(19,35,58,.08);max-width:100%}
.footer-promo__eyebrow{margin-bottom:10px;font-size:15px;font-weight:800;letter-spacing:.04em;color:var(--accent)}
.footer-promo__copy p{margin:0;font-size:18px;line-height:1.55;color:#23384d}
.footer-promo__action .button{min-width:240px}
.contact-scene__form{display:flex;justify-content:flex-end}
.question-panel{width:100%;max-width:410px;padding:28px;background:rgba(255,255,255,.94);border:1px solid rgba(255,255,255,.95);border-radius:28px;box-shadow:0 30px 70px rgba(19,35,58,.12);color:var(--text)}
.question-panel h3{margin:0 0 14px;font-size:clamp(28px,3vw,40px);line-height:1.05}
.question-panel p{margin:0 0 18px;font-size:17px;line-height:1.5;color:#50657a}
.question-panel .form-note{font-size:14px;color:#748495}
.question-panel .button{width:100%}
.site-footer{padding:28px 0 0;color:#d6e1ea}
.site-footer__inner{display:grid;grid-template-columns:auto auto 1fr auto;gap:18px 26px;align-items:end;border-top:1px solid rgba(255,255,255,.16);padding-top:26px;max-width:100%}
.footer-links{display:flex;gap:22px;flex-wrap:wrap;justify-content:center}
.footer-links a{color:#dbe5ed}
.scenic-footer{margin-top:90px}
.scenic-footer__brand{display:grid;gap:10px}
.logo--footer img{height:54px;width:auto}
.scenic-footer__brand a:last-child{font-size:14px;color:#c7d4df;text-decoration:underline}
.scenic-footer__meta{font-size:14px;color:#c3d0db;align-self:center}
.scenic-footer__actions{display:flex;gap:16px;align-items:center;justify-content:flex-end;flex-wrap:wrap}
.scenic-footer__actions .header-phone{font-size:20px}
.section-anchor{position:relative;top:-100px;display:block;height:0;visibility:hidden}
.integration-card{margin-top:18px;padding:24px;border-radius:28px;border:1px solid rgba(19,35,58,.1);background:#fff}
.integration-head{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-bottom:14px}.integration-head h3{margin:0;font-size:24px}
.integration-embed iframe{width:100%;min-height:530px;border:0;border-radius:20px;background:#fff}
.integration-note{margin:14px 0 0;color:var(--muted)}
.success-box{padding:16px 18px;border-radius:18px;background:#e5f3e8;color:#25612d;font-weight:700;margin-bottom:18px}
.modal{position:fixed;inset:0;background:rgba(6,14,22,.65);display:none;align-items:center;justify-content:center;z-index:60;padding:20px}
.modal.active{display:flex}
.modal-card{width:min(980px,100%);max-height:90vh;overflow:auto;background:var(--card);border-radius:34px;box-shadow:0 30px 90px rgba(0,0,0,.25);position:relative}
.modal-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:999px;border:0;background:#fff;box-shadow:0 8px 20px rgba(0,0,0,.1);cursor:pointer;font-size:24px}
.modal-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr)}
.modal-media{background:#dce6eb;min-height:360px}.modal-media img{width:100%;height:100%;object-fit:cover}
.modal-body{padding:34px}.modal-body h3{margin:0 0 10px;font-size:42px;line-height:1}.modal-body p{font-size:18px;color:#3e5267}
.modal-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.popup,.lightbox{position:fixed;inset:0;display:none;align-items:center;justify-content:center;z-index:72;padding:20px;background:rgba(8,16,25,.68)}
.popup.active,.lightbox.active{display:flex}
.popup-card{width:min(980px,100%);max-height:calc(100vh - 40px);background:var(--card);border-radius:34px;box-shadow:0 30px 90px rgba(0,0,0,.26);position:relative;overflow:auto;-webkit-overflow-scrolling:touch}
.popup-close,.lightbox-close{position:absolute;top:18px;right:18px;width:44px;height:44px;border-radius:999px;border:0;background:#fff;box-shadow:0 8px 20px rgba(0,0,0,.12);cursor:pointer;font-size:24px;z-index:6}
.popup-layout{display:grid;grid-template-columns:minmax(0,.92fr) minmax(0,1.08fr)}
.popup-copy{padding:40px;background:linear-gradient(180deg,#284f6e 0%,#1f425d 100%);color:#fff}
.popup-copy h3{margin:16px 0 12px;font-size:clamp(34px,4vw,54px);line-height:.96}
.popup-copy p{margin:0 0 22px;font-size:18px;line-height:1.6;color:rgba(255,255,255,.86)}
.mini-chip--light{border-color:rgba(255,255,255,.24);background:rgba(255,255,255,.12);color:#fff}
.popup-phone{display:inline-flex;align-items:center;gap:10px;font-size:30px;font-weight:700;color:#fff;margin-top:12px}
.popup-phone::before{content:"☎";font-size:15px;opacity:.9}
.popup-subnote{margin:20px 0 12px;font-size:14px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.72)}
.popup-socials{display:flex;gap:12px;flex-wrap:wrap}
.popup-form-wrap{padding:40px}
.popup-form .button{width:100%;min-height:56px}
.lightbox-frame{width:min(1120px,100%);max-height:88vh;display:grid;gap:14px;justify-items:center}
.lightbox-frame img{max-width:100%;max-height:78vh;border-radius:26px;box-shadow:0 24px 70px rgba(0,0,0,.36)}
.lightbox-caption{color:#fff;font-size:16px;text-align:center}
.lightbox-arrow{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.14);color:#fff;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(10px)}
.lightbox-arrow--prev{left:20px}.lightbox-arrow--next{right:20px}
@media (max-width: 1200px){
  .hero-grid,.hero-card-grid,.about-grid,.booking-layout,.cooperation-layout,.contacts-grid,.properties-grid,.news-grid,.modal-grid,.contact-scene__grid,.contact-columns,.site-footer__inner,.popup-layout{grid-template-columns:1fr}
  .hero-right{grid-template-columns:1fr}
  .social-stack{flex-direction:row;padding-top:0}
  .contact-scene__form{justify-content:flex-start}
  .scenic-footer__actions{justify-content:flex-start}
  .hero__content{padding-bottom:150px}
}
@media (max-width: 960px){
  .site-header{padding:16px 0}
  .site-header__inner{grid-template-columns:auto 1fr auto;align-items:center;gap:14px}
  .logo{min-width:auto}
  .logo img{height:46px}
  .header-burger{display:inline-flex;position:relative;z-index:31}
  .header-panel{position:fixed;top:18px;right:12px;left:12px;display:flex;flex-direction:column;gap:22px;padding:92px 22px 26px;border-radius:28px;background:rgba(12,24,38,.96);backdrop-filter:blur(18px);border:1px solid rgba(255,255,255,.1);box-shadow:0 28px 60px rgba(0,0,0,.34);transform:translateY(-18px) scale(.98);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:30;max-height:calc(100vh - 36px);overflow:auto}
  .site-header.menu-open .header-panel{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}
  .header-backdrop{display:block;position:fixed;inset:0;border:0;background:rgba(4,10,18,.46);opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:29}
  .site-header.menu-open .header-backdrop{opacity:1;pointer-events:auto}
  .site-header.menu-open .header-burger span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .site-header.menu-open .header-burger span:nth-child(2){opacity:0}
  .site-header.menu-open .header-burger span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}
  .main-nav{flex-direction:column;align-items:flex-start;gap:16px;justify-content:flex-start}
  .main-nav a{font-size:26px;font-weight:700;line-height:1.1}
  .header-actions{flex-direction:column;align-items:stretch;gap:14px}
  .header-phone{justify-content:flex-start;font-size:22px;padding:12px 0;border-top:1px solid rgba(255,255,255,.12);margin-top:4px}
  .header-actions .button{width:100%}
  .footer-promo{grid-template-columns:1fr}
  .features-grid,.news-grid,.contacts-grid,.properties-grid,.form-row,.question-card .form-row{grid-template-columns:1fr}
  .hero-grid,.hero-card-grid,.about-grid,.booking-layout,.cooperation-layout,.contacts-grid,.news-grid,.modal-grid,.contact-scene__grid,.contact-columns,.site-footer__inner,.popup-layout{grid-template-columns:1fr}
  .hero-right{grid-template-columns:1fr;padding-top:18px;gap:18px}
  .social-stack{flex-direction:row;padding-top:0}
  .contact-scene__form,.scenic-footer__actions{justify-content:flex-start}
  .hero__content{padding:120px 0 140px;min-height:auto}
  .hero-title{font-size:clamp(38px,11vw,60px);max-width:100%}
  .hero-line{max-width:180px;margin-bottom:18px}
  .hero-text{font-size:17px;max-width:100%}
  .hero-card-wrap{margin-top:-64px}
  .hero-card{padding:26px;border-radius:28px}
  .hero-card-grid{gap:28px}
  .hero-card-title{font-size:clamp(34px,8vw,50px);margin-top:26px;padding-bottom:22px;max-width:100%}
  .hero-card-watermark{width:220px;right:-10px;bottom:-8px}
  .hero-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .hero-copy{font-size:17px}
  .section-head{flex-direction:column;align-items:flex-start}
  .about-visual{min-height:340px}
  .about-copy h2,.section-head h2,.intro-center h2,.booking-copy h2,.cooperation-card h2,.question-card h2{font-size:clamp(34px,8vw,52px)}
  .about-copy,.booking-copy,.booking-card,.cooperation-card,.question-card,.contact-card,.contact-scene__copy,.contact-scene__form{padding:24px}
  .feature-card h3{font-size:22px}
  .feature-card p,.property-description,.review-card p,.contact-card p{font-size:17px}
  .popup-copy,.popup-form-wrap{padding:26px}
  .lightbox-arrow{width:46px;height:46px}
}
@media (max-width: 640px){
  .container{width:min(calc(100% - 24px),var(--container))}
  .logo img{height:40px}
  .header-burger{width:48px;height:48px;border-radius:14px}
  .header-panel{top:10px;left:10px;right:10px;padding:78px 18px 22px;border-radius:24px}
  .main-nav a{font-size:22px}
  .header-phone{font-size:20px}
  .contact-scene{padding:78px 0 30px}
  .contact-scene__copy h2{font-size:38px;max-width:12ch}
  .contact-scene__phone{font-size:28px;line-height:1.08}
  .question-panel{padding:22px}
  .scenic-footer{margin-top:44px}
  .hero__content{padding:110px 0 116px}
  .hero-card-wrap{margin-top:-46px}
  .hero-card{border-radius:26px;padding:22px}
  .review-card{flex-basis:86vw}
  .carousel-arrows{display:none}
  .hero-gallery{gap:10px}
  .mini-chip,.chip{padding:10px 14px;font-size:12px}
  .social-square{width:48px;height:48px}
  .footer-promo{padding:22px 20px}
  .footer-promo__action .button,.button{min-width:100%}
  .hero-actions{width:100%}
  .hero-actions .button{width:100%}
  .property-body{padding:20px}
  .popup{padding:12px;align-items:flex-start;overflow:auto}
  .popup-card,.modal-card{border-radius:26px}
  .popup-card{max-height:none;width:100%;margin:18px 0 12px;padding-top:14px}
  .popup-close{top:10px;right:10px;width:40px;height:40px;font-size:22px}
  .popup-layout{grid-template-columns:1fr}
  .popup-copy,.popup-form-wrap{padding:22px 18px}
  .popup-form-wrap{padding-top:12px;padding-bottom:18px}
  .popup-form .button{min-height:52px}
  .question-panel{padding:20px 18px}
  .question-panel h3{font-size:32px}
  .question-panel p{font-size:16px}
  .form-note{font-size:13px;line-height:1.45}
  .popup-phone{font-size:24px}
  .lightbox-arrow{display:none}
  .lightbox-frame img{max-height:72vh}
  .lightbox-close{top:12px;right:12px}
}

@media (max-width: 900px){
  .contact-columns{gap:16px}
  .contact-scene__meta{gap:8px}
  .footer-promo__copy p{font-size:16px}
  .footer-promo__action .button{min-width:0;width:100%}
}
@media (max-width: 520px){
  .contact-scene__copy h2{font-size:32px;line-height:1.02}
  .contact-scene__phone{font-size:24px}
  .contact-scene__meta a{font-size:18px}
  .social-inline--footer{gap:10px}
  .social-square{width:42px;height:42px;border-radius:12px}
  .footer-promo{padding:18px 16px;border-radius:22px}
  .footer-promo__eyebrow{font-size:13px}
  .footer-promo__copy p{font-size:15px}
  .question-panel .button,.form-grid .button{padding:15px 18px}
  .success-box,.form-alert{font-size:13px;padding:12px 14px}
}


.site-toast{position:fixed;top:18px;left:50%;transform:translateX(-50%) translateY(-18px);z-index:1600;min-width:min(calc(100% - 28px),560px);max-width:min(calc(100% - 28px),560px);padding:15px 18px;border-radius:18px;box-shadow:0 20px 44px rgba(10,20,34,.22);font-weight:700;opacity:0;pointer-events:none;transition:opacity .28s ease,transform .28s ease}
.site-toast.is-visible{opacity:1;transform:translateX(-50%) translateY(0)}
.site-toast--success{background:#193e31;color:#fff}
.site-toast--error{background:#7d2430;color:#fff}
.map-section{padding-top:0}
.map-head{align-items:end;gap:20px}
.map-card{overflow:hidden;border-radius:32px;border:1px solid rgba(255,255,255,.08);background:#fff;box-shadow:0 22px 54px rgba(14,31,53,.1)}
.map-card iframe{display:block;width:100%;min-height:420px}
.news-page{padding-top:120px;min-height:100vh}
.news-single-card{background:var(--card);border-radius:34px;padding:34px;box-shadow:0 20px 54px rgba(13,27,43,.08)}
.breadcrumbs{display:flex;flex-wrap:wrap;gap:10px;color:var(--muted);font-size:14px;margin-bottom:18px}
.breadcrumbs a{color:var(--muted)}
.news-single-meta{display:inline-flex;padding:8px 12px;border-radius:999px;background:#eef3f6;color:#33516c;font-weight:700;margin-bottom:16px}
.news-single-card h1{margin:0 0 24px;font-size:clamp(32px,4vw,56px);line-height:1.04}
.news-single-media{overflow:hidden;border-radius:28px;aspect-ratio:16/8.5;margin-bottom:22px}
.news-single-media img{width:100%;height:100%;object-fit:cover}
.news-single-text{font-size:18px;line-height:1.75;color:#22384e}
.news-single-actions{margin-top:28px}
.section--compact{padding-bottom:0}
.site-header--page{position:fixed;top:0;left:0;right:0;background:rgba(17,35,53,.86);backdrop-filter:blur(18px)}
.main-nav--page a{color:#fff}
@media (max-width: 900px){
  .news-page{padding-top:92px}
  .news-single-card{padding:22px}
  .news-single-text{font-size:16px;line-height:1.65}
  .map-card iframe{min-height:320px}
  .site-toast{top:12px;padding:14px 16px;font-size:14px}
}


.notice-modal{position:fixed;inset:0;z-index:1700;display:none;align-items:center;justify-content:center;padding:20px}
.notice-modal.active{display:flex}
.notice-modal__backdrop{position:absolute;inset:0;background:rgba(12,22,36,.58);backdrop-filter:blur(6px)}
.notice-modal__card{position:relative;z-index:1;width:min(100%,520px);background:#fff;border-radius:30px;box-shadow:0 28px 80px rgba(8,18,34,.28);padding:34px 28px 28px;text-align:center;display:flex;flex-direction:column;gap:14px;align-items:center}
.notice-modal__card--success h3{color:#163a2b}
.notice-modal__card--error h3{color:#7d2430}
.notice-modal__icon{width:74px;height:74px;border-radius:999px;display:grid;place-items:center;font-size:34px;font-weight:800;background:#e7f5ec;color:#1e6a3f}
.notice-modal__card--error .notice-modal__icon{background:#fff1f2;color:#9f2d2d}
.notice-modal__card h3{margin:0;font-size:32px;line-height:1.05}
.notice-modal__card p{margin:0;color:#42566b;font-size:17px;line-height:1.6;max-width:36ch}
.notice-modal__close{position:absolute;top:14px;right:14px;width:42px;height:42px;border:none;border-radius:999px;background:#f2f5f8;color:#16324d;font-size:24px;cursor:pointer}
.contact-scene--innerpage{padding-top:0}
.contact-scene--innerpage .contact-scene__inner{padding-top:0}
@media (max-width: 767px){
  .notice-modal{padding:14px}
  .notice-modal__card{padding:28px 18px 22px;border-radius:24px;width:min(100%,420px)}
  .notice-modal__icon{width:62px;height:62px;font-size:30px}
  .notice-modal__card h3{font-size:28px}
  .notice-modal__card p{font-size:15px}
}
