/* ==========================================================================
   base.css — Luxury / High-end + Minimalistic / Clean (mobile-first)
   Palette (strict):
   - Primary: rgb(0, 100, 95)
   - White:   rgb(255, 255, 255)
   - Black:   rgb(0, 0, 0)

   Font: Montserrat only
   Includes:
   - Grid & typography
   - Components (buttons, chips, glass panels)
   - Sticky header + drawer UI foundations
   - Scroll-reveal + micro-animations
   - Mobile bottom action bar (tap-first)
   =======================================240, 235, 223=================================== */

:root{
  --primary-rgb: 0, 100, 95;
  --primary: rgb(var(--primary-rgb));

  --bg: rgb(240, 235, 223);
  --text: rgb(0,0,0);

  /* neutrals (derived from black) */
  --muted: rgba(0,0,0,.68);
  --muted-2: rgba(0,0,0,.52);

  --line: rgba(0,0,0,.12);
  --line-strong: rgba(0,0,0,.18);

  /* surfaces (white + blur) */
  --glass: rgba(255,255,255,.55);
  --glass-strong: rgba(255,255,255,.70);

  --shadow: 0 26px 70px rgba(0,0,0,.14);
  --shadow-soft: 0 14px 40px rgba(0,0,0,.10);

  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 10px;

  --container: 1280px;

  --fs-900: clamp(2rem, 4vw, 3.5rem);
  --fs-800: clamp(1.6rem, 2.6vw, 2.4rem);
  --fs-700: clamp(1.2rem, 1.6vw, 1.6rem);
  --fs-600: clamp(1.02rem, 1.2vw, 1.18rem);
  --fs-500: 1rem;
  --fs-400: .92rem;

  --space-1: 6px;
  --space-2: 10px;
  --space-3: 14px;
  --space-4: 18px;
  --space-5: 24px;
  --space-6: clamp(28px, 4vw, 48px);
  --space-7: clamp(40px, 5.5vw, 76px);
  --space-8: clamp(56px, 7vw, 110px);

  --ease: cubic-bezier(.2,.8,.2,1);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }

body {
    margin: 0;
    font-family: "Montserrat",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
    background: var(--bg);
    color: var(--text);
    line-height: 1.7;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* Page leave (JS applies body.is-leaving) */
body.is-leaving{
  pointer-events:none;
  animation: pageOut .22s var(--ease) both;
}
@keyframes pageOut{ from{ opacity:1; transform: translateY(0); } to{ opacity:0; transform: translateY(8px); } }

/* Delicate grain (very light) */
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
  opacity:.028;
  mix-blend-mode:multiply;
  background-image:
    radial-gradient(circle at 18% 12%, rgba(0,0,0,.35) 0 1px, transparent 2px),
    radial-gradient(circle at 78% 30%, rgba(0,0,0,.28) 0 1px, transparent 2px);
  background-size: 170px 170px;
}

.page > *{ position:relative; z-index:1; }

a{ color:inherit; text-decoration:none; }
img{ max-width:100%; display:block; }
button{ font-family:inherit; }
::selection{ background: rgba(var(--primary-rgb), .18); }

:focus-visible{
  outline: 2px solid rgba(var(--primary-rgb), .52);
  outline-offset: 3px;
}

.container{
  width:min(100% - 2*var(--space-5), var(--container));
  margin-inline:auto;
}

/* Accessibility */
.skip-link{
  position:absolute;
  left:-999px;
  top:10px;
  background: rgba(255,255,255,.92);
  color: var(--text);
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(0,0,0,.14);
  z-index: 200;
}
.skip-link:focus{ left:10px; }

/* Icons */
.icon{
  width:18px; height:18px;
  display:inline-block;
  flex:0 0 auto;
  color: currentColor;
}
.icon--sm{ width:16px; height:16px; }

/* Typography */
.kicker{
  margin:0 0 var(--space-3);
  font-size:var(--fs-400);
  letter-spacing:.24em;
  text-transform:uppercase;
  color:rgba(0,0,0,.62);
}
.h1{ margin:0; font-weight:600; font-size:var(--fs-900); line-height:1.08; letter-spacing:-.02em; }
.h2{ margin:0; font-weight:600; font-size:var(--fs-800); line-height:1.12; letter-spacing:-.02em; }
.h3{ margin:0; font-weight:600; font-size:var(--fs-700); line-height:1.2; letter-spacing:-.01em; }
.p{ margin:0 0 var(--space-4); font-size:var(--fs-600); color:rgba(0,0,0,.88); }
.p--muted{ color:rgba(0,0,0,.62); }
strong{ font-weight:600; }

