/* =====================================================================
   Volba pro město Vyškov — styly
   Design systém dle grafického manuálu (magenta / žlutá / krémová / růžová)
   ===================================================================== */

/* ---------- Tokeny: výchozí = TMAVÝ (magenta) ---------- */
:root{
  --magenta:#ce0f68;
  --magenta-deep:#a60b53;
  --yellow:#ffed00;
  --cream:#fcf7e0;
  --pink:#ffc0c7;

  /* sémantické */
  --bg:var(--magenta);
  --fg:var(--cream);
  --fg-dim:rgba(252,247,224,.74);
  --accent:var(--yellow);
  --ink:var(--magenta);              /* text na žluté/krémové */
  --soft:var(--pink);
  --panel:rgba(252,247,224,.07);
  --panel-bd:rgba(252,247,224,.20);
  --blob:rgba(255,192,199,.20);
  --bubble-bg:var(--yellow);
  --bubble-ink:var(--magenta);
  --bubble-shadow:rgba(120,5,58,.55);
  --cream-bubble-bg:var(--cream);
  --pill-bg:rgba(255,192,199,.18);
  --pill-ink:var(--cream);
  --header-bg:rgba(166,11,83,.72);
  --shadow-photo:0 30px 60px -25px rgba(80,4,40,.7);

  --maxw:1200px;
  --pad:clamp(1.1rem,4vw,3rem);
  --scene-len:84svh;       /* délka scrollu na jednu scénu */
  --r:18px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

[data-theme="light"]{
  --bg:var(--cream);
  --fg:var(--magenta);
  --fg-dim:rgba(166,11,83,.80);
  --accent:var(--yellow);
  --ink:var(--magenta);
  --panel:rgba(206,15,104,.05);
  --panel-bd:rgba(206,15,104,.16);
  --blob:var(--pink);
  --bubble-shadow:rgba(206,15,104,.30);
  --cream-bubble-bg:#fffdf3;
  --pill-bg:var(--pink);
  --pill-ink:var(--magenta);
  --header-bg:rgba(252,247,224,.78);
  --shadow-photo:0 30px 60px -28px rgba(166,11,83,.38);
}

/* Světlý režim: žlutá na krémové má nízký kontrast — proto velké žluté
   nápisy dostanou magenta obrys a akcentová slova žlutý „zvýrazňovač“. */
[data-theme="light"] .hero-lockup__2{
  -webkit-text-stroke:2px var(--magenta);
  paint-order:stroke fill;
}
[data-theme="light"] .site-header .brand__l2,
[data-theme="light"] .card__num,
[data-theme="light"] .leader__claim{color:var(--magenta)}
[data-theme="light"] .hl,
[data-theme="light"] .y{
  color:var(--magenta);
  background:var(--yellow);
  padding:0 .12em;border-radius:.12em;
  -webkit-box-decoration-break:clone;box-decoration-break:clone;
}
[data-theme="light"] .nametag b.y{color:var(--yellow);background:none;padding:0}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box}
*{margin:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;overflow-x:clip}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  background:var(--bg);
  color:var(--fg);
  font-family:'Fraunces',Georgia,'Times New Roman',serif;
  font-optical-sizing:auto;
  font-size:clamp(1rem,.95rem + .35vw,1.18rem);
  line-height:1.55;
  letter-spacing:.005em;
  overflow-x:hidden;
  transition:background-color .5s var(--ease),color .5s var(--ease);
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;color:inherit;cursor:pointer;background:none;border:none}
:focus-visible{outline:3px solid var(--accent);outline-offset:3px;border-radius:4px}

.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip-link{position:fixed;top:-100px;left:1rem;z-index:1000;background:var(--accent);color:var(--magenta);padding:.7rem 1.1rem;border-radius:10px;font-weight:700;transition:top .2s}
.skip-link:focus{top:1rem}

/* ---------- Typografie ---------- */
.eyebrow{font-weight:600;letter-spacing:.04em;font-size:clamp(.8rem,.75rem + .3vw,1rem)}
.headline,.section-title,.hero-lockup,.leader__name,.stat__num,.card__num{
  font-family:'Anton',Impact,'Arial Narrow Bold',sans-serif;
  font-weight:400;line-height:1;letter-spacing:.005em;
  text-transform:none;
}
.hl{color:var(--accent)}
.y{color:var(--accent)}
/* Anton + česká diakritika (Ě, Í, ů…) potřebuje volnější řádkování, ať mají řádky vzduch */
.headline{line-height:1.14}
.section-title{line-height:1.12}
.leader__name,.person__name{line-height:1.06}

/* ---------- Layout primitiva ---------- */
.wrap{width:min(100% - 2*var(--pad),var(--maxw));margin-inline:auto}
.section{padding-block:clamp(4rem,9vw,8rem);position:relative}
.section-head{max-width:46ch;margin-bottom:clamp(2rem,5vw,3.5rem)}
.section-title{font-size:clamp(2.6rem,7vw,5.2rem);margin:.5rem 0 .8rem}
.section-lead{color:var(--fg-dim);max-width:48ch;font-size:clamp(1.05rem,1rem + .4vw,1.3rem)}

