/* ============================================================
   stralka.cz — main stylesheet (varianta-b port)
   Teplá editorialní / organická. Topbar + light sticky header,
   arch hero, číslované kategorie, dark visit band.
   Sloučeno z _designsource/assets/tokens.css + varianta-b.html
   inline <style>. Vanilla CSS, žádný framework, žádný preprocessor.
   ============================================================ */
/* ---------- 0. Local fonts (self-hosted, latin + latin-ext) ---------- */
/* Archivo — nadpisy */
@font-face{ font-family:'Archivo'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/archivo-v25-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face{ font-family:'Archivo'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/archivo-v25-latin_latin-ext-500.woff2') format('woff2'); }
@font-face{ font-family:'Archivo'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/archivo-v25-latin_latin-ext-600.woff2') format('woff2'); }
@font-face{ font-family:'Archivo'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/archivo-v25-latin_latin-ext-700.woff2') format('woff2'); }
@font-face{ font-family:'Archivo'; font-style:normal; font-weight:800; font-display:swap; src:url('../fonts/archivo-v25-latin_latin-ext-800.woff2') format('woff2'); }

/* League Spartan — body */
@font-face{ font-family:'League Spartan'; font-style:normal; font-weight:400; font-display:swap; src:url('../fonts/league-spartan-v15-latin_latin-ext-regular.woff2') format('woff2'); }
@font-face{ font-family:'League Spartan'; font-style:normal; font-weight:500; font-display:swap; src:url('../fonts/league-spartan-v15-latin_latin-ext-500.woff2') format('woff2'); }
@font-face{ font-family:'League Spartan'; font-style:normal; font-weight:600; font-display:swap; src:url('../fonts/league-spartan-v15-latin_latin-ext-600.woff2') format('woff2'); }
@font-face{ font-family:'League Spartan'; font-style:normal; font-weight:700; font-display:swap; src:url('../fonts/league-spartan-v15-latin_latin-ext-700.woff2') format('woff2'); }

/* ---------- 1. Design tokens ---------- */
:root{
  /* neutrály – světle zelené pozadí */
  --paper:      #EEF5EF;
  --paper-2:    #E0EDE2;
  --card:       #FFFFFF;
  --ink:        #1F261C;
  --ink-soft:   #515A49;
  --ink-faint:  #8A9180;
  --line:       #D5E4D8;
  --line-soft:  #E4F0E6;

  /* zelená – hlavní */
  --green:        #0f9146;
  --green-deep:   #0a5e2d;
  --green-bright: #8bbf95;
  --green-tint:   #DFECDF;
  --green-tint-2: #C7DECC;

  /* žlutá / gold – akcent */
  --accent:      #c9a84e;
  --accent-deep: #907419;
  --accent-tint: #FFDE82;

  /* doplňkové zemité */
  --wheat:  #c9a84e;
  --soil:   #907419;

  /* systém */
  --radius:    16px;
  --radius-lg: 26px;
  --radius-sm: 10px;
  --shadow:    0 1px 2px rgba(31,38,28,.04), 0 12px 30px -16px rgba(31,38,28,.22);
  --shadow-lg: 0 2px 4px rgba(31,38,28,.05), 0 30px 60px -28px rgba(31,38,28,.32);
  --maxw: 1460px;
  --ease: cubic-bezier(.2,.7,.2,1);

  --font-head: 'Archivo', system-ui, sans-serif;
  --font-body: 'League Spartan', system-ui, sans-serif;
}

/* ---------- 2. Base + reset ---------- */
*{ box-sizing:border-box; }
html{ -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--font-body); font-size:18px; line-height:1.62;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
h1,h2,h3,h4{ font-family:var(--font-head); font-weight:700; line-height:1.04; margin:0; letter-spacing:-.01em; }
p{ margin:0; text-wrap:pretty; }
ul{ margin:0; padding:0; list-style:none; }
button{ font:inherit; cursor:pointer; }

/* skip-link + viditelný klávesnicový fokus */
.skip-link{ position:absolute; left:-9999px; top:auto; }
.skip-link:focus{ left:16px; top:16px; z-index:999; background:var(--green); color:#fff;
  padding:10px 18px; border-radius:10px; font-family:var(--font-head); font-weight:700;
  box-shadow:var(--shadow-lg); }
:focus-visible{ outline:2px solid var(--green); outline-offset:2px; border-radius:2px; }

/* vizuálně skrytý text (pro čtečky — osnova nadpisů, štítky) */
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0 0 0 0); clip-path:inset(50%); white-space:nowrap; border:0; }

.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:28px; }

/* ---------- 3. Atomy (eyebrow, btn, ph placeholder) ---------- */
.eyebrow{
  font-family:var(--font-head); font-weight:700; font-size:13px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--green);
  display:inline-flex; align-items:center; gap:9px;
}
.eyebrow::before{ content:""; width:22px; height:2px; background:var(--accent); border-radius:2px; }
.accent-text{ color:var(--accent); }
.muted{ color:var(--ink-soft); }

