/* ============================================================
   ИНЖИР У РОДНИКА · Алаҳаӡыхь — Landing design system
   ============================================================ */

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

:root{
  /* brand palette (locked) */
  --indigo:#1B2A4A;
  --indigo-deep:#152138;
  --indigo-700:#26395d;
  --terracotta:#B0613B;
  --terracotta-2:#C2744A;
  --gold:#C49A5C;
  --cream:#F6F1E7;
  --cream-2:#EFE7D6;
  --sand:#E5DAC6;
  --ink:#20283A;
  --ink-soft:#5C6276;
  --line:rgba(27,42,74,.14);
  --line-soft:rgba(27,42,74,.08);
  --white:#fff;

  --accent:var(--terracotta);     /* tweakable */
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-body:'Manrope', system-ui, sans-serif;

  --maxw:1240px;
  --pad-section:clamp(64px, 9vw, 150px);
  --radius:3px;
  --shadow-card:0 24px 60px -28px rgba(21,33,56,.4);
  --shadow-soft:0 12px 36px -18px rgba(21,33,56,.3);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--ink);
  font-size:17px;
  line-height:1.68;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;}
::selection{background:var(--terracotta);color:#fff;}

/* ---------- typography helpers ---------- */
.display{font-family:var(--font-display);font-weight:500;line-height:1.04;letter-spacing:-.01em;}
.eyebrow{
  font-size:12.5px;font-weight:600;letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);
}
.eyebrow.muted{color:var(--ink-soft);}
.lead{font-size:clamp(18px,1.5vw,21px);line-height:1.6;color:var(--ink-soft);font-weight:400;}
h1,h2,h3,h4{margin:0;}
p{margin:0;text-wrap:pretty;}

