:root{
    --gold:#aa8453;--gold-d:#8e6d42;--gold-l:rgba(170,132,83,.12);
    --bg:#fcfcfc;--warm:#f8f5f0;--surf:#fff;
    --text:#2a2a2a;--mid:#6b6b6b;--light:#a0a0a0;--border:rgba(0,0,0,.06);
    --nav-bg:rgba(252,252,252,.96);
    --ft-bottom:#7a9199;--ft-text-muted:rgba(255,255,255,.3);--ft-text-phone:rgba(255,255,255,.85);
    --font:'Montserrat',system-ui,sans-serif;
    --r:1.5rem;--ease:cubic-bezier(.16,1,.3,1);--max:1200px;--px:clamp(20px,5vw,80px);
}
[data-theme="dark"]{
    --bg:#111113;--warm:#18181c;--surf:#1e1e23;
    --text:#f0ede8;--mid:#9a9490;--light:#5a5652;--border:rgba(255,255,255,.07);
    --nav-bg:rgba(17,17,19,.96);
    --gold:#c9a96e;--gold-d:#b8935a;--gold-l:rgba(201,169,110,.1);
    --ft-bottom:#0e1518;--ft-text-muted:rgba(255,255,255,.22);--ft-text-phone:rgba(255,255,255,.75);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--bg);color:var(--text);font-family:var(--font);font-size:16px;line-height:1.7;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{display:block;max-width:100%;height:auto;object-fit:cover}
a{text-decoration:none;color:inherit}ul{list-style:none}
h1,h2,h3,h4{font-family:var(--font);font-weight:400}
.container{width:100%;max-width:var(--max);margin:0 auto;padding:0 var(--px)}

/* Buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:15px 38px;border-radius:100px;font-family:var(--font);font-size:13px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;border:none;position:relative;overflow:hidden;transition:all .35s var(--ease)}
.btn::after{content:'';position:absolute;inset:0;background:rgba(255,255,255,.15);transform:translateX(-110%);transition:transform .5s var(--ease)}
.btn:hover::after{transform:translateX(0)}
.btn:active{transform:scale(.97) translateY(1px)}
.btn-hero{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.7);backdrop-filter:blur(4px)}
.btn-hero:hover{background:#fff;color:var(--text);box-shadow:0 0 20px rgba(201,169,110,0.5),0 0 50px rgba(201,169,110,0.25),0 10px 36px rgba(0,0,0,.15)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:var(--gold-d);box-shadow:0 0 20px rgba(201,169,110,0.55),0 0 50px rgba(201,169,110,0.25),0 10px 32px rgba(170,132,83,.3);transform:translateY(-2px)}
.btn-full{width:100%}

/* Nav */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:22px var(--px);transition:all .5s var(--ease)}
.nav.scrolled{background:var(--nav-bg);backdrop-filter:blur(18px);padding:14px var(--px);box-shadow:0 1px 0 var(--border)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:var(--max);margin:0 auto}
.nav-logo{display:flex;align-items:center;transition:opacity .3s}
.nav-logo:hover{opacity:.8}
.nav-logo-img{height:28px;width:auto;filter:brightness(0) invert(1);transition:filter .5s var(--ease)}
.nav.scrolled .nav-logo-img{filter:none}
.nav-links{display:flex;gap:32px}
.nav-link{font-size:12px;font-weight:500;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.8);transition:color .3s;position:relative}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1.5px;background:var(--gold);transition:width .35s var(--ease)}
.nav-link:hover::after{width:100%}
.nav-link:hover{color:#fff}
.nav.scrolled .nav-link{color:var(--mid)}
.nav.scrolled .nav-link:hover{color:var(--gold)}
.nav-cta{font-size:12px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);border:1.5px solid rgba(170,132,83,.4);padding:9px 24px;border-radius:100px;transition:all .3s var(--ease)}
.nav-cta:hover{background:var(--gold);color:#fff;transform:translateY(-1px);box-shadow:0 6px 20px rgba(170,132,83,.3)}
/* Theme toggle */
.theme-toggle{width:36px;height:36px;border-radius:50%;border:1.5px solid rgba(255,255,255,.3);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .35s var(--ease);color:rgba(255,255,255,.85);flex-shrink:0;outline:none}
.theme-toggle:hover{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.6);transform:rotate(20deg)}
.nav.scrolled .theme-toggle{border-color:var(--border);color:var(--mid)}
.nav.scrolled .theme-toggle:hover{background:var(--warm);color:var(--gold)}
.theme-toggle .icon-sun{display:none}
[data-theme="dark"] .theme-toggle .icon-moon{display:none}
[data-theme="dark"] .theme-toggle .icon-sun{display:block}
[data-theme="dark"] .nav.scrolled .nav-logo-img{filter:brightness(0) invert(1)}

