/* ============================================================
   ТЕТЯНА · OLD MONEY — shared design system
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#F4F1EA; --bg-2:#EDE8DD; --bg-3:#E4DDCF;
  --ink:#1C1B18; --ink-soft:#3A3A32; --ink-mute:#6B675C;
  --green:#2A3B31; --green-dark:#14140F;
  --camel:#A67B5B; --brass:#B8A98C; --hair:#CFC6B4;
  --hair-dark:#2E2E26;
  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --pad-x:clamp(24px,6vw,96px);
  --pad-y:clamp(96px,12vh,180px);
  --maxw:1320px;
  --ease:cubic-bezier(.16,1,.3,1);
}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:auto}
body{background:var(--bg);color:var(--ink-soft);font-family:var(--sans);font-weight:300;font-size:18px;line-height:1.7;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;background:none;border:none;color:inherit}
::selection{background:var(--camel);color:var(--bg)}
:focus-visible{outline:1px solid var(--camel);outline-offset:4px}

h1,h2,h3{font-family:var(--serif);font-weight:300;color:var(--ink);line-height:1.1;letter-spacing:-.01em}
.eyebrow{font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--camel)}
.h-display{font-size:clamp(2.75rem,6vw,5.5rem)}
.h-section{font-size:clamp(2.1rem,4.4vw,3.7rem);font-weight:400}
p{max-width:68ch;text-align:left}
.lede{font-size:clamp(1.05rem,1.5vw,1.28rem);color:var(--ink-soft);line-height:1.65}

.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x)}
section{padding-block:var(--pad-y);position:relative}
.hair{height:1px;background:var(--hair);transform:scaleX(0);transform-origin:left;transition:transform 1100ms var(--ease)}
.is-in .hair,.hair.is-in{transform:scaleX(1)}

/* grain */
.grain{position:fixed;inset:0;z-index:60;pointer-events:none;opacity:.05;
  background:url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20width='160'%20height='160'%3E%3Cfilter%20id='n'%3E%3CfeTurbulence%20type='fractalNoise'%20baseFrequency='0.8'%20numOctaves='2'%20stitchTiles='stitch'/%3E%3C/filter%3E%3Crect%20width='160'%20height='160'%20filter='url(%23n)'/%3E%3C/svg%3E") repeat;background-size:160px 160px}

/* cursor */
.cursor{position:fixed;top:0;left:0;width:8px;height:8px;border:1px solid var(--brass);border-radius:50%;z-index:80;pointer-events:none;transform:translate(-50%,-50%);display:none;align-items:center;justify-content:center;transition:width .5s var(--ease),height .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease)}
.cursor__label{font-family:var(--sans);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--bg);opacity:0;transition:opacity .4s var(--ease)}
.cursor.is-big{width:78px;height:78px;background:rgba(42,59,49,.86);border-color:transparent}
.cursor.is-big .cursor__label{opacity:1}

