/* BikeKempy.cz Styles */

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0
}

:root {
  --bg: #F5EFE4;
  --bg2: #EDE5D6;
  --bg3: #E4D9C6;
  --surface: #FAF6EE;
  --ink: #2A1F0E;
  --ink2: #6A5438;
  --muted: #9A8060;
  --ghost: #C8B898;
  --orange: #C8780A;
  --hot: #B06408;
  --ember: #E09020;
  --indigo: #8A6A3A;
  --lime: #4A8A2A;
  --lime2: #3A7020;
  --lime-bg: #E8F0DC;
  --tan: #A08060;
  --sand: #C4AA84;
  --border: #D4C4A4;
  --border2: #C0AC88;
  --yellow: #ead12e;
  --sh: 0 4px 24px rgba(80, 50, 10, .12);
  --sh2: 0 8px 40px rgba(80, 50, 10, .20);
  --fd: 'Bebas Neue', cursive;
  --fb: 'Outfit', sans-serif;
  --r: 6px;
  --rl: 16px;
  --t: .17s ease;
  --t2: .3s ease;
}

html {
  scroll-behavior: smooth
}

body {
  font-family: var(--fb);
  font-size: 15px;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.65;
  overflow-x: hidden
}

a {
  color: inherit;
  text-decoration: none
}

input,
select,
textarea,
button {
  font-family: var(--fb)
}

::-webkit-scrollbar {
  width: 5px
}

::-webkit-scrollbar-track {
  background: var(--bg2)
}

::-webkit-scrollbar-thumb {
  background: var(--border2);
  border-radius: 3px
}

/* ── PAGES ── */
.pg {
  display: none;
  min-height: 100vh
}

.pg.on {
  display: block;
  animation: fu .28s ease
}

@keyframes fu {
  from {
    opacity: 0;
    transform: translateY(10px)
  }

  to {
    opacity: 1;
    transform: none
  }
}

/* ── BUTTONS ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  padding: 11px 22px;
  border: none;
  border-radius: var(--r);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all var(--t);
  font-family: var(--fb)
}

.btn-o {
  background: var(--orange);
  color: #fff
}

.btn-o:hover {
  background: var(--hot);
  box-shadow: 0 4px 20px rgba(204, 68, 0, .3);
  transform: translateY(-1px)
}

.btn-ol {
  background: transparent;
  color: var(--orange);
  border: 2px solid var(--orange)
}

.btn-ol:hover {
  background: var(--orange);
  color: #fff
}

.btn-l {
  background: var(--lime);
  color: #fff
}

.btn-l:hover {
  background: var(--lime2);
  transform: translateY(-1px)
}

.btn-g {
  background: var(--surface);
  color: var(--ink2);
  border: 1.5px solid var(--border2)
}

.btn-g:hover {
  border-color: var(--orange);
  color: var(--orange)
}

.btn-ghost {
  background: transparent;
  color: var(--muted);
  border: none
}

.btn-ghost:hover {
  color: var(--ink)
}

.btn-sm {
  padding: 7px 14px;

  font-size: 13.5px
}

.btn-lg {
  padding: 14px 22px;
  font-size: 16px
}

.btn-xl {
  padding: 14px 44px;
  font-size: 16px
}

.btn-fw {
  width: 100%
}

/* ── BADGES ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px
}

.bg {
  background: #dcfce7;
  color: #15803d;
  border: 1px solid #bbf7d0
}

.bo {
  background: #fff7ed;
  color: var(--orange);
  border: 1px solid #fed7aa
}

.by {
  background: #fefce8;
  color: #92400e;
  border: 1px solid #fde68a
}

.br {
  background: #fef2f2;
  color: #b91c1c;
  border: 1px solid #fecaca
}

.bbl {
  background: #eff6ff;
  color: #1d4ed8;
  border: 1px solid #bfdbfe
}

.bgr {
  background: var(--bg2);
  color: var(--muted);
  border: 1px solid var(--border)
}

.diff-z {
  background: #dcfce7;
  color: #15803d;
  border: 1px solid #bbf7d0
}

.diff-p {
  background: #fff7ed;
  color: var(--orange);
  border: 1px solid #fed7aa
}

.diff-e {
  background: #fdf4ff;
  color: #7e22ce;
  border: 1px solid #e9d5ff
}

/* ── NAV ── */
.nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 900;
  height: 62px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10 48px;
  background: rgba(6, 21, 46, 0.82);
  backdrop-filter: blur(18px);
  border-bottom: 1.5px solid rgba(255, 255, 255, .08);
  transition: background .25s, border-color .25s
}

body[data-page="reg"] .nav,
body[data-page="login"] .nav {
  background: #06152E;
  border-bottom-color: rgba(255, 255, 255, .08)
}

body[data-page="reg"] .nav-logo,
body[data-page="reg"] .nav-logo em,
body[data-page="login"] .nav-logo,
body[data-page="login"] .nav-logo em {
  color: #fff
}

body[data-page="reg"] .navul a,
body[data-page="login"] .navul a {
  color: rgba(255, 255, 255, .6)
}

body[data-page="reg"] .navul a:hover,
body[data-page="login"] .navul a:hover {
  color: #fff
}

body[data-page="reg"] .navul li+li::before,
body[data-page="login"] .navul li+li::before {
  background: rgba(255, 255, 255, .2)
}

body[data-page="reg"] .nav-burger svg,
body[data-page="login"] .nav-burger svg {
  stroke: #fff
}

.nav-logo {
  font-family: var(--fd);
  font-size: 25px;
  letter-spacing: 2.5px;
  cursor: pointer;
  display: flex;
  align-items: center;
  padding: 0px 25px;
  gap: 7px;
  color: var(--orange)
    /* ──color: var(--ink)── */
}

.nav-logo em {
  font-style: normal;
  color: var(--orange)
}

.navul {
  display: flex;
  align-items: center;
  gap: 28px;
  list-style: none
}

.navul a {
  font-size: 15px;
  font-weight: 600;
  color: var(--orange);
  cursor: pointer;
  transition: color var(--t)
}

.navul a:hover {
  color: var(--ember)
}

.navul a.act {
  color: var(--orange)
}

.navul a.act:hover {
  color: var(--ember)
}

.navul li+li {
  position: relative;
  padding-left: 20px;
}

.navul li+li::before {
  content: '';
  position: absolute;
  left: -4px;
  top: 50%;
  transform: translateY(-50%);
  width: 1px;
  height: 16px;
  background: rgba(255, 255, 255, .2);
  border-radius: 1px;
}

.lang-toggle {
  display: flex;
  gap: 0;
  border: 1.5px solid rgba(255, 255, 255, .18);
  border-radius: 7px;
  overflow: hidden;
  margin-right: 4px;
}

.lang-toggle button {
  background: transparent;
  border: none;
  padding: 4px 10px;
  font-size: 11.5px;
  font-weight: 700;
  font-family: var(--fb);
  color: rgba(255, 255, 255, .55);
  cursor: pointer;
  letter-spacing: .5px;
  transition: all var(--t);
}

.lang-toggle button:first-child {
  border-right: 1.5px solid rgba(255, 255, 255, .18);
}

.lang-toggle button:hover {
  color: #fff;
  background: rgba(255, 255, 255, .08);
}

.lang-toggle button.on {
  background: var(--orange);
  color: #fff;
}

.nav-btns {
  display: flex;
  gap: 9px;
  padding-right: 30px
}

/* ── HERO ── */
.hero {
  padding: 60px 48px 52px;
  padding-top: calc(60px + 62px);
  position: relative;
  display: flex;
  align-items: center;
  overflow: hidden
}



.hero-bg {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(to right, rgba(245, 239, 228, .90) 5%, rgba(245, 239, 228, .55) 15%, rgba(245, 239, 228, .10) 65%, transparent 100%),
    url('../public/w2TME.jpg') center/cover no-repeat;
  border-bottom: 1.5px solid var(--border);
  padding: 60px 48px 52px
}

.hero-inner {
  position: relative;
  z-index: 1;
  max-width: 1240px;
  margin: 0 auto;
  padding: 30px 30px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: flex-start
}

/* Hero pill badge */
.hero-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--indigo);
  color: #fff;
  border-radius: 999px;
  padding: 5px 14px;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  margin-bottom: 20px;
  animation: fu .45s ease
}

/* Hero inline search */
.hero-search {
  display: flex;
  gap: 0;
  width: 100%;
  max-width: 480px;
  background: var(--surface);
  border: 1.5px solid var(--border2);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: var(--sh);
  margin-bottom: 18px;
  animation: fu .45s ease .22s both
}

.hero-search-input {
  flex: 1;
  border: none;
  outline: none;
  padding: 13px 16px;
  font-family: var(--fb);
  font-size: 14px;
  color: var(--ink);
  background: transparent
}

.hero-search-input::placeholder {
  color: var(--ghost)
}

.hero-search .btn {
  border-radius: 0 10px 10px 0;
  padding: 12px 20px;
  font-size: 14px
}

/* Hero stat pills */
.hero-stat-pills {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  animation: fu .45s ease .3s both
}

.hero-stat-pill {
  border: 1.5px solid var(--border2);
  border-radius: 999px;
  padding: 6px 16px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2);
  background: var(--surface)
}

/* Hero foto (right column) */
.hero-foto {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  aspect-ratio: 4/3;
  background: url('../ICON_TEMP/hero_bg2.jpg') center/cover no-repeat;
  animation: fu .45s ease .1s both
}

/* Floating testimonial on hero foto */
.hero-testimonial {
  position: absolute;
  bottom: 20px;
  left: 20px;
  right: 20px;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: blur(10px);
  border-radius: 12px;
  padding: 14px 18px;
  display: flex;
  flex-direction: column;
  gap: 4px
}

.hero-test-stars {
  font-size: 13px;
  letter-spacing: 1px
}

.hero-test-text {
  font-size: 13px;
  font-weight: 600;
  color: var(--ink);
  line-height: 1.4
}

.hero-test-author {
  font-size: 11px;
  color: var(--muted)
}

.eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 3.5px;
  color: var(--orange);
  margin-bottom: 18px;
  animation: fu .45s ease
}

.h1 {
  font-family: var(--fd);
  font-size: clamp(35px, 8.5vw, 65px);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: .9;
  margin-bottom: 5px;
  color: var(--ink);
  animation: fu .45s ease .07s both
}

.h1 em {
  font-style: normal;
  color: var(--hot);
  dissec-lay: block;
  text-shadow: 0 2px 20px rgba(235, 218, 161, 0.35)
}

.hero-sub {
  font-size: 17px;
  color: var(--ink);
  font-weight: 400;
  max-width: 540px;
  line-height: 1.75;
  margin-bottom: 14px;
  animation: fu .45s ease .14s both
}

.hero-tags {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  margin-bottom: 22px;
  animation: fu .45s ease .18s both
}

.htag {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 6px 14px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ink2);
  cursor: pointer;
  transition: all var(--t)
}

.htag:hover,
.htag.on {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff
}

.hero-ctas {
  display: flex;
  gap: 19px;
  flex-wrap: wrap;
  margin-bottom: 2px;
  animation: fu .45s ease .22s both
}

