/* ===========================================================================
   konenki — shared stylesheet
   Warm editorial wellness design. Class-based reimplementation of the original
   Claude Design mockups, kept visually identical with added motion + responsive.
   =========================================================================== */

:root {
  --bg:#F3ECE0;
  --bg-alt:#EFE7DA;
  --card:#F8F3EA;
  --ink:#2C261E;
  --ink-2:#3A3025;
  --ink-soft:#5C5247;
  --muted:#7A6B57;
  --muted-2:#7A6347;
  --accent:#A07C50;
  --accent-2:#D8B98F;
  --olive:#6E7A60;
  --rust:#9A6B55;
  --dark-hover:#4A4034;
  --line:rgba(44,38,30,0.10);
  --line-2:rgba(44,38,30,0.14);
  --line-3:rgba(44,38,30,0.18);
  --line-soft:rgba(44,38,30,0.16);
  --on-dark:#E2D7C6;
  --on-dark-soft:#C4B6A1;
  --on-dark-muted:#9A8B74;

  --serif:'Cormorant Garamond',serif;
  --sans:'Hanken Grotesk',sans-serif;
  --display:'Josefin Sans',sans-serif;

  --maxw:1180px;
  --pad-x:40px;
  --pad-y:128px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;}
::selection{background:var(--accent);color:#F8F3EA;}

/* ---------- Layout ---------- */
.container{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x);width:100%;}
.container--narrow{max-width:1080px;}
.container--mid{max-width:1120px;}
.container--tight{max-width:860px;}

.section{padding:var(--pad-y) var(--pad-x);}
.section--alt{background:var(--bg-alt);}
.section--soft{background:var(--bg);}

/* ---------- Type ---------- */
.eyebrow{display:flex;align-items:center;gap:12px;margin-bottom:26px;}
.eyebrow--center{justify-content:center;}
.eyebrow .rule{width:30px;height:1px;background:var(--accent);display:block;}
.eyebrow .label{font-size:12px;letter-spacing:0.24em;text-transform:uppercase;color:var(--accent);font-weight:600;}

.kicker{font-size:13px;letter-spacing:0.26em;text-transform:uppercase;color:var(--muted-2);font-weight:600;margin:0 0 22px;}

.h2{font-family:var(--serif);font-weight:500;font-size:clamp(38px,4.6vw,56px);line-height:1.05;color:var(--ink);margin:0;}
.h2--lg{font-size:clamp(38px,4.6vw,58px);line-height:1.06;letter-spacing:-0.01em;}
.h3{font-family:var(--serif);font-weight:600;font-size:27px;color:var(--ink);margin:0 0 12px;}
.lead{font-family:var(--serif);font-style:italic;font-weight:400;color:var(--ink-2);}
.prose{font-size:19px;line-height:1.75;color:var(--ink-soft);}
.prose strong{color:var(--ink);font-weight:600;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:var(--sans);font-size:13px;letter-spacing:0.16em;text-transform:uppercase;
  font-weight:600;text-decoration:none;border:none;cursor:pointer;
  background:var(--ink);color:#F3ECE0;padding:17px 34px;
  transition:background .25s ease, transform .25s ease, box-shadow .25s ease;
}
.btn:hover{background:var(--dark-hover);transform:translateY(-2px);box-shadow:0 10px 24px -12px rgba(44,38,30,0.5);}
.btn:active{transform:translateY(0);}
.btn--sm{padding:11px 22px;font-size:12px;}
.btn--block{display:block;width:100%;text-align:center;padding:17px;}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line-3);}
.btn--ghost:hover{background:rgba(44,38,30,0.04);box-shadow:none;}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 40px;
  border-bottom:1px solid var(--line);
  transition:box-shadow .3s ease;
}
/* Frosted background lives on a ::before layer so the header itself does not
   become the containing block for the fixed mobile nav drawer (backdrop-filter
   would otherwise trap .nav{position:fixed;inset:0} inside the header box). */