/* ---------- Tlačítka ---------- */
.btn{display:inline-flex;align-items:center;gap:.5em;font-weight:700;
  padding:.8em 1.4em;border-radius:999px;line-height:1;white-space:nowrap;
  transition:transform .18s var(--ease),box-shadow .18s var(--ease),background-color .2s;
  will-change:transform}
.btn--accent{background:var(--accent);color:var(--magenta);box-shadow:0 8px 22px -10px rgba(0,0,0,.4)}
.btn--accent:hover{transform:translateY(-2px);box-shadow:0 14px 28px -12px rgba(0,0,0,.5)}
.btn--block{width:100%;justify-content:center;padding-block:1em;font-size:1.05rem}

/* ---------- Pilulky / štítky ---------- */
.pill{display:inline-block;background:var(--pill-bg);color:var(--pill-ink);
  font-weight:600;font-size:.85em;padding:.35em .9em;border-radius:999px;line-height:1.2}
.pill--soft{background:var(--pink);color:var(--magenta)}
.pill--accent{background:var(--accent);color:var(--magenta)}

/* ---------- Bubliny (se „zobáčkem“) ---------- */
.bubble{position:relative;display:inline-block;background:var(--bubble-bg);color:var(--bubble-ink);
  font-weight:600;padding:.7em 1.1em;border-radius:16px;line-height:1.18;
  filter:drop-shadow(6px 7px 0 var(--bubble-shadow));max-width:min(92vw,30ch)}
.bubble::before{content:"";position:absolute;top:-9px;left:18px;width:20px;height:14px;
  background:var(--bubble-bg);clip-path:polygon(0 100%,100% 100%,18% 0)}
.bubble--cream{background:var(--cream-bubble-bg);color:var(--magenta)}
.bubble--cream::before{background:var(--cream-bubble-bg)}
.bubble--big{font-size:clamp(1.1rem,1rem + .8vw,1.6rem);padding:.85em 1.2em}
.bubble--accent{background:var(--accent);color:var(--magenta)}

/* ---------- Vzor / mapa ---------- */
/* Mapa Vyškova jako velký kruhový výřez uprostřed scény.
   Pozadí mapy = barva stránky (krémová/magenta), proto „plavou“ jen cesty. */
