/*!********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[2].use[1]!./node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[13].oneOf[2].use[2]!./node_modules/next/font/google/target.css?{"path":"src/app/layout.tsx","import":"Manrope","arguments":[{"subsets":["latin","cyrillic"],"variable":"--font-manrope","display":"swap"}],"variableName":"manrope"} ***!
  \********************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* cyrillic-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/438aa629764e75f3-s.woff2) format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/875ae681bfde4580-s.p.woff2) format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* greek */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/51251f8b9793cdb3-s.woff2) format('woff2');
  unicode-range: U+0370-0377, U+037A-037F, U+0384-038A, U+038C, U+038E-03A1, U+03A3-03FF;
}
/* vietnamese */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/e857b654a2caa584-s.woff2) format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/cc978ac5ee68c2b6-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Manrope';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url(/_next/static/media/4c9affa5bc8f420e-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Manrope Fallback';src: local("Arial");ascent-override: 103.31%;descent-override: 29.07%;line-gap-override: 0.00%;size-adjust: 103.19%
}.__className_fe7774 {font-family: 'Manrope', 'Manrope Fallback';font-style: normal
}.__variable_fe7774 {--font-manrope: 'Manrope', 'Manrope Fallback'
}

/*!*****************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[2]!./node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[13].oneOf[10].use[3]!./src/app/globals.css ***!
  \*****************************************************************************************************************************************************************************************************************************************************************/
*, ::before, ::after {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}

::backdrop {
  --tw-border-spacing-x: 0;
  --tw-border-spacing-y: 0;
  --tw-translate-x: 0;
  --tw-translate-y: 0;
  --tw-rotate: 0;
  --tw-skew-x: 0;
  --tw-skew-y: 0;
  --tw-scale-x: 1;
  --tw-scale-y: 1;
  --tw-pan-x:  ;
  --tw-pan-y:  ;
  --tw-pinch-zoom:  ;
  --tw-scroll-snap-strictness: proximity;
  --tw-gradient-from-position:  ;
  --tw-gradient-via-position:  ;
  --tw-gradient-to-position:  ;
  --tw-ordinal:  ;
  --tw-slashed-zero:  ;
  --tw-numeric-figure:  ;
  --tw-numeric-spacing:  ;
  --tw-numeric-fraction:  ;
  --tw-ring-inset:  ;
  --tw-ring-offset-width: 0px;
  --tw-ring-offset-color: #fff;
  --tw-ring-color: rgb(59 130 246 / 0.5);
  --tw-ring-offset-shadow: 0 0 #0000;
  --tw-ring-shadow: 0 0 #0000;
  --tw-shadow: 0 0 #0000;
  --tw-shadow-colored: 0 0 #0000;
  --tw-blur:  ;
  --tw-brightness:  ;
  --tw-contrast:  ;
  --tw-grayscale:  ;
  --tw-hue-rotate:  ;
  --tw-invert:  ;
  --tw-saturate:  ;
  --tw-sepia:  ;
  --tw-drop-shadow:  ;
  --tw-backdrop-blur:  ;
  --tw-backdrop-brightness:  ;
  --tw-backdrop-contrast:  ;
  --tw-backdrop-grayscale:  ;
  --tw-backdrop-hue-rotate:  ;
  --tw-backdrop-invert:  ;
  --tw-backdrop-opacity:  ;
  --tw-backdrop-saturate:  ;
  --tw-backdrop-sepia:  ;
  --tw-contain-size:  ;
  --tw-contain-layout:  ;
  --tw-contain-paint:  ;
  --tw-contain-style:  ;
}/*
! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com
*//*
1. Prevent padding and border from affecting element width. (https://github.com/mozdevs/cssremedy/issues/4)
2. Allow adding a border to an element by just adding a border-width. (https://github.com/tailwindcss/tailwindcss/pull/116)
*/

*,
::before,
::after {
  box-sizing: border-box; /* 1 */
  border-width: 0; /* 2 */
  border-style: solid; /* 2 */
  border-color: #e5e7eb; /* 2 */
}

::before,
::after {
  --tw-content: '';
}

/*
1. Use a consistent sensible line-height in all browsers.
2. Prevent adjustments of font size after orientation changes in iOS.
3. Use a more readable tab size.
4. Use the user's configured `sans` font-family by default.
5. Use the user's configured `sans` font-feature-settings by default.
6. Use the user's configured `sans` font-variation-settings by default.
7. Disable tap highlights on iOS
*/

html,
:host {
  line-height: 1.5; /* 1 */
  -webkit-text-size-adjust: 100%; /* 2 */
  -moz-tab-size: 4; /* 3 */
  -o-tab-size: 4;
     tab-size: 4; /* 3 */
  font-family: var(--font-manrope), system-ui, sans-serif; /* 4 */
  font-feature-settings: normal; /* 5 */
  font-variation-settings: normal; /* 6 */
  -webkit-tap-highlight-color: transparent; /* 7 */
}

