/* ===========================================================
   Jánský sen Residence — sdílený stylesheet
   Estetika: Alpine Editorial (světlý, patkové nadpisy, vzduch)
   =========================================================== */

:root{
  --bg:#f7f5f1; --bg-2:#ffffff; --ink:#1b1a17; --soft:#6b685f;
  --line:#e4ded3; --gold:#b08d57; --dark:#16140f;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:"Helvetica Neue",Arial,sans-serif;color:var(--ink);background:var(--bg);
     font-size:17.5px;line-height:1.7;-webkit-font-smoothing:antialiased;font-weight:300}
.serif{font-family:Georgia,"Times New Roman",serif;font-weight:400;letter-spacing:-.01em}
h1,h2,h3{font-family:Georgia,"Times New Roman",serif;font-weight:400;letter-spacing:-.015em}
.wrap{max-width:1240px;margin:0 auto;padding:0 40px}
.eyebrow{text-transform:uppercase;letter-spacing:.32em;font-size:11px;color:var(--gold);font-weight:600}
a{color:inherit}

/* NAV — fixed, transparent over hero, solid on scroll */
.site-nav{position:fixed;top:0;left:0;right:0;z-index:60;display:flex;align-items:center;
    justify-content:space-between;padding:22px 40px;color:#fff;transition:background .35s,padding .35s,color .35s}
.site-nav::before{content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
    background:linear-gradient(180deg,rgba(15,13,9,.6),rgba(15,13,9,0));transition:opacity .35s}
.site-nav.solid{background:var(--bg-2);color:var(--ink);padding:12px 40px;border-bottom:1px solid var(--line)}
.site-nav.solid::before{opacity:0}
.site-nav .logo{font-family:Georgia,serif;font-size:22px;letter-spacing:.01em;text-decoration:none;display:block}
.site-nav .logo img{height:72px;width:auto;display:block;transition:height .35s}
.site-nav.solid .logo img{height:58px}
@media(max-width:880px){.site-nav .logo img{height:56px}}
.site-nav .links{display:flex;align-items:center;gap:30px;font-size:13.5px;text-transform:uppercase;letter-spacing:.18em}
.site-nav .links a{position:relative;text-decoration:none;opacity:.92;padding-bottom:3px}
.site-nav:not(.solid) .links a{text-shadow:0 1px 6px rgba(0,0,0,.45)}
.site-nav .links a:not(.nav-cta)::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:currentColor;transition:width .3s}
.site-nav .links a:not(.nav-cta):hover{opacity:1}
.site-nav .links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{border:1px solid currentColor;padding:11px 18px;border-radius:2px;opacity:1;letter-spacing:.14em;transition:.25s;text-shadow:none!important}
.nav-cta:hover{background:var(--gold);border-color:var(--gold);color:#fff}
/* Hamburger */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:42px;height:42px;
    background:none;border:none;cursor:pointer;padding:0;z-index:70}
.nav-toggle span{display:block;width:26px;height:2px;background:currentColor;transition:.3s;margin:0 auto}
.nav-toggle.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
body.nav-lock{overflow:hidden}
@media(max-width:980px){
  .nav-toggle{display:flex}
  .site-nav .links{position:fixed;top:0;right:0;height:100vh;width:min(82vw,340px);
      background:var(--bg-2);color:var(--ink);flex-direction:column;align-items:flex-start;justify-content:center;
      gap:30px;padding:90px 40px;font-size:15px;letter-spacing:.16em;
      transform:translateX(100%);transition:transform .35s ease;box-shadow:-20px 0 60px rgba(0,0,0,.2)}
  .site-nav .links.open{transform:none}
  .site-nav:not(.solid) .links a{text-shadow:none}
  .nav-cta{border-color:var(--ink);align-self:stretch;text-align:center}
}

/* HERO (homepage) */
.hero{position:relative;height:100vh;min-height:660px;display:flex;align-items:flex-end;color:#fff;
      overflow:hidden;background:#16140f}
.hero .slide{position:absolute;inset:0;background-size:cover;background-position:center 38%;
      opacity:0;transition:opacity 1.6s ease;z-index:0;will-change:opacity}
.hero .slide.show{opacity:1}
.hero::after{content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
      background:linear-gradient(180deg,rgba(15,13,9,.42) 0%,rgba(15,13,9,0) 34%,rgba(15,13,9,.82) 100%)}
.hero .inner,.hero .scrollcue{position:relative;z-index:2}
.hero .inner{padding-bottom:9vh}
.hero h1{font-size:clamp(40px,6.4vw,86px);line-height:1.02;margin:20px 0 0;max-width:15ch}
.hero .sub{font-size:clamp(16px,1.6vw,20px);max-width:42ch;margin-top:26px;opacity:.9;font-weight:300}
.scrollcue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);font-size:10px;
           letter-spacing:.3em;text-transform:uppercase;opacity:.7}