.map-water{position:absolute;left:50%;top:50%;z-index:0;pointer-events:none;
  width:min(128vh,112%);aspect-ratio:1;transform:translate(-50%,-50%);
  background:center/cover no-repeat url(../img/mapa-vyskov-magenta.webp);
  opacity:.85;
  -webkit-mask:radial-gradient(circle at center,#000 50%,transparent 69%);
          mask:radial-gradient(circle at center,#000 50%,transparent 69%)}
[data-theme="light"] .map-water{background-image:url(../img/mapa-vyskov-cream.webp)}

/* =====================================================================
   HLAVIČKA
   ===================================================================== */
/* Hlavička: transparentní nad hero, plná barva až po odscrollování (jako starostove.cz) */
.site-header{position:fixed;inset-block-start:0;inset-inline:0;z-index:100;
  display:flex;align-items:center;gap:1rem;justify-content:space-between;
  padding:.9rem var(--pad);
  background:transparent;border-bottom:1px solid transparent;
  transition:background-color .35s var(--ease),border-color .35s var(--ease),backdrop-filter .35s}
.site-header.is-scrolled{background:var(--header-bg);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border-bottom-color:var(--panel-bd)}
/* Při otevřeném menu zruš backdrop-filter — jinak by vytvořil containing block
   pro fixní overlay a ten by se scvrkl na lištu hlavičky (rozbité menu uprostřed stránky). */
.nav-open .site-header{backdrop-filter:none;-webkit-backdrop-filter:none}
.brand{display:flex;align-items:baseline;gap:.5rem;line-height:1;z-index:2}
.brand__lockup{font-family:'Anton',sans-serif;text-transform:uppercase;font-size:1.18rem;letter-spacing:.01em;display:inline-flex;gap:.32em}
.brand__l1{color:var(--fg)}
.brand__l2{color:var(--accent)}
.brand__tag{font-weight:700;font-size:.82rem;color:var(--fg-dim)}

/* Navigace — verzálky, prostrkané (vzhled jako STAN) */
.site-nav{display:flex;align-items:center;gap:clamp(1rem,2vw,2rem);
  text-transform:uppercase;letter-spacing:.07em;font-weight:700;font-size:.92rem}
.site-nav a:not(.btn){position:relative;color:var(--fg);padding:.3rem .1rem;transition:color .2s}
.site-nav a:not(.btn)::after{content:"";position:absolute;left:.1rem;right:.1rem;bottom:-3px;height:2px;
  background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .25s var(--ease)}
.site-nav a:not(.btn):hover::after,.site-nav a:not(.btn):focus-visible::after,
.site-nav a:not(.btn).is-active::after{transform:scaleX(1)}
.nav-cta{display:none}
.header-actions{display:flex;align-items:center;gap:.7rem;z-index:2}

/* Akce jako obtažená pilulka */
.btn--ghost{background:transparent;border:2px solid var(--accent);color:var(--accent);
  text-transform:uppercase;letter-spacing:.05em;font-weight:700;font-size:.86rem;padding:.62em 1.25em}
.btn--ghost:hover{background:var(--accent);color:var(--magenta);transform:translateY(-1px)}
[data-theme="light"] .btn--ghost{border-color:var(--magenta);color:var(--magenta)}
[data-theme="light"] .btn--ghost:hover{background:var(--magenta);color:var(--cream)}

.theme-toggle{width:42px;height:42px;border-radius:50%;border:1px solid var(--panel-bd);
  display:grid;place-items:center;background:var(--panel);transition:transform .2s;flex:none}
.theme-toggle:hover{transform:rotate(20deg)}
.theme-toggle__icon{width:18px;height:18px;border-radius:50%;background:var(--accent);
  box-shadow:inset -6px -6px 0 0 var(--bg);transition:box-shadow .4s var(--ease),background-color .3s}
[data-theme="light"] .theme-toggle__icon{box-shadow:inset 0 0 0 2px var(--magenta);background:var(--yellow)}

/* Hamburger (jen mobil) */
.nav-toggle{display:none;width:44px;height:44px;border:0;background:transparent;cursor:pointer;
  align-items:center;justify-content:center;flex:none;z-index:2}
.nav-toggle__bars,.nav-toggle__bars::before,.nav-toggle__bars::after{
  display:block;width:26px;height:2.5px;background:var(--fg);border-radius:3px;
  transition:transform .3s var(--ease),opacity .2s,background-color .2s}
.nav-toggle__bars{position:relative}
.nav-toggle__bars::before{content:"";position:absolute;left:0;top:-8px}
.nav-toggle__bars::after{content:"";position:absolute;left:0;top:8px}
.nav-open .nav-toggle__bars{background:transparent}
.nav-open .nav-toggle__bars::before{transform:translateY(8px) rotate(45deg)}
.nav-open .nav-toggle__bars::after{transform:translateY(-8px) rotate(-45deg)}

/* progress bar */
.scroll-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:101;background:transparent;pointer-events:none}
.scroll-progress span{display:block;height:100%;width:0;background:var(--accent);transition:width .1s linear}

/* =====================================================================
   PŘÍBĚH — připnuté jeviště se scénami
   ===================================================================== */
.story{position:relative}
.stage{position:static}
.scene{position:relative;min-height:100svh;display:grid;place-items:center;
  padding:max(7svh,5rem) var(--pad);overflow:hidden}
.scene__inner{position:relative;width:min(100%,var(--maxw));margin-inline:auto;min-height:min(86svh,720px);
  display:grid;align-content:center}
.el{will-change:transform,opacity}

/* --- SNAP režim (desktop, JS): story je vlastní scroll-snap kontejner,
       každá scéna je celoobrazovkový panel a vždy „zaklapne“ na své místo.
       Žádné mezistavy s překrytím dvou scén. --- */
.story.is-snap{height:100svh;overflow:hidden;
  scrollbar-width:none;-ms-overflow-style:none}
.story.is-snap::-webkit-scrollbar{width:0;height:0;display:none}
.story.is-snap .stage{display:block}
.story.is-snap .scene{height:100svh;min-height:0}
.story.is-snap .scene__inner{min-height:0;height:100%}
/* prvky se poskládají z různých stran, jakmile scéna zaklapne */
.story.is-snap .el{opacity:0;transition:opacity .6s var(--ease),transform .8s var(--ease)}
.story.is-snap .el[data-from="left"]{transform:translateX(-55px)}
.story.is-snap .el[data-from="right"]{transform:translateX(90px)}
.story.is-snap .el[data-from="top"]{transform:translateY(-42px)}
.story.is-snap .el[data-from="bottom"]{transform:translateY(70px)}
.story.is-snap .el[data-from="scale"]{transform:scale(.86)}
.story.is-snap .scene.in .el{opacity:1;transform:none}

/* --- Stacked režim (mobil, reduced-motion, no-JS): scény pod sebou v toku --- */
.story:not(.is-snap) .scene{min-height:auto;display:block;padding-block:clamp(3rem,9vw,5.5rem)}
.story:not(.is-snap) .scene__inner{display:flex;flex-direction:column;align-items:flex-start;gap:1.2rem;min-height:0;height:auto;padding-inline-end:0}
.story:not(.is-snap) .scene--team .scene__inner{align-items:center;text-align:center}
.story:not(.is-snap) .headline{max-width:none}
.story:not(.is-snap) .photo--duo,
.story:not(.is-snap) .cutout--right{position:static;right:auto;bottom:auto;align-self:center;margin:0}
.story:not(.is-snap) .photo--duo{width:min(86%,380px)}
.story:not(.is-snap) .photo--duo img{width:100%;max-height:46svh}
.story:not(.is-snap) .cutout--right{width:min(70%,300px)}
.story:not(.is-snap) .photo__tags{position:static;margin-top:.7rem;flex-direction:row;justify-content:flex-start;gap:1.2rem}
.story:not(.is-snap) .map-water{width:min(124vw,540px);opacity:.6}
.story:not(.is-snap) .quote{max-width:100%}

/* ---- Scéna 0: intro lockup ---- */
.scene--intro .scene__inner{position:relative;justify-items:start;text-align:left}
.hero-lockup{font-family:'Anton',sans-serif;text-transform:uppercase;line-height:1.28;
  font-size:clamp(3.6rem,min(17vw,16svh),13rem);display:block}
.hero-lockup__1{display:block;color:var(--fg)}
.hero-lockup__2{display:block;color:var(--accent)}
/* horní řádek: Vyškov + badge na stejné úrovni a stejně vysoké */
.intro-head{display:flex;align-items:stretch;flex-wrap:wrap;gap:.5rem 1rem;
  margin-bottom:clamp(.6rem,2.4svh,1.5rem)}
.hero-place{font-family:'Anton',sans-serif;text-transform:uppercase;
  font-size:clamp(1.2rem,.9rem + 1.1vw,2rem);color:var(--fg);margin:0;letter-spacing:.06em;
  display:flex;align-items:center}
.scene--intro .eyebrow{display:inline-flex;align-items:center;
  background:var(--pill-bg);color:var(--pill-ink);padding:0 1.1em;border-radius:999px;margin:0}
/* „s podporou STAROSTOVÉ" do pravého dolního rohu intra */
.support-bubble--corner{position:absolute;right:0;bottom:0;margin:0;align-self:end}
.scene--intro .scroll-cue{margin-top:clamp(1rem,3svh,2.4rem)}
.support-bubble{display:inline-flex;flex-direction:column;line-height:1;gap:.15em}
.support-bubble .bubble__sup{font-weight:600;font-size:.62em;font-style:italic}
.support-bubble .bubble__main{font-family:'Fraunces',serif;font-weight:900;font-style:italic;font-size:1.5em;letter-spacing:.01em}
.scroll-cue{margin-top:2.2rem;font-style:italic;color:var(--fg-dim);font-size:.95rem;display:flex;align-items:center;gap:.6rem}
.scroll-cue span::after{content:"";display:inline-block;width:1px;height:34px;margin-left:.6rem;background:currentColor;vertical-align:middle;animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}40%{transform:scaleY(1);transform-origin:top}60%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

/* ---- Scény s nadpisem + fotkou ---- */
/* velikost omezená i výškou viewportu (svh), ať se nadpis vejde i na nižší obrazovky (MacBook) */
.headline{font-size:clamp(1.55rem,min(1.1rem + 2.9vw,4.6svh),3.3rem);max-width:18ch}
.headline--sub{font-size:clamp(1.2rem,min(1rem + 1.8vw,3svh),2.4rem);margin-top:.5rem;opacity:.96}
.lead{font-size:clamp(1.15rem,1rem + 1vw,1.7rem);max-width:30ch;color:var(--fg)}

.scene--story1 .scene__inner{display:grid;align-content:start;position:relative}
.scene--story1 .headline{position:relative;z-index:3;max-width:min(46%,20ch);padding-top:clamp(2.75rem,8.5svh,6rem);
  font-size:clamp(2rem,min(1.3rem + 3.4vw,6.4svh),4.6rem)}
.photo,.cutout{position:relative}
.photo--duo{position:absolute;right:0;bottom:0;width:min(54%,600px);z-index:2;margin:0}
.photo--duo img{width:100%;max-height:58svh;object-fit:cover;border-radius:var(--r);box-shadow:var(--shadow-photo)}
.photo__tags{position:absolute;left:4%;right:4%;bottom:5%;display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.nametag{display:flex;flex-direction:column;gap:.35rem;align-items:flex-start}
.nametag b{font-family:'Anton',sans-serif;font-size:clamp(1rem,2.4vw,1.7rem);color:var(--cream);text-shadow:2px 2px 4px rgba(0,0,0,.55)}
.nametag b.y{color:var(--yellow)}

/* scény s cutoutem vpravo — postava vystupuje z kruhového fleku (jako lídr),
   svisle vystředěná na viewport (top+margin místo transform kvůli snap enginu) */
.cutout--right{position:absolute;right:-1%;top:50%;--cw:min(43%,520px,62svh);
  width:var(--cw);aspect-ratio:4/5;margin-top:calc(var(--cw) * -0.625);z-index:1}
.cutout--right::before{content:"";position:absolute;left:0;bottom:0;width:100%;aspect-ratio:1;
  border-radius:50%;background:var(--blob);z-index:0}
.cutout--right img{position:relative;z-index:1;display:block;width:100%;height:100%;
  object-fit:contain;object-position:bottom;
  -webkit-mask:linear-gradient(#000 0 0) top/100% 60% no-repeat,radial-gradient(50% 40% at 50% 60%,#000 99%,#0000 100%);
          mask:linear-gradient(#000 0 0) top/100% 60% no-repeat,radial-gradient(50% 40% at 50% 60%,#000 99%,#0000 100%);
  filter:drop-shadow(0 12px 16px rgba(0,0,0,.24))}
.scene--story2 .scene__inner,.scene--story3 .scene__inner,.scene--story4 .scene__inner{align-content:center;justify-items:start;margin-inline:0;width:min(100%,var(--maxw));padding-inline-end:clamp(0px,46%,520px)}
.scene--story2 .headline,.scene--story4 .headline{position:relative;z-index:2}
.scene--story2 .bubble{margin-top:1.4rem}
.scene--story4 .bubble{margin-top:1rem}

/* scéna 3 — citace */
.scene--story3 .scene__inner{position:relative}
.quote{position:relative;z-index:2;max-width:34ch;margin-top:1.2rem;
  background:var(--cream-bubble-bg);color:var(--magenta);padding:1.3rem 1.5rem;border-radius:var(--r);
  filter:drop-shadow(8px 9px 0 var(--bubble-shadow))}
.quote p{font-size:clamp(1.05rem,1rem + .7vw,1.4rem);line-height:1.45}
.quote cite{display:block;margin-top:.8rem;font-weight:700;font-style:normal;font-size:.95rem}
.scene--story3 .headline{position:relative;z-index:2}

/* scéna 4 — otevřená radnice */
.scene--story4 .lead{margin-top:1.2rem}

/* scéna 5 — tým: vykreslený lockup + vyříznutý tým (velká, široká fotka)
   symetrický padding ≥ výška fixní navigace (65px) → obsah je svisle vycentrovaný a lockup nezajede pod menu */
.scene--team{padding-top:calc(clamp(4.5rem,7svh,5rem) + 4rem);padding-bottom:clamp(4.5rem,7svh,5rem)}
.scene--team .scene__inner{display:flex;flex-direction:column;justify-content:center;align-items:center;
  text-align:center;height:100%;min-height:0;gap:clamp(.3rem,1.2svh,.8rem)}
.hero-lockup--team{font-size:clamp(1.7rem,min(6vw,5.6svh),3.6rem);line-height:1.08;text-align:center;flex:0 0 auto}
.hero-lockup__pre{display:block;font-family:'Fraunces',serif;font-style:italic;text-transform:none;
  font-weight:500;font-size:.46em;line-height:1;color:var(--fg);opacity:.92;
  letter-spacing:.01em;margin-bottom:.1em}
.hero-lockup__post{margin-bottom:0;margin-top:.18em}
.support-bubble--top{margin:0;flex:0 0 auto}
.photo--team{width:min(100%,1400px);margin:0;flex:0 1 auto;min-height:0;display:flex;justify-content:center}
.photo--team img{display:block;width:auto;height:auto;max-width:100%;max-height:60svh;
  filter:drop-shadow(0 22px 30px rgba(0,0,0,.28))}
.team-caption{font-style:italic;color:var(--fg-dim);margin:0;flex:0 0 auto}
/* mobil / stacked: lockup a fotka pod sebou v toku */
.story:not(.is-snap) .scene--team{padding-block:clamp(3rem,9vw,5.5rem)}
.story:not(.is-snap) .scene--team .scene__inner{justify-content:flex-start;height:auto}
.story:not(.is-snap) .photo--team{width:min(100%,680px);flex:none}
.story:not(.is-snap) .photo--team img{max-height:none}
.story:not(.is-snap) .team-caption{margin-top:1rem;color:var(--fg)}

/* =====================================================================
   MOBIL (≤700px) — příběh jako svislé „stories" se snapem.
   Vlastní JS engine je tu vypnutý (ovládá kolečko, ne dotyk), takže
   používáme NATIVNÍ CSS scroll-snap, který jede plynule pod prstem.
   Layout: každá scéna = celý viewport, TEXT NAHOŘE → FOTO DOLE, na střed.
   ===================================================================== */
@media (max-width:700px){
  /* story = vlastní svislý snap kontejner (izolovaný od zbytku stránky) */
  .story:not(.is-snap){
    height:100svh;overflow-y:auto;
    scroll-snap-type:y mandatory;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .story:not(.is-snap)::-webkit-scrollbar{width:0;height:0;display:none}
  .story:not(.is-snap) .stage{display:block}

  /* každá scéna „zaklapne" na celý viewport */
  .story:not(.is-snap) .scene{
    min-height:100svh;height:100svh;
    display:grid;place-items:center;
    scroll-snap-align:start;scroll-snap-stop:always;
    padding:calc(3.5rem + env(safe-area-inset-top)) var(--pad) 1.4rem;
    overflow:hidden;
  }
  /* obsah svisle, vystředěný: text → foto */
  .story:not(.is-snap) .scene__inner{
    display:flex;flex-direction:column;
    align-items:center;justify-content:center;
    text-align:center;
    width:100%;height:100%;min-height:0;
    gap:clamp(.9rem,2.8svh,1.5rem);padding-inline-end:0;
  }

  /* text vystředit a omezit šířku pro čitelnost */
  .story:not(.is-snap) .headline{max-width:20ch;margin:0}
  .story:not(.is-snap) .scene--story1 .headline{font-size:clamp(1.7rem,7vw,2.4rem);padding-top:0;max-width:17ch}
  .story:not(.is-snap) .headline--sub{margin-top:0}
  .story:not(.is-snap) .bubble,
  .story:not(.is-snap) .lead{margin-inline:auto}
  .story:not(.is-snap) .quote{max-width:32ch;margin:0 auto;text-align:left}

  /* fotky do toku dole, výškově omezené ať se vejdou s textem */
  .story:not(.is-snap) .cutout--right{
    position:static;inset:auto;margin:0 auto;align-self:center;
    width:min(58%,230px);aspect-ratio:4/5;margin-top:0;
  }
  .story:not(.is-snap) .cutout--right img{max-height:40svh}
  .story:not(.is-snap) .photo--duo{position:relative;inset:auto;margin:0 auto;align-self:center;width:min(92%,420px)}
  .story:not(.is-snap) .photo--duo img{width:100%;height:auto;max-height:34svh;object-fit:cover}
  /* jmenovky zpět jako overlay na spodek fotky (čitelné v obou režimech) */
  .story:not(.is-snap) .photo__tags{position:absolute;left:0;right:0;bottom:0;inset-block-start:auto;
    margin:0;padding:.85rem .8rem .7rem;flex-direction:row;justify-content:space-between;
    align-items:flex-end;gap:.5rem;
    background:linear-gradient(180deg,transparent,rgba(0,0,0,.55));border-radius:0 0 var(--r) var(--r)}
  .story:not(.is-snap) .photo__tags .nametag b{text-shadow:2px 2px 4px rgba(0,0,0,.6)}

  /* mapa pod story1 jen jako jemný podklad */
  .story:not(.is-snap) .map-water{width:min(150vw,520px);opacity:.4}

  /* intro vystředit */
  .story:not(.is-snap) .scene--intro .scene__inner{justify-items:center;align-items:center;text-align:center}

  /* tým — taky celý viewport, foto pod lockupem */
  .story:not(.is-snap) .scene--team{padding-block:calc(3.5rem + env(safe-area-inset-top)) 1.4rem}
  .story:not(.is-snap) .scene--team .scene__inner{justify-content:center;height:100%}
  .story:not(.is-snap) .photo--team{width:min(100%,520px);flex:0 1 auto}
  .story:not(.is-snap) .photo--team img{max-height:42svh;width:auto;max-width:100%}
  .story:not(.is-snap) .team-caption{margin-top:0}
}

/* =====================================================================
   REVEAL animace (běžné sekce)
   ===================================================================== */
.reveal{opacity:0;transform:translateY(38px);transition:opacity .7s var(--ease),transform .7s var(--ease);transition-delay:calc(var(--i,0) * 80ms)}
.reveal[data-from="left"]{transform:translateX(-46px)}
.reveal[data-from="right"]{transform:translateX(46px)}
.reveal.in{opacity:1;transform:none}

/* =====================================================================
   PROGRAM
   ===================================================================== */
.section--program{border-top:1px solid var(--panel-bd)}
.cards{list-style:none;padding:0;display:grid;gap:1.1rem;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr))}
.card{background:var(--panel);border:1px solid var(--panel-bd);border-radius:var(--r);
  padding:clamp(1.4rem,3vw,2rem);display:flex;flex-direction:column;gap:.6rem;
  transition:transform .25s var(--ease),background-color .25s,border-color .25s}
.card:hover{transform:translateY(-6px);border-color:var(--accent)}
.card__num{font-family:'Anton',sans-serif;font-size:2.2rem;color:var(--accent);line-height:1}
.card__title{font-family:'Anton',sans-serif;font-weight:400;font-size:1.5rem;line-height:1}
.card p{color:var(--fg-dim);font-size:1rem}
.card--cta{background:var(--accent);border-color:var(--accent);color:var(--magenta)}
.card--cta .card__title{color:var(--magenta)}
.card--cta p{color:var(--magenta);opacity:.85}
.card--cta .btn{margin-top:auto;background:var(--magenta);color:var(--cream)}

/* =====================================================================
   LIDÉ
   ===================================================================== */
.section--people{background:var(--panel)}
.leader{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:clamp(1.5rem,4vw,3.5rem);
  align-items:center;margin-bottom:clamp(2.5rem,6vw,4.5rem)}
/* kruhový flek = „díra“: spodek postavy ořezaný přesně podle kruhu,
   hlava nahoře volně přesahuje ven; na hover se celý medailonek zvětší */
.leader__photo{position:relative;align-self:end;justify-self:center;
  width:min(84%,380px);aspect-ratio:4/5;
  transition:transform .45s var(--ease);transform-origin:center bottom}
.leader__photo::before{content:"";position:absolute;left:0;bottom:0;width:100%;aspect-ratio:1;
  border-radius:50%;background:var(--blob);z-index:0;box-shadow:0 22px 40px -22px rgba(70,3,33,.3)}
.leader__photo img{position:relative;z-index:1;display:block;width:100%;height:100%;
  object-fit:contain;object-position:bottom;
  -webkit-mask:linear-gradient(#000 0 0) top/100% 60% no-repeat,
               radial-gradient(50% 40% at 50% 60%,#000 99%,#0000 100%);
          mask:linear-gradient(#000 0 0) top/100% 60% no-repeat,
               radial-gradient(50% 40% at 50% 60%,#000 99%,#0000 100%);
  filter:drop-shadow(0 12px 16px rgba(0,0,0,.16))}
.leader__photo:hover{transform:scale(1.045)}
@media (prefers-reduced-motion: reduce){
  .leader__photo{transition:none}
  .leader__photo:hover{transform:none}
}
.leader__name{font-size:clamp(2.4rem,6vw,4rem);margin:.4rem 0 .6rem}
.leader__claim{font-size:clamp(1.2rem,1rem + 1vw,1.7rem);font-style:italic;line-height:1.4;max-width:30ch}
.leader__role{margin-top:1rem;color:var(--fg-dim);max-width:40ch}

.people-grid{display:grid;gap:1.4rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,300px),1fr))}
.person{position:relative;overflow:hidden;background:var(--bg);border:1px solid var(--panel-bd);
  border-radius:var(--r);min-height:clamp(260px,24vw,300px);transition:transform .25s var(--ease)}
.person:hover{transform:translateY(-6px)}
/* text vlevo: profese → jméno → popis */
.person__text{position:relative;z-index:2;width:62%;padding:1.5rem;
  display:flex;flex-direction:column;align-items:flex-start;gap:.5rem}
.person__role{margin:0;white-space:nowrap;font-size:1.08rem}
.person__name{font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(1.45rem,1.2rem + .7vw,1.85rem);line-height:1.05}
.person__note{color:var(--fg-dim);font-size:.95rem;line-height:1.45}
/* fotka / iniciály v pravém dolním rohu na „fleku“ (od kraje, jako u lídra) */
.person__media{position:absolute;right:0;top:12%;bottom:0;width:48%;max-width:210px;z-index:1;pointer-events:none}
.person__media::before{content:"";position:absolute;z-index:0;background:var(--blob);
  left:0;right:-14%;bottom:-14%;height:76%;border-radius:48% 52% 58% 42%/52% 44% 56% 48%}
.person__media--photo img{position:relative;z-index:1;display:block;width:100%;height:100%;
  object-fit:contain;object-position:bottom right;filter:drop-shadow(0 14px 20px rgba(0,0,0,.22));
  transform-origin:bottom right;transition:transform .45s var(--ease),filter .45s var(--ease)}
/* hover karty → plynulý zoom fotky, spodek/pravý okraj ukotvený u hrany */
.person:hover .person__media--photo img{transform:scale(1.1);
  filter:drop-shadow(0 20px 26px rgba(0,0,0,.28))}
@media (prefers-reduced-motion: reduce){
  .person__media--photo img{transition:none}
  .person:hover .person__media--photo img{transform:none}
}
/* karta bez fotky: žlutý medailonek s iniciálami v rohu */
.person__media--avatar{top:auto;right:1.3rem;bottom:1.3rem;width:clamp(74px,17%,96px);aspect-ratio:1;max-width:none}
.person__media--avatar::before{inset:0;left:0;right:0;bottom:0;height:auto;background:var(--accent);border-radius:50%}
.person__media--avatar b{position:absolute;inset:0;z-index:1;display:grid;place-items:center;
  font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(1.7rem,4vw,2.4rem);color:var(--magenta)}

.team-claim{margin-top:clamp(2.4rem,6vw,4.4rem);text-align:center;
  display:flex;flex-direction:column;align-items:center;gap:clamp(.5rem,1.4vw,1rem)}
.team-claim__pre{font-family:'Fraunces',serif;font-style:italic;font-weight:600;
  font-size:clamp(1.05rem,1rem + .7vw,1.6rem);color:var(--fg-dim);letter-spacing:.01em}
.team-claim__main{font-family:'Anton',sans-serif;text-transform:uppercase;line-height:1.28;
  font-size:clamp(2.1rem,1.1rem + 4.6vw,5rem);max-width:15ch;color:var(--fg)}
.team-claim__main .hl{padding:.02em .14em;border-radius:.1em}

/* =====================================================================
   ČÍSLA
   ===================================================================== */
.section--stats{background:var(--accent);color:var(--magenta)}
[data-theme="light"] .section--stats{background:var(--magenta);color:var(--cream)}
.stats{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,200px),1fr));text-align:center;align-items:start}
.stat{display:flex;flex-direction:column;justify-content:flex-start}
.stat__num{font-family:'Anton',sans-serif;font-size:clamp(3rem,8vw,5.5rem);line-height:.95;display:block}
.stat__pre{display:block;font-family:'Fraunces',serif;font-weight:700;font-size:.26em;line-height:1.2;margin-bottom:.05em;letter-spacing:.02em}
.stat__label{font-weight:600;font-size:1rem;opacity:.85;margin-top:.4rem;display:block}

/* =====================================================================
   KONTAKT
   ===================================================================== */
.contact{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,320px),1fr));gap:clamp(2rem,5vw,4rem);align-items:start}
.contact__list{list-style:none;padding:0;margin-top:2rem;display:grid;gap:1rem}
.contact__list li{display:flex;flex-direction:column;gap:.15rem;border-top:1px solid var(--panel-bd);padding-top:.9rem}
.contact__k{font-weight:700;font-size:.82rem;letter-spacing:.04em;color:var(--fg-dim);text-transform:uppercase}
.contact__list a{font-size:1.1rem;border-bottom:2px solid var(--accent);width:fit-content}

