/* ===========================================================
   DOLNÍ DUNAJOVICE — rezidenční bydlení
   Brand stylesheet
   Style: centered-emblem nav · serif display hero + bold-sans
   sections · antique-gold accents · pixel mosaic motif
   =========================================================== */

:root{
  /* palette */
  --paper:#FBF8F2;
  --cream:#F3ECE0;
  --sand:#E7DBC8;
  --sand-deep:#D9C9AF;
  --ink:#27221C;
  --ink-2:#322C24;
  --ink-soft:#6E6555;
  --taupe:#8A8068;
  --line:#E4DACA;

  --gold:#B08D4F;
  --gold-soft:#CBAE6E;
  --gold-deep:#977338;

  /* type */
  --serif:"DM Serif Display", Georgia, serif;
  --sans:"Hanken Grotesk", system-ui, sans-serif;
  --hero:'Italiana',var(--sans);

  /* metrics */
  --maxw:1320px;
  --gutter:clamp(20px,5vw,76px);
  --section:clamp(84px,10vw,160px);
  --radius:3px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-weight:400;font-size:17px;line-height:1.7;
  letter-spacing:.004em;-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;}

/* ---------- typography ---------- */
h1,h2,h3,h4{margin:0;}
.display{
  font-family:var(--serif);font-weight:400;line-height:1;
  font-size:clamp(2.7rem,6.2vw,5.4rem);letter-spacing:.018em;
}
.h-sec{
  font-family:var(--sans);font-weight:800;line-height:1.04;letter-spacing:-.018em;
  font-size:clamp(2rem,4.4vw,3.7rem);color:var(--ink);text-wrap:balance;
}
.h-card{font-family:var(--sans);font-weight:700;letter-spacing:-.01em;font-size:clamp(1.4rem,2vw,1.85rem);line-height:1.1;}
.ac{color:var(--gold-deep);}
.ac-it{font-family:var(--serif);font-style:italic;font-weight:500;color:var(--gold-deep);letter-spacing:.01em;}
p{margin:0 0 1.1em;}p:last-child{margin-bottom:0;}

.eyebrow{
  font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.3em;
  text-transform:uppercase;color:var(--gold-deep);display:inline-flex;align-items:center;gap:.8em;margin:0;
}
.eyebrow::before{content:"";width:30px;height:1.5px;background:var(--gold);display:inline-block;}
.eyebrow.no-rule::before{display:none;}
.lead{font-size:clamp(1.08rem,1.45vw,1.3rem);line-height:1.62;color:var(--ink-soft);font-weight:400;}
.muted{color:var(--ink-soft);}

/* index numeral */
.idx{font-family:var(--serif);font-size:1rem;font-style:italic;color:var(--gold-deep);}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
.section{padding-block:var(--section);position:relative;}
.section--cream{background:var(--cream);}
.section--sand{background:var(--sand);}
.divider{height:1px;background:var(--line);border:0;margin:0;}

/* ---------- pixel mosaic motif ---------- */
.pixels{
  --c:var(--gold);--s:13px;
  width:calc(var(--s)*7);height:calc(var(--s)*7);pointer-events:none;
  background:repeating-conic-gradient(var(--c) 0% 25%,transparent 0% 50%) 0 0 / calc(var(--s)*2) calc(var(--s)*2);
  -webkit-mask-image:radial-gradient(120% 120% at var(--mx,0%) var(--my,100%),#000 0%,transparent 70%);
  mask-image:radial-gradient(120% 120% at var(--mx,0%) var(--my,100%),#000 0%,transparent 70%);
  opacity:.85;
}
.pixels.lg{--s:17px;}
.pixels.light{--c:var(--gold-soft);}

/* ---------- buttons ---------- */
.btn{
  --bg:transparent;--fg:var(--ink);--bd:var(--gold);
  display:inline-flex;align-items:center;gap:.8em;padding:1.05em 2em;
  background:var(--bg);color:var(--fg);border:1.5px solid var(--bd);border-radius:var(--radius);
  font-size:.74rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;
  transition:background .45s var(--ease),color .45s var(--ease),border-color .45s var(--ease),transform .4s var(--ease);
}
.btn .arr{transition:transform .45s var(--ease);}
.btn:hover .arr{transform:translateX(5px);}
.btn--solid{--bg:var(--ink);--fg:var(--paper);--bd:var(--ink);}
.btn--solid:hover{--bg:var(--gold-deep);--bd:var(--gold-deep);}
.btn--ghost:hover{--bg:var(--gold);--fg:#fff;--bd:var(--gold);}
.btn--light{--fg:var(--paper);--bd:rgba(255,255,255,.5);}
.btn--light:hover{--bg:var(--paper);--fg:var(--ink);--bd:var(--paper);}
.btn--block{width:100%;justify-content:center;}

.textlink{
  display:inline-flex;align-items:center;gap:.55em;font-size:.76rem;font-weight:700;
  letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);
  padding-bottom:.35em;background-image:linear-gradient(var(--gold),var(--gold));
  background-size:100% 1.5px;background-repeat:no-repeat;background-position:0 100%;
  transition:gap .4s var(--ease),color .3s,background-size .4s var(--ease);
}
.textlink:hover{gap:.95em;color:var(--ink);}
.textlink.dotted{background-image:none;border-bottom:1.5px dotted var(--gold);}

/* ===========================================================
   HEADER — centered emblem nav
   =========================================================== */
.header{position:fixed;inset:0 0 auto 0;z-index:60;padding-block:20px;
  transition:background .5s var(--ease),box-shadow .5s var(--ease),padding .5s var(--ease);}
.header__inner{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);
  display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:20px;}
.nav-side{display:flex;gap:30px;list-style:none;margin:0;padding:0;}
.nav-side.left{justify-self:start;}
.nav-side.right{justify-self:end;align-items:center;}
.nav-side a{font-size:.76rem;font-weight:600;letter-spacing:.13em;text-transform:uppercase;
  color:var(--paper);position:relative;padding-block:6px;transition:color .4s var(--ease);}
.nav-side a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:var(--gold-soft);transition:width .4s var(--ease);}
.nav-side a:hover::after{width:100%;}
.lang{font-size:.7rem;font-weight:800;letter-spacing:.1em;color:var(--paper);cursor:pointer;
  border:1.5px solid rgba(255,255,255,.5);border-radius:999px;padding:6px 13px;line-height:1;
  transition:background .35s var(--ease),color .35s,border-color .35s;}
.lang:hover{background:var(--paper);color:var(--ink);border-color:var(--paper);}
.lang::after{display:none !important;}
.header.is-stuck .lang{color:var(--gold-deep);border-color:var(--gold);}
.header.is-stuck .lang:hover{background:var(--gold-deep);color:var(--paper);border-color:var(--gold-deep);}
.lang--mobile{margin-bottom:14px;color:var(--gold-deep);border-color:var(--gold);align-self:center;}
.brand{justify-self:center;display:block;position:relative;}
.brand__mark{width:71px;height:71px;object-fit:contain;transition:opacity .5s var(--ease),width .5s var(--ease);}
.brand__mark.dark{position:absolute;inset:0;opacity:0;}
.header.is-stuck{background:rgba(251,248,242,.93);backdrop-filter:saturate(1.1) blur(12px);
  box-shadow:0 1px 0 var(--line);padding-block:12px;}
.header.is-stuck .nav-side a{color:var(--ink);}
.header.is-stuck .nav-side a:hover{color:var(--gold-deep);}
.header.is-stuck .lang{color:var(--gold-deep);}
.header.is-stuck .brand__mark{opacity:0;width:55px;}
.header.is-stuck .brand__mark.dark{opacity:1;}
.mobile-nav{display:none;}
.nav-toggle{display:none;background:none;border:0;padding:8px;flex-direction:column;gap:6px;justify-self:end;}
.nav-toggle span{width:28px;height:2px;background:var(--paper);transition:.4s var(--ease);display:block;}
.header.is-stuck .nav-toggle span{background:var(--ink);}