/* Hero */
.hero{position:relative;min-height:100dvh;display:flex;align-items:center;justify-content:flex-start;overflow:hidden}
.hero-bg{position:absolute;inset:0}
.hero-slide{position:absolute;inset:0;background-size:cover;background-position:center;opacity:0;transition:opacity 1.8s ease;will-change:opacity}
.hero-slide-active{opacity:1}
.hero-slide-label{position:absolute;bottom:clamp(28px,3.5vw,48px);left:clamp(20px,2.5vw,40px);display:flex;flex-direction:column;align-items:flex-start;gap:3px;opacity:0;transform:translateY(6px);transition:opacity .7s ease .7s,transform .7s ease .7s;pointer-events:none}
.hero-slide-active .hero-slide-label{opacity:1;transform:translateY(0)}
.hsl-sub{font-size:clamp(8px,.62vw,10px);font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-bottom:1px}
.hsl-name{font-size:clamp(10px,.85vw,13px);font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.9)}
.hsl-loc{font-size:clamp(9px,0.75vw,11px);font-weight:400;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.45)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.45) 0%,rgba(0,0,0,.5) 50%,rgba(0,0,0,.7) 100%)}
.hero-content{position:relative;z-index:2;max-width:720px;width:100%;padding:0 var(--px);text-align:left}
.hero-label{font-size:13px;font-weight:400;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;opacity:0;animation:fadeUp .8s var(--ease) .3s forwards}
.hero-title{font-size:clamp(42px,7vw,76px);font-weight:500;line-height:1.02;color:#fff;margin-bottom:22px;letter-spacing:.04em;text-transform:uppercase;opacity:0;animation:fadeUp .9s var(--ease) .45s forwards}
.hero-title-gold{font-family:var(--font);font-style:normal;font-weight:500;color:#fff;display:inline;animation:goldGlow 4s ease-in-out infinite}
@keyframes goldGlow{
  0%,100%{text-shadow:0 0 8px rgba(201,169,110,0),0 0 0px rgba(201,169,110,0)}
  50%{text-shadow:0 0 24px rgba(201,169,110,0.7),0 0 60px rgba(201,169,110,0.3),0 0 100px rgba(201,169,110,0.1)}
}
.hero-sub{font-size:clamp(15px,2vw,17px);color:rgba(255,255,255,.72);font-weight:300;margin-bottom:38px;opacity:0;animation:fadeUp .8s var(--ease) .6s forwards}
.hero-content .btn{opacity:0;animation:fadeUp .8s var(--ease) .75s forwards}
.hero-dots{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:3;display:flex;gap:10px}
.hero-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);cursor:pointer;transition:all .35s var(--ease)}
.hero-dot-active{background:#fff;transform:scale(1.35)}
.hero-dot:hover{background:rgba(255,255,255,.65)}
.scroll-line{position:absolute;bottom:80px;left:50%;transform:translateX(-50%);z-index:2}
.scroll-line span{display:block;width:1px;height:48px;background:linear-gradient(to bottom,rgba(255,255,255,.5),transparent);animation:pulse 2.2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.3;transform:scaleY(.6);transform-origin:top}50%{opacity:1;transform:scaleY(1)}}

/* Advantages */
.adv{padding:90px 0;background:var(--bg)}
.adv-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0}
.adv-item{padding:40px 28px;border-left:1px solid var(--border);transition:background .4s var(--ease),transform .4s var(--ease)}
.adv-item:first-child{border-left:none}
.adv-item:hover{background:var(--gold-l);transform:translateY(-3px)}
.adv-num{font-size:12px;font-weight:500;color:var(--gold);margin-bottom:14px;letter-spacing:.06em}
.adv-item h3{font-size:15px;font-weight:500;margin-bottom:8px}
.adv-item p{font-size:13px;color:var(--mid);line-height:1.6}