.site-header::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:rgba(243,236,224,0.82);
  backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  transition:background .3s ease;
}
.site-header.is-scrolled{box-shadow:0 6px 24px -18px rgba(44,38,30,0.55);}
.site-header.is-scrolled::before{background:rgba(243,236,224,0.92);}
.brand{font-family:var(--serif);font-size:26px;font-weight:500;letter-spacing:0.02em;color:var(--ink);text-decoration:none;}
.nav{display:flex;align-items:center;gap:34px;}
.nav a{font-size:13px;letter-spacing:0.08em;color:var(--ink-soft);text-decoration:none;position:relative;}
.nav a:not(.btn)::after{
  content:"";position:absolute;left:0;right:0;bottom:-6px;height:1px;background:var(--accent);
  transform:scaleX(0);transform-origin:left;transition:transform .3s ease;
}
.nav a:not(.btn):hover::after{transform:scaleX(1);}
.nav a:not(.btn):hover{color:var(--ink);}
.nav a.btn{color:#F3ECE0;}
.nav a.btn:hover{color:#F3ECE0;}

.nav-toggle{display:none;background:none;border:none;cursor:pointer;width:30px;height:24px;position:relative;z-index:80;}
.nav-toggle span{position:absolute;left:0;right:0;height:2px;background:var(--ink);transition:transform .3s ease,opacity .25s ease,top .3s ease;}
.nav-toggle span:nth-child(1){top:2px;}
.nav-toggle span:nth-child(2){top:11px;}
.nav-toggle span:nth-child(3){top:20px;}
body.nav-open .nav-toggle span:nth-child(1){top:11px;transform:rotate(45deg);}
body.nav-open .nav-toggle span:nth-child(2){opacity:0;}
body.nav-open .nav-toggle span:nth-child(3){top:11px;transform:rotate(-45deg);}

.simple-header{justify-content:flex-start;position:relative;}
.simple-header .brand{position:absolute;left:50%;transform:translateX(-50%);}
.simple-header .back{font-size:13px;letter-spacing:0.08em;color:var(--ink-soft);text-decoration:none;}
.simple-header .back:hover{color:var(--ink);}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:90vh;display:flex;align-items:center;
  background-image:url('../img/hero.webp');background-size:cover;background-position:72% center;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(90deg,
    rgba(243,236,224,0.92) 0%,
    rgba(243,236,224,0.62) 40%,
    rgba(243,236,224,0.10) 72%,
    rgba(243,236,224,0) 100%);
}
.hero__inner{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:64px 40px;width:100%;}
.hero__copy{max-width:620px;}
.hero h1{
  font-family:var(--display);font-weight:300;font-size:clamp(58px,8vw,116px);
  line-height:1;letter-spacing:0.14em;color:var(--ink);margin:0 0 26px;text-indent:0.14em;
}
.hero__sub{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3.4vw,38px);line-height:1.25;color:var(--ink-2);margin:0 0 40px;max-width:480px;}
.hero__eyebrow{font-size:clamp(15px,2.2vw,19px);letter-spacing:0.26em;text-transform:uppercase;color:var(--muted-2);font-weight:600;line-height:1.4;margin:0 0 40px;max-width:520px;}
.hero__actions{display:flex;align-items:center;gap:28px;flex-wrap:wrap;}
.kanji{
  font-family:var(--sans);font-size:40px;line-height:1;color:var(--ink);opacity:0.85;
  position:absolute;z-index:2;
}
.hero .kanji{right:8%;top:24%;writing-mode:vertical-rl;font-size:clamp(28px,4vw,52px);letter-spacing:0.1em;opacity:0.5;}

/* ---------- Myšlienka ---------- */
.split{display:grid;grid-template-columns:1fr 1.15fr;gap:80px;align-items:start;}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);margin-top:88px;}
.pillar{background:var(--bg);padding:44px 36px;}
.pillar .num{font-family:var(--serif);font-size:30px;color:var(--accent);display:block;margin-bottom:18px;}
.pillar p{font-size:16px;line-height:1.65;color:var(--ink-soft);margin:0;}

/* ---------- Quote band ---------- */
.quote-band{
  position:relative;padding:140px 40px;text-align:center;
  background-image:linear-gradient(rgba(231,221,202,0.55),rgba(231,221,202,0.55)),url('../img/hero.webp');
  background-size:cover;background-position:center;
}
.quote-band p{
  font-family:var(--serif);font-style:italic;font-size:clamp(30px,4.6vw,54px);
  line-height:1.28;color:var(--ink);margin:0 auto;max-width:880px;
}

/* ---------- Pre koho ---------- */
.prekoho-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:72px;align-items:center;}
.checklist{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:22px;}
.checklist li{display:flex;gap:18px;align-items:flex-start;}
.checklist .tick{flex:0 0 22px;height:22px;border-radius:50%;background:var(--accent);color:#F8F3EA;display:flex;align-items:center;justify-content:center;font-size:12px;margin-top:2px;}
.checklist span:last-child{font-size:18px;line-height:1.55;color:var(--ink-2);}
.photo{border-radius:9px;object-fit:cover;width:100%;height:auto;}

/* ---------- Program cards ---------- */
.program-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px;}
.program-card{background:var(--card);padding:44px 36px;border-top:2px solid var(--accent);display:flex;flex-direction:column;}
.program-card .tag{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--accent);font-weight:600;margin-bottom:24px;}
.program-card h3{font-family:var(--serif);font-weight:600;font-size:30px;color:var(--ink);margin:0 0 16px;line-height:1.1;}
.program-card p{font-size:16px;line-height:1.65;color:var(--ink-soft);margin:0 0 26px;flex:1;}
.program-card .by{font-size:13px;letter-spacing:0.04em;color:var(--ink);border-top:1px solid var(--line-2);padding-top:18px;}