/* ===========================================================
   HERO
   =========================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;text-align:center;}
.hero__media{position:absolute;inset:0;z-index:0;}
.hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.05);}
.hero__slide{position:absolute;inset:0;opacity:0;will-change:opacity,transform;
  animation:heroKen 24s infinite;}
.hero__slide:nth-child(1){animation-delay:0s;}
.hero__slide:nth-child(2){animation-delay:8s;}
.hero__slide:nth-child(3){animation-delay:16s;}
@keyframes heroKen{
  0%{opacity:0;transform:scale(1.04);}
  4%{opacity:1;}
  29%{opacity:1;}
  35%{opacity:0;}
  100%{opacity:0;transform:scale(1.13);}
}
@media (prefers-reduced-motion:reduce){
  .hero__slide{animation:none;opacity:0;}
  .hero__slide:nth-child(1){opacity:1;}
}
.hero__media::after{content:"";position:absolute;inset:0;
  background:
    radial-gradient(68% 60% at 50% 46%,rgba(16,12,7,.72) 0%,rgba(16,12,7,.34) 50%,rgba(16,12,7,.12) 78%),
    linear-gradient(to bottom,rgba(24,19,12,.5) 0%,rgba(24,19,12,.32) 38%,rgba(20,15,9,.86) 100%);}
.hero__inner{position:relative;z-index:3;padding:150px var(--gutter) clamp(48px,8vh,96px);width:100%;max-width:1180px;}
.hero .eyebrow{color:var(--gold-soft);justify-content:center;text-shadow:0 1px 14px rgba(20,16,10,.6);}
.hero .eyebrow::before{display:none;}
.hero__title{color:var(--paper);text-shadow:0 2px 50px rgba(12,9,5,.7),0 1px 6px rgba(12,9,5,.4);
  font-family:var(--hero);font-weight:400;font-size:clamp(3.8rem,9.4vw,8.6rem);letter-spacing:.012em;text-transform:uppercase;}
.hero__title .small{font-size:.42em;}
.hero__tag{margin-top:20px;font-size:clamp(.74rem,1.3vw,.96rem);font-weight:700;letter-spacing:.34em;
  text-transform:uppercase;color:var(--gold-soft);text-shadow:0 1px 16px rgba(20,16,10,.6);}
.hero__sub{color:rgba(255,255,255,.88);max-width:50ch;margin:26px auto 0;
  font-size:clamp(1.02rem,1.4vw,1.22rem);font-weight:300;line-height:1.62;}
.hero__actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center;margin-top:38px;}
.hero__meta{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;
  gap:clamp(30px,6vw,80px);margin-top:clamp(48px,8vh,90px);}
.hero__meta .stat{color:var(--paper);position:relative;padding:0 6px;text-align:center;}
.hero__meta .stat+.stat::before{content:"";position:absolute;left:calc(-1*clamp(15px,3vw,40px));top:50%;transform:translateY(-50%);height:78%;width:1px;background:rgba(255,255,255,.34);}
.hero__meta .stat b{font-family:var(--serif);font-weight:400;font-size:clamp(2.8rem,4.8vw,4.2rem);display:block;line-height:1;letter-spacing:.01em;}
.hero__meta .stat span{font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.74);margin-top:15px;display:block;line-height:1.5;max-width:14ch;margin-inline:auto;}
.hero .pixels{position:absolute;z-index:2;}
.hero .px-bl{left:0;bottom:0;--mx:0%;--my:100%;}
.hero .px-br{right:0;bottom:0;--mx:100%;--my:100%;}

/* circular badge */
.badge{position:absolute;z-index:4;top:118px;right:var(--gutter);width:128px;height:128px;}
.badge svg{width:100%;height:100%;}
.badge .ring text{fill:var(--paper);font-family:var(--sans);font-size:9.3px;font-weight:700;letter-spacing:2.4px;text-transform:uppercase;}
.badge .ring{transform-origin:center;animation:spin 26s linear infinite;}
.badge circle{fill:none;stroke:rgba(203,174,110,.7);}
.badge .dot{fill:var(--gold-soft);}
@keyframes spin{to{transform:rotate(360deg);}}
@media (prefers-reduced-motion:reduce){.badge .ring{animation:none;}}
@media (max-width:860px){.badge{display:none;}}

.scroll-cue{position:absolute;left:50%;transform:translateX(-50%);bottom:26px;z-index:4;
  font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.66);
  display:flex;flex-direction:column;align-items:center;gap:10px;}
.scroll-cue::after{content:"";width:1px;height:42px;background:linear-gradient(var(--gold-soft),transparent);}

/* ===========================================================
   KONCEPT — collage
   =========================================================== */
.koncept__head{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,90px);align-items:end;margin-bottom:clamp(40px,5vw,68px);}
.koncept__head .h-sec{max-width:13ch;margin:22px 0 0;}
.koncept__head .right{padding-bottom:6px;}
/* section 01: align right text to the heading line */
#projekt .koncept__head{align-items:start;}
#projekt .koncept__head .right{padding-bottom:0;margin-top:calc(.72rem * 1.7 + 22px);}
.koncept__head .lead{margin-bottom:1.5em;}
.collage{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(78px,9vw,128px);gap:clamp(12px,1.6vw,22px);}
.collage figure{margin:0;overflow:hidden;border-radius:var(--radius);position:relative;}
.collage img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.collage figure:hover img{transform:scale(1.06);}
.c1{grid-column:1 / 6;grid-row:1 / 7;}
.c2{grid-column:6 / 13;grid-row:1 / 4;}
.c3{grid-column:6 / 9;grid-row:4 / 7;}
.c4{grid-column:9 / 13;grid-row:4 / 7;}
.collage figcaption{position:absolute;left:18px;bottom:16px;color:#fff;font-size:.72rem;
  letter-spacing:.16em;text-transform:uppercase;font-weight:600;text-shadow:0 1px 14px rgba(0,0,0,.5);}

/* ===========================================================
   STANDARDY / benefits
   =========================================================== */
.benefits-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:clamp(44px,5vw,72px);border-top:1px solid var(--line);}
.benefit{padding:40px 34px 8px;border-right:1px solid var(--line);}
.benefit:first-child{padding-left:0;}
.benefit:last-child{border-right:0;padding-right:0;}
.benefit .ico{width:36px;height:36px;color:var(--gold-deep);margin-bottom:26px;}
.benefit .ico svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;}
.benefit h3{font-family:var(--sans);font-weight:700;font-size:1.22rem;margin-bottom:12px;letter-spacing:-.01em;}
.benefit p{font-size:.95rem;color:var(--ink-soft);margin:0;line-height:1.6;}

/* ===========================================================
   BYDLENÍ / units
   =========================================================== */
.units{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.4vw,32px);margin-top:clamp(46px,5vw,72px);}
.unit{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;display:flex;flex-direction:column;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s;}
.unit:hover{transform:translateY(-6px);box-shadow:0 28px 54px -32px rgba(39,34,28,.46);border-color:var(--sand-deep);}
.unit__media{position:relative;aspect-ratio:4/3;overflow:hidden;}
.unit__media img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease);}
.unit:hover .unit__media img{transform:scale(1.06);}
.unit__badge{position:absolute;top:15px;left:15px;background:rgba(251,248,242,.94);color:var(--gold-deep);
  font-size:.64rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;padding:7px 13px;border-radius:999px;white-space:nowrap;}
.unit__body{padding:28px 28px 30px;display:flex;flex-direction:column;flex:1;}
.unit__body h3{margin-bottom:7px;}
.unit__disp{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;}
.unit__specs{display:flex;gap:24px;margin:22px 0;padding:18px 0;border-block:1px solid var(--line);}
.unit__specs div{display:flex;flex-direction:column;gap:4px;}
.unit__specs b{font-family:var(--serif);font-size:1.55rem;font-weight:400;line-height:1;}
.unit__specs span{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
.unit__price{margin-top:auto;}
.unit__price .from{font-size:.68rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);}
.unit__price .val{font-family:var(--serif);font-size:1.85rem;color:var(--ink);display:block;margin-top:3px;}
.unit__cta{margin-top:22px;}

.units--two{grid-template-columns:repeat(2,1fr);max-width:1040px;margin-inline:auto;}