/* header */
.header{position:fixed;top:0;left:0;width:100%;z-index:50;transition:transform .5s var(--ease),background .5s var(--ease),border-color .5s var(--ease);border-bottom:1px solid transparent}
.header--solid{background:var(--bg);border-bottom-color:var(--hair)}
.header--hidden{transform:translateY(-100%)}
.header__in{max-width:var(--maxw);margin-inline:auto;padding:22px var(--pad-x);display:flex;align-items:center;justify-content:space-between;gap:24px}
.wordmark{font-family:var(--serif);font-weight:400;font-size:1.5rem;letter-spacing:.02em;color:var(--ink)}
.nav{display:flex;gap:30px}
.nav a{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);position:relative;padding-block:4px}
.nav a::after{content:"";position:absolute;left:0;bottom:0;width:100%;height:1px;background:var(--camel);transform:scaleX(0);transform-origin:right;transition:transform .5s var(--ease)}
.nav a:hover::after,.nav a.is-current::after{transform:scaleX(1);transform-origin:left}
.nav a.is-current{color:var(--ink)}
.header__right{display:flex;align-items:center;gap:24px}
.lang{display:flex;gap:2px;align-items:center}
.lang button{font-size:11px;letter-spacing:.12em;color:var(--ink-mute);padding:4px 5px;transition:color .4s var(--ease)}
.lang button.is-active{color:var(--ink)}
.lang button:hover{color:var(--camel)}
.lang .sep{color:var(--hair);font-size:10px;pointer-events:none}
.header__phone{font-size:12px;letter-spacing:.06em;color:var(--ink-soft)}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:14px;font-family:var(--sans);font-weight:400;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink);border:1px solid var(--ink);padding:18px 32px;border-radius:1px;transition:background .6s var(--ease),color .6s var(--ease),border-color .6s var(--ease);position:relative;overflow:hidden}
.btn::after{content:"";width:18px;height:1px;background:currentColor;transition:width .6s var(--ease)}
.btn:hover{background:var(--green);color:var(--bg);border-color:var(--green)}
.btn:hover::after{width:30px}
.btn--light{color:var(--bg);border-color:var(--brass)}
.btn--light:hover{background:var(--bg);color:var(--green-dark);border-color:var(--bg)}
.btn--sm{padding:14px 24px;font-size:11px}

/* reveal */
.js .reveal{opacity:0;transform:translateY(28px);transition:opacity 1200ms var(--ease),transform 1200ms var(--ease)}
.js .reveal.is-in{opacity:1;transform:none}
.js .clip{clip-path:inset(0 0 100% 0);transition:clip-path 1400ms var(--ease)}
.js .clip.is-in{clip-path:inset(0 0 0 0)}
.line-mask{display:block;overflow:hidden}
.js .line-mask>span{display:block;transform:translateY(110%);transition:transform 1100ms var(--ease)}
.js .line-mask.is-in>span{transform:none}

