/* ===========================================================================
   AGENTURA POHODÁŘI — cinematic redesign
   Design system: deep charcoal, warm off-white, amber accent
   Display serif (Cormorant Garamond) + grotesque sans (Manrope)
   =========================================================================== */

:root{
  /* color */
  --bg:        #0d0e11;
  --bg-elev:   #15171c;
  --bg-elev2:  #1b1e25;
  --ink:       #f3efe7;
  --ink-dim:   #bdb8ad;
  --muted:     #8c877c;
  --line:      rgba(243,239,231,.12);
  --line-soft: rgba(243,239,231,.07);

  --accent:    #E9BB5C;          /* amber / sunset gold — tweakable */
  --accent-ink:#0d0e11;
  --accent-soft: color-mix(in srgb, var(--accent) 16%, transparent);

  /* type */
  --font-display: 'Bricolage Grotesque', system-ui, sans-serif;
  --font-sans: 'Manrope', system-ui, -apple-system, sans-serif;
  --display-weight: 700;

  /* motion */
  --parallax: 1;                 /* multiplier, tweakable 0..1.6 */
  --ease: cubic-bezier(.22,.61,.36,1);

  /* layout */
  --container: 1240px;
  --pad: clamp(20px, 5vw, 64px);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion: reduce){ html{ scroll-behavior:auto; } }

body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--font-sans);
  font-weight:400;
  line-height:1.6;
  letter-spacing:.005em;
  -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; }
::selection{ background:var(--accent); color:var(--accent-ink); }

/* ---- typographic primitives ---- */
.eyebrow{
  font-family:var(--font-sans);
  font-size:.74rem;
  font-weight:600;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex;
  align-items:center;
  gap:.7em;
}
.eyebrow::before{
  content:"";
  width:30px; height:1px;
  background:var(--accent);
  opacity:.8;
}
.eyebrow.no-rule::before{ display:none; }

h1,h2,h3{
  font-family:var(--font-display);
  font-weight:var(--display-weight);
  line-height:1.04;
  letter-spacing:-.01em;
  margin:0;
}
.display{
  font-family:var(--font-display);
  font-weight:var(--display-weight);
  line-height:1.02;
}
.section-title{
  font-size:clamp(2.4rem, 5.5vw, 4.6rem);
  letter-spacing:-.015em;
}
.lead{
  font-size:clamp(1.05rem, 1.5vw, 1.28rem);
  color:var(--ink-dim);
  line-height:1.65;
  font-weight:350;
}
.muted{ color:var(--muted); }
em.serif-it{ font-style:italic; font-family:var(--font-display); color:var(--accent); }
.amber{ color:var(--accent); }   /* zlaté zvýraznění slova v textu */

/* ---- layout helpers ---- */
.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }
.section{ padding-block:clamp(76px, 11vh, 150px); position:relative; }
.section--tight{ padding-block:clamp(54px, 7vh, 96px); }
.grid{ display:grid; gap:clamp(28px,4vw,72px); }