/*
1. Remove the margin in all browsers.
2. Inherit line-height from `html` so users can set them as a class directly on the `html` element.
*/

body {
  margin: 0; /* 1 */
  line-height: inherit; /* 2 */
}

/*
1. Add the correct height in Firefox.
2. Correct the inheritance of border color in Firefox. (https://bugzilla.mozilla.org/show_bug.cgi?id=190655)
3. Ensure horizontal rules are visible by default.
*/

hr {
  height: 0; /* 1 */
  color: inherit; /* 2 */
  border-top-width: 1px; /* 3 */
}

/*
Add the correct text decoration in Chrome, Edge, and Safari.
*/

abbr:where([title]) {
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

/*
Remove the default font size and weight for headings.
*/

h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
  font-weight: inherit;
}

/*
Reset links to optimize for opt-in styling instead of opt-out.
*/

a {
  color: inherit;
  text-decoration: inherit;
}

/*
Add the correct font weight in Edge and Safari.
*/

b,
strong {
  font-weight: bolder;
}

/*
1. Use the user's configured `mono` font-family by default.
2. Use the user's configured `mono` font-feature-settings by default.
3. Use the user's configured `mono` font-variation-settings by default.
4. Correct the odd `em` font sizing in all browsers.
*/

code,
kbd,
samp,
pre {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; /* 1 */
  font-feature-settings: normal; /* 2 */
  font-variation-settings: normal; /* 3 */
  font-size: 1em; /* 4 */
}

/*
Add the correct font size in all browsers.
*/

small {
  font-size: 80%;
}

/*
Prevent `sub` and `sup` elements from affecting the line height in all browsers.
*/

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

/*
1. Remove text indentation from table contents in Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=999088, https://bugs.webkit.org/show_bug.cgi?id=201297)
2. Correct table border color inheritance in all Chrome and Safari. (https://bugs.chromium.org/p/chromium/issues/detail?id=935729, https://bugs.webkit.org/show_bug.cgi?id=195016)
3. Remove gaps between table borders by default.
*/

table {
  text-indent: 0; /* 1 */
  border-color: inherit; /* 2 */
  border-collapse: collapse; /* 3 */
}

/*
1. Change the font styles in all browsers.
2. Remove the margin in Firefox and Safari.
3. Remove default padding in all browsers.
*/

button,
input,
optgroup,
select,
textarea {
  font-family: inherit; /* 1 */
  font-feature-settings: inherit; /* 1 */
  font-variation-settings: inherit; /* 1 */
  font-size: 100%; /* 1 */
  font-weight: inherit; /* 1 */
  line-height: inherit; /* 1 */
  letter-spacing: inherit; /* 1 */
  color: inherit; /* 1 */
  margin: 0; /* 2 */
  padding: 0; /* 3 */
}

/*
Remove the inheritance of text transform in Edge and Firefox.
*/

button,
select {
  text-transform: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Remove default button styles.
*/

button,
input:where([type='button']),
input:where([type='reset']),
input:where([type='submit']) {
  -webkit-appearance: button; /* 1 */
  background-color: transparent; /* 2 */
  background-image: none; /* 2 */
}

/*
Use the modern Firefox focus style for all focusable elements.
*/

:-moz-focusring {
  outline: auto;
}

/*
Remove the additional `:invalid` styles in Firefox. (https://github.com/mozilla/gecko-dev/blob/2f9eacd9d3d995c937b4251a5557d95d494c9be1/layout/style/res/forms.css#L728-L737)
*/

:-moz-ui-invalid {
  box-shadow: none;
}

/*
Add the correct vertical alignment in Chrome and Firefox.
*/

progress {
  vertical-align: baseline;
}

/*
Correct the cursor style of increment and decrement buttons in Safari.
*/

::-webkit-inner-spin-button,
::-webkit-outer-spin-button {
  height: auto;
}

/*
1. Correct the odd appearance in Chrome and Safari.
2. Correct the outline style in Safari.
*/

[type='search'] {
  -webkit-appearance: textfield; /* 1 */
  outline-offset: -2px; /* 2 */
}

/*
Remove the inner padding in Chrome and Safari on macOS.
*/

::-webkit-search-decoration {
  -webkit-appearance: none;
}

/*
1. Correct the inability to style clickable types in iOS and Safari.
2. Change font properties to `inherit` in Safari.
*/

::-webkit-file-upload-button {
  -webkit-appearance: button; /* 1 */
  font: inherit; /* 2 */
}

/*
Add the correct display in Chrome and Safari.
*/

summary {
  display: list-item;
}

/*
Removes the default spacing and border for appropriate elements.
*/

blockquote,
dl,
dd,
h1,
h2,
h3,
h4,
h5,
h6,
hr,
figure,
p,
pre {
  margin: 0;
}

fieldset {
  margin: 0;
  padding: 0;
}

legend {
  padding: 0;
}

ol,
ul,
menu {
  list-style: none;
  margin: 0;
  padding: 0;
}

/*
Reset default styling for dialogs.
*/
dialog {
  padding: 0;
}

/*
Prevent resizing textareas horizontally by default.
*/

textarea {
  resize: vertical;
}

/*
1. Reset the default placeholder opacity in Firefox. (https://github.com/tailwindlabs/tailwindcss/issues/3300)
2. Set the default placeholder color to the user's configured gray 400 color.
*/

input::-moz-placeholder, textarea::-moz-placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

input::placeholder,
textarea::placeholder {
  opacity: 1; /* 1 */
  color: #9ca3af; /* 2 */
}

/*
Set the default cursor for buttons.
*/

button,
[role="button"] {
  cursor: pointer;
}

/*
Make sure disabled buttons don't get the pointer cursor.
*/
:disabled {
  cursor: default;
}

/*
1. Make replaced elements `display: block` by default. (https://github.com/mozdevs/cssremedy/issues/14)
2. Add `vertical-align: middle` to align replaced elements more sensibly by default. (https://github.com/jensimmons/cssremedy/issues/14#issuecomment-634934210)
   This can trigger a poorly considered lint error in some tools but is included by design.
*/

img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block; /* 1 */
  vertical-align: middle; /* 2 */
}

