/* ============================================================
   ŠŤASTNO — sdílený design systém
   Útulná, hřejivá, přírodní rezidence. Dřevo, krém, lesní zeleň.
   ============================================================ */

:root{
  /* Barvy ------------------------------------------------- */
  --bg:        #faf6ee;   /* teplá krémová */
  --bg-deep:   #f1e8d9;   /* písková pro střídavé sekce */
  --bg-ink:    #2b2620;   /* tmavá hřejivá – tmavé sekce */
  --card:      #fffdf8;
  --ink:       #2b2620;   /* hlavní text, skoro černá hřejivá */
  --ink-soft:  #6b6155;   /* sekundární text */
  --ink-mute:  #8c8377;
  --line:      #e6dccb;   /* linky, ohraničení */
  --line-soft: #efe7d8;

  --green:     #4a5a44;   /* lesní zeleň – primární akce */
  --green-d:   #3a4836;   /* hover */
  --green-soft:#eaeee4;
  --terra:     #b56a4a;   /* terakota – jemný akcent */
  --terra-d:   #9c573b;

  /* Typografie ------------------------------------------- */
  --serif: "Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:  "Mulish", system-ui, -apple-system, sans-serif;

  /* Rozměry ---------------------------------------------- */
  --wrap: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --radius: 14px;
  --radius-lg: 22px;
  --shadow: 0 18px 50px -28px rgba(43,38,32,.45);
  --shadow-soft: 0 10px 30px -22px rgba(43,38,32,.4);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* Typografická škála ------------------------------------- */
h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:600;
  line-height:1.08;
  margin:0;
  letter-spacing:.005em;
  color:var(--ink);
  text-wrap:balance;
}
.h-display{ font-size:clamp(3rem, 7.5vw, 6rem); font-weight:500; }
h1{ font-size:clamp(2.6rem, 5.5vw, 4.4rem); }
h2{ font-size:clamp(2.1rem, 4vw, 3.3rem); }
h3{ font-size:clamp(1.5rem, 2.3vw, 2rem); }
p{ margin:0 0 1.1em; text-wrap:pretty; }

.eyebrow{
  font-family:var(--sans);
  font-size:.78rem;
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--terra);
  margin:0 0 1.1rem;
  display:inline-flex; align-items:center; gap:.7em;
}
.eyebrow::before{
  content:""; width:26px; height:1px; background:var(--terra); opacity:.6;
}
.eyebrow.center{ justify-content:center; }
.lead{
  font-family:var(--serif);
  font-size:clamp(1.3rem, 2.1vw, 1.7rem);
  line-height:1.4;
  color:var(--ink-soft);
  font-weight:500;
}