.h-section{
  font-family:var(--font-display);font-weight:500;
  font-size:clamp(38px,5.2vw,62px);line-height:1.02;letter-spacing:-.012em;
  color:var(--indigo);text-wrap:balance;
}
.h-section.on-dark{color:#F4EEE2;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(22px,5vw,56px);}
.wrap-wide{max-width:1480px;margin:0 auto;padding:0 clamp(18px,3vw,40px);}
section{position:relative;}
.sec{padding-block:var(--pad-section);}
.sec-tight{padding-block:clamp(48px,6vw,86px);}
.bg-cream2{background:var(--cream-2);}
.bg-indigo{background:var(--indigo);color:#E9E3D6;}
.divider-fade{height:1px;background:var(--line);}

.sec-head{max-width:760px;}
.sec-head .eyebrow{margin-bottom:18px;display:block;}
.sec-head p.lead{margin-top:22px;}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:11px;
  font-weight:600;font-size:15px;letter-spacing:.01em;
  padding:15px 26px;border-radius:var(--radius);
  transition:transform .25s cubic-bezier(.2,.7,.2,1), background .25s, color .25s, box-shadow .25s;
  white-space:nowrap;line-height:1;
}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--accent);color:#fff;box-shadow:0 14px 30px -14px rgba(176,97,59,.8);}
.btn-primary:hover{background:#9c5230;transform:translateY(-2px);box-shadow:0 20px 38px -16px rgba(176,97,59,.85);}
.btn-ghost{border:1px solid currentColor;color:var(--indigo);}
.btn-ghost:hover{background:var(--indigo);color:#fff;border-color:var(--indigo);}
.btn-ghost.on-dark{color:#F4EEE2;}
.btn-ghost.on-dark:hover{background:#fff;color:var(--indigo);border-color:#fff;}
.btn-light{background:#fff;color:var(--indigo);}
.btn-light:hover{background:var(--cream);transform:translateY(-2px);}
.btn-arrow svg{width:15px;height:15px;transition:transform .25s;}
.btn:hover .btn-arrow svg{transform:translateX(3px);}
.btn-sm{padding:12px 20px;font-size:13.5px;}

.link-underline{
  display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px;
  color:var(--accent);border-bottom:1px solid transparent;padding-bottom:2px;
  transition:border-color .25s,gap .25s;
}
.link-underline:hover{border-color:var(--accent);gap:12px;}

/* ============================================================
   HEADER
   ============================================================ */
.hdr{
  position:fixed;top:0;left:0;right:0;z-index:60;
  transition:background .4s ease, box-shadow .4s ease, padding .4s ease;
  padding:20px 0;
}
.hdr.scrolled{background:rgba(246,241,231,.92);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--line),0 10px 30px -22px rgba(21,33,56,.4);padding:12px 0;}
.hdr-inner{display:flex;align-items:center;gap:30px;}
.hdr-logo{display:flex;align-items:center;gap:13px;flex-shrink:0;}
.hdr-logo .em{height:38px;width:auto;transition:height .4s;}
.hdr-logo .wm{height:19px;width:auto;transition:opacity .4s, filter .4s;}
.hdr.scrolled .hdr-logo .em{height:34px;}
.hdr-nav{display:flex;align-items:center;gap:27px;margin-left:auto;}
.hdr-nav a{
  font-size:14px;font-weight:500;color:var(--indigo);position:relative;padding:5px 0;
  transition:color .25s,opacity .25s;letter-spacing:.005em;
}
.hdr:not(.scrolled) .hdr-logo .em.dark,.hdr:not(.scrolled) .hdr-logo .wm.dark{display:none;}
.hdr.scrolled .hdr-logo .em.light,.hdr.scrolled .hdr-logo .wm.light{display:none;}
.hdr:not(.scrolled) .hdr-nav a{color:#F4EEE2;}
.hdr:not(.scrolled) .hdr-tel{color:#F4EEE2;}
.hdr-nav a::after{content:"";position:absolute;left:0;bottom:-2px;height:1.5px;width:0;background:var(--accent);transition:width .3s;}
.hdr-nav a:hover::after,.hdr-nav a.active::after{width:100%;}
.hdr-nav a.active{color:var(--accent);}
.hdr:not(.scrolled) .hdr-nav a.active{color:#fff;}
.hdr-right{display:flex;align-items:center;gap:18px;margin-left:8px;}
.hdr-tel{font-weight:600;font-size:14.5px;color:var(--indigo);white-space:nowrap;transition:color .3s;}
.hdr-tel:hover{color:var(--accent);}
.hdr-burger{display:none;width:42px;height:42px;border-radius:3px;align-items:center;justify-content:center;flex-direction:column;gap:5px;}
.hdr-burger span{display:block;width:22px;height:2px;background:currentColor;transition:.3s;}
.hdr:not(.scrolled) .hdr-burger{color:#fff;}
.hdr.scrolled .hdr-burger{color:var(--indigo);}

/* mobile nav drawer */
.mnav{
  position:fixed;inset:0;z-index:70;background:var(--indigo-deep);
  display:flex;flex-direction:column;padding:26px clamp(22px,6vw,40px);
  transform:translateY(-100%);transition:transform .5s cubic-bezier(.5,0,0,1);
  visibility:hidden;
}
.mnav.open{transform:translateY(0);visibility:visible;}
.mnav-top{display:flex;align-items:center;justify-content:space-between;}
.mnav-close{color:#fff;font-size:30px;line-height:1;width:44px;height:44px;}
.mnav-links{display:flex;flex-direction:column;gap:4px;margin-top:8vh;}
.mnav-links a{
  font-family:var(--font-display);font-size:34px;color:#F4EEE2;padding:9px 0;font-weight:500;
  border-bottom:1px solid rgba(255,255,255,.08);transition:color .2s,padding-left .25s;
}
.mnav-links a:hover{color:var(--gold);padding-left:10px;}
.mnav-foot{margin-top:auto;display:flex;flex-direction:column;gap:16px;padding-top:24px;}
.mnav-foot .btn{justify-content:center;}

/* floating mobile CTA */
.float-cta{
  position:fixed;left:14px;right:14px;bottom:14px;z-index:55;display:none;
  box-shadow:0 18px 40px -12px rgba(21,33,56,.55);
}
.float-cta .btn{width:100%;justify-content:center;padding:17px;font-size:15px;}

/* ============================================================
   HERO
   ============================================================ */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;color:#fff;}
.hero-bg{position:absolute;inset:0;}
.hero-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.06);animation:heroZoom 16s ease-out forwards;}
@keyframes heroZoom{to{transform:scale(1);}}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,21,38,.60) 0%,rgba(13,21,38,.30) 38%,rgba(13,21,38,.42) 62%,rgba(10,17,31,.88) 100%);}
.hero-inner{position:relative;z-index:2;width:100%;padding-bottom:clamp(48px,7vw,96px);padding-top:140px;}
.hero-eyebrow{color:rgba(255,255,255,.92);font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:13px;
  display:flex;align-items:center;gap:14px;}
.hero-eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--gold);}
.hero h1{font-family:var(--font-display);font-weight:500;font-size:clamp(46px,7vw,98px);line-height:1.0;letter-spacing:-.015em;
  margin:24px 0 0;max-width:16ch;text-shadow:0 2px 30px rgba(15,24,42,.4);text-wrap:balance;}
.hero h1 br{display:block;}
.hero h1 em{font-style:italic;color:var(--gold);}
.hero-sub{margin-top:26px;max-width:60ch;font-size:clamp(16px,1.4vw,20px);line-height:1.6;color:rgba(255,255,255,.9);font-weight:400;}
.hero-urgency{display:inline-flex;align-items:center;gap:11px;margin-top:30px;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(6px);
  padding:10px 18px;border-radius:40px;font-size:13.5px;font-weight:500;letter-spacing:.01em;}
.hero-urgency .pulse{width:9px;height:9px;border-radius:50%;background:#7BD389;box-shadow:0 0 0 0 rgba(123,211,137,.7);animation:pulse 2.2s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(123,211,137,.6);}70%{box-shadow:0 0 0 12px rgba(123,211,137,0);}100%{box-shadow:0 0 0 0 rgba(123,211,137,0);}}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px;}
.hero-scroll{position:absolute;left:50%;bottom:24px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.7);
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px;}
.hero-scroll .ln{width:1px;height:34px;background:rgba(255,255,255,.5);animation:scrollLn 2s ease-in-out infinite;transform-origin:top;}
@keyframes scrollLn{0%,100%{transform:scaleY(.3);opacity:.4;}50%{transform:scaleY(1);opacity:1;}}

/* anim on enter */
.rise{opacity:0;transform:translateY(26px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.7,.2,1);}
.rise.in{opacity:1;transform:none;}
.rise.d1{transition-delay:.08s;}.rise.d2{transition-delay:.16s;}.rise.d3{transition-delay:.24s;}.rise.d4{transition-delay:.32s;}.rise.d5{transition-delay:.4s;}
@media (prefers-reduced-motion:reduce){.rise{opacity:1;transform:none;transition:none;}.hero-bg img{animation:none;transform:none;}}

/* ============================================================
   KEY NUMBERS strip
   ============================================================ */
.kn{background:var(--indigo);color:#F2ECDF;}
.kn-grid{display:grid;grid-template-columns:repeat(6,1fr);}
.kn-cell{padding:34px 20px;text-align:center;border-right:1px solid rgba(255,255,255,.1);}
.kn-cell:last-child{border-right:none;}
.kn-num{font-family:var(--font-display);font-size:clamp(34px,3.6vw,50px);font-weight:500;line-height:1;color:#fff;}
.kn-num .u{font-size:.5em;color:var(--gold);margin-left:3px;font-family:var(--font-body);font-weight:600;letter-spacing:.02em;}
.kn-lbl{margin-top:9px;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:rgba(242,236,223,.62);font-weight:600;}

/* ============================================================
   CONCEPT
   ============================================================ */
.concept{position:relative;overflow:hidden;}
.concept-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,96px);align-items:center;}
.concept-text .statement{font-family:var(--font-display);font-weight:500;font-size:clamp(28px,3.2vw,42px);line-height:1.12;color:var(--indigo);letter-spacing:-.01em;}
.concept-text .statement em{font-style:italic;color:var(--accent);}
.concept-text p+p{margin-top:20px;}
.concept-text .body{margin-top:28px;color:var(--ink-soft);font-size:17px;}
.etym{margin-top:34px;border-top:1px solid var(--line);padding-top:28px;display:flex;gap:26px;flex-wrap:wrap;}
.etym-item{flex:1;min-width:150px;}
.etym-word{font-family:var(--font-display);font-size:30px;color:var(--accent);font-weight:600;font-style:italic;}
.etym-tr{font-size:13px;letter-spacing:.04em;color:var(--ink-soft);margin-top:4px;}
.concept-media{position:relative;}
.concept-media .main{aspect-ratio:4/5;width:100%;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-card);}
.concept-media .inset{position:absolute;width:46%;aspect-ratio:1/1;object-fit:cover;right:-26px;bottom:-30px;border-radius:var(--radius);
  box-shadow:var(--shadow-card);border:6px solid var(--cream);}

/* ============================================================
   LOCATION
   ============================================================ */
.loc-top{display:grid;grid-template-columns:1fr 360px;gap:50px;align-items:end;}
.loc-drivers{display:flex;flex-direction:column;gap:16px;}
.driver{display:flex;gap:15px;align-items:flex-start;background:#fff;border:1px solid var(--line-soft);border-radius:var(--radius);padding:18px 20px;box-shadow:var(--shadow-soft);}
.driver .ic{flex-shrink:0;width:40px;height:40px;border-radius:50%;background:var(--cream-2);display:flex;align-items:center;justify-content:center;color:var(--accent);}
.driver .ic svg{width:20px;height:20px;}
.driver h4{font-size:15px;font-weight:700;color:var(--indigo);margin-bottom:3px;}
.driver p{font-size:13.5px;color:var(--ink-soft);line-height:1.5;}
.loc-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;margin-top:48px;}
.loc-card{position:relative;border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;box-shadow:var(--shadow-soft);}
.loc-card.big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto;}
.loc-grid .loc-card:last-child{grid-column:span 4;aspect-ratio:auto;}
.loc-card img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1);}
.loc-card:hover img{transform:scale(1.06);}
.loc-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 40%,rgba(15,24,42,.78));}
.loc-card .cap{position:absolute;left:0;right:0;bottom:0;padding:18px;z-index:2;color:#fff;}
.loc-card .cap .t{font-family:var(--font-display);font-size:22px;font-weight:500;line-height:1.05;}
.loc-card .cap .d{font-size:12px;color:rgba(255,255,255,.78);margin-top:3px;letter-spacing:.03em;}

/* ============================================================
   INFRASTRUCTURE tabs
   ============================================================ */
.infra-tabs{display:flex;gap:8px;flex-wrap:wrap;margin-top:40px;}
.infra-tab{
  padding:11px 20px;border-radius:40px;font-size:14px;font-weight:600;color:var(--ink-soft);
  border:1px solid var(--line);transition:.25s;letter-spacing:.005em;background:transparent;
}
.infra-tab:hover{color:var(--indigo);border-color:var(--indigo);}
.infra-tab.active{background:var(--indigo);color:#fff;border-color:var(--indigo);}
.infra-panel{display:grid;grid-template-columns:1.35fr 1fr;gap:0;margin-top:30px;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);min-height:clamp(380px,52vh,500px);}
.infra-img{position:relative;overflow:hidden;background:var(--sand);}
.infra-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.infra-imgfade{animation:fadeImg .7s ease;}
@keyframes fadeImg{from{opacity:0;transform:scale(1.03);}to{opacity:1;transform:none;}}
.infra-meta{background:#fff;padding:clamp(34px,3.5vw,52px);display:flex;flex-direction:column;}
.infra-meta .idx{font-size:13px;font-weight:700;color:var(--accent);letter-spacing:.1em;}
.infra-meta h3{font-family:var(--font-display);font-size:clamp(30px,2.6vw,40px);font-weight:500;color:var(--indigo);margin:14px 0 16px;line-height:1.04;}
.infra-meta .desc{color:var(--ink-soft);font-size:16px;}
.infra-feats{margin-top:26px;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line);}
.infra-feat{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:14px 0;border-bottom:1px solid var(--line-soft);}
.infra-feat .k{font-size:14.5px;color:var(--ink);font-weight:500;}
.infra-feat .v{font-family:var(--font-display);font-size:23px;color:var(--accent);font-weight:600;white-space:nowrap;}
.infra-stat-row{display:flex;gap:8px;margin-top:auto;padding-top:26px;}

/* ============================================================
   GASTRO
   ============================================================ */
.gastro{position:relative;}
.gastro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:46px;}
.gcard{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-soft);aspect-ratio:1/1;}
.gcard.tall{grid-row:span 2;aspect-ratio:1/2;}
.gcard.wide{grid-column:span 2;aspect-ratio:2/1;}
.gastro-grid .gcard:last-child{grid-column:span 3;aspect-ratio:3/1;}
.gcard img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1);}
.gcard:hover img{transform:scale(1.05);}
.gcard::after{content:"";position:absolute;inset:0;background:linear-gradient(160deg,transparent 45%,rgba(15,24,42,.8));}
.gcard .cap{position:absolute;left:0;bottom:0;padding:22px;z-index:2;color:#fff;}
.gcard .cap .t{font-family:var(--font-display);font-size:25px;font-weight:500;}
.gcard .cap .d{font-size:13px;color:rgba(255,255,255,.8);margin-top:4px;max-width:34ch;line-height:1.45;}

/* ============================================================
   VILLAS
   ============================================================ */
.villa-switch{display:inline-flex;background:var(--cream-2);border:1px solid var(--line);border-radius:44px;padding:5px;margin-top:38px;}
.villa-switch button{padding:12px 26px;border-radius:40px;font-size:14.5px;font-weight:600;color:var(--ink-soft);transition:.3s;}
.villa-switch button.active{background:var(--indigo);color:#fff;box-shadow:var(--shadow-soft);}
.villa-stage{margin-top:38px;display:grid;grid-template-columns:1.25fr 1fr;gap:44px;align-items:start;}
.villa-gallery .vmain{width:100%;aspect-ratio:16/10;object-fit:cover;border-radius:var(--radius);box-shadow:var(--shadow-card);}
.villa-thumbs{display:flex;flex-wrap:wrap;gap:10px;margin-top:12px;}
.villa-thumbs img{width:84px;height:62px;object-fit:cover;border-radius:2px;cursor:pointer;opacity:.55;transition:.25s;border:2px solid transparent;}
.villa-thumbs img:hover{opacity:.85;}
.villa-thumbs img.active{opacity:1;border-color:var(--accent);}
.villa-info .vtype{font-size:13px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);}
.villa-info h3{font-family:var(--font-display);font-weight:500;font-size:clamp(32px,3vw,46px);color:var(--indigo);line-height:1.02;margin:10px 0 6px;}
.villa-info .vmeta{display:flex;gap:26px;margin-top:20px;flex-wrap:wrap;}
.villa-info .vmeta div span{display:block;}
.villa-info .vmeta .mv{font-family:var(--font-display);font-size:30px;color:var(--indigo);font-weight:600;line-height:1;}
.villa-info .vmeta .ml{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);margin-top:6px;}
.villa-incl{margin-top:26px;border-top:1px solid var(--line);padding-top:22px;display:grid;grid-template-columns:1fr 1fr;gap:11px 22px;}
.villa-incl li{list-style:none;font-size:14.5px;color:var(--ink);display:flex;gap:10px;align-items:flex-start;}
.villa-incl li svg{width:16px;height:16px;color:var(--accent);flex-shrink:0;margin-top:4px;}
.villa-price{margin-top:28px;background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;display:flex;align-items:center;justify-content:space-between;gap:20px;flex-wrap:wrap;}
.villa-price .pl{font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;}
.villa-price .pv{font-family:var(--font-display);font-size:42px;color:var(--indigo);font-weight:600;line-height:1;margin-top:4px;}
.villa-price .pv small{font-size:.5em;color:var(--ink-soft);font-family:var(--font-body);font-weight:600;}