.rule{
  height:1px;
  background:linear-gradient(90deg, transparent, var(--line-strong), transparent);
  margin-top:var(--space-4);
}

/* Glass */
.glass{
  background:linear-gradient(180deg, var(--glass-strong), var(--glass));
  border:1px solid rgba(0,0,0,.10);
  border-radius:var(--radius-lg);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow:var(--shadow-soft);
}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 18px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.16);
  background:transparent;
  cursor:pointer;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease), box-shadow .25s var(--ease), opacity .25s var(--ease);
  font-weight:500;
  letter-spacing:.02em;
  min-height:44px;
  -webkit-tap-highlight-color: transparent;
}
.btn:hover{ transform:translateY(-1px); box-shadow: 0 14px 30px rgba(0,0,0,.10); }
.btn:active{ transform:translateY(0); opacity:.92; box-shadow:none; }

.btn--primary{
  border-color:rgba(var(--primary-rgb), .55);
  background:
    linear-gradient(180deg, rgba(var(--primary-rgb), .12), rgba(var(--primary-rgb), .06)),
    radial-gradient(120px 80px at 30% 20%, rgba(var(--primary-rgb), .22), transparent 60%);
}
.btn--primary:hover{ border-color:rgba(var(--primary-rgb), .75); }

.btn--ghost{
  background:rgba(255,255,255,.62);
}
.btn--ghost:hover{
  background:rgba(255,255,255,.82);
  border-color: rgba(0,0,0,.22);
}

.btn--sm{ padding:10px 14px; min-height:38px; font-size:.9rem; }

/* Button icon micro-motion */
.btn .icon{ transition: transform .35s var(--ease); }
.btn:hover .icon{ transform: translateY(-1px); }

/* Links */
.link{
  position:relative;
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding-bottom:2px;
}
.link,
.contact-row__value,
.footer__meta,
.footer__link,
.fact-val{
  overflow-wrap:anywhere;
  word-break:break-word;
}

.contact-row > div,
.fact-row > div,
.room-card__top > div{
  min-width:0;
}
.link::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:0;
  height:1px;
  background:rgba(var(--primary-rgb), .72);
  transform:scaleX(.22);
  transform-origin:left;
  opacity:.7;
  transition:transform .35s var(--ease), opacity .35s var(--ease);
}
.link:hover::after{ transform:scaleX(1); opacity:1; }

/* Chips */
.chips {
    display: flex;
    flex-wrap: wrap;
    margin-top: var(--space-5);
    flex-direction: row;
    justify-content: center;
    align-content: space-around;
}
.chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 8px 12px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.14);
    background: rgba(255,255,255,.62);
    font-size: .88rem;
    color: rgba(0,0,0,.74);
    backdrop-filter: blur(10px);
    margin: 5px;
}
.chip--btn{ cursor:pointer; transition: transform .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease); }
.chip--btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.85);
  border-color: rgba(var(--primary-rgb), .26);
}

/* Header */
.site-header{
  position:sticky; top:0; z-index:100;
  transition: background .25s var(--ease), backdrop-filter .25s var(--ease), border-color .25s var(--ease);
  border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background: rgba(240,235,223,.52);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom-color: rgba(0,0,0,.10);
}
.header__inner{
  display:flex; align-items:center; justify-content:space-between;
  gap:var(--space-4);
  padding:12px 0;
}

