:root{
	--text: #2b3027;
	--text-soft: #4a5246;
	--background: #f4f3e7;
	--background-2: #ecead8;
	--surface: #ffffff;
	--primary: #056c31;
	--primary-deep: #0a4126;
	--secondary: #b8cca7;
	--secondary-soft: #dfe7d2;
	--accent: #08a960;
	--sun: #fff8da;
	--sky: #cce4f1;
	--sky-deep: #6fa9d2;

	--radius-sm: 8px;
	--radius: 18px;
	--radius-lg: 28px;
	--shadow-sm: 0 2px 6px rgba(11,30,18,.06);
	--shadow: 0 18px 40px -18px rgba(11,30,18,.22);
	--shadow-lg: 0 40px 80px -30px rgba(11,30,18,.35);

	--ease: cubic-bezier(.22,.61,.36,1);
	--ease-out: cubic-bezier(.16,1,.3,1);
	--header-h: 84px;

	--container: 1200px;
}

/* ------------------------------ reset ------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;background:var(--background);color:var(--text);font-family:"Nata Sans","Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;font-size:17px;line-height:1.65;font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:0;background:transparent;color:inherit}
ul{list-style:none;padding:0;margin:0}
::selection{background:var(--primary);color:#fff}

@media (prefers-reduced-motion:reduce){
	*,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
}

/* ------------------------------ typography ------------------------------ */
h1,h2,h3,h4{font-family:"Rozha One",serif;font-weight:400;letter-spacing:-.01em;line-height:1.08;color:var(--text);margin:0}
h1{font-size:clamp(2.6rem,7vw,5.6rem)}
h2{font-size:clamp(2rem,4.6vw,3.6rem)}
h3{font-size:clamp(1.25rem,1.8vw,1.55rem);line-height:1.25}
em{font-style:italic;color:var(--primary)}

.eyebrow{display:inline-block;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--primary);margin-bottom:1rem}
.eyebrow--light{color:var(--secondary)}

p{margin:0 0 1em}

/* ------------------------------ layout ------------------------------ */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 28px}
.section{padding:clamp(80px,10vw,140px) 0;position:relative}
.section__head{max-width:780px;margin-bottom:64px}
.section__head--center{text-align:center;margin-left:auto;margin-right:auto}
.section__title{margin-bottom:18px}
.section__title--light{color:var(--background)}
.section__lead{font-size:1.15rem;color:var(--text-soft);max-width:62ch}

.container--split{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.container--reverse .split__media{order:2}
@media (max-width:880px){
	.container--split{grid-template-columns:1fr}
	.container--reverse .split__media{order:0}
}

/* ------------------------------ buttons ------------------------------ */
.btn{display:inline-flex;align-items:center;gap:.6em;padding:.95em 1.6em;border-radius:999px;font-weight:600;font-size:.98rem;letter-spacing:.01em;transition:transform .4s var(--ease-out),background .3s,color .3s,box-shadow .4s;will-change:transform}
.btn--primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-sm)}
.btn--primary:hover{background:var(--primary-deep);transform:translateY(-2px);box-shadow:var(--shadow)}
.btn--ghost{background:transparent;color:var(--text);border:1px solid color-mix(in srgb,var(--text) 25%, transparent)}
.btn--ghost:hover{background:var(--text);color:var(--background);transform:translateY(-2px)}

/* ------------------------------ loader ------------------------------ */
.loader{position:fixed;inset:0;background:var(--background);z-index:1000;display:grid;place-items:center;color:var(--primary);transition:opacity .6s var(--ease),visibility .6s}
.loader__inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.loader__mark{width:54px;height:54px;animation:bloom 2.6s var(--ease-out) infinite}
.loader__label{font-family:"Rozha One",serif;font-size:1.05rem;letter-spacing:.06em;color:var(--text);opacity:.7}
.is-loaded .loader{opacity:0;visibility:hidden}
@keyframes bloom{
	0%,100%{transform:scale(.85) rotate(-2deg);opacity:.8}
	50%{transform:scale(1.05) rotate(2deg);opacity:1}
}

/* ------------------------------ header ------------------------------ */
.site-header{position:fixed;top:0;left:0;right:0;z-index:50;display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:24px;padding:18px 28px;transition:background .35s var(--ease),box-shadow .35s var(--ease),padding .35s var(--ease)}
.site-header.is-scrolled{background:rgba(244,243,231,.86);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 1px 0 rgba(11,30,18,.06);padding-top:12px;padding-bottom:12px}