.hero-stats {
  display: flex;
  gap: 44px;
  flex-wrap: wrap;
  padding-top: 16px;
  border-top: 1.5px solid var(--border);
  animation: fu .45s ease .3s both
}

.hs-n {
  font-family: var(--fd);
  font-size: 28px;
  letter-spacing: .5px;
  line-height: 1;
  color: var(--ink)
}

.hs-l {
  font-size: 11px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 3px
}

/* ── SECTIONS ── */
.section {
  padding: 20px 40px;
  max-width: 1240px;
  margin: 0 auto
}

.sec-l {
  font-size: 14px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 2.5px;
  color: var(--orange);
  margin-bottom: 7px
}

.sec-t {
  font-family: var(--fd);
  font-size: clamp(32px, 3.0vw, 35px);
  text-transform: uppercase;
  letter-spacing: 1px;
  line-height: 1;
  color: var(--ink)
}

/* ── FILTER BAR ── */
.filter-bar {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 20px 24px;
  margin-bottom: 28px;
  box-shadow: var(--sh);
  display: flex;
  gap: 14px;
  align-items: flex-end;
  flex-wrap: wrap
}

.fg-f {
  display: flex;
  flex-direction: column;
  gap: 5px
}

.fg-f label {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted)
}

.fsel,
.finp {
  padding: 9px 12px;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  color: var(--ink);
  font-size: 13.5px;
  font-weight: 600;
  outline: none;
  cursor: pointer;
  font-family: var(--fb);
  transition: border-color var(--t)
}

.fsel {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='11' height='7'%3E%3Cpath d='M.5.5l5 5 5-5' stroke='%238a7660' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  padding-right: 28px;
  -webkit-appearance: none;
  appearance: none
}

.fsel:focus,
.finp:focus {
  border-color: var(--orange)
}

.finp {
  min-width: 200px;
  flex: 1
}

.finp::placeholder {
  color: var(--ghost)
}

.diff-pills {
  display: flex;
  gap: 6px;
  flex-wrap: wrap
}

.dpill {
  padding: 7px 13px;
  border-radius: 20px;
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  color: var(--muted);
  transition: all var(--t)
}

.dpill:hover {
  border-color: var(--orange);
  color: var(--orange)
}

.dpill.on {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff
}

/* ── COURSE CARDS ── */
.kgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px
}

.pop-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px
}

.kcard {
  background: var(--surface);
  border: none;
  border-radius: var(--rl);
  overflow: hidden;
  box-shadow: var(--sh);
  transition: transform var(--t2), box-shadow var(--t2);
  cursor: pointer;
  display: flex;
  flex-direction: column
}

.kcard:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh2)
}

.kcard-img {
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden
}

.kcard-img::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(24, 17, 10, .55) 0%, transparent 55%)
}

.kcard-badges {
  position: absolute;
  top: 11px;
  left: 11px;
  display: flex;
  gap: 6px;
  z-index: 1;
  flex-wrap: wrap
}

.kcard-price {
  position: absolute;
  bottom: 11px;
  right: 11px;
  z-index: 1;
  background: var(--orange);
  color: #fff;
  font-family: var(--fd);
  font-size: 22px;
  letter-spacing: .5px;
  padding: 4px 11px;
  border-radius: 5px;
  line-height: 1.2
}

.kcard-body {
  padding: 17px 19px 20px;
  display: flex;
  flex-direction: column;
  flex: 1
}

.kcard-type {
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.8px;
  color: var(--orange);
  margin-bottom: 4px
}

.kcard-title {
  font-family: var(--fd);
  font-size: 23px;
  text-transform: uppercase;
  letter-spacing: .5px;
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 0px
}

.kcard-focus {
  font-size: 13px;
  color: var(--ink2);
  line-height: 1.5;
  margin-bottom: 10px
}

/* session box in card */
.kcard-sess {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 10px 13px;
  margin-bottom: 12px
}

.kcard-sess-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 4px
}

.kcard-sess-date {
  font-weight: 800;
  font-size: 13.5px;
  color: var(--ink)
}

.kcard-sess-time {
  font-size: 12px;
  color: var(--muted);
  display: flex;
  align-items: center;
  gap: 6px
}

.capb {
  height: 4px;
  background: var(--bg3);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 6px
}

.capf {
  height: 100%;
  border-radius: 2px;
  transition: width .5s
}

.capf-g {
  background: var(--lime)
}

.capf-y {
  background: #f59e0b
}

.capf-r {
  background: #dc2626
}

.kcard-seats {
  font-size: 11px;
  color: var(--muted);
  margin-top: 4px
}

/* focus tags */
.focus-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px
}

.ftag {
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  background: var(--bg2);
  color: var(--muted);
  border: 1px solid var(--border)
}

.kcard-lektor {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-top: auto;
  padding-top: 12px;
  border-top: 1px solid var(--border)
}

.kcard-av {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid var(--orange);
  flex-shrink: 0
}

.kcard-rating {
  text-align: right;
  margin-left: auto
}

.kcard-stars {
  color: #f59e0b;
  font-size: 12px
}

.kcard-rn {
  font-size: 11px;
  color: var(--muted)
}

/* ── HOW IT WORKS ── */
.how-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 15px;
  position: relative;
  margin-top: 42px
}

.how-grid::before {
  content: '';
  position: absolute;
  top: 44px;
  left: 12.5%;
  right: 12.5%;
  height: 2px;
  background: var(--border2);
  z-index: 0
}

.hstep {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 24px 20px;
  position: relative;
  overflow: hidden;
  transition: border-color var(--t), transform var(--t2)
}

.hstep:hover {
  border-color: rgba(204, 68, 0, .3);
  transform: translateY(-3px);
  box-shadow: var(--sh)
}

.hstep-n {
  font-family: var(--fd);
  font-size: 78px;
  line-height: 1;
  color: rgba(204, 68, 0, .05);
  position: absolute;
  top: 2px;
  right: 10px
}

.hstep-ico {
  font-size: 32px;
  margin-bottom: 12px
}

.hstep-t {
  font-family: var(--fd);
  font-size: 20px;
  text-transform: uppercase;
  letter-spacing: .8px;
  color: var(--ink);
  margin-bottom: 6px
}

.hstep-d {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.65
}

/* ── TESTIMONIALS ── */
.tgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 35px;
  margin-top: 30px;
  margin-bottom: 25px;
  padding-right: 170px;
  padding-left: 170px
}

.tcard {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 40px;
  transition: border-color var(--t)
}

.tcard:hover {
  border-color: rgba(204, 68, 0, .2)
}

.tquote {
  font-size: 14px;
  color: var(--ink2);
  line-height: 1.75;
  font-style: italic;
  margin-bottom: 16px;
  padding-left: 18px;
  position: relative
}

.tquote::before {
  content: '"';
  position: absolute;
  left: 0;
  top: -4px;
  font-size: 34px;
  font-family: Georgia, serif;
  color: var(--orange);
  line-height: 1
}

.tperson {
  display: flex;
  align-items: center;
  gap: 10px
}

.tav {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid var(--border);
  flex-shrink: 0
}

.tname {
  font-weight: 700;
  font-size: 13.5px;
  color: var(--ink)
}

.tmeta {
  font-size: 11.5px;
  color: var(--muted)
}

/* ── LEKTOR STRIP ── */
.lstrip {
  background: var(--bg2);
  margin: 0;
  padding: 70px 48px
}

.lstrip-in {
  max-width: 1240px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center
}

.lstrip .sec-l {
  color: var(--orange)
}

.lstrip .sec-t {
  color: var(--ink)
}

.lstrip p {
  color: var(--ink2);
  font-size: 15px;
  line-height: 1.8;
  margin: 16px 0 26px
}

.lstrip-stats {
  display: flex;
  gap: 32px;
  margin-bottom: 30px
}

.ls-n {
  font-family: var(--fd);
  font-size: 40px;
  color: var(--orange)
}

.ls-l {
  font-size: 11px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 2px
}

.lfeats {
  display: flex;
  flex-direction: column;
  gap: 12px
}

.lf {
  display: flex;
  align-items: flex-start;
  gap: 12px
}

.lf-ico {
  width: 36px;
  height: 36px;
  background: rgba(232, 75, 0, .10);
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 15px;
  flex-shrink: 0;
  margin-top: 1px
}

.lf-t {
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
  margin-bottom: 2px
}

.lf-d {
  font-size: 12.5px;
  color: var(--muted)
}

/* ── REGISTRATION ── */
.reg-shell {
  display: grid;
  grid-template-columns: 300px 1fr;
  min-height: calc(100vh - 62px)
}

.reg-side {
  background: #0A2550;
  border-right: 1.5px solid rgba(255, 255, 255, .08);
  padding: 34px 22px;
  position: sticky;
  top: 62px;
  height: calc(100vh - 62px);
  overflow-y: auto;
  display: flex;
  flex-direction: column
}

.reg-main {
  padding: 46px 54px 80px;
  max-width: 580px;
  background: #E8EFF8
}

.rstep {
  display: none
}

.rstep.on {
  display: block;
  animation: fu .28s ease
}

.lstep {
  display: none
}

.lstep.on {
  display: block;
  animation: fu .28s ease
}

.step-li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 11px;
  border-radius: 7px;
  border: 1.5px solid transparent;
  margin-bottom: 5px;
  transition: all var(--t)
}

.step-li.done {
  border-color: rgba(130, 200, 80, .3);
  background: rgba(130, 200, 80, .1)
}

.step-li.cur {
  border-color: var(--orange);
  background: rgba(255, 255, 255, .08)
}

.step-li.idle {
  border-color: rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .04)
}

.step-circ {
  width: 29px;
  height: 29px;
  border-radius: 50%;
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 12.5px;
  transition: all var(--t)
}

.step-li.done .step-circ {
  background: var(--lime-bg);
  color: var(--lime)
}

.step-li.cur .step-circ {
  background: var(--orange);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(204, 68, 0, .1)
}

.step-li.idle .step-circ {
  background: rgba(255, 255, 255, .12);
  color: rgba(255, 255, 255, .45)
}

.step-name {
  font-size: 13px;
  font-weight: 700;
  color: #fff
}

.step-li.idle .step-name {
  color: rgba(255, 255, 255, .45)
}

.step-sub {
  font-size: 11px;
  color: rgba(255, 255, 255, .4);
  margin-top: 1px
}

/* ── FORMS ── */
.fg {
  margin-bottom: 16px
}

.fg label {
  display: block;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
  margin-bottom: 5px
}

.inp {
  width: 100%;
  padding: 11px 14px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  color: var(--ink);
  font-size: 14px;
  outline: none;
  transition: border-color var(--t), box-shadow var(--t);
  font-family: var(--fb);
  -webkit-appearance: none
}

.inp:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(204, 68, 0, .09)
}

.inp::placeholder {
  color: var(--ghost)
}

.g2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px
}

.g3 {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px
}

.err-msg {
  display: none;
  font-size: 11.5px;
  color: #dc2626;
  margin-top: 4px
}

.has-err .inp {
  border-color: #dc2626
}

.has-err .err-msg {
  display: block
}

.check-row {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  cursor: pointer;
  padding: 2px 0
}

.check-row input[type=checkbox] {
  width: 17px;
  height: 17px;
  flex-shrink: 0;
  margin-top: 2px;
  accent-color: var(--orange);
  cursor: pointer
}