.brand{ display:flex; align-items:center; gap:12px; min-width: 190px; }
.brand--logo-only{ min-width:auto; gap:0; }
.brand__img{
  width:170px;
  display:block;
  object-fit:contain;
}
.brand__mark{
  width:34px; height:34px; border-radius:999px;
  border:1px solid rgba(var(--primary-rgb), .55);
  background-color: rgba(var(--primary-rgb), .08);
  background-image: url("../assets/logo.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  box-shadow: 0 14px 26px rgba(0,0,0,.10);
}
.brand__text{ display:flex; flex-direction:column; line-height:1.05; }
.brand__name{ font-weight:600; letter-spacing:.10em; font-size:.9rem; }
.brand__sub{ font-weight:400; letter-spacing:.24em; text-transform:uppercase; font-size:.78rem; color:rgba(0,0,0,.62); }

.nav{ display:flex; align-items:center; gap:18px; }
.nav__link{
  position:relative;
  font-size:.95rem;
  color:rgba(0,0,0,.70);
  padding:10px 6px;
  transition: color .25s var(--ease);
}
.site-header .nav--desktop .nav__link {
    font-family: "Montserrat", sans-serif;
    font-weight: 600; /* было 550 → чуть жирнее */
    color: rgba(0,0,0,.78);
    font-size: 17px; /* было unset → задаём конкретно */
    line-height: 1.2; /* чтобы выглядело аккуратнее */
}

.nav__link:hover{ color:rgba(0,0,0,.92); }
.nav__link::after{
  content:"";
  position:absolute;
  left:6px; right:6px; bottom:6px;
  height:1px;
  background:rgba(var(--primary-rgb), .74);
  transform:scaleX(0);
  transform-origin:left;
  transition:transform .35s var(--ease);
}
.nav__link:hover::after{ transform:scaleX(1); }
.nav__link.is-active{ color:rgba(0,0,0,.96); }
.nav__link.is-active::after{ transform:scaleX(1); }

.header__actions{ display:flex; align-items:center; gap:10px; }
.site-header .header__book{
  font-family: "Montserrat", sans-serif;
  background: rgb(var(--primary-rgb));
  color: rgb(255,255,255);
  border-color: rgb(var(--primary-rgb));
  border-radius: 9999px;
  box-shadow: 0 8px 18px rgba(0,0,0,.14);
}
.site-header .header__book:hover{
  background: rgb(0, 88, 84);
  border-color: rgb(0, 88, 84);
  color: rgb(255,255,255);
  box-shadow: 0 12px 24px rgba(0,0,0,.16);
}
.site-header .header__book:active{
  background: rgb(0, 78, 74);
  border-color: rgb(0, 78, 74);
  box-shadow: 0 6px 14px rgba(0,0,0,.14);
}
.site-header .header__book:focus-visible{
  outline: 2px solid rgba(0, 100, 95, .45);
  outline-offset: 2px;
}

/* Burger */
.burger{
  width:44px; height:44px; border-radius:999px;
  border:1px solid rgba(0,0,0,.16);
  background: rgba(255,255,255,.62);
  display:inline-flex; align-items:center; justify-content:center;
  cursor:pointer;
  transition: background .25s var(--ease), transform .25s var(--ease), border-color .25s var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.burger:hover{
  background: rgba(255,255,255,.86);
  border-color: rgba(var(--primary-rgb), .26);
  transform: translateY(-1px);
}

/* Desktop / mobile */
.nav--desktop{ display:none; }

/* Drawer (mobile menu) */
.drawer{ position:fixed; inset:0; pointer-events:none; z-index:120; }
.drawer.is-open{ pointer-events:auto; }
.drawer__backdrop{
  position:absolute; inset:0; border:0;
  background: rgba(0,0,0,.26);
  opacity:0; transition: opacity .30s var(--ease);
}
.drawer.is-open .drawer__backdrop{ opacity:1; }
.drawer__panel{
  position:absolute; right:0; top:0; height:100%;
  width:min(92vw, 420px);
  background: rgba(255,255,255,.92);
  border-left:1px solid rgba(0,0,0,.12);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  transform: translateX(102%);
  transition: transform .38s var(--ease);
  padding: 18px;
  display:flex; flex-direction:column; gap:16px;
}
.drawer.is-open .drawer__panel{ transform: translateX(0); }
.drawer__top{
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:10px;
  border-bottom:1px solid rgba(0,0,0,.10);
}
.drawer__title{
  font-weight:600;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.85rem;
  color:rgba(0,0,0,.62);
}
.drawer__close{
  width:40px; height:40px; border-radius:999px;
  border:1px solid rgba(0,0,0,.16);
  background: rgba(255,255,255,.62);
  cursor:pointer;
  display:inline-flex; align-items:center; justify-content:center;
  -webkit-tap-highlight-color: transparent;
}
.drawer__close:hover{ border-color: rgba(var(--primary-rgb), .26); }

.nav--mobile{ display:grid; gap:10px; }
.nav--mobile .nav__link{
  padding:12px 12px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.62);
}
.nav--mobile .nav__link::after{ display:none; }
.drawer__cta{ margin-top:auto; display:grid; gap:10px; }
.drawer__meta{
  padding-top:12px;
  border-top:1px solid rgba(0,0,0,.10);
  display:grid; gap:6px;
}
.meta-line{ font-size:.9rem; color:rgba(0,0,0,.66); }
.drawer__row{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.drawer__label{
  font-size:.9rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(0,0,0,.56);
}
.drawer__langs{ display:flex; gap:8px; }
.drawer__lang{
  display:grid;
  gap:5px;
}
.drawer__lang .lang{ width:100%; }
.drawer__lang .lang__btn{
  width:100%;
  min-height:44px;
  justify-content:space-between;
}
.drawer__lang .lang__menu{
  left:0;
  right:auto;
  min-width:100%;
}

/* Language switch */
.lang{ position:relative; }
.lang__btn{
  display:inline-flex; align-items:center; gap:8px;
  height:38px; padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(0,0,0,.16);
  background: rgba(255,255,255,.62);
  cursor:pointer;
  transition: border-color .25s var(--ease), background .25s var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.lang__btn:hover{
  background: rgba(255,255,255,.86);
  border-color: rgba(var(--primary-rgb), .26);
}
.lang__code{ font-weight:600; letter-spacing:.10em; font-size:.85rem; }
.lang__menu{
  position:absolute; right:0; top:calc(100% + 8px);
  min-width: 170px;
  padding:8px;
  border-radius:14px;
  border:1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: var(--shadow-soft);
  display:none;
}
.lang.is-open .lang__menu{ display:block; }
.lang__item{
  width:100%;
  text-align:left;
  padding:10px 10px;
  margin:0px 0px 3px 0px;
  border-radius:12px;
  border:0;
  background: transparent;
  cursor:pointer;
  color: rgba(0,0,0,.86);
  -webkit-tap-highlight-color: transparent;
}
.lang__item:hover{ background: rgba(var(--primary-rgb), .08); }
.lang__item.is-active{
  background: rgba(var(--primary-rgb), .14);
  color: rgba(0,0,0,.98);
  font-weight: 600;
}

/* Sections */
.section{
  padding: var(--space-8) 0;
  content-visibility: auto;
  contain-intrinsic-size: 1px 1200px;
}
.section--flush{ padding-top:0; }
.section__header{ display:grid; gap:10px; margin-bottom: var(--space-6); }

.two-col{ display:grid; gap: var(--space-5); }
.two-col > .glass{ padding: var(--space-5); }

.mini-list{ display:grid; gap:10px; }
.mini-list__item{ display:flex; align-items:flex-start; gap:10px; color: rgba(0,0,0,.78); }

/* Page hero (inner pages) */
.page-hero{
  position:relative;
  min-height: 58vh;
  min-height: 58svh;
  display:grid;
  align-items:end;
  padding: 0 0 var(--space-7);
  overflow:hidden;
}
@keyframes heroKenBurns{
  from{ transform: scale(1.05) translate3d(0,0,0); }
  to{ transform: scale(1.12) translate3d(-1.2%, -1.4%, 0); }
}

.page-hero__media{
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  transform: scale(1.04);
  filter: saturate(1.03) contrast(1.02);
  animation: heroKenBurns 18s var(--ease) infinite alternate;
}
.page-hero__veil{
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.34), rgba(0,0,0,.12) 55%, rgba(240, 235, 223,.96)),
    radial-gradient(900px 520px at 12% 10%, rgba(var(--primary-rgb),.16), transparent 60%);
}
.page-hero__content{ position:relative; z-index:2; padding-top: var(--space-8); }

@media (max-width: 768px){
  .page-hero__media{ animation:none; transform: scale(1.04); }
}

@media (max-width: 640px){
  .page-hero{ min-height: 46vh; min-height: 46svh; padding-bottom: var(--space-6); }
  .page-hero__content{ padding-top: var(--space-7); }
}

/* Scroll reveal */
[data-reveal]{
  opacity:0;
  transform: translateY(14px);
  transition:
    opacity .7s var(--ease),
    transform .7s var(--ease);
  transition-delay: var(--reveal-delay, 0ms);
}
.is-visible{
  opacity:1 !important;
  transform: translateY(0) !important;
}

/* Offscreen rendering optimization */
.feature-grid,
.rooms-grid,
.info-grid,
.facts,
.rules-grid,
.contact-grid,
.media-strip,
.media-card,
.map-card{
  
  contain-intrinsic-size: 1px 800px;
}

/* Mobile bottom action bar */
.mobile-actions {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(12px + env(safe-area-inset-bottom));
    width: min(92vw, 520px);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 10px;
    border-radius: 999px;
    border: 1px solid rgba(0,0,0,.12);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: var(--shadow-soft);
    z-index: 90;

}


.blur-card1 {
    position: fixed;
    left: 50%;
    transform: translateX(-50%);
    bottom: calc(12px + env(safe-area-inset-bottom));
    width: min(92vw, 520px);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    padding: 10px;
    border-radius: 9px;
    border: 1px solid rgba(0,0,0,.12);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    box-shadow: var(--shadow-soft);
    z-index: 90;
}
.mobile-actions__btn{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.12);
  background: rgba(255,255,255,.62);
  color: rgba(0,0,0,.92);
  font-weight: 500;
  transition: transform .25s var(--ease), background .25s var(--ease), border-color .25s var(--ease);
  -webkit-tap-highlight-color: transparent;
}
.mobile-actions__btn:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.86);
  border-color: rgba(var(--primary-rgb), .26);
}