/* ============ Object Hero ============ */
.obj-hero{position:relative;min-height:80vh;display:flex;align-items:flex-end;justify-content:flex-start;overflow:hidden}
.obj-hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform 8s ease-out;will-change:transform}
.obj-hero.in-view .obj-hero-bg{transform:scale(1.04)}
.obj-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.obj-hero-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.08) 0%,rgba(0,0,0,.12) 40%,rgba(0,0,0,.65) 100%)}
.obj-hero-content{position:relative;z-index:2;padding:0 var(--px) 80px;max-width:var(--max);width:100%;margin:0 auto}
.obj-logo-park{height:60px;width:auto;filter:brightness(0) invert(1);margin-bottom:20px;opacity:.9}

/* ============ ПАРК Hero (стиль park-deso.ru) ============ */
.park-hero-wrap{padding:8px clamp(8px,1.5vw,24px) 12px;background:var(--bg)}
.park-hero-box{position:relative;width:100%;height:calc(100svh - clamp(46px,4.5vw,60px) - 20px);min-height:500px;border-radius:clamp(16px,2vw,32px);overflow:hidden;box-shadow:0 4px 32px rgba(0,0,0,.12)}
.park-hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center;z-index:0}
.park-hero-grad{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.82) 0%,rgba(0,0,0,.45) 40%,rgba(0,0,0,.72) 100%);z-index:1;pointer-events:none}
.park-hero-center{position:absolute;inset:0;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none}
.park-hero-logo{width:clamp(220px,28vw,400px);height:auto;filter:brightness(0) invert(1);margin-bottom:20px}
.park-hero-tagline{font-size:clamp(9px,0.72vw,12px);font-weight:500;letter-spacing:.18em;color:rgba(255,255,255,.7);text-transform:uppercase}
.park-hero-addr{position:absolute;bottom:clamp(20px,3vw,40px);left:clamp(20px,2.5vw,36px);z-index:2}
.park-hero-addr-sub{font-size:clamp(9px,0.7vw,11px);font-weight:500;letter-spacing:.18em;color:rgba(255,255,255,.5);text-transform:uppercase;margin-bottom:3px}
.park-hero-addr-main{font-size:clamp(11px,0.9vw,14px);font-weight:500;letter-spacing:.08em;color:rgba(255,255,255,.9);text-transform:uppercase}
.park-hero-deso{position:absolute;bottom:clamp(20px,3vw,40px);right:clamp(20px,2.5vw,36px);z-index:2}
.park-hero-deso-img{height:clamp(18px,1.8vw,28px);width:auto;filter:brightness(0) invert(1);opacity:.85;transition:opacity .2s}
.park-hero-deso-img:hover{opacity:1}
.park-hero-scroll{position:absolute;bottom:clamp(24px,3vw,40px);left:50%;transform:translateX(-50%);z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;animation:bounce 2s ease-in-out infinite;opacity:.7}
.park-hero-scroll-line{width:1px;height:32px;background:rgba(255,255,255,.6)}
@keyframes bounce{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(6px)}}
.obj-tag{font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;display:inline-block;padding:6px 16px;border:1px solid rgba(170,132,83,.4);border-radius:100px;backdrop-filter:blur(6px);background:rgba(0,0,0,.2)}
.obj-tag-light{background:rgba(255,255,255,.1)}
.obj-name{font-size:clamp(48px,8vw,96px);font-weight:300;line-height:.95;color:#fff;letter-spacing:-.03em;margin-bottom:20px;text-shadow:0 2px 40px rgba(0,0,0,.25)}
.obj-lead{font-size:clamp(15px,1.8vw,18px);color:rgba(255,255,255,.8);font-weight:400;line-height:1.6;max-width:560px}

/* ============ Object Details ============ */
.obj-details{padding:100px 0;background:var(--bg)}
.obj-details-warm{background:var(--warm)}
.obj-details-bg{position:relative;background-size:cover;background-position:center;background-attachment:fixed}
.obj-details-bg::before{content:'';position:absolute;inset:0;background:rgba(0,0,0,.55);z-index:0;pointer-events:none}
.obj-details-bg .container{position:relative;z-index:1}
.obj-details-bg .spec-card{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.12);backdrop-filter:blur(12px)}
.obj-details-bg .sl{color:rgba(255,255,255,.5)}
.obj-details-bg .sv{color:rgba(255,255,255,.9)}