/* ============================ NAV ============================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:60;
  display:flex; align-items:center; justify-content:space-between;
  gap:24px;
  padding:18px var(--pad);
  transition:background .4s var(--ease), padding .4s var(--ease), border-color .4s;
  border-bottom:1px solid transparent;
}
.nav.scrolled{
  background:color-mix(in srgb, var(--bg) 86%, transparent);
  backdrop-filter:saturate(140%) blur(14px);
  -webkit-backdrop-filter:saturate(140%) blur(14px);
  border-bottom:1px solid var(--line-soft);
  padding-block:12px;
}
.nav__logo{ display:flex; align-items:center; gap:12px; flex:0 0 auto; }
.nav__logo img{ height:54px; width:auto; }
.nav__logo .wordmark{
  font-family:var(--font-display); font-weight:600; font-size:1.28rem; letter-spacing:.02em;
  line-height:1; white-space:nowrap;
}
.nav__logo .wordmark small{ display:block; font-family:var(--font-sans); font-size:.56rem; letter-spacing:.36em; text-transform:uppercase; color:var(--accent); margin-top:3px; font-weight:600; }

.nav__links{ display:flex; align-items:center; gap:30px; margin-left:auto; }
.nav__links a{
  font-size:.82rem; font-weight:500; letter-spacing:.04em;
  color:var(--ink-dim); position:relative; padding:6px 0;
  transition:color .25s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--accent);
  transition:width .3s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }

.nav__social{ display:flex; align-items:center; gap:14px; padding-left:26px; border-left:1px solid var(--line); }
.nav__social a{ color:var(--ink-dim); transition:color .25s, transform .25s; display:grid; place-items:center; }
.nav__social a:hover{ color:var(--accent); transform:translateY(-2px); }
.nav__social svg{ width:18px; height:18px; }

.nav__burger{ display:none; background:none; border:0; color:var(--ink); width:42px; height:42px; }
.nav__burger svg{ width:26px; height:26px; }

/* mobile menu */
.mobile-menu{
  position:fixed; inset:0; z-index:70; background:color-mix(in srgb,var(--bg) 97%, #000);
  display:flex; flex-direction:column; padding:90px var(--pad) 40px;
  transform:translateY(-100%); gap:6px; overflow-y:auto; visibility:hidden;
  transition:transform .5s var(--ease), visibility 0s linear .5s;
}
.mobile-menu.open{ transform:translateY(0); visibility:visible; transition:transform .5s var(--ease); }
.mobile-menu a{ font-family:var(--font-display); font-size:2rem; padding:12px 0; border-bottom:1px solid var(--line-soft); }
.mobile-menu .close{ position:absolute; top:22px; right:var(--pad); background:none; border:0; color:var(--ink); width:42px; height:42px; }
.mobile-menu .close svg{ width:28px; height:28px; }

/* ============================ HERO ============================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__bg{ position:absolute; inset:0; z-index:0; }
.hero__slide{
  position:absolute; inset:-3% ; background-size:cover; background-position:center;
  opacity:0; transition:opacity 2s ease;
  animation:kenburns var(--kb-dur, 20s) ease-in-out infinite alternate;
}
.hero__slide.active{ opacity:1; }
@keyframes kenburns{
  from{ transform:scale(1) translate(0,0); }
  to  { transform:scale(1.07) translate(-1%, -1%); }
}
@media (prefers-reduced-motion: reduce){ .hero__slide{ animation:none; } }
.hero__overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(13,14,17,.55) 0%, rgba(13,14,17,.12) 26%, rgba(13,14,17,.30) 60%, rgba(13,14,17,.94) 100%),
    radial-gradient(120% 80% at 15% 90%, rgba(13,14,17,.6), transparent 60%);
}
.hero__inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(56px,9vh,120px); }
/* eyebrow v heru — stín po jednotlivých písmenech (jako titulky), čitelné na světlé i tmavé fotce */
.hero__inner .eyebrow{ text-shadow:0 1px 2px rgba(0,0,0,1), 0 0 5px rgba(0,0,0,.95), 0 2px 8px rgba(0,0,0,.8), 0 3px 16px rgba(0,0,0,.6); }
/* nízká výška (mobil na šířku) — zmenšit hero, ať nadpis nenaráží na menu */
@media (max-height:520px){
  .nav__logo img{ height:38px; }
  .hero__inner{ padding-top:56px; padding-bottom:18px; }
  .hero__title{ font-size:clamp(1.4rem,4.6vw,2rem); line-height:1.05; max-width:none; }
  .hero__sub{ margin-top:.6rem; font-size:.9rem; max-width:54ch; }
  .hero__cta{ margin-top:.9rem; }
  .scroll-cue, .hero__cap{ display:none; }
}
/* popisek aktuálního snímku slideshow (vpravo dole, nad „27 sezón") */
.hero__cap{
  display:none; margin-bottom:.5rem; max-width:34ch; text-align:right;
  font-family:var(--font-sans); font-size:.9rem; font-weight:400; font-style:italic;
  letter-spacing:.01em; line-height:1.4; color:var(--ink-dim);
  text-shadow:0 1px 12px rgba(0,0,0,.55);
  opacity:0; transition:opacity .6s var(--ease);
}
.hero__cap.show{ display:block; opacity:.9; }
/* lišta úpravy polohy fotky na heru (jen režim úprav) */
.hero-edit{ position:absolute; top:84px; left:50%; transform:translateX(-50%); z-index:6; display:none; align-items:center; gap:9px; padding:7px 13px; border-radius:999px; background:rgba(13,14,17,.72); border:1px solid var(--line); backdrop-filter:blur(8px); color:var(--ink); font:600 .8rem var(--font-sans); transition:border-color .3s; }
body.inline-edit .hero-edit{ display:flex; }   /* lišta polohy jen v zapnutém režimu úprav */
.hero-edit.saved{ border-color:#5fb6a8; }
.hero-edit .he-btn{ background:rgba(255,255,255,.08); border:1px solid var(--line); color:var(--ink); width:30px; height:30px; border-radius:50%; cursor:pointer; line-height:1; transition:.2s; }
.hero-edit .he-btn:hover{ border-color:var(--accent); color:var(--accent); }
.hero-edit .he-val{ min-width:48px; text-align:center; color:var(--accent); font-variant-numeric:tabular-nums; }
.hero-edit .he-lab{ font-weight:500; color:var(--ink-dim); letter-spacing:.04em; }
.hero-edit .he-sep{ width:1px; height:18px; background:var(--line); }
.hero__title{
  font-size:clamp(3rem, 9vw, 8.2rem);
  line-height:.98; letter-spacing:-.02em; margin:.28em 0 0;
  max-width:14ch; text-wrap:balance;
}
.hero__title em{ font-style:italic; color:var(--accent); }
.hero__sub{ margin-top:1.4rem; max-width:46ch; font-size:clamp(1.02rem,1.5vw,1.24rem); color:var(--ink-dim); font-weight:350; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:16px; margin-top:2.2rem; }

.hero__meta{
  position:absolute; right:var(--pad); bottom:clamp(56px,9vh,120px); z-index:2;
  text-align:right; display:flex; flex-direction:column; align-items:flex-end; gap:6px;
  max-width:360px;
}
.hero__meta .num{ font-family:var(--font-display); font-size:3.4rem; line-height:1; color:var(--ink); }
.hero__meta .lbl{ font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--ink-dim); }

.hero__dots{ position:absolute; left:var(--pad); bottom:30px; z-index:3; display:flex; gap:10px; }
.hero__dots button{ width:30px; height:3px; border:0; background:rgba(243,239,231,.28); padding:0; transition:background .3s; }
.hero__dots button.active{ background:var(--accent); }

.scroll-cue{ position:absolute; left:50%; transform:translateX(-50%); bottom:24px; z-index:3; display:flex; flex-direction:column; align-items:center; gap:8px; color:var(--ink-dim); font-size:.66rem; letter-spacing:.24em; text-transform:uppercase; }
.scroll-cue .line{ width:1px; height:42px; background:linear-gradient(var(--accent),transparent); animation:cue 2.2s var(--ease) infinite; transform-origin:top; }
@keyframes cue{ 0%{transform:scaleY(0);} 40%{transform:scaleY(1);} 100%{transform:scaleY(0); transform-origin:bottom;} }

/* ============================ BUTTONS ============================ */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--font-sans); font-size:.82rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase;
  padding:15px 28px; border-radius:2px; border:1px solid transparent; transition:all .3s var(--ease);
}
.btn svg{ width:16px; height:16px; transition:transform .3s var(--ease); }
.btn--primary{ background:var(--accent); color:var(--accent-ink); }
.btn--primary:hover{ background:color-mix(in srgb,var(--accent) 86%, #fff); transform:translateY(-2px); }
.btn--primary:hover svg{ transform:translateX(4px); }
.btn--ghost{ border-color:var(--line); color:var(--ink); background:transparent; }
.btn--ghost:hover{ border-color:var(--accent); color:var(--accent); }
.btn--light{ background:var(--ink); color:var(--bg); }
.btn--light:hover{ transform:translateY(-2px); }

/* ============================ INTRO / MANIFESTO ============================ */
.intro{ background:var(--bg); }
.intro__grid{ grid-template-columns:1.15fr .85fr; align-items:center; }
.intro__copy p{ font-size:clamp(1.05rem,1.5vw,1.32rem); color:var(--ink-dim); font-weight:350; }
.intro__copy p + p{ margin-top:1.1em; }
.pull{
  font-family:var(--font-display); font-style:italic;
  font-size:clamp(1.7rem,3vw,2.8rem); line-height:1.18; color:var(--ink); margin:0;
  text-wrap:balance;
}
.pull cite{ display:block; margin-top:1.1rem; font-style:normal; font-family:var(--font-sans);
  font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.intro__media{ position:relative; aspect-ratio:3/4; overflow:hidden; border-radius:3px; background:var(--bg-elev); }
.intro__media img{ width:100%; height:100%; object-fit:cover; }

/* ============================ FEATURE (current show) ============================ */
.feature{ position:relative; background:var(--bg); overflow:hidden; }
.feature__grid{ grid-template-columns:1fr 1fr; align-items:stretch; gap:0; min-height:84vh; }
.feature__media{ position:relative; overflow:hidden; min-height:60vh; background:var(--bg-elev); }
.feature__media .ph{ position:absolute; inset:-12% 0; background-size:cover; background-position:center; will-change:transform; }
.feature__media::after{ content:""; position:absolute; inset:0; background:linear-gradient(90deg, transparent 60%, var(--bg)); }
.feature__body{ display:flex; flex-direction:column; justify-content:center; padding:clamp(40px,6vw,96px); }
.feature__logo{ height:clamp(72px,12vw,128px); width:auto; object-fit:contain; object-position:left; margin-bottom:24px; align-self:flex-start; filter:drop-shadow(0 6px 24px rgba(0,0,0,.5)); }
.feature__title{ font-size:clamp(2rem,4vw,3.4rem); margin:.1em 0 .4em; }
.feature__title small{ display:block; font-family:var(--font-sans); font-size:.8rem; letter-spacing:.24em; text-transform:uppercase; color:var(--accent); margin-bottom:.7em; font-weight:600; }
.meta-list{ list-style:none; padding:0; margin:1.8rem 0 0; display:grid; gap:14px; }
.meta-list li{ display:flex; gap:16px; align-items:baseline; padding-bottom:14px; border-bottom:1px solid var(--line-soft); }
.meta-list .k{ flex:0 0 132px; font-size:.72rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.meta-list .v{ color:var(--ink); font-size:1rem; }

/* trailer */
.trailer{ margin-top:30px; position:relative; aspect-ratio:16/9; border-radius:4px; overflow:hidden; background:#000; cursor:pointer; }
.trailer img{ width:100%; height:100%; object-fit:cover; opacity:.7; transition:opacity .4s, transform 6s var(--ease); }
.trailer:hover img{ opacity:.9; transform:scale(1.05); }
.trailer__play{ position:absolute; inset:0; display:grid; place-items:center; }
.trailer__play span{ width:78px; height:78px; border-radius:50%; background:color-mix(in srgb,var(--accent) 92%, #fff); display:grid; place-items:center; transition:transform .3s var(--ease); box-shadow:0 10px 40px rgba(0,0,0,.5); }
.trailer:hover .trailer__play span{ transform:scale(1.1); }
.trailer__play svg{ width:26px; height:26px; fill:var(--accent-ink); margin-left:4px; }
.trailer__label{ position:absolute; left:20px; bottom:18px; font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:#fff; text-shadow:0 2px 8px rgba(0,0,0,.7); }
.trailer iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ============================ STEPS ============================ */
.steps{ background:var(--bg-elev); }
.steps__grid{ grid-template-columns:repeat(4,1fr); gap:clamp(24px,3vw,44px); margin-top:clamp(40px,6vh,72px); }
.step{ position:relative; }
.step__num{ font-family:var(--font-display); font-size:1rem; color:var(--accent); letter-spacing:.1em; }
.step__icon{ width:46px; height:46px; color:var(--accent); margin:18px 0 18px; }
.step__icon svg{ width:100%; height:100%; stroke:currentColor; fill:none; stroke-width:1.25; }
.step h3{ font-size:1.5rem; margin-bottom:.5rem; }
.step p{ color:var(--ink-dim); font-size:.98rem; font-weight:350; }
.step::before{ content:""; position:absolute; top:8px; left:0; width:100%; height:1px; background:var(--line-soft); }

/* ============================ GALLERY ============================ */
.gallery{ background:var(--bg); }
.gallery__head{ display:flex; align-items:flex-end; justify-content:space-between; gap:24px; flex-wrap:wrap; margin-bottom:clamp(34px,5vh,60px); }
/* Připravujeme: úvod může být delší (popis pořadu) → zarovnat nahoru, ať nevzniká mezera nad nadpisem */
#pripravujeme .gallery__head{ align-items:flex-start; }
.gallery__grid{
  display:grid; grid-template-columns:repeat(12,1fr);
  grid-auto-rows:clamp(120px,16vh,200px); gap:14px;
}
.gallery__item{ position:relative; overflow:hidden; border-radius:3px; background:var(--bg-elev); cursor:pointer; }
.gallery__item img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease), filter .5s; filter:saturate(.95) brightness(.92); }
.gallery__item:hover img{ transform:scale(1.07); filter:saturate(1.05) brightness(1); }
.gallery__item::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(13,14,17,.7), transparent 45%); opacity:0; transition:opacity .4s; }
.gallery__item:hover::after{ opacity:1; }
.gallery__cap{ position:absolute; left:16px; right:16px; bottom:14px; z-index:2; font-size:.84rem; color:#fff; opacity:0; transform:translateY(8px); transition:.4s var(--ease); text-shadow:0 1px 6px rgba(0,0,0,.6); }
.gallery__item:hover .gallery__cap{ opacity:1; transform:none; }
.gallery__cap .plus{ display:inline-block; margin-right:8px; color:var(--accent); }

.gallery__more{ text-align:center; margin-top:clamp(22px,3vh,34px); }
/* spans for editorial rhythm */
.g-wide{ grid-column:span 6; grid-row:span 2; }
.g-tall{ grid-column:span 3; grid-row:span 2; }
.g-sq{ grid-column:span 3; grid-row:span 1; }
.g-big{ grid-column:span 5; grid-row:span 2; }
.g-med{ grid-column:span 4; grid-row:span 2; }
.g-s4{ grid-column:span 4; grid-row:span 1; }

/* lightbox */
.lb{ position:fixed; inset:0; z-index:200; background:rgba(8,9,11,.96); display:none; align-items:center; justify-content:center; opacity:0; transition:opacity .4s; }
.lb.open{ display:flex; opacity:1; }
.lb__img{ max-width:90vw; max-height:80vh; object-fit:contain; border-radius:3px; box-shadow:0 30px 90px rgba(0,0,0,.7); transform-origin:0 0; will-change:transform; cursor:zoom-in; touch-action:none; user-select:none; -webkit-user-drag:none; }
.lb__img.zoomed{ cursor:grab; border-radius:0; }
.lb__img.dragging{ cursor:grabbing; }
.lb__cap{ position:absolute; left:0; right:0; bottom:30px; text-align:center; padding-inline:10vw; color:var(--ink-dim); font-size:.95rem; }
.lb__cap b{ color:var(--accent); font-weight:600; margin-right:8px; font-family:var(--font-display); }
.lb__close,.lb__nav{ position:absolute; z-index:5; background:rgba(13,14,17,.55); border:1px solid var(--line); color:var(--ink); width:54px; height:54px; border-radius:50%; display:grid; place-items:center; transition:.25s; backdrop-filter:blur(6px); }
.lb__close:hover,.lb__nav:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.lb__close{ top:26px; right:26px; }
.lb__close svg,.lb__nav svg{ width:22px; height:22px; }
.lb__nav{ top:50%; transform:translateY(-50%); }
.lb__nav.prev{ left:26px; } .lb__nav.next{ right:26px; }
.lb__count{ position:absolute; top:34px; left:34px; font-size:.8rem; letter-spacing:.2em; color:var(--muted); }

/* ============================ MAP ============================ */
.mapsec{ background:var(--bg-elev); position:relative; }
.mapsec__grid{ grid-template-columns:1fr 1.5fr; gap:clamp(30px,4vw,64px); align-items:stretch; }
.mapsec__aside{ display:flex; flex-direction:column; }
.map-stat{ display:flex; gap:28px; margin:26px 0 6px; }
.map-stat .num{ font-family:var(--font-display); font-size:2.8rem; line-height:1; color:var(--accent); }
.map-stat .lbl{ font-size:.72rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); margin-top:6px; }
.dest-scroll{ margin-top:22px; max-height:260px; overflow:auto; padding-right:8px; }
.dest-scroll::-webkit-scrollbar{ width:6px; } .dest-scroll::-webkit-scrollbar-thumb{ background:var(--line); border-radius:3px; }
.dest-row{ display:flex; align-items:baseline; gap:14px; padding:9px 4px; border-bottom:1px solid var(--line-soft); cursor:pointer; transition:.2s; }
.dest-row:hover,.dest-row.active{ padding-left:12px; }
.dest-row:hover .dest-name,.dest-row.active .dest-name{ color:var(--accent); }
.dest-yr{ flex:0 0 78px; font-size:.78rem; color:var(--muted); letter-spacing:.04em; font-variant-numeric:tabular-nums; }
.dest-name{ font-size:1rem; color:var(--ink); transition:color .2s; }
#map{ width:100%; min-height:560px; height:100%; border-radius:5px; overflow:hidden; background:var(--bg);
  position:relative; z-index:0; isolation:isolate;   /* uzavře Leaflet z-indexy, ať mapa nepřelézá přes fixní menu */
  border:1px solid color-mix(in srgb, var(--accent) 24%, var(--line));
  box-shadow:0 28px 70px -24px rgba(0,0,0,.8), 0 0 0 1px rgba(255,255,255,.02),
    0 0 0 7px color-mix(in srgb, var(--accent) 6%, transparent); }
#map .leaflet-tile{ filter:brightness(1.22) saturate(1.18) contrast(1.03); }
.leaflet-container{ background:#0d0e11 !important; font-family:var(--font-sans) !important; }
.leaflet-popup-content-wrapper{ background:var(--bg-elev2); color:var(--ink); border-radius:3px; box-shadow:0 12px 40px rgba(0,0,0,.6); }
.leaflet-popup-tip{ background:var(--bg-elev2); }
.leaflet-popup-content{ margin:12px 16px; font-family:var(--font-sans); }
.leaflet-popup-content .pyr{ color:var(--accent); font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; }
.leaflet-popup-content .pnm{ font-family:var(--font-display); font-size:1.2rem; margin-top:2px; }
.leaflet-control-zoom a{ background:var(--bg-elev2) !important; color:var(--ink) !important; border-color:var(--line) !important; }
.leaflet-bar{ border:none !important; }
.poho-pin{ }
.poho-pin span{ display:block; width:13px; height:13px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 4px var(--accent-soft), 0 2px 8px rgba(0,0,0,.6); transition:transform .25s; }
.poho-pin.current span{ background:#fff; box-shadow:0 0 0 5px rgba(255,255,255,.18), 0 0 18px rgba(255,255,255,.5); animation:pulse 2.4s infinite; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 5px rgba(255,255,255,.16);} 50%{ box-shadow:0 0 0 11px rgba(255,255,255,.04);} }
.poho-pin.selected{ z-index:1000 !important; }
.poho-pin.selected span{ width:22px; height:22px; margin:-4.5px; background:#fff;
  box-shadow:0 0 0 6px var(--accent-soft), 0 0 22px color-mix(in srgb, var(--accent) 85%, transparent); }

/* trasa napříč roky — jen jemně naznačená */
.poho-route{ stroke:var(--accent); fill:none; stroke-linecap:round; stroke-linejoin:round; }

/* obohacené bubliny */
.poho-popup .leaflet-popup-content-wrapper{ padding:0; overflow:hidden; border-radius:5px; }
.poho-popup .leaflet-popup-content{ margin:0; width:auto !important; }
.poho-popup .ppimg{ height:122px; background:var(--bg); }
.poho-popup .ppimg img{ width:100%; height:100%; object-fit:cover; display:block; }
.poho-popup .ppbody{ padding:13px 17px 16px; }
.poho-popup .pyr{ color:var(--accent); font-size:.7rem; letter-spacing:.14em; text-transform:uppercase; }
.poho-popup .pnm{ font-family:var(--font-display); font-size:1.3rem; margin-top:3px; line-height:1.08; color:var(--ink); }
.poho-popup .pplace{ color:var(--muted); font-size:.86rem; margin-top:4px; }
.poho-popup .pplink{ display:inline-flex; align-items:center; gap:.45em; margin-top:13px;
  font-size:.72rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:var(--accent); }
.poho-popup .pplink span{ transition:transform .3s var(--ease); }
.poho-popup .pplink:hover span{ transform:translateX(4px); }
.poho-popup .leaflet-popup-close-button{ color:#fff !important; top:7px !important; right:9px !important;
  font-size:20px; text-shadow:0 1px 5px rgba(0,0,0,.7); z-index:3; }
/* bublina i náhled se objeví postupně až po doletění na bod */
.poho-popup .leaflet-popup-content-wrapper{ animation:pohoPopIn .5s var(--ease) both; }
.poho-popup .leaflet-popup-tip{ animation:pohoPopIn .5s var(--ease) both; }
.poho-popup .ppimg img{ animation:pohoImgIn .8s var(--ease) .18s both; }
.poho-popup .ppbody > *{ animation:pohoBodyIn .6s var(--ease) both; }
.poho-popup .pyr{ animation-delay:.22s; }
.poho-popup .pnm{ animation-delay:.30s; }
.poho-popup .pplace{ animation-delay:.38s; }
.poho-popup .pplink{ animation-delay:.46s; }
@keyframes pohoPopIn{ from{ opacity:0; transform:translateY(10px) scale(.96); } to{ opacity:1; transform:none; } }
@keyframes pohoImgIn{ from{ opacity:0; transform:scale(1.08); } to{ opacity:1; transform:none; } }
@keyframes pohoBodyIn{ from{ opacity:0; transform:translateY(6px); } to{ opacity:1; transform:none; } }
@media (prefers-reduced-motion: reduce){
  .poho-popup .leaflet-popup-content-wrapper, .poho-popup .leaflet-popup-tip,
  .poho-popup .ppimg img, .poho-popup .ppbody > *{ animation:none; }
}

/* ============================ POŘADY (dlaždice) ============================ */
.shows{ background:var(--bg); }
.shows-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,2.2vw,30px); margin-top:clamp(36px,5vh,60px); }
/* filtr pořadů dle stavu */
.porady-filtr{ display:flex; flex-wrap:wrap; gap:10px; margin:clamp(10px,2vh,20px) 0 0; }
.porady-filtr__btn{ background:transparent; border:1px solid var(--line); color:var(--ink-dim); border-radius:999px; padding:9px 18px; font:600 .8rem var(--font-sans); letter-spacing:.04em; cursor:pointer; transition:.2s var(--ease); }
.porady-filtr__btn:hover{ border-color:var(--accent); color:var(--ink); }
.porady-filtr__btn.is-active{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.show-tile{ cursor:pointer; outline:none; border:1px solid color-mix(in srgb, var(--accent) 42%, transparent); border-radius:10px; overflow:hidden; background:var(--bg-elev); transition:transform .3s var(--ease), box-shadow .3s, border-color .3s; }
.show-tile:hover{ border-color:color-mix(in srgb, var(--accent) 70%, transparent); }
.show-tile:hover{ transform:translateY(-2px); box-shadow:0 10px 28px rgba(0,0,0,.35); }
.show-tile:focus-visible{ box-shadow:0 0 0 3px var(--accent-soft); }
.show-tile__img{ position:relative; aspect-ratio:3/4; overflow:hidden; background:var(--bg-elev2); }
.show-tile__img img{ width:100%; height:100%; object-fit:cover; transition:transform .9s var(--ease), filter .5s; filter:brightness(.92); }
.show-tile:hover .show-tile__img img, .show-tile:focus-visible .show-tile__img img{ transform:scale(1.07); filter:brightness(1.03); }
.show-tile__img::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(13,14,17,.6), transparent 52%); opacity:.7; transition:opacity .4s; }
.show-tile:hover .show-tile__img::after{ opacity:1; }
.show-tile.no-cover .show-tile__img{ background:var(--bg-elev); }
.archive{ position:absolute; inset:0; overflow:hidden;
  background:
    radial-gradient(120% 90% at 78% 12%, hsl(41 42% 26% / .55), transparent 60%),
    linear-gradient(155deg, hsl(41 30% 16%) 0%, var(--bg-elev) 62%, var(--bg) 100%);
  display:flex; flex-direction:column; justify-content:flex-end; }
.archive::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, rgba(13,14,17,.5), transparent 55%); }
.archive__yr{ position:absolute; top:-.18em; right:.04em; font-family:var(--font-display); font-weight:600;
  font-size:clamp(4.4rem,9vw,6.6rem); line-height:1; color:hsl(41 40% 70% / .14); letter-spacing:-.03em; font-variant-numeric:tabular-nums; }