/* Make room for bottom bar on mobile */
@media (max-width: 768px){
  body{ padding-bottom: 90px; }
}

@media (max-width: 768px){
  .header__actions > .header__book,
  .header__actions > .lang{ display:none; }
}

@media (max-width: 768px){
  .btn--sm,
  .lang__btn,
  .burger,
  .drawer__close,
  .nav--mobile .nav__link,
  .lang__item,
  .chip--btn{
    min-height:44px;
  }
  .nav--mobile .nav__link{
    display:flex;
    align-items:center;
  }
}

@media (max-width: 768px){
  body::before{ opacity:.02; }
  .glass,
  .feature-card,
  .room-card,
  .media-card,
  .map-card,
  .mobile-actions{
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
  }
  .glass,
  .feature-card,
  .room-card,
  .media-card,
  .map-card{
    box-shadow: 0 10px 24px rgba(0,0,0,.08);
  }
}

@media (max-width: 640px){
  :root{
    --fs-900: clamp(1.9rem, 7.2vw, 2.6rem);
    --fs-800: clamp(1.5rem, 6vw, 2.05rem);
    --fs-700: clamp(1.15rem, 4.4vw, 1.5rem);
    --fs-600: 1rem;
    --fs-500: .98rem;
    --fs-400: .9rem;

    --space-5: 20px;
    --space-6: clamp(24px, 5.2vw, 38px);
    --space-7: clamp(32px, 7.4vw, 58px);
    --space-8: clamp(44px, 9vw, 82px);
  }

  body{ line-height:1.65; }
  .container{ width:min(100% - 2*var(--space-4), var(--container)); }

  .header__inner{ padding:10px 0; gap: var(--space-3); flex-wrap:wrap; }
  .brand{ min-width:auto; gap:10px; }
  .brand__img{ width:120px; }
  .brand__mark{ width:30px; height:30px; }
  .brand__name{ font-size:.82rem; }
  .brand__sub{ font-size:.7rem; letter-spacing:.18em; }
  .header__actions{ gap:8px; margin-left:auto; }
  .header__book{ padding:10px 12px; min-height:44px; font-size:.85rem; }

  .lang__btn{ height:44px; padding:0 10px; }
  .burger{ width:44px; height:44px; }
  .drawer__close{ width:44px; height:44px; }
  .drawer__panel{ width:min(92vw, 360px); padding:16px; }
  .nav--mobile{ gap:8px; }
  .nav--mobile .nav__link{ padding:12px 12px; font-size:.95rem; }

  .section{ padding: var(--space-7) 0; }
  .section__header{ margin-bottom: var(--space-5); }
  .two-col{ gap: var(--space-4); }
  .two-col > .glass{ padding: var(--space-4); }

  .chips{ gap:8px; margin-top: var(--space-4); }
  .chip{ padding:6px 10px; font-size:.82rem; }

  .mobile-actions{ width:min(94vw, 520px); gap:8px; padding:8px; }
  .mobile-actions__btn{ height:44px; font-size:.92rem; }

  .footer__inner{ gap: var(--space-5); }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
}