/* ---------- Timeline (ukážka dňa) ---------- */
.days{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:start;}
.day__head{display:flex;align-items:baseline;gap:14px;margin-bottom:30px;}
.day__head h3{font-family:var(--serif);font-weight:500;font-size:28px;color:var(--ink);margin:0;}
.day__head .badge{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.tl{display:flex;flex-direction:column;}
.tl__row{display:flex;gap:20px;}
.tl__time{flex:0 0 50px;text-align:right;font-size:14px;font-weight:600;color:var(--ink);padding-top:1px;}
.tl__body{position:relative;border-left:1px solid var(--line-3);padding:0 0 22px 24px;}
.tl__row:last-child .tl__body{border-left:1px solid transparent;padding-bottom:0;}
.tl__body::before{content:"";position:absolute;left:-4px;top:5px;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px var(--bg-alt);}
.tl__body h4{font-family:var(--serif);font-weight:600;font-size:19px;color:var(--ink);margin:0 0 3px;}
.tl__body p{font-size:14px;line-height:1.5;color:var(--ink-soft);margin:0;}

/* ---------- Miesto ---------- */
.miesto-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:72px;align-items:center;}
.miesto-grid .photo{height:613px;max-height:72vh;}
.facts{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--line);}
.fact{background:var(--bg);padding:26px 24px;}
.fact h4{font-family:var(--serif);font-weight:600;font-size:22px;color:var(--ink);margin:0 0 6px;}
.fact p{font-size:15px;line-height:1.55;color:var(--ink-soft);margin:0;}

/* ---------- Cena ---------- */
.cena{
  position:relative;
  background-image:linear-gradient(rgba(44,38,30,0.55),rgba(44,38,30,0.62)),url('../img/hero.webp');
  background-size:cover;background-position:center;
}
.cena__grid{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;}
.cena__grid .eyebrow .rule{background:var(--accent-2);}
.cena__grid .eyebrow .label{color:var(--accent-2);}
.cena h2{color:#F3ECE0;margin:0 0 22px;}
.cena__lede{font-size:18px;line-height:1.7;color:var(--on-dark);margin:0;max-width:420px;}
.price-card{background:var(--card);padding:48px 44px;}
.price-card__row{display:flex;align-items:baseline;gap:10px;margin-bottom:6px;}
.price-card__amount{font-family:var(--serif);font-weight:500;font-size:72px;line-height:1;color:var(--ink);}
.price-card__per{font-size:15px;color:var(--ink-soft);}
.price-card__meta{font-size:14px;color:var(--muted-2);margin:0 0 28px;letter-spacing:0.02em;}
.price-list{list-style:none;margin:0;padding:26px 0 0;display:flex;flex-direction:column;gap:13px;border-top:1px solid var(--line-2);}
.price-list li{display:flex;gap:12px;align-items:flex-start;font-size:16px;color:var(--ink-2);}
.price-list .check{color:var(--accent);}
.price-addon{margin-top:24px;padding:16px 18px;background:var(--bg-alt);display:flex;justify-content:space-between;align-items:center;gap:12px;}
.price-addon span:first-child{font-size:15px;color:var(--ink-2);}
.price-addon span:last-child{font-size:15px;font-weight:600;color:var(--ink);}

/* ---------- FAQ ---------- */
.faq details{border-top:1px solid var(--line-2);}
.faq details:last-of-type{border-bottom:1px solid var(--line-2);}
.faq summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:24px;padding:26px 0;font-family:var(--serif);font-size:25px;color:var(--ink);}
.faq summary::-webkit-details-marker{display:none;}
.faq .plus{flex:0 0 auto;font-size:24px;color:var(--accent);font-family:var(--sans);font-weight:300;transition:transform .3s ease;}
.faq details[open] .plus{transform:rotate(45deg);}
.faq .answer{font-size:17px;line-height:1.7;color:var(--ink-soft);margin:0;padding:0 0 30px;max-width:680px;}
.faq details[open] .answer{animation:fadeA .4s ease both;}
@keyframes fadeA{from{opacity:0;transform:translateY(-6px);}to{opacity:1;transform:none;}}