.archive__ico{ position:absolute; top:16px; left:16px; width:30px; height:30px; color:hsl(41 48% 66% / .82); }
.archive__inner{ position:relative; z-index:1; padding:18px; }
.archive__tag{ display:inline-block; font-size:.6rem; font-weight:600; letter-spacing:.22em; text-transform:uppercase; color:hsl(41 45% 72% / .9); margin-bottom:8px; }
.archive__name{ display:block; font-family:var(--font-display); font-size:clamp(1.5rem,2.4vw,2rem); font-weight:500; line-height:1.04; color:var(--ink); }
.show-tile:hover .archive__ico{ transform:scale(1.08); transition:transform .5s var(--ease); }
.show-tile:hover .archive{ transition:transform .9s var(--ease); }
.show-tile__yr{ position:absolute; top:11px; left:11px; z-index:2; background:rgba(13,14,17,.66); backdrop-filter:blur(6px); padding:5px 9px; font-size:.68rem; letter-spacing:.08em; color:var(--accent); border-radius:2px; font-variant-numeric:tabular-nums; }
.show-tile__badge{ position:absolute; top:11px; right:11px; z-index:2; background:var(--accent); color:var(--accent-ink); padding:5px 9px; font-size:.6rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; border-radius:2px; }
.show-tile__cam{ position:absolute; bottom:11px; right:11px; z-index:2; display:flex; align-items:center; gap:5px; background:rgba(13,14,17,.6); backdrop-filter:blur(6px); padding:4px 8px; border-radius:2px; font-size:.72rem; color:var(--ink); }
.show-tile__cam svg{ width:14px; height:14px; color:var(--accent); }
.show-tile__cap{ padding:12px 14px 13px; background:var(--bg-elev); border-top:1px solid var(--accent-soft);
  transition:background .3s; }