.blur-card {
    position: relative;
    overflow: hidden;
    padding: 24px;
    border-radius: 18px;
    /* эффект "стекла" */
    background: rgba(255,255,255,.08);
    border: 1px solid rgba(255,255,255,.14);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    color: #fff;
}

    /* размытая фигура 1 */
    .blur-card::before {
        content: "";
        position: absolute;
        width: 260px;
        height: 260px;
        left: -80px;
        top: -90px;
        background: radial-gradient(circle at 30% 30%, rgba(0,255,200,.55), rgba(0,255,200,0) 70%);
        filter: blur(18px);
        opacity: .9;
        z-index: 0;
    }

    /* размытая фигура 2 */
    .blur-card::after {
        content: "";
        position: absolute;
        width: 320px;
        height: 320px;
        right: -120px;
        bottom: -140px;
        background: radial-gradient(circle at 40% 40%, rgba(255,200,0,.45), rgba(255,200,0,0) 70%);
        filter: blur(22px);
        opacity: .85;
        z-index: 0;
    }

    /* чтобы контент был поверх фигур */
    .blur-card > * {
        position: relative;
        z-index: 1;
    }


/* Footer */
.site-footer {
 

    border-top: 0px solid rgba(255,255,255,.18);
    padding: var(--space-7) 0 var(--space-5);
    content-visibility: auto;
    contain-intrinsic-size: 1px 640px;
    background: rgb(0, 55, 52);
}
.footer__inner{ display:grid; gap: var(--space-6); }
.footer__title{ font-weight:600; letter-spacing:.08em; text-transform:uppercase; font-size:.92rem; }
.footer__meta{ color:rgba(255,255,255,.82); margin-top:6px; font-size:.95rem; }
.footer__links{ display:grid; gap: var(--space-5);
}
.footer__col{ display:grid; gap:10px; }
.footer__head{
  font-weight:600;
  font-size:.92rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(255,255,255,.88);
}
.footer__link{
  color:rgba(255,255,255,.84);
  display:inline-flex;
  align-items:center;
  gap:8px;
}
.footer__link:hover{ color:#ffffff; }
.footer-icons{
  display:flex;
 
  align-items:flex-start;
  gap:10px;
}
.footer-icon{
  width:40px;
  height:40px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:rgba(255,255,255,.92);
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.24);
  cursor:pointer;
  transition:opacity .2s ease, background-color .2s ease, transform .2s ease;
}
.footer-icon .icon{
  width:22px;
  height:22px;
  fill:currentColor;
}
.footer-icon:hover{
  opacity:.86;
  background:rgba(255,255,255,.16);
  transform:translateY(-1px);
}
.footer-icon:focus-visible{
  outline:2px solid #ffffff;
  outline-offset:2px;
}
.visually-hidden{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0, 0, 0, 0);
  white-space:nowrap;
  border:0;
}
.footer__links > .footer__col:last-child{
  margin:0;
  padding:0;
  gap:6px;
  align-content:start;
  align-self:start;
}
.footer__links > .footer__col:last-child .footer__head{
  margin:0;
}
.footer__links > .footer__col:last-child .footer__link{
  margin:0;
  padding:0;
  gap:6px;
  line-height:1.2;
}
.footer__bottom{
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid rgba(255,255,255,.16);
  display:flex;
  justify-content:space-between;
  gap:14px;
  color:rgba(255,255,255,.74);
  font-size:.9rem;
}
[data-year]{
  display:inline-block;
  min-width:4ch;
}

/* Desktop */
@media (min-width: 769px){
  .nav--desktop{ display:flex; }
  .burger{ display:none; }

  .two-col{ grid-template-columns: 1.1fr .9fr; }

  .footer__inner{ grid-template-columns: 1fr 1.2fr; }
  .footer__links{ grid-template-columns: repeat(3, 1fr); gap: var(--space-6); }

  /* hide mobile bar on desktop */
  .mobile-actions{ display:none; }
  body{ padding-bottom: 0; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  [data-reveal]{ transition:none; transform:none; opacity:1; }
  .drawer__panel, .drawer__backdrop, .btn, .mobile-actions__btn{ transition:none; }
  body{ animation:none; }
  body.is-leaving{ animation:none; opacity:0; }
  .page-hero__media{ animation:none; transform: scale(1.04); }
}

.site-header.is-scrolled {
    border-bottom: 1px solid #00645f;
}