/* ============================================================
   INVESTMENT
   ============================================================ */
.inv-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:46px;}
.swap-anim{animation:swapIn .5s cubic-bezier(.2,.7,.2,1);}
@keyframes swapIn{from{transform:translateY(12px);}to{transform:none;}}
@media (prefers-reduced-motion:reduce){.swap-anim{animation:none;}}
.inv-card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,3vw,42px);box-shadow:var(--shadow-soft);}
.inv-card .tag{font-size:13px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);}
.inv-card h3{font-family:var(--font-display);font-size:30px;color:var(--indigo);font-weight:500;margin:8px 0 0;}
.inv-rows{margin-top:26px;}
.inv-row{display:flex;justify-content:space-between;align-items:baseline;padding:13px 0;border-bottom:1px solid var(--line-soft);gap:14px;}
.inv-row .k{font-size:14.5px;color:var(--ink-soft);}
.inv-row .v{font-weight:700;font-size:16px;color:var(--ink);}
.inv-payback{margin-top:24px;background:var(--indigo);color:#fff;border-radius:var(--radius);padding:22px 26px;display:flex;align-items:center;justify-content:space-between;}
.inv-payback .pl{font-size:13px;letter-spacing:.06em;color:rgba(255,255,255,.7);text-transform:uppercase;font-weight:600;max-width:16ch;}
.inv-payback .pv{font-family:var(--font-display);font-size:46px;font-weight:600;line-height:1;color:var(--gold);}
.inv-payback .pv small{font-size:.42em;color:#fff;font-family:var(--font-body);font-weight:600;display:block;text-align:right;margin-top:3px;}

/* price ladder */
.ladder{margin-top:30px;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:clamp(28px,3vw,46px);box-shadow:var(--shadow-soft);}
.ladder-head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:18px;margin-bottom:34px;}
.ladder-chart{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,2.5vw,40px);align-items:end;height:300px;}
.lstage{display:flex;flex-direction:column;justify-content:flex-end;height:100%;text-align:center;gap:0;}
.lbars{display:flex;gap:8px;align-items:flex-end;justify-content:center;height:236px;}
.lbar{width:38px;border-radius:3px 3px 0 0;position:relative;transition:height 1.1s cubic-bezier(.2,.7,.2,1);display:flex;justify-content:center;}
.lbar.t1{background:linear-gradient(180deg,var(--terracotta-2),var(--terracotta));}
.lbar.t2{background:linear-gradient(180deg,var(--indigo-700),var(--indigo));}
.lbar .bv{position:absolute;top:-24px;font-size:13px;font-weight:700;color:var(--ink);white-space:nowrap;}
.lstage .ls-name{margin-top:16px;font-size:13.5px;font-weight:600;color:var(--indigo);}
.lstage .ls-sub{font-size:11.5px;color:var(--ink-soft);letter-spacing:.04em;}
.lstage.now .ls-name{color:var(--accent);}
.lstage.now::before{content:"СЕЙЧАС";display:inline-block;font-size:10px;letter-spacing:.12em;font-weight:700;color:#fff;background:var(--accent);padding:3px 9px;border-radius:30px;margin-bottom:8px;align-self:center;}
.ladder-legend{display:flex;gap:24px;flex-wrap:wrap;margin-top:8px;}
.lleg{display:flex;align-items:center;gap:9px;font-size:13.5px;color:var(--ink-soft);font-weight:500;}
.lleg .sw{width:14px;height:14px;border-radius:3px;}
.lleg .sw.t1{background:var(--terracotta);}.lleg .sw.t2{background:var(--indigo);}
.gain-pill{display:inline-flex;align-items:center;gap:8px;background:var(--cream-2);border:1px solid var(--line);border-radius:30px;padding:8px 16px;font-size:14px;font-weight:600;color:var(--indigo);}
.gain-pill b{color:var(--accent);}

.disclaimer{font-size:12.5px;color:var(--ink-soft);line-height:1.55;margin-top:22px;max-width:88ch;opacity:.85;}

/* ============================================================
   PRICES / urgency band
   ============================================================ */
.price-band{background:var(--indigo);color:#F2ECDF;overflow:hidden;position:relative;}
.price-band .wrap{position:relative;z-index:2;}
.price-ladder-mini{display:flex;align-items:center;gap:18px;flex-wrap:wrap;margin-top:34px;}
.pstep{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius);padding:20px 26px;min-width:190px;flex:1;}
.pstep.cur{background:var(--accent);border-color:var(--accent);}
.pstep .ps-l{font-size:12px;letter-spacing:.1em;text-transform:uppercase;font-weight:600;opacity:.75;}
.pstep.cur .ps-l{opacity:.95;}
.pstep .ps-v{font-family:var(--font-display);font-size:30px;font-weight:600;margin-top:8px;color:#fff;}
.pstep .ps-v small{font-size:.5em;font-family:var(--font-body);opacity:.8;}
.parrow{color:var(--gold);flex-shrink:0;}

/* ============================================================
   LEGAL / TRUST
   ============================================================ */
.trust-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 56px;margin-top:46px;}
.titem{display:flex;gap:20px;padding:26px 0;border-top:1px solid var(--line);}
.titem .tn{font-family:var(--font-display);font-size:24px;color:var(--accent);font-weight:600;flex-shrink:0;width:38px;line-height:1;padding-top:2px;}
.titem h4{font-size:17px;font-weight:700;color:var(--indigo);margin-bottom:8px;line-height:1.3;}
.titem p{font-size:14.5px;color:var(--ink-soft);line-height:1.55;}
.tnote{margin-top:14px;font-size:12px;background:var(--cream-2);border:1px solid var(--line);border-radius:30px;padding:5px 13px;display:inline-flex;gap:7px;align-items:center;color:var(--indigo);font-weight:600;}
.lead-magnet{margin-top:50px;display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.lm-card{display:flex;gap:22px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:26px 28px;box-shadow:var(--shadow-soft);transition:transform .3s,box-shadow .3s;}
.lm-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-card);}
.lm-doc{flex-shrink:0;width:64px;height:80px;background:linear-gradient(160deg,var(--cream-2),#fff);border:1px solid var(--line);border-radius:3px;position:relative;display:flex;align-items:flex-end;justify-content:center;padding-bottom:10px;box-shadow:var(--shadow-soft);}
.lm-doc::before{content:"";position:absolute;top:0;right:0;border-width:0 16px 16px 0;border-style:solid;border-color:var(--cream) var(--cream) var(--line);}
.lm-doc svg{width:26px;height:26px;color:var(--accent);}
.lm-card h4{font-size:16.5px;font-weight:700;color:var(--indigo);line-height:1.25;}
.lm-card p{font-size:13px;color:var(--ink-soft);margin:6px 0 12px;line-height:1.45;}

/* ============================================================
   CONTRACTOR
   ============================================================ */
.contr-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,5vw,80px);align-items:center;}
.contr-grid .lead{margin-top:20px;}
.contr-stats{display:grid;grid-template-columns:1fr 1fr;gap:30px 24px;margin-top:36px;}
.cstat .cv{font-family:var(--font-display);font-size:clamp(40px,4vw,58px);font-weight:500;color:#fff;line-height:1;}
.cstat .cv .u{font-size:.4em;color:var(--gold);font-family:var(--font-body);font-weight:600;margin-left:4px;}
.cstat .cl{font-size:13.5px;color:rgba(242,236,223,.65);margin-top:8px;line-height:1.4;}
.subs{margin-top:8px;display:flex;flex-direction:column;gap:0;}
.sub{padding:20px 0;border-bottom:1px solid rgba(255,255,255,.12);}
.sub:first-child{border-top:1px solid rgba(255,255,255,.12);}
.sub h5{font-size:15px;font-weight:700;color:#fff;}
.sub p{font-size:13.5px;color:rgba(242,236,223,.66);margin-top:4px;}
.base-tags{display:flex;gap:9px;flex-wrap:wrap;margin-top:24px;}
.base-tag{font-size:12.5px;font-weight:500;color:#F2ECDF;border:1px solid rgba(255,255,255,.22);border-radius:30px;padding:7px 14px;}

/* ============================================================
   DEAL STEPS
   ============================================================ */
.steps{display:grid;grid-template-columns:repeat(6,1fr);gap:0;margin-top:48px;counter-reset:st;}
.step{padding:0 22px 0 0;position:relative;}
.step::before{counter-increment:st;content:"0" counter(st);font-family:var(--font-display);font-size:30px;color:var(--accent);font-weight:600;display:block;}
.step .sln{height:2px;background:var(--line);margin:14px 0 16px;position:relative;}
.step .sln::after{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:7px;height:7px;border-radius:50%;background:var(--accent);}
.step h4{font-size:15px;font-weight:700;color:var(--indigo);line-height:1.25;}
.step p{font-size:13px;color:var(--ink-soft);margin-top:7px;line-height:1.45;}

/* ============================================================
   FAQ
   ============================================================ */
.faq{max-width:880px;margin:46px auto 0;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:20px;width:100%;text-align:left;padding:24px 0;font-size:18px;font-weight:600;color:var(--indigo);font-family:var(--font-body);}
.faq-q .pm{flex-shrink:0;width:30px;height:30px;border:1px solid var(--line);border-radius:50%;position:relative;transition:.3s;}
.faq-q .pm::before,.faq-q .pm::after{content:"";position:absolute;left:50%;top:50%;background:var(--accent);transition:.3s;}
.faq-q .pm::before{width:12px;height:1.5px;transform:translate(-50%,-50%);}
.faq-q .pm::after{width:1.5px;height:12px;transform:translate(-50%,-50%);}
.faq-item.open .faq-q .pm{background:var(--accent);border-color:var(--accent);}
.faq-item.open .faq-q .pm::before,.faq-item.open .faq-q .pm::after{background:#fff;}
.faq-item.open .faq-q .pm::after{transform:translate(-50%,-50%) scaleY(0);}
.faq-a{overflow:hidden;max-height:0;transition:max-height .45s cubic-bezier(.4,0,.2,1);}
.faq-a-inner{padding:0 0 26px;color:var(--ink-soft);font-size:15.5px;line-height:1.65;max-width:72ch;}

/* ============================================================
   FINAL FORM
   ============================================================ */
.final{position:relative;overflow:hidden;color:#fff;}
.final-bg{position:absolute;inset:0;}
.final-bg img{width:100%;height:100%;object-fit:cover;}
.final-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,rgba(15,24,42,.92) 0%,rgba(21,33,56,.82) 45%,rgba(21,33,56,.45) 100%);}
.final-inner{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center;}
.final-copy h2{font-family:var(--font-display);font-weight:500;font-size:clamp(36px,4.4vw,58px);line-height:1.02;}
.final-copy h2 em{font-style:italic;color:var(--gold);}
.final-copy .lead{color:rgba(255,255,255,.85);margin-top:22px;max-width:46ch;}
.final-mgr{margin-top:34px;display:flex;gap:16px;align-items:center;}
.final-mgr .av{width:56px;height:56px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:22px;color:#fff;font-weight:600;}
.final-mgr .mn{font-weight:700;font-size:15px;}
.final-mgr .mr{font-size:13px;color:rgba(255,255,255,.7);}
.final-msgs{display:flex;gap:10px;margin-top:22px;}
.msg-btn{display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:40px;padding:10px 18px;font-size:13.5px;font-weight:600;color:#fff;transition:.25s;}
.msg-btn:hover{background:#fff;color:var(--indigo);}
.msg-btn svg{width:16px;height:16px;}

/* form card */
.form-card{background:#fff;color:var(--ink);border-radius:var(--radius);padding:clamp(28px,3vw,42px);box-shadow:var(--shadow-card);}
.form-card h3{font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--indigo);}
.form-card .fc-sub{font-size:14px;color:var(--ink-soft);margin-top:6px;}
.field{margin-top:18px;}
.field label{display:block;font-size:12.5px;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);text-transform:uppercase;margin-bottom:7px;}
.field input,.field select{width:100%;padding:14px 16px;border:1px solid var(--line);border-radius:var(--radius);font-family:inherit;font-size:15px;color:var(--ink);background:var(--cream);transition:border-color .2s,box-shadow .2s;}
.field input:focus,.field select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(176,97,59,.13);background:#fff;}
.field.err input{border-color:#c0432f;box-shadow:0 0 0 3px rgba(192,67,47,.12);}
.field .errmsg{font-size:12px;color:#c0432f;margin-top:6px;font-weight:600;}
.villa-pick{display:flex;gap:10px;margin-top:7px;}
.villa-pick button{flex:1;padding:12px;border:1px solid var(--line);border-radius:var(--radius);font-size:13.5px;font-weight:600;color:var(--ink-soft);background:var(--cream);transition:.2s;}
.villa-pick button.sel{border-color:var(--accent);color:var(--accent);background:#fff;box-shadow:0 0 0 2px rgba(176,97,59,.12);}
.consent{display:flex;gap:11px;align-items:flex-start;margin-top:20px;cursor:pointer;}
.consent input{margin-top:3px;width:17px;height:17px;flex-shrink:0;accent-color:var(--accent);cursor:pointer;}
.consent span{font-size:12px;color:var(--ink-soft);line-height:1.5;}
.consent a{color:var(--accent);border-bottom:1px solid currentColor;}
.consent.err span{color:#c0432f;}
.consents{margin-top:18px;display:flex;flex-direction:column;gap:12px;}
.consents .consent{margin-top:0;}

/* ============================================================
   LEGAL POPUP (consent / privacy policy)
   ============================================================ */
.legal-ov{position:fixed;inset:0;z-index:95;background:rgba(15,24,42,.66);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .3s;}
.legal-ov.open{opacity:1;pointer-events:auto;}
.legal-modal{width:min(720px,100%);max-height:88vh;display:flex;flex-direction:column;background:#fff;border-radius:var(--radius);box-shadow:0 40px 100px -30px rgba(15,24,42,.6);transform:translateY(22px) scale(.985);transition:transform .4s cubic-bezier(.2,.8,.2,1);}
.legal-ov.open .legal-modal{transform:none;}
.legal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;padding:26px clamp(24px,3vw,40px) 16px;border-bottom:1px solid var(--line);}
.legal-head h3{font-family:var(--font-display);font-weight:500;font-size:clamp(21px,2.3vw,27px);color:var(--indigo);line-height:1.12;}
.legal-head .modal-x{position:static;flex-shrink:0;width:38px;height:38px;background:var(--cream-2);}
.legal-body{overflow-y:auto;padding:20px clamp(24px,3vw,40px) clamp(28px,3vw,40px);}
.legal-body .lh{font-size:15.5px;font-weight:700;color:var(--indigo);margin:24px 0 2px;}
.legal-body .lh:first-child{margin-top:0;}
.legal-body p{font-size:14.5px;color:var(--ink);line-height:1.62;margin-top:10px;max-width:none;}
.legal-body .lul{margin:6px 0 0;padding-left:20px;}
.legal-body .lul li{font-size:14.5px;color:var(--ink);line-height:1.55;margin-top:6px;}
@media (prefers-reduced-motion:reduce){.legal-modal{transition:none;}}
.form-card .btn-primary{width:100%;justify-content:center;margin-top:22px;padding:17px;font-size:15.5px;}
.btn[disabled],.btn[aria-busy="true"]{opacity:.72;cursor:progress;pointer-events:none;}
.spin{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;display:inline-block;animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.spin{animation-duration:1.6s;}}
.form-success{text-align:center;padding:30px 10px;}
.form-success .chk{width:64px;height:64px;border-radius:50%;background:var(--cream-2);display:flex;align-items:center;justify-content:center;margin:0 auto 20px;color:var(--accent);animation:pop .5s cubic-bezier(.2,1.4,.4,1);}
@keyframes pop{from{transform:scale(.3);opacity:0;}to{transform:scale(1);opacity:1;}}
.form-success h3{margin-bottom:10px;}
.form-success p{color:var(--ink-soft);font-size:14.5px;max-width:36ch;margin:0 auto 22px;}

/* ============================================================
   MODAL
   ============================================================ */
.modal-ov{position:fixed;inset:0;z-index:90;background:rgba(15,24,42,.62);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .35s;}
.modal-ov.open{opacity:1;pointer-events:auto;}
.modal{width:min(760px,100%);max-height:92vh;overflow:auto;background:#fff;border-radius:var(--radius);box-shadow:0 40px 100px -30px rgba(15,24,42,.6);transform:translateY(24px) scale(.98);transition:transform .4s cubic-bezier(.2,.8,.2,1);position:relative;}
.modal-ov.open .modal{transform:none;}
.modal-x{position:absolute;top:16px;right:16px;z-index:5;width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.85);display:flex;align-items:center;justify-content:center;color:var(--indigo);font-size:22px;transition:.2s;}
.modal-x:hover{background:var(--cream-2);transform:rotate(90deg);}
.modal-split{display:grid;grid-template-columns:.85fr 1fr;}
.modal-aside{position:relative;background:var(--indigo);overflow:hidden;display:flex;flex-direction:column;justify-content:flex-end;padding:34px;color:#fff;min-height:240px;}
.modal-aside img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.5;}
.modal-aside .ma-c{position:relative;z-index:2;}
.modal-aside .eyebrow{color:var(--gold);}
.modal-aside h4{font-family:var(--font-display);font-size:28px;font-weight:500;margin-top:12px;line-height:1.05;}
.modal-aside ul{margin:16px 0 0;padding:0;list-style:none;display:flex;flex-direction:column;gap:9px;}
.modal-aside li{font-size:13px;color:rgba(255,255,255,.82);display:flex;gap:9px;align-items:flex-start;line-height:1.4;}
.modal-aside li svg{width:14px;height:14px;color:var(--gold);flex-shrink:0;margin-top:3px;}
.modal-form{padding:clamp(28px,3vw,44px);}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:var(--indigo-deep);color:rgba(242,236,223,.62);padding:72px 0 36px;font-size:13.5px;line-height:1.6;}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1);}
.footer .ft-logo{height:54px;width:auto;margin-bottom:22px;}
.footer h5{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#fff;margin-bottom:16px;font-weight:700;}
.footer a:hover{color:var(--gold);}
.footer-links{display:flex;flex-direction:column;gap:9px;}
.footer-disc{padding-top:28px;font-size:12px;color:rgba(242,236,223,.42);line-height:1.6;max-width:96ch;}
.footer-bottom{display:flex;justify-content:space-between;gap:20px;flex-wrap:wrap;margin-top:24px;font-size:12.5px;}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1080px){
  .kn-grid{grid-template-columns:repeat(3,1fr);}
  .kn-cell:nth-child(3){border-right:none;}
  .kn-cell:nth-child(-n+3){border-bottom:1px solid rgba(255,255,255,.1);}
  .concept-grid{grid-template-columns:1fr;gap:54px;}
  .concept-media{max-width:520px;}
  .loc-top{grid-template-columns:1fr;gap:32px;}
  .loc-grid{grid-template-columns:repeat(3,1fr);}
  .loc-card.big{grid-column:span 3;grid-row:auto;aspect-ratio:16/9;}
  .loc-grid .loc-card:last-child{grid-column:span 3;aspect-ratio:16/7;}
  .infra-panel{grid-template-columns:1fr;}
  .infra-img{min-height:340px;}
  .villa-stage{grid-template-columns:1fr;gap:30px;}
  .contr-grid{grid-template-columns:1fr;gap:44px;}
  .steps{grid-template-columns:repeat(3,1fr);row-gap:38px;}
  .final-inner{grid-template-columns:1fr;gap:40px;}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media (max-width:760px){
  body{font-size:16px;}
  .hdr-nav,.hdr-tel{display:none;}
  .hdr-right .btn-primary{display:none;}
  .hdr-inner{justify-content:space-between;}
  .hdr-burger{display:flex;}
  .float-cta{display:block;}
  .hero{min-height:92svh;}
  .hero-scroll{display:none;}
  .kn-grid{grid-template-columns:repeat(2,1fr);}
  .kn-cell{border-right:1px solid rgba(255,255,255,.1);}
  .kn-cell:nth-child(2n){border-right:none;}
  .kn-cell:nth-child(-n+4){border-bottom:1px solid rgba(255,255,255,.1);}
  .gastro-grid{grid-template-columns:1fr 1fr;}
  .gcard.wide{grid-column:span 2;}
  .gcard.tall{grid-row:auto;aspect-ratio:1/1;}
  .gastro-grid .gcard:last-child{grid-column:span 2;aspect-ratio:16/9;}
  .inv-grid{grid-template-columns:1fr;}
  .trust-grid{grid-template-columns:1fr;gap:0;}
  .lead-magnet{grid-template-columns:1fr;}
  .villa-incl{grid-template-columns:1fr;}
  .ladder{padding-left:18px;padding-right:18px;}
  .ladder-chart{height:auto;gap:10px;}
  .lbars{height:180px;}
  .lbar{width:26px;}
  .lstage .ls-name{font-size:12px;}
  .lstage .ls-sub{font-size:10.5px;}
  .steps{grid-template-columns:1fr 1fr;}
  .modal-split{grid-template-columns:1fr;}
  .modal-aside{min-height:170px;}
  .footer-top{grid-template-columns:1fr;}
  .concept-media .inset{width:42%;right:-12px;bottom:-18px;}
  .price-ladder-mini{flex-direction:column;align-items:stretch;}
  .parrow{transform:rotate(90deg);align-self:center;}
}
@media (max-width:430px){
  .loc-grid{grid-template-columns:1fr 1fr;}
  .loc-grid .loc-card:last-child{grid-column:span 2;aspect-ratio:16/9;}
  .gastro-grid{grid-template-columns:1fr;}
  .gastro-grid .gcard:last-child{grid-column:auto;aspect-ratio:16/10;}
  .villa-thumbs img{width:64px;height:48px;}
}