.show-tile:hover .show-tile__cap{ background:var(--bg-elev2); }
.show-tile__cap .show-tile__name{ font-family:var(--font-display); font-size:1.24rem; font-weight:500; margin:0; line-height:1.1; transition:color .25s; }
.show-tile:hover .show-tile__cap .show-tile__name{ color:var(--accent); }
.show-tile__cap .place{ font-size:.8rem; color:var(--muted); margin-top:2px; }

/* ============================ DETAIL POŘADU ============================ */
.show-detail{ position:fixed; inset:0; z-index:120; background:var(--bg); opacity:0; visibility:hidden; transition:opacity .5s var(--ease), visibility .5s; }
.show-detail.open{ opacity:1; visibility:visible; }
.sd__scroll{ position:absolute; inset:0; overflow-y:auto; overflow-x:hidden; }
.sd__close{ position:fixed; top:20px; right:20px; z-index:130; width:52px; height:52px; border-radius:50%; background:rgba(13,14,17,.55); backdrop-filter:blur(10px); border:1px solid var(--line); color:var(--ink); display:grid; place-items:center; transition:.3s var(--ease); }
.sd__close:hover{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); transform:rotate(90deg); }
.sd__close svg{ width:24px; height:24px; }
.sd__hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.sd__hero-img{ position:absolute; inset:0; z-index:0; background-size:cover; background-position:center; }
.sd__hero-img.empty{ background:linear-gradient(140deg, var(--bg-elev2), var(--bg)); }
.sd__hero-ov{ position:absolute; inset:0; z-index:1;
  background:linear-gradient(180deg, transparent 0%, transparent 40%, var(--bg) 100%);
}
.sd__hero-inner{ position:relative; z-index:2; width:100%; padding-bottom:clamp(160px,42vh,460px); }
.sd__title{ font-size:clamp(2.6rem,7vw,6rem); line-height:.98; letter-spacing:-.02em; margin:.16em 0 0; }
.sd__place{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.2rem,2.4vw,1.9rem); color:var(--accent); margin:.3em 0 0; }
/* dovětek (místo) u aktuálního pořadu — stejný styl jako v detailu pořadu */
.feature__place{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.15rem,2.1vw,1.65rem); color:var(--accent); margin:.35em 0 0; }
.sd__body{ position:relative; z-index:3; margin-top:-36vh; padding-top:5vh; padding-bottom:clamp(60px,9vh,110px);
  background:linear-gradient(180deg, rgba(13,14,17,.5) 0%, var(--bg) 26vh); }
