/* ============================================================
   ЗАМЬЯНЫ · База отдыха — единая дизайн-система сайта
   Направление: «Тёмный премиум» (кинематографичный)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant:ital,wght@0,400;0,500;0,600;1,400;1,500&family=Golos+Text:wght@400;500;600;700;800&display=swap');

:root{
  --forest:#1d3d2f; --forest-2:#14271e; --forest-3:#0e1812;
  --sage:#8a9a5b; --sage-soft:#aab487;
  --cream:#e8e4da; --paper:#faf8f3; --paper-2:#f2efe7;
  --gold:#c9a14a; --gold-soft:#e0c688; --wood:#7a5a3a;
  --ink:#20271f; --ink-soft:#5c6157;

  /* поверхности тёмной темы */
  --bg:#14271e; --bg-2:#0e1812; --surface:#1b3225;
  --txt:#e8e4da; --txt-soft:rgba(255,255,255,.72); --txt-dim:rgba(255,255,255,.5);
  --hair:rgba(255,255,255,.12); --hair-2:rgba(255,255,255,.08);

  --serif:'Cormorant',Georgia,'Times New Roman',serif;
  --sans:'Golos Text',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;

  --pad:clamp(20px,5vw,80px);
  --maxw:1240px;
  --r:18px; --r-lg:28px;
  --shadow:0 18px 50px -18px rgba(0,0,0,.5);
  --shadow-lg:0 40px 90px -30px rgba(0,0,0,.6);
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--sans);color:var(--txt);background:var(--bg);
  font-size:17px;line-height:1.6;letter-spacing:.01em;
}
::selection{background:var(--gold);color:var(--forest-2)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

.serif{font-family:var(--serif)}
h1,h2,h3,h4{font-family:var(--serif);font-weight:500;line-height:1.04;letter-spacing:-.01em;color:#fff}
.display{font-family:var(--serif);font-weight:500;line-height:.94;letter-spacing:-.02em;font-size:clamp(44px,8vw,132px);color:#fff}
.h-eyebrow{font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-soft)}
.lead{font-size:clamp(18px,2vw,22px);line-height:1.55;color:var(--txt-soft);font-weight:400}
em{font-style:italic;color:var(--gold)}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad)}
.section{padding-block:clamp(72px,12vh,150px)}
.center{text-align:center}
.secbar{display:flex;align-items:center;gap:14px;margin-bottom:18px}
.secbar .rule{width:42px;height:2px;background:var(--gold)}

/* ============================================================ NAV */
.nav{
  position:fixed;inset:0 0 auto 0;z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:6px var(--pad);
  backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);
  background:rgba(14,24,18,.55);border-bottom:1px solid var(--hair);color:var(--cream);
  transition:background .4s var(--ease),box-shadow .4s var(--ease);
}
.nav.scrolled{background:rgba(14,24,18,.86);box-shadow:0 10px 30px -16px rgba(0,0,0,.6)}
.nav__brand{display:flex;align-items:center;gap:11px;font-weight:600}
.nav__mark{width:30px;height:30px;flex:0 0 auto}
.nav__name{font-family:var(--serif);font-size:23px;font-weight:600}
.nav__logo{height:clamp(58px,6.4vw,76px);width:auto;display:block;flex:0 0 auto;margin-left:clamp(16px,3vw,48px)}
@media(max-width:560px){.nav__logo{height:48px;margin-left:8px}}
.nav__links{display:flex;gap:28px;align-items:center;font-size:14.5px;font-weight:500}
.nav__links a{opacity:.82;transition:opacity .25s,color .25s;white-space:nowrap}
.nav__links a:hover{opacity:1}
.nav__links a.active{opacity:1;color:var(--gold-soft)}
.nav__right{display:flex;align-items:center;gap:14px}
.nav__burger{display:none;width:42px;height:42px;border:1px solid var(--hair);border-radius:12px;background:transparent;cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__burger span{display:block;width:18px;height:2px;background:var(--cream);transition:transform .3s var(--ease),opacity .3s}
.nav.open .nav__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(max-width:940px){
  .nav__links{display:none}
  .nav__burger{display:flex}
}
/* мобильное выпадающее меню */
.mmenu{position:fixed;inset:0;z-index:190;background:rgba(14,24,18,.97);backdrop-filter:blur(14px);
  display:flex;flex-direction:column;justify-content:center;gap:6px;padding:0 var(--pad);
  opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s}
.mmenu.open{opacity:1;visibility:visible}
.mmenu a{font-family:var(--serif);font-size:clamp(30px,8vw,52px);color:#fff;padding:8px 0;border-bottom:1px solid var(--hair-2);transition:color .25s}
.mmenu a:hover,.mmenu a.active{color:var(--gold-soft)}
.mmenu .m-cta{margin-top:28px;border-bottom:none}

/* ============================================================ BUTTONS */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:15px;font-weight:600;
  padding:13px 26px;border-radius:999px;cursor:pointer;border:none;white-space:nowrap;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),background .3s,border-color .3s;will-change:transform}