/* ---------- ceník / price list ---------- */
.cenik{margin-top:clamp(54px,6vw,86px);}
.cenik__bar{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:26px;}
.cenik__title{font-family:var(--sans);font-weight:800;letter-spacing:-.015em;font-size:clamp(1.5rem,2.4vw,2.1rem);}
.cenik__legend{display:inline-flex;align-items:center;gap:9px;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;}
.cenik__legend .dot,.cenik__stav .dot{width:8px;height:8px;border-radius:50%;background:#7BA05B;box-shadow:0 0 0 3px rgba(123,160,91,.18);display:inline-block;flex:none;}

.cenik__row{display:grid;grid-template-columns:1.25fr .85fr .8fr .85fr 1fr 1.05fr .8fr;gap:18px;align-items:center;
  padding:17px 6px;border-bottom:1px solid var(--line);transition:background .35s var(--ease);}
.cenik__row--head{padding-block:0 15px;border-bottom:1.5px solid var(--sand-deep);}
.cenik__row--head span{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
.cenik__row:not(.cenik__row--head):hover{background:rgba(176,141,79,.05);}
.cenik__row .num{text-align:right;justify-self:end;}
.cenik__apt{font-weight:700;font-size:1.06rem;letter-spacing:-.01em;}
.cenik__disp{display:inline-flex;width:fit-content;padding:4px 12px;border:1px solid var(--sand-deep);border-radius:999px;
  font-size:.74rem;font-weight:700;letter-spacing:.04em;color:var(--ink-soft);}
.cenik__disp--alt{border-color:var(--gold);color:var(--gold-deep);background:rgba(176,141,79,.07);}
.cenik__price{font-family:var(--sans);font-size:1.06rem;color:var(--ink);font-weight:700;}
.cenik__stav{display:inline-flex;align-items:center;gap:8px;font-size:.78rem;font-weight:600;color:var(--ink-soft);}

.cenik__extras{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);margin-top:34px;}
.cenik__extras .extra{background:var(--paper);padding:26px 28px;display:flex;flex-direction:column;gap:7px;}
.section--cream .cenik__extras .extra{background:var(--cream);}
.extra__k{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
.extra__v{font-family:var(--serif);font-size:1.7rem;color:var(--ink);line-height:1;}
.extra__note{font-size:.82rem;color:var(--ink-soft);line-height:1.5;}
.extra--cta{justify-content:space-between;}
.extra--cta .textlink{margin-top:6px;}

/* ===========================================================
   DARK STATEMENT BAND
   =========================================================== */
.band{background:var(--ink);color:var(--paper);position:relative;overflow:hidden;}
.band__photo{height:clamp(280px,40vh,460px);overflow:hidden;}
.band__photo img{width:100%;height:100%;object-fit:cover;}
.band__body{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,90px);align-items:center;
  padding-block:clamp(64px,8vw,120px);}
.band .h-sec{color:var(--paper);max-width:11ch;}
.band .lead{color:rgba(251,248,242,.74);}
.band .pixels{position:absolute;right:0;top:0;--mx:100%;--my:0%;opacity:.7;}

/* ===========================================================
   LOKALITA
   =========================================================== */
.lokalita{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(40px,6vw,92px);align-items:center;}
.lokalita__media{position:relative;}
.lokalita__media img{width:100%;height:clamp(420px,56vh,640px);object-fit:cover;border-radius:var(--radius);}
.lokalita__media .pin{position:absolute;left:24px;top:24px;background:var(--paper);padding:14px 20px;border-radius:var(--radius);
  font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;font-weight:700;color:var(--gold-deep);box-shadow:0 14px 30px -18px rgba(39,34,28,.5);}
.lokalita__body .h-sec{margin:22px 0 22px;max-width:14ch;}
.dist-list{list-style:none;margin:32px 0 0;padding:0;border-top:1px solid var(--line);}
.dist-list li{display:flex;align-items:baseline;justify-content:space-between;gap:20px;padding:16px 0;border-bottom:1px solid var(--line);}
.dist-list .place{font-size:1.02rem;font-weight:500;}
.dist-list .place small{display:block;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);margin-top:4px;font-weight:600;}
.dist-list .time{font-family:var(--serif);font-size:1.45rem;color:var(--gold-deep);white-space:nowrap;}

/* ===========================================================
   GALERIE
   =========================================================== */
.gal-head{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:24px;}
.gallery{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:clamp(140px,16vw,220px);gap:clamp(10px,1.2vw,16px);margin-top:clamp(38px,4.5vw,60px);}
.gtile{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;}
.gtile img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.gtile:hover img{transform:scale(1.07);}
.gtile::after{content:"";position:absolute;inset:0;background:rgba(39,34,28,0);transition:background .5s;}
.gtile:hover::after{background:rgba(39,34,28,.14);}
.gtile .plus{position:absolute;right:15px;bottom:15px;width:36px;height:36px;border:1.5px solid rgba(255,255,255,.75);border-radius:50%;
  display:grid;place-items:center;color:#fff;opacity:0;transform:translateY(8px);transition:.5s var(--ease);z-index:2;font-size:1.1rem;}
.gtile:hover .plus{opacity:1;transform:translateY(0);}
.ga{grid-column:span 7;grid-row:span 2;}
.gb{grid-column:span 5;grid-row:span 1;}
.gc{grid-column:span 5;grid-row:span 1;}
.gd{grid-column:span 4;grid-row:span 1;}
.ge{grid-column:span 4;grid-row:span 1;}
.gf{grid-column:span 4;grid-row:span 1;}
.gg{grid-column:span 8;grid-row:span 1;}

.lightbox{position:fixed;inset:0;z-index:200;background:rgba(20,16,11,.95);display:none;align-items:center;justify-content:center;padding:5vh 7vw;}
.lightbox.open{display:flex;}
.lightbox img{max-width:100%;max-height:90vh;object-fit:contain;border-radius:var(--radius);box-shadow:0 30px 80px rgba(0,0,0,.6);}
.lb-btn{position:absolute;background:none;border:0;color:rgba(255,255,255,.8);}
.lb-close{top:26px;right:32px;font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;}
.lb-prev,.lb-next{top:50%;transform:translateY(-50%);width:56px;height:56px;border:1.5px solid rgba(255,255,255,.3);border-radius:50%;display:grid;place-items:center;font-size:1.1rem;transition:.35s;}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.12);color:#fff;}
.lb-prev{left:3vw;}.lb-next{right:3vw;}

/* ===========================================================
   INVESTICE
   =========================================================== */
.invest{display:grid;grid-template-columns:1fr 1fr;gap:clamp(36px,6vw,92px);align-items:center;}
.invest__stats{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);border:1px solid var(--line);}
.invest__stats .cell{background:var(--paper);padding:34px 30px;}
.section--cream .invest__stats .cell{background:var(--cream);}
.invest__stats b{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,4vw,3.4rem);display:block;line-height:1;color:var(--ink);}
.invest__stats .cell.gold b{color:var(--gold-deep);}
.invest__stats span{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-top:12px;display:block;line-height:1.4;font-weight:600;}
.invest__body .h-sec{margin:22px 0 22px;max-width:15ch;}

/* ===========================================================
   KONTAKT
   =========================================================== */
.kontakt{display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(40px,6vw,96px);}
.kontakt__aside .h-sec{margin:20px 0 24px;max-width:12ch;}
.contact-lines{list-style:none;margin:34px 0 0;padding:0;display:grid;gap:22px;}
.contact-lines li{display:grid;gap:5px;}
.contact-lines .k{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
.contact-lines .v{font-size:1.14rem;font-weight:500;}
.contact-lines .v a:hover{color:var(--gold-deep);}
.status-chip{display:inline-flex;align-items:center;gap:10px;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);margin-top:30px;font-weight:600;}
.status-chip .dot{width:9px;height:9px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(176,141,79,.2);}

.kontakt__form{display:grid;gap:22px;}
.field{display:flex;flex-direction:column;gap:9px;}
.field label{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:700;}
.field input,.field textarea{font-family:var(--sans);font-size:1rem;color:var(--ink);background:transparent;border:0;border-bottom:1.5px solid var(--sand-deep);padding:11px 2px;transition:border-color .4s;}
.field input::placeholder,.field textarea::placeholder{color:#b9ad97;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--gold);}
.field textarea{resize:vertical;min-height:80px;}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:22px;}
.disp-choice{display:flex;flex-wrap:wrap;gap:12px;margin-top:4px;}
.chip{position:relative;}
.chip input{position:absolute;opacity:0;inset:0;cursor:pointer;}
.chip span{display:inline-flex;align-items:center;gap:9px;padding:11px 18px;border:1.5px solid var(--sand-deep);border-radius:999px;
  font-size:.78rem;font-weight:600;letter-spacing:.06em;color:var(--ink-soft);transition:.35s var(--ease);}