.btn{
  display:inline-flex; align-items:center; gap:10px; cursor:pointer;
  font-family:var(--font-head); font-weight:600; font-size:15.5px;
  padding:14px 24px; border-radius:999px; border:1.5px solid transparent;
  transition:transform .25s var(--ease), background .25s var(--ease), box-shadow .25s var(--ease), color .25s var(--ease);
  white-space:nowrap;
}
.btn svg{ width:18px; height:18px; }
.btn-primary{ background:var(--green); color:#fff; }
.btn-primary:hover{ background:var(--green-deep); transform:translateY(-2px); box-shadow:0 14px 26px -12px rgba(28,74,43,.6); }
.btn-accent{ background:var(--accent); color:#fff; }
.btn-accent:hover{ background:var(--accent-deep); transform:translateY(-2px); box-shadow:0 14px 26px -12px rgba(189,63,18,.55); }
.btn-ghost{ background:transparent; color:var(--green); border-color:var(--green-tint-2); }
.btn-ghost:hover{ background:var(--green-tint); border-color:var(--green); transform:translateY(-2px); }
.btn-light{ background:#fff; color:var(--green); }
.btn-light:hover{ transform:translateY(-2px); box-shadow:0 14px 26px -12px rgba(0,0,0,.35); }
.btn-outline-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.4); }
.btn-outline-light:hover{ background:rgba(255,255,255,.1); border-color:#fff; transform:translateY(-2px); }

.ph{
  position:relative; overflow:hidden; background:var(--green-tint);
  background-image:repeating-linear-gradient(135deg,
    rgba(44,107,63,.07) 0 12px, rgba(44,107,63,0) 12px 24px);
  display:flex; align-items:center; justify-content:center; color:var(--green);
}
.ph::after{
  content:attr(data-label);
  font-family:ui-monospace,'SF Mono',Menlo,Consolas,monospace;
  font-size:11.5px; letter-spacing:.06em; text-transform:uppercase;
  color:var(--green); opacity:.72; padding:6px 12px;
  border:1px dashed rgba(44,107,63,.4); border-radius:999px;
  background:rgba(255,255,255,.5); text-align:center; max-width:80%;
}
.ph.warm{ background:var(--accent-tint);
  background-image:repeating-linear-gradient(135deg,
    rgba(224,83,31,.08) 0 12px, rgba(224,83,31,0) 12px 24px); color:var(--accent-deep); }
.ph.warm::after{ color:var(--accent-deep); border-color:rgba(224,83,31,.4); }

/* ---------- 4. Open badge ---------- */
.open-badge{
  display:inline-flex; align-items:center; gap:9px;
  font-family:var(--font-body); font-weight:600; font-size:14px;
  padding:8px 15px 8px 13px; border-radius:999px;
  background:var(--green-tint); color:var(--green-deep);
  border:1px solid var(--green-tint-2);
}
.open-badge .dot{ width:9px; height:9px; border-radius:50%; background:var(--green-bright);
  box-shadow:0 0 0 0 rgba(79,161,90,.6); animation:pulse 2.4s infinite; }
.open-badge.closed{ background:var(--accent-tint); color:var(--accent-deep); border-color:#f0cdbd; }
.open-badge.closed .dot{ background:var(--accent); animation:none; box-shadow:none; }
@keyframes pulse{ 0%{box-shadow:0 0 0 0 rgba(79,161,90,.55)} 70%{box-shadow:0 0 0 8px rgba(79,161,90,0)} 100%{box-shadow:0 0 0 0 rgba(79,161,90,0)} }

/* ---------- 5. Reveal animace ---------- */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s var(--ease), transform .7s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal.shown{ opacity:1 !important; transform:none !important; transition:none !important; }
.no-js .reveal{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .open-badge .dot{animation:none}
  html{scroll-behavior:auto}
  /* hover transformy, zoom galerie a lightbox bez pohybu */
  .pillar, .v-hl, .s-card, .news-item, .btn,
  .gallery-2row .g-item img, .gallery-grid .gg-item img,
  .lightbox, .lightbox-img{ transition:none; }
  .pillar:hover, .v-hl:hover, .s-card:hover, .btn:hover{ transform:none; }
  .gallery-2row .g-item:hover img, .gallery-grid .gg-item:hover img{ transform:none; }
}

/* ---------- 6. Topbar (utility) ---------- */
.topbar{ background:var(--green-deep); color:#cfdfc8; font-size:13.5px; }
.topbar-inner{ display:flex; align-items:center; justify-content:space-between; height:28px; gap:18px; }
.topbar-inner .l{ display:flex; align-items:center; gap:16px; }
.topbar-inner .r{ display:flex; align-items:center; gap:20px; }
.topbar a{ color:#dfe9da; display:inline-flex; align-items:center; gap:7px; }
.topbar a:hover{ color:#fff; }
.topbar svg{ width:14px; height:14px; }
.topbar .open-badge{ background:transparent; border:none; color:#bfe3b1; padding:0; font-size:13.5px; }
.topbar .open-badge.closed{ background:transparent; color:#f2b59c; }

/* ---------- 7. Header (light sticky) ---------- */
.site-header{ position:sticky; top:0; z-index:50; background:var(--paper); border-bottom:1px solid var(--line); }
.header-inner{ display:flex; align-items:center; gap:24px; height:74px; }
.brand{ display:flex; align-items:center; gap:12px; }
.brand img{ height:68px; }
.brand b{ font-family:var(--font-body); font-weight:600; font-size:19px; color:var(--green); letter-spacing:-.01em; }
.brand .brand-name .i{ font-weight:800; font-size:1.18em; color:var(--accent); }
.brand small{ display:block; font-size:11px; letter-spacing:.14em; text-transform:uppercase; color:var(--ink-faint); line-height:1; }
.main-nav{ display:flex; gap:2px; margin-left:auto; }
.main-nav a{ font-family:var(--font-body); font-weight:600; font-size:16px; text-transform:uppercase; letter-spacing:.04em; padding:10px 14px; border-radius:10px; color:var(--ink); position:relative; }
.main-nav a::after{ content:""; position:absolute; left:14px; right:14px; bottom:6px; height:2px; background:var(--accent); border-radius:2px; transform:scaleX(0); transform-origin:left; transition:transform .25s var(--ease); }
.main-nav a:hover::after, .main-nav a:focus-visible::after, .main-nav a.is-active::after, .main-nav a[aria-current="page"]::after{ transform:scaleX(1); }
.burger{ display:none; width:46px; height:46px; border-radius:12px; border:1px solid var(--line); background:var(--card); cursor:pointer; flex-direction:column; align-items:center; justify-content:center; gap:5px; }
.burger span{ width:20px; height:2px; background:var(--ink); border-radius:2px; }

/* ---------- 8. Mobilní menu (drawer, light) ---------- */
.mnav{ position:fixed; inset:0; z-index:90; background:var(--paper); padding:24px; transform:translateX(100%); transition:transform .35s var(--ease); }
.mnav.open{ transform:none; }
.mnav .mnav-top{ display:flex; justify-content:flex-end; align-items:center; margin-bottom:30px; }
.mnav .mnav-wordmark{ font-family:var(--font-body); font-weight:800; color:var(--green); font-size:18px; }
.mnav .mnav-close{ width:46px; height:46px; border:1px solid var(--line); border-radius:12px; background:var(--card); font-size:32px; line-height:1; cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--ink); }
.mnav a{ display:block; font-family:var(--font-body); font-weight:700; font-size:24px; padding:14px 0; border-bottom:1px solid var(--line); }

/* ---------- 9. HERO split (panel + foto + stat bar) ---------- */
.hero2{ display:grid; grid-template-columns:1fr 1fr; min-height:600px; background:var(--green-deep); }
.hero2-left{ position:relative; color:#fff; padding:clamp(48px,5vw,76px) clamp(28px,4vw,68px);
  display:flex; flex-direction:column; justify-content:center; align-items:flex-end; overflow:hidden; }
.hero2-left::before{ content:""; position:absolute; inset:0; opacity:.5;
  background:
    linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px) 0 0/100% 30px,
    linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px) 0 0/30px 100%;
  -webkit-mask-image:linear-gradient(90deg,#000 60%,transparent); mask-image:linear-gradient(90deg,#000 60%,transparent); }
.hero2-left::after{ content:""; position:absolute; right:-1px; top:0; bottom:0; width:1px;
  background:linear-gradient(180deg,transparent,var(--green-bright) 30%,var(--green-bright) 70%,transparent); }
.hero2-inner{ position:relative; max-width:575px; }
.hero2-kicker{ color:var(--accent-tint); }
.hero2-kicker::before{ background:var(--accent); }
.hero2 h1{ color:#fff; font-size:clamp(34px,4.4vw,60px); line-height:1.02; letter-spacing:-.02em; margin-top:22px; }
.hero2 h1 em{ font-style:normal; color:var(--accent-tint); }
.hero2 .lead{ color:#d6e6d8; font-size:clamp(17px,1.6vw,22px); line-height:1.5; margin-top:22px; max-width:46ch; }
.hero2-cta{ display:flex; gap:13px; margin-top:32px; flex-wrap:wrap; }
.hero2-left .corner{ position:absolute; width:14px; height:14px; border:2px solid rgba(139,191,149,.55); }
.hero2-left .corner.tl{ top:24px; left:24px; border-right:0; border-bottom:0; }
.hero2-left .corner.tr{ top:24px; right:24px; border-left:0; border-bottom:0; }
.hero2-left .corner.bl{ bottom:24px; left:24px; border-right:0; border-top:0; }
.hero2-left .corner.br{ bottom:24px; right:24px; border-left:0; border-top:0; }
.hero2-right{ position:relative; overflow:hidden; background:var(--green-deep); }
.hero2-photo{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:center; }
.hero2-shade{ position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,rgba(10,94,45,.30) 0%,rgba(10,94,45,0) 28%,rgba(10,94,45,0) 58%,rgba(10,94,45,.58) 100%); }
.hud{ position:absolute; z-index:2; }
.hud-spec{ left:28px; bottom:28px; right:28px; display:grid; grid-template-columns:repeat(3,1fr);
  border:1px solid rgba(255,255,255,.2); border-radius:10px; overflow:hidden; backdrop-filter:blur(4px); background:rgba(10,94,45,.42); }
.hud-spec .c{ padding:15px 18px; border-right:1px solid rgba(255,255,255,.16); text-align:center; }
.hud-spec .c:last-child{ border-right:0; }
.hud-spec a.c{ transition:background .2s var(--ease); }
.hud-spec a.c:hover{ background:rgba(255,255,255,.12); }
.hud-spec .c-shop .v{ display:inline-flex; align-items:center; gap:7px; color:var(--accent-tint); }
.hud-spec .c-shop .v svg{ width:17px; height:17px; }
.hud-spec .v{ font-family:var(--font-head); font-size:25px; font-weight:700; color:#fff; line-height:1; letter-spacing:-.01em; }
.hud-spec .l{ font-size:11px; letter-spacing:.07em; text-transform:uppercase; color:#bcd6bf; margin-top:7px; }

/* ---------- 10. Sezónní strip (wrapping grid, max 4/řádek) ---------- */
.season{ padding-block:clamp(28px,3.5vw,45px); background:var(--green-tint); }
.season-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:20px; margin-bottom:26px; }
.season-head h2{ font-size:clamp(26px,3.2vw,38px); margin-top:10px; }
.season-rail{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.s-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; transition:transform .25s var(--ease), box-shadow .25s; }
.s-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow); }
/* .media drží jednotný poměr 16/10 — obrázek libovolného poměru se ořízne (cover) */
.s-card .media{ aspect-ratio:16/10; overflow:hidden; }
.s-card .media img{ width:100%; height:100%; object-fit:cover; display:block; }
.s-card .media .ph{ width:100%; height:100%; }
.s-card .b{ padding:15px 17px 18px; }
.s-card .b b{ font-family:var(--font-head); font-size:19px; color:var(--green-deep); display:block; }
.s-card .b small{ color:var(--ink-soft); font-size:17px; }
.s-card .tag{ display:inline-block; font-family:var(--font-head); font-weight:700; font-size:11.5px; letter-spacing:.07em; text-transform:uppercase; color:var(--accent); margin-bottom:7px; }

/* ---------- 11. Sekce / section-head ---------- */
section.block{ padding-block:clamp(28px,3.5vw,45px); }
.section-head h2{ font-size:clamp(30px,4vw,48px); margin-top:12px; letter-spacing:-.02em; max-width:20ch; }
.section-head p{ color:var(--ink-soft); margin-top:14px; font-size:20px; }

/* ---------- 12. Kategorie — 3 pilíře DKZ (bílá karta + tráva) ---------- */
.cats{ background:var(--green-tint); }
.pillars{ display:grid; grid-template-columns:repeat(3,1fr);
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg);
  box-shadow:var(--shadow); overflow:hidden; }
.pillar{ padding:38px 34px 34px; border-right:1px solid var(--line);
  display:grid; grid-template-columns:auto 1fr; align-items:center; column-gap:20px;
  transition:background .25s var(--ease); }
.pillar:last-of-type{ border-right:0; }
.pillar:hover{ background:var(--paper); }
.pillar-ic{ display:inline-flex; width:74px; height:74px; border-radius:18px; background:var(--green-tint);
  align-items:center; justify-content:center; }
.pillar-ic img{ width:44px; height:44px; object-fit:contain; }
.pillar:hover .pillar-ic{ background:#fff; }
.pillar h3{ font-family:var(--font-head); font-weight:700; font-size:22px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--green); }
.pillar p{ grid-column:1/-1; color:var(--ink-soft); font-size:17.5px; margin-top:16px; }

/* ---------- 13. About — O naší prodejně (foto + bloky) ---------- */
.about-grid{ display:grid; grid-template-columns:minmax(260px,340px) 1fr; gap:56px; align-items:start; }
.about-visual{ position:sticky; top:100px; text-align:center; }
.about-photo{ position:relative; display:flex; justify-content:center; align-items:flex-end; }
.about-photo::before{ content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%);
  width:84%; aspect-ratio:1/1; border-radius:50%;
  background:radial-gradient(circle at 50% 45%, var(--green-tint-2), var(--green-tint)); z-index:0; }
.about-photo img{ position:relative; z-index:1; width:100%; display:block; }
.about-cta{ margin-top:26px; }
.about-title{ font-size:clamp(30px,3.4vw,44px); color:var(--accent-deep); margin-top:12px; letter-spacing:-.01em; }
.about-title .dkz{ color:var(--green); }
.about-title .sep{ color:var(--green-bright); font-weight:400; }
.about-blocks{ margin-top:26px; display:grid; gap:22px; }
.about-blocks .ab h3{ font-family:var(--font-head); font-weight:700; font-size:21px; color:var(--green); }
.about-blocks .ab p{ color:var(--ink-soft); font-size:18px; margin-top:8px; }
.about-gift{ font-size:18px; color:var(--soil); padding:16px 20px; background:var(--accent-tint);
  border-radius:var(--radius-sm); border:1px solid var(--wheat); }
.about-gift b{ font-family:var(--font-head); color:var(--accent-deep); }

/* ---------- 14. Empty state (galerie / sezónní bez položek) ---------- */
.news-empty{ color:var(--ink-soft); font-style:italic; padding:1rem 0; text-align:center; }

/* ---------- 15. Galerie (2 řady, střídavé šířky) ---------- */
.gallery-2row{ display:grid; grid-template-columns:repeat(12,1fr); grid-auto-rows:clamp(170px,18vw,250px); gap:14px; margin-top:42px; }
.gallery-2row .g-item{ margin:0; overflow:hidden; border-radius:16px; }
.gallery-2row .g-item img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.gallery-2row .g-item:hover img{ transform:scale(1.06); }
.gallery-2row .gw{ grid-column:span 4; }
.gallery-2row .gn{ grid-column:span 2; }

/* Lightbox */
.lightbox{ position:fixed; inset:0; z-index:200; display:flex; align-items:center; justify-content:center;
  padding:clamp(16px,4vw,48px); background:rgba(14,50,30,.38); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  opacity:0; visibility:hidden; transition:opacity .22s var(--ease), visibility .22s; }
.lightbox.open{ opacity:1; visibility:visible; }
.lightbox-img{ max-width:100%; max-height:100%; object-fit:contain; border-radius:10px;
  box-shadow:var(--shadow-lg); background:#fff; transform:scale(.97); transition:transform .22s var(--ease); }
.lightbox.open .lightbox-img{ transform:scale(1); }
.lightbox-close{ position:absolute; top:14px; right:20px; width:46px; height:46px; border:0; background:transparent;
  color:#fff; font-size:38px; line-height:1; cursor:pointer; opacity:.85; transition:opacity .15s; z-index:2; }
.lightbox-close:hover{ opacity:1; }
.lightbox-nav{ position:absolute; top:50%; transform:translateY(-50%); z-index:2; width:54px; height:54px; border:0;
  border-radius:50%; background:rgba(255,255,255,.14); color:#fff; font-size:32px; line-height:1; cursor:pointer;
  display:grid; place-items:center; transition:background .15s; }
.lightbox-nav:hover{ background:var(--accent); }
.lightbox-prev{ left:18px; }
.lightbox-next{ right:18px; }
.lightbox.is-single .lightbox-nav{ display:none; }
@media (max-width:560px){ .lightbox-nav{ width:44px; height:44px; font-size:26px; } }

/* ---------- 16. Visit (světlý zelený band) ---------- */
.visit{ background:var(--green-tint); color:var(--ink-soft); }
.visit .section-head h2{ color:var(--green-deep); }
.visit .section-head .eyebrow{ color:var(--green); }
.visit .section-head p{ color:var(--ink-soft); }
.visit-grid{ display:grid; grid-template-columns:1fr 1fr 1.2fr; gap:30px; margin-top:42px; }
.v-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:30px 28px; }
.v-card h3{ color:var(--green-deep); font-size:20px; display:flex; align-items:center; gap:10px; margin-bottom:16px; }
.v-card h3 svg{ width:20px; height:20px; color:var(--accent-deep); }
.v-card .hours-table{ width:100%; border-collapse:collapse; }
.v-card .hours-table tr{ border-bottom:1px solid var(--line); }
.v-card .hours-table tr:last-child{ border:none; }
.v-card .hours-table td{ padding:9px 0; font-size:15px; color:var(--ink-soft); }
.v-card .hours-table td:last-child{ text-align:right; font-family:var(--font-head); font-weight:600; color:var(--ink); }
.v-card .hours-table tr.is-today td{ color:var(--accent-deep); }
.v-card .hours-table tr.is-today td:last-child{ color:var(--accent-deep); }
.v-list li{ padding:11px 0; border-bottom:1px solid var(--line); }
.v-list li:last-child{ border:none; }
.v-list b{ display:block; font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--green); margin-bottom:2px; }
.v-list a, .v-list span{ color:var(--ink); font-size:16px; }
.v-list a:hover{ color:var(--green); }
/* highlight odkazy ve visit (3. sloupec) */
.v-links{ display:flex; flex-direction:column; gap:16px; }
.v-hl{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:16px;
  background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:22px 24px; transition:transform .25s var(--ease), background .25s, border-color .25s, box-shadow .25s; }
.v-hl:hover{ transform:translateY(-3px); box-shadow:var(--shadow); border-color:var(--green-tint-2); }
.v-hl-ic{ display:inline-flex; width:48px; height:48px; border-radius:13px; background:var(--green-tint);
  color:var(--green); align-items:center; justify-content:center; flex-shrink:0; }
.v-hl-ic svg{ width:24px; height:24px; }
.v-hl-t b{ display:block; font-family:var(--font-head); font-size:18px; color:var(--green-deep); }
.v-hl-t small{ display:block; font-size:13.5px; color:var(--ink-soft); margin-top:2px; }
.v-hl-go{ width:22px; height:22px; color:var(--green); transition:transform .25s var(--ease); }
.v-hl:hover .v-hl-go{ transform:translateX(3px); }
.v-hl-primary{ background:var(--accent); border-color:var(--accent); }
.v-hl-primary:hover{ background:var(--accent-deep); border-color:var(--accent-deep); }
.v-hl-primary .v-hl-ic{ background:rgba(255,255,255,.25); color:#fff; }
.v-hl-primary .v-hl-t b{ color:#fff; }
.v-hl-primary .v-hl-t small{ color:rgba(255,255,255,.9); }
.v-hl-primary .v-hl-go{ color:#fff; }

/* ---------- 17. Footer (sdílený, jen spodní lišta) ---------- */
.site-footer{ background:var(--green-deep); color:#dfe9da; }
.site-footer a:hover{ color:#fff; }
.footer-bottom{ padding:18px 0; display:flex; justify-content:space-between; align-items:center; gap:16px 28px; font-size:13.5px; color:#9fb897; flex-wrap:wrap; }
.footer-credit a{ color:#cfdfc8; }
.footer-links{ display:flex; gap:24px; }
.footer-links a{ color:#9fb897; }

/* ---------- 18. Subpage placeholder layout ---------- */
.page{
  padding:60px 0 80px;
  min-height:40vh;
}
.page .wrap > h1{
  font-size:clamp(34px,4vw,52px);
  color:var(--green-deep);
  margin-bottom:16px;
}
.page .page-content{
  color:var(--ink-soft);
  font-size:17px;
  max-width:60ch;
}
.breadcrumb{
  display:flex; align-items:center; gap:9px;
  font-size:14px; color:var(--ink-soft);
  padding:14px 0 24px;
}
.breadcrumb a{ color:var(--green); font-weight:600; }
.breadcrumb [aria-current="page"]{ color:var(--ink); }

/* ---------- 20. Subpage šablona (hero + tělo + CTA aside) ---------- */
.sp-hero{ background:var(--green-tint); padding:clamp(24px,3vw,40px) 0 clamp(34px,4vw,52px); }
.sp-hero .breadcrumb{ padding:0 0 22px; }
.sp-hero-head{ display:flex; align-items:center; gap:22px; }
.sp-ic{ display:inline-flex; width:84px; height:84px; border-radius:20px; background:#fff;
  align-items:center; justify-content:center; flex-shrink:0; box-shadow:var(--shadow); }
.sp-ic img{ width:50px; height:50px; object-fit:contain; }
.sp-hero h1{ font-size:clamp(28px,3.6vw,46px); color:var(--green-deep); margin-top:8px; letter-spacing:-.01em; }
.sp-lead{ margin-top:24px; display:grid; gap:14px; }
.sp-lead p{ color:var(--ink-soft); font-size:19px; }

.sp-grid{ display:grid; grid-template-columns:1fr 340px; gap:56px; align-items:start; }
.sp-main h2{ font-size:clamp(24px,2.6vw,32px); color:var(--green-deep); }
.sp-main .checklist + h2{ margin-top:40px; }
.checklist{ margin-top:24px; display:grid; grid-template-columns:1fr 1fr; gap:14px 28px; }
.checklist li{ display:flex; gap:12px; align-items:flex-start; font-size:17px; color:var(--ink-soft); }
.checklist svg{ width:20px; height:20px; color:var(--accent); flex-shrink:0; margin-top:3px; }
.sp-note{ margin-top:36px; padding:26px 28px; background:var(--green-tint); border-radius:var(--radius); border:1px solid var(--green-tint-2); }
.sp-note h3{ font-family:var(--font-head); font-weight:700; font-size:20px; color:var(--green); }
.sp-note p{ color:var(--ink-soft); font-size:17px; margin-top:10px; }

.sp-aside{ position:sticky; top:100px; }
.sp-cta{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius-lg); padding:28px 26px; box-shadow:var(--shadow); }
.sp-cta h3{ font-family:var(--font-head); font-weight:700; font-size:21px; color:var(--green-deep); }
.sp-cta p{ color:var(--ink-soft); font-size:15.5px; margin:10px 0 20px; }
.sp-cta .btn{ display:flex; width:100%; justify-content:center; margin-bottom:12px; }
.sp-cta-tel{ display:flex; align-items:center; justify-content:center; gap:9px; margin-top:6px;
  font-family:var(--font-head); font-weight:700; font-size:18px; color:var(--green-deep); }
.sp-cta-tel svg{ width:19px; height:19px; color:var(--green); }
.sp-cta-tel:hover{ color:var(--green); }

/* kontakt stránka */
.kontakt-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:40px; }
.k-col h3{ font-family:var(--font-head); font-weight:700; font-size:22px; color:var(--green); margin-bottom:14px; }
.k-col p{ color:var(--ink-soft); font-size:17px; margin-bottom:14px; line-height:1.7; }
.k-col b{ color:var(--ink); font-family:var(--font-head); }
.k-col a{ color:var(--green); }
.k-col a:hover{ color:var(--green-deep); }
.k-hours{ display:grid; gap:0; margin-bottom:18px; max-width:340px; }
.k-hours li{ display:flex; justify-content:space-between; gap:16px; color:var(--ink-soft); font-size:17px; padding:9px 0; border-bottom:1px solid var(--line); }
.k-hours li:last-child{ border-bottom:0; }
.k-note{ margin-top:44px; }
.k-note h3{ font-family:var(--font-head); font-weight:700; font-size:22px; color:var(--green); margin-bottom:10px; }
.k-note p{ color:var(--ink-soft); font-size:17px; }
.k-note a{ color:var(--green); font-weight:600; border-bottom:1px solid var(--green-tint-2); }
.k-note a:hover{ color:var(--green-deep); border-color:var(--green); }
.k-map{ margin-top:40px; }
.k-map iframe{ display:block; width:100%; height:440px; border:0; border-radius:var(--radius-lg); border:1px solid var(--line); }
.k-map-link{ display:inline-block; margin-top:12px; color:var(--green); font-family:var(--font-head); font-weight:600; font-size:15px; }
.k-map-link:hover{ color:var(--green-deep); }

/* galerie stránka — 4 sloupce, čtvercové náhledy */
.gallery-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
.gallery-grid .gg-item{ aspect-ratio:1/1; overflow:hidden; border-radius:14px; display:block; }
.gallery-grid .gg-item img{ width:100%; height:100%; object-fit:cover; display:block; transition:transform .5s var(--ease); }
.gallery-grid .gg-item:hover img{ transform:scale(1.06); }

/* prose sloupec (právní / textové stránky) — šířku drží .wrap (1460px) */
.sp-prose p{ color:var(--ink-soft); font-size:18px; margin-bottom:16px; }
.sp-prose b{ color:var(--ink); font-family:var(--font-head); }
.sp-prose ul{ margin:0 0 20px; padding-left:0; display:grid; gap:8px; }
.sp-prose li{ position:relative; padding-left:22px; color:var(--ink-soft); font-size:18px; }
.sp-prose li::before{ content:""; position:absolute; left:0; top:11px; width:8px; height:8px; border-radius:50%; background:var(--accent); }
.sp-prose a{ color:var(--green); font-weight:600; border-bottom:1px solid var(--green-tint-2); }
.sp-prose a:hover{ color:var(--green-deep); border-color:var(--green); }

/* ---------- 19. Media queries ---------- */
@media (max-width:1080px){
  .main-nav{ display:none; }
  .burger{ display:flex; }
  .about-grid{ grid-template-columns:1fr; gap:40px; }
  .about-visual{ position:static; max-width:340px; margin-inline:auto; }
  .visit-grid{ grid-template-columns:1fr 1fr; }
  .v-links{ grid-column:1/-1; }
  .gallery-2row .gw, .gallery-2row .gn{ grid-column:span 6; }
  .season-rail{ grid-template-columns:repeat(2,1fr); }
  .pillars{ grid-template-columns:1fr; }
  .pillar{ border-right:0; border-bottom:1px solid var(--line); }
  .pillar:last-of-type{ border-bottom:0; }
  .sp-grid{ grid-template-columns:1fr; gap:36px; }
  .sp-aside{ position:static; max-width:420px; }
  .gallery-grid{ grid-template-columns:repeat(3,1fr); }
}
@media (max-width:900px){
  .hero2{ grid-template-columns:1fr; }
  .hero2-right{ min-height:340px; order:2; }
  .hero2-left{ text-align:center; align-items:center; }
  .hero2-left::before, .hero2-left::after{ -webkit-mask-image:none; mask-image:none; }
  .hero2-inner{ margin-inline:auto; }
  .hero2-kicker, .hero2-cta{ justify-content:center; }
  .hero2 .lead{ max-width:none; margin-inline:auto; }
}
@media (max-width:880px){
  .footer-top{ grid-template-columns:1fr 1fr; gap:32px; padding:48px 0 40px; }
}
@media (max-width:680px){
  .topbar{ display:none; }
  .footer-bottom{ flex-direction:column; justify-content:center; text-align:center; }
  .footer-links{ justify-content:center; }
  .visit-grid{ grid-template-columns:1fr; }
  .gallery-2row .gw, .gallery-2row .gn{ grid-column:span 12; }
  .season-rail{ grid-template-columns:1fr; }
  .checklist{ grid-template-columns:1fr; }
  .sp-hero-head{ flex-direction:column; align-items:flex-start; gap:16px; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); }
  .kontakt-grid{ grid-template-columns:1fr; gap:32px; }
  .k-map iframe{ height:340px; }
}
@media (max-width:560px){
  body{ font-size:18px; }
  .wrap{ padding-inline:20px; }
  /* hero stat bar: na mobilu jen Nákup online + menší písmo */
  .hud-spec{ grid-template-columns:1fr; }
  .hud-spec .c:not(.c-shop){ display:none; }
  .hud-spec .c{ padding:13px 16px; }
  .hud-spec .v{ font-size:20px; }
  .hud-spec .l{ font-size:10px; }
}