/* ---------- Kontakt / forms ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:start;}
.contact-lede{font-size:18px;line-height:1.7;color:var(--ink-soft);margin:0 0 36px;max-width:420px;}
.contact-email{font-family:var(--serif);font-size:30px;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:4px;}
.contact-phone{display:block;margin-top:18px;font-size:17px;color:var(--ink-soft);text-decoration:none;letter-spacing:0.02em;}
.form{display:flex;flex-direction:column;gap:26px;}
.field{display:flex;flex-direction:column;gap:8px;}
.field label{font-size:12px;letter-spacing:0.16em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.field input,.field textarea{
  background:transparent;border:none;border-bottom:1px solid rgba(44,38,30,0.28);
  padding:12px 0;font-size:18px;color:var(--ink);font-family:var(--sans);
  transition:border-color .25s ease;
}
.field textarea{resize:vertical;}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--ink);}
.field input::placeholder,.field textarea::placeholder{color:#A99C88;}
/* boxed inputs (checkout, auth) */
.field--box input,.field--box select{
  background:var(--card);border:1px solid rgba(44,38,30,0.20);padding:15px 16px;
  font-size:17px;color:var(--ink);font-family:var(--sans);
}
.form-note{font-size:13px;color:var(--muted);}
.form-error{color:#9A4B3B;font-size:14px;margin:0;min-height:1em;}
.form-ok{color:var(--olive);font-size:14px;margin:0;}

/* ---------- Footer ---------- */
.site-footer{background:var(--ink);color:var(--on-dark);padding:80px 40px 40px;}
.footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:48px;align-items:start;border-bottom:1px solid rgba(226,215,198,0.18);padding-bottom:56px;}
.footer-grid .brand-lg{font-family:var(--serif);font-size:34px;font-weight:500;color:#F3ECE0;margin-bottom:14px;}
.footer-grid p{font-size:16px;line-height:1.6;color:var(--on-dark-soft);margin:0;max-width:320px;}
.footer-col{display:flex;flex-direction:column;gap:14px;}
.footer-col .col-h{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--on-dark-muted);margin-bottom:4px;}
.footer-col a{font-size:15px;color:var(--on-dark);text-decoration:none;transition:color .2s ease;}
.footer-col a:hover{color:#F3ECE0;}
.footer-bottom{max-width:var(--maxw);margin:28px auto 0;display:flex;justify-content:center;flex-wrap:wrap;gap:12px;}
.footer-bottom span{font-size:13px;color:var(--on-dark-muted);}
.footer-bottom .quiet{font-style:italic;font-family:var(--serif);}

/* ---------- Checkout / rezervácia ---------- */
.page-head{padding:64px 40px 0;}
.checkout-wrap{max-width:1120px;margin:0 auto;padding:40px 40px 100px;}
.checkout-title{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5.4vw,64px);line-height:1;letter-spacing:-0.01em;margin:0 0 48px;}
.checkout-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:56px;align-items:start;}
.card-block{background:var(--card);border:1px solid var(--line-2);padding:32px 30px;margin-bottom:28px;}
.card-block h2{font-family:var(--serif);font-weight:600;font-size:24px;margin:0 0 20px;}
.grid-2-sm{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.choice-row{display:flex;gap:12px;flex-wrap:wrap;}
.choice{flex:1;min-width:120px;border:1px solid rgba(44,38,30,0.20);background:var(--card);padding:14px 16px;cursor:pointer;font-family:var(--sans);font-size:15px;color:var(--ink);transition:border-color .2s,background .2s;text-align:center;}
.choice.is-active{border-color:var(--ink);background:#fff;font-weight:600;}
.switch{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 16px;border:1px solid rgba(44,38,30,0.20);background:var(--card);cursor:pointer;}
.switch input{appearance:none;width:42px;height:24px;border-radius:24px;background:rgba(44,38,30,0.25);position:relative;cursor:pointer;transition:background .2s;flex:0 0 auto;}
.switch input::after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform .2s;}
.switch input:checked{background:var(--accent);}
.switch input:checked::after{transform:translateX(18px);}

.pay-tabs{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(44,38,30,0.16);border:1px solid rgba(44,38,30,0.16);margin-bottom:28px;}
.pay-tab{display:flex;flex-direction:column;align-items:flex-start;text-align:left;padding:18px 20px;border:none;cursor:pointer;font-family:var(--sans);background:var(--card);color:var(--ink);transition:background .2s;}
.pay-tab .t{font-size:15px;font-weight:600;letter-spacing:0.02em;}
.pay-tab .s{font-size:12px;color:var(--muted);margin-top:3px;}
.pay-tab.is-active{background:var(--ink);color:#F8F3EA;}
.pay-tab.is-active .s{color:#C4B6A1;}

.stripe-mount{padding:4px 0 8px;}
.bank-grid{display:grid;grid-template-columns:1fr 200px;gap:36px;align-items:start;}
.bank-rows{display:flex;flex-direction:column;border:1px solid var(--line-soft);}
.bank-rows .r{display:flex;justify-content:space-between;gap:16px;padding:14px 16px;border-bottom:1px solid var(--line);background:var(--card);}
.bank-rows .r:last-child{border-bottom:none;}
.bank-rows .k{font-size:13px;color:var(--muted);}
.bank-rows .v{font-size:14px;font-weight:600;letter-spacing:0.02em;}
.qr-box{background:var(--card);padding:14px;border:1px solid var(--line-soft);}
.hint{font-size:13px;color:var(--muted);text-align:center;margin:0;display:flex;align-items:center;justify-content:center;gap:7px;}
.hint .dot{width:6px;height:6px;border-radius:50%;background:var(--olive);}

.summary{background:var(--card);border:1px solid var(--line-2);padding:34px 30px;position:sticky;top:90px;}
.summary h2{font-family:var(--serif);font-weight:600;font-size:24px;margin:0 0 6px;}
.summary .loc{font-size:14px;color:var(--muted);margin:0 0 24px;}
.summary .item{display:flex;gap:14px;align-items:center;padding-bottom:22px;margin-bottom:22px;border-bottom:1px solid var(--line-2);}
.summary .thumb{flex:0 0 64px;height:64px;border-radius:6px;overflow:hidden;background:#E0D2BD;}
.summary .item .t{font-family:var(--serif);font-weight:600;font-size:20px;line-height:1.1;}
.summary .item .s{font-size:13px;color:var(--muted);margin-top:3px;}
.summary .lines{display:flex;flex-direction:column;gap:13px;margin-bottom:22px;}
.summary .lines .l{display:flex;justify-content:space-between;font-size:15px;color:var(--ink-2);}
.summary .lines .l.muted{color:#A99C88;}
.summary .total{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line-soft);padding-top:20px;}
.summary .total .lab{font-size:15px;font-weight:600;letter-spacing:0.04em;}
.summary .total .amt{font-family:var(--serif);font-weight:500;font-size:38px;line-height:1;}
.summary .note{margin-top:24px;padding:14px 16px;background:var(--bg-alt);display:flex;gap:10px;align-items:flex-start;}
.summary .note .tick{flex:0 0 18px;height:18px;border-radius:50%;background:var(--olive);color:#F8F3EA;display:flex;align-items:center;justify-content:center;font-size:11px;margin-top:1px;}
.summary .note span:last-child{font-size:13px;line-height:1.5;color:var(--ink-soft);}
.is-hidden{display:none !important;}

@media (max-width:880px){
  .checkout-grid{grid-template-columns:1fr;gap:36px;}
  .checkout-wrap{padding:32px 24px 80px;}
  .page-head{padding:48px 24px 0;}
  .summary{position:static;order:-1;}
  .bank-grid{grid-template-columns:1fr;gap:24px;}
  .grid-2-sm{grid-template-columns:1fr;}
}

/* ---------- Program (detail page) ---------- */
.prog-hero{
  position:relative;padding:120px 40px 110px;
  background-image:linear-gradient(rgba(243,236,224,0.62),rgba(243,236,224,0.78)),url('../img/hero.webp');
  background-size:cover;background-position:72% center;
}
.prog-hero .container{position:relative;z-index:2;}
.prog-hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(48px,7vw,92px);line-height:0.98;letter-spacing:-0.015em;color:var(--ink);margin:0 0 24px;max-width:760px;}
.prog-hero .lead{font-size:clamp(20px,2.6vw,30px);line-height:1.35;color:var(--ink-2);margin:0;max-width:560px;}
.tags{display:flex;gap:28px;flex-wrap:wrap;margin-top:48px;}
.tag-dot{display:inline-flex;align-items:center;gap:9px;font-size:12px;letter-spacing:0.16em;text-transform:uppercase;font-weight:600;}
.tag-dot .d{width:8px;height:8px;border-radius:50%;background:currentColor;}
.t-health{color:var(--accent);}
.t-create{color:var(--rust);}
.t-move{color:var(--olive);}

.day-head{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:12px;border-bottom:1px solid var(--line-soft);padding-bottom:24px;margin-bottom:14px;}
.day-head h2{font-family:var(--serif);font-weight:500;font-size:clamp(40px,5vw,64px);line-height:1;color:var(--ink);margin:0;}
.day-head .meta{font-size:13px;letter-spacing:0.2em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.prog-row{display:grid;grid-template-columns:96px 1fr;gap:28px;padding:26px 0;border-bottom:1px solid var(--line);}
.prog-row .time{font-size:16px;font-weight:600;color:var(--ink);padding-top:2px;}
.prog-row h3{font-family:var(--serif);font-weight:600;font-size:25px;color:var(--ink);margin:0 0 5px;}
.prog-row p{font-size:16px;line-height:1.6;color:var(--ink-soft);margin:0;}
.prog-row--hl{padding:30px 28px;background:var(--card);border-bottom:none;margin:8px 0;border-left:3px solid var(--accent);}
.prog-row--hl.acc-rust{border-left-color:var(--rust);}
.prog-row--hl.acc-move{border-left-color:var(--olive);}
.prog-row--hl h3{font-size:27px;}
.cat{display:inline-flex;align-items:center;gap:7px;font-size:11px;letter-spacing:0.16em;text-transform:uppercase;font-weight:600;margin-bottom:10px;}
.cat .d{width:6px;height:6px;border-radius:50%;background:currentColor;}
.prog-cta{margin-top:64px;text-align:center;background:var(--card);padding:64px 40px;}
.prog-cta p{font-family:var(--serif);font-style:italic;font-size:clamp(24px,3.4vw,38px);line-height:1.3;color:var(--ink);margin:0 auto 32px;max-width:620px;}
.footer-min{background:var(--ink);color:var(--on-dark-muted);padding:40px;text-align:center;}
.footer-min a{color:var(--on-dark);text-decoration:none;}

/* ---------- Auth ---------- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:40px 20px;}
.auth-card{width:100%;max-width:420px;background:var(--card);border:1px solid var(--line-2);padding:48px 40px;animation:authIn .6s cubic-bezier(.16,.7,.3,1) both;}
@keyframes authIn{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
.auth-card .brand{display:block;text-align:center;font-family:var(--display);font-weight:300;letter-spacing:0.2em;font-size:30px;color:var(--ink);text-decoration:none;margin-bottom:6px;}
.auth-card .sub{text-align:center;font-family:var(--serif);font-style:italic;font-size:18px;color:var(--muted);margin:0 0 32px;}
.auth-card .form{gap:20px;}
.auth-foot{text-align:center;margin-top:24px;font-size:14px;color:var(--muted);}
.auth-foot a{color:var(--ink);}

/* ---------- Members (mini Pinterest) ---------- */
.app-header{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:20px;justify-content:space-between;padding:16px 28px;background:rgba(243,236,224,0.9);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--line);}
.app-header .brand{font-family:var(--serif);font-size:24px;font-weight:500;color:var(--ink);text-decoration:none;}
.app-header .who{font-size:13px;color:var(--muted);}
.app-actions{display:flex;align-items:center;gap:18px;}
.linkbtn{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:13px;letter-spacing:0.04em;color:var(--ink-soft);text-decoration:none;}
.linkbtn:hover{color:var(--ink);}

.members-intro{padding:48px 28px 8px;max-width:1280px;margin:0 auto;}
.members-intro h1{font-family:var(--serif);font-weight:500;font-size:clamp(34px,4.4vw,52px);line-height:1.05;margin:0 0 10px;}
.members-intro p{font-size:17px;color:var(--ink-soft);margin:0;max-width:560px;}

.chips{display:flex;flex-wrap:wrap;gap:10px;padding:24px 28px;max-width:1280px;margin:0 auto;position:sticky;top:65px;z-index:40;background:var(--bg);}
.chip{border:1px solid var(--line-3);background:transparent;color:var(--ink-soft);padding:9px 18px;border-radius:40px;font-family:var(--sans);font-size:13px;letter-spacing:0.04em;cursor:pointer;transition:all .2s;}
.chip:hover{border-color:var(--ink);color:var(--ink);}
.chip.is-active{background:var(--ink);border-color:var(--ink);color:#F3ECE0;}

.masonry{columns:4 260px;column-gap:20px;padding:8px 28px 80px;max-width:1280px;margin:0 auto;}
.pin{break-inside:avoid;margin:0 0 20px;background:var(--card);border:1px solid var(--line-2);border-radius:12px;overflow:hidden;cursor:pointer;transition:transform .25s ease, box-shadow .25s ease;opacity:0;transform:translateY(14px);animation:pinIn .5s ease forwards;}
@keyframes pinIn{to{opacity:1;transform:none;}}
.pin:hover{transform:translateY(-4px);box-shadow:0 16px 36px -22px rgba(44,38,30,0.55);}
.pin__imgwrap{position:relative;}
.pin__img{width:100%;display:block;background:#E6DAC6;}
.pin__save{position:absolute;top:12px;right:12px;width:38px;height:38px;border-radius:50%;border:none;background:rgba(248,243,234,0.92);color:var(--ink);font-size:17px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:transform .15s ease, background .2s;}
.pin__save:hover{transform:scale(1.08);}
.pin__save.is-saved{background:var(--accent);color:#fff;}
.pin__body{padding:16px 18px 18px;}
.pin__board{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.pin__title{font-family:var(--serif);font-weight:600;font-size:20px;color:var(--ink);margin:6px 0 6px;line-height:1.2;}
.pin__desc{font-size:14px;line-height:1.5;color:var(--ink-soft);margin:0;}
.empty{max-width:1280px;margin:40px auto;padding:60px 28px;text-align:center;color:var(--muted);}
.empty p{font-family:var(--serif);font-style:italic;font-size:22px;}

/* pin modal */
.modal{position:fixed;inset:0;z-index:100;display:none;align-items:center;justify-content:center;padding:24px;background:rgba(44,38,30,0.5);backdrop-filter:blur(4px);}
.modal.is-open{display:flex;animation:fadeIn .25s ease;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.modal__card{background:var(--bg);max-width:760px;width:100%;max-height:88vh;overflow:auto;border-radius:14px;display:grid;grid-template-columns:1fr 1fr;animation:authIn .3s ease both;}
.modal__card.no-img{grid-template-columns:1fr;}
.modal__img{width:100%;height:100%;object-fit:cover;background:#E6DAC6;min-height:280px;}
.modal__body{padding:34px 32px;}
.modal__close{position:absolute;top:18px;right:22px;background:rgba(248,243,234,0.9);border:none;width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer;color:var(--ink);}
.modal__board{font-size:11px;letter-spacing:0.16em;text-transform:uppercase;color:var(--accent);font-weight:600;}
.modal__title{font-family:var(--serif);font-weight:600;font-size:30px;margin:8px 0 14px;line-height:1.1;}
.modal__text{font-size:16px;line-height:1.7;color:var(--ink-soft);white-space:pre-wrap;}

@media (max-width:640px){
  .masonry{columns:2 150px;column-gap:14px;padding:8px 18px 60px;}
  .pin{margin-bottom:14px;}
  .chips{padding:18px;top:61px;}
  .members-intro{padding:32px 18px 4px;}
  .modal__card{grid-template-columns:1fr;}
  .app-header{padding:14px 18px;}
}

/* ---------- Admin ---------- */
.admin-shell{max-width:1200px;margin:0 auto;padding:32px 28px 80px;}
.admin-tabs{display:flex;gap:6px;border-bottom:1px solid var(--line-2);margin-bottom:32px;flex-wrap:wrap;}
.admin-tab{background:none;border:none;cursor:pointer;font-family:var(--sans);font-size:14px;letter-spacing:0.04em;color:var(--muted);padding:14px 18px;border-bottom:2px solid transparent;margin-bottom:-1px;}
.admin-tab.is-active{color:var(--ink);border-bottom-color:var(--accent);font-weight:600;}
.admin-panel{display:none;}
.admin-panel.is-active{display:block;animation:fadeIn .3s ease;}
.stat-row{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;}
.stat{background:var(--card);border:1px solid var(--line-2);padding:24px;}
.stat .n{font-family:var(--serif);font-size:40px;line-height:1;color:var(--ink);}
.stat .l{font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted);margin-top:8px;}
.tbl{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line-2);}
.tbl th,.tbl td{text-align:left;padding:13px 16px;font-size:14px;border-bottom:1px solid var(--line);}
.tbl th{font-size:11px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted);font-weight:600;}
.tbl tr:last-child td{border-bottom:none;}
.pill{display:inline-block;padding:3px 10px;border-radius:30px;font-size:12px;font-weight:600;}
.pill.paid{background:#E2EAD9;color:#46583A;}
.pill.pending{background:#F1E6D2;color:#7A6347;}
.pill.failed{background:#F0DAD4;color:#9A4B3B;}
.admin-grid{display:grid;grid-template-columns:340px 1fr;gap:32px;align-items:start;}
.admin-card{background:var(--card);border:1px solid var(--line-2);padding:24px;}
.admin-card h3{font-family:var(--serif);font-size:22px;margin:0 0 18px;}
.mini{font-size:13px;color:var(--muted);}
.tag-pill{display:inline-flex;align-items:center;gap:8px;background:var(--bg-alt);padding:7px 12px;border-radius:30px;font-size:13px;margin:0 8px 8px 0;}
.tag-pill button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:15px;line-height:1;}
.danger{color:#9A4B3B;}
.copybox{background:var(--bg-alt);border:1px dashed var(--accent);padding:14px 16px;margin-top:14px;font-size:14px;}
.copybox b{font-size:18px;letter-spacing:0.04em;}
@media (max-width:760px){
  .stat-row{grid-template-columns:1fr;}
  .admin-grid{grid-template-columns:1fr;}
  .tbl{display:block;overflow-x:auto;white-space:nowrap;}
}

/* ---------- Scroll reveal animations ---------- */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .8s cubic-bezier(.16,.7,.3,1),transform .8s cubic-bezier(.16,.7,.3,1);}
[data-reveal="left"]{transform:translateX(-30px);}
[data-reveal="right"]{transform:translateX(30px);}
[data-reveal="scale"]{transform:scale(.96);}
[data-reveal].is-visible{opacity:1;transform:none;}
.reveal-stagger>*{opacity:0;transform:translateY(22px);transition:opacity .7s cubic-bezier(.16,.7,.3,1),transform .7s cubic-bezier(.16,.7,.3,1);}
.reveal-stagger.is-visible>*{opacity:1;transform:none;}
.reveal-stagger.is-visible>*:nth-child(2){transition-delay:.09s;}
.reveal-stagger.is-visible>*:nth-child(3){transition-delay:.18s;}
.reveal-stagger.is-visible>*:nth-child(4){transition-delay:.27s;}
.reveal-stagger.is-visible>*:nth-child(5){transition-delay:.36s;}
.reveal-stagger.is-visible>*:nth-child(6){transition-delay:.45s;}

/* hero entrance */
.hero__copy>*{opacity:0;transform:translateY(20px);animation:heroIn .9s cubic-bezier(.16,.7,.3,1) forwards;}
.hero__copy>*:nth-child(1){animation-delay:.15s;}
.hero__copy>*:nth-child(2){animation-delay:.28s;}
.hero__copy>*:nth-child(3){animation-delay:.41s;}
.hero__copy>*:nth-child(4){animation-delay:.54s;}
@keyframes heroIn{to{opacity:1;transform:none;}}

@media (prefers-reduced-motion:reduce){
  *{animation:none !important;transition:none !important;}
  [data-reveal],.reveal-stagger>*,.hero__copy>*{opacity:1 !important;transform:none !important;}
  html{scroll-behavior:auto;}
}

/* ===========================================================================
   Responsive
   =========================================================================== */
@media (max-width:1024px){
  :root{--pad-y:104px;}
  .split{gap:48px;}
  .prekoho-grid,.miesto-grid,.cena__grid,.contact-grid{gap:48px;}
}

@media (max-width:880px){
  :root{--pad-x:24px;--pad-y:84px;}

  /* Nav → mobile drawer */
  .nav-toggle{display:block;}
  .nav{
    position:fixed;inset:0;background:rgba(243,236,224,0.98);
    backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
    flex-direction:column;justify-content:center;gap:28px;
    transform:translateY(-100%);transition:transform .45s cubic-bezier(.16,.7,.3,1);
    z-index:70;
  }
  body.nav-open .nav{transform:translateY(0);}
  body.nav-open{overflow:hidden;}
  .nav a{font-size:18px;letter-spacing:0.06em;color:var(--ink);}
  .nav a.btn{font-size:13px;margin-top:8px;}
  .nav a:not(.btn)::after{display:none;}

  /* Stack all two/three-column grids */
  .split,.prekoho-grid,.miesto-grid,.cena__grid,.contact-grid,.days{grid-template-columns:1fr;gap:40px;}
  .pillars,.program-grid{grid-template-columns:1fr;}
  .pillars{margin-top:48px;}
  .pillars .pillar{padding:32px 26px;}

  /* Pre koho / miesto: image first feels better on mobile */
  .prekoho-grid .photo{order:-1;}
  .miesto-grid .photo{height:auto;max-height:none;aspect-ratio:5/6;}

  .quote-band{padding:96px 24px;}
  .section{padding:var(--pad-y) var(--pad-x);}
  .hero{min-height:84vh;background-position:68% center;}
  .hero__inner{padding:48px 24px;}
  .hero .kanji{display:none;}

  .footer-grid{grid-template-columns:1fr;gap:36px;}
  .footer-bottom{flex-direction:column;}

  .price-card{padding:36px 28px;}
  .tl__time{flex:0 0 44px;}
}

@media (max-width:560px){
  :root{--pad-x:20px;--pad-y:68px;}
  .price-card__amount{font-size:60px;}
  .h3{font-size:24px;}
  .program-card{padding:34px 26px;}
  .facts{grid-template-columns:1fr;}
  .fact{padding:22px 0;}
  .contact-email{font-size:24px;}
  .faq summary{font-size:21px;}
  .site-footer{padding:64px 20px 32px;}
  .checklist span:last-child{font-size:16px;}
}