.chip span::before{content:"";width:8px;height:8px;border-radius:50%;border:1.5px solid var(--sand-deep);transition:.3s;}
.chip input:checked+span{border-color:var(--gold);color:var(--ink);background:rgba(176,141,79,.06);}
.chip input:checked+span::before{background:var(--gold);border-color:var(--gold);}
.field--full{grid-column:1 / -1;}
.form-note{font-size:.8rem;color:var(--ink-soft);}
.form-note a{color:var(--gold-deep);text-decoration:underline;text-underline-offset:3px;}
.form-success{display:none;padding:18px 22px;border:1.5px solid var(--gold);color:var(--gold-deep);background:rgba(176,141,79,.06);border-radius:var(--radius);font-size:.95rem;}
.form-success.show{display:block;}

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{background:var(--ink);color:rgba(251,248,242,.74);padding-block:clamp(64px,8vw,108px) 38px;position:relative;overflow:hidden;}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:clamp(34px,5vw,80px);position:relative;z-index:2;}
.footer__cta .h-sec{color:var(--paper);max-width:9ch;}
.footer__cta p{margin:18px 0 26px;max-width:30ch;color:rgba(251,248,242,.62);font-size:.96rem;}
.footer__cta a.mail{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-soft);background-image:linear-gradient(var(--gold-soft),var(--gold-soft));background-size:100% 1px;background-repeat:no-repeat;background-position:0 100%;padding-bottom:4px;}
.footer h4{font-family:var(--sans);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-soft);font-weight:700;margin-bottom:22px;}
.footer ul{list-style:none;margin:0;padding:0;display:grid;gap:13px;}
.footer__col a,.footer__col span{font-size:.96rem;color:rgba(251,248,242,.68);}
.footer a:hover{color:var(--paper);}
.footer__watermark{position:absolute;right:-2%;bottom:-12%;z-index:0;font-family:var(--serif);font-weight:400;
  font-size:clamp(11rem,26vw,30rem);line-height:.7;color:rgba(251,248,242,.045);letter-spacing:.02em;pointer-events:none;user-select:none;}
.footer__bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;align-items:center;position:relative;z-index:2;
  margin-top:clamp(48px,6vw,82px);padding-top:26px;border-top:1px solid rgba(255,255,255,.13);
  font-size:.76rem;letter-spacing:.04em;color:rgba(251,248,242,.5);}
.footer__bottom .logo-mini{height:30px;opacity:.8;}

/* ===========================================================
   REVEAL
   =========================================================== */
@media (prefers-reduced-motion:no-preference){
  [data-reveal]{opacity:0;transform:translateY(28px);transition:opacity 1s var(--ease),transform 1s var(--ease);}
  [data-reveal].in{opacity:1;transform:none;}
  [data-reveal][data-d="1"]{transition-delay:.08s;}
  [data-reveal][data-d="2"]{transition-delay:.16s;}
  [data-reveal][data-d="3"]{transition-delay:.24s;}
  [data-reveal][data-d="4"]{transition-delay:.32s;}
}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1080px){
  .benefits-grid{grid-template-columns:1fr 1fr;}
  .benefit{padding:34px 30px 8px;}
  .benefit:nth-child(odd){padding-left:0;}
  .benefit:nth-child(2n){border-right:0;padding-right:0;}
  .benefit:nth-child(1),.benefit:nth-child(2){border-bottom:1px solid var(--line);padding-bottom:34px;}
  .units{grid-template-columns:1fr;max-width:520px;margin-inline:auto;}
}
@media (max-width:920px){
  .units--two{grid-template-columns:1fr;max-width:520px;margin-inline:auto;}
  /* ceník collapses to stacked rows */
  .cenik__row--head{display:none;}
  .cenik__row{grid-template-columns:1fr;gap:10px;padding:22px 0;}
  .cenik__row .num{text-align:right;justify-self:stretch;}
  .cenik__row span:not(.cenik__apt){display:flex;width:100%;align-items:baseline;justify-content:space-between;gap:16px;font-size:.95rem;}
  .cenik__row span:not(.cenik__apt)::before{content:attr(data-label);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;flex:none;}
  .cenik__apt{font-size:1.15rem;margin-bottom:4px;}
  .cenik__disp{display:flex;width:100%;border:0;padding:0;background:none;color:var(--ink);}
  .cenik__row span.cenik__stav{justify-content:flex-end;gap:8px;}
  .cenik__row span.cenik__stav::before{margin-right:auto;}
  .cenik__row span.cenik__stav .dot{margin:0;}
  .cenik__extras{grid-template-columns:1fr;}
}
@media (max-width:920px){
  .koncept__head,.band__body,.lokalita,.invest,.kontakt{grid-template-columns:1fr;}
  #projekt .koncept__head .right{margin-top:0;}
  .koncept__head{gap:24px;}
  .lokalita__media,.invest__stats{order:-1;}
  .collage{grid-auto-rows:clamp(60px,16vw,120px);}
  .gallery{grid-template-columns:repeat(6,1fr);}
  .ga{grid-column:span 6;grid-row:span 2;}
  .gb,.gc,.gd,.ge,.gf,.gg{grid-column:span 3;grid-row:span 1;}
  .footer__top{grid-template-columns:1fr 1fr;}
  .footer__cta{grid-column:1 / -1;}
}
@media (max-width:760px){
  body{font-size:16px;}
  .nav-side,.lang{display:none;}
  .nav-toggle{display:flex;}
  .header__inner{grid-template-columns:auto 1fr;}
  .brand{justify-self:start;grid-column:1;grid-row:1;margin-right:auto;}
  .nav-toggle{grid-column:2;grid-row:1;justify-self:end;}
  .mobile-nav{position:fixed;inset:0;background:var(--paper);z-index:80;flex-direction:column;align-items:center;justify-content:center;gap:6px;}
  .mobile-nav.open{display:flex;}
  .mobile-nav a{font-family:var(--sans);font-weight:700;font-size:1.25rem;color:var(--ink);padding:11px;letter-spacing:-.01em;}
  .mobile-nav .close{position:absolute;top:22px;right:26px;font-size:1.8rem;background:none;border:0;color:var(--ink);}
  .form-row{grid-template-columns:1fr;}
}
@media (max-width:540px){
  .gallery{grid-template-columns:1fr 1fr;}
  .ga{grid-column:span 2;grid-row:span 2;}
  .gb,.gc,.gd,.ge,.gf,.gg{grid-column:span 1;}
  .invest__stats{grid-template-columns:1fr;}
  .collage{grid-template-columns:repeat(6,1fr);}
  .c1{grid-column:1/7;grid-row:span 2;margin-top:0;}.c2{grid-column:1/7;grid-row:span 2;}.c3{grid-column:1/4;grid-row:span 2;}.c4{grid-column:4/7;grid-row:span 2;}
}

/* ===========================================================
   GALLERY PAGE (galerie.html)
   =========================================================== */
.gal-hero{position:relative;padding:clamp(150px,20vh,236px) var(--gutter) clamp(20px,4vw,52px);text-align:center;overflow:hidden;}
.gal-hero .eyebrow{justify-content:center;margin-bottom:22px;}
.gal-hero .eyebrow::before{display:none;}
.gal-hero__title{font-family:var(--hero);font-weight:400;line-height:.92;color:var(--ink);
  font-size:clamp(3.6rem,13vw,10rem);letter-spacing:.05em;text-transform:uppercase;}
.gal-hero .lead{max-width:58ch;margin:30px auto 0;}
.gal-hero .pixels{position:absolute;top:clamp(64px,11vh,128px);right:var(--gutter);--mx:100%;--my:0%;}
@media (max-width:860px){.gal-hero .pixels{display:none;}}

.gal-cats{display:grid;grid-template-columns:1fr 1fr;border-top:1px solid var(--line);margin-top:clamp(34px,5vw,64px);}
.gal-cat{position:relative;cursor:pointer;border-right:1px solid var(--line);display:flex;flex-direction:column;}
.gal-cat:last-child{border-right:0;}
.gal-cat__head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:26px var(--gutter) 26px;}
.gal-cat__head h2{font-family:var(--sans);font-weight:800;letter-spacing:-.015em;font-size:clamp(1.55rem,2.6vw,2.4rem);}
.gal-cat__head .count{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;white-space:nowrap;}
.gal-cat__media{position:relative;overflow:hidden;height:clamp(420px,64vh,780px);}
.gal-cat__media img{width:100%;height:100%;object-fit:cover;transition:transform 1.3s var(--ease);}
.gal-cat:hover .gal-cat__media img{transform:scale(1.045);}
.gal-cat__media::after{content:"";position:absolute;inset:0;background:rgba(30,24,16,0);transition:background .55s var(--ease);}
.gal-cat:hover .gal-cat__media::after{background:rgba(30,24,16,.16);}
.gal-cat__open{position:absolute;left:50%;bottom:34px;transform:translate(-50%,12px);z-index:2;opacity:0;
  display:inline-flex;align-items:center;gap:.7em;padding:13px 24px;background:rgba(251,248,242,.95);border-radius:999px;
  font-size:.7rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);
  transition:opacity .5s var(--ease),transform .5s var(--ease);}
