/* ========================================
   KIZOMBA ACADEMY — KOMPLETNÝ CSS
   Extrahované zo súčasného header content + dopracované o language switcher, footer, persistent radio.
======================================== */

:root {
	--ka-gold:        #D4AF37;
	--ka-gold-light:  #F0C040;
	--ka-font:        'Montserrat', sans-serif;
	--ka-display:     'Playfair Display', serif;
	--ka-dark:        #0D0D0D;
	--ka-dark-purple: #1a0a2e;
	--ka-purple:      #2D1B69;
	--ka-red-dark:    #6b0f1a;
	--ka-white:       #ffffff;
	--ka-gray-light:  #f8f8f8;
	--ka-gray:        #666666;
	--ka-radius:      16px;
	--ka-shadow:      0 20px 60px rgba(0,0,0,0.12);
	--ka-shadow-gold: 0 8px 30px rgba(212,175,55,0.25);
}

/* Default hidden pre EN/ES/PT (cur lang sa zobrazí cez JS) */
.ka-lang[hidden] { display: none !important; }

/* ===== KILL old theme leftovers — Mara wants no switcher ===== */
html[data-ka-theme] body,
html[data-ka-theme="dark"] body,
html[data-ka-theme="pink"] body,
html[data-ka-theme="light"] body { background: #ffffff !important; }
html[data-ka-theme] .ka-section.ka-bg-light,
html[data-ka-theme] .ka-section.ka-bg-soft { background: revert !important; }

/* ===== /tim/ button v topbare — len pre admin/Mara/inštruktorov ===== */
.ka-tim-btn {
	display: inline-flex; align-items: center; gap: 6px;
	background: linear-gradient(135deg, #D4AF37, #F0C040);
	color: #1a0a2e !important;
	padding: 4px 12px;
	border-radius: 50px;
	font-size: 0.78rem; font-weight: 800; letter-spacing: 0.02em;
	text-decoration: none !important;
	box-shadow: 0 2px 8px rgba(212,175,55,0.3);
	transition: transform 0.15s, box-shadow 0.15s;
}
.ka-tim-btn:hover { transform: translateY(-1px); box-shadow: 0 4px 12px rgba(212,175,55,0.5); }
.ka-tim-btn svg { flex-shrink: 0; }

/* ===== THEME SWITCHER — disabled, retained only for legacy data-attr cleanup ===== */
.ka-theme-switcher {
	display: inline-flex; background: rgba(255,255,255,0.06);
	border: 1px solid rgba(212,175,55,0.3);
	border-radius: 50px; padding: 2px; gap: 0;
}
.ka-theme-btn {
	background: transparent; border: 0;
	width: 28px; height: 28px;
	border-radius: 50%; cursor: pointer;
	font-size: 14px; line-height: 1;
	display: inline-flex; align-items: center; justify-content: center;
	transition: background 0.2s, transform 0.15s;
	opacity: 0.55;
}
.ka-theme-btn:hover { opacity: 0.85; transform: scale(1.05); }
.ka-theme-btn.is-active {
	background: var(--ka-gold);
	opacity: 1;
	box-shadow: 0 2px 6px rgba(212,175,55,0.4);
}

/* ===== THEME — IBA background pre body + .ka-bg-light sekcie ===== */
/* Mara: prepínač má meniť LEN pozadie, nič iné (texty, tlačidlá, gradienty ostávajú) */

/* DARK (čierne) — default = current biele, dark = čierna body + sekcie */
html[data-ka-theme="dark"] body { background: #0a0a0a; }
html[data-ka-theme="dark"] .ka-section.ka-bg-light { background: #0a0a0a; }
html[data-ka-theme="dark"] .ka-section.ka-bg-soft  { background: #141414; }

/* PINK */
html[data-ka-theme="pink"] body { background: #ffe0ec; }
html[data-ka-theme="pink"] .ka-section.ka-bg-light { background: #ffe0ec; }
html[data-ka-theme="pink"] .ka-section.ka-bg-soft  { background: #ffd0e0; }

/* ===== TOP BAR ===== */
.ka-topbar { background: #000; padding: 8px 0; border-bottom: 1px solid rgba(212,175,55,0.2); }
.ka-topbar-inner { max-width: 1400px; margin: 0 auto; padding: 0 24px; display: flex; justify-content: flex-end; }
.ka-topbar-right { display: flex; gap: 16px; align-items: center; }

/* ── TOPBAR RADIO NOTA ── */
.ka-tb-radio {
	position: relative;
	width: 30px; height: 30px;
	border-radius: 50%;
	border: 1.5px solid rgba(212,175,55,0.5);
	background: rgba(212,175,55,0.08);
	color: var(--ka-gold);
	display: flex; align-items: center; justify-content: center;
	text-decoration: none !important;
	flex-shrink: 0;
	transition: background 0.3s, border-color 0.3s;
}
.ka-tb-radio:hover { background: rgba(212,175,55,0.2); border-color: var(--ka-gold); }

.ka-tb-note { animation: ka-note-spin 6s linear infinite; transform-origin: center; flex-shrink: 0; }
@keyframes ka-note-spin {
	0%   { transform: rotate(0deg)   scale(1);    }
	25%  { transform: rotate(10deg)  scale(1.08); }
	50%  { transform: rotate(0deg)   scale(1);    }
	75%  { transform: rotate(-10deg) scale(1.05); }
	100% { transform: rotate(0deg)   scale(1);    }
}

.ka-tb-radio-ring {
	position: absolute;
	inset: -3px;
	border-radius: 50%;
	border: 1.5px solid rgba(212,175,55,0.6);
	animation: ka-tb-ring 2.4s ease-out infinite;
	pointer-events: none;
}
.ka-tb-radio-ring--2 { animation-delay: 1.2s; }
@keyframes ka-tb-ring {
	0%   { transform: scale(1);    opacity: 0.7; }
	100% { transform: scale(1.65); opacity: 0;   }
}

/* ── LANGUAGE SWITCHER ── */
.ka-lang-switcher { position: relative; }
.ka-lang-current {
	display: flex; align-items: center; gap: 6px;
	background: rgba(212,175,55,0.08);
	border: 1.5px solid rgba(212,175,55,0.4);
	border-radius: 999px;
	padding: 4px 10px 4px 6px;
	color: var(--ka-gold);
	font: 600 12px var(--ka-font);
	letter-spacing: 0.5px;
	cursor: pointer;
	height: 30px;
}
.ka-lang-current:hover { background: rgba(212,175,55,0.18); border-color: var(--ka-gold); }
.ka-lang-current .ka-flag { font-size: 14px; line-height: 1; }
.ka-lang-current .ka-lang-code { font-size: 11px; }

.ka-lang-list {
	position: absolute; top: 100%; right: 0;
	margin-top: 6px;
	min-width: 160px;
	background: #1a1a1a;
	border: 1px solid var(--ka-gold);
	border-radius: 12px;
	padding: 6px 0;
	list-style: none;
	z-index: 10001;
	box-shadow: 0 12px 36px rgba(0,0,0,0.6);
}
.ka-lang-list li {
	display: flex; align-items: center; gap: 10px;
	padding: 8px 14px;
	color: #fff; font-size: 13px;
	cursor: pointer;
	transition: background 0.15s;
}
.ka-lang-list li:hover { background: rgba(212,175,55,0.2); }
.ka-lang-list li[aria-selected="true"] { color: var(--ka-gold); font-weight: 700; }
.ka-lang-list .ka-flag { font-size: 16px; }

/* social + account ikony */
.ka-social-icon {
	color: var(--ka-gold);
	text-decoration: none;
	display: flex; align-items: center; justify-content: center;
	width: 30px; height: 30px;
	transition: opacity 0.3s, transform 0.2s;
}
.ka-social-icon:hover { opacity: 0.8; transform: scale(1.08); }
.ka-account-icon { border: 1.5px solid rgba(212,175,55,0.3); border-radius: 50%; }
.ka-account-icon:hover { border-color: var(--ka-gold); background: rgba(212,175,55,0.1); }

/* ===== HEADER ===== */
.ka-header {
	background: #0D0D0D;
	font-family: var(--ka-font);
	position: sticky; top: 0;
	z-index: 9999;
	height: 100px;
	border-bottom: 2px solid rgba(212,175,55,0.1);
}
.ka-header-inner {
	max-width: 1400px; margin: 0 auto; padding: 0 24px;
	display: flex; align-items: center; justify-content: space-between;
	height: 100%;
}
.ka-logo-link { flex-shrink: 0; display: flex; align-items: center; }
.ka-header-logo {
	height: 85px !important;
	width: auto !important;
	max-width: 100%;
	object-fit: contain;
	filter: brightness(0) invert(1);
	transition: transform 0.3s;
}
.ka-header-logo:hover { transform: scale(1.03); }

/* ===== NAVIGÁCIA ===== */
.ka-nav { display: flex; gap: 8px; align-items: center; }
.ka-nav-item { position: relative; }
.ka-nav-link {
	color: #ffffff;
	padding: 10px 15px;
	font-weight: 300; cursor: pointer;
	text-transform: uppercase;
	font-size: 1.15rem;
	font-family: var(--ka-font);
	letter-spacing: 1.5px;
	transition: color 0.3s;
	display: block; white-space: nowrap;
	text-decoration: none;
}
.ka-nav-link:hover { color: var(--ka-gold); }
.ka-dropdown {
	position: absolute; top: 100%; left: 0;
	background: #1a1a1a;
	border-top: 3px solid var(--ka-gold);
	min-width: 250px;
	padding: 10px 0;
	opacity: 0; visibility: hidden;
	transform: translateY(15px);
	transition: 0.3s;
	z-index: 1000;
}
.ka-nav-item:hover .ka-dropdown { opacity: 1; visibility: visible; transform: translateY(0); }
.ka-dropdown-link {
	color: #fff; text-decoration: none; display: block;
	padding: 12px 25px;
	font-size: 1rem; font-family: var(--ka-font);
	font-weight: 400; letter-spacing: 0.5px;
	transition: background 0.2s;
}
.ka-dropdown-link:hover { background: var(--ka-gold); color: #000; }

/* ===== HEADER ACTIONS ===== */
.ka-header-actions { display: flex; align-items: center; gap: 15px; flex-shrink: 0; }
.ka-checkout-btn {
	display: flex !important; align-items: center !important; gap: 10px !important;
	background: linear-gradient(135deg, #D4AF37, #F0C040) !important;
	color: #000 !important;
	padding: 12px 25px !important;
	border-radius: 50px !important;
	border: none !important;
	font-weight: 600 !important; font-size: 1rem !important;
	font-family: var(--ka-font) !important;
	cursor: pointer !important;
	box-shadow: 0 4px 15px rgba(212,175,55,0.3) !important;
	transition: transform 0.3s, box-shadow 0.3s !important;
	white-space: nowrap !important; letter-spacing: 0.5px !important;
}
.ka-checkout-btn:hover { transform: translateY(-2px); box-shadow: 0 6px 25px rgba(212,175,55,0.5); }
.ka-checkout-btn { text-decoration: none !important; position: relative; }
.ka-cart-count {
	background: #6b0f1a; color: #fff;
	min-width: 22px; height: 22px; padding: 0 6px;
	border-radius: 11px;
	display: inline-flex; align-items: center; justify-content: center;
	font-size: 0.8rem; font-weight: 700;
	margin-left: 4px;
	box-shadow: 0 2px 6px rgba(0,0,0,0.2);
}

/* ===== HAMBURGER ===== */
.ka-hamburger {
	display: none; flex-direction: column;
	justify-content: center; align-items: center;
	gap: 6px;
	width: 44px; height: 44px;
	background: none;
	border: 2px solid rgba(255,255,255,0.2);
	border-radius: 8px;
	cursor: pointer; padding: 0; z-index: 10001;
}
.ka-hamburger span { display: block; width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: 0.3s; }
.ka-hamburger.open span:nth-child(1) { transform: translateY(8px) rotate(45deg); }
.ka-hamburger.open span:nth-child(2) { opacity: 0; }
.ka-hamburger.open span:nth-child(3) { transform: translateY(-8px) rotate(-45deg); }

/* Persistent radio audio element je `hidden`; CSS hidden = OK, ale prehliadač ho stále drží v DOM */
#ka-persistent-radio { display: none; }

/* ADMIN BAR */
.admin-bar .ka-header { top: 32px !important; }
@media screen and (max-width: 782px) {
	.admin-bar .ka-header { top: 46px !important; }
}

/* ========================================
   FOOTER
======================================== */
.ka-footer {
	background: linear-gradient(180deg, #0D0D0D 0%, #1a0a2e 100%);
	color: rgba(255,255,255,0.75);
	font-family: var(--ka-font);
	padding: 60px 24px 24px;
	margin-top: 60px;
}
.ka-footer-inner {
	max-width: 1400px; margin: 0 auto;
	display: grid;
	grid-template-columns: 1.5fr 1fr 1fr 1fr 1.2fr;
	gap: 30px;
}
.ka-footer-col h3, .ka-footer-col h4 {
	color: #fff;
	font-family: var(--ka-display);
	font-weight: 700;
	margin: 0 0 16px;
	font-size: 1.05rem;
	letter-spacing: 0.5px;
}
.ka-footer-col h3 { font-size: 1.5rem; color: var(--ka-gold-light); }
.ka-footer-brand { display: inline-block; margin-bottom: 14px; }
.ka-footer-logo {
	max-width: 180px; height: auto; display: block;
	filter: brightness(0) invert(1);
	opacity: 0.92;
	transition: opacity 0.18s;
}
.ka-footer-brand:hover .ka-footer-logo { opacity: 1; }
.ka-footer-tagline { font-style: italic; color: rgba(255,255,255,0.55); font-size: 0.92rem; line-height: 1.6; }
.ka-footer-col ul { list-style: none; padding: 0; margin: 0; }
.ka-footer-col li { margin: 8px 0; }
.ka-footer-col a {
	color: rgba(255,255,255,0.7);
	text-decoration: none;
	font-size: 0.92rem;
	transition: color 0.2s;
}
.ka-footer-col a:hover { color: var(--ka-gold); }
.ka-footer-col p { margin: 6px 0; font-size: 0.92rem; }
.ka-footer-social { margin-top: 14px; display: flex; gap: 12px; }
.ka-footer-social a {
	width: 40px; height: 40px;
	border: 1.5px solid rgba(212,175,55,0.4);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center;
	color: var(--ka-gold);
	transition: all 0.2s;
}
.ka-footer-social a:hover { background: var(--ka-gold); color: #000; transform: translateY(-2px); }

.ka-footer-bottom {
	max-width: 1400px;
	margin: 40px auto 0;
	padding: 20px 0 0;
	border-top: 1px solid rgba(255,255,255,0.08);
	text-align: center;
	color: rgba(255,255,255,0.4);
	font-size: 0.8rem;
}
.ka-footer-bottom p { margin: 0; }

/* ========================================
   MOBILE / TABLET
======================================== */
@media (max-width: 1200px) {
	.ka-hamburger { display: flex !important; }
	.ka-nav {
		position: fixed; top: 0; left: 0; right: 0; bottom: 0;
		background: rgba(13,13,13,0.98);
		flex-direction: column; align-items: flex-start; justify-content: flex-start;
		padding: 120px 40px 40px 40px;
		gap: 0; overflow-y: auto;
		transform: translateX(100%);
		transition: 0.4s cubic-bezier(0.16, 1, 0.3, 1);
		z-index: 10000;
	}
	.ka-nav.active { transform: translateX(0); }
	.ka-nav-link { font-size: 1.4rem; padding: 16px 0; border-bottom: 1px solid rgba(255,255,255,0.06); width: 100%; }
	.ka-dropdown {
		position: static; opacity: 1; visibility: visible; transform: none;
		background: transparent; border: none; padding: 0 0 0 20px;
		max-height: 0; overflow: hidden; transition: max-height 0.4s ease;
	}
	.ka-nav-item.open .ka-dropdown { max-height: 400px; }
	.ka-dropdown-link { padding: 12px 0; font-size: 1.1rem; border-bottom: 1px solid rgba(255,255,255,0.04); }
	.ka-checkout-label { display: none; }
	.ka-checkout-btn { padding: 10px !important; border-radius: 50% !important; gap: 0 !important; }
}

@media (max-width: 900px) {
	.ka-footer-inner { grid-template-columns: 1fr 1fr; gap: 24px; }
}

@media (max-width: 480px) {
	.ka-header { height: 80px; }
	.ka-header-logo { height: 65px !important; }
	.ka-topbar-right { gap: 12px; }
	.ka-tb-radio { width: 26px; height: 26px; }
	.ka-footer-inner { grid-template-columns: 1fr; }
}