.btn:hover{transform:translateY(-2px)}
.btn svg{width:18px;height:18px}
.btn--gold{background:var(--gold);color:var(--forest-2)}
.btn--gold:hover{box-shadow:0 14px 30px -10px rgba(201,161,74,.6)}
.btn--ghost{background:transparent;border:1.5px solid rgba(255,255,255,.4);color:#fff}
.btn--ghost:hover{border-color:var(--gold)}
.btn--lg{padding:16px 34px;font-size:16px}

.alink{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:600;color:var(--gold-soft)}
.alink svg{width:18px;height:18px;transition:transform .3s var(--ease)}
.alink:hover svg{transform:translateX(5px)}

/* ============================================================ PLACEHOLDERS */
.ph{position:relative;overflow:hidden;border-radius:var(--r);
  background:linear-gradient(135deg,var(--sage-soft),var(--forest));isolation:isolate}
.ph::after{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;
  background:radial-gradient(120% 90% at 50% 10%,transparent 40%,rgba(14,24,18,.34) 100%);mix-blend-mode:multiply}
.ph__tag{position:absolute;left:14px;bottom:13px;z-index:3;display:inline-flex;align-items:center;gap:7px;
  font-size:11px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.92);
  padding:6px 11px;border-radius:999px;background:rgba(14,24,18,.4);backdrop-filter:blur(6px);border:1px solid rgba(255,255,255,.18)}