.check-row span {
  font-size: 13.5px;
  color: var(--ink2);
  line-height: 1.5
}

.pw-bar {
  flex: 1;
  height: 3px;
  background: var(--border);
  border-radius: 2px;
  overflow: hidden
}

.pw-fill {
  height: 100%;
  border-radius: 2px;
  transition: width .3s, background .3s
}

.otp-inp {
  width: 52px;
  height: 60px;
  text-align: center;
  font-size: 26px;
  font-weight: 700;
  border: 2px solid var(--border);
  border-radius: 10px;
  font-family: var(--fb);
  color: var(--ink);
  outline: none;
  background: var(--surface);
  transition: border-color var(--t), box-shadow var(--t)
}

.otp-inp:focus {
  border-color: var(--orange);
  box-shadow: 0 0 0 3px rgba(204, 68, 0, .12)
}

/* ── BOOKING MODAL ── */
.bm-step {
  display: none
}

.bm-step.on {
  display: block;
  animation: fu .25s ease
}

.bm-head {
  margin-bottom: 20px
}

.bm-step-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--muted);
  margin-bottom: 4px
}

.bm-title {
  font-family: var(--fd);
  font-size: 26px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--ink)
}

.bm-sub {
  font-size: 13px;
  color: var(--orange);
  font-weight: 600;
  margin-top: 3px
}

.book-summary {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 14px 16px
}

.book-sum-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 5px 0;
  font-size: 13px;
  color: var(--ink2)
}

.book-sum-row span:first-child {
  color: var(--muted)
}

.book-sum-sep {
  height: 1px;
  background: var(--border);
  margin: 8px 0
}

.book-sum-row.total {
  font-size: 14.5px;
  font-weight: 700;
  color: var(--ink)
}

.book-sum-row.muted {
  font-size: 12px;
  color: var(--muted)
}

.email-preview {
  max-height: 260px;
  overflow-y: auto;
  border-radius: 10px;
  text-align: left
}

.stripe-spinner {
  width: 36px;
  height: 36px;
  border: 3px solid rgba(255, 255, 255, .3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  margin: 0 auto
}

@keyframes spin {
  to {
    transform: rotate(360deg)
  }
}

/* ── REMINDER LOG ── */
.rem-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 13px
}

.rem-row:last-child {
  border-bottom: none
}

/* ── UPCOMING COURSES ── */
.upc-row {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  transition: background .15s;
  border-radius: 6px
}

.upc-row:last-child {
  border-bottom: none
}

.upc-row:hover {
  background: var(--bg2)
}

.upc-date {
  width: 38px;
  flex-shrink: 0;
  text-align: center;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 8px;
  padding: 5px 4px
}

.cal-chip {
  position: relative;
  text-align: left
}

.cal-tip {
  display: none;
  position: absolute;
  bottom: calc(100% + 6px);
  left: 50%;
  transform: translateX(-50%);
  background: var(--ink);
  color: #fff;
  font-size: 10.5px;
  font-weight: 600;
  white-space: nowrap;
  padding: 4px 8px;
  border-radius: 6px;
  z-index: 50;
  pointer-events: none
}

.cal-tip::after {
  content: '';
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 4px solid transparent;
  border-top-color: var(--ink)
}

.cal-chip:hover .cal-tip {
  display: block
}

.skb {
  padding: 9px 7px;
  border-radius: var(--r);
  text-align: center;
  cursor: pointer;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--muted);
  transition: all var(--t);
  user-select: none
}

.skb:hover {
  border-color: rgba(204, 68, 0, .35);
  color: var(--ink)
}

.skb.on {
  background: #fff7f3;
  border-color: var(--orange);
  color: var(--orange)
}

.tag-list {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 7px
}

.tag {
  background: rgba(204, 68, 0, .08);
  border: 1.5px solid rgba(204, 68, 0, .2);
  color: var(--orange);
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px
}

.tag button {
  background: none;
  border: none;
  color: inherit;
  cursor: pointer;
  font-size: 13px
}

.pcrd {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 14px 16px;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  transition: border-color var(--t2), transform var(--t2);
  margin-bottom: 10px
}

.pcrd:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh)
}

.pcrd.feat {
  border-color: var(--orange)
}

.pcrd.feat::before {
  content: 'POPULAR';
  position: absolute;
  top: 14px;
  right: -28px;
  background: var(--orange);
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 4px 36px;
  transform: rotate(35deg)
}

.pcrd.sel {
  border-color: var(--lime);
  background: var(--lime-bg)
}

.pcrd-r {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid var(--border);
  flex-shrink: 0;
  transition: all var(--t)
}

/* ── DASHBOARD ── */
.dash-shell {
  display: grid;
  grid-template-columns: 250px 1fr;
  min-height: calc(100vh - 62px)
}

.dash-side {
  background: var(--surface);
  border-right: 1.5px solid var(--border);
  padding: 15px 10px;
  position: sticky;
  top: 62px;
  height: calc(100vh - 62px);
  overflow-y: auto;
  display: flex;
  flex-direction: column
}

.dash-main {
  padding: 30px 36px 60px;
  overflow-x: hidden
}

.dash-panel {
  display: none
}

.dash-panel.on {
  display: block;
  animation: fu .25s ease
}

.dh {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 22px;
  flex-wrap: wrap;
  gap: 10px
}

.dt {
  font-family: var(--fd);
  font-size: 30px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--ink)
}

.snav {
  display: flex;
  flex-direction: column;
  gap: 2px
}

.snav button {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 10px;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  color: var(--muted);
  transition: all var(--t);
  border: none;
  background: transparent;
  font-family: var(--fb);
  width: 100%;
  text-align: left;
  position: relative
}

.snav button::before {
  content: '';
  position: absolute;
  left: 0;
  top: 4px;
  bottom: 4px;
  width: 3px;
  border-radius: 2px;
  background: transparent;
  transition: background var(--t)
}

.snav button:hover {
  background: var(--bg2);
  color: var(--ink)
}

.snav button.on {
  background: #fff7f3;
  color: var(--orange)
}

.snav button.on::before {
  background: var(--orange)
}

.snav .ico {
  font-size: 14px;
  width: 17px;
  text-align: center;
  flex-shrink: 0
}

.snav .cnt {
  margin-left: auto;
  background: var(--orange);
  color: #fff;
  font-size: 9.5px;
  padding: 1px 6px;
  border-radius: 8px;
  font-weight: 700
}

.snav-sep {
  height: 1px;
  background: var(--border);
  margin: 5px 0
}

.scard {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 18px 20px
}

.sval {
  font-family: var(--fd);
  font-size: 36px;
  letter-spacing: .5px;
  line-height: 1;
  margin-bottom: 3px;
  color: var(--ink)
}

.slbl {
  font-size: 10.5px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1.3px;
  font-weight: 700
}

.card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 22px
}

.card-t {
  font-family: var(--fd);
  font-size: 17px;
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 13px;
  padding-bottom: 11px;
  border-bottom: 1.5px solid var(--border);
  color: var(--ink)
}

.chart {
  height: 130px;
  display: flex;
  align-items: flex-end;
  gap: 5px
}

.chcol {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px
}

.chbar {
  width: 100%;
  border-radius: 3px 3px 0 0;
  background: rgba(204, 68, 0, .1);
  cursor: pointer;
  transition: background var(--t)
}

.chbar:hover,
.chbar.hi {
  background: var(--orange)
}

.chlbl {
  font-size: 10px;
  color: var(--muted)
}

.itabs {
  display: flex;
  gap: 3px;
  background: var(--bg2);
  padding: 3px;
  border-radius: 7px;
  border: 1.5px solid var(--border);
  width: fit-content;
  margin-bottom: 18px
}

.itab {
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 600;
  border-radius: 5px;
  cursor: pointer;
  color: var(--muted);
  background: transparent;
  border: none;
  font-family: var(--fb);
  transition: all var(--t)
}

.itab.on {
  background: var(--orange);
  color: #fff
}

.btable {
  width: 100%;
  border-collapse: collapse
}

.btable th {
  text-align: left;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--muted);
  padding: 0 13px 9px
}

.btable td {
  padding: 12px 13px;
  border-top: 1px solid var(--border);
  font-size: 13px;
  vertical-align: middle
}

.btable tr:hover td {
  background: var(--bg2)
}

.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 3px;
  margin-top: 6px
}

.cal-day {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 5px 2px 4px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--t);
  min-height: 36px;
  border: 1.5px solid transparent
}

.cal-day.other {
  color: var(--ghost)
}

.cal-day.has-ev {
  background: var(--bg2);
  border-color: var(--border);
  font-weight: 700
}

.cal-day.today {
  background: var(--orange);
  color: #fff;
  font-weight: 700;
  border-color: var(--orange)
}

.cal-day.today .cal-dot {
  opacity: .85
}

.cal-day:hover:not(.today) {
  background: var(--bg2)
}

.cal-dots {
  display: flex;
  gap: 2px;
  margin-top: 3px;
  flex-wrap: wrap;
  justify-content: center
}

.cal-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  flex-shrink: 0
}

.cal-sess-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border)
}

.cal-sess-row:last-child {
  border-bottom: none
}

.cal-sess-bar {
  width: 3px;
  height: 38px;
  border-radius: 3px;
  flex-shrink: 0
}

.av {
  width: 86px;
  height: 86px;
  border-radius: 50%;
  background: var(--orange);
  border: 3px solid rgba(204, 68, 0, .2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--fd);
  font-size: 29px;
  color: #fff
}

.av-wrap {
  position: relative;
  width: 86px;
  flex-shrink: 0
}

.av-btn {
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 25px;
  height: 25px;
  border-radius: 50%;
  background: var(--orange);
  border: 2px solid var(--bg);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  cursor: pointer;
  color: #fff
}

.type-btn {
  padding: 12px 8px;
  border-radius: var(--r);
  text-align: center;
  cursor: pointer;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  font-size: 13px;
  font-weight: 600;
  color: var(--muted);
  transition: all var(--t)
}

.type-btn-ico {
  display: flex;
  justify-content: center;
  margin-bottom: 5px;
  line-height: 1
}

.type-btn:hover {
  border-color: rgba(204, 68, 0, .4);
  color: var(--ink)
}

.type-btn.on {
  background: #fff7f3;
  border-color: var(--orange);
  color: var(--orange)
}

.diff-btn {
  flex: 1;
  padding: 9px 5px;
  border-radius: var(--r);
  text-align: center;
  cursor: pointer;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  font-size: 12px;
  font-weight: 600;
  color: var(--muted);
  transition: all var(--t)
}

.dnd-zone {
  border: 2px dashed var(--border2);
  border-radius: var(--r);
  padding: 24px;
  text-align: center;
  cursor: pointer;
  color: var(--muted);
  transition: all var(--t);
  position: relative
}

.dnd-zone:hover,
.dnd-zone.drag-active {
  border-color: var(--orange);
  background: rgba(204, 68, 0, .03);
  color: var(--orange)
}

.dnd-zone input[type=file] {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer
}

.dnd-photos {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 12px
}

.dnd-th {
  aspect-ratio: 1;
  border-radius: 5px;
  background-size: cover;
  background-position: center;
  border: 1.5px solid var(--border);
  position: relative;
  overflow: hidden;
  cursor: grab
}