.gal-cat:hover .gal-cat__open{opacity:1;transform:translate(-50%,0);}

/* category browse grids */
.gal-section{padding-block:clamp(64px,8vw,120px);}
.gal-section__head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:clamp(30px,4vw,48px);}
.gal-section__head h2{font-family:var(--sans);font-weight:800;letter-spacing:-.018em;font-size:clamp(1.8rem,3.4vw,2.8rem);}
.gal-section__head .eyebrow{margin-bottom:14px;}
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(10px,1.2vw,16px);}
.gal-grid .gtile{aspect-ratio:1/1;}
.gal-grid .gtile:nth-child(6n+1){grid-column:span 2;grid-row:span 2;}
@media (max-width:900px){
  .gal-cats{grid-template-columns:1fr;}
  .gal-cat{border-right:0;border-bottom:1px solid var(--line);}
  .gal-cat__media{height:clamp(360px,52vh,560px);}
  .gal-grid{grid-template-columns:repeat(3,1fr);}
}
@media (max-width:560px){
  .gal-grid{grid-template-columns:repeat(2,1fr);}
  .gal-grid .gtile:nth-child(6n+1){grid-column:span 2;grid-row:span 2;}
}

.lb-count{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.72);
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;}

/* make the two entry tiles behave as links */
a.gal-cat{text-decoration:none;color:inherit;}

/* ===========================================================
   GALLERY DETAIL (galerie-byty.html / galerie-areal.html)
   masonry tiles with caption · click → lightbox
   =========================================================== */
.mgal-hero{padding:clamp(132px,17vh,196px) var(--gutter) 0;max-width:var(--maxw);margin-inline:auto;}
.mgal-back{display:inline-flex;align-items:center;gap:.6em;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;
  font-weight:700;color:var(--ink-soft);transition:color .3s;}
.mgal-back:hover{color:var(--gold-deep);}
.mgal-back .arr{transform:rotate(180deg);display:inline-block;}
.mgal-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:22px 40px;
  margin-top:clamp(26px,4vw,46px);padding-bottom:clamp(26px,3.4vw,40px);border-bottom:1.5px solid var(--sand-deep);}
.mgal-head .eyebrow{margin-bottom:16px;}
.mgal-title{font-family:var(--serif);font-weight:400;line-height:.92;color:var(--ink);letter-spacing:.01em;
  font-size:clamp(3rem,7vw,5.6rem);text-transform:uppercase;}
.mgal-head .lead{max-width:40ch;margin:0;padding-bottom:8px;}
.mgal-head .count{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}

.mgal{max-width:var(--maxw);margin:clamp(28px,4vw,50px) auto 0;padding:0 var(--gutter) clamp(72px,9vw,128px);
  display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:clamp(10px,1.1vw,16px);grid-auto-flow:dense;}
.mtile{position:relative;overflow:hidden;border-radius:var(--radius);cursor:pointer;background:var(--cream);
  grid-column:span 1;grid-row:span 1;}
.mtile.w2{grid-column:span 2;}
.mtile.h2{grid-row:span 2;}
.mtile img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease);}
.mtile:hover img{transform:scale(1.06);}
.mtile::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,9,.62) 0%,rgba(20,15,9,.12) 38%,transparent 64%);
  opacity:.85;transition:opacity .4s var(--ease);}
.mtile:hover::after{opacity:1;}
.mtile__cap{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:clamp(16px,1.6vw,22px);color:#fff;
  transform:translateY(6px);opacity:.94;transition:transform .45s var(--ease),opacity .45s;}
.mtile:hover .mtile__cap{transform:translateY(0);opacity:1;}
.mtile__cap h3{font-family:var(--sans);font-weight:700;font-size:clamp(1rem,1.25vw,1.18rem);letter-spacing:-.01em;line-height:1.15;}
.mtile__cap p{font-size:.82rem;line-height:1.45;color:rgba(255,255,255,.82);margin-top:5px;max-width:34ch;
  max-height:0;overflow:hidden;opacity:0;transition:max-height .45s var(--ease),opacity .4s,margin .45s;}
.mtile:hover .mtile__cap p{max-height:4.2em;opacity:1;}
.mtile__zoom{position:absolute;top:14px;right:14px;z-index:2;width:36px;height:36px;border-radius:50%;
  background:rgba(251,248,242,.92);color:var(--ink);display:grid;place-items:center;font-size:1.05rem;
  transform:scale(.7);opacity:0;transition:transform .4s var(--ease),opacity .4s;}
.mtile:hover .mtile__zoom{transform:scale(1);opacity:1;}

@media (max-width:900px){
  .mgal{grid-template-columns:repeat(2,1fr);grid-auto-rows:180px;}
  .mtile.w2{grid-column:span 2;}
  .mtile.h2{grid-row:span 2;}
  .mgal-head{grid-template-columns:1fr;}
  .mgal-head .lead{padding-bottom:0;}
}
@media (max-width:560px){
  .mgal{grid-auto-rows:150px;}
  .mtile__cap p{max-height:none;opacity:1;}
}

/* ===========================================================
   FINANCOVÁNÍ PAGE (financovani.html)
   =========================================================== */
.fin-hero{text-align:center;max-width:1180px;margin-inline:auto;
  padding:clamp(150px,20vh,232px) var(--gutter) 0;}
.fin-hero__title{font-family:var(--serif);font-weight:400;line-height:.9;color:var(--ink);letter-spacing:.018em;
  font-size:clamp(3rem,10vw,8rem);text-transform:uppercase;}
.fin-hero .lead{max-width:60ch;margin:clamp(20px,2.6vw,32px) auto 0;}

.fin-steps{max-width:1040px;margin:clamp(60px,9vw,128px) auto 0;padding:0 var(--gutter);}
.fin-step{display:grid;grid-template-columns:300px 1fr;gap:clamp(20px,5vw,70px);align-items:center;
  padding:clamp(34px,4.4vw,58px) 0;border-bottom:1px solid var(--line);}
.fin-step:last-child{border-bottom:0;}
.fin-step__num{font-family:var(--serif);font-weight:400;line-height:.8;color:var(--sand-deep);
  font-size:clamp(4.4rem,9vw,7.4rem);letter-spacing:.01em;}
.fin-step__body h3{font-family:var(--sans);font-weight:700;font-size:clamp(1.1rem,1.5vw,1.32rem);
  letter-spacing:-.01em;color:var(--ink);margin-bottom:10px;}
.fin-step__body p{font-size:clamp(.98rem,1.15vw,1.08rem);line-height:1.62;color:var(--ink-soft);max-width:52ch;}
.fin-step__body .tag{display:inline-block;margin-top:14px;font-family:var(--serif);font-size:1.5rem;color:var(--gold-deep);}

@media (max-width:720px){
  .fin-step{grid-template-columns:1fr;gap:6px;padding:30px 0;}
  .fin-step__num{font-size:clamp(3.6rem,16vw,5rem);}
}

/* contact CTA band */
.fin-cta{position:relative;margin-top:clamp(64px,9vw,120px);background:var(--cream);overflow:hidden;}
.fin-cta__inner{max-width:var(--maxw);margin-inline:auto;display:grid;grid-template-columns:1fr 1fr;align-items:stretch;}
.fin-cta__text{padding:clamp(54px,7vw,104px) clamp(28px,5vw,72px);}
.fin-cta__text h2{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;font-size:clamp(1.9rem,3.4vw,2.9rem);margin-bottom:26px;}
.fin-cta__text .lead{max-width:44ch;margin-bottom:34px;}
.fin-cta__mail{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.7vw,2.2rem);color:var(--gold-deep);
  background-image:linear-gradient(var(--gold),var(--gold));background-size:100% 1.5px;background-repeat:no-repeat;
  background-position:0 100%;padding-bottom:6px;transition:color .35s;}
.fin-cta__mail:hover{color:var(--ink);}
.fin-cta__media{position:relative;min-height:340px;}
.fin-cta__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
@media (max-width:860px){
  .fin-cta__inner{grid-template-columns:1fr;}
  .fin-cta__media{min-height:300px;order:-1;}
}

/* ===========================================================
   O PROJEKTU PAGE (o-projektu.html)
   =========================================================== */
/* hero reuses .loc-hero */

/* concept split: text | tall photo */
.ab-split{max-width:var(--maxw);margin-inline:auto;padding:clamp(64px,8vw,120px) var(--gutter) 0;
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(34px,6vw,84px);align-items:center;}
.ab-split__text .eyebrow{margin-bottom:18px;}
.ab-split__text h2{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;
  font-size:clamp(2rem,3.6vw,3.1rem);line-height:1.02;margin-bottom:22px;}