.logo{display:inline-flex;align-items:center;gap:12px;color:var(--primary)}
.logo__mark{width:34px;height:34px;flex:none}
.logo__text{display:flex;flex-direction:column;line-height:1.05;color:var(--text)}
.logo__text strong{font-family:"Rozha One",serif;font-weight:400;font-size:1.05rem;letter-spacing:.01em}
.logo__text em{font-style:normal;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--text-soft)}

.nav ul{display:flex;gap:6px;justify-content:center}
.nav__link{position:relative;display:inline-block;padding:10px 14px;border-radius:999px;font-size:.95rem;color:var(--text);transition:color .3s,background .3s}
.nav__link::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .45s var(--ease-out)}
.nav__link:hover{color:var(--primary)}
.nav__link:hover::after{transform:scaleX(1)}
.nav__link.is-active{color:var(--primary)}
.nav__link.is-active::after{transform:scaleX(1)}

.header-cta{display:inline-flex;align-items:center;gap:.55em;padding:.7em 1.1em;border-radius:999px;background:var(--text);color:var(--background);font-weight:600;font-size:.92rem;transition:transform .35s var(--ease-out),background .3s}
.header-cta svg{width:16px;height:16px}
.header-cta:hover{background:var(--primary);transform:translateY(-2px)}

.nav-toggle{display:none;width:42px;height:42px;border-radius:999px;border:1px solid color-mix(in srgb,var(--text) 18%, transparent);position:relative}
.nav-toggle span{position:absolute;left:11px;right:11px;height:1.5px;background:var(--text);transition:transform .35s var(--ease),opacity .25s,top .35s var(--ease)}
.nav-toggle span:nth-child(1){top:14px}
.nav-toggle span:nth-child(2){top:20px}
.nav-toggle span:nth-child(3){top:26px}
.nav-toggle[aria-expanded=true] span:nth-child(1){top:20px;transform:rotate(45deg)}
.nav-toggle[aria-expanded=true] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded=true] span:nth-child(3){top:20px;transform:rotate(-45deg)}

@media (max-width:980px){
	.site-header{grid-template-columns:auto 1fr auto}
	.header-cta{display:none}
	.nav-toggle{display:block;justify-self:end}
	.nav{position:fixed;inset:0 0 0 auto;width:min(360px,100%);background:var(--background);padding:calc(var(--header-h) + 20px) 28px 28px;transform:translateX(100%);transition:transform .5s var(--ease);box-shadow:var(--shadow-lg)}
	.nav ul{flex-direction:column;align-items:flex-start;gap:6px}
	.nav__link{font-family:"Rozha One",serif;font-size:1.6rem;padding:8px 0}
	.nav__link::after{left:0;right:0;bottom:2px}
	body.is-menu-open .nav{transform:translateX(0)}
	body.is-menu-open{overflow:hidden}
}