.dnd-th.first::after {
  content: 'Titulní';
  position: absolute;
  bottom: 3px;
  left: 3px;
  font-size: 9px;
  font-weight: 700;
  background: var(--orange);
  color: #fff;
  padding: 2px 5px;
  border-radius: 3px
}

.dnd-del {
  position: absolute;
  top: 3px;
  right: 3px;
  background: rgba(0, 0, 0, .55);
  border: none;
  color: #fff;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  font-size: 11px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--t)
}

.dnd-th:hover .dnd-del {
  opacity: 1
}

.dnd-add {
  aspect-ratio: 1;
  border-radius: 5px;
  background: var(--bg2);
  border: 1.5px dashed var(--border2);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: 22px;
  cursor: pointer;
  transition: all var(--t)
}

.dnd-add:hover {
  border-color: var(--orange);
  color: var(--orange)
}

.sm-ov {
  position: fixed;
  inset: 0;
  z-index: 800;
  background: rgba(0, 0, 0, .45);
  backdrop-filter: blur(4px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--t)
}

.sm-ov.on {
  opacity: 1;
  pointer-events: all
}

.sm-box {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 28px;
  width: 90%;
  max-width: 550px;
  max-height: 88vh;
  overflow-y: auto;
  position: relative;
  transform: translateY(14px);
  transition: transform var(--t2);
  box-shadow: var(--sh2)
}

.sm-ov.on .sm-box {
  transform: none
}

.sm-x {
  position: absolute;
  top: 12px;
  right: 14px;
  background: none;
  border: none;
  color: var(--muted);
  font-size: 20px;
  cursor: pointer;
  padding: 4px 8px
}

.sm-x:hover {
  color: var(--ink)
}

/* Review star picker */
.rv-stars {
  display: flex;
  gap: 4px;
}
.rv-stars span {
  font-size: 22px;
  cursor: pointer;
  color: #d1d5db;
  transition: color .15s;
  line-height: 1;
  user-select: none;
}
.rv-stars span.on { color: #f59e0b }
.rv-stars span:hover { color: #f59e0b }

/* Review card */
.rv-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 16px 18px;
  margin-bottom: 12px;
}
.rv-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  flex-wrap: wrap;
  gap: 6px;
}
.rv-card-name {
  font-weight: 700;
  font-size: 14px;
  color: var(--ink);
}
.rv-card-stars { color: #f59e0b; font-size: 13px; }
.rv-card-date { font-size: 11px; color: var(--muted); }
.rv-card-text { font-size: 13.5px; color: var(--ink2); line-height: 1.7; }
.rv-card-sub {
  display: flex;
  gap: 14px;
  margin-top: 8px;
  flex-wrap: wrap;
}
.rv-card-sub span {
  font-size: 11.5px;
  color: var(--muted);
}

.sess-row {
  display: grid;
  grid-template-columns: 26px 145px 1fr 90px 80px 26px;
  gap: 8px;
  align-items: center;
  padding: 11px 13px;
  border-radius: 7px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  margin-bottom: 8px;
  transition: border-color var(--t)
}

.sess-row:hover {
  border-color: rgba(204, 68, 0, .25)
}

.sess-row.recurring {
  border-left: 3px solid var(--lime)
}

.rec-day-btn {
  width: 33px;
  height: 33px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11.5px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid var(--border);
  color: var(--muted);
  background: var(--bg2);
  transition: all var(--t);
  user-select: none
}

.rec-day-btn:hover {
  border-color: rgba(204, 68, 0, .4)
}

.rec-day-btn.on {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff
}

.hgrid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 4px;
  margin-top: 8px
}

.hblock {
  padding: 6px 2px;
  border-radius: 4px;
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid var(--border);
  color: var(--muted);
  background: var(--bg2);
  transition: all var(--t);
  user-select: none;
  line-height: 1.3
}

.hblock:hover {
  border-color: rgba(204, 68, 0, .4);
  color: var(--orange)
}

.hblock.sel-s {
  background: var(--orange);
  border-color: var(--hot);
  color: #fff;
  border-radius: 4px 0 0 4px
}

.hblock.sel-m {
  background: rgba(204, 68, 0, .12);
  border-color: rgba(204, 68, 0, .3);
  color: var(--orange);
  border-radius: 0
}

.hblock.sel-e {
  background: var(--orange);
  border-color: var(--hot);
  color: #fff;
  border-radius: 0 4px 4px 0
}

.hblock.sel {
  background: var(--orange);
  border-color: var(--hot);
  color: #fff
}

.hblock.dis {
  opacity: .28;
  cursor: not-allowed;
  pointer-events: none
}

.toggle {
  position: relative;
  width: 42px;
  height: 22px;
  flex-shrink: 0
}

.toggle input {
  opacity: 0;
  width: 0;
  height: 0;
  position: absolute
}

.toggle-sl {
  position: absolute;
  inset: 0;
  cursor: pointer;
  background: var(--border2);
  border-radius: 11px;
  transition: background var(--t)
}

.toggle-sl::before {
  content: '';
  position: absolute;
  height: 16px;
  width: 16px;
  left: 2px;
  bottom: 2px;
  border-radius: 50%;
  background: #fff;
  transition: all var(--t);
  box-shadow: 0 1px 3px rgba(0, 0, 0, .15)
}

.toggle input:checked+.toggle-sl {
  background: var(--orange)
}

.toggle input:checked+.toggle-sl::before {
  transform: translateX(20px)
}

.prev-card {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  overflow: hidden;
  margin-bottom: 12px
}

.prev-img {
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  position: relative;
  background-color: var(--bg3)
}

.prev-body {
  padding: 12px 14px 14px
}

.comp-item {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 12px;
  margin-bottom: 5px
}

.capb2 {
  height: 4px;
  background: var(--bg2);
  border-radius: 2px;
  overflow: hidden
}

.capf2 {
  height: 100%;
  border-radius: 2px;
  transition: width .4s
}

.capf2-l {
  background: var(--lime)
}

.capf2-m {
  background: var(--orange)
}

.capf2-h {
  background: #dc2626
}

#toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  z-index: 9999;
  background: var(--lime);
  color: #fff;
  padding: 12px 20px;
  border-radius: 8px;
  font-weight: 700;
  font-size: 13.5px;
  transform: translateY(60px);
  opacity: 0;
  transition: all .32s cubic-bezier(.34, 1.56, .64, 1);
  pointer-events: none;
  max-width: 320px;
  box-shadow: var(--sh2)
}

#toast.show {
  transform: translateY(0);
  opacity: 1
}

#toast.err {
  background: #dc2626
}

.no-results {
  text-align: center;
  padding: 56px 0;
  color: var(--muted);
  display: none
}

.lektor-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  cursor: pointer;
  transition: border-color var(--t), background var(--t)
}

.lektor-chip:hover {
  border-color: var(--orange);
  background: rgba(204, 68, 0, .04)
}

.lchip-av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  border: 2px solid var(--orange);
  flex-shrink: 0
}

/* ── PAGE HERO (Kurzy / Lektoři) — sjednoceno s hero-v2 stylem ── */
.l-page-hero {
  position: relative;
  min-height: 42vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #1a120a
}

.l-page-hero-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0
}

.l-page-hero-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(10, 40, 80, .88) 0%, rgba(10, 40, 80, .55) 60%, rgba(10, 40, 80, .2) 85%, rgba(10, 40, 80, .65) 100%);
  z-index: 1
}

.l-page-hero-in {
  position: relative;
  z-index: 2;
  max-width: 1240px;
  width: 100%;
  margin: 0 auto;
  padding: 110px 48px 52px
}

.lgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px
}

.lcard {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--t2), box-shadow var(--t2), border-color var(--t);
  display: flex;
  flex-direction: column
}

.lcard:hover {
  transform: translateY(-5px);
  box-shadow: var(--sh2);
  border-color: rgba(204, 68, 0, .25)
}

.lcard-top {
  position: relative;
  height: 180px;
  overflow: hidden;
  flex-shrink: 0
}

.lcard-av {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center top
}

.lcard-top::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(24, 17, 10, .55) 0%, transparent 55%)
}

.lcard-rating-badge {
  position: absolute;
  top: 11px;
  right: 11px;
  z-index: 1;
  background: rgba(24, 17, 10, .72);
  backdrop-filter: blur(6px);
  color: #f59e0b;
  font-weight: 800;
  font-size: 13.5px;
  padding: 4px 10px;
  border-radius: 20px;
  border: 1px solid rgba(245, 158, 11, .3)
}

.lcard-body {
  padding: 18px 19px 20px;
  display: flex;
  flex-direction: column;
  flex: 1
}

.lcard-name {
  font-family: var(--fd);
  font-size: 22px;
  text-transform: uppercase;
  letter-spacing: .5px;
  line-height: 1.05;
  color: var(--ink);
  margin-bottom: 3px
}

.lcard-title2 {
  font-size: 12px;
  color: var(--muted);
  font-weight: 600;
  margin-bottom: 10px
}

.lcard-discs {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 11px
}

.ltag {
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 700;
  background: rgba(204, 68, 0, .07);
  color: var(--orange);
  border: 1px solid rgba(204, 68, 0, .18)
}

.ltag-lg {
  padding: 5px 13px;
  font-size: 12.5px
}

.lcard-bio {
  font-size: 13px;
  color: var(--ink2);
  line-height: 1.6;
  margin-bottom: 14px;
  flex: 1
}

.lcard-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-bottom: 12px;
  padding: 12px;
  background: var(--bg2);
  border-radius: 8px;
  border: 1px solid var(--border)
}

.lcard-stat {
  text-align: center
}

.lcard-stat-n {
  font-family: var(--fd);
  font-size: 20px;
  color: var(--ink);
  line-height: 1
}

.lcard-stat-l {
  font-size: 10px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .5px;
  margin-top: 2px
}

.lcard-certs {
  display: flex;
  gap: 5px;
  flex-wrap: wrap
}

/* ── LEKTOR DETAIL ── */
.ld-hero {
  background: linear-gradient(135deg, #06152E 0%, #0a2850 100%);
  padding: 52px 48px 44px
}

.ld-hero-in {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  gap: 36px;
  align-items: center;
  flex-wrap: wrap
}

.ld-av-wrap {
  flex-shrink: 0
}

.ld-av {
  width: 140px;
  height: 140px;
  border-radius: 50%;
  background-size: cover;
  background-position: center top;
  border: 4px solid var(--orange);
  box-shadow: 0 0 0 8px rgba(204, 68, 0, .15)
}

.ld-hero-info {
  flex: 1
}

.ld-name {
  font-family: var(--fd);
  font-size: clamp(32px, 4vw, 54px);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  line-height: 1;
  color: #fff;
  margin-bottom: 6px
}

.ld-htitle {
  font-size: 14px;
  color: rgba(255, 255, 255, .6);
  font-weight: 600;
  margin-bottom: 6px
}

.ld-region {
  font-size: 13.5px;
  color: rgba(255, 255, 255, .5);
  margin-bottom: 14px
}

.ld-rating-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap
}

.ld-stars {
  color: #f59e0b;
  font-size: 16px;
  letter-spacing: 1px
}

.ld-rval {
  font-family: var(--fd);
  font-size: 26px;
  color: #f59e0b
}