/* ============ Инфраструктура ============ */
.infra{padding:72px 0;background:var(--bg)}
.infra-warm{background:var(--warm)}
.infra-title{font-size:clamp(9px,0.7vw,11px);font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:36px}
.infra-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:28px}
.infra-item{display:flex;align-items:flex-start;gap:14px}
.infra-ico{width:36px;height:36px;border-radius:10px;background:var(--gold-l);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.infra-label{font-size:11px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);margin-bottom:3px}
.infra-val{font-size:clamp(12px,1vw,14px);font-weight:400;color:var(--text)}

/* ============ Планировки ============ */
.plans-cta{padding:100px 0;background:var(--bg)}
.plans-inner{display:grid;grid-template-columns:1fr 1.4fr;gap:clamp(40px,6vw,100px);align-items:center}
.plans-tag{font-size:11px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.plans-cta h2{font-size:clamp(28px,3.5vw,46px);font-weight:500;letter-spacing:.03em;text-transform:uppercase;line-height:1.08;margin-bottom:18px;color:var(--text)}
.plans-cta p{font-size:clamp(13px,1vw,15px);color:var(--mid);line-height:1.7;margin-bottom:32px}
.plans-btns{display:flex;gap:14px;flex-wrap:wrap}
.btn-outline{font-size:12px;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--text);border:1.5px solid var(--border);padding:13px 28px;border-radius:100px;transition:all .3s var(--ease)}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.plans-cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.plans-card{display:block;background:var(--surf);border:1px solid var(--border);border-radius:clamp(12px,1.5vw,20px);padding:clamp(20px,2.5vw,32px);transition:all .35s var(--ease);text-decoration:none;cursor:pointer}
.plans-card:hover{border-color:var(--gold);transform:translateY(-4px);box-shadow:0 12px 40px rgba(170,132,83,.12)}
.plans-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.plans-card-tag{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.plans-card-arrow{font-size:16px;color:var(--light);transition:transform .3s}
.plans-card:hover .plans-card-arrow{transform:translateX(4px);color:var(--gold)}
.plans-card-range{font-size:clamp(20px,2.2vw,28px);font-weight:500;color:var(--text);margin-bottom:4px}
.plans-card-loc{font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--mid);margin-bottom:18px}
.plans-card-types{display:flex;flex-wrap:wrap;gap:6px}
.plans-card-types span{font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--mid);background:var(--warm);padding:4px 10px;border-radius:100px}
.obj-grid-reverse{grid-template-columns:1fr 1.2fr}
.obj-grid-reverse .obj-gallery{order:2}
.obj-grid-reverse .obj-info{order:1}

.obj-main-wrap{aspect-ratio:4/3;border-radius:var(--r);overflow:hidden;background:var(--warm);margin-bottom:12px;box-shadow:0 6px 30px rgba(0,0,0,.08)}
.obj-main-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease),opacity .3s}
.obj-main-wrap:hover img{transform:scale(1.03)}

.obj-thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px}
.obj-thumb{aspect-ratio:1;border-radius:8px;overflow:hidden;cursor:pointer;opacity:.45;border:2px solid transparent;transition:all .35s var(--ease)}
.obj-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .4s var(--ease)}
.obj-thumb:hover{opacity:.8;transform:translateY(-2px)}
.obj-thumb:hover img{transform:scale(1.1)}
.obj-thumb.active{opacity:1;border-color:var(--gold)}