/* ---------- HOME HERO ---------- */
.hero{min-height:100svh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(64px,10vh,120px)}
.hero__media{position:absolute;inset:-8% -8% -8% -8%;z-index:-2;overflow:hidden}
.hero__media img{width:100%;height:100%;object-fit:cover;object-position:70% 28%;transform-origin:center;animation:kenburns 24s ease-in-out infinite alternate}
@keyframes kenburns{from{transform:scale(1) translateY(0)}to{transform:scale(1.08) translateY(-1.5%)}}
.hero__scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(103deg,rgba(244,241,234,.90) 0%,rgba(244,241,234,.58) 30%,rgba(244,241,234,0) 60%),linear-gradient(0deg,rgba(244,241,234,.5) 0%,rgba(244,241,234,0) 26%),linear-gradient(180deg,rgba(244,241,234,.55) 0%,rgba(244,241,234,0) 22%)}
.hero__in{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);width:100%;position:relative;z-index:2}
.hero__eyebrow{margin-bottom:34px}
.hero-credo{font-size:clamp(2.7rem,6.4vw,5.9rem);font-weight:300;max-width:16ch}
.hero-credo .line-mask span{padding-bottom:.04em}
.hero__sub{margin-top:30px;font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.2rem,2.1vw,1.7rem);color:var(--ink);max-width:34ch;line-height:1.35}
.hero__cta{margin-top:46px}
.hero__cue{position:absolute;left:var(--pad-x);bottom:34px;z-index:2;display:flex;align-items:center;gap:14px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute)}
/* прогресивне розчинення низу героя: різко → мʼяке розмиття → повністю у крем */
.hero__blur{position:absolute;inset:0;z-index:1;pointer-events:none;backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px);
  -webkit-mask-image:linear-gradient(180deg,transparent 38%,#000 56%,#000 72%,transparent 86%);
          mask-image:linear-gradient(180deg,transparent 38%,#000 56%,#000 72%,transparent 86%)}
.hero__blur::before,.hero__blur::after{content:"";position:absolute;inset:0;pointer-events:none}
.hero__blur::before{backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  -webkit-mask-image:linear-gradient(180deg,transparent 54%,#000 72%,#000 86%,transparent 98%);
          mask-image:linear-gradient(180deg,transparent 54%,#000 72%,#000 86%,transparent 98%)}
.hero__blur::after{backdrop-filter:blur(34px);-webkit-backdrop-filter:blur(34px);
  background:linear-gradient(180deg,rgba(244,241,234,0) 50%,rgba(244,241,234,.42) 76%,rgba(244,241,234,.92) 93%,var(--bg) 100%);
  -webkit-mask-image:linear-gradient(180deg,transparent 52%,#000 80%,#000 100%);
          mask-image:linear-gradient(180deg,transparent 52%,#000 80%,#000 100%)}
html.night .hero__blur::after{background:linear-gradient(180deg,rgba(22,26,15,0) 50%,rgba(22,26,15,.42) 76%,rgba(22,26,15,.92) 93%,var(--bg) 100%)}
.hero__cue i{display:block;width:1px;height:44px;background:var(--camel);transform-origin:top;animation:cue 2.6s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- SUB-PAGE HERO (.phero) ---------- */
.phero{min-height:82svh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(56px,9vh,110px)}
.phero--tonal{min-height:70svh;background:linear-gradient(158deg,#EFEAE0 0%,#E4DDCF 100%)}
.phero__media{position:absolute;inset:-8%;z-index:-2;overflow:hidden}
.phero__media img{width:100%;height:100%;object-fit:cover;transform-origin:center;animation:kenburns 26s ease-in-out infinite alternate}
.phero__scrim{position:absolute;inset:0;z-index:-1;background:linear-gradient(100deg,rgba(244,241,234,.9) 0%,rgba(244,241,234,.5) 34%,rgba(244,241,234,0) 66%),linear-gradient(180deg,rgba(244,241,234,.5) 0%,rgba(244,241,234,0) 20%),linear-gradient(0deg,rgba(244,241,234,.42) 0%,rgba(244,241,234,0) 24%)}
.phero__in{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--pad-x);width:100%;position:relative;z-index:2}
.phero__eyebrow{margin-bottom:28px}
.phero__title{font-size:clamp(2.6rem,6vw,5rem);font-weight:300;max-width:15ch}
.phero__sub{margin-top:26px;font-family:var(--serif);font-style:italic;font-size:clamp(1.15rem,1.9vw,1.55rem);color:var(--ink);max-width:36ch;line-height:1.4}
.phero__scart{position:absolute;inset:0;z-index:0;opacity:.6;pointer-events:none}

/* section intro */
.sec-head{display:flex;flex-direction:column;gap:22px;margin-bottom:clamp(48px,7vh,92px);max-width:62ch}
.sec-head .eyebrow{margin-bottom:2px}

/* two-column text block (про мене) */
.split{display:grid;grid-template-columns:0.92fr 1.08fr;gap:clamp(40px,7vw,110px);align-items:start}
.split__figure{position:sticky;top:120px}
.split__figure .frame{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.split__figure img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.split__figure figcaption{margin-top:16px;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--camel)}
.prose .eyebrow{margin-bottom:26px}
.prose h2{margin-bottom:42px}
.prose p{margin-bottom:26px;font-size:clamp(1.05rem,1.35vw,1.24rem)}
.prose p.accent{color:var(--ink);font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,1.7vw,1.5rem);line-height:1.4;max-width:30ch}

/* ---------- ARCHITECTURAL PLATE (shared) ---------- */
.plate{position:relative;aspect-ratio:4/5;overflow:hidden;background:linear-gradient(158deg,#EFEAE0 0%,#E4DDCF 100%)}
.plate svg{position:absolute;inset:0;width:100%;height:100%;transition:transform 1200ms var(--ease)}
.plate::after{content:"";position:absolute;inset:0;border:1px solid var(--hair)}
.plate img{width:100%;height:100%;object-fit:cover}
.card-hover:hover .plate svg,.card-hover:hover .plate img{transform:scale(1.04)}

/* residences / objects grid */
.res__grid,.obj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,44px)}
.obj-grid{grid-template-columns:repeat(2,1fr);gap:clamp(30px,4vw,64px)}
.res__card,.obj-card{display:flex;flex-direction:column}
.res__meta,.obj-meta{padding-top:22px}
.res__name,.obj-name{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.4rem,1.9vw,1.9rem);color:var(--ink);line-height:1.15}
.res__loc,.obj-loc{margin-top:9px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--camel)}
.res__desc,.obj-desc{margin-top:16px;font-size:.98rem;color:var(--ink-soft);max-width:34ch;line-height:1.6}
.res__price,.obj-price{margin-top:18px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-mute)}
.obj-specs{margin-top:16px;display:flex;flex-wrap:wrap;gap:8px 22px;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-mute)}
.obj-specs span{display:inline-flex;gap:8px}
.obj-specs b{font-weight:400;color:var(--ink-soft)}

/* numbered principle rows (approach / disciplines) */
.rows .row{display:grid;grid-template-columns:auto 1fr;gap:clamp(28px,6vw,90px);padding-block:clamp(34px,5vh,60px);align-items:baseline}
.rows .num{font-family:var(--serif);font-weight:300;font-size:clamp(2.2rem,3.4vw,3rem);color:var(--camel);line-height:1}
.rows .row h3{font-size:clamp(1.6rem,2.4vw,2.2rem);font-weight:400;margin-bottom:16px}
.rows .row p{font-size:clamp(1rem,1.25vw,1.15rem);max-width:46ch}

/* stat strip (discreet) */
.stats{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,54px);border-top:1px solid var(--hair);padding-top:clamp(36px,5vh,54px)}
.stat .n{font-family:var(--serif);font-weight:300;font-size:clamp(2.4rem,4vw,3.6rem);color:var(--ink);line-height:1}
.stat .l{margin-top:14px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--camel);max-width:22ch}

/* nutrition cards */
.nutri{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(28px,3vw,48px)}
.nutri .card{border-top:1px solid var(--hair);padding-top:26px}
.nutri .card .k{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--camel);margin-bottom:16px}
.nutri .card h3{font-family:var(--serif);font-weight:400;font-size:clamp(1.4rem,2vw,1.9rem);margin-bottom:14px}
.nutri .card p{font-size:1rem;color:var(--ink-soft);max-width:40ch}

/* dark section */
.dark{background:var(--green-dark);color:var(--bg-2)}
.dark .eyebrow{color:var(--brass)}
.dark h2,.dark h3{color:var(--bg)}
.dark .hair{background:rgba(184,169,140,.4)}

/* referrals */
.refs__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(36px,4vw,64px)}
.ref{display:flex;flex-direction:column;gap:26px}
.ref__line{width:34px;height:1px;background:rgba(184,169,140,.5)}
.ref__q{font-family:var(--serif);font-style:italic;font-weight:400;font-size:clamp(1.25rem,1.7vw,1.55rem);line-height:1.42;color:#EDE8DD}
.ref__by{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--brass)}

/* CTA band */
.cta-band{text-align:left}
.cta-band h2{margin-bottom:34px;max-width:20ch}

/* contact */
.contact__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,96px);align-items:center}
.contact__figure{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--bg-2)}
.contact__figure img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.contact__panel .eyebrow{margin-bottom:24px}
.contact__panel h2{margin-bottom:26px}
.contact__panel .lede{margin-bottom:44px;max-width:40ch}
.contact__direct{display:flex;flex-direction:column;gap:2px;margin-bottom:46px}
.contact__direct a{display:flex;align-items:baseline;gap:16px;padding-block:16px;border-top:1px solid var(--hair)}
.contact__direct a:last-child{border-bottom:1px solid var(--hair)}
.contact__direct .k{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--camel);width:92px;flex:none}
.contact__direct .v{font-family:var(--serif);font-size:1.35rem;color:var(--ink);transition:color .4s var(--ease)}
.contact__direct a:hover .v{color:var(--camel)}
.form{display:flex;flex-direction:column;gap:0}
.field{position:relative;border-bottom:1px solid var(--hair)}
.field label{position:absolute;left:0;top:22px;font-size:.95rem;color:var(--ink-mute);pointer-events:none;transition:transform .4s var(--ease),font-size .4s var(--ease),color .4s var(--ease);transform-origin:left}
.field input,.field textarea{width:100%;background:none;border:none;padding:24px 0 16px;font-family:var(--sans);font-weight:300;font-size:1.05rem;color:var(--ink);resize:none}
.field textarea{min-height:96px;line-height:1.6}
.field input:focus,.field textarea:focus{outline:none}
.field.is-filled label,.field input:focus+label,.field textarea:focus+label{transform:translateY(-24px) scale(.72);color:var(--camel)}
.form__foot{display:flex;align-items:center;gap:24px;margin-top:38px;flex-wrap:wrap}
.form__status{font-size:.9rem;color:var(--green);opacity:0;transition:opacity .5s var(--ease)}
.form__status.show{opacity:1}