/* ------------------------------ hero ------------------------------ */
.hero{position:relative;min-height:100vh;min-height:100dvh;display:flex;align-items:center;padding:calc(var(--header-h) + 40px) 28px 80px;overflow:hidden;isolation:isolate}
.hero__bg{position:absolute;inset:0;z-index:-1;overflow:hidden}
.hero__sky{position:absolute;inset:0;background:linear-gradient(180deg,#9ec9ea 0%,#cee2f0 38%,var(--background) 100%)}
.hero__sky::after{content:"";position:absolute;inset:0;background:radial-gradient(circle at 78% 22%,rgba(255,248,218,.95) 0,rgba(255,248,218,0) 35%)}
.hero__sun{position:absolute;top:14%;right:14%;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,#fffbe6 0%,#fff8da 30%,rgba(255,248,218,0) 70%);filter:blur(2px);animation:float 14s ease-in-out infinite}
.hero__branch{position:absolute;width:min(720px,70vw);height:auto;opacity:.92;color:var(--text)}
.hero__branch--tl{top:-2%;left:-3%;transform:translateZ(0);animation:sway 16s ease-in-out infinite}
.hero__branch--br{bottom:-4%;right:-4%;transform:scale(.95);animation:sway 18s ease-in-out infinite reverse}
.hero__branch circle{transform-box:fill-box;transform-origin:center}

@keyframes sway{
	0%,100%{transform:rotate(0deg) translateY(0)}
	50%{transform:rotate(-1.2deg) translateY(-6px)}
}
@keyframes float{
	0%,100%{transform:translateY(0)}
	50%{transform:translateY(-14px)}
}

.hero__content{max-width:880px;margin:0 auto;text-align:center;width:100%}
.hero__title{margin:14px 0 28px;font-size:clamp(2.8rem,8vw,6rem)}
.hero__title em{display:inline-block}
.hero__lead{font-size:clamp(1.05rem,1.4vw,1.25rem);color:var(--text-soft);max-width:60ch;margin:0 auto 36px}
.hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.reveal-line{display:block;overflow:hidden}
.reveal-line>span{display:block;transform:translateY(110%);transition:transform 1s var(--ease-out)}
.is-loaded .reveal-line>span{transform:translateY(0)}
.reveal-line:nth-child(2)>span{transition-delay:.18s}

.scroll-hint{position:absolute;bottom:28px;left:50%;transform:translateX(-50%);width:24px;height:40px;border:1px solid color-mix(in srgb,var(--text) 35%, transparent);border-radius:999px;display:none}
.scroll-hint span{position:absolute;left:50%;top:8px;transform:translateX(-50%);width:3px;height:8px;background:var(--text);border-radius:3px;animation:hint 1.6s ease-in-out infinite}
@media (min-height:760px){.scroll-hint{display:block}}
@keyframes hint{0%,100%{opacity:0;transform:translate(-50%,0)}40%{opacity:1}80%{transform:translate(-50%,12px);opacity:0}}

/* ------------------------------ manifest ------------------------------ */
.manifest{padding:clamp(80px,10vw,140px) 28px;text-align:center;background:linear-gradient(180deg,var(--background) 0%,var(--background-2) 100%)}
.manifest__text{font-family:"Rozha One",serif;font-size:clamp(1.5rem,3.2vw,2.6rem);line-height:1.3;max-width:22ch;margin:0 auto;color:var(--text)}
.manifest__text em{color:var(--primary)}
.manifest__sig{margin-top:36px;font-size:.95rem;color:var(--text-soft);letter-spacing:.18em;text-transform:uppercase}

/* ------------------------------ reveal animation ------------------------------ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
.reveal.is-in{opacity:1;transform:none}
.reveal:nth-child(2){transition-delay:.06s}
.reveal:nth-child(3){transition-delay:.12s}
.reveal:nth-child(4){transition-delay:.18s}
.reveal:nth-child(5){transition-delay:.24s}

/* ------------------------------ terapie ------------------------------ */
.terapie{background:var(--background-2)}
.terapie__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:24px}
@media (max-width:880px){.terapie__grid{grid-template-columns:1fr}}

.card{background:var(--surface);padding:36px 32px;border-radius:var(--radius);border:1px solid color-mix(in srgb,var(--text) 8%, transparent);transition:transform .5s var(--ease-out),box-shadow .5s,border-color .3s}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--primary) 18%, transparent)}
.card__icon{width:44px;height:44px;color:var(--primary);margin-bottom:18px}
.card h3{margin-bottom:10px}
.card p{color:var(--text-soft);font-size:.97rem}

.meta-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:80px;padding-top:48px;border-top:1px solid color-mix(in srgb,var(--text) 12%, transparent)}
@media (max-width:680px){.meta-row{grid-template-columns:1fr;gap:16px;text-align:center}}
.meta__num{display:block;font-family:"Rozha One",serif;font-size:clamp(2.6rem,5vw,4rem);color:var(--primary);line-height:1}
.meta__num small{font-size:.45em;color:var(--text-soft);font-family:"Nata Sans",sans-serif;font-weight:500;margin-left:4px}
.meta__label{display:block;margin-top:8px;font-size:.92rem;color:var(--text-soft);letter-spacing:.04em}

/* ------------------------------ pro koho ------------------------------ */
.poster{aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);transform:rotate(-1.5deg);transition:transform .6s var(--ease-out)}
.poster:hover{transform:rotate(0deg) scale(1.02)}