.ab-split__text p{font-size:clamp(1rem,1.2vw,1.12rem);line-height:1.66;color:var(--ink-soft);max-width:46ch;}
.ab-split__text .textlink{margin-top:30px;}
.ab-split__media{position:relative;overflow:hidden;border-radius:var(--radius);aspect-ratio:4/4.6;}
.ab-split__media img{width:100%;height:100%;object-fit:cover;}

/* photo + gold stat block */
.ab-stats-row{max-width:var(--maxw);margin:clamp(20px,3vw,40px) auto 0;padding:0 var(--gutter);
  display:grid;grid-template-columns:1fr 1.05fr;gap:clamp(20px,3vw,40px);align-items:stretch;}
.ab-stats-row__media{position:relative;overflow:hidden;border-radius:var(--radius);min-height:340px;}
.ab-stats-row__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.ab-stats{background:var(--gold);color:var(--ink);border-radius:var(--radius);
  padding:clamp(40px,5vw,72px) clamp(20px,3vw,44px);display:flex;align-items:center;justify-content:space-between;gap:0;}
.ab-stat{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;
  position:relative;padding:2px clamp(16px,2.4vw,34px);}
.ab-stat+.ab-stat::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  height:74px;width:1px;background:rgba(39,34,28,.28);}
.ab-stat b{font-family:var(--serif);font-weight:600;font-size:clamp(2.8rem,4.8vw,4.4rem);line-height:1;display:block;min-height:1.1em;letter-spacing:.005em;}
.ab-stat span{display:block;margin-top:16px;font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:rgba(39,34,28,.74);max-width:13ch;line-height:1.5;}

@media (max-width:820px){
  .ab-split,.ab-stats-row{grid-template-columns:1fr;}
  .ab-split__media{aspect-ratio:16/11;}
  .ab-stats-row__media{min-height:280px;}
}

/* dark full-bleed band with 3 features */
.ab-band{position:relative;margin-top:clamp(64px,8vw,120px);min-height:clamp(560px,86vh,820px);
  display:flex;flex-direction:column;align-items:center;justify-content:center;overflow:hidden;
  padding:clamp(80px,12vh,150px) var(--gutter);}
.ab-band__media{position:absolute;inset:0;z-index:0;}
.ab-band__media img{width:100%;height:100%;object-fit:cover;}
.ab-band__media::after{content:"";position:absolute;inset:0;background:linear-gradient(to bottom,rgba(20,16,11,.5),rgba(20,16,11,.66));}
.ab-band__inner{position:relative;z-index:2;width:100%;max-width:1180px;text-align:center;}
.ab-band__title{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;color:#fff;
  font-size:clamp(2.1rem,4.4vw,3.6rem);line-height:1.05;margin-bottom:clamp(40px,6vw,70px);}
.ab-feats{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid rgba(255,255,255,.22);}
.ab-feat{padding:clamp(22px,2.4vw,32px) clamp(18px,2vw,30px);border-right:1px solid rgba(255,255,255,.22);
  color:rgba(255,255,255,.92);font-size:clamp(.95rem,1.15vw,1.12rem);font-weight:600;letter-spacing:-.005em;line-height:1.4;}
.ab-feat:last-child{border-right:0;}
@media (max-width:760px){
  .ab-feats{grid-template-columns:1fr;border-top:0;}
  .ab-feat{border-right:0;border-bottom:1px solid rgba(255,255,255,.22);padding-block:18px;}
}

/* position + light map */
.ab-pos{max-width:var(--maxw);margin-inline:auto;padding:clamp(64px,8vw,116px) var(--gutter);
  display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,6vw,80px);align-items:center;}
.ab-pos__text h2{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;font-size:clamp(2rem,3.6vw,3.1rem);margin-bottom:22px;}
.ab-pos__text p{font-size:clamp(1rem,1.2vw,1.12rem);line-height:1.66;color:var(--ink-soft);max-width:40ch;}
.ab-pos__text .textlink{margin-top:30px;}
.ab-minimap{position:relative;height:clamp(360px,52vh,520px);border-radius:var(--radius);overflow:hidden;background:#eee;}
.ab-minimap .leaflet-container{background:#e8e6e0;font-family:var(--sans);}
@media (max-width:820px){.ab-pos{grid-template-columns:1fr;}}

/* ===========================================================
   CONTACT PAGE (kontakt.html)
   =========================================================== */
.kontakt-page{position:relative;overflow:hidden;
  background:linear-gradient(90deg,var(--paper) 0 47%,var(--cream) 47% 100%);
  padding:clamp(140px,17vh,210px) 0 clamp(72px,9vw,132px);}
.kontakt-page__inner{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);
  display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:start;position:relative;z-index:2;}
.kp-left{padding-top:clamp(6px,2vw,30px);}
.kp-left .eyebrow{margin-bottom:24px;}
.kp-title{font-family:var(--hero);font-weight:400;line-height:.88;color:var(--ink);letter-spacing:.012em;
  font-size:clamp(3.4rem,9.4vw,7.4rem);text-transform:uppercase;}
.kp-left .lead{margin:30px 0 32px;max-width:42ch;}
.kp-mail{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,2.7vw,2.2rem);color:var(--gold-deep);
  background-image:linear-gradient(var(--gold),var(--gold));background-size:100% 1.5px;background-repeat:no-repeat;
  background-position:0 100%;padding-bottom:6px;transition:color .35s,background-size .4s var(--ease);}
.kp-mail:hover{color:var(--ink);}
.kp-left .contact-lines{margin-top:44px;}
.kp-right h2{font-family:var(--sans);font-weight:800;letter-spacing:-.018em;font-size:clamp(1.9rem,3.1vw,2.7rem);margin-bottom:18px;}
.kp-right > .lead{margin-bottom:32px;max-width:42ch;}
.kp-px-tr{position:absolute;top:clamp(44px,8vh,96px);right:var(--gutter);--mx:100%;--my:0%;z-index:1;}
.kp-px-bl{position:absolute;bottom:clamp(34px,6vh,76px);left:var(--gutter);--mx:0%;--my:100%;z-index:1;}
@media (max-width:860px){
  .kontakt-page{background:var(--paper);padding-top:clamp(120px,14vh,160px);}
  .kontakt-page__inner{grid-template-columns:1fr;gap:clamp(36px,7vw,52px);}
  .kp-right{background:var(--cream);padding:clamp(28px,6vw,46px);border-radius:var(--radius);}
  .kp-px-tr,.kp-px-bl{display:none;}
}

/* ===========================================================
   BYTY PAGE (byty.html)
   =========================================================== */
.byty-hero{position:relative;min-height:64vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  padding:clamp(150px,20vh,240px) var(--gutter) clamp(54px,9vh,100px);}
.byty-hero__media{position:absolute;inset:0;z-index:0;}
.byty-hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);}
.byty-hero__media::after{content:"";position:absolute;inset:0;
  background:radial-gradient(70% 64% at 50% 44%,rgba(16,12,7,.62) 0%,rgba(16,12,7,.3) 52%,rgba(16,12,7,.12) 80%),
  linear-gradient(to bottom,rgba(24,19,12,.46),rgba(20,15,9,.74));}
.byty-hero__inner{position:relative;z-index:2;max-width:1080px;}
.byty-hero__title{font-family:var(--hero);font-weight:400;line-height:.9;color:var(--paper);letter-spacing:.038em;
  font-size:clamp(3rem,9.6vw,7.6rem);text-shadow:0 2px 44px rgba(12,9,5,.6);text-transform:uppercase;}
.byty-hero .lead{color:rgba(255,255,255,.86);max-width:52ch;margin:26px auto 0;font-weight:300;}