/* footer */
.footer{background:var(--green-dark);color:var(--bg-2);padding-block:clamp(60px,8vh,96px)}
.footer__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:44px;align-items:start}
.footer__brand .wordmark{color:var(--bg);font-size:1.7rem}
.footer__note{margin-top:22px;color:var(--brass);font-size:.92rem;max-width:34ch;line-height:1.65}
.footer h4{font-family:var(--sans);font-weight:500;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--brass);margin-bottom:20px}
.footer__col a{display:block;padding-block:6px;color:var(--bg-2);font-size:.98rem;transition:color .4s var(--ease)}
.footer__col a:hover{color:var(--bg)}
.footer .lang{margin-top:8px}
.footer .lang button{color:rgba(237,232,221,.6)}
.footer .lang button.is-active{color:var(--bg)}
.footer .lang .sep{color:rgba(184,169,140,.4)}
.footer__base{max-width:var(--maxw);margin:clamp(48px,6vh,72px) auto 0;padding-inline:var(--pad-x);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;border-top:1px solid rgba(184,169,140,.22);padding-top:26px;font-size:11px;letter-spacing:.08em;color:rgba(237,232,221,.55)}

/* ============================================================
   CONCIERGE (floating assistant + mascot)
   ============================================================ */
.cnc-launch{position:fixed;right:clamp(18px,3vw,34px);bottom:clamp(18px,3vw,34px);z-index:70;display:flex;align-items:center;gap:12px;background:var(--bg);border:1px solid var(--hair);border-radius:2px;padding:10px 18px 10px 12px;transition:border-color .5s var(--ease),transform .6s var(--ease);cursor:pointer}
.cnc-launch:hover{border-color:var(--camel);transform:translateY(-2px)}
.cnc-launch .m{width:34px;height:34px;flex:none}
.cnc-launch .t{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.cnc-launch .t small{display:block;font-size:9px;letter-spacing:.14em;color:var(--camel);margin-top:3px}
@media (max-width:620px){.cnc-launch .t{display:none}.cnc-launch{padding:10px}}

.cnc-panel{position:fixed;right:clamp(18px,3vw,34px);bottom:clamp(18px,3vw,34px);z-index:71;width:min(380px,calc(100vw - 32px));height:min(560px,calc(100vh - 48px));background:var(--bg);border:1px solid var(--hair);border-radius:2px;display:flex;flex-direction:column;opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;transition:opacity .5s var(--ease),transform .5s var(--ease)}
.cnc-panel.open{opacity:1;transform:none;pointer-events:auto}
.cnc-head{display:flex;align-items:center;gap:14px;padding:20px 22px;border-bottom:1px solid var(--hair)}
.cnc-head .m{width:40px;height:40px;flex:none}
.cnc-head .who{flex:1}
.cnc-head .who b{font-family:var(--serif);font-weight:400;font-size:1.25rem;color:var(--ink);display:block;line-height:1.1}
.cnc-head .who span{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--camel)}
.cnc-close{font-size:20px;color:var(--ink-mute);line-height:1;padding:6px;transition:color .4s var(--ease)}
.cnc-close:hover{color:var(--ink)}
.cnc-body{flex:1;overflow-y:auto;padding:22px;display:flex;flex-direction:column;gap:16px}
.cnc-msg{max-width:86%;font-size:.96rem;line-height:1.55}
.cnc-msg.bot{align-self:flex-start;color:var(--ink-soft)}
.cnc-msg.bot .b{display:block;background:var(--bg-2);border:1px solid var(--hair);border-radius:2px;padding:13px 16px}
.cnc-msg.me{align-self:flex-end;text-align:right}
.cnc-msg.me .b{display:inline-block;background:var(--green);color:var(--bg);border-radius:2px;padding:12px 16px;text-align:left}
.cnc-typing{align-self:flex-start;color:var(--ink-mute);font-size:.9rem;font-style:italic;font-family:var(--serif)}
.cnc-foot{border-top:1px solid var(--hair);padding:14px 16px;display:flex;gap:10px;align-items:flex-end}
.cnc-foot textarea{flex:1;background:none;border:none;resize:none;max-height:96px;font-family:var(--sans);font-weight:300;font-size:.98rem;color:var(--ink);padding:8px 4px;line-height:1.5}
.cnc-foot textarea:focus{outline:none}
.cnc-send{flex:none;width:40px;height:40px;border:1px solid var(--ink);border-radius:2px;display:flex;align-items:center;justify-content:center;transition:background .5s var(--ease),color .5s var(--ease),border-color .5s var(--ease)}
.cnc-send:hover{background:var(--green);border-color:var(--green);color:var(--bg)}
.cnc-send svg{width:16px;height:16px}
.cnc-quick{display:flex;flex-wrap:wrap;gap:8px}
.cnc-quick button{font-size:11px;letter-spacing:.06em;color:var(--ink-soft);border:1px solid var(--hair);border-radius:2px;padding:8px 12px;transition:border-color .4s var(--ease),color .4s var(--ease)}
.cnc-quick button:hover{border-color:var(--camel);color:var(--ink)}