/*
Constrain images and videos to the parent width and preserve their intrinsic aspect ratio. (https://github.com/mozdevs/cssremedy/issues/14)
*/

img,
video {
  max-width: 100%;
  height: auto;
}

/* Make elements with the HTML hidden attribute stay hidden by default */
[hidden]:where(:not([hidden="until-found"])) {
  display: none;
}
.block {
  display: block;
}
.flex {
  display: flex;
}
.hidden {
  display: none;
}
.transform {
  transform: translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y));
}
.uppercase {
  text-transform: uppercase;
}
.filter {
  filter: var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow);
}

/* ===== Дизайн-система перенесена из прототипа (borderless, radius:0) ===== */
/* ============ СБРОС / ТОКЕНЫ ============ */
:root{
  --teal:#0E7C86;
  --teal-deep:#0A5C64;
  --sand:#F2E7CE;
  --sand-deep:#E9D8B4;
  --white:#FFFFFF;
  --mist:#F6F9FA;
  --ink:#1E2A2E;
  --ink-soft:#3A4A4F;
  --line-on-dark:#2C3A3E;
  --maxw:1200px;
}
*,*::before,*::after{
  box-sizing:border-box;
  border-radius:0 !important;   /* жёсткое требование: прямые углы везде */
  margin:0;
  padding:0;
}
html{scroll-behavior:smooth;scroll-padding-top:118px;}
body{
  font-family:var(--font-manrope),system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  color:var(--ink);
  background:var(--white);
  line-height:1.55;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}
ul{list-style:none;}
input,textarea{font-family:inherit;font-size:16px;}

/* ============ УТИЛИТЫ ============ */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%;}
.eyebrow{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);}
.h-sec{font-size:clamp(28px,4.4vw,46px);font-weight:800;line-height:1.05;letter-spacing:-.02em;}
.sub{font-size:clamp(15px,1.6vw,18px);color:var(--ink-soft);font-weight:500;}
.pin{display:inline-flex;align-items:center;gap:6px;color:var(--ink-soft);font-size:14px;font-weight:600;}

/* кнопки */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:15px;padding:14px 26px;min-height:48px;
  transition:background .15s ease, color .15s ease;letter-spacing:.01em;text-align:center;}