.ld-stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px
}

.ldstat {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 18px;
  text-align: center
}

.ldstat-n {
  font-family: var(--fd);
  font-size: 34px;
  line-height: 1;
  margin-bottom: 4px
}

.ldstat-l {
  font-size: 10.5px;
  color: var(--muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px
}

.ldskill {
  margin-bottom: 2px
}

.ldskill-top {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 4px
}

.ldrev {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 18px 20px;
  transition: border-color var(--t)
}

.ldrev:hover {
  border-color: rgba(204, 68, 0, .2)
}

.ldrev-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px
}

.ldrev-name {
  font-weight: 700;
  font-size: 14px;
  color: var(--ink)
}

.ldrev-course {
  font-size: 11.5px;
  color: var(--muted);
  margin-top: 2px
}

.ldrev-stars {
  color: #f59e0b;
  font-size: 14px;
  letter-spacing: 1px
}

.ldrev-text {
  font-size: 13.5px;
  color: var(--ink2);
  line-height: 1.7;
  font-style: italic
}

/* ── MESSAGES PANEL ── */
.msg-tabs {
  display: flex;
  gap: 6px;
  flex-wrap: wrap
}

.msg-tab {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1.5px solid var(--border);
  background: var(--bg2);
  font-size: 12.5px;
  font-weight: 600;
  color: var(--muted);
  cursor: pointer;
  transition: .15s
}

.msg-tab.on {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink)
}

.msg-card {
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 12px;
  padding: 16px 18px;
  transition: .15s
}

.msg-card:hover {
  border-color: var(--orange);
  box-shadow: 0 2px 12px rgba(204, 68, 0, .08)
}

.msg-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px
}

.msg-sender {
  display: flex;
  gap: 10px;
  align-items: center
}

.msg-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: var(--orange);
  color: #fff;
  font-family: var(--fd);
  font-size: 17px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0
}

.msg-name {
  font-weight: 700;
  font-size: 14px;
  color: var(--ink)
}

.msg-meta {
  font-size: 11.5px;
  color: var(--muted);
  margin-top: 1px
}

.msg-course-tag {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 600;
  color: var(--orange);
  background: rgba(204, 68, 0, .07);
  border-radius: 5px;
  padding: 2px 8px;
  margin-bottom: 8px
}

.msg-body {
  font-size: 13.5px;
  color: var(--ink2);
  line-height: 1.65;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  padding: 10px 13px;
  margin-bottom: 12px
}

.msg-actions {
  display: flex;
  gap: 7px;
  flex-wrap: wrap
}

.badge.bo-err {
  background: rgba(220, 38, 38, .08);
  color: #dc2626;
  border-color: rgba(220, 38, 38, .25)
}

.badge.bo-warn {
  background: rgba(234, 179, 8, .08);
  color: #b45309;
  border-color: rgba(234, 179, 8, .35)
}

/* ═══════════════════ ADMIN STYLES ═══════════════════ */
.gw-radio-lbl {
  cursor: pointer;
  flex: 1;
  min-width: 140px;
  max-width: 220px;
}

.gw-radio-lbl input[type="radio"] {
  display: none;
}

.gw-radio-box {
  border: 2px solid var(--border);
  border-radius: 10px;
  padding: 14px 18px;
  background: var(--bg2);
  text-align: center;
  transition: border-color .15s, background .15s;
}

.gw-radio-lbl:hover .gw-radio-box {
  border-color: var(--orange);
  background: rgba(204, 68, 0, .04);
}

.gw-section {
  transition: box-shadow .2s;
}

/* ─── In-app reply (messages panel) ─── */
.msg-reply-box {
  margin-top: 12px;
  padding: 12px;
  background: var(--bg2);
  border: 1.5px solid var(--border);
  border-radius: 8px;
}

.msg-reply-ta {
  width: 100%;
  min-height: 80px;
  resize: vertical;
  box-sizing: border-box;
}

.msg-thread {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.msg-reply-row {
  padding: 9px 12px;
  background: rgba(82, 122, 0, .07);
  border-left: 3px solid var(--lime);
  border-radius: 0 6px 6px 0;
}

.msg-reply-meta {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 3px;
  font-weight: 600;
}

.msg-reply-text {
  font-size: 13px;
  color: var(--ink2);
  line-height: 1.6;
  white-space: pre-wrap;
}

.nav-logo-img {
  height: 38px;
  width: 38px;
  object-fit: cover;
  object-position: center 20%;
  border-radius: 8px;
}

/* ── RESPONSIVE — mobile hero split → single column ── */
@media (max-width: 768px) {
  .hero {
    grid-template-columns: 1fr;
    padding-left: 20px;
    padding-right: 20px;
    gap: 24px
  }

  .hero-foto {
    aspect-ratio: 16/9
  }

  .lstrip {
    margin: 0 16px 40px;
    padding: 40px 24px
  }

  .lstrip-in {
    grid-template-columns: 1fr
  }

  .how-grid::before {
    display: none
  }

  .how-grid {
    grid-template-columns: 1fr 1fr
  }
}

/* HOME V2 - Hero */
.hero-v2 {
  position: relative;
  min-height: 65vh;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: #1a120a
}

.hero-v2-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  z-index: 0;
  display: block
}

.hero-v2-bg {
  position: absolute;
  inset: 0;
  background-image: url('/public/w2TME.jpg');
  background-size: cover;
  background-position: center 30%;
  transform: scale(1.04);
  transition: transform 8s ease;
  z-index: 0
}

.hero-v2:hover .hero-v2-bg {
  transform: scale(1)
}

.hero-v2-overlay {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: linear-gradient(135deg, rgba(10, 40, 80, .88) 0%, rgba(10, 40, 80, .55) 60%, rgba(10, 40, 80, .2) 85%, rgba(10, 40, 80, .65) 100%);
  z-index: 1
}

.hero-v2-content {
  position: relative;
  z-index: 2;
  max-width: 840px;
  padding: 0 28px;
  margin: 20px 150px;
  width: 100%
}

.hero-v2-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  background: rgba(200, 120, 10, .18);
  border: 1px solid rgba(200, 120, 10, .45);
  color: var(--ember);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 6px 14px;
  border-radius: 20px;
  margin-bottom: 24px
}

.hero-v2-title {
  font-family: var(--fd);
  font-size: clamp(40px, 7vw, 84px);
  line-height: .95;
  letter-spacing: .01em;
  color: #fff;
  margin-bottom: 20px
}

.hero-v2-title span {
  color: var(--orange)
}

.hero-v2-sub {
  font-size: 18px;
  color: rgba(224, 170, 95, 0.72);
  max-width: 560px;
  line-height: 1.6;
  margin-bottom: 18px
}

.hero-v2-search {
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, .1);
  border: 1.5px solid rgba(255, 255, 255, .22);
  border-radius: 50px;
  overflow: hidden;
  max-width: 520px;
  backdrop-filter: blur(12px)
}

.hvs-icon {
  padding: 0 16px 0 20px;
  color: rgba(255, 255, 255, .5);
  display: flex;
  align-items: center
}

.hvs-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: #fff;
  font-size: 15px;
  font-family: var(--fb);
  padding: 14px 0
}

.hvs-input::placeholder {
  color: rgba(255, 255, 255, .45)
}

.hvs-btn {
  background: var(--orange);
  color: #fff;
  border: none;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--fb);
  cursor: pointer;
  border-radius: 50px;
  margin: 5px;
  transition: background var(--t)
}

.hvs-btn:hover {
  background: var(--hot)
}

.hero-v2-stats {
  display: flex;
  align-items: center;
  gap: 0;
  margin-top: 24px;
  margin-bottom: 0px;
  flex-wrap: wrap
}

.hv2-stat {
  display: flex;
  flex-direction: column;
  padding-right: 32px
}

.hv2-stat-n {
  font-family: var(--fd);
  font-size: 36px;
  letter-spacing: .02em;
  color: #fff;
  line-height: 1
}

.hv2-stat-l {
  font-size: 12px;
  color: rgba(255, 255, 255, .5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 3px
}

.hv2-stat-sep {
  width: 1px;
  height: 40px;
  background: rgba(255, 255, 255, .18);
  margin: 0 32px 0 0
}

.hero-v2-scroll {
  position: absolute;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: rgba(255, 255, 255, .45);
  font-size: 11px;
  letter-spacing: .1em;
  text-transform: uppercase;
  z-index: 2
}

.hero-v2-scroll svg {
  animation: scrollBounce 1.6s ease-in-out infinite
}

@keyframes scrollBounce {

  0%,
  100% {
    transform: translateY(0)
  }

  50% {
    transform: translateY(6px)
  }
}

/* HOME V2 - Section shared */
.home-sec {
  padding: 10px 24px
}

.popular.home-sec {
  padding-top: 12px
}

.home-sec-inner {
  max-width: 1160px;
  margin: 0 auto
}

.home-sec-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-bottom: 40px;
  gap: 16px;
  flex-wrap: wrap
}

.home-sec-title {
  font-family: var(--fd);
  font-size: clamp(32px, 5vw, 52px);
  letter-spacing: .02em;
  color: var(--ink);
  line-height: 1.05
}

.home-sec-title span {
  color: var(--orange)
}

.home-sec-title-white {
  font-family: var(--fd);
  font-size: clamp(32px, 5vw, 52px);
  letter-spacing: .02em;
  color: #fff;
  line-height: 1.05
}

.home-sec-title-white span {
  color: var(--ember)
}

/* HOME V2 - Stats band */
.stats-band {
  background: #0A2550;
  padding: 36px 24px
}

.stats-band-inner {
  max-width: 1265px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  flex-wrap: wrap
}

.sb-stat {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 0 38px;
  flex: 0 0 auto
}

.sb-stat svg {
  color: var(--ember);
  flex-shrink: 0
}

.sb-n {
  font-family: var(--fd);
  font-size: 48px;
  letter-spacing: .02em;
  color: #fff;
  line-height: 1
}

.sb-l {
  font-size: 13px;
  color: rgba(255, 255, 255, .5);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 3px
}

.sb-div {
  width: 1px;
  height: 60px;
  background: rgba(255, 255, 255, .12)
}

/* HOME V2 - How it works */
.how-steps {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 0;
  position: relative;
  flex-wrap: wrap
}

.how-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  flex: 1;
  min-width: 180px;
  max-width: 240px;
  padding: 0 8px;
  position: relative
}

.how-step-wrap {
  display: flex;
  align-items: center;
  width: 100%;
  margin-bottom: 20px
}

.how-step-icon {
  width: 72px;
  height: 72px;
  background: var(--surface);
  border: 2px solid var(--border);
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--orange);
  transition: background var(--t), border-color var(--t);
  margin: 0 auto
}

.how-step:hover .how-step-icon {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff
}

.how-step-num {
  position: absolute;
  top: -8px;
  left: calc(50% - 11px);
  width: 22px;
  height: 22px;
  background: var(--orange);
  color: #fff;
  font-size: 11px;
  font-weight: 800;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1
}

.how-step-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--ink);
  margin-bottom: 6px
}

.how-step-desc {
  font-size: 13px;
  color: var(--muted);
  line-height: 1.55
}