.sd__intro{ display:grid; grid-template-columns:1.4fr .9fr; gap:clamp(28px,4vw,64px); padding-top:clamp(30px,4vh,48px); align-items:start; }
.sd__desc{ font-size:clamp(1.05rem,1.5vw,1.28rem); line-height:1.65; color:var(--ink-dim); font-weight:350; margin:0; }
.sd__intro .meta-list{ margin-top:0; }
.sd__trailer{ margin-top:clamp(34px,5vh,56px); }
.sd__trailer .trailer{ margin-top:0; }
.sd__galhead{ display:flex; align-items:baseline; gap:16px; margin:clamp(44px,6vh,72px) 0 clamp(22px,3vh,32px); }
.sd__gtitle{ font-family:var(--font-display); font-size:clamp(1.8rem,3vw,2.6rem); font-weight:500; margin:0; }
.sd__galcount{ font-size:.78rem; letter-spacing:.16em; text-transform:uppercase; color:var(--muted); }
.sd__note{ color:var(--muted); font-size:1rem; margin:10px 0 0; max-width:60ch; }
.sd__foot{ display:flex; align-items:center; justify-content:space-between; gap:20px; flex-wrap:wrap; margin-top:clamp(44px,6vh,72px); padding-top:28px; border-top:1px solid var(--line-soft); }
.sd__pager{ display:flex; align-items:center; gap:10px; background:none; border:0; color:var(--ink-dim); font-family:inherit; font-size:.92rem; transition:color .25s; max-width:40%; cursor:pointer; }
.sd__pager svg{ width:20px; height:20px; flex:0 0 20px; transition:transform .3s var(--ease); }
.sd__pager:hover{ color:var(--accent); }
.sd__pager:hover svg{ transform:translateX(-4px); }
.sd__pager.next:hover svg{ transform:translateX(4px); }
.sd__pager span{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }

/* ============================ ABOUT (expanded) ============================ */
.about{ background:var(--bg-elev); }
.about__intro{ grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,80px); align-items:end; }
.about__intro .lead p + p{ margin-top:1em; }
.about__intro .lead p{ margin:0; }

.about-banner{ position:relative; margin-top:clamp(40px,6vh,72px); height:clamp(280px,46vh,520px); overflow:hidden; border-radius:4px; background:var(--bg-elev2); }
.about-banner .ph{ position:absolute; inset:-12% 0; background-size:cover; background-position:center 38%; will-change:transform; }
.about-banner::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg, rgba(13,14,17,.1), rgba(13,14,17,.7)); }
.about-banner figcaption{ position:absolute; left:clamp(20px,4vw,44px); bottom:clamp(18px,3vh,32px); z-index:2; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:var(--ink-dim); }
.about-banner figcaption b{ color:var(--accent); font-weight:600; }

/* příběh agentury */
.founders{ margin-top:clamp(56px,9vh,120px); }
.founders__grid{ grid-template-columns:1fr 1fr; gap:clamp(40px,6vw,96px); align-items:start; }
.milestones{ position:relative; margin-top:8px; }
.ms{ position:relative; display:grid; grid-template-columns:96px 1fr; gap:24px; padding:0 0 30px 0; }
.ms:last-child{ padding-bottom:0; }
.ms::before{ content:""; position:absolute; left:7px; top:14px; bottom:-6px; width:1px; background:var(--line); }
.ms:last-child::before{ display:none; }
.ms__dot{ position:absolute; left:0; top:7px; width:15px; height:15px; border-radius:50%; background:var(--bg-elev); border:2px solid var(--accent); }
.ms__yr{ font-family:var(--font-display); font-size:1.1rem; color:var(--accent); padding-left:34px; line-height:1.4; font-variant-numeric:tabular-nums; }
.ms__body h4{ font-family:var(--font-display); font-size:1.5rem; font-weight:500; margin:0 0 .35em; }
.ms__body p{ color:var(--ink-dim); font-size:.98rem; font-weight:350; margin:0; }

.mission{ }
.mission p{ font-size:clamp(1rem,1.4vw,1.16rem); color:var(--ink-dim); font-weight:350; }
.mission p + p{ margin-top:1em; }
.twain{ margin:30px 0 0; padding:26px 30px; border-left:2px solid var(--accent); background:color-mix(in srgb,var(--accent) 6%, transparent); border-radius:0 4px 4px 0; }
.twain p{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2vw,1.7rem); line-height:1.3; margin:0; color:var(--ink); }
.twain cite{ display:block; margin-top:14px; font-style:normal; font-family:var(--font-sans); font-size:.74rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }

/* medailonky */
.profiles{ grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,56px); margin-top:clamp(48px,7vh,96px); }
.profile{ display:grid; grid-template-columns:clamp(120px,18vw,180px) 1fr; gap:clamp(20px,3vw,34px); align-items:start; }
.profile__img{ aspect-ratio:4/5; border-radius:4px; overflow:hidden; background:var(--bg-elev2); }
.profile__img img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.25); transition:filter .6s, transform .9s var(--ease); }
.profile:hover .profile__img img{ filter:none; transform:scale(1.04); }
.profile__name{ font-family:var(--font-display); font-size:1.7rem; font-weight:500; margin:0; }
.profile__role{ font-size:.74rem; letter-spacing:.16em; text-transform:uppercase; color:var(--accent); margin:5px 0 2px; }
.profile__since{ font-size:.76rem; color:var(--muted); }
.profile__quote{ font-family:var(--font-display); font-style:italic; font-size:1.12rem; line-height:1.4; color:var(--ink); margin:16px 0 14px; text-wrap:pretty; }
.profile__focus{ font-size:.92rem; color:var(--ink-dim); font-weight:350; margin:0; padding-top:14px; border-top:1px solid var(--line-soft); }