/* ============================================================
   STORIES (кадри) — quiet-luxury story circles + viewer
   ============================================================ */
.stories-sec{padding-block:clamp(40px,6vh,72px)}
.stories-sec .eyebrow{margin-bottom:26px}
.stories{display:flex;gap:clamp(20px,3vw,42px);flex-wrap:wrap}
.story{display:flex;flex-direction:column;align-items:center;gap:13px;width:90px;text-align:center}
.story-ring{width:76px;height:76px;border-radius:50%;padding:3px;background:var(--bg);box-shadow:0 0 0 1px var(--brass);position:relative;transition:box-shadow .5s var(--ease),transform .6s var(--ease)}
.story:hover .story-ring{box-shadow:0 0 0 1px var(--camel);transform:translateY(-2px)}
.story-ring img{width:100%;height:100%;border-radius:50%;object-fit:cover;filter:grayscale(20%) saturate(.9)}
.story-label{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-mute);transition:color .4s var(--ease)}
.story:hover .story-label{color:var(--camel)}
@media(max-width:620px){.stories{gap:16px;flex-wrap:nowrap;overflow-x:auto;padding-bottom:10px;-webkit-overflow-scrolling:touch}.story{width:78px;flex:none}.story-ring{width:64px;height:64px}}

.story-viewer{position:fixed;inset:0;z-index:90;background:rgba(20,20,15,.97);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .5s var(--ease)}
.story-viewer.open{opacity:1;pointer-events:auto}
.sv-bars{position:absolute;top:18px;left:50%;transform:translateX(-50%);width:min(440px,84vw);display:flex;gap:5px;z-index:4}
.sv-bar{flex:1;height:2px;background:rgba(184,169,140,.25);overflow:hidden;border-radius:2px}
.sv-bar i{display:block;height:100%;background:var(--brass);transform:scaleX(0);transform-origin:left}
.sv-close{position:absolute;top:24px;right:28px;font-size:30px;line-height:1;color:var(--bg-2);z-index:5;opacity:.75;transition:opacity .4s var(--ease)}
.sv-close:hover{opacity:1}
.sv-stage{position:relative;width:min(440px,84vw);max-height:84vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;padding-top:44px;z-index:1}
.sv-img{max-width:100%;max-height:60vh;object-fit:contain;border-radius:2px;box-shadow:0 30px 80px rgba(0,0,0,.5)}
.sv-cap{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.2vw,1.45rem);line-height:1.4;color:#EDE8DD;text-align:center;max-width:34ch}
.sv-link{display:none}
.sv-link.show{display:inline-flex}
.sv-nav{position:absolute;top:0;bottom:0;width:34%;z-index:3;background:none;cursor:pointer}
.sv-prev{left:0}.sv-next{right:0}
@media (prefers-reduced-motion:reduce){.sv-bar i{transition:none !important}}