.how-connector {
  flex: 1;
  min-width: 24px;
  max-width: 56px;
  height: 2px;
  background: var(--border);
  position: relative;
  top: -36px;
  margin: 0 -4px
}

.how-connector::after {
  content: "";
  position: absolute;
  right: -5px;
  top: -4px;
  width: 10px;
  height: 10px;
  border-top: 2px solid var(--border);
  border-right: 2px solid var(--border);
  transform: rotate(45deg)
}

/* HOME V2 - Testimonials */
.tgrid2 {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 24px
}

.t2card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: box-shadow var(--t), transform var(--t)
}

.t2card:hover {
  box-shadow: var(--sh2);
  transform: translateY(-4px)
}

.t2-stars {
  display: flex;
  gap: 3px;
  color: var(--ember)
}

.t2-quote {
  font-size: 14.5px;
  color: var(--ink);
  line-height: 1.65;
  flex: 1;
  font-style: italic
}

.t2-person {
  display: flex;
  align-items: center;
  gap: 12px;
  border-top: 1px solid var(--border);
  padding-top: 16px;
  margin-top: auto
}

.t2-av {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
  border: 2px solid var(--border)
}

.t2-name {
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ink)
}

.t2-meta {
  font-size: 12px;
  color: var(--muted)
}

/* HOME V2 - Pricing */
.pricing-sec {
  background: #0A2550;
  padding: 80px 24px
}

.pricing-sec-inner {
  max-width: 900px;
  margin: 0 auto
}

.pricing-toggle-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 14px;
  margin-bottom: 48px
}

.pt-label {
  font-size: 14px;
  font-weight: 600;
  color: rgba(255, 255, 255, .65)
}

.pt-label.active {
  color: #fff
}

.pt-save {
  font-size: 11px;
  font-weight: 700;
  color: var(--ember);
  background: rgba(200, 120, 10, .18);
  border: 1px solid rgba(200, 120, 10, .3);
  padding: 2px 8px;
  border-radius: 12px;
  margin-left: 4px
}

.ptoggle {
  width: 52px;
  height: 28px;
  background: rgba(255, 255, 255, .12);
  border: 1.5px solid rgba(255, 255, 255, .2);
  border-radius: 14px;
  cursor: pointer;
  position: relative;
  transition: background var(--t)
}

.ptoggle.yearly {
  background: var(--orange);
  border-color: var(--orange)
}

.ptoggle-thumb {
  position: absolute;
  width: 20px;
  height: 20px;
  background: #fff;
  border-radius: 50%;
  top: 3px;
  left: 4px;
  transition: transform .3s ease
}

.ptoggle.yearly .ptoggle-thumb {
  transform: translateX(24px)
}

.pricing-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px
}

.pcard {
  background: rgba(255, 255, 255, .05);
  border: 1.5px solid rgba(255, 255, 255, .1);
  border-radius: 20px;
  padding: 36px 32px;
  transition: border-color var(--t)
}

.pcard:hover {
  border-color: rgba(255, 255, 255, .22)
}

.pcard-pro {
  background: linear-gradient(145deg, rgba(200, 120, 10, .15), rgba(200, 120, 10, .05));
  border-color: rgba(200, 120, 10, .4);
  position: relative;
  overflow: hidden
}

.pcard-pro:hover {
  border-color: rgba(200, 120, 10, .65)
}

.pcard-best {
  position: absolute;
  top: 20px;
  right: 20px;
  background: var(--orange);
  color: #fff;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 20px
}

.pcard-name {
  font-family: var(--fd);
  font-size: 28px;
  letter-spacing: .04em;
  color: #fff;
  margin-bottom: 8px
}

.pcard-desc {
  font-size: 13px;
  color: rgba(255, 255, 255, .5);
  margin-bottom: 28px;
  line-height: 1.5
}

.pcard-price {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-bottom: 28px
}

.pcard-amt {
  font-family: var(--fd);
  font-size: 52px;
  letter-spacing: .01em;
  color: #fff;
  line-height: 1
}

.pcard-per {
  font-size: 13px;
  color: rgba(255, 255, 255, .45)
}

.pcard-feats {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-bottom: 32px
}

.pcard-feats li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 14px;
  color: rgba(255, 255, 255, .8);
  list-style: none
}

.pcf-icon {
  color: var(--lime);
  flex-shrink: 0
}

.pcard-feats li.muted .pcf-icon {
  color: rgba(255, 255, 255, .2)
}

.pcard-feats li.muted {
  color: rgba(255, 255, 255, .35)
}

/* HOME V2 - FAQ */
.faq-sec {
  padding: 80px 24px
}

.faq-sec-inner {
  max-width: 760px;
  margin: 0 auto
}

.faq-list {
  display: flex;
  flex-direction: column;
  gap: 8px
}

.faq-item {
  border: 1.5px solid var(--border);
  border-radius: var(--r);
  overflow: hidden;
  background: var(--surface)
}

.faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  cursor: pointer;
  font-size: 15px;
  font-weight: 600;
  color: var(--ink);
  user-select: none;
  gap: 12px
}

.faq-q:hover {
  color: var(--orange)
}

.faq-chevron {
  flex-shrink: 0;
  color: var(--muted);
  transition: transform var(--t)
}

.faq-item.open .faq-chevron {
  transform: rotate(180deg)
}

.faq-item.open .faq-q {
  color: var(--orange)
}

.faq-a {
  max-height: 0;
  overflow: hidden;
  transition: max-height .35s ease
}

.faq-item.open .faq-a {
  max-height: 320px
}

.faq-a-inner {
  padding: 0 22px 20px;
  font-size: 14px;
  color: var(--ink2);
  line-height: 1.7
}

/* HOME V2 - Footer V2 */
.footer-v2 {
  background: var(--ink);
  padding: 64px 24px 0
}

.footer-v2-grid {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 40px;
  padding-bottom: 48px;
  border-bottom: 1px solid rgba(255, 255, 255, .08)
}

.footer-logo {
  font-family: var(--fd);
  font-size: 26px;
  letter-spacing: .06em;
  color: #fff;
  margin-bottom: 12px
}

.footer-logo span {
  color: var(--orange)
}

.footer-tagline {
  font-size: 13px;
  color: rgba(255, 255, 255, .45);
  line-height: 1.6;
  margin-bottom: 24px;
  max-width: 260px
}

.footer-social {
  display: flex;
  gap: 10px
}

.fsoc-btn {
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .55);
  cursor: pointer;
  transition: background var(--t), color var(--t);
  text-decoration: none
}

.fsoc-btn:hover {
  background: var(--orange);
  color: #fff;
  border-color: var(--orange)
}

.footer-col h4 {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .4);
  margin-bottom: 16px
}

.footer-col a {
  display: block;
  font-size: 13.5px;
  color: rgba(255, 255, 255, .6);
  text-decoration: none;
  margin-bottom: 10px;
  transition: color var(--t)
}

.footer-col a:hover {
  color: #fff
}

.footer-v2-bottom {
  max-width: 1160px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 0;
  font-size: 12.5px;
  color: rgba(255, 255, 255, .3);
  flex-wrap: wrap;
  gap: 8px
}

.footer-links {
  display: flex;
  gap: 20px
}

.footer-links a {
  color: rgba(255, 255, 255, .3);
  text-decoration: none;
  transition: color var(--t)
}

.footer-links a:hover {
  color: rgba(255, 255, 255, .7)
}

/* Popular courses arrow btn */
.sec-arrow-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13.5px;
  font-weight: 700;
  color: var(--orange);
  text-decoration: none;
  padding: 8px 16px;
  border: 1.5px solid var(--orange);
  border-radius: 20px;
  transition: background var(--t), color var(--t)
}

.sec-arrow-btn:hover {
  background: var(--orange);
  color: #fff
}

/* HOME V2 - Responsive */
@media (max-width: 900px) {
  .footer-v2-grid {
    grid-template-columns: 1fr 1fr;
    gap: 32px
  }

  .footer-brand {
    grid-column: 1 / -1
  }

  .pricing-cards {
    grid-template-columns: 1fr
  }

  .sb-stat {
    padding: 10px 22px
  }

  .sb-div {
    width: 100%;
    height: 1px;
    margin: 0
  }
}

@media (max-width: 640px) {
  .hero-v2-content {
    padding: 5px 16px;
    margin: 20px 0
  }

  .hv2-stat-sep {
    display: none
  }

  .how-connector {
    display: none
  }

  .how-steps {
    gap: 24px
  }

  .how-step {
    max-width: 100%;
    padding: 0
  }

  .footer-v2-grid {
    grid-template-columns: 1fr
  }

  .tgrid2 {
    grid-template-columns: 1fr
  }
}

/* ════════════════════════════════════════════════════════
   MOBILE NAV — hamburger + overlay
   ════════════════════════════════════════════════════════ */
.nav-burger {
  display: none;
  align-items: center;
  justify-content: center;
  background: none;
  border: 1.5px solid rgba(255, 255, 255, .25);
  border-radius: var(--r);
  width: 40px;
  height: 40px;
  cursor: pointer;
  color: #fff;
  flex-shrink: 0;
  transition: border-color var(--t), color var(--t)
}

.nav-burger:hover {
  border-color: var(--orange);
  color: var(--orange)
}

.nav-burger .burger-open {
  display: block
}

.nav-burger .burger-close {
  display: none
}

.nav-burger.open .burger-open {
  display: none
}

.nav-burger.open .burger-close {
  display: block
}

.nav-mobile {
  display: none;
  position: fixed;
  top: 62px;
  left: 0;
  right: 0;
  bottom: 0;
  background: #06152E;
  z-index: 850;
  padding: 16px;
  overflow-y: auto;
  flex-direction: column;
  gap: 7px;
  border-top: 1.5px solid rgba(255, 255, 255, .08)
}

.nav-mobile.open {
  display: flex
}

.nav-mob-link {
  display: block;
  width: 100%;
  text-align: left;
  padding: 15px 18px;
  font-size: 15px;
  font-weight: 600;
  color: rgba(255, 255, 255, .75);
  border-radius: var(--r);
  border: 1.5px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .05);
  cursor: pointer;
  font-family: var(--fb);
  transition: all var(--t)
}

.nav-mob-link:hover,
.nav-mob-link.act {
  border-color: var(--orange);
  color: var(--orange);
  background: rgba(255, 255, 255, .08)
}

.nav-mob-divider {
  height: 1px;
  background: rgba(255, 255, 255, .1);
  margin: 4px 0
}

.nav-mob-cta {
  display: block;
  width: 100%;
  text-align: center;
  padding: 15px 18px;
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  border-radius: var(--r);
  border: none;
  background: var(--orange);
  cursor: pointer;
  font-family: var(--fb);
  transition: background var(--t)
}

.nav-mob-cta:hover {
  background: var(--hot)
}

.nav-mob-lang {
  display: flex;
  gap: 0;
  border: 1.5px solid var(--border);
  border-radius: 7px;
  overflow: hidden;
  margin-top: 6px;
  align-self: flex-start
}

.nav-mob-lang button {
  background: transparent;
  border: none;
  padding: 9px 22px;
  font-size: 13px;
  font-weight: 700;
  font-family: var(--fb);
  color: var(--muted);
  cursor: pointer;
  letter-spacing: .5px;
  transition: all var(--t)
}