/* filter bar */
.byty-filters{max-width:var(--maxw);margin-inline:auto;padding:clamp(44px,6vw,76px) var(--gutter) 0;
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px 40px;}
.filter-group{display:flex;flex-direction:column;gap:16px;}
.filter-group__label{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
.filter-chips{display:flex;flex-wrap:wrap;gap:10px;}
.fchip{padding:10px 18px;border:1.5px solid var(--sand-deep);border-radius:999px;background:none;
  font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.04em;color:var(--ink-soft);
  cursor:pointer;transition:background .3s var(--ease),color .3s,border-color .3s;}
.fchip:hover{border-color:var(--gold);color:var(--ink);}
.fchip.active{background:var(--ink);border-color:var(--ink);color:var(--paper);}

.byty-listing{max-width:var(--maxw);margin-inline:auto;padding:clamp(34px,4.5vw,56px) var(--gutter) clamp(72px,9vw,128px);}
.byty-count{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;
  padding-bottom:18px;border-bottom:1.5px solid var(--sand-deep);margin-bottom:4px;}
.byty-count b{color:var(--ink);font-weight:800;}

.byty-row{display:grid;grid-template-columns:.85fr .85fr .8fr .9fr 1fr 1.05fr 1.5fr .5fr;gap:16px;align-items:center;
  padding:19px 6px;border-bottom:1px solid var(--line);transition:background .3s var(--ease);}
.byty-row--head{padding-block:16px 14px;border-bottom:0;}
.byty-row--head span{font-size:.64rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
.byty-row:not(.byty-row--head):hover{background:rgba(176,141,79,.05);}
.byty-row .num{text-align:right;justify-self:end;}
.byty-apt{font-weight:700;font-size:1.06rem;letter-spacing:-.01em;}
.byty-disp{display:inline-flex;width:fit-content;padding:4px 12px;border:1px solid var(--sand-deep);border-radius:999px;
  font-size:.74rem;font-weight:700;color:var(--ink-soft);}
.byty-disp--alt{border-color:var(--gold);color:var(--gold-deep);background:rgba(176,141,79,.07);}
.byty-price{font-family:var(--sans);font-size:1.06rem;color:var(--ink);font-weight:700;}
.byty-act{display:flex;gap:9px;justify-content:flex-end;flex-wrap:wrap;}
.btn--sm{padding:.78em 1.2em;font-size:.62rem;letter-spacing:.16em;border-width:1.5px;}
.byty-stav{display:inline-flex;align-items:center;justify-content:flex-end;gap:8px;font-size:.74rem;font-weight:600;color:var(--ink-soft);}
.byty-stav .dot{width:8px;height:8px;border-radius:50%;background:#7BA05B;box-shadow:0 0 0 3px rgba(123,160,91,.18);flex:none;}
.byty-empty{display:none;padding:48px 6px;text-align:center;color:var(--ink-soft);font-size:1.02rem;}
.byty-empty.show{display:block;}

@media (max-width:1080px){
  .byty-row{grid-template-columns:.8fr .8fr .7fr .8fr 1fr 1.3fr .55fr;}
  .byty-row .byty-permeter{display:none;}
}
@media (max-width:860px){
  .byty-filters{flex-direction:column;gap:26px;}
  .byty-row--head{display:none;}
  .byty-row{grid-template-columns:1fr 1fr;gap:12px 16px;padding:22px 0;}
  .byty-row .num{text-align:left;justify-self:start;}
  .byty-row span:not(.byty-apt):not(.byty-act){display:flex;align-items:baseline;justify-content:space-between;gap:14px;font-size:.95rem;}
  .byty-row span:not(.byty-apt):not(.byty-act)::before{content:attr(data-label);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;}
  .byty-apt{font-size:1.18rem;grid-column:1 / -1;}
  .byty-disp{border:0;padding:0;background:none;color:var(--ink);}
  .byty-act{grid-column:1 / -1;justify-content:flex-start;margin-top:6px;}
  .byty-permeter{display:none;}
}

/* unit detail modal */
.unit-modal{position:fixed;inset:0;z-index:200;background:rgba(20,16,11,.86);display:none;align-items:center;justify-content:center;padding:5vh 5vw;}
.unit-modal.open{display:flex;}
.unit-modal__card{background:var(--paper);border-radius:var(--radius);max-width:1000px;width:100%;max-height:90vh;overflow:auto;
  display:grid;grid-template-columns:1.15fr .85fr;box-shadow:0 40px 90px rgba(0,0,0,.5);}
.unit-modal__plan{background:#fff;padding:26px;display:flex;align-items:center;justify-content:center;border-right:1px solid var(--line);}
.unit-modal__plan img{width:100%;border-radius:2px;}
.unit-modal__body{padding:clamp(28px,3vw,44px);}
.unit-modal__body .eyebrow{margin-bottom:14px;}
.unit-modal__body h3{font-family:var(--sans);font-weight:800;letter-spacing:-.015em;font-size:clamp(1.6rem,2.4vw,2.2rem);margin-bottom:8px;}
.unit-modal__floor{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;}
.unit-modal__specs{list-style:none;margin:26px 0;padding:0;border-top:1px solid var(--line);}
.unit-modal__specs li{display:flex;justify-content:space-between;gap:18px;padding:13px 0;border-bottom:1px solid var(--line);font-size:.98rem;}
.unit-modal__specs .k{color:var(--ink-soft);}
.unit-modal__specs .v{font-weight:600;}
.unit-modal__specs .v.big{font-family:var(--serif);font-size:1.4rem;font-weight:400;color:var(--gold-deep);}
.unit-modal__close{position:absolute;top:24px;right:30px;background:none;border:0;color:var(--paper);font-size:.74rem;letter-spacing:.2em;text-transform:uppercase;font-weight:700;}
@media (max-width:760px){
  .unit-modal__card{grid-template-columns:1fr;}
  .unit-modal__plan{border-right:0;border-bottom:1px solid var(--line);}
}

/* ---------- interactive floor plan ---------- */
.byty-plan{max-width:var(--maxw);margin-inline:auto;padding:clamp(10px,2vw,30px) var(--gutter) clamp(72px,9vw,120px);}
.byty-plan__head{max-width:62ch;margin-bottom:clamp(26px,3.4vw,42px);}
.byty-plan__head .eyebrow{margin-bottom:14px;}
.byty-plan__head h2{font-family:var(--sans);font-weight:800;letter-spacing:-.02em;font-size:clamp(1.8rem,3.2vw,2.7rem);margin-bottom:14px;}
.byty-plan__head .lead{margin:0;}

.floorplan{margin-top:clamp(30px,4vw,52px);}
.floorplan__bar{display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  padding-bottom:14px;margin-bottom:14px;border-bottom:1px solid var(--line);}
.floorplan__bar h3{font-family:var(--sans);font-weight:700;font-size:clamp(1.05rem,1.5vw,1.32rem);letter-spacing:-.01em;}
.floorplan__bar span{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;white-space:nowrap;}

.fp-stage{position:relative;width:100%;aspect-ratio:1672 / 941;}
.fp-stage > img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;user-select:none;-webkit-user-drag:none;}
.fp-zone{position:absolute;margin:0;padding:0;border:1.5px solid transparent;border-radius:7px;background:transparent;
  cursor:pointer;display:grid;place-items:center;transition:background .25s var(--ease),border-color .25s,box-shadow .25s;}
.fp-zone__no{font-family:var(--serif);font-weight:600;font-size:clamp(1rem,1.9vw,1.7rem);color:rgba(120,95,55,.32);
  transition:color .25s var(--ease),transform .25s var(--ease);pointer-events:none;}
.fp-zone:hover,.fp-zone:focus-visible,.fp-zone.is-active{background:rgba(176,141,79,.28);border-color:var(--gold-deep);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.45),0 10px 26px -12px rgba(120,95,55,.6);outline:none;}
.fp-zone:hover .fp-zone__no,.fp-zone:focus-visible .fp-zone__no,.fp-zone.is-active .fp-zone__no{color:var(--gold-deep);transform:scale(1.08);}
.fp-zone.is-off{opacity:.16;pointer-events:none;}
.fp-zone.is-off .fp-zone__no{color:rgba(120,95,55,.22);}

.byty-row.is-active{background:rgba(176,141,79,.12);}

/* floating tooltip */
.fp-tip{position:fixed;z-index:300;min-width:236px;max-width:288px;background:var(--paper);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:0 24px 60px -18px rgba(20,15,9,.55);padding:18px 20px;
  pointer-events:none;opacity:0;transform:translateY(6px);transition:opacity .18s var(--ease),transform .18s var(--ease);}
.fp-tip.show{opacity:1;transform:translateY(0);}
.fp-tip__top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:14px;}
.fp-tip__apt{font-family:var(--sans);font-weight:800;font-size:1.16rem;letter-spacing:-.01em;}
.fp-tip__disp{font-size:.72rem;font-weight:700;letter-spacing:.03em;color:var(--gold-deep);border:1px solid var(--gold);border-radius:999px;padding:3px 11px;white-space:nowrap;}
.fp-tip__list{list-style:none;margin:0 0 13px;padding:0;}
.fp-tip__list li{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding:7px 0;border-bottom:1px solid var(--line);font-size:.9rem;}
.fp-tip__list li:last-child{border-bottom:0;}
.fp-tip__list span{color:var(--ink-soft);}
.fp-tip__list b{font-weight:600;}
.fp-tip__price{font-family:var(--serif);font-weight:400;font-size:1.18rem;color:var(--gold-deep);}
.fp-tip__stav{display:inline-flex;align-items:center;gap:8px;font-size:.84rem;font-weight:600;color:var(--ink);}
.fp-tip__stav i{width:8px;height:8px;border-radius:50%;background:#7BA05B;box-shadow:0 0 0 3px rgba(123,160,91,.18);flex:none;}

@media (max-width:560px){
  .fp-zone__no{font-size:.88rem;}
  .floorplan__bar{flex-direction:column;gap:4px;align-items:flex-start;}
}

/* ===========================================================
   LOKALITA PAGE (lokalita.html)
   =========================================================== */
.loc-hero{position:relative;min-height:74vh;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden;
  padding:clamp(150px,20vh,240px) var(--gutter) clamp(60px,12vh,130px);}
.loc-hero__media{position:absolute;inset:0;z-index:0;}
.loc-hero__media img{width:100%;height:100%;object-fit:cover;transform:scale(1.04);}
.loc-hero__media::after{content:"";position:absolute;inset:0;
  background:radial-gradient(72% 64% at 50% 42%,rgba(16,12,7,.58) 0%,rgba(16,12,7,.3) 54%,rgba(16,12,7,.14) 82%),
  linear-gradient(to bottom,rgba(24,19,12,.42),rgba(20,15,9,.72));}
.loc-hero__inner{position:relative;z-index:2;max-width:980px;}
.loc-hero__title{font-family:var(--hero);font-weight:400;line-height:.9;color:var(--paper);letter-spacing:.05em;
  font-size:clamp(3rem,9.6vw,7.6rem);text-shadow:0 2px 44px rgba(12,9,5,.6);text-transform:uppercase;}
.loc-hero .lead{color:rgba(255,255,255,.86);max-width:54ch;margin:26px auto 0;font-weight:300;}
.loc-hero__cta{margin-top:clamp(30px,4vw,42px);}

.loc-intro{text-align:center;}
.loc-intro__head{max-width:46ch;margin:0 auto clamp(40px,5vw,64px);}
.loc-intro__head .h-sec{margin:18px 0 20px;}
.loc-intro__head .lead{margin-inline:auto;}

.loc-poi{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.loc-poi .poi{background:var(--paper);padding:clamp(28px,2.6vw,38px) clamp(24px,2.2vw,34px);display:flex;flex-direction:column;gap:11px;text-align:left;}
.section--cream .loc-poi .poi{background:var(--cream);}
.poi__ico{width:32px;height:32px;color:var(--gold-deep);}
.poi__ico svg{width:100%;height:100%;stroke:currentColor;fill:none;stroke-width:1.3;stroke-linecap:round;stroke-linejoin:round;}
.poi__row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-top:4px;}
.poi__name{font-family:var(--sans);font-weight:700;font-size:1.16rem;letter-spacing:-.01em;}
.poi__time{font-family:var(--serif);font-size:1.5rem;color:var(--gold-deep);white-space:nowrap;}
.poi__sub{font-size:.85rem;color:var(--ink-soft);line-height:1.5;}

.loc-map-sec{padding-block:0;}
.loc-map{position:relative;overflow:hidden;height:clamp(400px,62vh,680px);background:var(--ink);}
.loc-map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.2) contrast(1.02);}
.loc-map__card{position:absolute;left:clamp(18px,3vw,40px);top:clamp(18px,3vw,40px);z-index:2;
  background:var(--paper);padding:18px 24px;border-radius:var(--radius);box-shadow:0 18px 40px -18px rgba(39,34,28,.55);max-width:300px;}