.contact__form{background:var(--panel);border:1px solid var(--panel-bd);border-radius:var(--r);
  padding:clamp(1.4rem,3.5vw,2.4rem);display:grid;gap:1.1rem}
.form-row{display:grid;gap:.4rem}
.form-row label{font-weight:700;font-size:.95rem}
.opt{font-weight:400;color:var(--fg-dim);font-size:.85em}
.contact__form input,.contact__form textarea{
  font:inherit;font-size:1rem;color:var(--fg);background:var(--bg);
  border:1px solid var(--panel-bd);border-radius:12px;padding:.75em .9em;width:100%;
  transition:border-color .2s,box-shadow .2s}
.contact__form input::placeholder,.contact__form textarea::placeholder{color:var(--fg-dim);opacity:.7}
.contact__form input:focus,.contact__form textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--accent) 35%,transparent)}
.contact__form textarea{resize:vertical;min-height:120px}
.form-row--check{grid-template-columns:auto 1fr;align-items:start;gap:.7rem}
.form-row--check input{width:20px;height:20px;margin-top:.2rem;accent-color:var(--accent)}
.form-row--check label{font-weight:400;color:var(--fg-dim);font-size:.92rem}
.hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden}
.form-note{font-size:.92rem;color:var(--fg-dim);min-height:1.2em}
.form-note.ok{color:var(--accent);font-weight:700}
.form-note.err{color:#ffd2d8}

/* =====================================================================
   PATIČKA
   ===================================================================== */
.site-footer{position:relative;background:var(--magenta);color:var(--cream);padding-block:clamp(3rem,6vw,5rem) 2rem;overflow:hidden}
[data-theme="light"] .site-footer{background:var(--magenta);color:var(--cream)}
.pattern{position:absolute;inset:0;opacity:.10;pointer-events:none;
  background-image:radial-gradient(circle at 20% 30%,var(--pink) 0 22px,transparent 23px),
    radial-gradient(circle at 65% 18%,var(--pink) 0 28px,transparent 29px),
    radial-gradient(circle at 88% 60%,var(--pink) 0 24px,transparent 25px),
    radial-gradient(circle at 40% 75%,var(--pink) 0 30px,transparent 31px),
    radial-gradient(circle at 10% 88%,var(--pink) 0 20px,transparent 21px);
  background-size:340px 300px}
.footer__grid{position:relative;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(min(100%,220px),1fr));align-items:start}
.footer__brand .brand__lockup{font-size:1.6rem}
.footer__brand .brand__l1{color:var(--cream)}
.footer__tag{margin-top:.5rem;color:rgba(252,247,224,.8)}
.footer__tag i{color:var(--yellow);font-weight:900}
.footer__nav{display:flex;flex-direction:column;gap:.6rem;font-weight:600}
.footer__nav a{width:fit-content;border-bottom:2px solid transparent;transition:border-color .2s}
.footer__nav a:hover{border-color:var(--yellow)}
.footer__meta{color:rgba(252,247,224,.75);font-size:.9rem;display:grid;gap:.4rem}
.footer__disclaimer{font-style:italic;opacity:.7}
.footer__disclaimer a{color:var(--cream);text-decoration:underline;text-underline-offset:2px;transition:color .2s}
.footer__disclaimer a:hover{color:var(--yellow)}
.to-top{position:absolute;right:var(--pad);bottom:1.4rem;width:46px;height:46px;border-radius:50%;
  background:var(--yellow);color:var(--magenta);display:grid;place-items:center;font-size:1.3rem;font-weight:700;
  box-shadow:0 8px 20px -8px rgba(0,0,0,.5);transition:transform .2s}
