/* ===========================================================
   HODINY ŠPANĚLŠTINY · Barbora Kalvach Frydrych
   Sdílené styly pro všechny stránky
   =========================================================== */

/* === REAL PHOTOS === */
.photo-real{
  position:relative;width:100%;aspect-ratio:4/5;
  border-radius:24px;overflow:hidden;box-shadow:var(--shadow-hover);
  background:linear-gradient(135deg,var(--azafran),var(--naranja));
}
.photo-real img{width:100%;height:100%;object-fit:cover;display:block}
.photo-real.square{aspect-ratio:1/1}
.photo-real.tall{aspect-ratio:3/4}
.photo-real.round{border-radius:50%}
.photo-real .badge{
  position:absolute;bottom:20px;left:20px;background:#fff;
  padding:14px 18px;border-radius:14px;display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow);
}
.photo-real .badge .num{font-family:"Fraunces",serif;font-size:1.9rem;font-weight:700;color:var(--paprika);line-height:1}
.photo-real .badge span{font-size:.85rem;color:var(--soft);max-width:130px;line-height:1.25}

/* Pomeranč jako reálný PNG */
.orange-photo{
  position:relative;width:340px;height:340px;
  filter:drop-shadow(0 30px 50px rgba(217,98,10,.4));
}
.orange-photo img{width:100%;height:100%;object-fit:contain;display:block}