/* ============================ NEWSLETTER ============================ */
.newsletter{ position:relative; overflow:hidden; }
.newsletter__bg{ position:absolute; inset:-10% 0; background-size:cover; background-position:center 18%; z-index:0; }
.newsletter__ov{ position:absolute; inset:0; z-index:1; background:linear-gradient(180deg, rgba(13,14,17,.5), rgba(13,14,17,.66)); }
.newsletter .container{ position:relative; z-index:2; text-align:center; }
.nl-form{ display:flex; gap:12px; max-width:520px; margin:30px auto 0; }
.nl-form input{ flex:1; background:rgba(13,14,17,.5); border:1px solid var(--line); color:var(--ink); padding:15px 18px; border-radius:2px; font-family:inherit; font-size:.95rem; transition:border-color .25s; backdrop-filter:blur(4px); }
.nl-form input:focus{ outline:none; border-color:var(--accent); }
.nl-form input::placeholder{ color:var(--muted); }
.nl-note{ font-size:.8rem; color:var(--muted); margin-top:16px; }
.nl-ok{ color:var(--accent); margin-top:18px; font-size:1rem; min-height:1.2em; }

/* ============================ CONTACT ============================ */
.contact{ background:var(--bg); }
.contact__grid{ grid-template-columns:1fr 1fr; gap:clamp(34px,5vw,80px); align-items:start; }
.contact-cards{ display:grid; gap:22px; }
.cc{ display:flex; gap:20px; align-items:center; padding:20px; background:var(--bg-elev); border:1px solid var(--line-soft); border-radius:4px; transition:.3s var(--ease); }
.cc:hover{ border-color:var(--line); transform:translateY(-3px); }
.cc__img{ flex:0 0 92px; width:92px; aspect-ratio:4/5; border-radius:12px; overflow:hidden; background:var(--bg-elev2); }
.cc__img img{ width:100%; height:100%; object-fit:cover; }
.cc h4{ font-family:var(--font-display); font-size:1.4rem; font-weight:500; margin:0; }
.cc .role{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--accent); margin:3px 0 10px; }
.cc .row{ display:flex; gap:8px; align-items:center; font-size:.9rem; color:var(--ink-dim); margin:3px 0; }
.cc .row svg{ width:15px; height:15px; color:var(--muted); flex:0 0 15px; }
.cc .row a:hover{ color:var(--accent); }

.contact-form{ display:grid; gap:16px; }
.contact-form .field{ display:grid; gap:7px; }
.contact-form label{ font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; color:var(--muted); }
.contact-form input,.contact-form textarea{ background:var(--bg-elev); border:1px solid var(--line); color:var(--ink); padding:14px 16px; border-radius:2px; font-family:inherit; font-size:.96rem; transition:border-color .25s; }
.contact-form input:focus,.contact-form textarea:focus{ outline:none; border-color:var(--accent); }
.contact-form textarea{ resize:vertical; min-height:120px; }
.contact-form .row2{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.form-ok{ color:var(--accent); min-height:1.2em; font-size:.92rem; }

.contact-meta{ display:flex; flex-wrap:wrap; gap:28px; margin-top:24px; padding-top:24px; border-top:1px solid var(--line-soft); }
.contact-meta .blk .lbl{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--muted); }
.contact-meta .blk a,.contact-meta .blk span{ font-size:1.02rem; color:var(--ink); }
.contact-meta .blk a:hover{ color:var(--accent); }

/* ============================ FOOTER ============================ */
.footer{ background:#0a0b0d; border-top:1px solid var(--line-soft); padding-block:clamp(50px,7vh,84px); }
.footer__top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
.footer__brand img{ height:72px; margin-bottom:16px; }
.footer__brand p{ color:var(--muted); max-width:34ch; font-size:.92rem; }
.footer__nav{ display:flex; gap:60px; flex-wrap:wrap; }
.footer__col h5{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--accent); margin:0 0 14px; }
.footer__col a{ display:block; color:var(--ink-dim); font-size:.92rem; padding:5px 0; transition:color .2s; }
.footer__col a:hover{ color:var(--ink); }
.footer__bottom{ margin-top:clamp(40px,6vh,64px); padding-top:24px; border-top:1px solid var(--line-soft); display:flex; justify-content:space-between; gap:20px; flex-wrap:wrap; color:var(--muted); font-size:.82rem; }
.footer__social{ display:flex; gap:16px; }
.footer__social a{ color:var(--ink-dim); transition:.25s; } .footer__social a:hover{ color:var(--accent); transform:translateY(-2px); }
.footer__social svg{ width:20px; height:20px; }

/* ============================ REVEAL / PARALLAX ============================ */
.reveal{ opacity:1; }  /* bez JS viditelné */
.js .reveal{ opacity:0; transform:translateY(30px); transition:opacity 1s var(--ease), transform 1.1s var(--ease); }
.reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }
.reveal[data-d="4"]{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1; transform:none; transition:none; } }

.section-num{ position:absolute; top:clamp(28px,5vh,64px); right:var(--pad); font-family:var(--font-display); font-size:.9rem; color:var(--muted); letter-spacing:.1em; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 1000px){
  .nav__links, .nav__social{ display:none; }
  .nav__burger{ display:grid; place-items:center; }
  .intro__grid, .feature__grid, .mapsec__grid, .about__intro, .founders__grid, .profiles, .contact__grid, .sd__intro{ grid-template-columns:1fr; }
  .shows-grid{ grid-template-columns:repeat(3,1fr); }
  .feature__grid{ min-height:auto; }
  .feature__media{ min-height:54vh; }
  .feature__media::after{ background:linear-gradient(0deg, var(--bg), transparent 40%); }
  .steps__grid{ grid-template-columns:1fr 1fr; }
  .intro__media{ aspect-ratio:16/10; }
  .hero__meta{ display:none; }
  .scroll-cue{ display:none; }
}
@media (max-width: 620px){
  .steps__grid, .team, .contact-form .row2{ grid-template-columns:1fr; }
  .shows-grid{ grid-template-columns:1fr; gap:16px; }   /* mobil: každý pořad na svůj řádek */
  .sd__pager{ max-width:46%; font-size:.8rem; }
  .sd__pager span{ display:none; }
  .profile{ grid-template-columns:96px 1fr; gap:18px; }
  .ms{ grid-template-columns:78px 1fr; gap:16px; }
  .gallery__grid{ grid-template-columns:repeat(6,1fr); grid-auto-rows:130px; }
  .g-wide,.g-big{ grid-column:span 6; grid-row:span 2; }
  .g-tall{ grid-column:span 3; grid-row:span 2; }
  .g-sq,.g-med,.g-s4{ grid-column:span 3; grid-row:span 1; }
  .tl-row{ grid-template-columns:64px 1fr; }
  .tl-place{ display:none; }
  .cc{ flex-direction:column; text-align:center; align-items:center; }
  .cc__img{ flex:none; width:min(170px,46vw); aspect-ratio:4/5; }   /* na mobilu obdélník na výšku, ne čtverec */
  .cc .row{ justify-content:center; }
  .nl-form{ flex-direction:column; }
}