.loc-map__card .k{font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;display:block;margin-bottom:7px;}
.loc-map__card .v{font-family:var(--sans);font-weight:700;font-size:1.16rem;letter-spacing:-.01em;display:block;}
.loc-map__card .s{font-size:.82rem;color:var(--ink-soft);margin-top:6px;display:block;}

.loc-strip-head{text-align:center;max-width:46ch;margin:0 auto clamp(34px,4vw,52px);}
.loc-strip-head .h-sec{margin:16px 0 18px;}
.loc-strip-head .lead{margin:0 auto 22px;}
.loc-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(10px,1.2vw,18px);}
.loc-strip a{position:relative;display:block;overflow:hidden;border-radius:var(--radius);aspect-ratio:3/3.6;}
.loc-strip img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease);}
.loc-strip a:hover img{transform:scale(1.06);}
.loc-strip a::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,15,9,.6),transparent 52%);}
.loc-strip figcaption{position:absolute;left:20px;bottom:18px;z-index:2;color:#fff;font-size:.78rem;
  letter-spacing:.14em;text-transform:uppercase;font-weight:700;text-shadow:0 1px 12px rgba(0,0,0,.5);}

@media (max-width:900px){
  .loc-poi{grid-template-columns:1fr 1fr;}
  .loc-strip{grid-template-columns:1fr;max-width:480px;margin-inline:auto;}
  .loc-strip a{aspect-ratio:16/10;}
}
@media (max-width:560px){
  .loc-poi{grid-template-columns:1fr;}
}

/* ---------- interactive dark map (Leaflet) ---------- */
.lmap-sec{position:relative;}
.lmap{height:clamp(460px,72vh,760px);width:100%;background:#11110f;}
.lmap .leaflet-container{background:#11110f;font-family:var(--sans);}
.lmap .leaflet-control-attribution{background:rgba(20,16,11,.6);color:rgba(255,255,255,.5);}
.lmap .leaflet-control-attribution a{color:rgba(255,255,255,.7);}
.lmap .leaflet-bar a{background:#1d1b16;color:#f3ede1;border-color:rgba(255,255,255,.12);}
.lmap .leaflet-bar a:hover{background:#2a2620;}

.lmap-card{position:absolute;left:clamp(16px,3vw,40px);top:clamp(16px,3vw,40px);z-index:600;
  background:var(--paper);padding:18px 24px;border-radius:var(--radius);box-shadow:0 18px 40px -18px rgba(20,15,9,.6);max-width:300px;pointer-events:none;}
.lmap-card .k{font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold-deep);font-weight:700;display:block;margin-bottom:7px;}
.lmap-card .v{font-family:var(--sans);font-weight:800;font-size:1.2rem;letter-spacing:-.01em;display:block;}
.lmap-card .s{font-size:.82rem;color:var(--ink-soft);margin-top:6px;display:block;line-height:1.5;}

.lmap-legend{position:absolute;right:clamp(16px,3vw,40px);bottom:clamp(16px,3vw,40px);z-index:600;
  background:rgba(20,16,11,.82);backdrop-filter:blur(6px);padding:15px 18px;border-radius:var(--radius);
  display:flex;flex-wrap:wrap;gap:9px 16px;max-width:330px;}
.lmap-legend span{display:inline-flex;align-items:center;gap:7px;font-size:.72rem;color:rgba(255,255,255,.82);font-weight:500;}
.lmap-legend i{width:11px;height:11px;border-radius:50%;background:var(--gold);flex:none;}
.lmap-legend i.home{background:#fff;}

/* custom pins (DivIcon) */
.poi-pin{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;
  background:var(--gold-deep);color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.45),0 0 0 4px rgba(176,141,79,.28);
  transition:transform .2s var(--ease),box-shadow .2s;border:1.5px solid rgba(255,255,255,.85);}
.poi-pin svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.poi-pin:hover{transform:scale(1.14);box-shadow:0 6px 18px rgba(0,0,0,.55),0 0 0 6px rgba(176,141,79,.34);z-index:700;}
.poi-pin--home{width:46px;height:46px;background:var(--ink);border-color:var(--gold);
  font-family:var(--serif);font-weight:600;font-size:.92rem;letter-spacing:.02em;color:var(--gold);
  box-shadow:0 6px 18px rgba(0,0,0,.55),0 0 0 5px rgba(176,141,79,.4);}
.leaflet-tooltip.poi-tip{background:var(--ink);color:#fff;border:0;border-radius:8px;padding:7px 12px;
  font-family:var(--sans);font-size:.78rem;font-weight:600;box-shadow:0 8px 22px rgba(0,0,0,.45);}
.leaflet-tooltip.poi-tip::before{border-top-color:var(--ink);}
.poi-tip .t{display:block;}
.poi-tip .d{display:block;font-weight:500;color:var(--gold);font-size:.72rem;margin-top:2px;letter-spacing:.04em;}

@media (max-width:600px){.lmap-legend{display:none;}}