.btn--primary{background:var(--teal);color:#fff;}
.btn--primary:hover{background:var(--teal-deep);}
.btn--sand{background:var(--sand);color:var(--ink);}
.btn--sand:hover{background:var(--sand-deep);}
.btn--ghost-light{background:rgba(255,255,255,.16);color:#fff;}
.btn--ghost-light:hover{background:rgba(255,255,255,.28);}
.btn--block{width:100%;}

/* плейсхолдер фото */
.ph{position:relative;background:#D7E0E2;color:#5C6B6F;display:flex;align-items:center;
  justify-content:center;text-align:center;font-weight:700;font-size:14px;letter-spacing:.02em;
  background-image:repeating-linear-gradient(135deg,#D7E0E2 0 14px,#CDD8DA 14px 28px);}
.ph span{background:rgba(30,42,46,.62);color:#fff;padding:7px 12px;font-size:12.5px;font-weight:700;letter-spacing:.04em;}

/* чипы / теги / бейджи */
.chip{display:inline-flex;align-items:center;gap:6px;background:var(--mist);color:var(--ink);
  font-size:13px;font-weight:700;padding:7px 11px;}
.tag{display:inline-flex;align-items:center;background:var(--sand);color:var(--ink-soft);
  font-size:12.5px;font-weight:600;padding:5px 10px;}
.badge{background:var(--teal);color:#fff;font-size:12px;font-weight:800;letter-spacing:.04em;
  text-transform:uppercase;padding:6px 11px;}

.ico{width:22px;height:22px;flex:none;stroke:currentColor;stroke-width:1.8;fill:none;
  stroke-linecap:round;stroke-linejoin:round;}
.ico-sm{width:18px;height:18px;}

/* ============ ШАПКА ============ */
.topbar{background:var(--ink);color:#C6D2D4;}
.topbar .wrap{display:flex;gap:26px;align-items:center;flex-wrap:wrap;
  min-height:38px;padding-top:8px;padding-bottom:8px;font-size:12.5px;font-weight:600;}
.topbar .addr{display:inline-flex;gap:7px;align-items:flex-start;}
.topbar .ico{stroke:#7FA9AC;}

.head{position:sticky;top:0;z-index:60;background:var(--white);}
.head .wrap{display:flex;align-items:center;gap:20px;min-height:78px;padding-top:12px;padding-bottom:12px;}
.brand{display:flex;align-items:center;gap:14px;flex:1;min-width:0;}
.emblem{width:50px;height:50px;background:var(--teal);color:#fff;display:flex;align-items:center;
  justify-content:center;flex:none;}
.emblem svg{width:30px;height:30px;}
.brand-txt{min-width:0;}
.brand-names{display:flex;flex-wrap:wrap;gap:4px 14px;font-weight:800;font-size:16px;line-height:1.1;letter-spacing:-.01em;}
.brand-names b{font-weight:800;}
.brand-names .dot{color:var(--teal);}
.brand-desc{font-size:12.5px;color:var(--ink-soft);font-weight:600;margin-top:3px;}

.head-actions{display:flex;align-items:center;gap:16px;}
.tel{display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:18px;white-space:nowrap;}
.tel .ico{stroke:var(--teal);}
.msgs{display:flex;gap:8px;}
.msg-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  background:var(--mist);color:var(--ink);transition:background .15s;}
.msg-btn:hover{background:var(--sand);}
.msg-btn svg{width:22px;height:22px;}
.tg{color:#229ED9;} .wa{color:#1FAF54;} .mx{color:var(--teal);font-weight:800;font-size:13px;}

.burger{display:none;width:48px;height:48px;background:var(--teal);color:#fff;align-items:center;justify-content:center;flex:none;}
.burger svg{width:26px;height:26px;stroke:#fff;}

/* нижняя строка меню (десктоп) */
.navbar{background:var(--mist);}
.navbar .wrap{display:flex;gap:4px;flex-wrap:wrap;min-height:46px;align-items:center;}
.navbar a{font-size:13.5px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;
  padding:12px 14px;color:var(--ink-soft);transition:color .15s,background .15s;}
.navbar a:hover{color:var(--teal);background:var(--white);}

/* ============ ВВОДНЫЙ ЭКРАН ============ */
.intro{position:relative;overflow:hidden;background:var(--white);}
.intro-bg{-o-object-fit:cover;object-fit:cover;z-index:0;}
.intro::after{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(90deg,rgba(246,249,250,.8) 0%,rgba(246,249,250,.46) 40%,rgba(246,249,250,.1) 100%);}
.intro .wrap{position:relative;z-index:1;display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;
  min-height:clamp(360px,50vh,500px);padding-top:54px;padding-bottom:54px;}
.intro h1{font-size:clamp(32px,5vw,54px);font-weight:800;line-height:1.03;letter-spacing:-.025em;}
.intro .lead{font-size:clamp(16px,1.8vw,20px);color:var(--ink-soft);font-weight:600;margin-top:18px;max-width:30ch;}
.intro .cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:30px;}
.intro-media{position:relative;height:clamp(300px,42vh,440px);}
.intro-media .ph{position:absolute;inset:0;font-size:15px;}
.geo1{position:absolute;width:108px;height:108px;background:var(--teal);left:-22px;top:-22px;z-index:2;}
.geo2{position:absolute;width:84px;height:84px;background:var(--sand);right:-18px;bottom:-18px;z-index:2;}
.geo3{position:absolute;width:0;height:0;border-left:54px solid transparent;border-right:54px solid transparent;
  border-bottom:80px solid var(--sand-deep);right:34px;top:-40px;z-index:2;}

/* ============ ЛЕНТА ФАКТОВ ============ */
.facts{background:var(--mist);}
.facts .wrap{padding-top:26px;padding-bottom:26px;display:grid;
  grid-template-columns:repeat(4,1fr);gap:0;}
.fact{background:var(--white);display:flex;align-items:center;gap:12px;padding:18px 16px;font-weight:700;font-size:14px;}
.fact .ico{stroke:var(--teal);flex:none;width:34px;height:34px;}

/* ---- страница гостиницы ---- */
.hotel-hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:46px;align-items:center;padding-top:48px;padding-bottom:48px;}
.hotel-hero h1{font-size:clamp(30px,4.6vw,50px);font-weight:800;line-height:1.04;letter-spacing:-.025em;}
.hotel-hero .pin{margin-top:16px;font-size:15px;}
.hotel-hero p{font-size:17px;color:var(--ink-soft);font-weight:500;margin-top:14px;max-width:44ch;line-height:1.65;}
.hotel-hero .cta-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px;}
.hotel-facts{background:var(--mist);}
.hotel-facts .wrap{padding-top:26px;padding-bottom:26px;}
.hfacts{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;}

/* ============ СЕКЦИИ (общий ритм) ============ */
.section{padding-top:64px;padding-bottom:64px;}
.sec-white{background:var(--white);}
.sec-mist{background:var(--mist);}
.sec-sand{background:var(--sand);}

.sec-head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:34px;}
.sec-head .right{max-width:40ch;text-align:right;}
.sec-head.center{flex-direction:column;align-items:center;text-align:center;}

/* ============ НАШИ ГОСТИНИЦЫ ============ */
.hotels-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.hotel-card{background:var(--white);display:flex;flex-direction:column;}
.hotel-card .ph{height:200px;}
.hotel-card .body{padding:22px;display:flex;flex-direction:column;gap:12px;flex:1;}
.hotel-card h3{font-size:22px;font-weight:800;}
.hotel-card p{font-size:14.5px;color:var(--ink-soft);font-weight:500;flex:1;}
.hotel-card .btn{margin-top:6px;}

/* ============ КАТАЛОГ НОМЕРОВ ============ */
.tabs{display:flex;flex-wrap:wrap;gap:2px;justify-content:center;margin-bottom:34px;}
.tab{font-size:15px;font-weight:800;padding:14px 22px;color:var(--ink-soft);
  background:var(--white);border-bottom:3px solid transparent;transition:color .15s,border-color .15s;}
.tab[aria-selected="true"]{color:var(--teal);border-bottom-color:var(--teal);}
.rooms{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.room-card{background:var(--white);display:flex;flex-direction:column;}
.sec-mist .room-card{background:var(--white);}
.room-card .media{position:relative;}
.room-card .ph{height:188px;}
.room-card .media .badge{position:absolute;left:0;top:0;}
.room-card .body{padding:20px;display:flex;flex-direction:column;gap:13px;flex:1;}
.room-top{display:flex;justify-content:space-between;align-items:baseline;gap:12px;}
.room-top h3{font-size:19px;font-weight:800;}
.price{white-space:nowrap;text-align:right;}
.price b{font-size:20px;font-weight:800;color:var(--teal);}
.price span{display:block;font-size:12px;color:var(--ink-soft);font-weight:600;}
.chips{display:flex;flex-wrap:wrap;gap:8px;}
.tags{display:flex;flex-wrap:wrap;gap:6px;}
.room-card .actions{display:flex;gap:10px;margin-top:auto;padding-top:4px;}
.room-card .actions .btn{flex:1;padding:13px 14px;font-size:14px;}

/* ============ ПРЕИМУЩЕСТВА ============ */
.adv{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:center;}
.adv-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--sand-deep);}
.adv-item{background:var(--sand);padding:24px;display:flex;flex-direction:column;gap:11px;}
.adv-item .ico{stroke:var(--teal);width:30px;height:30px;}
.adv-head{display:flex;align-items:center;gap:14px;}
.adv-ico{flex-shrink:0;width:48px;height:48px;-o-object-fit:contain;object-fit:contain;}
.adv-item h4{font-size:18px;font-weight:800;}
.adv-item p{font-size:14px;color:var(--ink-soft);font-weight:500;}
.collage{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:2px;height:100%;min-height:360px;}
.collage .ph{height:100%;font-size:12px;}

/* ============ CTA ПОЛОСА ============ */
.cta-band{background:var(--teal);color:#fff;}
.cta-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:26px;
  flex-wrap:wrap;padding-top:40px;padding-bottom:40px;}
.cta-band h3{font-size:clamp(22px,2.8vw,30px);font-weight:800;max-width:24ch;line-height:1.15;}

/* ============ ТЕКСТОВЫЙ БЛОК ============ */
.textblock{max-width:880px;}
.textblock h2{font-size:clamp(26px,3.6vw,40px);font-weight:800;line-height:1.1;letter-spacing:-.02em;}
.textblock .welcome{font-size:18px;font-weight:700;color:var(--teal);margin-top:16px;}
.textblock p{font-size:17px;color:var(--ink-soft);font-weight:500;margin-top:14px;line-height:1.7;}

/* ============ ГАЛЕРЕЯ ============ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;}
.gallery .ph{height:230px;}

/* ============ ОТЗЫВЫ ============ */
.reviews-section{position:relative;overflow:hidden;}
.reviews-bg{-o-object-fit:cover;object-fit:cover;z-index:0;}
.reviews-section::after{content:"";position:absolute;inset:0;z-index:0;background:rgba(242,231,206,.6);}
.reviews-section .wrap{position:relative;z-index:1;}
.reviews{position:relative;}
.review-track{overflow:hidden;}
.review-row{display:flex;transition:transform .4s ease;}
.review{flex:0 0 100%;padding:8px 4px;}
.review-inner{background:var(--white);padding:34px;max-width:760px;margin:0 auto;}
.stars{color:var(--teal);font-size:18px;letter-spacing:3px;font-weight:800;margin-bottom:14px;}
.review-text{font-size:19px;font-weight:600;line-height:1.55;}
.review-by{margin-top:18px;font-weight:800;font-size:15px;}
.review-by span{color:var(--ink-soft);font-weight:600;}
.review-nav{display:flex;justify-content:center;gap:10px;margin-top:24px;}
.dot-btn{width:40px;height:40px;background:var(--white);color:var(--ink);display:flex;align-items:center;justify-content:center;transition:background .15s;}
.dot-btn:hover{background:var(--teal);color:#fff;}
.dots{display:flex;gap:7px;align-items:center;}
.dots button{width:11px;height:11px;background:var(--sand-deep);}
.dots button[aria-current="true"]{background:var(--teal);}

/* ============ FAQ ============ */
.faq{max-width:840px;margin:0 auto;display:flex;flex-direction:column;gap:2px;background:var(--mist);}
.faq-item{background:var(--white);}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:16px;
  text-align:left;padding:22px 24px;font-size:17px;font-weight:800;}
.faq-q .ico{stroke:var(--teal);transition:transform .2s;flex:none;}
.faq-item.open .faq-q .ico{transform:rotate(45deg);}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease;}
.faq-a p{padding:0 24px 24px;font-size:15.5px;color:var(--ink-soft);font-weight:500;}

/* ============ КОНТАКТЫ ============ */
.contacts{display:grid;grid-template-columns:.85fr 1.15fr;gap:42px;align-items:start;}
.contact-block{display:flex;flex-direction:column;gap:26px;}
.contact-row{display:flex;gap:16px;}
.contact-ic{width:48px;height:48px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;flex:none;}
.contact-ic svg{width:24px;height:24px;stroke:#fff;}
.contact-row h4{font-size:14px;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);font-weight:700;margin-bottom:6px;}
.contact-row a,.contact-row p{font-size:17px;font-weight:700;}
.contact-row p{font-weight:600;color:var(--ink-soft);font-size:15px;line-height:1.5;}
.addr-group+.addr-group{margin-top:16px;}
.addr-region{color:var(--ink);font-weight:700;}
.map{position:relative;height:380px;background:#CBD8DA;
  background-image:repeating-linear-gradient(90deg,#CBD8DA 0 38px,#C2D1D3 38px 76px),
                   repeating-linear-gradient(0deg,#CBD8DA 0 38px,#C2D1D3 38px 76px);}
.map .marker{position:absolute;transform:translate(-50%,-100%);display:flex;flex-direction:column;align-items:center;}
.map .marker b{background:var(--ink);color:#fff;font-size:11px;font-weight:700;padding:4px 8px;white-space:nowrap;}
.map .marker i{width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:9px solid var(--teal);}
.map .marker em{width:14px;height:14px;background:var(--teal);margin-top:-1px;}

/* ============ ФУТЕР ============ */
.footer{position:relative;overflow:hidden;background:var(--ink);color:#AEBDBF;}
.footer-bg{-o-object-fit:cover;object-fit:cover;z-index:0;opacity:.16;}
.footer .wrap{position:relative;z-index:1;padding-top:48px;padding-bottom:30px;}
.footer-top{display:flex;justify-content:space-between;gap:30px;flex-wrap:wrap;padding-bottom:28px;}
.footer-brand{display:flex;gap:14px;align-items:center;}
.footer-brand .emblem{width:46px;height:46px;}
.footer-brand b{color:#fff;font-size:18px;font-weight:800;display:block;}
.footer-brand span{font-size:13px;}
.footer-links{display:flex;gap:8px 26px;flex-wrap:wrap;align-items:center;}
.footer-links a{font-weight:700;font-size:14px;color:#CBD7D9;}
.footer-links a:hover{color:#fff;}
.footer-legal{padding-top:22px;font-size:12.5px;line-height:1.9;color:#8A9A9C;}
.footer-legal .reg{display:flex;flex-wrap:wrap;gap:4px 22px;margin-top:8px;}

/* плавающая кнопка связи (моб.) */
.fab{display:none;position:fixed;right:18px;bottom:18px;z-index:55;width:60px;height:60px;
  background:var(--teal);color:#fff;align-items:center;justify-content:center;}
.fab svg{width:30px;height:30px;stroke:#fff;}

/* ============ COOKIE ============ */
.cookie{position:fixed;left:0;right:0;bottom:0;z-index:80;background:var(--ink);color:#D6E0E1;
  padding:16px 24px;display:flex;align-items:center;gap:20px;flex-wrap:wrap;justify-content:center;}
.cookie p{font-size:14px;font-weight:500;max-width:70ch;}
.cookie a{color:#fff;text-decoration:underline;}

/* ============ МОДАЛКА БРОНИ ============ */
.overlay{position:fixed;inset:0;z-index:90;background:rgba(15,24,26,.62);
  display:none;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto;}
.overlay.show{display:flex;}
.modal{background:#fff;width:100%;max-width:520px;}
.modal-head{background:var(--teal);color:#fff;padding:22px 26px;display:flex;justify-content:space-between;align-items:center;}
.modal-head h3{font-size:21px;font-weight:800;}
.modal-close{width:40px;height:40px;color:#fff;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.16);}
.modal-close:hover{background:rgba(255,255,255,.3);}
.modal-body{padding:26px;}
.field{margin-bottom:16px;}
.field label{display:block;font-size:13px;font-weight:700;color:var(--ink-soft);margin-bottom:7px;letter-spacing:.02em;}
.field input,.field textarea{width:100%;background:var(--mist);padding:13px 14px;color:var(--ink);
  border:none;outline:2px solid transparent;outline-offset:-2px;transition:outline-color .15s,background .15s;}
.field input:focus,.field textarea:focus{outline-color:var(--teal);background:#fff;}
.field textarea{resize:vertical;min-height:84px;}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.consent{display:flex;gap:11px;align-items:flex-start;margin:6px 0 20px;}
.consent input{width:22px;height:22px;flex:none;margin-top:1px;accent-color:var(--teal);}
.consent label{font-size:13px;color:var(--ink-soft);font-weight:500;line-height:1.5;}
.thanks{padding:46px 30px;text-align:center;}
.thanks .ok{width:72px;height:72px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;margin:0 auto 22px;}
.thanks .ok svg{width:40px;height:40px;stroke:#fff;stroke-width:2.4;}
.thanks h3{font-size:26px;font-weight:800;}
.thanks p{color:var(--ink-soft);font-weight:500;margin-top:10px;}

/* ============ БУРГЕР-ПАНЕЛЬ (моб.) ============ */
.drawer{position:fixed;inset:0;z-index:85;display:none;}
.drawer.show{display:block;}
.drawer-bg{position:absolute;inset:0;background:rgba(15,24,26,.55);}
.drawer-panel{position:absolute;right:0;top:0;height:100%;width:min(360px,88vw);background:#fff;
  overflow-y:auto;transform:translateX(100%);transition:transform .25s ease;}
.drawer.show .drawer-panel{transform:translateX(0);}
.drawer-head{background:var(--ink);color:#fff;padding:18px 22px;display:flex;justify-content:space-between;align-items:center;}
.drawer-head b{font-weight:800;font-size:16px;}
.drawer-head button{width:42px;height:42px;color:#fff;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.14);}
.drawer nav{padding:8px 0 26px;}
.drawer .grp>button{width:100%;display:flex;justify-content:space-between;align-items:center;
  padding:16px 22px;font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.02em;text-align:left;}
.drawer .grp>button .ico{stroke:var(--teal);transition:transform .2s;}
.drawer .grp.open>button .ico{transform:rotate(180deg);}
.drawer .grp .subs{max-height:0;overflow:hidden;transition:max-height .22s ease;background:var(--mist);}
.drawer .grp .subs a{display:block;padding:12px 34px;font-weight:700;font-size:14px;color:var(--ink-soft);}
.drawer .single{display:block;padding:16px 22px;font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.02em;}
.drawer .single:hover,.drawer .grp .subs a:hover{color:var(--teal);}
.drawer-msgs{display:flex;gap:10px;padding:18px 22px;background:var(--mist);}
.drawer-msgs .msg-btn{flex:1;height:50px;}

/* ============ СТРАНИЦА НОМЕРА ============ */


.room-page{padding-top:30px;padding-bottom:70px;}
.back{display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--ink-soft);
  background:var(--mist);padding:11px 18px;margin-bottom:24px;}
.back:hover{background:var(--sand);color:var(--ink);}
.room-layout{display:grid;grid-template-columns:1.45fr .9fr;gap:36px;align-items:start;}
.room-gallery{display:grid;grid-template-columns:1fr 1fr;gap:2px;}
.room-gallery .main{grid-column:1 / -1;position:relative;}
.room-gallery .main .ph{height:380px;}
.room-gallery .main .badge{position:absolute;left:0;top:0;}
.room-gallery .mini .ph{height:180px;}
.room-page h1{font-size:clamp(26px,3.4vw,38px);font-weight:800;letter-spacing:-.02em;margin-top:26px;}
.room-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;}
.room-section{margin-top:34px;}
.room-section h3{font-size:20px;font-weight:800;margin-bottom:14px;}
.room-section p{font-size:16px;color:var(--ink-soft);font-weight:500;line-height:1.7;}
.amen-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--mist);}
.amen{background:#fff;display:flex;align-items:center;gap:11px;padding:16px;font-weight:700;font-size:14px;}
.amen .ico{stroke:var(--teal);flex:none;}
.book-side{position:sticky;top:130px;background:var(--mist);padding:26px;}
.book-side .bp{display:flex;align-items:baseline;gap:8px;margin-bottom:18px;}
.book-side .bp b{font-size:30px;font-weight:800;color:var(--teal);}
.book-side .bp span{color:var(--ink-soft);font-weight:600;font-size:14px;}
.book-side .field input{background:#fff;}
.book-side .quick{margin-top:18px;}
.book-side .quick-row{display:flex;gap:10px;margin-top:10px;}
.book-side .quick-row .msg-btn{flex:1;height:50px;background:#fff;}
.book-side .quick-row .msg-btn:hover{background:var(--sand);}

/* ============ АДАПТИВ ============ */
@media(max-width:1024px){
  .intro .wrap{grid-template-columns:1fr;gap:34px;}
  .facts .wrap{grid-template-columns:repeat(2,1fr);}
  .hotels-grid{grid-template-columns:1fr;}
  .rooms{grid-template-columns:repeat(2,1fr);}
  .gallery{grid-template-columns:repeat(2,1fr);}
  .adv{grid-template-columns:1fr;gap:30px;}
  .contacts{grid-template-columns:1fr;gap:28px;}
  .room-layout{grid-template-columns:1fr;}
  .book-side{position:static;}
  .hotel-hero .wrap{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:860px){
  html{scroll-padding-top:90px;}
  .navbar{display:none;}
  .head-actions .tel{display:none;}
  .head-actions .msgs{display:none;}
  .burger{display:flex;}
  .topbar{display:none;}
  .fab{display:flex;}
  .sec-head{flex-direction:column;align-items:flex-start;}
  .sec-head .right{text-align:left;}
  .brand-names{font-size:14px;}
  .head .wrap{min-height:66px;}
  .hfacts{grid-template-columns:1fr 1fr;}
}
@media(max-width:600px){
  .wrap{padding:0 18px;}
  .section{padding-top:46px;padding-bottom:46px;}
  .facts .wrap{grid-template-columns:1fr;}
  .rooms{grid-template-columns:1fr;}
  .gallery{grid-template-columns:1fr;}
  .adv-grid{grid-template-columns:1fr;}
  .collage{grid-template-columns:1fr 1fr;min-height:300px;}
  .field-2{grid-template-columns:1fr;}
  .cta-band .wrap{flex-direction:column;align-items:flex-start;}
  .cta-band .btn{width:100%;}
  .intro .cta-row .btn{flex:1;}
  .room-card .actions{flex-direction:column;}
  .footer-top{flex-direction:column;}
  .amen-grid{grid-template-columns:1fr 1fr;}
  .hfacts{grid-template-columns:1fr;}
  .hotel-hero .cta-row .btn{flex:1;}
  .review-inner{padding:24px 18px;}
  .review-text{font-size:17px;}
}

/* ===== Кнопки, выступающие как пункты меню (Next: <button> вместо <a>) ===== */
.navbar .nav-book{font-size:13.5px;font-weight:700;letter-spacing:.02em;text-transform:uppercase;
  padding:12px 14px;color:var(--ink-soft);cursor:pointer;transition:color .15s,background .15s;}
.navbar .nav-book:hover{color:var(--teal);background:var(--white);}
.drawer nav button.single{cursor:pointer;background:none;}