/* ============================================================
   OBJECTS MARQUEE — нескінченна карусель резиденцій
   ============================================================ */
.marquee-sec{padding-block:clamp(40px,6vh,80px);overflow:hidden}
.marquee-sec .wrap{margin-bottom:clamp(24px,3vh,40px)}
.marquee{overflow:hidden;-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 7%,#000 93%,transparent 100%)}
.marquee__track{display:flex;gap:clamp(18px,2.4vw,38px);width:max-content;padding-inline:clamp(18px,2.4vw,38px);animation:marq 70s linear infinite;will-change:transform}
.marquee:hover .marquee__track{animation-play-state:paused}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.mq-card{flex:0 0 clamp(200px,23vw,270px);text-decoration:none;color:inherit;display:block}
.mq-plate{display:block;position:relative;aspect-ratio:4/5;overflow:hidden;background:linear-gradient(158deg,#EFEAE0 0%,#E4DDCF 100%);border:1px solid var(--hair);border-radius:2px}
.mq-plate svg{position:absolute;inset:0;width:100%;height:100%;transition:transform 1200ms var(--ease)}
.mq-card:hover .mq-plate svg{transform:scale(1.04)}
.mq-n{display:block;margin-top:15px;font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.25rem;color:var(--ink);line-height:1.15}
.mq-l{display:block;margin-top:7px;font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--camel)}
html.night .mq-plate{background:linear-gradient(158deg,#20241A 0%,#161A0F 100%)}
@media (prefers-reduced-motion:reduce){.marquee{-webkit-mask-image:none;mask-image:none}.marquee__track{animation:none;overflow-x:auto}}

/* ---------- responsive ---------- */
@media (max-height:780px) and (min-width:900px){
  .hero-credo{font-size:clamp(2.4rem,4.6vw,3.7rem)}
  .hero__sub{margin-top:20px;font-size:1.18rem}
  .hero__cta{margin-top:30px}
  .hero__eyebrow{margin-bottom:24px}
}
@media (max-width:1000px){
  .nav,.header__phone{display:none}
  .split{grid-template-columns:1fr;gap:48px}
  .split__figure{position:relative;top:0;max-width:440px}
  .res__grid{grid-template-columns:1fr 1fr;gap:32px}
  .obj-grid{grid-template-columns:1fr;gap:44px;max-width:520px}
  .refs__grid{grid-template-columns:1fr;gap:44px}
  .nutri{grid-template-columns:1fr}
  .contact__grid{grid-template-columns:1fr;gap:48px}
  .contact__figure{max-width:440px;order:2}
  .footer__grid{grid-template-columns:1fr 1fr}
}
@media (max-width:620px){
  body{font-size:16.5px}
  .res__grid{grid-template-columns:1fr;gap:40px;max-width:400px}
  .rows .row{grid-template-columns:1fr;gap:14px}
  .rows .num{font-size:2rem}
  .stats{grid-template-columns:1fr;gap:30px}
  .contact__direct .k{width:76px}
  .footer__grid{grid-template-columns:1fr;gap:40px}
  .hero{padding-bottom:96px}
  .hero__cue{display:none}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none !important}
  .hero__media img,.phero__media img{animation:none}
  .js .reveal,.js .clip,.js .line-mask>span{opacity:1 !important;transform:none !important;clip-path:none !important;transition:none !important}
  .hair{transform:scaleX(1) !important;transition:none !important}
  html{scroll-behavior:auto}
}

/* ============================================================
   НІЧНИЙ РЕЖИМ — бронза + темна олива
   ============================================================ */
body,section,.footer,.plate,.phero--tonal{transition:background-color .55s var(--ease),color .55s var(--ease)}
.theme-toggle{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;flex:none;color:var(--ink-mute);transition:color .4s var(--ease)}
.theme-toggle svg{width:17px;height:17px;fill:currentColor}
.theme-toggle:hover{color:var(--camel)}

html.night{
  --bg:#161A0F; --bg-2:#1E2216; --bg-3:#252A1B;
  --ink:#ECE6D6; --ink-soft:#C6BFAC; --ink-mute:#8E8975;
  --green:#B8894F; --green-dark:#10130B;
  --camel:#C79B62; --brass:#C7A87E; --hair:#3A4029;
}
html.night .theme-toggle{color:var(--camel)}
html.night .hero__media img,html.night .phero__media img{filter:brightness(.8) contrast(1.02)}
html.night .split__figure img,html.night .contact__figure img,html.night .story-ring img{filter:brightness(.86)}
html.night .hero__scrim{background:linear-gradient(103deg,rgba(22,26,15,.94) 0%,rgba(22,26,15,.55) 32%,rgba(22,26,15,0) 62%),linear-gradient(0deg,rgba(22,26,15,.62) 0%,rgba(22,26,15,0) 26%),linear-gradient(180deg,rgba(22,26,15,.55) 0%,rgba(22,26,15,0) 22%)}
html.night .phero__scrim{background:linear-gradient(100deg,rgba(22,26,15,.92) 0%,rgba(22,26,15,.5) 34%,rgba(22,26,15,0) 66%),linear-gradient(180deg,rgba(22,26,15,.5) 0%,rgba(22,26,15,0) 20%),linear-gradient(0deg,rgba(22,26,15,.45) 0%,rgba(22,26,15,0) 24%)}
html.night .phero--tonal{background:linear-gradient(158deg,#1E2216 0%,#161A0F 100%)}
html.night .plate{background:linear-gradient(158deg,#20241A 0%,#161A0F 100%)}
html.night .grain{opacity:.06}
/* світлий-текст-на-темному (використовує --bg/--bg-2, що інвертувались) — тримаємо кремовим */
html.night .dark{color:var(--ink-soft)}
html.night .dark h2,html.night .dark h3{color:var(--ink)}
html.night .footer{color:var(--ink-soft)}
html.night .footer__brand .wordmark{color:var(--ink)}
html.night .footer__col a{color:var(--ink-soft)}
html.night .footer__col a:hover{color:var(--ink)}
html.night .btn--light{color:var(--ink);border-color:var(--brass)}
html.night .btn--light:hover{background:var(--ink);color:var(--green-dark);border-color:var(--ink)}