/* STATEMENT */
.statement{padding:clamp(110px,16vh,200px) 0;text-align:center}
.statement .big{font-family:Georgia,serif;font-size:clamp(28px,4.4vw,58px);line-height:1.22;
                max-width:20ch;margin:30px auto 0}
.statement .big em{font-style:italic;color:var(--gold)}

/* STATS row */
.stats{border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stats .cell{padding:54px 28px;text-align:center;border-right:1px solid var(--line)}
.stats .cell:last-child{border-right:none}
.stats .num{font-family:Georgia,serif;font-size:clamp(34px,3.6vw,50px);line-height:1}
.stats .lab{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft);margin-top:14px}
@media(max-width:760px){.stats .grid{grid-template-columns:1fr 1fr}.stats .cell:nth-child(2){border-right:none}
      .stats .cell:nth-child(1),.stats .cell:nth-child(2){border-bottom:1px solid var(--line)}}

/* FEATURE split */
.feature{padding:clamp(100px,14vh,180px) 0}
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:80px;align-items:center}
@media(max-width:900px){.split{grid-template-columns:1fr;gap:48px}}
.feature .ph{aspect-ratio:4/5;background:#cfc7b8 center/cover no-repeat;border-radius:2px}
.feature h2{font-size:clamp(28px,3.6vw,46px);line-height:1.16;max-width:16ch}
.feature p{color:var(--soft);font-size:18px;max-width:46ch;margin-top:22px}

/* APARTMENTS — editorial list (řádky jsou odkazy) */
.apts{padding:clamp(100px,14vh,180px) 0;background:var(--bg-2);border-top:1px solid var(--line)}
.apts .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:30px}
.apts h2{font-size:clamp(30px,4vw,52px)}
.apts .note{color:var(--soft);font-size:15px;max-width:32ch}
.alist{border-top:1px solid var(--line)}
.arow{display:grid;grid-template-columns:84px 1fr 110px 140px minmax(150px,1fr) 26px;align-items:center;gap:20px;
      padding:30px 8px;border-bottom:1px solid var(--line);transition:.25s;text-decoration:none;color:inherit}