.checklist{display:flex;flex-direction:column;gap:14px;margin:24px 0 40px}
.checklist li{position:relative;padding:14px 0 14px 44px;border-bottom:1px solid color-mix(in srgb,var(--text) 10%, transparent);font-size:1.04rem}
.checklist li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:28px;height:28px;border-radius:50%;background:var(--secondary-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23056c31' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><polyline points='4 12 10 18 20 6'/></svg>") center/14px no-repeat}

.sub-title{margin-top:36px;margin-bottom:18px;font-family:"Nata Sans",sans-serif;font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;color:var(--primary);font-weight:700}

.tags{display:flex;flex-wrap:wrap;gap:10px}
.tag{display:inline-block;padding:.55em 1.05em;border-radius:999px;background:var(--secondary-soft);color:var(--primary-deep);font-size:.9rem;font-weight:500;transition:transform .35s var(--ease-out),background .3s}
.tag:hover{background:var(--secondary);transform:translateY(-2px)}

/* ------------------------------ o mně ------------------------------ */
.section--dark{background:var(--primary-deep);color:var(--background);position:relative;overflow:hidden}
.section--dark::before{content:"";position:absolute;inset:auto -10% -40% auto;width:50%;height:80%;background:radial-gradient(circle,rgba(8,169,96,.25) 0%,transparent 60%);pointer-events:none}
.section--dark p{color:color-mix(in srgb,var(--background) 80%, transparent)}
.section--dark em{color:var(--secondary)}

.portrait{aspect-ratio:3/4;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-lg);position:relative}
.portrait::after{content:"";position:absolute;inset:0;border-radius:inherit;border:1px solid rgba(255,255,255,.1);pointer-events:none}

.bio{display:flex;flex-direction:column;gap:14px;margin:32px 0 0;padding-top:32px;border-top:1px solid rgba(255,255,255,.12)}
.bio>div{display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:baseline}
.bio dt{font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--secondary);margin:0}
.bio dd{margin:0;color:var(--background)}
@media (max-width:520px){.bio>div{grid-template-columns:1fr;gap:4px}}

/* ------------------------------ kontakt ------------------------------ */
.kontakt{background:var(--background)}
.kontakt__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:64px}
@media (max-width:880px){.kontakt__grid{grid-template-columns:1fr}}

.contact-card{display:flex;flex-direction:column;gap:6px;padding:36px 32px;border-radius:var(--radius);background:var(--surface);border:1px solid color-mix(in srgb,var(--text) 8%, transparent);transition:transform .5s var(--ease-out),box-shadow .5s,border-color .3s,background .3s;color:var(--text)}
.contact-card svg{width:24px;height:24px;color:var(--primary);margin-bottom:12px}
.contact-card__label{font-size:.75rem;letter-spacing:.2em;text-transform:uppercase;color:var(--text-soft);font-weight:600}
.contact-card__value{font-family:"Rozha One",serif;font-size:1.45rem;line-height:1.2}
.contact-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:color-mix(in srgb,var(--primary) 25%, transparent)}

.cta-banner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:48px;border-radius:var(--radius-lg);background:var(--primary-deep);color:#fff;flex-wrap:wrap}
.cta-banner h3{font-family:"Rozha One",serif;font-size:clamp(1.4rem,2.6vw,2rem);color:#fff;max-width:24ch}
.cta-banner .btn--primary{background:var(--accent);color:var(--primary-deep)}
.cta-banner .btn--primary:hover{background:#fff}

/* ------------------------------ footer ------------------------------ */
.site-footer{background:var(--text);color:color-mix(in srgb,var(--background) 80%, transparent);padding:48px 0;font-size:.92rem}
.site-footer__row{display:flex;flex-wrap:wrap;gap:32px;align-items:center;justify-content:space-between}
.site-footer__brand{display:flex;flex-direction:column;line-height:1.3}
.site-footer__brand strong{font-family:"Rozha One",serif;font-weight:400;font-size:1.1rem;color:var(--background);margin-bottom:2px}
.site-footer__nav{display:flex;gap:18px;flex-wrap:wrap}
.site-footer__nav a{transition:color .3s}
.site-footer__nav a:hover{color:var(--secondary)}
.site-footer__meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:.85rem}
.site-footer__meta a{color:var(--background)}
.site-footer__meta strong{color:var(--accent);font-weight:700}
@media (max-width:680px){.site-footer__meta{align-items:flex-start}}