/* Detail pořadu — statistiky + sdílení (M9/M10) */
.sd__actions{ display:flex; align-items:center; justify-content:space-between; gap:18px; flex-wrap:wrap; margin:4px 0 28px; padding:14px 0; border-top:1px solid var(--line-soft); border-bottom:1px solid var(--line-soft); }
.polozka-stats{ display:flex; align-items:center; gap:16px; }
.lajk-btn{ background:transparent; border:1px solid var(--line); color:var(--ink-dim); border-radius:999px; padding:7px 16px; font:600 .9rem var(--font-sans); cursor:pointer; transition:.2s; }
.lajk-btn:hover{ border-color:var(--accent); color:var(--ink); }
.lajk-btn.lajknuto{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.polozka-stats .vid{ color:var(--muted); font-size:.9rem; }
.sdileni{ display:flex; align-items:center; gap:8px; }
.sd-share{ display:inline-flex; align-items:center; justify-content:center; width:38px; height:38px; border:1px solid var(--line); border-radius:50%; color:var(--ink-dim); background:transparent; cursor:pointer; transition:.2s; }
.sd-share svg{ width:18px; height:18px; }
.sd-share:hover{ border-color:var(--accent); color:var(--accent); transform:translateY(-2px); }
.sd-share.zkopirovano{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }

/* Galerie — jednotný formát 4:3, 4 fotky na řádek přes celou šířku (žádné díry) */
.gallery__grid{ grid-template-columns:repeat(4,1fr) !important; grid-auto-rows:auto !important; gap:8px !important; }
.gallery__item{ aspect-ratio:4/3; margin:0 !important;   /* <figure> má defaultní margin 40px po stranách → dělalo „mezery" */
  border:1px solid color-mix(in srgb, var(--accent) 38%, transparent); transition:border-color .3s var(--ease); }
.gallery__item:hover{ border-color:var(--accent); }
.gallery__item.g-wide,.gallery__item.g-tall,.gallery__item.g-sq,.gallery__item.g-big,.gallery__item.g-med,.gallery__item.g-s4{ grid-column:auto !important; grid-row:auto !important; }
@media (max-width:980px){ .gallery__grid{ grid-template-columns:repeat(3,1fr) !important; } }
@media (max-width:620px){ .gallery__grid{ grid-template-columns:repeat(2,1fr) !important; } }

/* Autor webu v patičce */
.footer__author{ display:inline-block; margin-left:14px; padding-left:14px; border-left:1px solid var(--line); color:var(--muted); }
.footer__author a{ color:var(--accent); transition:opacity .2s; }
.footer__author a:hover{ opacity:.75; }
@media (max-width:560px){ .footer__author{ display:block; margin:8px 0 0; padding:0; border:0; } }

/* Zarovnání inline-editovaného textu (platí i pro veřejnost) */
[data-align="left"]{ text-align:left; }
[data-align="center"]{ text-align:center; }
[data-align="right"]{ text-align:right; }
[data-align="justify"]{ text-align:justify; }

/* Video + popis vedle (detail pořadu) — popis stejně vysoký jako video, vyplní zbytek šířky */
.video-row{ margin-bottom:18px; max-width:760px; }            /* samostatné video bez popisu */
.video-row .trailer{ margin-top:0; }
.video-row.has-desc{ max-width:none; display:flex; gap:24px; align-items:stretch; }
.video-row.has-desc .trailer{ flex:0 0 60%; }                 /* video box (16:9 určí výšku řádku) */
.video-popis{ flex:1; min-width:0; overflow-y:auto; color:var(--ink-dim); font-size:1.02rem; line-height:1.7; font-weight:350; }
@media (max-width:760px){
  .video-row.has-desc{ flex-direction:column; gap:14px; }
  .video-row.has-desc .trailer{ flex:none; }
}

/* Tlumený badge pro archivní pořady (ať 21 štítků nekřičí akcentem) */
.show-tile__badge--archiv{ background:rgba(13,14,17,.66); color:var(--ink-dim); font-weight:600; }

/* Drobná atribuce map pod mapou */
.map-attr{ margin:8px 2px 0; font-size:.7rem; color:var(--muted); text-align:right; letter-spacing:.02em; }
.map-attr a{ color:var(--muted); text-decoration:underline; text-underline-offset:2px; }
.map-attr a:hover{ color:var(--ink-dim); }

/* Lightbox — lajky + zhlédnutí fotky */
.lb__stage{ position:relative; display:inline-flex; max-width:90vw; max-height:80vh; }
.lb__hint{
  position:absolute; bottom:100%; left:50%; transform:translateX(-50%); margin-bottom:12px; z-index:3;
  background:rgba(13,14,17,.6); color:#e9e4d9; border:1px solid rgba(243,239,231,.16);
  border-radius:999px; padding:6px 14px; font:500 .78rem var(--font-sans); letter-spacing:.01em;
  white-space:nowrap; pointer-events:none; backdrop-filter:blur(6px);
  opacity:1; transition:opacity .4s; max-width:92vw; overflow:hidden; text-overflow:ellipsis;
}
.lb__hint.hide{ opacity:0; }
.lb__actions{ position:absolute; bottom:12px; right:12px; z-index:3; display:flex; align-items:center; gap:10px; }
.lb__lajk{ background:rgba(13,14,17,.55); border:1px solid rgba(243,239,231,.22); color:#fff; border-radius:999px; padding:7px 16px; font:600 .9rem var(--font-sans); cursor:pointer; transition:.2s; backdrop-filter:blur(6px); }
.lb__lajk:hover{ border-color:var(--accent); }
.lb__lajk.lajknuto{ background:var(--accent); color:var(--accent-ink); border-color:var(--accent); }
.lb__vid{ background:rgba(13,14,17,.55); border:1px solid rgba(243,239,231,.22); color:#fff; border-radius:999px; padding:7px 16px; font:600 .9rem var(--font-sans); backdrop-filter:blur(6px); white-space:nowrap; }

/* Lajky/zhlédnutí přímo na dlaždici fotky (srdíčko je klikací) */
.gallery__item .foto-meta{ position:absolute; right:7px; bottom:7px; z-index:4; display:inline-flex; align-items:center; gap:6px;
  background:rgba(13,14,17,.62); color:#fff; font-size:.7rem; padding:2px 7px; border-radius:999px; backdrop-filter:blur(6px); letter-spacing:.01em; }
.gallery__item .foto-like{ background:transparent; border:0; color:#fff; font:inherit; cursor:pointer; padding:2px 3px; display:inline-flex; align-items:center; gap:4px; transition:color .15s, transform .15s; }
.gallery__item .foto-like:hover{ color:var(--accent); transform:scale(1.12); }
.gallery__item .foto-like.liked{ color:var(--accent); }
.gallery__item .foto-views{ opacity:.92; }