.arow:hover{background:#faf8f4;padding-left:22px}
.arow .id{font-family:Georgia,serif;font-size:30px;color:var(--gold)}
.arow .disp{font-family:Georgia,serif;font-size:22px}
.arow .meta{font-size:13px;color:var(--soft);letter-spacing:.04em}
.arow .area{font-size:16px;color:var(--ink)}
.arow .price{text-align:right;font-size:18px;white-space:nowrap}
.arow .price b{font-weight:400}
.arow .go{text-align:right;color:var(--gold);font-size:20px;opacity:0;transition:.25s}
.arow:hover .go{opacity:1}
@media(max-width:820px){
  .arow{grid-template-columns:64px 1fr auto;row-gap:6px}
  .arow .area{grid-column:2;font-size:14px;color:var(--soft)}
  .arow .price{grid-column:3;grid-row:1}
  .arow .meta,.arow .go{display:none}
}
.apts .total{display:flex;justify-content:space-between;align-items:baseline;margin-top:30px;
             padding-top:24px;border-top:2px solid var(--ink);font-size:15px;letter-spacing:.04em}
.apts .total b{font-family:Georgia,serif;font-size:26px}
.apts .total .thint{display:block;margin-top:5px;font-size:12px;letter-spacing:.02em;color:var(--soft)}

/* LOCATION full-bleed */
.loc{position:relative;height:80vh;min-height:520px;display:flex;align-items:center;color:#fff;
     background:linear-gradient(90deg,rgba(15,13,9,.72),rgba(15,13,9,.15)),
                url("../images/img_kostel_vila.jpg") center 60%/cover no-repeat}
.loc h2{font-size:clamp(30px,4.4vw,56px);max-width:14ch;line-height:1.1}
.loc p{max-width:40ch;margin-top:20px;opacity:.9;font-size:18px}

/* LEAD MAGNET */
.magnet{padding:clamp(100px,14vh,170px) 0;text-align:center}
.magnet h2{font-size:clamp(28px,4vw,48px);max-width:18ch;margin:22px auto 0}
.magnet p{color:var(--soft);max-width:46ch;margin:20px auto 34px;font-size:18px}
.form{display:flex;max-width:480px;margin:0 auto;border:1px solid var(--ink)}
.form input{flex:1;padding:18px 20px;border:none;background:transparent;color:var(--ink);font-size:15px;font-family:inherit}
.form input:focus{outline:none}
.form button{border:none;background:var(--ink);color:#fff;padding:0 30px;font-size:12px;
             letter-spacing:.18em;text-transform:uppercase;cursor:pointer;font-family:inherit}

/* FOOTER */
footer{background:var(--dark);color:#9a9489;padding:70px 0 56px;font-size:15px;line-height:1.65}
footer .frow{display:flex;justify-content:space-between;flex-wrap:wrap;gap:30px}
footer .logo{font-family:Georgia,serif;font-size:24px;color:#fff;text-decoration:none;display:inline-block}
footer .logo img{height:88px;width:auto;display:block}
footer a{color:#c9b48a;text-decoration:none}

/* USP — výnos od prvního dne */
.usp{padding:clamp(100px,15vh,190px) 0;background:var(--dark);color:#ece7db}
.usp .eyebrow{color:var(--gold)}
.usp h2{font-size:clamp(28px,4.2vw,54px);line-height:1.12;max-width:20ch;margin:18px 0 0;color:#fff}
.usp .lead{color:#b8b1a2;font-size:18px;line-height:1.7;max-width:56ch;margin-top:26px}
.usp .points{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:70px;
             background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}
.usp .pt{background:var(--dark);padding:42px 34px}
.usp .pt .n{font-family:Georgia,serif;font-size:30px;color:var(--gold)}
.usp .pt h3{font-family:Georgia,serif;font-size:21px;color:#fff;margin:14px 0 10px;font-weight:400}
.usp .pt p{color:#b8b1a2;font-size:16px;line-height:1.66}
@media(max-width:820px){.usp .points{grid-template-columns:1fr}}

/* CO KUPUJETE */
.incl{padding:clamp(100px,14vh,180px) 0}
.incl .head{max-width:60ch}
.incl h2{font-size:clamp(28px,3.6vw,48px);line-height:1.16;margin-top:14px}
.incl .grid{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:60px;border-top:1px solid var(--line)}
.incl .it{padding:36px 34px 36px 0;border-bottom:1px solid var(--line)}
.incl .it .n{font-family:Georgia,serif;font-size:22px;color:var(--gold)}
.incl .it h3{font-family:Georgia,serif;font-size:20px;font-weight:400;margin:14px 0 10px}
.incl .it p{color:var(--soft);font-size:16px;line-height:1.66}
@media(max-width:900px){.incl .grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.incl .grid{grid-template-columns:1fr}.incl .it{padding-right:0}}

/* OKOLÍ */
.area-sec{padding:clamp(100px,14vh,180px) 0;background:var(--bg-2);border-top:1px solid var(--line)}
.area-sec .head{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;margin-bottom:50px}
.area-sec .head h2{font-size:clamp(28px,4vw,52px);line-height:1.12}
.area-sec .note{color:var(--soft);font-size:15px;max-width:34ch}
.area-sec .cards{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.area-sec .card{background:var(--bg-2);padding:44px 38px}
.area-sec .card .dist{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.area-sec .card h3{font-family:Georgia,serif;font-size:25px;font-weight:400;margin:10px 0 12px}
.area-sec .card p{color:var(--soft);font-size:16px;line-height:1.68}
@media(max-width:760px){.area-sec .cards{grid-template-columns:1fr}.area-sec .head{flex-direction:column;align-items:flex-start}}

/* FULL-BLEED PHOTO BAND */
.band{position:relative;min-height:64vh;display:flex;align-items:center;justify-content:center;
    text-align:center;color:#fff;overflow:hidden;background:#16140f}
.band .bg{position:absolute;inset:0;background-size:cover;background-position:center;transform:scale(1.03)}
.band::after{content:"";position:absolute;inset:0;
    background:linear-gradient(180deg,rgba(15,13,9,.55),rgba(15,13,9,.28) 50%,rgba(15,13,9,.7))}
.band .inner{position:relative;z-index:2;max-width:760px;padding:80px 32px}
.band .eyebrow{color:#d9b877}
.band h2{color:#fff;font-size:clamp(28px,4vw,50px);line-height:1.16;margin-top:18px}
.band p{color:#e7e0d2;margin:18px auto 0;font-size:18px;line-height:1.7;max-width:54ch}
@media(min-width:900px){.band .bg{background-attachment:fixed}}

/* PAGE HERO (podstránky) */
.phero{position:relative;min-height:60vh;display:flex;align-items:flex-end;color:#fff;overflow:hidden;background:#16140f}
.phero .bg{position:absolute;inset:0;background-size:cover;background-position:center}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(15,13,9,.5),rgba(15,13,9,.1) 42%,rgba(15,13,9,.85))}
.phero .inner{position:relative;z-index:2;padding-bottom:7vh;width:100%}
.phero h1{font-size:clamp(34px,5.2vw,68px);line-height:1.05;margin:14px 0 0;max-width:18ch}
.phero .lede{max-width:48ch;margin-top:20px;font-size:clamp(16px,1.6vw,19px);opacity:.92;font-weight:300}

/* PROSE / obsah podstránek */
.prose-sec{padding:clamp(80px,12vh,150px) 0}
.lede-split{display:grid;grid-template-columns:.9fr 1.4fr;gap:70px;align-items:start}
@media(max-width:900px){.lede-split{grid-template-columns:1fr;gap:30px}}
.lede-split .big{font-family:Georgia,serif;font-size:clamp(23px,3vw,34px);line-height:1.28}
.lede-split .big em{font-style:italic;color:var(--gold)}
.prose{max-width:64ch}
.prose h2{font-size:clamp(26px,3.4vw,42px);line-height:1.16;margin:0 0 22px}
.prose h3{font-family:Georgia,serif;font-weight:400;font-size:clamp(20px,2.4vw,28px);margin:48px 0 14px}
.prose p{color:var(--soft);font-size:18px;line-height:1.75;margin-bottom:18px}
.prose strong{color:var(--ink);font-weight:600}
.prose ul{list-style:none;margin:18px 0 26px}
.prose ul li{position:relative;padding-left:26px;color:var(--soft);font-size:17px;line-height:1.75;margin-bottom:12px}
.prose ul li::before{content:"";position:absolute;left:0;top:11px;width:8px;height:8px;background:var(--gold);border-radius:50%}

/* FAQ accordion */
.faq{border-top:1px solid var(--line);margin-top:10px}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:26px 0;display:flex;justify-content:space-between;gap:20px;
    font-family:Georgia,serif;font-size:clamp(18px,2vw,23px);align-items:center}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--gold);font-size:28px;line-height:1;transition:transform .25s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--soft);font-size:16px;line-height:1.72;padding:0 0 26px;max-width:72ch}

/* CTA ribbon */
.ribbon{background:var(--dark);color:#ece7db;padding:clamp(70px,10vh,120px) 0;text-align:center}
.ribbon h2{color:#fff;font-size:clamp(26px,3.6vw,46px);max-width:22ch;margin:0 auto;line-height:1.14}
.ribbon p{color:#b8b1a2;max-width:50ch;margin:18px auto 32px;font-size:18px;line-height:1.7}
.btn{display:inline-block;border:1px solid var(--gold);color:#fff;padding:16px 34px;text-decoration:none;
    font-size:12px;letter-spacing:.18em;text-transform:uppercase;transition:.25s}
.btn:hover{background:var(--gold);color:#fff}

/* REVEAL */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .9s ease,transform .9s ease}
.reveal.in{opacity:1;transform:none}

/* ===========================================================
   DETAIL APARTMÁNU
   =========================================================== */
.dhero{position:relative;height:78vh;min-height:560px;display:flex;align-items:flex-end;color:#fff;
       background-size:cover;background-position:center}
.dhero::after{content:"";position:absolute;inset:0;
       background:linear-gradient(180deg,rgba(15,13,9,.3),rgba(15,13,9,0) 38%,rgba(15,13,9,.82))}
.dhero .inner{position:relative;z-index:2;padding-bottom:6vh;width:100%}
.dhero .id{font-family:Georgia,serif;font-size:clamp(14px,2vw,18px);letter-spacing:.3em;color:#d9b877;text-transform:uppercase}
.dhero h1{font-size:clamp(34px,5.4vw,72px);line-height:1.02;margin:12px 0 0}
.dhero .facts{display:flex;flex-wrap:wrap;gap:30px;margin-top:24px;font-size:15px;letter-spacing:.02em}
.dhero .facts b{font-family:Georgia,serif;font-weight:400;font-size:20px;display:block}
.dhero .facts span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;opacity:.75}

.backlink{display:inline-flex;align-items:center;gap:8px;font-size:12px;letter-spacing:.18em;
          text-transform:uppercase;text-decoration:none;color:var(--soft);margin:0}

/* DESC + SPECS split */
.dbody{padding:clamp(80px,11vh,140px) 0}
.dsplit{display:grid;grid-template-columns:1.2fr .8fr;gap:70px;align-items:start}
@media(max-width:900px){.dsplit{grid-template-columns:1fr;gap:44px}}
.desc h2{font-size:clamp(24px,3vw,38px);margin-bottom:20px}
.desc p{color:var(--soft);font-size:18px;margin-bottom:18px;max-width:54ch}
.specs{border-top:1px solid var(--ink)}
.specs .row{display:flex;justify-content:space-between;gap:18px;padding:15px 0;border-bottom:1px solid var(--line);font-size:15px}
.specs .row span:first-child{color:var(--soft)}
.specs .row span:last-child{text-align:right;font-weight:400}
.specs .price-row{padding:22px 0;border-bottom:none}
.specs .price-row span:last-child{font-family:Georgia,serif;font-size:26px}
.specs .row a{color:var(--gold);text-decoration:none}
.specs .row a:hover{text-decoration:underline}
.specs .row .todo{color:#b08d57;font-style:italic}

/* CONTACT form */
.cform{margin-top:30px}
.cform label{display:block;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--soft);margin:18px 0 8px}
.cform input,.cform textarea{width:100%;padding:14px 16px;border:1px solid var(--line);background:var(--bg-2);
    font-family:inherit;font-size:15px;color:var(--ink)}
.cform input:focus,.cform textarea:focus{outline:none;border-color:var(--gold)}
.cform textarea{min-height:150px;resize:vertical}
.cform button{margin-top:26px;border:none;background:var(--ink);color:#fff;padding:16px 36px;
    font-size:12px;letter-spacing:.18em;text-transform:uppercase;cursor:pointer;font-family:inherit;transition:.25s}
.cform button:hover{background:var(--gold)}
.cform .hint{font-size:13px;color:var(--soft);margin-top:16px;line-height:1.6}
.cform .consent{display:flex;gap:10px;align-items:flex-start;margin-top:24px;font-size:13.5px;line-height:1.55;color:var(--soft);text-transform:none;letter-spacing:0}
.cform .consent input{width:auto;margin:3px 0 0;flex:0 0 auto;accent-color:var(--gold)}
.cform .consent a{color:var(--gold);text-decoration:none}
.cform .consent a:hover{text-decoration:underline}
.form-note{max-width:480px;margin:14px auto 0;text-align:center;font-size:12.5px;line-height:1.55;color:var(--soft)}
.form-note a{color:var(--gold);text-decoration:none}
.form-note a:hover{text-decoration:underline}
/* Honeypot — skryté pole pro roboty */
.hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
/* Stav odeslání formuláře */
.form-status{margin-top:14px;font-size:14px;line-height:1.5}
.form-status:empty{display:none}
.form-status.ok{color:#2e7d4f}
.form-status.err{color:#b3402f}
.cform .form-status{text-transform:none;letter-spacing:0}

/* RECENZE / SOCIAL PROOF */
.reviews{padding:clamp(80px,12vh,140px) 0;background:var(--bg-2);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.reviews .head{max-width:760px;margin:0 auto 56px;text-align:center}
.reviews .head h2{font-size:clamp(28px,4vw,46px);margin-top:16px}
.reviews .head .score{display:inline-flex;align-items:baseline;gap:10px;margin-top:22px}
.reviews .head .score b{font-family:Georgia,serif;font-size:40px;color:var(--gold);line-height:1}
.reviews .head .score span{font-size:14px;color:var(--soft);letter-spacing:.04em}
.reviews .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.rcard{border:1px solid var(--line);padding:32px 30px;background:var(--bg);display:flex;flex-direction:column}
.rcard .stars{color:var(--gold);font-size:14px;letter-spacing:3px}
.rcard .title{font-family:Georgia,serif;font-size:21px;margin:16px 0 12px;line-height:1.3}
.rcard .quote{color:var(--ink);font-size:15.5px;line-height:1.72;flex:1}
.rcard .by{margin-top:22px;padding-top:18px;border-top:1px solid var(--line);font-size:13px;color:var(--soft);display:flex;justify-content:space-between;align-items:baseline;gap:10px}
.rcard .by b{color:var(--ink);font-weight:600}
.reviews .more{text-align:center;margin-top:48px}
.reviews .more a{color:var(--soft);font-size:14px;letter-spacing:.04em;text-decoration:none;border-bottom:1px solid var(--line);padding-bottom:3px;transition:.25s}
.reviews .more a:hover{color:var(--gold);border-color:var(--gold)}
@media(max-width:900px){.reviews .grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.reviews .grid{grid-template-columns:1fr}}

/* GALLERY */
.dgallery{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;padding-bottom:clamp(80px,10vh,130px)}
.dgallery .img{background:#cfc7b8 center/cover no-repeat;border-radius:2px;aspect-ratio:1}
.dgallery .img.big{grid-column:span 2;grid-row:span 2;aspect-ratio:auto}
@media(max-width:760px){.dgallery{grid-template-columns:repeat(2,1fr)}.dgallery .img.big{grid-column:span 2}}
.dgallery .img:focus-visible{outline:2px solid var(--gold);outline-offset:3px}

/* LIGHTBOX */
.lightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
    background:rgba(12,10,7,.92);padding:5vh 4vw}
.lightbox.open{display:flex}
.lightbox .lb-img{max-width:92vw;max-height:90vh;object-fit:contain;box-shadow:0 30px 80px rgba(0,0,0,.5);border-radius:2px}
.lightbox .lb-close{position:absolute;top:22px;right:26px;width:46px;height:46px;border:none;background:none;
    color:#fff;font-size:38px;line-height:1;cursor:pointer;opacity:.8;transition:.2s}
.lightbox .lb-close:hover{opacity:1}
.lightbox .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:60px;height:60px;border:none;
    background:rgba(255,255,255,.08);color:#fff;font-size:34px;line-height:1;cursor:pointer;border-radius:50%;
    display:flex;align-items:center;justify-content:center;transition:.2s}
.lightbox .lb-nav:hover{background:var(--gold)}
.lightbox .lb-prev{left:18px}
.lightbox .lb-next{right:18px}
@media(max-width:760px){.lightbox .lb-nav{width:46px;height:46px;font-size:26px}.lightbox .lb-prev{left:8px}.lightbox .lb-next{right:8px}}

/* PREV / NEXT */
.apnav{border-top:1px solid var(--line);display:grid;grid-template-columns:1fr 1fr}
.apnav a{padding:40px;text-decoration:none;transition:.25s}
.apnav a:hover{background:#faf8f4}
.apnav a.next{text-align:right;border-left:1px solid var(--line)}
.apnav .lab{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--soft)}
.apnav .ttl{font-family:Georgia,serif;font-size:22px;margin-top:8px}
@media(max-width:620px){.apnav{grid-template-columns:1fr}.apnav a.next{border-left:none;border-top:1px solid var(--line)}}

/* ===========================================================
   MOBILNÍ DOLADĚNÍ — zamezení vodorovného přetékání a
   zmenšení velkých paddingů na úzkých displejích
   =========================================================== */
html,body{overflow-x:hidden;max-width:100%}
@media(max-width:600px){
  .wrap{padding:0 24px}
  .site-nav{padding:16px 24px}
  .site-nav.solid{padding:10px 24px}
  .usp .pt{padding:34px 26px}
  .area-sec .card{padding:34px 26px}
  .rcard{padding:28px 24px}
  .apnav a{padding:30px 24px}
  .band .inner{padding:60px 24px}
}
@media(max-width:400px){
  .wrap{padding:0 18px}
  .site-nav{padding:14px 18px}
  .site-nav.solid{padding:9px 18px}
  .usp .pt{padding:28px 20px}
  .area-sec .card{padding:28px 20px}
  .rcard{padding:24px 20px}
  .apnav a{padding:26px 18px}
  .band .inner{padding:48px 20px}
}