.spec-card{display:flex;flex-direction:column;background:var(--surf);border-radius:var(--r);border:1px solid var(--border);overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.04);margin-bottom:32px}
.spec-row{display:flex;justify-content:space-between;align-items:center;padding:18px 28px;border-bottom:1px solid var(--border);transition:all .3s var(--ease)}
.spec-row:last-child{border-bottom:none}
.spec-row:hover{background:var(--gold-l);padding-left:34px}
.sl{font-size:12px;color:var(--light);font-weight:400;text-transform:uppercase;letter-spacing:.08em}
.sv{font-size:14px;color:var(--text);font-weight:500}

/* Contact */
.contact{padding:120px 0;background:var(--warm);position:relative;overflow:hidden}
.contact::before{content:'';position:absolute;top:-200px;right:-100px;width:500px;height:500px;background:radial-gradient(circle,rgba(170,132,83,.08) 0%,transparent 70%);pointer-events:none}
.contact-wrap{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center}
.contact-text h2{font-size:clamp(30px,4vw,44px);font-weight:300;line-height:1.15;margin-bottom:20px;letter-spacing:-.02em}
.contact-text p{font-size:15px;color:var(--mid);line-height:1.7;max-width:400px}
.contact-form{display:flex;flex-direction:column;gap:14px}
.field-wrap{position:relative}
.field-wrap input{width:100%;background:var(--surf);border:1px solid var(--border);border-radius:14px;padding:18px 20px 10px;font-family:var(--font);font-size:15px;color:var(--text);outline:none;transition:border-color .3s,box-shadow .3s}
.field-wrap label{position:absolute;top:15px;left:20px;font-size:14px;color:var(--light);pointer-events:none;transition:all .25s var(--ease)}
.field-wrap input:focus,.field-wrap input:not(:placeholder-shown){border-color:var(--gold);box-shadow:0 0 0 3px rgba(170,132,83,.1)}
.field-wrap input:focus+label,.field-wrap input:not(:placeholder-shown)+label{top:5px;font-size:10px;color:var(--gold);font-weight:500;letter-spacing:.06em}
/* Checkboxes */
.consent-label{display:flex;align-items:flex-start;gap:10px;cursor:pointer;font-size:12px;color:var(--mid);line-height:1.5}
.consent-label input[type=checkbox]{width:16px;height:16px;flex-shrink:0;margin-top:2px;accent-color:var(--gold);cursor:pointer}
.consent-link{color:var(--gold);text-decoration:underline;text-underline-offset:2px}
.consent-link:hover{opacity:.75}
.form-ok{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:48px 32px;background:var(--surf);border-radius:var(--r);border:1px solid rgba(170,132,83,.15)}
.form-ok-ico{width:52px;height:52px;border-radius:50%;background:var(--gold-l);display:flex;align-items:center;justify-content:center;color:var(--gold);animation:pop .5s var(--ease)}
.form-ok h3{font-size:20px;font-weight:500}
.form-ok p{font-size:14px;color:var(--mid)}