.to-top:hover{transform:translateY(-3px)}

/* =====================================================================
   RESPONZIVITA
   ===================================================================== */
@media (max-width:860px){
  .nav-toggle{display:inline-flex}
  .header-cta{display:none}            /* desktopová pilulka skrytá, je v overlay menu */
  /* Navigace = celoobrazovkové překryvné menu (pod logem a křížkem, nad obsahem) */
  .site-nav{position:fixed;inset:0;z-index:1;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    gap:1.7rem;background:var(--bg);
    text-transform:uppercase;letter-spacing:.05em;font-size:1.7rem;
    padding:6rem var(--pad) 3rem;
    transform:translateY(-100%);opacity:0;visibility:hidden;
    transition:transform .4s var(--ease),opacity .3s,visibility .4s}
  .nav-open .site-nav{transform:translateY(0);opacity:1;visibility:visible}
  .site-nav a:not(.btn)::after{display:none}
  .site-nav a:not(.btn).is-active{color:var(--accent)}
  [data-theme="light"] .site-nav a:not(.btn).is-active{color:var(--magenta);text-decoration:underline;text-underline-offset:6px}
  .nav-cta{display:inline-flex;margin-top:.8rem;font-size:1rem}
  body.nav-open{overflow:hidden}

  .leader{grid-template-columns:1fr;text-align:center}
  .leader__photo{justify-self:center;margin-bottom:1rem}
  .leader__claim{margin-inline:auto}
}
@media (max-width:560px){
  .brand__tag{display:none}
  .nametag b{text-shadow:none}
  .hero-lockup{font-size:clamp(3rem,17vw,5rem)}
}

/* =====================================================================
   REDUCED MOTION — vše statické, scény naskládané
   ===================================================================== */
@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1;transform:none;transition:none}
  .el{opacity:1!important;transform:none!important}
  .scroll-cue,.theme-toggle{animation:none}
}