.nav-mob-lang button:first-child {
  border-right: 1.5px solid var(--border)
}

.nav-mob-lang button:hover {
  color: var(--ink);
  background: var(--bg2)
}

.nav-mob-lang button.on {
  background: var(--orange);
  color: #fff
}

/* ════════════════════════════════════════════════════════
   KURZ / LEKTOR DETAIL — layout classes
   (replaces inline styles so media queries can override)
   ════════════════════════════════════════════════════════ */
.kd-hero-banner {
  height: 420px
}

.kd-hero-inner {
  padding: 0 48px 36px
}

.kdbg {
  padding: 36px 48px;
  grid-template-columns: 1fr 340px
}

.kd-sticky {
  position: sticky;
  top: 80px
}

.ldbg {
  padding: 36px 48px;
  grid-template-columns: 1fr 340px
}

/* ════════════════════════════════════════════════════════
   TABLET — max-width: 900px
   ════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .pop-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px
  }

  .kgrid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px
  }

  .lgrid {
    grid-template-columns: repeat(2, 1fr);
    gap: 14px
  }

  .kdbg,
  .ldbg {
    grid-template-columns: 1fr;
    padding: 28px 28px
  }

  .kd-sticky {
    position: static
  }

  .kd-hero-banner {
    height: 320px
  }

  .kd-hero-inner {
    padding: 0 28px 28px
  }

  .ld-hero {
    padding: 40px 28px 36px
  }
}

/* ════════════════════════════════════════════════════════
   MOBILE — max-width: 768px
   ════════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* NAV */
  .navul {
    display: none !important
  }

  .nav-btns {
    display: none !important
  }

  .lang-toggle {
    display: none !important
  }

  .nav-burger {
    display: flex
  }

  .nav {
    padding: 0 12px 0 12px
  }

  /* HOME POPULAR GRID — 1 col on mobile */
  .pop-grid {
    grid-template-columns: 1fr;
    gap: 14px
  }

  /* SECTION padding */
  .section {
    padding: 12px 16px
  }

  /* PAGE HEROES */
  .l-page-hero-in {
    padding: 90px 16px 32px
  }

  /* STATS BAND */
  .stats-band {
    padding: 0
  }

  .stats-band-inner {
    flex-wrap: wrap
  }

  .sb-stat {
    flex: 0 0 50%;
    padding: 24px 16px;
    box-sizing: border-box
  }

  .sb-div {
    display: none
  }

  /* HOME SECTIONS */
  .home-sec {
    padding: 48px 16px
  }

  .home-sec-head {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px
  }

  .pricing-sec {
    padding: 52px 16px
  }

  .faq-sec {
    padding: 52px 16px
  }

  .footer-v2 {
    padding: 48px 16px 0
  }

  /* KURZ DETAIL */
  .kd-hero-banner {
    height: 260px
  }

  .kd-hero-inner {
    padding: 0 16px 20px
  }

  .kdbg {
    padding: 20px 16px;
    grid-template-columns: 1fr
  }

  .kd-sticky {
    position: static
  }

  /* LEKTOR DETAIL */
  .ld-hero {
    padding: 28px 16px 24px
  }

  .ld-av {
    width: 100px;
    height: 100px
  }

  .ldbg {
    padding: 20px 16px;
    grid-template-columns: 1fr
  }

  /* REGISTRATION / LOGIN — hide sidebar */
  .reg-side {
    display: none !important
  }

  .reg-shell {
    grid-template-columns: 1fr
  }

  .reg-main {
    padding: 28px 20px 64px;
    max-width: 100%
  }

  /* FILTER BAR */
  .filter-bar {
    flex-direction: column;
    align-items: stretch;
    gap: 10px
  }

  .fg-f {
    min-width: 0
  }

  .finp {
    min-width: 0
  }

  /* OTP inputs (2FA) */
  .otp-inp {
    width: 44px;
    height: 54px;
    font-size: 22px
  }

  /* BREADCRUMBS (inline style override) */
  #pg-kurz>div:first-child,
  #pg-lektor>div:first-child {
    padding: 10px 16px !important
  }

  /* PAGE MINI FOOTERS */
  #pg-kurzy>div+div>footer,
  #pg-lektori>div+div>footer {
    padding: 20px 16px !important
  }

  /* GALLERY stacks on mobile */
  #kd-gallery {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto !important
  }
}

/* ════════════════════════════════════════════════════════
   SMALL MOBILE — max-width: 480px
   ════════════════════════════════════════════════════════ */
@media (max-width: 480px) {
  .pop-grid {
    grid-template-columns: 1fr
  }

  .kgrid {
    grid-template-columns: 1fr
  }

  .lgrid {
    grid-template-columns: 1fr
  }

  /* Two-col form grids → single col */
  .g2 {
    grid-template-columns: 1fr !important
  }

  /* Hero v2 */
  .hero-v2-title {
    font-size: 52px !important
  }

  .hero-v2-sub {
    font-size: 15px;
    margin-bottom: 24px
  }

  .hero-v2-search {
    border-radius: 12px
  }

  .hv2-stat-n {
    font-size: 28px
  }

  /* Pricing card padding */
  .pcard {
    padding: 28px 20px
  }

  /* How steps full width */
  .how-step {
    min-width: 100%
  }

  /* Reg main */
  .reg-main {
    padding: 20px 16px 56px
  }

  /* Kurz detail gallery */
  #kd-gallery {
    height: auto !important
  }

  /* Kurz detail "included" grid → single col */
  #pg-kurz .card+.card {
    margin-top: 12px
  }
}

/* ════════════════════════════════════════════════════════════
   ANIMATIONS & MODERN REDESIGN
   ════════════════════════════════════════════════════════════ */

/* ── SCROLL REVEAL ── */
[data-reveal] {
  opacity: 0;
  transform: translateY(32px);
  transition: opacity .72s cubic-bezier(.16, 1, .3, 1), transform .72s cubic-bezier(.16, 1, .3, 1);
}

[data-reveal].revealed {
  opacity: 1;
  transform: none;
}

/* ── SHIMMER TEXT (hero title em) ── */
.shimmer-em {
  display: inline;
  background: linear-gradient(90deg,
      var(--ember) 0%,
      #fff 40%,
      var(--ember) 55%,
      var(--orange) 100%);
  background-size: 250% auto;
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: shimmer-move 3.5s linear infinite;
}

@keyframes shimmer-move {
  0% {
    background-position: 200% center;
  }

  100% {
    background-position: -100% center;
  }
}

/* ── HERO CANVAS ── */
#hero-canvas {
  position: absolute;
  inset: 0;
  z-index: 2;
  pointer-events: none;
}

.hero-v2-overlay {
  z-index: 1;
}

.hero-v2-content {
  z-index: 3;
}

.hero-v2-scroll {
  z-index: 3;
}

/* ── DASHBOARD MOBILE ── */
.dash-mob-bar {
  display: none;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: var(--surface);
  border-bottom: 1.5px solid var(--border);
  position: sticky;
  top: 62px;
  z-index: 100
}

.dash-mob-toggle {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  background: transparent;
  cursor: pointer;
  color: var(--ink);
  flex-shrink: 0
}

.dash-mob-toggle:hover {
  background: var(--bg2)
}

.dash-mob-title {
  font-family: var(--fd);
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--ink)
}

.dash-mob-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .45);
  z-index: 190
}

.dash-mob-overlay.on {
  display: block
}

@media (max-width: 768px) {
  .dash-mob-bar {
    display: flex
  }

  .dash-shell {
    grid-template-columns: 1fr
  }

  .dash-side {
    position: fixed;
    top: 0;
    left: -270px;
    width: 250px;
    height: 100vh;
    z-index: 200;
    transition: left .28s ease;
    box-shadow: 4px 0 24px rgba(0, 0, 0, .12)
  }

  .dash-side.open {
    left: 0
  }

  .dash-main {
    padding: 18px 14px 50px
  }

  .dt {
    font-size: 22px
  }

  .g2 {
    grid-template-columns: 1fr
  }
}

/* ── FILTER REDESIGN ── */
.htag {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.htag svg {
  flex-shrink: 0;
  opacity: .7;
  transition: opacity var(--t)
}

.htag:hover svg,
.htag.on svg {
  opacity: 1
}

.fg-f label {
  display: flex;
  align-items: center;
  gap: 5px;
}

.fg-f label svg {
  opacity: .6;
  flex-shrink: 0
}

.dpill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.dpill-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

.dpill-g {
  background: #22c55e
}

.dpill-y {
  background: #f59e0b
}

.dpill-r {
  background: #ef4444
}

.btn-reset {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 9px 16px;
  border-radius: 50px;
  border: 1.5px solid var(--border);
  background: transparent;
  font-size: 12px;
  font-weight: 700;
  font-family: var(--fb);
  letter-spacing: .04em;
  color: var(--ink2);
  cursor: pointer;
  align-self: flex-end;
  flex-shrink: 0;
  transition: border-color var(--t), color var(--t);
  white-space: nowrap;
}

.btn-reset:hover {
  border-color: var(--orange);
  color: var(--orange)
}

.btn-reset svg {
  opacity: .7;
  transition: opacity var(--t)
}

.btn-reset:hover svg {
  opacity: 1
}

.filter-bar {
  box-shadow: 0 2px 16px rgba(0, 0, 0, .07)
}

/* ── LCARD HOVER REVEAL ── */
.lcard {
  background: #1a120a;
  border: none;
  height: 380px;
  display: block;
  transform: none;
}

.lcard:hover {
  transform: translateY(-4px);
  border-color: transparent;
}

.lcard-photo {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center top;
  transition: transform .6s ease;
}

.lcard:hover .lcard-photo {
  transform: scale(1.06)
}

.lcard-rating-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 3;
}

.lcard-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 52px 18px 18px;
  background: linear-gradient(to top, rgba(6, 21, 46, .97) 0%, rgba(6, 21, 46, .82) 55%, transparent 100%);
}

.lcard-info-peek {
  margin-bottom: 0
}

.lcard-name {
  color: #fff;
  margin-bottom: 2px;
}

.lcard-title2 {
  color: rgba(255, 255, 255, .6);
  margin-bottom: 0;
}

.lcard-info-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .45s cubic-bezier(.25, .46, .45, .94), opacity .35s ease;
  opacity: 0;
  margin-top: 0;
}

.lcard:hover .lcard-info-body {
  max-height: 260px;
  opacity: 1;
  margin-top: 12px;
}

.ltag-inv {
  background: rgba(255, 255, 255, .12);
  border-color: rgba(255, 255, 255, .2);
  color: rgba(255, 255, 255, .85);
}

.lcard-bio-inv {
  color: rgba(255, 255, 255, .65);
  font-size: 12px;
  margin-bottom: 10px;
}

.lcard-stats-inv {
  background: rgba(255, 255, 255, .08);
  border-color: rgba(255, 255, 255, .12);
  margin-bottom: 0;
}

.lcard-stat-n-inv {
  color: #fff
}

.lcard-stat-l-inv {
  color: rgba(255, 255, 255, .45)
}

.lcard-cert-inv {
  border-color: rgba(255, 255, 255, .22);
  color: rgba(255, 255, 255, .75);
  background: rgba(255, 255, 255, .07);
}