/* === BADGE / CREDENTIAL STRIP === */
.badge-strip{
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
  padding:32px;border-radius:22px;background:#fff;
  box-shadow:var(--shadow);border:1px solid rgba(196,69,54,.06);
}
.credential{
  display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;
  padding:18px 14px;border-radius:14px;transition:background .25s;
}
.credential:hover{background:var(--crema-deep)}
.credential .seal{
  width:72px;height:72px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  background:radial-gradient(circle at 30% 30%,#FFF8EE,var(--azafran) 70%,var(--naranja));
  border:3px solid var(--paprika);
  box-shadow:inset -4px -4px 8px rgba(74,14,14,.15),0 6px 14px -4px rgba(196,69,54,.3);
  font-family:"Fraunces",serif;font-style:italic;font-weight:700;
  font-size:1.1rem;color:var(--vino);position:relative;
}
.credential .seal::before{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1px dashed rgba(74,14,14,.3);
}
.credential.amber .seal{background:radial-gradient(circle at 30% 30%,#FFF8EE,#FFB347 70%,#C44536)}
.credential.green .seal{background:radial-gradient(circle at 30% 30%,#F4FAE8,#7BB453 70%,var(--green));border-color:var(--green);color:#fff}
.credential.red .seal{background:radial-gradient(circle at 30% 30%,#FFE4E4,#E85A5A 70%,var(--paprika-deep));border-color:var(--vino);color:#fff}
.credential b{font-family:"Fraunces",serif;font-size:1rem;line-height:1.2}
.credential span{font-size:.78rem;color:var(--soft);line-height:1.35}

/* === MINI ENROLLMENT FORM (uvnitř enroll-card) === */
.enroll-form{
  display:grid;gap:12px;
}
.enroll-form input,.enroll-form select,.enroll-form textarea{
  font-family:"Manrope",inherit;font-size:.96rem;color:var(--noche);
  padding:12px 14px;border-radius:10px;border:1.5px solid rgba(255,255,255,.4);
  background:rgba(255,246,233,.95);transition:border-color .2s,background .2s;
  width:100%;
}
.enroll-form input:focus,.enroll-form select:focus,.enroll-form textarea:focus{
  outline:none;border-color:var(--azafran);background:#fff;
}
.enroll-form input::placeholder,.enroll-form textarea::placeholder{color:rgba(74,14,14,.5)}
.enroll-form .row2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.enroll-form .submit{margin-top:6px}
.enroll-card .form-note{
  font-size:.82rem;color:rgba(255,246,233,.85);margin-top:8px;line-height:1.45;
}

/* === RADIO PILLS === */
.radio-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:10px;
}
.radio-pill{
  display:flex;align-items:center;gap:10px;
  padding:12px 16px;border-radius:12px;
  background:var(--crema);border:1.5px solid var(--line);
  cursor:pointer;transition:border-color .2s,background .2s,transform .15s;
  font-size:.95rem;font-weight:500;
}
.radio-pill:hover{border-color:var(--paprika);transform:translateY(-1px)}
.radio-pill input{
  appearance:none;width:18px;height:18px;border-radius:50%;
  border:2px solid var(--line);margin:0;cursor:pointer;flex-shrink:0;
  transition:border-color .15s,background .15s;
  display:inline-grid;place-content:center;
}
.radio-pill input::before{
  content:"";width:8px;height:8px;border-radius:50%;background:var(--paprika);
  transform:scale(0);transition:transform .15s;
}
.radio-pill input:checked{border-color:var(--paprika)}
.radio-pill input:checked::before{transform:scale(1)}
.radio-pill:has(input:checked){border-color:var(--paprika);background:#fff;box-shadow:0 6px 14px -8px var(--paprika)}

/* === PREFERS-REDUCED-MOTION === */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
    scroll-behavior:auto !important;
  }
  .sun-art{animation:none !important;transform:none !important}
  .strip-track{animation:none !important;transform:none !important}
  .pulse{animation:none !important;opacity:1 !important}
  .float-card,.tag-float{animation:none !important;transform:none !important}
}


:root{
  --paprika:#E63946;
  --paprika-deep:#C0202C;
  --terracotta:#C44536;
  --naranja:#F77F00;
  --naranja-light:#FFA94D;
  --azafran:#FCBF49;
  --crema:#FFF6E9;
  --crema-deep:#FBE9D0;
  --arena:#F4D9B0;
  --vino:#4A0E0E;
  --noche:#2B1810;
  --soft:#7A5A48;
  --line:#E8D3B8;
  --green:#3D6B2F;
  --shadow: 0 18px 40px -22px rgba(74,14,14,.35);
  --shadow-hover: 0 26px 60px -22px rgba(74,14,14,.45);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Manrope",system-ui,-apple-system,sans-serif;
  background:var(--crema);
  color:var(--noche);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
h1,h2,h3,h4{font-family:"Fraunces",Georgia,serif;font-weight:700;letter-spacing:-.01em;line-height:1.05;margin:0}
h1{font-size:clamp(2.6rem,6vw,5.4rem)}
h2{font-size:clamp(1.9rem,4.2vw,3.2rem)}
h3{font-size:1.4rem}
h4{font-size:1.15rem}
.italic{font-family:"Fraunces",Georgia,serif;font-style:italic;font-weight:500}
img{max-width:100%;display:block}
a{color:inherit}

.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.wrap-narrow{max-width:920px;margin:0 auto;padding:0 28px}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.78rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;
  color:var(--paprika-deep);
}
.eyebrow::before{content:"";width:28px;height:2px;background:var(--paprika);flex-shrink:0}

/* ===========================================================
   ICON SYSTEM (custom SVG) — žádné emoji
   =========================================================== */
.ico{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;flex-shrink:0;color:currentColor;
}
.ico svg{width:100%;height:100%;display:block}
.ico-lg{width:32px;height:32px}
.ico-xl{width:48px;height:48px}
.ico-circle{
  width:44px;height:44px;border-radius:12px;
  background:linear-gradient(135deg,var(--azafran),var(--naranja));
  color:var(--vino);
}
.ico-circle.wa{
  background:linear-gradient(135deg,#25D366,#128C7E);
  color:#fff;
}
.ico-circle.ig{
  background:linear-gradient(135deg,#F58529,#DD2A7B 50%,#8134AF);
  color:#fff;
}
.ico-circle.mail{
  background:linear-gradient(135deg,var(--paprika),var(--terracotta));
  color:#fff;
}
.ico-circle .ico{width:22px;height:22px}
.ico-on-dark{color:var(--azafran)}

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(255,246,233,.85);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid rgba(196,69,54,.1);
}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 28px;max-width:1280px;margin:0 auto;gap:20px}
.brand{display:flex;align-items:center;gap:12px;text-decoration:none;color:var(--noche);flex-shrink:0}
.brand-mark{width:42px;height:42px;border-radius:50%;background:radial-gradient(circle at 30% 30%,var(--azafran),var(--naranja) 60%,var(--paprika));position:relative;box-shadow:inset -4px -6px 12px rgba(74,14,14,.2);flex-shrink:0}
.brand-mark::after{content:"";position:absolute;left:50%;top:-6px;width:10px;height:14px;background:var(--green);border-radius:60% 40% 80% 20%;transform:translateX(-50%) rotate(-18deg)}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text b{font-family:"Fraunces",serif;font-size:1.15rem;font-weight:700;white-space:nowrap}
.brand-text span{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:var(--soft);margin-top:3px;white-space:nowrap}
.menu{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.menu a{text-decoration:none;color:var(--noche);font-weight:500;font-size:.9rem;position:relative;padding:6px 0;white-space:nowrap}
.menu a:hover{color:var(--paprika-deep)}
.menu a::after{content:"";position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--paprika);transition:width .25s}
.menu a:hover::after,.menu a.active::after{width:100%}
.menu a.active{color:var(--paprika-deep)}
.menu-toggle{display:none;background:transparent;border:0;color:var(--noche);cursor:pointer;padding:6px;line-height:0}

/* === MENU DROPDOWN === */
.menu-dropdown{position:relative;display:inline-block}
.menu-dropdown .dd-trigger{
  display:inline-flex;align-items:center;gap:5px;
  text-decoration:none;color:var(--noche);font-weight:500;
  font-size:.9rem;padding:6px 0;white-space:nowrap;
  position:relative;transition:color .2s;
}
.menu-dropdown .dd-trigger:hover,
.menu-dropdown .dd-trigger.active{color:var(--paprika-deep)}
.menu-dropdown .dd-trigger::after{
  content:"";position:absolute;left:0;bottom:0;height:2px;width:0;
  background:var(--paprika);transition:width .25s;
}
.menu-dropdown .dd-trigger.active::after,
.menu-dropdown:hover .dd-trigger::after{width:100%}
.dd-caret{
  width:12px;height:12px;flex-shrink:0;
  transition:transform .25s;
}
.menu-dropdown:hover .dd-caret{transform:rotate(180deg)}
.dd-menu{
  display:none;position:absolute;top:100%;left:50%;
  transform:translateX(-50%) translateY(8px);
  background:#fff;border-radius:14px;
  box-shadow:0 18px 40px -10px rgba(74,14,14,.25),0 4px 10px rgba(74,14,14,.08);
  border:1px solid rgba(196,69,54,.08);
  padding:8px;min-width:180px;
  z-index:100;
  flex-direction:column;
}
.menu-dropdown:hover .dd-menu,
.menu-dropdown:focus-within .dd-menu{display:flex}
.dd-menu a{
  display:block;padding:10px 16px;border-radius:8px;
  text-decoration:none;color:var(--noche);
  font-size:.92rem;font-weight:500;
  transition:background .15s,color .15s;
  white-space:nowrap;
}
.dd-menu a:hover,.dd-menu a.active{
  background:rgba(230,57,70,.08);
  color:var(--paprika-deep);
}
.dd-menu a::after{display:none}
/* malý překlenovací pruh, aby se hover nepřerušoval mezi triggerem a menu */
.menu-dropdown::before{
  content:"";position:absolute;top:100%;left:0;right:0;height:14px;
  pointer-events:auto;
}

/* ===========================================================
   BUTTONS  (žádný overflow textu)
   =========================================================== */
.cta-btn,.btn-ghost,.btn-card{
  display:inline-flex;align-items:center;gap:10px;
  text-decoration:none;font-weight:700;font-family:"Manrope",sans-serif;
  white-space:nowrap;cursor:pointer;border:0;
  transition:transform .2s,box-shadow .2s,background .2s,color .2s;
  line-height:1;
}
.cta-btn{
  background:var(--paprika);color:#fff;
  padding:13px 22px;border-radius:999px;font-size:.92rem;
  box-shadow:0 8px 20px -8px var(--paprika);
}
.cta-btn:hover{transform:translateY(-2px);background:var(--paprika-deep);box-shadow:0 14px 30px -10px var(--paprika)}
.cta-btn.lg{padding:17px 30px;font-size:1rem}
.cta-btn.giant{padding:20px 36px;font-size:1.05rem}
.cta-btn.on-dark{background:#fff;color:var(--paprika-deep);box-shadow:0 8px 20px -8px rgba(0,0,0,.4)}
.cta-btn.on-dark:hover{background:var(--noche);color:#fff;box-shadow:0 14px 30px -10px rgba(0,0,0,.5)}

.btn-ghost{
  background:transparent;color:var(--noche);
  padding:13px 23px;border-radius:999px;border:2px solid var(--noche);
  font-size:.94rem;
}
.btn-ghost:hover{background:var(--noche);color:var(--crema)}
.btn-ghost.on-dark{color:var(--crema);border-color:var(--crema)}
.btn-ghost.on-dark:hover{background:var(--crema);color:var(--noche)}

.btn-card{
  background:var(--noche);color:var(--crema);
  padding:11px 18px;border-radius:999px;font-size:.86rem;
}
.btn-card:hover{background:var(--paprika);transform:translateY(-2px)}

.cta-btn .arr,.btn-card .arr,.btn-ghost .arr{transition:transform .25s;display:inline-flex;align-items:center;flex-shrink:0}
.cta-btn:hover .arr,.btn-card:hover .arr,.btn-ghost:hover .arr{transform:translateX(4px)}

/* SVG arrow — pro CTA, vrací konzistentní glyph */
.arr svg{width:14px;height:14px}

/* ===========================================================
   ANNOUNCEMENT BAR
   =========================================================== */
.bar{
  background:var(--vino);color:var(--crema);text-align:center;
  padding:11px 16px;font-size:.85rem;letter-spacing:.04em;
  display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap;
}
.bar b{color:var(--azafran);font-family:"Fraunces",serif;font-style:italic;font-weight:700}
.pulse{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--azafran);animation:pulse 2s infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ===========================================================
   HERO (varianty: hero-default, hero-course)
   =========================================================== */
.hero{
  position:relative;padding:90px 0 130px;overflow:hidden;
  background:
    radial-gradient(1200px 600px at 90% -10%,rgba(252,191,73,.45),transparent 60%),
    radial-gradient(900px 500px at -10% 30%,rgba(247,127,0,.18),transparent 65%),
    var(--crema);
}
.hero-grid{display:grid;grid-template-columns:1.15fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.hero-grid.tight{grid-template-columns:1.4fr 1fr}
.hero h1{margin:18px 0 24px}
.hero h1 .accent{color:var(--paprika);font-style:italic;font-weight:500;display:inline-block;transform:rotate(-2deg)}
.hero h1 .underlined{position:relative;white-space:nowrap;display:inline-block}
.hero h1 .underlined::after{
  content:"";position:absolute;left:-2%;right:-2%;bottom:6%;height:14px;
  background:var(--azafran);border-radius:30px;z-index:-1;opacity:.85;
}
.hero p.lead{font-size:1.18rem;color:var(--soft);max-width:540px;margin:0 0 32px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap;align-items:center}
.hero-meta{display:flex;gap:32px;margin-top:42px;flex-wrap:wrap}
.hero-meta div{display:flex;flex-direction:column}
.hero-meta b{font-family:"Fraunces",serif;font-size:1.7rem;color:var(--paprika-deep);line-height:1.05}
.hero-meta span{font-size:.82rem;color:var(--soft);letter-spacing:.04em;margin-top:4px}

.hero-badge{
  display:inline-flex;align-items:center;gap:10px;
  background:#fff;padding:10px 18px;border-radius:999px;
  font-size:.85rem;font-weight:700;
  box-shadow:var(--shadow);margin-bottom:18px;
  white-space:nowrap;
}
.hero-badge .pulse{background:var(--paprika)}

.facts-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:42px}
.fact-pill{
  background:#fff;padding:18px 16px;border-radius:18px;box-shadow:var(--shadow);
  display:flex;flex-direction:column;gap:6px;border:1px solid rgba(196,69,54,.05);
  min-height:108px;justify-content:flex-start;
}
.fact-pill .ico-circle{width:38px;height:38px;border-radius:10px;margin-bottom:4px}
.fact-pill .ico-circle .ico{width:20px;height:20px}
.fact-pill span{font-size:.7rem;text-transform:uppercase;letter-spacing:.1em;color:var(--soft)}
.fact-pill b{font-family:"Fraunces",serif;font-size:1rem;line-height:1.2;color:var(--noche)}

/* ARTWORK utility */
.hero-art{position:relative;height:520px;display:flex;align-items:center;justify-content:center}
.orange-art{
  position:relative;width:340px;height:340px;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#FFD89E 0%,var(--naranja) 45%,#D9620A 100%);
  box-shadow:inset -20px -30px 60px rgba(74,14,14,.35),0 30px 80px -20px rgba(217,98,10,.5);
}
.orange-art::before{
  content:"";position:absolute;left:50%;top:-22px;width:30px;height:36px;
  background:linear-gradient(180deg,#5A8E3D,var(--green));
  border-radius:60% 40% 80% 20%;transform:translateX(-50%) rotate(-22deg);
  box-shadow:0 6px 12px rgba(74,14,14,.3);
}
.orange-art::after{
  content:"";position:absolute;width:60px;height:90px;left:24%;top:18%;
  background:radial-gradient(ellipse at center,rgba(255,255,255,.5),transparent 70%);
  border-radius:50%;transform:rotate(-30deg);filter:blur(4px);
}
.sun-art{position:absolute;width:200px;height:200px;animation:rotate 30s linear infinite;pointer-events:none}
@keyframes rotate{to{transform:rotate(360deg)}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}

/* ========== FLASHCARDS — papírové nálepky se slovíčky ========== */
.tag-float{
  position:absolute;background:#FFFBF2;
  padding:9px 14px 8px;
  border:1px dashed rgba(196,69,54,.4);
  border-radius:6px;
  box-shadow:0 6px 16px -8px rgba(74,14,14,.22),0 1px 2px rgba(74,14,14,.06);
  display:flex;flex-direction:column;align-items:flex-start;
  line-height:1.15;white-space:nowrap;
  transform:rotate(var(--rot,-2deg));
  transition:transform .3s ease, box-shadow .3s ease;
}
.tag-float:hover{
  transform:rotate(0deg) scale(1.04);
  box-shadow:0 10px 22px -8px rgba(74,14,14,.28),0 2px 4px rgba(74,14,14,.08);
  z-index:5;
}
.tag-float em{
  font-family:"Fraunces",Georgia,serif;
  font-style:italic;font-weight:600;
  font-size:.95rem;
  color:var(--paprika-deep);
  letter-spacing:.005em;
}
.tag-float span{
  font-size:.66rem;font-weight:600;
  color:var(--soft);
  letter-spacing:.08em;
  text-transform:uppercase;
  margin-top:1px;
}
/* malý rožek jako kousek lepicí pásky / pin */
.tag-float::before{
  content:"";position:absolute;top:-3px;left:50%;
  width:18px;height:6px;background:rgba(252,191,73,.55);
  transform:translateX(-50%) rotate(-3deg);
  border-radius:1px;
  box-shadow:inset 0 -1px 2px rgba(74,14,14,.15);
  pointer-events:none;
}

.wave{position:absolute;left:0;right:0;bottom:-1px;width:100%;display:block}

/* ===========================================================
   STRIP (running marquee)
   =========================================================== */
.strip{background:var(--noche);color:var(--crema);overflow:hidden;border-top:1px solid var(--vino)}
.strip-track{display:flex;gap:60px;padding:22px 0;animation:slide 50s linear infinite;white-space:nowrap;width:max-content}
.strip-track span{font-family:"Fraunces",serif;font-style:italic;font-size:1.35rem;font-weight:500;display:inline-flex;align-items:center;gap:24px;flex-shrink:0}
.strip-track span::after{content:"✦";color:var(--azafran);margin-left:24px;font-style:normal}
@keyframes slide{to{transform:translateX(-50%)}}

/* ===========================================================
   SECTION HEADERS / GENERIC
   =========================================================== */
.section{padding:120px 0;position:relative}
.section.alt{background:linear-gradient(180deg,var(--crema) 0%,var(--crema-deep) 100%)}
.section.dark{background:var(--noche);color:var(--crema)}
.section.dark .eyebrow{color:var(--azafran)}
.section.dark .eyebrow::before{background:var(--azafran)}
.section.dark h2{color:var(--crema)}
.section-head{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:end;margin-bottom:60px}
.section-head h2{margin-top:14px}
.section-head p{color:var(--soft);font-size:1.05rem;margin:0;max-width:480px}
.section-head.center{display:block;text-align:center;max-width:760px;margin:0 auto 60px}
.section-head.center p{max-width:none;margin:18px auto 0}

/* ===========================================================
   COURSE CARDS GRID
   =========================================================== */
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:30px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}

.card{
  position:relative;background:#fff;border-radius:24px;padding:36px;
  box-shadow:var(--shadow);transition:transform .3s,box-shadow .3s;
  display:flex;flex-direction:column;overflow:hidden;
  border:1px solid rgba(196,69,54,.06);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-hover)}
.card-glow{
  position:absolute;width:240px;height:240px;border-radius:50%;
  filter:blur(60px);opacity:.4;top:-80px;right:-80px;pointer-events:none;
  transition:opacity .3s;
}
.card:hover .card-glow{opacity:.6}
.card .level{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 14px;border-radius:999px;font-size:.74rem;font-weight:700;
  letter-spacing:.1em;text-transform:uppercase;align-self:flex-start;
  position:relative;z-index:1;white-space:nowrap;
}
.lvl-dele{background:rgba(230,57,70,.12);color:var(--paprika-deep)}
.lvl-conv{background:rgba(247,127,0,.15);color:#A04F00}
.lvl-work{background:rgba(252,191,73,.25);color:#7A5A0E}
.lvl-coach{background:rgba(74,14,14,.1);color:var(--vino)}
.lvl-kids{background:rgba(61,107,47,.15);color:var(--green)}
.card h3{margin:18px 0 10px;font-size:1.5rem;line-height:1.18;position:relative;z-index:1}
.card .sub{color:var(--soft);margin:0 0 22px;position:relative;z-index:1;font-size:.97rem}
.card-meta{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:18px 0;position:relative;z-index:1}
.card-meta .row{display:flex;gap:10px;align-items:flex-start}
.card-meta .row .ico-circle{width:32px;height:32px;border-radius:8px;flex-shrink:0}
.card-meta .row .ico-circle .ico{width:16px;height:16px}
.card-meta .row .lbl{display:flex;flex-direction:column;line-height:1.2;gap:1px}
.card-meta .row .lbl span{font-size:.7rem;color:var(--soft);text-transform:uppercase;letter-spacing:.08em}
.card-meta .row .lbl b{font-family:"Fraunces",serif;font-size:.95rem;font-weight:600}
.card-divider{height:1px;background:linear-gradient(to right,var(--line),transparent);margin:8px 0 20px;position:relative;z-index:1}
.card-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-top:auto;position:relative;z-index:1;flex-wrap:wrap}
.price{display:flex;flex-direction:column;line-height:1}
.price b{font-family:"Fraunces",serif;font-size:1.7rem;font-weight:700;color:var(--noche);line-height:1}
.price span{font-size:.78rem;color:var(--soft);margin-top:4px}
.price .strike{text-decoration:line-through;color:var(--soft);font-size:.95rem;margin-right:8px;font-weight:400}

.card.featured{
  grid-column:span 2;
  background:linear-gradient(135deg,var(--paprika) 0%,var(--naranja) 100%);
  color:#fff;padding:44px;display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center;
  position:relative;overflow:hidden;
}
.card.featured::before{
  content:"";position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(252,191,73,.4),transparent 60%);
  bottom:-200px;right:-150px;
}
.card.featured .level{background:rgba(255,255,255,.18);color:#fff}
.card.featured h3{font-size:2rem;color:#fff;line-height:1.12}
.card.featured .sub{color:rgba(255,255,255,.92);font-size:1rem}
.card.featured-art{position:relative;display:flex;align-items:center;justify-content:center;height:240px}
.card.featured .row .lbl span{color:rgba(255,255,255,.85)}
.card.featured .row .lbl b{color:#fff}
.card.featured .row .ico-circle{background:rgba(255,255,255,.18);color:#fff}
.early-bird{
  background:var(--azafran);color:var(--vino);
  padding:6px 12px;border-radius:6px;font-size:.74rem;font-weight:800;
  letter-spacing:.08em;display:inline-flex;align-items:center;gap:8px;
  align-self:flex-start;margin-bottom:14px;text-transform:uppercase;
}

/* ===========================================================
   ABOUT
   =========================================================== */
.about-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:80px;align-items:center}
.about-photo{
  position:relative;aspect-ratio:4/5;border-radius:24px;overflow:hidden;
  background:linear-gradient(135deg,var(--azafran),var(--naranja));
  box-shadow:var(--shadow);
}
.about-photo svg.portrait{position:absolute;inset:0;width:100%;height:100%}
.about-photo .badge{
  position:absolute;bottom:24px;left:24px;background:#fff;
  padding:14px 18px;border-radius:14px;display:flex;align-items:center;gap:14px;
  box-shadow:var(--shadow);
}
.about-photo .badge .num{font-family:"Fraunces",serif;font-size:2rem;font-weight:700;color:var(--paprika);line-height:1}
.about-photo .badge span{font-size:.85rem;color:var(--soft);max-width:120px;line-height:1.25}
.about h2 .qmk{color:var(--paprika);font-style:italic;font-family:"Fraunces",serif}
.about-text p{color:var(--soft);font-size:1.05rem;margin:18px 0}
.about-text p strong{color:var(--noche)}
.facts{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:32px}
.fact{background:#fff;padding:22px;border-radius:18px;box-shadow:var(--shadow)}
.fact b{font-family:"Fraunces",serif;font-size:1.85rem;color:var(--paprika);display:block;line-height:1}
.fact span{font-size:.86rem;color:var(--soft);margin-top:6px;display:block;line-height:1.3}

/* ===========================================================
   TESTIMONIALS
   =========================================================== */
.test-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.test-grid.two{grid-template-columns:repeat(2,1fr)}
.test{
  background:rgba(255,246,233,.06);border:1px solid rgba(255,246,233,.12);
  border-radius:20px;padding:30px;backdrop-filter:blur(8px);
}
.section.dark .test p{color:var(--crema)}
.test.light{background:#fff;border-color:rgba(196,69,54,.08);box-shadow:var(--shadow)}
.test .stars{color:var(--azafran);font-size:1rem;letter-spacing:2px;margin-bottom:14px}
.test p{font-family:"Fraunces",serif;font-style:italic;font-size:1.05rem;line-height:1.5;margin:0 0 20px}
.test-by{display:flex;align-items:center;gap:12px}
.test-by .av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--naranja),var(--paprika));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-family:"Fraunces",serif;flex-shrink:0}
.test-by b{font-size:.95rem;display:block}
.test-by span{font-size:.8rem;color:var(--soft)}
.section.dark .test-by span{color:rgba(255,246,233,.6)}

/* ===========================================================
   TIMELINE (program)
   =========================================================== */
.timeline{position:relative;max-width:920px;margin:0 auto}
.timeline::before{content:"";position:absolute;left:36px;top:20px;bottom:20px;width:2px;background:linear-gradient(180deg,var(--paprika),var(--naranja),var(--azafran));border-radius:2px}
.tl-item{position:relative;padding:0 0 44px 96px;display:flex;flex-direction:column;gap:10px}
.tl-item:last-child{padding-bottom:0}
.tl-num{
  position:absolute;left:0;top:0;width:74px;height:74px;border-radius:50%;
  background:linear-gradient(135deg,var(--paprika),var(--naranja));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:"Fraunces",serif;font-style:italic;font-size:1.6rem;font-weight:700;
  box-shadow:0 12px 28px -12px var(--paprika);border:6px solid var(--crema);
}
.section.dark .tl-num{border-color:var(--noche)}
.tl-item h3{font-size:1.45rem;line-height:1.2}
.tl-item .tag{display:inline-block;background:rgba(247,127,0,.15);color:#A04F00;font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:4px 10px;border-radius:6px;align-self:flex-start}
.tl-item ul{margin:6px 0 0;padding:0;list-style:none}
.tl-item ul li{position:relative;padding:6px 0 6px 22px;color:var(--soft);font-size:.97rem;line-height:1.5}
.section.dark .tl-item ul li{color:rgba(255,246,233,.78)}
.tl-item ul li::before{content:"";position:absolute;left:0;top:14px;width:10px;height:2px;background:var(--paprika)}
.tl-item .takeaway{background:#fff;padding:12px 16px;border-radius:12px;border-left:3px solid var(--azafran);font-size:.9rem;color:var(--noche);margin-top:8px;font-style:italic;font-family:"Fraunces",serif;font-weight:500}

/* compact program for course pages */
.program-blocks{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1100px;margin:0 auto}
.pb{background:#fff;padding:26px;border-radius:18px;box-shadow:var(--shadow);border:1px solid rgba(196,69,54,.05);position:relative;overflow:hidden}
.pb::after{content:"";position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle,rgba(252,191,73,.3),transparent 60%);top:-40px;right:-40px;pointer-events:none}
.pb .num{font-family:"Fraunces",serif;font-style:italic;font-size:1.7rem;color:var(--paprika);line-height:1;margin-bottom:10px;display:block;position:relative;z-index:1}
.pb h4{font-size:1.05rem;line-height:1.25;margin-bottom:8px;position:relative;z-index:1}
.pb ul{margin:8px 0 0;padding:0;list-style:none;position:relative;z-index:1}
.pb ul li{padding:4px 0 4px 18px;font-size:.9rem;color:var(--soft);position:relative;line-height:1.45}
.pb ul li::before{content:"";position:absolute;left:0;top:13px;width:8px;height:2px;background:var(--paprika)}

/* ===========================================================
   ENROLL BOX
   =========================================================== */
.enroll-card{
  background:linear-gradient(135deg,var(--paprika) 0%,var(--naranja) 100%);
  border-radius:32px;padding:54px;color:#fff;
  display:grid;grid-template-columns:1.3fr 1fr;gap:50px;
  position:relative;overflow:hidden;box-shadow:var(--shadow-hover);
}
.enroll-card::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(252,191,73,.5),transparent 60%);bottom:-300px;right:-200px}
.enroll-card::after{content:"";position:absolute;width:300px;height:300px;border-radius:50%;background:rgba(255,246,233,.08);top:-100px;left:-100px}
.enroll-card .col{position:relative;z-index:1}
.enroll-card .eyebrow{color:rgba(255,246,233,.95)}
.enroll-card .eyebrow::before{background:var(--azafran)}
.enroll-card h2{color:#fff;margin:14px 0 18px}
.enroll-card p{color:rgba(255,246,233,.92);font-size:1.02rem;margin:0 0 24px;max-width:480px}
.in-price{display:flex;align-items:flex-end;gap:14px;margin-bottom:6px;flex-wrap:wrap}
.in-price b{font-family:"Fraunces",serif;font-size:3.2rem;line-height:1;font-weight:700}
.in-price del{font-family:"Fraunces",serif;font-size:1.3rem;opacity:.6;font-weight:500;margin-bottom:6px}
.in-price-sub{font-size:.88rem;opacity:.85;margin-bottom:24px;display:block}
.enroll-bullets{list-style:none;padding:0;margin:0 0 28px;display:grid;gap:10px}
.enroll-bullets li{padding-left:30px;position:relative;font-size:.96rem}
.enroll-bullets li::before{content:"";position:absolute;left:0;top:2px;width:20px;height:20px;border-radius:50%;background:rgba(255,246,233,.2);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>");background-size:14px;background-repeat:no-repeat;background-position:center}
.enroll-summary{background:rgba(255,246,233,.12);backdrop-filter:blur(10px);padding:26px;border-radius:20px;border:1px solid rgba(255,246,233,.2)}
.enroll-summary h4{font-size:1.05rem;color:var(--azafran);margin-bottom:16px}
.enroll-summary .row{display:flex;justify-content:space-between;align-items:flex-start;padding:11px 0;border-bottom:1px solid rgba(255,246,233,.15);gap:12px}
.enroll-summary .row:last-child{border-bottom:0}
.enroll-summary .row span{opacity:.85;font-size:.85rem;flex-shrink:0}
.enroll-summary .row b{font-family:"Fraunces",serif;font-size:.95rem;text-align:right}

/* ===========================================================
   COUNTDOWN STRIP
   =========================================================== */
.cd-strip{background:var(--noche);color:var(--crema);padding:24px 0}
.cd-strip-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.cd-left{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.countdown{display:flex;gap:10px}
.cd-cell{background:rgba(255,246,233,.08);border:1px solid rgba(252,191,73,.25);padding:8px 12px;border-radius:10px;text-align:center;min-width:54px}
.cd-cell b{font-family:"Fraunces",serif;font-size:1.4rem;display:block;color:var(--azafran);line-height:1}
.cd-cell span{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;opacity:.8}
.cd-text b{color:var(--azafran);font-family:"Fraunces",serif;font-style:italic}

/* ===========================================================
   FAQ (details)
   =========================================================== */
.faq-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:60px;align-items:flex-start}
.faq-list{display:grid;gap:14px}
details.q{
  background:#fff;border-radius:14px;padding:18px 22px;
  box-shadow:var(--shadow);border:1px solid rgba(196,69,54,.05);
  transition:box-shadow .2s;
}
details.q[open]{box-shadow:var(--shadow-hover)}
details.q summary{
  list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:12px;
  font-family:"Fraunces",serif;font-weight:600;font-size:1.05rem;color:var(--noche);
}
details.q summary::-webkit-details-marker{display:none}
details.q summary::after{content:"+";color:var(--paprika);font-size:1.6rem;font-weight:700;transition:transform .25s;line-height:1;flex-shrink:0}
details.q[open] summary::after{content:"−"}
details.q p{color:var(--soft);margin:14px 0 0;font-size:.96rem;line-height:1.6}

/* ===========================================================
   PRICE LIST (ceník)
   =========================================================== */
.price-list{display:grid;gap:16px}
.price-row{
  background:#fff;border-radius:18px;padding:24px 28px;box-shadow:var(--shadow);
  display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;
  border:1px solid rgba(196,69,54,.05);transition:transform .25s,box-shadow .25s;
}
.price-row:hover{transform:translateX(4px);box-shadow:var(--shadow-hover)}
.price-row .what b{font-family:"Fraunces",serif;font-size:1.15rem;display:block;line-height:1.3;margin-bottom:4px}
.price-row .what span{font-size:.93rem;color:var(--soft)}
.price-row .pr{font-family:"Fraunces",serif;font-size:1.45rem;font-weight:700;color:var(--paprika-deep);white-space:nowrap}

/* ===========================================================
   CONTACT FORM
   =========================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:flex-start}
.contact-info{display:flex;flex-direction:column;gap:14px}
.contact-row{
  display:flex;align-items:center;gap:18px;
  background:#fff;padding:20px 24px;border-radius:16px;
  box-shadow:var(--shadow);border:1px solid rgba(196,69,54,.05);
  text-decoration:none;color:inherit;transition:transform .25s,box-shadow .25s;
}
.contact-row:hover{transform:translateX(4px);box-shadow:var(--shadow-hover)}
.contact-row .ico-circle{width:48px;height:48px;border-radius:14px}
.contact-row .ico-circle .ico{width:24px;height:24px}
.contact-row .det b{font-family:"Fraunces",serif;font-size:1.1rem;display:block}
.contact-row .det span{font-size:.85rem;color:var(--soft)}
form.contact{
  background:#fff;border-radius:24px;padding:40px;box-shadow:var(--shadow);
  border:1px solid rgba(196,69,54,.05);display:grid;gap:18px;
}
form.contact h3{margin-bottom:6px}
form.contact .field{display:grid;gap:6px}
form.contact .field label{font-size:.84rem;font-weight:700;color:var(--noche);letter-spacing:.04em}
form.contact input,form.contact textarea{
  font-family:inherit;font-size:1rem;color:var(--noche);
  padding:12px 16px;border-radius:12px;border:1.5px solid var(--line);
  background:var(--crema);transition:border-color .2s,background .2s;
  width:100%;
}
form.contact input:focus,form.contact textarea:focus{outline:none;border-color:var(--paprika);background:#fff}
form.contact textarea{min-height:120px;resize:vertical}
form.contact .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
form.contact button{
  justify-self:flex-start;
}

/* ===========================================================
   COURSE HEADER (varianta hero pro DELE/Konv stránky)
   =========================================================== */
.course-hero{padding:70px 0 60px;background:radial-gradient(900px 500px at 80% -10%,rgba(252,191,73,.5),transparent 60%),radial-gradient(700px 500px at -10% 50%,rgba(247,127,0,.2),transparent 65%),var(--crema);position:relative;overflow:hidden}
.course-hero .grid{display:grid;grid-template-columns:1.2fr 1fr;gap:60px;align-items:center;position:relative;z-index:2}
.course-hero h1{margin:14px 0 18px;font-size:clamp(2.4rem,5vw,4.4rem)}
.course-hero p.lead{font-size:1.15rem;color:var(--soft);max-width:560px;margin:0 0 28px}
.course-hero .price-line{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;margin-bottom:8px}
.course-hero .price-line b{font-family:"Fraunces",serif;font-size:2.6rem;font-weight:700;line-height:1;color:var(--paprika-deep)}
.course-hero .price-line span{font-size:1rem;color:var(--soft)}

/* breadcrumb */
.crumbs{font-size:.85rem;color:var(--soft);margin-bottom:8px}
.crumbs a{text-decoration:none;color:var(--soft)}
.crumbs a:hover{color:var(--paprika)}
.crumbs span{margin:0 8px;opacity:.5}

/* ===========================================================
   SERVICE GRID (homepage)
   =========================================================== */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.svc{
  background:#fff;border-radius:22px;padding:32px;box-shadow:var(--shadow);
  border:1px solid rgba(196,69,54,.05);transition:transform .25s,box-shadow .25s;
  display:flex;flex-direction:column;gap:14px;
}
.svc:hover{transform:translateY(-4px);box-shadow:var(--shadow-hover)}
.svc .ico-circle{width:54px;height:54px}
.svc .ico-circle .ico{width:28px;height:28px}
.svc h3{font-size:1.3rem;line-height:1.2}
.svc p{color:var(--soft);font-size:.96rem;margin:0;line-height:1.55}

/* ===========================================================
   FINAL CTA
   =========================================================== */
.cta-final{padding:120px 0;text-align:center;position:relative;overflow:hidden;background:var(--crema)}
.cta-final::before{content:"";position:absolute;width:600px;height:600px;border-radius:50%;background:radial-gradient(circle,rgba(247,127,0,.15),transparent 60%);top:-200px;left:-200px;pointer-events:none}
.cta-final::after{content:"";position:absolute;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(252,191,73,.2),transparent 60%);bottom:-200px;right:-100px;pointer-events:none}
.cta-final .wrap{position:relative;z-index:1}
.cta-final h2{margin:18px auto 18px;max-width:820px}
.cta-final p{color:var(--soft);font-size:1.1rem;max-width:560px;margin:0 auto 32px}
.cta-final .hero-cta{justify-content:center}

/* ===========================================================
   FOOTER
   =========================================================== */
footer{background:var(--vino);color:var(--crema);padding:60px 0 30px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px;margin-bottom:50px}
.foot-grid h4{font-family:"Fraunces",serif;font-size:1.05rem;margin:0 0 14px;color:var(--azafran)}
.foot-grid a{color:rgba(255,246,233,.8);text-decoration:none;display:block;font-size:.92rem;padding:5px 0}
.foot-grid a:hover{color:var(--azafran)}
.foot-bottom{border-top:1px solid rgba(255,246,233,.15);padding-top:24px;display:flex;justify-content:space-between;font-size:.85rem;color:rgba(255,246,233,.6);flex-wrap:wrap;gap:12px}
.foot-brand p{color:rgba(255,246,233,.7);font-size:.93rem;max-width:340px;margin:14px 0 0;line-height:1.55}

/* ===========================================================
   RESPONSIVE
   =========================================================== */
@media (max-width:1180px){
  .menu{gap:14px}
  .menu a{font-size:.86rem}
  .cta-btn{padding:11px 18px;font-size:.88rem}
}
@media (max-width:1100px){
  .menu-toggle{display:inline-flex}
  .menu{display:none;position:absolute;top:100%;left:0;right:0;background:var(--crema);flex-direction:column;align-items:flex-start;padding:24px;gap:16px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  /* Dropdown na mobilu — rozbalený inline, bez hover triku */
  .menu-dropdown{display:flex;flex-direction:column;align-items:flex-start;gap:6px;width:100%}
  .menu-dropdown .dd-trigger{display:flex}
  .dd-caret{display:none}
  .dd-menu{display:flex !important;position:static;transform:none;background:transparent;box-shadow:none;border:0;padding:0 0 0 14px;min-width:0;border-left:2px solid var(--line);margin-left:2px}
  .dd-menu a{padding:6px 0;font-size:.86rem;color:var(--soft)}
  .dd-menu a:hover,.dd-menu a.active{background:transparent;color:var(--paprika-deep)}
  .menu-dropdown::before{display:none}
  .menu.open{display:flex}
  .hero-grid,.hero-grid.tight,.course-hero .grid{grid-template-columns:1fr;gap:40px}
  .hero-art{height:380px}
  .hero{padding:60px 0 100px}
  .section{padding:90px 0}
  .section-head{grid-template-columns:1fr;gap:20px}
  .grid-2,.grid-3,.grid-4,.svc-grid{grid-template-columns:1fr}
  .badge-strip{grid-template-columns:1fr 1fr;padding:24px;gap:14px}
  .radio-grid{grid-template-columns:1fr}
  .grid-2.dele{grid-template-columns:1fr}
  .card.featured{grid-column:span 1;grid-template-columns:1fr;padding:36px}
  .about-grid{grid-template-columns:1fr;gap:50px}
  .facts{grid-template-columns:1fr 1fr}
  .test-grid,.test-grid.two{grid-template-columns:1fr;gap:18px}
  .program-blocks{grid-template-columns:1fr 1fr}
  .enroll-card{grid-template-columns:1fr;padding:36px}
  .faq-grid,.contact-grid{grid-template-columns:1fr;gap:30px}
  .foot-grid{grid-template-columns:1fr 1fr;gap:30px}
  .timeline::before{left:24px}
  .tl-item{padding-left:72px}
  .tl-num{width:54px;height:54px;font-size:1.2rem;border-width:4px}
  .facts-row{grid-template-columns:1fr 1fr}
  .price-row{grid-template-columns:1fr;gap:8px}
  .price-row .pr{font-size:1.3rem}
}
@media (max-width:520px){
  body{font-size:16px}
  .wrap,.wrap-narrow{padding:0 18px}
  .nav-inner{padding:14px 18px;gap:12px}
  .brand-text b{font-size:1rem}
  .brand-text span{font-size:.66rem}
  .brand-mark{width:36px;height:36px}
  .bar{padding:10px 14px;font-size:.78rem;line-height:1.4}

  /* Hero */
  .hero{padding:36px 0 60px}
  .hero-grid,.hero-grid.tight,.course-hero .grid{gap:30px}
  .hero h1{font-size:2rem;line-height:1.1}
  .course-hero h1{font-size:2rem}
  .hero p.lead,.course-hero p.lead{font-size:1rem}
  .hero-meta{gap:16px;margin-top:28px;flex-wrap:wrap}
  .hero-meta div{flex:1;min-width:90px}
  .hero-meta b{font-size:1.4rem}
  .hero-art{height:300px}
  .hero-badge{font-size:.78rem;padding:8px 14px;white-space:normal;line-height:1.3}

  /* Hero artwork — zmenšit a zviditelnit */
  .orange-art,.orange-photo{width:220px !important;height:220px !important}
  .sun-art{width:120px !important;height:120px !important}
  .tag-float{font-size:.74rem;padding:7px 12px;max-width:160px;white-space:normal;line-height:1.3}

  /* Course hero — facts */
  .facts-row{grid-template-columns:1fr 1fr;gap:10px;margin-top:24px}
  .fact-pill{padding:14px 12px;min-height:auto}
  .fact-pill b{font-size:.92rem}
  .fact-pill .ico-circle{width:32px;height:32px}
  .fact-pill .ico-circle .ico{width:18px;height:18px}

  /* Sections */
  .section,.cta-final{padding:60px 0}
  h2{font-size:1.7rem !important;line-height:1.15}
  h3{font-size:1.2rem}
  .section-head{margin-bottom:36px}

  /* Cards */
  .card{padding:24px}
  .card h3{font-size:1.25rem}
  .card.featured,.enroll-card{padding:24px}
  .card.featured h3{font-size:1.5rem}
  .card-meta{grid-template-columns:1fr;gap:10px}
  .card-meta .row .lbl b{font-size:.88rem}
  .card-meta .row .lbl span{font-size:.68rem}
  .card-foot{flex-direction:column;align-items:flex-start;gap:14px}
  .card-foot .btn-card{align-self:stretch;justify-content:center}

  /* Buttons — zmenšit padding na malém viewportu */
  .cta-btn{padding:13px 18px;font-size:.88rem}
  .cta-btn.lg{padding:14px 22px;font-size:.92rem}
  .cta-btn.giant{padding:16px 24px;font-size:.96rem}
  .btn-ghost{padding:11px 18px;font-size:.88rem}
  .hero-cta{flex-direction:column;align-items:stretch;width:100%}
  .hero-cta .cta-btn,.hero-cta .btn-ghost{justify-content:center;width:100%}

  /* Strip and countdown */
  .strip-track span{font-size:1rem;gap:14px}
  .strip-track span::after{margin-left:14px}
  .cd-strip{padding:18px 0}
  .cd-strip-inner{flex-direction:column;align-items:stretch;gap:14px}
  .cd-left{flex-direction:column;align-items:stretch;gap:10px;width:100%}
  .cd-text{text-align:center;font-size:.88rem}
  .countdown{gap:6px;justify-content:center}
  .cd-cell{min-width:0;flex:1;padding:8px 4px;max-width:80px}
  .cd-cell b{font-size:1.2rem}
  .cd-strip-inner > a{align-self:center}

  /* Enroll */
  .in-price b{font-size:2.4rem}
  .in-price del{font-size:1.1rem}
  .enroll-summary{padding:20px}
  .enroll-summary .row{padding:8px 0}
  .enroll-summary .row span,.enroll-summary .row b{font-size:.88rem}

  /* Program */
  .program-blocks{grid-template-columns:1fr}
  .pb{padding:22px}
  .timeline::before{left:18px}
  .tl-item{padding:0 0 32px 60px}
  .tl-num{width:44px;height:44px;font-size:1rem;border-width:3px}
  .tl-item h3{font-size:1.2rem}

  /* Photos */
  .photo-real{aspect-ratio:1/1}
  .photo-real .badge{padding:10px 14px;bottom:14px;left:14px}
  .photo-real .badge .num{font-size:1.4rem}
  .photo-real .badge span{font-size:.76rem;max-width:100px}

  /* Forms */
  form.contact{padding:22px}
  form.contact .row2{grid-template-columns:1fr}
  .enroll-form .row2{grid-template-columns:1fr}
  .radio-grid{grid-template-columns:1fr}
  .radio-pill{padding:10px 14px;font-size:.92rem}

  /* Badge strip */
  .badge-strip{grid-template-columns:1fr;gap:12px;padding:18px}
  .credential{flex-direction:row;text-align:left;gap:14px;justify-content:flex-start}
  .credential .seal{width:54px;height:54px;font-size:.95rem;flex-shrink:0}

  /* Contact info */
  .contact-row{padding:14px 16px}
  .contact-row .ico-circle{width:40px;height:40px;border-radius:10px}
  .contact-row .ico-circle .ico{width:20px;height:20px}
  .contact-row .det b{font-size:.95rem}
  .contact-row .det span{font-size:.78rem}

  /* Featured (workshop card) */
  .featured-art{height:160px;margin-top:6px}
  .featured-art svg{width:160px;height:160px}

  /* Eyebrow */
  .eyebrow{font-size:.7rem;letter-spacing:.14em}

  /* Foot */
  .foot-grid{grid-template-columns:1fr;gap:24px;margin-bottom:30px}
  .foot-bottom{flex-direction:column;gap:8px;font-size:.78rem;text-align:center}

  /* Italic accents */
  .hero h1 .underlined::after{height:8px;bottom:8%}

  /* Crumbs */
  .crumbs{font-size:.78rem}

  /* About facts */
  .facts{grid-template-columns:1fr 1fr;gap:12px}
  .fact{padding:18px 14px}
  .fact b{font-size:1.5rem}
  .fact span{font-size:.8rem}

  /* Test grid */
  .test{padding:22px}
  .test p{font-size:.96rem}

  /* Inline grids (statistiky 3-col v lektor sekcích) přebijou */
  [style*="grid-template-columns:repeat(3,1fr)"]{grid-template-columns:1fr 1fr !important;gap:10px !important}
  [style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:1fr 1fr"]{grid-template-columns:1fr !important}
  [style*="grid-template-columns:1.4fr 1fr"]{grid-template-columns:1fr !important;gap:24px !important}

  /* Early bird pill */
  .early-bird{font-size:.66rem;padding:5px 10px}

  /* Mobile menu */
  .menu{padding:20px 18px;gap:14px;max-height:calc(100vh - 60px);overflow-y:auto}
  .menu .cta-btn{align-self:flex-start;width:auto}
}

@media (max-width:380px){
  .hero h1{font-size:1.7rem}
  h2{font-size:1.5rem !important}
  .facts-row{grid-template-columns:1fr}
  .hero-meta{flex-direction:column;gap:12px}
  .hero-meta div{flex-direction:row;justify-content:space-between;align-items:baseline;width:100%}
  .hero-meta b{font-size:1.3rem}
  .countdown{flex-wrap:wrap}
  .cd-cell{min-width:60px}
  .price b{font-size:1.4rem}
  .in-price{flex-wrap:wrap}
  .in-price b{font-size:2rem}
  .featured-meta,.card-meta{grid-template-columns:1fr}
}