/* Layout ------------------------------------------------- */
.wrap{ max-width:var(--wrap); margin:0 auto; padding-inline:var(--gutter); }
.wrap-narrow{ max-width:780px; margin:0 auto; padding-inline:var(--gutter); }
section{ position:relative; }
.section{ padding-block:clamp(64px, 9vw, 140px); }
.section-deep{ background:var(--bg-deep); }
.section-ink{ background:var(--bg-ink); color:#ece4d6; }
.section-ink h1,.section-ink h2,.section-ink h3{ color:#fbf6ec; }
.section-ink .lead{ color:#cabfae; }
.center{ text-align:center; }
.divider{ height:1px; background:var(--line); border:0; margin:0; }

/* Tlačítka ----------------------------------------------- */
.btn{
  --bg:var(--green); --fg:#fbf7ef;
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--sans); font-weight:700; font-size:.92rem;
  letter-spacing:.02em;
  padding:.95em 1.7em; border-radius:100px;
  background:var(--bg); color:var(--fg);
  border:1px solid transparent; cursor:pointer;
  transition:transform .25s ease, background .25s ease, box-shadow .25s ease;
  box-shadow:0 10px 24px -16px rgba(74,90,68,.9);
}
.btn:hover{ background:var(--green-d); transform:translateY(-2px); }
.btn .arr{ transition:transform .25s ease; }
.btn:hover .arr{ transform:translateX(3px); }
.btn-ghost{
  background:transparent; color:var(--ink); border-color:var(--line);
  box-shadow:none;
}
.btn-ghost:hover{ background:#fff; border-color:var(--ink-soft); color:var(--ink); }
.btn-light{ background:#fbf7ef; color:var(--ink); box-shadow:none; }
.btn-light:hover{ background:#fff; color:var(--ink); }
.btn-terra{ background:var(--terra); box-shadow:0 10px 24px -16px rgba(181,106,74,.9); }
.btn-terra:hover{ background:var(--terra-d); }
.btn-lg{ padding:1.05em 2em; font-size:1rem; }
.link-arrow{
  display:inline-flex; align-items:center; gap:.5em;
  font-weight:700; font-size:.9rem; letter-spacing:.02em;
  color:var(--green); border-bottom:1px solid transparent; padding-bottom:2px;
}
.link-arrow:hover{ border-color:var(--green); }
.section-ink .link-arrow{ color:#d8b79f; }

/* Header ------------------------------------------------- */
.site-header{
  position:sticky; top:0; z-index:60;
  background:rgba(250,246,238,.82);
  backdrop-filter:saturate(140%) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease, box-shadow .3s;
}
.site-header.scrolled{
  border-color:var(--line); box-shadow:0 6px 24px -20px rgba(43,38,32,.5);
}
.nav{
  display:flex; align-items:center; gap:1.5rem;
  height:74px; max-width:var(--wrap); margin:0 auto; padding-inline:var(--gutter);
}
.brand{
  font-family:var(--serif); font-size:1.65rem; font-weight:600;
  letter-spacing:.02em; line-height:1; display:flex; align-items:baseline; gap:.45rem;
}
.brand .dot{ width:7px; height:7px; border-radius:50%; background:var(--terra); display:inline-block; }
.nav-links{ display:flex; gap:1.25rem; margin-left:auto; align-items:center; }
.nav-links a{
  font-size:.92rem; font-weight:600; color:var(--ink-soft);
  letter-spacing:.01em; position:relative; padding:.3em 0; white-space:nowrap;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; height:1.5px; width:0;
  background:var(--terra); transition:width .25s ease;
}
.nav-links a:hover, .nav-links a.active{ color:var(--ink); }
.nav-links a:hover::after, .nav-links a.active::after{ width:100%; }

/* Malé emoji u položek menu */
.nav-links a[href]::before, .mobile-menu a:not(.btn)[href]::before{
  margin-right:.4em; font-size:.92em; opacity:.95;
}
.nav-links a[href^="index"]::before, .mobile-menu a[href^="index"]::before{ content:"🏡"; }
.nav-links a[href^="o-vile"]::before, .mobile-menu a[href^="o-vile"]::before{ content:"🛋️"; }
.nav-links a[href^="galerie"]::before, .mobile-menu a[href^="galerie"]::before{ content:"📷"; }
.nav-links a[href^="cenik"]::before, .mobile-menu a[href^="cenik"]:not(.btn)::before{ content:"🗓️"; }
.nav-links a[href^="okoli"]::before, .mobile-menu a[href^="okoli"]::before{ content:"🧭"; }
.nav-links a[href^="kontakt"]::before, .mobile-menu a[href^="kontakt"]::before{ content:"✉️"; }
.nav-right{ display:flex; align-items:center; gap:1rem; margin-left:.4rem; }

/* Přepínač jazyků */
.lang{ display:flex; gap:.1rem; align-items:center; font-size:.8rem; font-weight:700; letter-spacing:.06em; }
.lang button{
  background:none; border:0; cursor:pointer; color:var(--ink-mute);
  padding:.25em .4em; border-radius:6px; font:inherit; transition:color .2s, background .2s;
}
.lang button:hover{ color:var(--ink); }
.lang button.on{ color:var(--green); }
.lang .sep{ color:var(--line); }

.nav-toggle{ display:none; }
.mobile-menu{ display:none; }

/* Hero --------------------------------------------------- */
.hero{ position:relative; min-height:clamp(560px, 88vh, 880px); display:flex; align-items:flex-end; overflow:hidden; }
.hero-media{ position:absolute; inset:0; background:linear-gradient(155deg,#3a4836,#2b2620 70%); }
.hero-media img{ width:100%; height:100%; object-fit:cover; }
.hero::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(20,17,13,.66) 0%, rgba(20,17,13,.34) 40%, rgba(20,17,13,0) 72%),
    linear-gradient(180deg, rgba(20,17,13,.30) 0%, rgba(20,17,13,0) 32%, rgba(20,17,13,.55) 100%);
  pointer-events:none;
}
.hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(48px,7vw,90px); padding-top:120px; color:#fff; }
.hero h1{ color:#fff; max-width:none; line-height:1.1; margin-bottom:1.3rem; text-wrap:normal; }
.hero h1 span{ display:block; }
.hero h1 .accent{ font-style:italic; color:#ecc6a0; font-weight:500; }
.hero .lead{ color:rgba(255,255,255,.92); max-width:38ch; margin:0; }
.hero-tag{
  display:inline-flex; gap:.8rem; align-items:center; flex-wrap:wrap;
  font-size:.82rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(255,255,255,.92); margin-bottom:1.4rem;
}
.hero-tag .pip{ width:5px;height:5px;border-radius:50%;background:var(--terra); }
.hero-cta{ display:flex; gap:.9rem; flex-wrap:wrap; margin-top:1.9rem; }

/* Fakta strip ------------------------------------------- */
.facts{
  display:grid; grid-template-columns:repeat(6,1fr);
  border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; background:var(--card);
}
.fact{ padding:1.5rem 1rem; text-align:center; border-right:1px solid var(--line-soft); }
.fact:last-child{ border-right:0; }
.fact .n{ font-family:var(--serif); font-size:2rem; line-height:1; color:var(--green); }
.fact .l{ font-size:.78rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--ink-mute); margin-top:.5rem; }

/* Pilíře (Co na vás čeká) ------------------------------- */
.pillars{ display:grid; gap:clamp(48px,6vw,90px); }
.pillar{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,70px); align-items:center; }
.pillar:nth-child(even) .pillar-media{ order:2; }
.pillar-media img{ width:100%; aspect-ratio:4/3.2; object-fit:cover; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.pillar-num{ font-family:var(--serif); font-size:1.1rem; color:var(--terra); letter-spacing:.1em; margin-bottom:.8rem; }
.pillar h3{ margin-bottom:.7rem; }
.pillar ul{ list-style:none; margin:1.2rem 0 0; padding:0; display:flex; flex-wrap:wrap; gap:.5rem; }
.pillar ul li{ font-size:.82rem; font-weight:600; color:var(--ink-soft); background:var(--green-soft); padding:.4em .9em; border-radius:100px; }

/* Karta / grid 3 ---------------------------------------- */
.grid-3{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,30px); }
.grid-2{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(24px,4vw,60px); align-items:center; }
.card{
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:2rem; box-shadow:var(--shadow-soft);
}
.feature .idx{ font-family:var(--serif); font-size:2.4rem; color:var(--terra); line-height:1; }
.feature h3{ margin:.7rem 0 .5rem; }
.feature p{ color:var(--ink-soft); font-size:.98rem; margin:0; }

/* Galerie mřížka ---------------------------------------- */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); grid-auto-rows:200px; gap:14px; }
.gallery-grid image-slot{ width:100%; height:100%; border-radius:12px; box-shadow:var(--shadow-soft); }
.g-tall{ grid-row:span 2; }
.g-wide{ grid-column:span 2; }

/* Recenze ----------------------------------------------- */
.reviews{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
.review{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:2rem; }
.stars{ color:var(--terra); letter-spacing:.15em; font-size:.95rem; margin-bottom:.9rem; }
.review p{ font-family:var(--serif); font-size:1.22rem; line-height:1.45; color:var(--ink); }
.review .who{ font-family:var(--sans); font-size:.85rem; font-weight:700; color:var(--ink-soft); margin-top:1.1rem; }
.review .who span{ color:var(--ink-mute); font-weight:600; }

/* CTA band ---------------------------------------------- */
.cta-band{ text-align:center; }
.cta-band h2{ max-width:18ch; margin:0 auto 1rem; }
.cta-band .lead{ max-width:48ch; margin:0 auto 2rem; }
.cta-row{ display:flex; gap:.9rem; justify-content:center; flex-wrap:wrap; }

/* Story -------------------------------------------------- */
.story-media img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.signature{ font-family:var(--serif); font-style:italic; font-size:1.5rem; color:var(--terra); margin-top:1rem; }

/* Footer ------------------------------------------------- */
.site-footer{ background:var(--bg-ink); color:#cabfae; padding-block:clamp(56px,7vw,88px) 36px; }
.site-footer a{ color:#cabfae; }
.site-footer a:hover{ color:#fff; }
.foot-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1.2fr; gap:clamp(24px,4vw,48px); }
.foot-brand .brand{ color:#fbf6ec; font-size:2rem; }
.foot-brand p{ color:#a89e8f; max-width:34ch; margin-top:1rem; font-size:.95rem; }
.foot-col h4{ font-family:var(--sans); font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:#8c8377; margin-bottom:1rem; }
.foot-col ul{ list-style:none; margin:0; padding:0; display:grid; gap:.6rem; font-size:.95rem; }
.foot-bottom{ display:flex; justify-content:space-between; flex-wrap:wrap; gap:1rem; margin-top:clamp(40px,5vw,64px); padding-top:24px; border-top:1px solid rgba(255,255,255,.1); font-size:.82rem; color:#8c8377; }

/* Pomocné labely pro placeholdery ------------------------ */
image-slot{ --slot-bg:#ece3d2; }

/* Scroll reveal ----------------------------------------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s cubic-bezier(.2,.7,.2,1); }
.reveal.in{ opacity:1; transform:none; }
.reveal.d1{ transition-delay:.08s; } .reveal.d2{ transition-delay:.16s; } .reveal.d3{ transition-delay:.24s; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion:reduce){ .reveal{ opacity:1; transform:none; } html{ scroll-behavior:auto; } }

/* Sekce nadpis ------------------------------------------ */
.sec-head{ max-width:680px; margin-bottom:clamp(36px,5vw,64px); }
.sec-head.center{ margin-inline:auto; }

/* Ikony -------------------------------------------------- */
.ic{ width:1em; height:1em; display:inline-block; vertical-align:middle; fill:none; stroke:currentColor; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.fact .fact-ic{ display:block; width:24px; height:24px; margin:0 auto .55rem; color:var(--green); stroke-width:1.6; }
.pillar-num{ display:inline-flex; align-items:center; gap:.5rem; }
.pillar-num .ic{ width:19px; height:19px; color:var(--terra); }
.amenity-num{ display:inline-flex; align-items:center; gap:.45rem; }
.amenity-num .ic{ width:18px; height:18px; color:var(--terra); }
.chip .ic{ width:16px; height:16px; color:var(--green); margin-right:.15rem; }
.chip{ display:inline-flex; align-items:center; gap:.1rem; }

/* Mobil -------------------------------------------------- */
@media (max-width:920px){
  .facts{ grid-template-columns:repeat(3,1fr); }
  .fact:nth-child(3){ border-right:0; }
  .fact{ border-bottom:1px solid var(--line-soft); }
  .grid-3, .reviews{ grid-template-columns:1fr 1fr; }
  .pillar{ grid-template-columns:1fr; }
  .pillar:nth-child(even) .pillar-media{ order:0; }
  .grid-2{ grid-template-columns:1fr; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .foot-grid{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  body{ font-size:16px; }
  .nav-links{ display:none; }
  .nav-toggle{
    display:inline-flex; margin-left:auto; flex-direction:column; gap:5px;
    background:none; border:0; cursor:pointer; padding:8px;
  }
  .nav-toggle span{ width:24px; height:2px; background:var(--ink); border-radius:2px; transition:.3s; }
  .nav.open .nav-toggle span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
  .nav.open .nav-toggle span:nth-child(2){ opacity:0; }
  .nav.open .nav-toggle span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }
  .mobile-menu{
    position:fixed; inset:74px 0 auto 0; background:var(--bg); z-index:55;
    border-bottom:1px solid var(--line); padding:1rem var(--gutter) 1.6rem;
    display:none; flex-direction:column; gap:.2rem; box-shadow:var(--shadow);
  }
  .mobile-menu.open{ display:flex; }
  .mobile-menu a{ padding:.85rem 0; font-size:1.1rem; font-weight:600; border-bottom:1px solid var(--line-soft); }
  .mobile-menu .btn{ margin-top:1rem; justify-content:center; }
  .facts{ grid-template-columns:repeat(2,1fr); }
  .fact:nth-child(2){ border-right:0; }
  .grid-3, .reviews, .foot-grid, .gallery-grid{ grid-template-columns:1fr; }
  .hero-cta{ flex-direction:column; align-items:stretch; }
  .hero-cta .btn{ justify-content:center; }
  .cta-row{ flex-direction:column; }
  .foot-bottom{ flex-direction:column; }
}

/* ============================================================
   PODSTRÁNKY — komponenty
   ============================================================ */

/* Page hero (kompaktní hlavička stránky) */
.page-hero{ position:relative; padding:clamp(110px,16vw,180px) 0 clamp(48px,7vw,84px); background:var(--bg-deep); overflow:hidden; }
.page-hero .eyebrow{ margin-bottom:1.2rem; }
.page-hero h1{ max-width:18ch; text-wrap:normal; }
.page-hero p{ max-width:54ch; color:var(--ink-soft); font-size:1.1rem; margin-top:1.2rem; }
.page-hero.media{ background:var(--bg-ink); color:#ece4d6; }
.page-hero.media h1{ color:#fbf6ec; }

/* Breadcrumb */
.crumb{ font-size:.82rem; color:var(--ink-mute); margin-bottom:1.4rem; letter-spacing:.04em; }
.crumb a:hover{ color:var(--terra); }

/* Vybavení — sloupce */
.amenity-block{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,64px); align-items:start; }
.amenity-block.rev .amenity-media{ order:2; }
.amenity-media image-slot{ width:100%; aspect-ratio:5/4; border-radius:var(--radius-lg); box-shadow:var(--shadow); }
.amenity-list{ list-style:none; margin:1.4rem 0 0; padding:0; display:grid; gap:.85rem; }
.amenity-list li{ display:flex; gap:.8rem; align-items:baseline; font-size:1rem; color:var(--ink-soft); }
.amenity-list li::before{ content:""; flex:none; width:7px; height:7px; margin-top:.45em; border-radius:2px; background:var(--terra); transform:rotate(45deg); }
.amenity-num{ font-family:var(--serif); color:var(--terra); font-size:1.1rem; letter-spacing:.1em; margin-bottom:.6rem; }

/* Čipsy vybavení */
.chips{ display:flex; flex-wrap:wrap; gap:.6rem; }
.chip{ font-size:.85rem; font-weight:600; color:var(--ink-soft); background:var(--card); border:1px solid var(--line); padding:.5em 1em; border-radius:100px; }

/* Seznam „Šťastno to je" */
.essence{ display:grid; grid-template-columns:repeat(2,1fr); gap:1px; background:var(--line); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; }
.essence-item{ background:var(--card); padding:1.8rem; display:flex; gap:1rem; align-items:flex-start; }
.essence-item .e-num{ font-family:var(--serif); font-size:1.6rem; color:var(--terra); line-height:1; flex:none; }
.essence-item h4{ font-family:var(--serif); font-size:1.3rem; margin:0 0 .3rem; }
.essence-item p{ margin:0; font-size:.95rem; color:var(--ink-soft); }

/* Ceník */
.price-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(20px,3vw,32px); }
.price-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:2.4rem; display:flex; flex-direction:column; box-shadow:var(--shadow-soft); }
.price-card.feature{ background:var(--bg-ink); color:#ece4d6; border-color:transparent; }
.price-card.feature h3{ color:#fbf6ec; }
.price-card .ptag{ font-size:.76rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--terra); margin-bottom:1rem; }
.price-card.feature .ptag{ color:#d8b79f; }
.price-card .amount{ font-family:var(--serif); font-size:3rem; line-height:1; margin:.4rem 0 .2rem; }
.price-card .per{ font-size:.95rem; color:var(--ink-mute); }
.price-card.feature .per{ color:#a89e8f; }
.price-card ul{ list-style:none; margin:1.6rem 0 1.8rem; padding:0; display:grid; gap:.7rem; font-size:.95rem; }
.price-card ul li{ display:flex; gap:.7rem; align-items:baseline; }
.price-card ul li::before{ content:"—"; color:var(--terra); }
.price-card .btn{ margin-top:auto; justify-content:center; }
.price-note{ font-size:.9rem; color:var(--ink-mute); }

/* Kalendář dostupnosti */
.cal-wrap{ display:grid; grid-template-columns:repeat(2,1fr); gap:clamp(20px,3vw,30px); }
.cal{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:1.6rem; }
.cal h4{ font-family:var(--sans); font-size:.95rem; font-weight:800; letter-spacing:.02em; text-transform:capitalize; margin:0 0 1rem; display:flex; justify-content:space-between; }
.cal-grid{ display:grid; grid-template-columns:repeat(7,1fr); gap:5px; }
.cal-grid .dow{ font-size:.7rem; font-weight:700; text-transform:uppercase; color:var(--ink-mute); text-align:center; padding-bottom:.3rem; }
.cal-day{ aspect-ratio:1; display:flex; align-items:center; justify-content:center; font-size:.82rem; border-radius:8px; color:var(--ink-soft); }
.cal-day.free{ background:var(--green-soft); color:var(--green-d); font-weight:600; }
.cal-day.booked{ background:#f0e2da; color:#b98e78; text-decoration:line-through; }
.cal-day.empty{ visibility:hidden; }
.cal-legend{ display:flex; gap:1.4rem; flex-wrap:wrap; font-size:.85rem; color:var(--ink-soft); margin-top:1.4rem; }
.cal-legend span{ display:inline-flex; align-items:center; gap:.5rem; }
.cal-legend .sw{ width:14px; height:14px; border-radius:4px; }
.embed-note{ border:1px dashed var(--line); border-radius:var(--radius); padding:1.4rem 1.6rem; background:#fff; font-size:.92rem; color:var(--ink-soft); }
.embed-note strong{ color:var(--ink); }

/* FAQ */
.faq{ max-width:820px; margin:0 auto; border-top:1px solid var(--line); }
.faq details{ border-bottom:1px solid var(--line); }
.faq summary{ cursor:pointer; list-style:none; padding:1.4rem 0; font-family:var(--serif); font-size:1.3rem; color:var(--ink); display:flex; justify-content:space-between; align-items:center; gap:1rem; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary .ico{ flex:none; width:24px; height:24px; position:relative; transition:transform .3s; }
.faq summary .ico::before, .faq summary .ico::after{ content:""; position:absolute; background:var(--terra); border-radius:2px; }
.faq summary .ico::before{ top:50%; left:3px; right:3px; height:2px; transform:translateY(-50%); }
.faq summary .ico::after{ left:50%; top:3px; bottom:3px; width:2px; transform:translateX(-50%); transition:opacity .3s; }
.faq details[open] summary .ico::after{ opacity:0; }
.faq details[open] summary .ico{ transform:rotate(180deg); }
.faq .ans{ padding:0 0 1.5rem; color:var(--ink-soft); max-width:64ch; }
.faq .ans p{ margin:0; }

/* Formulář */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,5vw,60px); align-items:start; }
.field{ display:flex; flex-direction:column; gap:.4rem; margin-bottom:1.1rem; }
.field.row2{ display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label{ font-size:.82rem; font-weight:700; letter-spacing:.04em; color:var(--ink-soft); }
.field input, .field select, .field textarea{
  font-family:var(--sans); font-size:1rem; color:var(--ink);
  background:var(--card); border:1px solid var(--line); border-radius:10px; padding:.85em 1em;
  transition:border-color .2s, box-shadow .2s; width:100%;
}
.field textarea{ resize:vertical; min-height:120px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--green); box-shadow:0 0 0 3px var(--green-soft); }
.form-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.6rem,3vw,2.4rem); box-shadow:var(--shadow-soft); }
.form-success{ display:none; background:var(--green-soft); border:1px solid var(--green); color:var(--green-d); border-radius:12px; padding:1.2rem 1.4rem; font-weight:600; margin-bottom:1.2rem; }
.contact-list{ list-style:none; margin:0; padding:0; display:grid; gap:1.4rem; }
.contact-list li{ display:grid; gap:.2rem; }
.contact-list .k{ font-size:.78rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--ink-mute); }
.contact-list .v{ font-size:1.15rem; font-family:var(--serif); }
.contact-list .v a:hover{ color:var(--terra); }

/* Karty atrakcí */
.attractions{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,28px); }
.attraction{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-soft); display:flex; flex-direction:column; }
.attraction image-slot{ width:100%; height:200px; }
.attraction .body{ padding:1.5rem 1.6rem 1.8rem; }
.attraction .dist{ font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--terra); }
.attraction h3{ font-size:1.4rem; margin:.5rem 0 .5rem; }
.attraction p{ font-size:.95rem; color:var(--ink-soft); margin:0; }

/* Galerie kategorie */
.gal-cat{ margin-bottom:clamp(40px,5vw,72px); }
.gal-cat h2{ margin-bottom:1.6rem; }
.map-embed{ width:100%; border:0; border-radius:var(--radius-lg); box-shadow:var(--shadow-soft); min-height:380px; display:block; }

@media (max-width:920px){
  .amenity-block{ grid-template-columns:1fr; }
  .amenity-block.rev .amenity-media{ order:0; }
  .price-grid, .cal-wrap, .form-grid, .essence{ grid-template-columns:1fr; }
  .attractions{ grid-template-columns:1fr 1fr; }
}
@media (max-width:680px){
  .attractions{ grid-template-columns:1fr; }
  .field.row2{ grid-template-columns:1fr; }
}

/* Rezervace — interaktivní kalendář ---------------------- */
.booking{ display:grid; grid-template-columns:1.25fr 1fr; gap:clamp(20px,3vw,34px); align-items:start; }
.booking-cal{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(1.1rem,2.4vw,1.6rem); box-shadow:var(--shadow-soft); }
.cal-nav{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1rem; }
.cal-nav span{ font-family:var(--serif); font-size:1.35rem; text-transform:capitalize; }
.cal-nav button{ width:42px; height:42px; border-radius:11px; border:1px solid var(--line); background:#fff; font-size:1.3rem; line-height:1; cursor:pointer; color:var(--ink); transition:.2s; }
.cal-nav button:hover{ background:var(--green-soft); border-color:var(--green); }
.cal-nav button:disabled{ opacity:.3; cursor:default; background:#fff; border-color:var(--line); }
.booking .cal-day.free{ cursor:pointer; }
.booking .cal-day.free:hover{ background:var(--green); color:#fff; }
.booking .cal-day.inrange{ background:var(--green-soft); color:var(--green-d); border-radius:0; text-decoration:none; }
.booking .cal-day.sel{ background:var(--green); color:#fff; font-weight:700; text-decoration:none; }
.booking .cal-day.booked{ cursor:default; }
.booking .cal-day.locked{ color:#c3b8a8; cursor:not-allowed; opacity:.5; text-decoration:line-through; text-decoration-thickness:1px; }
.booking .cal-day.locked.inrange{ color:var(--green-d); opacity:1; text-decoration:none; }
.booking-summary{ background:var(--bg-ink); color:#ece4d6; border-radius:var(--radius-lg); padding:clamp(1.4rem,2.6vw,1.9rem); position:sticky; top:90px; box-shadow:var(--shadow); }
.booking-summary h3{ color:#fff; margin-bottom:1.1rem; }
.bs-row{ display:flex; justify-content:space-between; gap:1rem; padding:.6rem 0; border-bottom:1px solid rgba(255,255,255,.1); font-size:.95rem; color:#cabfae; }
.bs-row strong{ color:#fff; font-weight:700; }
.bs-field{ margin:1.1rem 0 0; display:flex; flex-direction:column; gap:.45rem; }
.bs-field label{ font-size:.78rem; letter-spacing:.06em; text-transform:uppercase; color:#a89e8f; }
.bs-field select{ background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.2); color:#fff; border-radius:10px; padding:.7em 1em; font-family:var(--sans); font-size:1rem; }
.bs-total{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; margin:1.3rem 0 .3rem; padding-top:1rem; border-top:1px solid rgba(255,255,255,.16); }
.bs-total span{ color:#cabfae; }
.bs-total strong{ font-family:var(--serif); font-size:1.9rem; color:#fff; }
.bs-note{ font-size:.85rem; color:#d8b79f; min-height:1.1em; margin:0 0 1.2rem; }
@media (max-width:920px){ .booking{ grid-template-columns:1fr; } .booking-summary{ position:static; } }

/* Ceník — info (úklid, check-in/out) */
.price-info{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(14px,2vw,20px); margin-top:1.8rem; }
.price-info .pi{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:1.3rem 1.4rem; }
.price-info .pi-k{ display:block; font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--terra); }
.price-info .pi-v{ display:block; font-family:var(--serif); font-size:1.5rem; margin:.3rem 0 .2rem; }
.price-info .pi-d{ display:block; font-size:.86rem; color:var(--ink-mute); }
@media (max-width:760px){ .price-info{ grid-template-columns:1fr; } }

/* Koláž fotek v amenity blocích */
.collage{ display:grid; grid-template-columns:1fr 1fr; gap:10px; align-items:stretch; }
.collage img{ width:100%; object-fit:cover; border-radius:14px; display:block; box-shadow:var(--shadow-soft); }
.collage .c-big{ grid-column:1 / -1; height:clamp(190px,25vw,250px); }
.collage .c-sm{ height:clamp(115px,15vw,150px); }

/* Logo mark (domeček + slunce) */
.brand{ align-items:center; }
.brand-mark{ width:1.5em; height:1.5em; flex:none; display:inline-block; }
.foot-brand .brand-mark{ width:1.35em; height:1.35em; }

/* Page-hero s velkou fotkou */
.page-hero.photo{ color:#fff; }
.page-hero.photo .page-hero-bg{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:0; }
.page-hero.photo::after{ content:""; position:absolute; inset:0; z-index:1; background:linear-gradient(90deg, rgba(20,17,13,.78), rgba(20,17,13,.40) 58%, rgba(20,17,13,.12)); }
.page-hero.photo .wrap{ position:relative; z-index:2; }
.page-hero.photo h1{ color:#fff; }
.page-hero.photo p{ color:rgba(255,255,255,.92); }
.page-hero.photo .crumb{ color:rgba(255,255,255,.8); }
.page-hero.photo .crumb a:hover{ color:#fff; }
.page-hero.photo .eyebrow{ color:#e8c6a0; }

/* Galerie — reálné fotky + lightbox */
.gallery-grid img{ width:100%; height:100%; object-fit:cover; border-radius:12px; box-shadow:var(--shadow-soft); display:block; cursor:zoom-in; transition:transform .3s ease, filter .3s ease; }
.gallery-grid img:hover{ filter:brightness(1.04); transform:scale(1.01); }
.lightbox{ position:fixed; inset:0; z-index:200; background:rgba(20,17,13,.93); display:none; align-items:center; justify-content:center; padding:24px; cursor:zoom-out; }
.lightbox.on{ display:flex; }
.lightbox img{ max-width:95%; max-height:92%; border-radius:10px; box-shadow:0 24px 70px rgba(0,0,0,.55); }

/* Výletní karty v galerii */
.trip{ display:block; transition:transform .25s ease, border-color .25s ease; overflow:hidden; }
a.trip:hover{ border-color:var(--terra); transform:translateY(-3px); }
.trip-thumb{ margin:-2rem -2rem 1.3rem; height:118px; border-radius:var(--radius-lg) var(--radius-lg) 0 0; display:flex; align-items:center; justify-content:center; font-size:3.1rem; line-height:1; }
.attraction-thumb{ width:100%; height:200px; display:flex; align-items:center; justify-content:center; font-size:4rem; line-height:1; }
.trip .dist{ font-size:.76rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:var(--terra); }
.trip h3{ font-size:1.4rem; margin:.5rem 0 .5rem; }
.trip p{ font-size:.95rem; color:var(--ink-soft); margin:0 0 1rem; }