.ph__tag svg{width:13px;height:13px}
.ph[data-ph="dawn"]  {background:linear-gradient(180deg,#f0c489 0%,#e8a05f 26%,#9e7b66 55%,#3e5448 78%,#1d3d2f 100%)}
.ph[data-ph="water"] {background:linear-gradient(165deg,#cfe0d8 0%,#8aa9a0 40%,#3f6259 72%,#1d3d2f 100%)}
.ph[data-ph="forest"]{background:linear-gradient(145deg,#aab487 0%,#6f8049 45%,#2f4a36 100%)}
.ph[data-ph="cabin"] {background:linear-gradient(150deg,#e8d9c0 0%,#b58f63 45%,#6f5235 100%)}
.ph[data-ph="wood"]  {background:repeating-linear-gradient(92deg,#8a6a45 0 18px,#7a5a3a 18px 38px)}
.ph[data-ph="reed"]  {background:linear-gradient(175deg,#e9d9a8 0%,#c2a85c 38%,#6c7a3f 72%,#34492f 100%)}
.ph[data-ph="dusk"]  {background:linear-gradient(180deg,#3a4a55 0%,#6b5d63 40%,#c98f5e 72%,#e7b070 100%)}
.ph[data-ph="banya"] {background:linear-gradient(155deg,#c98f5e 0%,#7a5a3a 50%,#3a2c1e 100%)}
.ph[data-ph="map"]   {background:linear-gradient(150deg,#2f4a36 0%,#1d3d2f 60%,#0e1812 100%)}
.ph--sun::before{content:"";position:absolute;z-index:1;width:38%;aspect-ratio:1;border-radius:50%;left:50%;top:34%;
  transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(255,247,230,.95) 0%,rgba(247,206,141,.55) 45%,transparent 70%);filter:blur(2px)}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}
.reveal[data-d="4"]{transition-delay:.32s}
.reveal[data-d="5"]{transition-delay:.40s}

/* ============================================================ PAGE HERO (внутренние страницы) */
.phero{position:relative;min-height:62vh;display:flex;align-items:flex-end;overflow:hidden;padding-top:90px}
.phero .bg{position:absolute;inset:-6%;z-index:0}
.phero .bg.ph{border-radius:0}
.phero .bg.ph::after{background:linear-gradient(180deg,rgba(14,24,18,.45) 0%,rgba(14,24,18,.2) 45%,rgba(14,24,18,.95) 100%)}
.phero__in{position:relative;z-index:2;width:100%;max-width:var(--maxw);margin:0 auto;padding:0 var(--pad) clamp(40px,7vh,80px)}
.phero .top{display:flex;align-items:center;gap:14px;margin-bottom:20px}
.phero .top .rule{flex:1;height:1px;max-width:120px;background:linear-gradient(90deg,var(--gold),transparent)}
.phero h1{font-size:clamp(44px,8vw,108px);line-height:.94}
.phero p{font-size:clamp(17px,1.8vw,21px);color:var(--txt-soft);max-width:560px;margin-top:22px}
.crumbs{font-size:13px;color:var(--txt-dim);letter-spacing:.04em;margin-bottom:18px}
.crumbs a:hover{color:var(--gold-soft)}

/* ============================================================ CARDS / GRID */
.grid{display:grid;gap:22px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.g-3,.g-4{grid-template-columns:1fr 1fr}}
@media(max-width:620px){.g-2,.g-3,.g-4{grid-template-columns:1fr}}

.card{background:var(--surface);border:1px solid var(--hair-2);border-radius:var(--r-lg);overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .4s}
.card:hover{transform:translateY(-8px);box-shadow:var(--shadow-lg);border-color:var(--hair)}
.card__pic{aspect-ratio:4/3;position:relative}
.card__pic .ph{position:absolute;inset:0;border-radius:0}
.card__body{padding:26px 26px 30px}
.card__body h3{font-size:27px;margin-bottom:8px}
.card__meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--txt-dim);font-size:13.5px;margin-bottom:14px}
.card__meta span{display:flex;align-items:center;gap:6px}
.card__meta svg{width:15px;height:15px;color:var(--gold-soft)}
.card__body p{color:var(--txt-soft);font-size:15px;line-height:1.55;margin-bottom:18px}
.card__foot{display:flex;align-items:center;justify-content:space-between;gap:12px}
.price{font-family:var(--serif);font-size:30px;color:#fff;line-height:1}
.price small{font-family:var(--sans);font-size:13px;color:var(--txt-dim);font-weight:500}

.chip{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--gold-soft);
  background:rgba(201,161,74,.12);border:1px solid rgba(201,161,74,.25);padding:7px 14px;border-radius:999px}

/* список преимуществ */
.ticks{list-style:none;display:flex;flex-direction:column;gap:11px}
.ticks li{display:flex;gap:11px;align-items:flex-start;font-size:15.5px;color:var(--txt)}
.ticks svg{width:19px;height:19px;color:var(--gold);flex:0 0 auto;margin-top:2px}

/* split row */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,72px);align-items:center}
@media(max-width:860px){.split{grid-template-columns:1fr;gap:30px}}
.split.flip .split__pic{order:2}
@media(max-width:860px){.split.flip .split__pic{order:0}}
.split__pic .ph{aspect-ratio:4/3;border-radius:var(--r-lg);box-shadow:var(--shadow)}
.split__txt h2{font-size:clamp(30px,4vw,52px);margin-bottom:16px}
.split__txt p{color:var(--txt-soft);font-size:16.5px;margin-bottom:18px}

/* CTA band */
.ctaband{position:relative;border-radius:var(--r-lg);overflow:hidden;text-align:center;padding:clamp(60px,10vw,120px) var(--pad)}
.ctaband .ph{position:absolute;inset:0;border-radius:0;z-index:0}
.ctaband .ph::after{background:rgba(14,24,18,.74)}
.ctaband__in{position:relative;z-index:2;max-width:660px;margin:0 auto}
.ctaband h2{font-size:clamp(34px,6vw,80px);line-height:.98;margin-bottom:18px}
.ctaband p{color:rgba(255,255,255,.85);font-size:18px;margin-bottom:32px}

/* ============================================================ FOOTER */
.foot{background:var(--forest-3);color:var(--cream);padding-block:64px 40px}
.foot a{opacity:.78;transition:opacity .25s,color .25s}
.foot a:hover{opacity:1;color:var(--gold-soft)}
.foot__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:40px}
@media(max-width:780px){.foot__grid{grid-template-columns:1fr 1fr}}
.foot__col h4{font-family:var(--sans);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-soft);margin-bottom:16px;font-weight:600}
.foot__col li{list-style:none;margin-bottom:10px;font-size:14.5px}
.foot__bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-size:13px;opacity:.6}

/* ============================================================ FORMS */
.field{display:flex;flex-direction:column;gap:8px;margin-bottom:18px}
.field label{font-size:13px;font-weight:600;letter-spacing:.04em;color:var(--txt-soft)}
.field input,.field select,.field textarea{
  font-family:var(--sans);font-size:15px;color:#fff;background:rgba(255,255,255,.04);
  border:1px solid var(--hair);border-radius:12px;padding:13px 15px;transition:border-color .25s,background .25s}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--gold);background:rgba(255,255,255,.07)}
.field input::placeholder,.field textarea::placeholder{color:var(--txt-dim)}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23e0c688' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none;transition:none}
  .marquee__track{animation:none}
}