/* Валидация */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-6px)}40%{transform:translateX(6px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
.field-err{display:none;font-size:11px;color:#c0392b;margin-top:5px;padding-left:4px;animation:fadeIn .2s ease}
.field-has-error .field-err{display:block}
.consent-err{display:none;font-size:11px;color:#c0392b;margin-top:-8px;padding-left:4px;animation:fadeIn .2s ease}
.consent-has-error + .consent-err{display:block}
.field-has-error input{border-color:#c0392b !important;box-shadow:0 0 0 3px rgba(192,57,43,.1) !important}
.consent-has-error{outline:2px solid rgba(192,57,43,.4);outline-offset:4px;border-radius:6px}
.form-shake{animation:shake .4s ease}
.form-ok-ico svg{color:var(--gold)}

/* ============ ФУТЕР ============ */
.site-footer{background:var(--warm)}
.ft-top{display:grid;grid-template-columns:1fr 1fr;min-height:clamp(420px,55vw,760px)}
.ft-photo{position:relative;overflow:hidden}
.ft-photo img{width:100%;height:100%;object-fit:cover;object-position:center}
.ft-contacts{display:flex;flex-direction:column;justify-content:space-between;align-items:center;text-align:center;padding:clamp(40px,5vw,80px) clamp(32px,5vw,80px);gap:16px}
.ft-logos{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:28px;flex-wrap:wrap}
.ft-logo-obj{height:clamp(28px,3.5vw,52px);width:auto;object-fit:contain}
.ft-divider{width:100%;height:1px;background:rgba(0,0,0,.1);margin:4px 0}
.ft-mini-divider{width:24px;height:1px;background:rgba(0,0,0,.15)}
.ft-label{font-size:clamp(7px,0.55vw,9px);letter-spacing:.26em;color:rgba(0,0,0,.38);text-transform:uppercase}
.ft-phone{display:block;font-size:clamp(14px,1.1vw,17px);font-weight:400;color:rgba(0,0,0,.78);transition:opacity .2s}
.ft-phone:hover{opacity:.6}
.ft-email{font-size:clamp(11px,0.8vw,13px);color:rgba(0,0,0,.55);transition:opacity .2s}
.ft-email:hover{opacity:.6}
.ft-addr{font-size:clamp(11px,0.8vw,13px);color:rgba(0,0,0,.42)}
.ft-site{font-size:clamp(8px,0.55vw,10px);letter-spacing:.18em;color:rgba(0,0,0,.35);text-transform:uppercase;transition:opacity .2s}
.ft-site:hover{opacity:.6}

/* Нижняя тёмная полоса */
.ft-bottom{background:var(--ft-bottom)}
.ft-bottom-inner{display:flex;align-items:center;justify-content:space-between;padding:clamp(28px,3.5vw,52px) clamp(20px,3vw,56px);gap:24px}
.ft-bottom-left{display:flex;flex-direction:column;gap:6px}
.ft-b-phone{font-size:clamp(13px,1.2vw,18px);font-weight:300;color:var(--ft-text-phone);transition:opacity .2s}
.ft-b-phone:hover{opacity:.65}
.ft-b-email{font-size:clamp(9px,0.65vw,11px);color:rgba(255,255,255,.38);text-transform:uppercase;letter-spacing:.16em;margin-top:2px}
.ft-bottom-center{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:24px;flex-wrap:wrap}
.ft-b-logo{height:clamp(28px,3.5vw,52px);width:auto;filter:brightness(0) invert(1);object-fit:contain}
.ft-b-logo-deso{height:clamp(16px,1.8vw,28px)}
.ft-bottom-right{display:flex;flex-direction:column;align-items:flex-end;gap:12px}
.ft-tg{font-size:clamp(9px,0.65vw,11px);letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.5);transition:opacity .2s}
.ft-tg:hover{opacity:.85}
.ft-b-cta{font-size:clamp(10px,0.78vw,12px);letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7);border:1px solid rgba(255,255,255,.25);padding:clamp(10px,1.2vw,16px) clamp(18px,2.5vw,40px);transition:all .3s}
.ft-b-cta:hover{background:#fff;color:#7a9199}
.ft-legal-row{display:flex;align-items:center;justify-content:center;gap:14px;padding:0 clamp(20px,3vw,56px) clamp(14px,1.8vw,24px)}
.ft-policy{font-size:clamp(9px,0.6vw,11px);color:var(--ft-text-muted);text-transform:uppercase;letter-spacing:.16em;transition:opacity .2s}
.ft-policy:hover{opacity:.65}
.ft-dot{color:rgba(255,255,255,.12);font-size:11px}
.ft-copy{font-size:clamp(9px,0.6vw,11px);color:var(--ft-text-muted);letter-spacing:.1em}
.ft-disclaimer{font-size:10px;color:rgba(255,255,255,.45);text-align:center;line-height:1.7;padding:0 clamp(20px,3vw,56px) clamp(16px,2vw,28px);border-top:1px solid rgba(255,255,255,.1);padding-top:14px;max-width:1100px;margin:0 auto}

@media(max-width:768px){
    .ft-top{grid-template-columns:1fr}
    .ft-photo{height:300px}
    .ft-bottom-inner{flex-direction:column;align-items:center;text-align:center}
    .ft-bottom-left{align-items:center}
    .ft-bottom-right{align-items:center}
}

/* WA */
.wa-btn{position:fixed;bottom:28px;right:28px;z-index:99;width:54px;height:54px;border-radius:50%;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 18px rgba(37,211,102,.35);transition:transform .3s var(--ease),box-shadow .3s;animation:pop .6s var(--ease) 1.5s both}
.wa-btn:hover{transform:scale(1.12) translateY(-2px);box-shadow:0 8px 28px rgba(37,211,102,.45)}

/* Animations */
[data-animate]{opacity:0;transform:translateY(32px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
[data-animate].in-view{opacity:1;transform:translateY(0)}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{from{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}

/* Scrollbar */
::-webkit-scrollbar{width:6px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--gold);border-radius:4px}

/* Responsive */
@media(max-width:1024px){
    .obj-grid,.obj-grid-reverse{gap:40px}
    .adv-grid{grid-template-columns:repeat(2,1fr)}
    .adv-item:nth-child(1),.adv-item:nth-child(3){border-left:none}
    .adv-item:nth-child(3),.adv-item:nth-child(4){border-top:1px solid var(--border)}
}
@media(max-width:768px){
    :root{--px:20px}
    .nav-links,.nav-cta{display:none}
    .adv-grid{grid-template-columns:1fr}
    .adv-item{border-left:none;border-top:1px solid var(--border);padding:24px 16px}
    .adv-item:first-child{border-top:none}
    .obj-hero{min-height:60vh}
    .obj-details{padding:64px 0}
    .obj-grid,.obj-grid-reverse{grid-template-columns:1fr;gap:32px}
    .obj-grid-reverse .obj-gallery{order:0}
    .obj-grid-reverse .obj-info{order:0}
    .contact-wrap{grid-template-columns:1fr;gap:40px}
    .contact{padding:80px 0}
    .footer-row{flex-direction:column;gap:8px;text-align:center}
    .wa-btn{bottom:18px;right:18px;width:48px;height:48px}
}
@media(max-width:480px){
    .hero-title{font-size:38px}
    .obj-name{font-size:48px}
    .obj-thumbs{gap:4px}
}

/* ============ Попап планировки ============ */
.plans-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .35s var(--ease)}
.plans-modal.active{opacity:1;pointer-events:all}
.plans-modal-overlay{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(6px)}
.plans-modal-box{position:relative;z-index:1;width:min(1200px,96vw);height:min(88vh,900px);background:var(--surf);border-radius:clamp(12px,1.5vw,20px);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 32px 80px rgba(0,0,0,.4);transform:translateY(24px) scale(.97);transition:transform .4s var(--ease);border:1px solid var(--border)}
.plans-modal.active .plans-modal-box{transform:translateY(0) scale(1)}
.plans-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border);flex-shrink:0}
.plans-modal-title{font-size:12px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--mid)}
.plans-modal-close{width:32px;height:32px;border-radius:50%;border:1px solid var(--border);background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--mid);transition:all .2s}
.plans-modal-close:hover{background:var(--warm);color:var(--text)}
.plans-modal #plans-iframe{flex:1;width:100%;border:none;background:var(--warm)}
@media(max-width:600px){
    .plans-modal-box{width:100%;height:100%;border-radius:0}
}

/* ============ Cookie Banner ============ */
.cookie-bar{position:fixed;bottom:0;left:0;right:0;z-index:900;background:#fff;border-top:1px solid var(--border);box-shadow:0 -4px 32px rgba(0,0,0,.08);transform:translateY(100%);transition:transform .4s cubic-bezier(.22,1,.36,1);pointer-events:none}
.cookie-bar.visible{transform:translateY(0);pointer-events:all}
.cookie-bar-inner{max-width:var(--max);margin:0 auto;padding:20px clamp(20px,3vw,60px);display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.cookie-bar-inner p{font-size:13px;color:var(--mid);line-height:1.6;flex:1;min-width:200px}
.cookie-bar-inner a{color:var(--gold)}
.cookie-btns{display:flex;align-items:center;gap:14px;flex-shrink:0}
.cookie-accept{font-size:12px;padding:10px 24px}
.cookie-more{font-size:12px;color:var(--mid);letter-spacing:.08em;text-transform:uppercase;transition:color .2s}
.cookie-more:hover{color:var(--gold)}
@media(max-width:600px){.cookie-bar-inner{gap:14px}.cookie-btns{width:100%}.cookie-accept{flex:1;text-align:center}}