/* ── KCARD HOVER REVEAL ── */
.kcard {
  background: #1a120a;
  border: none;
  height: 460px;
  display: block;
  box-shadow: 0 4px 20px rgba(0, 0, 0, .18);
}

.kcard:hover {
  transform: translateY(-4px)
}

.kcard-photo {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform .6s ease;
}

.kcard:hover .kcard-photo {
  transform: scale(1.05)
}

.kcard-badges {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 3;
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
}

.kcard-type-badge {
  background: rgba(255, 255, 255, .18);
  color: #fff;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 10.5px;
  font-weight: 700;
  border: 1px solid rgba(255, 255, 255, .3);
}

.kcard-info {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 2;
  padding: 80px 16px 16px;
  background: linear-gradient(to top, rgba(6, 21, 46, .97) 0%, rgba(6, 21, 46, .9) 40%, rgba(6, 21, 46, .7) 70%, transparent 100%);
}

.kcard-info-peek {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.kcard-info .kcard-title {
  color: #fff;
  font-size: 20px;
  margin-bottom: 0;
}

.kcard-peek-loc {
  font-size: 12px;
  color: rgba(255, 255, 255, .55);
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 0;
}

.kcard-peek-loc svg {
  opacity: .8;
  flex-shrink: 0
}

.kcard-price-pill {
  background: var(--orange);
  color: #fff;
  font-size: 13px;
  font-weight: 800;
  font-family: var(--fb);
  padding: 4px 11px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
  cursor: pointer;
  transition: opacity .15s;
}

.kcard-price-pill:hover {
  opacity: .85;
}

.kcard-info-body {
  max-height: none;
  overflow: visible;
  opacity: 1;
  margin-top: 10px;
}

.kcard-focus-inv {
  color: rgba(255, 255, 255, .65);
  font-size: 12.5px;
  margin-bottom: 8px
}

.kcard-tags-inv {
  margin-bottom: 8px
}

.ftag-inv {
  background: rgba(255, 255, 255, .1);
  border-color: rgba(255, 255, 255, .18);
  color: rgba(255, 255, 255, .75);
}

.kcard-sess-inv {
  background: rgba(255, 255, 255, .07);
  border-color: rgba(255, 255, 255, .12);
  margin-bottom: 8px;
}

.kcard-lektor-inv {
  background: rgba(255, 255, 255, .06);
  border-color: rgba(255, 255, 255, .1);
}

.kcard-lektor-inv .kcard-stars {
  color: rgba(255, 255, 255, .9)
}

.kcard-lektor-inv .kcard-rn {
  color: rgba(255, 255, 255, .45)
}

/* ── CARD SPOTLIGHT ── */
.kcard::before,
.lcard::before,
.t2card::before,
.hstep::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(320px circle at var(--mx, 50%) var(--my, 50%),
      rgba(200, 120, 10, .09),
      transparent 70%);
  opacity: 0;
  transition: opacity .35s;
  z-index: 0;
  pointer-events: none;
  border-radius: inherit;
}

.kcard:hover::before,
.lcard:hover::before,
.t2card:hover::before,
.hstep:hover::before {
  opacity: 1;
}

.kcard,
.lcard,
.t2card,
.hstep {
  position: relative;
  overflow: hidden;
}

/* ── GRADIENT LINE SEPARATOR ── */
.grad-line {
  height: 1px;
  background: linear-gradient(90deg, transparent 0%, var(--orange) 35%, var(--ember) 65%, transparent 100%);
  opacity: 0.35;
  margin: 0;
}

/* ── COUNTER digits ── */
[data-count] {
  font-variant-numeric: tabular-nums;
}

/* ── TESTIMONIALS SCROLL COLUMNS ── */
.test-columns-wrap {
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to bottom, transparent, black 15%, black 85%, transparent);
  mask-image: linear-gradient(to bottom, transparent, black 15%, black 85%, transparent);
  max-height: 680px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px
}

.test-col-scroll {
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.test-col-track {
  display: flex;
  flex-direction: column;
  gap: 16px;
  animation: test-scroll-up 22s linear infinite;
}

.test-col-track.reverse {
  animation-direction: reverse;
  animation-duration: 26s;
}

@keyframes test-scroll-up {
  from {
    transform: translateY(0);
  }

  to {
    transform: translateY(-50%);
  }
}

.test-col-track:hover,
.test-col-track.reverse:hover {
  animation-play-state: paused;
}

/* ── TEST CARD inside columns ── */
.tscroll-card {
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--rl);
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  transition: box-shadow var(--t2), border-color var(--t);
  flex-shrink: 0;
}

.tscroll-card:hover {
  box-shadow: var(--sh2);
  border-color: rgba(200, 120, 10, .3);
}

.tsc-stars {
  display: flex;
  gap: 3px;
}

.tsc-quote {
  font-size: 14px;
  color: var(--ink);
  line-height: 1.7;
  flex: 1;
  font-style: italic;
}

.tsc-person {
  display: flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid var(--border);
  padding-top: 14px;
}

.tsc-av {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background-size: cover;
  background-position: center;
  flex-shrink: 0;
  border: 2px solid var(--orange);
}

.tsc-name {
  font-size: 13px;
  font-weight: 700;
  color: var(--ink);
}

.tsc-role {
  font-size: 11.5px;
  color: var(--muted);
}

/* ── FAQ REDESIGN ── */
.faq-v2 {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.faq-v2-item {
  border-bottom: 1px solid var(--border);
}

.faq-v2-item:first-child {
  border-top: 1px solid var(--border);
}

.faq-v2-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 22px 4px;
  cursor: pointer;
  font-size: 15.5px;
  font-weight: 600;
  color: var(--ink);
  gap: 16px;
  background: none;
  border: none;
  text-align: left;
  font-family: var(--fb);
  width: 100%;
  transition: color var(--t);
  user-select: none;
}

.faq-v2-q:hover {
  color: var(--orange);
}

.faq-v2-item.open .faq-v2-q {
  color: var(--orange);
}

.faq-v2-num {
  font-family: var(--fd);
  font-size: 18px;
  color: var(--ghost);
  flex-shrink: 0;
  width: 28px;
  transition: color var(--t);
}

.faq-v2-item.open .faq-v2-num {
  color: var(--orange);
}

.faq-v2-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  transition: all var(--t);
}

.faq-v2-item.open .faq-v2-icon {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
  transform: rotate(45deg);
}

.faq-v2-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .4s cubic-bezier(.16, 1, .3, 1);
}

.faq-v2-item.open .faq-v2-body {
  max-height: 300px;
}

.faq-v2-ans {
  padding: 0 4px 22px 36px;
  font-size: 14.5px;
  color: var(--ink2);
  line-height: 1.75;
}

/* ── FOOTER V3 redesign ── */
.footer-v3 {
  background: #06152E;
  padding: 0;
}

.footer-v3-top {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 48px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 72px 24px 56px;
  border-bottom: 1px solid rgba(255, 255, 255, .07);
}

.fv3-brand {}

.fv3-logo {
  display: flex;
  align-items: center;
  gap: 9px;
  font-family: var(--fd);
  font-size: 24px;
  letter-spacing: 3px;
  color: #fff;
  margin-bottom: 14px;
}

.fv3-logo span {
  color: var(--orange);
}

.fv3-tagline {
  font-size: 13.5px;
  color: rgba(255, 255, 255, .42);
  line-height: 1.7;
  max-width: 250px;
  margin-bottom: 28px;
}

.fv3-social {
  display: flex;
  gap: 8px;
}

.fv3-soc {
  width: 36px;
  height: 36px;
  background: rgba(255, 255, 255, .06);
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, .5);
  transition: all var(--t);
  text-decoration: none;
}

.fv3-soc:hover {
  background: var(--orange);
  border-color: var(--orange);
  color: #fff;
}

.fv3-col h4 {
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, .35);
  margin-bottom: 20px;
}

.fv3-col ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 11px;
}

.fv3-col a {
  font-size: 13.5px;
  color: rgba(255, 255, 255, .55);
  text-decoration: none;
  transition: color var(--t);
  cursor: pointer;
}

.fv3-col a:hover {
  color: #fff;
}

.footer-v3-bottom {
  max-width: 1180px;
  margin: 0 auto;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12.5px;
  color: rgba(255, 255, 255, .25);
  flex-wrap: wrap;
  gap: 8px;
}

.footer-v3-bottom a {
  color: rgba(255, 255, 255, .25);
  text-decoration: none;
  transition: color var(--t);
}

.footer-v3-bottom a:hover {
  color: rgba(255, 255, 255, .6);
}

.fv3-links {
  display: flex;
  gap: 20px;
}

/* ── SECTION EYEBROW badge style ── */
.eyebrow-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(200, 120, 10, .1);
  border: 1px solid rgba(200, 120, 10, .25);
  color: var(--orange);
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 20px;
  margin-bottom: 16px;
}

/* ── HOW-STEPS enhanced ── */
.how-step-icon svg {
  transition: transform var(--t2);
}

.how-step:hover .how-step-icon svg {
  transform: scale(1.15) rotate(-5deg);
}

/* ── STATS BAND enhanced ── */
.sb-stat {
  cursor: default;
}

.sb-n {
  transition: color var(--t2);
}

.sb-stat:hover .sb-n {
  color: var(--ember);
}

/* ── PRICING enhanced ── */
.pcard {
  transition: transform var(--t2), border-color var(--t);
}

.pcard:hover {
  transform: translateY(-6px);
}

/* ── RESPONSIVE for new components ── */
@media (max-width: 900px) {
  .footer-v3-top {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
  }

  .fv3-brand {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .test-columns-wrap {
    grid-template-columns: 1fr;
    max-height: 520px;
  }

  .footer-v3-top {
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    padding: 48px 16px 40px;
  }

  .footer-v3-bottom {
    padding: 16px;
  }
}

@media (max-width: 480px) {
  .footer-v3-top {
    grid-template-columns: 1fr;
  }
}

/* ── BLUE THEME: Dashboard + Admin sidebars ─────────────────────────────── */
#pg-dash .dash-side,
#pg-admin .dash-side {
  background: #0A2550;
  border-right: 1.5px solid rgba(255, 255, 255, .08)
}

#pg-dash .dash-side .snav button,
#pg-admin .dash-side .snav button {
  color: rgba(255, 255, 255, .6)
}

#pg-dash .dash-side .snav button:hover,
#pg-admin .dash-side .snav button:hover {
  background: rgba(255, 255, 255, .07);
  color: #fff
}

#pg-dash .dash-side .snav button.on,
#pg-admin .dash-side .snav button.on {
  background: rgba(255, 255, 255, .1);
  color: var(--orange)
}

#pg-dash .dash-side [style*="color:var(--ink)"],
#pg-admin .dash-side [style*="color:var(--ink)"] {
  color: #fff !important
}

#pg-dash .dash-side [style*="color:var(--muted)"],
#pg-admin .dash-side [style*="color:var(--muted)"] {
  color: rgba(255, 255, 255, .5) !important
}

#pg-dash .dash-side [style*="border-bottom"],
#pg-admin .dash-side [style*="border-bottom"] {
  border-color: rgba(255, 255, 255, .1) !important
}

#pg-dash .dash-main,
#pg-admin .dash-main {
  background: #E8EFF8
}