/* ==========================================================================
   KNOX KPOP — "STAGE CALL" Design System
   The lights drop. The bass hits. You're at a K-pop concert.
   ========================================================================== */


/* ═══════════════════════════════════════════════════════════════════════════
   TOKENS
   ═══════════════════════════════════════════════════════════════════════════ */
:root {
  --kk-void: #06060C;
  --kk-deep: #0C0C18;
  --kk-surface: #12121F;
  --kk-surface-2: #1A1A2E;

  --kk-hot-pink: #FF1493;
  --kk-magenta: #E040FB;
  --kk-electric-violet: #7C3AED;
  --kk-cyan: #00E5FF;
  --kk-gold: #FFD600;
  --kk-white: #F5F5FA;
  --kk-silver: #B0B0C8;
  --kk-muted: #6E6E8A;

  --kk-gradient-hero: linear-gradient(135deg, #FF1493 0%, #E040FB 40%, #7C3AED 100%);
  --kk-gradient-chrome: linear-gradient(180deg, #E8E8F0 0%, #8888A0 50%, #D0D0E0 100%);
  --kk-gradient-stage: linear-gradient(180deg, var(--kk-void) 0%, #0D0818 50%, var(--kk-void) 100%);

  --kk-font-display: 'Oswald', 'Impact', sans-serif;
  --kk-font-body: 'DM Sans', 'Segoe UI', sans-serif;
  --kk-font-hangul: 'Black Han Sans', sans-serif;

  --kk-ease-out-expo: cubic-bezier(0.16, 1, 0.3, 1);
  --kk-ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}


/* ═══════════════════════════════════════════════════════════════════════════
   KEYFRAMES — The choreography
   ═══════════════════════════════════════════════════════════════════════════ */
@keyframes kk-spotlight-sweep {
  0%   { transform: rotate(-25deg) translateX(-100%); opacity: 0; }
  10%  { opacity: 1; }
  90%  { opacity: 1; }
  100% { transform: rotate(25deg) translateX(100%); opacity: 0; }
}

@keyframes kk-pulse-glow {
  0%, 100% { box-shadow: 0 0 20px rgba(255, 20, 147, 0.2), 0 0 60px rgba(255, 20, 147, 0.05); }
  50%      { box-shadow: 0 0 30px rgba(255, 20, 147, 0.4), 0 0 80px rgba(255, 20, 147, 0.1); }
}

@keyframes kk-gradient-shift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes kk-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-8px); }
}

@keyframes kk-bokeh-drift {
  0%   { transform: translate(0, 0) scale(1); }
  33%  { transform: translate(30px, -20px) scale(1.1); }
  66%  { transform: translate(-20px, 15px) scale(0.9); }
  100% { transform: translate(0, 0) scale(1); }
}

@keyframes kk-border-travel {
  0%   { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}

@keyframes kk-entrance-up {
  from { opacity: 0; transform: translateY(60px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes kk-entrance-scale {
  from { opacity: 0; transform: scale(0.85); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes kk-text-shimmer {
  0%   { background-position: -200% center; }
  100% { background-position: 200% center; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   GLOBAL BODY — The venue
   ═══════════════════════════════════════════════════════════════════════════ */
body.elementor-default,
body.elementor-page {
  background: var(--kk-void) !important;
  color: var(--kk-white) !important;
  font-family: var(--kk-font-body) !important;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
  padding-top: 60px !important;
}

/* Grain texture — like concert haze */
body.elementor-default::after {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 512 512' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.75' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
  mix-blend-mode: overlay;
}

::selection {
  background: rgba(255, 20, 147, 0.35);
  color: #fff;
}

::-webkit-scrollbar { width: 6px; }
::-webkit-scrollbar-track { background: var(--kk-void); }
::-webkit-scrollbar-thumb {
  background: var(--kk-gradient-hero);
  border-radius: 10px;
}


/* ═══════════════════════════════════════════════════════════════════════════
   TYPOGRAPHY — Headlines that HIT
   ═══════════════════════════════════════════════════════════════════════════ */

/* Every heading gets the gradient treatment */
.elementor-heading-title,
.elementor-widget-heading .elementor-heading-title {
  font-family: var(--kk-font-display) !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  line-height: 1.05 !important;
  background: var(--kk-gradient-hero) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

h1.elementor-heading-title { font-size: clamp(3.5rem, 10vw, 7rem) !important; }
h2.elementor-heading-title { font-size: clamp(2.2rem, 6vw, 4rem) !important; }
h3.elementor-heading-title {
  font-size: clamp(1.4rem, 3vw, 2rem) !important;
  letter-spacing: 0.06em !important;
}
h4.elementor-heading-title {
  font-size: clamp(1.2rem, 2.5vw, 1.6rem) !important;
}

/* ── Shortcode headings — override Elementor's global heading color ────── */
.kk-section-header__title,
.kk-feature-card__title,
.kk-pricing-card__title,
.kk-info-card__title,
.kk-class-card__time,
.kk-class-card__group {
  -webkit-text-fill-color: unset !important;
  background: none !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  color: var(--kk-white) !important;
}

.kk-instructor-card__name,
.kk-cta-banner__headline,
.kk-hero__headline {
  background: var(--kk-gradient-hero) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

/* ── Links inside shortcode components — force visible colors ──────── */
.kk-info-card a,
.kk-instructor-card a,
.kk-feature-card a,
.kk-class-card a,
.kk-pricing-card a,
.kk-cta-banner a:not(.kk-btn),
.kk-hero a:not(.kk-btn) {
  color: var(--kk-cyan) !important;
  -webkit-text-fill-color: var(--kk-cyan) !important;
  text-decoration: underline !important;
  text-decoration-color: rgba(0, 229, 255, 0.3) !important;
  text-underline-offset: 2px !important;
}

.kk-info-card a:hover,
.kk-instructor-card a:hover,
.kk-feature-card a:hover,
.kk-class-card a:hover,
.kk-pricing-card a:hover {
  color: var(--kk-hot-pink) !important;
  -webkit-text-fill-color: var(--kk-hot-pink) !important;
  text-decoration-color: rgba(255, 20, 147, 0.5) !important;
}

/* Chrome/metallic heading variant for counters & stats */
.elementor-counter-number-wrapper {
  font-family: var(--kk-font-display) !important;
  font-weight: 700 !important;
  font-size: clamp(3rem, 8vw, 5rem) !important;
  background: var(--kk-gradient-chrome) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  filter: brightness(1.2) contrast(1.1);
}

.elementor-counter-title {
  font-family: var(--kk-font-body) !important;
  color: var(--kk-cyan) !important;
  text-transform: uppercase !important;
  letter-spacing: 0.2em !important;
  font-size: 0.75rem !important;
  font-weight: 700 !important;
}

/* Body text */
.elementor-widget-text-editor,
.elementor-widget-text-editor p,
.elementor-text-editor p {
  font-family: var(--kk-font-body) !important;
  color: var(--kk-silver) !important;
  font-size: 1.05rem !important;
  line-height: 1.75 !important;
}

.elementor-widget-text-editor strong,
.elementor-text-editor strong {
  color: var(--kk-white) !important;
  font-weight: 600;
}


/* ═══════════════════════════════════════════════════════════════════════════
   HEADER — Backstage pass
   ═══════════════════════════════════════════════════════════════════════════ */
.site-header,
header.site-header,
.elementor-location-header {
  background: rgba(6, 6, 12, 0.7) !important;
  backdrop-filter: blur(24px) saturate(180%) !important;
  -webkit-backdrop-filter: blur(24px) saturate(180%) !important;
  border-bottom: 1px solid rgba(255, 20, 147, 0.08) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 1000 !important;
  transition: all 0.5s var(--kk-ease-out-expo) !important;
  overflow: visible !important;
  height: auto !important;
  min-height: auto !important;
}

.site-header.scrolled,
.elementor-location-header.scrolled {
  background: rgba(6, 6, 12, 0.92) !important;
  border-bottom-color: rgba(255, 20, 147, 0.15) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.6), 0 0 60px rgba(255, 20, 147, 0.04) !important;
}

/* Site title — gradient text (high specificity to beat global h2 rule) */
.site-header .elementor-heading-title,
.site-header h2.elementor-heading-title,
.site-header h2.elementor-heading-title a,
.site-header .site-title,
.elementor-location-header .elementor-heading-title,
.elementor-location-header h2.elementor-heading-title,
.elementor-location-header h2.elementor-heading-title a {
  font-family: var(--kk-font-display) !important;
  font-size: 1.1rem !important;
  letter-spacing: 0.12em !important;
  background: var(--kk-gradient-hero) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
  text-decoration: none !important;
  white-space: nowrap !important;
  line-height: 1.3 !important;
}

/* Header layout — single row */
.site-header .e-con-inner,
.site-header .elementor-container,
.elementor-location-header .e-con-inner,
.elementor-location-header .elementor-container {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: nowrap !important;
  gap: 1rem !important;
}

/* Nav links */
.site-header nav a,
.site-header .elementor-nav-menu a,
.site-header .elementor-item,
.elementor-location-header nav a,
.elementor-location-header .elementor-nav-menu a,
.elementor-location-header .elementor-item {
  font-family: var(--kk-font-body) !important;
  font-weight: 600 !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
  color: var(--kk-silver) !important;
  text-decoration: none !important;
  transition: all 0.3s var(--kk-ease-out-expo) !important;
  position: relative !important;
}

.site-header nav a:hover,
.site-header .elementor-item:hover,
.elementor-location-header nav a:hover,
.elementor-location-header .elementor-item:hover {
  color: var(--kk-white) !important;
  text-shadow: 0 0 20px rgba(255, 20, 147, 0.6) !important;
}

/* Animated underline on hover */
.site-header nav a::after,
.site-header .elementor-item::after,
.elementor-location-header nav a::after,
.elementor-location-header .elementor-item::after {
  content: '' !important;
  position: absolute !important;
  bottom: -4px !important;
  left: 0 !important;
  width: 0 !important;
  height: 2px !important;
  background: var(--kk-gradient-hero) !important;
  transition: width 0.4s var(--kk-ease-out-expo) !important;
  box-shadow: 0 0 8px rgba(255, 20, 147, 0.4) !important;
}

.site-header nav a:hover::after,
.site-header .elementor-item:hover::after,
.elementor-location-header nav a:hover::after,
.elementor-location-header .elementor-item:hover::after {
  width: 100% !important;
}

/* Social icons — constrain to single row */
.site-header .elementor-social-icons-wrapper,
.elementor-location-header .elementor-social-icons-wrapper {
  display: flex !important;
  flex-wrap: nowrap !important;
  gap: 0.4rem !important;
}

.elementor-social-icons-wrapper .elementor-icon {
  background: transparent !important;
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  color: var(--kk-silver) !important;
  fill: var(--kk-silver) !important;
  transition: all 0.3s var(--kk-ease-out-expo) !important;
}

.site-header .elementor-social-icons-wrapper .elementor-icon,
.elementor-location-header .elementor-social-icons-wrapper .elementor-icon {
  width: 28px !important;
  height: 28px !important;
  min-width: 28px !important;
  font-size: 12px !important;
}

.elementor-social-icons-wrapper .elementor-icon:hover {
  border-color: var(--kk-hot-pink) !important;
  color: var(--kk-hot-pink) !important;
  fill: var(--kk-hot-pink) !important;
  box-shadow: 0 0 20px rgba(255, 20, 147, 0.3) !important;
}

/* Nav toggle icon */
.elementor-location-header .e-n-menu-toggle-icon,
.elementor-location-header .e-n-menu-title {
  background-color: transparent !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SECTIONS — Each one is a stage entrance
   ═══════════════════════════════════════════════════════════════════════════ */

/* Kill all old Elementor backgrounds */
.elementor-section,
.elementor-top-section,
.e-con,
.e-con.e-parent,
.elementor-element[style*="background-color"] {
  background-color: transparent !important;
}

/* Column wrapper cards → glass with animated borders */
.elementor-widget-wrap.elementor-element-populated {
  background: rgba(12, 12, 24, 0.6) !important;
  backdrop-filter: blur(12px) !important;
  -webkit-backdrop-filter: blur(12px) !important;
  border: 1px solid rgba(255, 255, 255, 0.04) !important;
  border-radius: 16px !important;
  transition: all 0.5s var(--kk-ease-out-expo) !important;
  position: relative !important;
}

.elementor-widget-wrap.elementor-element-populated:hover {
  border-color: rgba(255, 20, 147, 0.2) !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4), 0 0 40px rgba(255, 20, 147, 0.06) !important;
  transform: translateY(-4px) !important;
}

/* Full-width sections — no card treatment */
.elementor-section-full_width > .elementor-container > .elementor-column > .elementor-widget-wrap.elementor-element-populated,
.elementor-section-boxed > .elementor-container > .elementor-column:only-child > .elementor-widget-wrap.elementor-element-populated {
  background: transparent !important;
  backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  transform: none !important;
  box-shadow: none !important;
}

/* Header/footer — exempt from section and card overrides */
.elementor-location-header .elementor-top-section,
.elementor-location-header .e-con.e-parent {
  padding-top: 0.75rem !important;
  padding-bottom: 0.75rem !important;
  overflow: visible !important;
}

.elementor-location-footer .elementor-top-section,
.elementor-location-footer .e-con.e-parent {
  padding-top: 2rem !important;
  padding-bottom: 2rem !important;
  overflow: visible !important;
}

.elementor-location-header .elementor-widget-wrap.elementor-element-populated,
.elementor-location-footer .elementor-widget-wrap.elementor-element-populated {
  background: transparent !important;
  backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  transform: none !important;
  box-shadow: none !important;
}

.elementor-location-header .elementor-widget-wrap.elementor-element-populated:hover {
  transform: none !important;
  box-shadow: none !important;
}

/* Nav toggle */
.e-n-menu-toggle-icon,
.e-n-menu-title {
  background-color: transparent !important;
}

/* Alternating dark section rhythm */
.elementor-top-section:nth-child(odd),
.e-con.e-parent:nth-child(odd) {
  background: var(--kk-void) !important;
}

.elementor-top-section:nth-child(even),
.e-con.e-parent:nth-child(even) {
  background: var(--kk-gradient-stage) !important;
}

/* Section spacing — dramatic */
.elementor-top-section,
.e-con.e-parent {
  padding-top: clamp(4rem, 8vw, 8rem) !important;
  padding-bottom: clamp(4rem, 8vw, 8rem) !important;
  position: relative !important;
  overflow: hidden !important;
}

/* Spotlight beam effect on sections (injected via JS) */
.kk-has-spotlight::before {
  content: '';
  position: absolute;
  top: -50%;
  left: 50%;
  width: 200px;
  height: 200%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(255, 20, 147, 0.03) 30%,
    rgba(255, 20, 147, 0.08) 50%,
    rgba(255, 20, 147, 0.03) 70%,
    transparent 100%
  );
  transform: rotate(-15deg);
  pointer-events: none;
  z-index: 0;
}

.kk-has-spotlight-alt::before {
  content: '';
  position: absolute;
  top: -50%;
  right: 20%;
  left: auto;
  width: 180px;
  height: 200%;
  background: linear-gradient(
    180deg,
    transparent 0%,
    rgba(124, 58, 237, 0.03) 30%,
    rgba(124, 58, 237, 0.06) 50%,
    rgba(124, 58, 237, 0.03) 70%,
    transparent 100%
  );
  transform: rotate(12deg);
  pointer-events: none;
  z-index: 0;
}

/* Section divider — thin gradient line */
.elementor-top-section + .elementor-top-section::after,
.e-con.e-parent + .e-con.e-parent::after {
  content: '';
  position: absolute;
  top: 0;
  left: 10%;
  width: 80%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 20, 147, 0.15), rgba(124, 58, 237, 0.15), transparent);
}


/* ═══════════════════════════════════════════════════════════════════════════
   BUTTONS — Stage-ready CTAs
   ═══════════════════════════════════════════════════════════════════════════ */
.elementor-button,
.elementor-button-link {
  font-family: var(--kk-font-body) !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  font-size: 0.85rem !important;
  background: var(--kk-gradient-hero) !important;
  background-size: 200% 200% !important;
  animation: kk-gradient-shift 4s ease infinite !important;
  color: #fff !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 16px 40px !important;
  position: relative !important;
  overflow: hidden !important;
  transition: all 0.4s var(--kk-ease-out-expo) !important;
  box-shadow: 0 4px 20px rgba(255, 20, 147, 0.25) !important;
}

/* Shimmer sweep on button */
.elementor-button::before {
  content: '' !important;
  position: absolute !important;
  top: 0 !important;
  left: -100% !important;
  width: 100% !important;
  height: 100% !important;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent) !important;
  transition: left 0.6s ease !important;
}

.elementor-button:hover {
  transform: translateY(-3px) scale(1.03) !important;
  box-shadow: 0 8px 40px rgba(255, 20, 147, 0.4), 0 0 80px rgba(255, 20, 147, 0.12) !important;
}

.elementor-button:hover::before {
  left: 100% !important;
}

.elementor-button:active {
  transform: translateY(-1px) scale(0.98) !important;
}

/* Outline button variant */
.elementor-button.elementor-size-xs {
  background: transparent !important;
  border: 2px solid rgba(255, 20, 147, 0.5) !important;
  animation: kk-pulse-glow 3s ease-in-out infinite !important;
  box-shadow: none !important;
}

.elementor-button.elementor-size-xs:hover {
  background: rgba(255, 20, 147, 0.1) !important;
  border-color: var(--kk-hot-pink) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   IMAGES & VIDEO — Cinematic treatment
   ═══════════════════════════════════════════════════════════════════════════ */
.elementor-widget-image img {
  border-radius: 12px !important;
  transition: all 0.6s var(--kk-ease-out-expo) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5) !important;
}

.elementor-widget-image:hover img {
  transform: scale(1.02) !important;
  box-shadow: 0 16px 64px rgba(0, 0, 0, 0.6), 0 0 40px rgba(255, 20, 147, 0.08) !important;
}

.elementor-widget-video .elementor-wrapper {
  border-radius: 12px !important;
  overflow: hidden !important;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.6) !important;
}

.elementor-image-carousel-wrapper,
.elementor-slides-wrapper {
  border-radius: 12px !important;
  overflow: hidden !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   FORMS — Backstage access
   ═══════════════════════════════════════════════════════════════════════════ */
.forminator-custom-form input[type="text"],
.forminator-custom-form input[type="email"],
.forminator-custom-form input[type="tel"],
.forminator-custom-form input[type="number"],
.forminator-custom-form textarea,
.forminator-custom-form select,
.forminator-ui input,
.forminator-ui textarea,
.forminator-ui select {
  background: var(--kk-deep) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: 8px !important;
  color: var(--kk-white) !important;
  font-family: var(--kk-font-body) !important;
  padding: 16px 18px !important;
  font-size: 0.95rem !important;
  transition: all 0.3s var(--kk-ease-out-expo) !important;
}

.forminator-custom-form input:focus,
.forminator-custom-form textarea:focus,
.forminator-ui input:focus,
.forminator-ui textarea:focus {
  border-color: var(--kk-hot-pink) !important;
  box-shadow: 0 0 0 4px rgba(255, 20, 147, 0.1), 0 0 20px rgba(255, 20, 147, 0.05) !important;
  outline: none !important;
}

.forminator-custom-form label,
.forminator-ui .forminator-label {
  color: var(--kk-muted) !important;
  font-family: var(--kk-font-body) !important;
  font-weight: 600 !important;
  font-size: 0.7rem !important;
  letter-spacing: 0.15em !important;
  text-transform: uppercase !important;
}

.forminator-custom-form .forminator-button,
.forminator-ui .forminator-button-submit {
  background: var(--kk-gradient-hero) !important;
  background-size: 200% 200% !important;
  animation: kk-gradient-shift 4s ease infinite !important;
  border: none !important;
  border-radius: 50px !important;
  color: #fff !important;
  font-family: var(--kk-font-body) !important;
  font-weight: 700 !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
  padding: 16px 48px !important;
  cursor: pointer !important;
  transition: all 0.4s var(--kk-ease-out-expo) !important;
  box-shadow: 0 4px 20px rgba(255, 20, 147, 0.25) !important;
}

.forminator-custom-form .forminator-button:hover,
.forminator-ui .forminator-button-submit:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 40px rgba(255, 20, 147, 0.4) !important;
}

.forminator-custom-form input::placeholder,
.forminator-custom-form textarea::placeholder {
  color: var(--kk-muted) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   FOOTER — Exit stage
   ═══════════════════════════════════════════════════════════════════════════ */
footer,
.elementor-location-footer,
footer.site-footer {
  background: var(--kk-void) !important;
  border-top: 1px solid rgba(255, 20, 147, 0.06) !important;
}

.elementor-location-footer .elementor-heading-title {
  background: var(--kk-gradient-hero) !important;
  -webkit-background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
  background-clip: text !important;
}

.elementor-location-footer p,
.elementor-location-footer .elementor-widget-text-editor p {
  color: var(--kk-muted) !important;
}

.elementor-location-footer a {
  color: var(--kk-silver) !important;
  transition: color 0.3s !important;
}

.elementor-location-footer a:hover {
  color: var(--kk-hot-pink) !important;
}

.elementor-location-footer nav a {
  font-family: var(--kk-font-body) !important;
  font-size: 0.75rem !important;
  letter-spacing: 0.12em !important;
  text-transform: uppercase !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   LISTS & ICONS
   ═══════════════════════════════════════════════════════════════════════════ */
.elementor-icon-list-items .elementor-icon-list-item {
  color: var(--kk-silver) !important;
}

.elementor-icon-list-icon i,
.elementor-icon-list-icon svg {
  color: var(--kk-hot-pink) !important;
  fill: var(--kk-hot-pink) !important;
}

.elementor-divider-separator {
  border-color: rgba(255, 20, 147, 0.12) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   LINKS
   ═══════════════════════════════════════════════════════════════════════════ */
a { color: var(--kk-hot-pink); text-decoration: none; }
a:hover { color: var(--kk-cyan); }

.elementor-widget-text-editor a {
  color: var(--kk-hot-pink) !important;
  text-decoration: underline !important;
  text-decoration-color: rgba(255, 20, 147, 0.25) !important;
  text-underline-offset: 3px !important;
  transition: all 0.3s !important;
}

.elementor-widget-text-editor a:hover {
  color: var(--kk-cyan) !important;
  text-decoration-color: var(--kk-cyan) !important;
}

/* Widget containers */
.elementor-widget-container { color: var(--kk-white); }


/* ═══════════════════════════════════════════════════════════════════════════
   AMELIA — Dark concert mode
   ═══════════════════════════════════════════════════════════════════════════ */
.amelia-app-booking,
.amelia-v2-booking {
  background: transparent !important;
  font-family: var(--kk-font-body) !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   WOOCOMMERCE
   ═══════════════════════════════════════════════════════════════════════════ */
.woocommerce .button,
.woocommerce a.button {
  background: var(--kk-gradient-hero) !important;
  color: #fff !important;
  border-radius: 50px !important;
  border: none !important;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SCROLL REVEAL — Theatrical entrances
   ═══════════════════════════════════════════════════════════════════════════ */
.kk-reveal {
  opacity: 0;
  transform: translateY(60px) scale(0.97);
  transition: opacity 1s var(--kk-ease-out-expo),
              transform 1s var(--kk-ease-out-expo);
  will-change: opacity, transform;
}

.kk-reveal.revealed {
  opacity: 1;
  transform: translateY(0) scale(1);
}


/* ═══════════════════════════════════════════════════════════════════════════
   BOKEH — Floating light particles (injected via JS)
   ═══════════════════════════════════════════════════════════════════════════ */
.kk-bokeh-dot {
  position: absolute;
  border-radius: 50%;
  pointer-events: none;
  z-index: 0;
  animation: kk-bokeh-drift 20s ease-in-out infinite;
  mix-blend-mode: screen;
}


/* ═══════════════════════════════════════════════════════════════════════════
   HANGUL WATERMARK — Korean accent text (injected via JS)
   ═══════════════════════════════════════════════════════════════════════════ */
.kk-hangul-float {
  position: absolute;
  font-family: var(--kk-font-hangul);
  pointer-events: none;
  z-index: 0;
  line-height: 1;
  user-select: none;
  white-space: nowrap;
  background: linear-gradient(180deg, rgba(255, 20, 147, 0.25) 0%, rgba(124, 58, 237, 0.18) 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
}


/* ═══════════════════════════════════════════════════════════════════════════
   SHORTCODE CARD SYSTEM
   ═══════════════════════════════════════════════════════════════════════════ */

/* Prevent double-card from Elementor wrapper */
.elementor-widget-shortcode > .elementor-widget-container {
  background: transparent !important;
  backdrop-filter: none !important;
  border: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* ── Shared button component ──────────────────────────────────────── */
.kk-btn {
  display: inline-block;
  font-family: var(--kk-font-body);
  font-weight: 700;
  font-size: 0.85rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 50px;
  padding: 14px 36px;
  cursor: pointer;
  transition: all 0.4s var(--kk-ease-out-expo);
  position: relative;
  overflow: hidden;
}

.kk-btn--primary {
  background: var(--kk-gradient-hero);
  background-size: 200% 200%;
  animation: kk-gradient-shift 4s ease infinite;
  color: #fff;
  box-shadow: 0 4px 20px rgba(255, 20, 147, 0.25);
}

.kk-btn--primary:hover {
  transform: translateY(-3px) scale(1.03);
  box-shadow: 0 8px 40px rgba(255, 20, 147, 0.4);
  color: #fff;
}

.kk-btn--outline {
  background: transparent !important;
  border: 2px solid rgba(255, 20, 147, 0.5) !important;
  color: var(--kk-white) !important;
  -webkit-text-fill-color: var(--kk-white) !important;
}

.kk-btn--outline:hover {
  background: rgba(255, 20, 147, 0.1) !important;
  border-color: var(--kk-hot-pink) !important;
  color: #fff !important;
  -webkit-text-fill-color: #fff !important;
}

.kk-btn--sm {
  padding: 10px 24px;
  font-size: 0.75rem;
}

/* ── Hero ─────────────────────────────────────────────────────────── */
.kk-hero {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  margin-top: -60px;
}

.kk-hero__video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}

.kk-hero__bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

.kk-hero__overlay {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.kk-hero__overlay--gradient {
  background: linear-gradient(180deg, rgba(6,6,12,0.7) 0%, rgba(6,6,12,0.4) 40%, rgba(6,6,12,0.8) 100%);
}

.kk-hero__overlay--solid {
  background: rgba(6, 6, 12, 0.75);
}

.kk-hero__content {
  position: relative;
  z-index: 2;
  max-width: 900px;
  padding: 4rem 2rem;
}

.kk-hero--center { text-align: center; }
.kk-hero--center .kk-hero__content { margin: 0 auto; }
.kk-hero--left .kk-hero__content { margin-right: auto; }

.kk-hero__headline {
  font-family: var(--kk-font-display);
  font-weight: 700;
  font-size: clamp(3.5rem, 10vw, 7rem);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1;
  background: var(--kk-gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 0.5rem;
}

.kk-hero__subtext {
  font-family: var(--kk-font-body);
  font-size: 1.15rem;
  color: var(--kk-silver);
  margin: 0 0 2rem;
  line-height: 1.6;
}

.kk-hero__body {
  color: var(--kk-silver);
  font-size: 1rem;
  line-height: 1.7;
  margin-bottom: 2rem;
}

.kk-hero__actions {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.kk-hero--center .kk-hero__actions { justify-content: center; }

/* ── Section Header ───────────────────────────────────────────────── */
.kk-section-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: 4rem;
  margin-bottom: 3rem;
  gap: 2rem;
}

.kk-section-header--center {
  flex-direction: column;
  align-items: center;
  text-align: center;
}

.kk-section-header__label {
  display: block;
  font-family: var(--kk-font-body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--kk-cyan);
  margin-bottom: 0.5rem;
}

.kk-section-header__title {
  font-family: var(--kk-font-display);
  font-size: clamp(2rem, 5vw, 3.5rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.03em;
  line-height: 1.05;
  color: var(--kk-white);
  margin: 0;
}

.kk-section-header__link {
  font-family: var(--kk-font-body);
  font-size: 0.8rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--kk-silver);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.3s;
}

.kk-section-header__link:hover { color: var(--kk-hot-pink); }

/* ── Card Grid ────────────────────────────────────────────────────── */
.kk-card-grid {
  display: grid;
  width: 100%;
}

.kk-card-grid--cols-2 { grid-template-columns: repeat(2, 1fr); }
.kk-card-grid--cols-3 { grid-template-columns: repeat(3, 1fr); }
.kk-card-grid--cols-4 { grid-template-columns: repeat(4, 1fr); }

.kk-card-grid--gap-sm { gap: 1rem; }
.kk-card-grid--gap-md { gap: 1.5rem; }
.kk-card-grid--gap-lg { gap: 2rem; }

.kk-card-grid--align-stretch { align-items: stretch; }
.kk-card-grid--align-start   { align-items: start; }
.kk-card-grid--align-center  { align-items: center; }

/* ── Glass card base (shared by class, pricing, feature, info) ──── */
.kk-class-card,
.kk-pricing-card,
.kk-feature-card,
.kk-info-card,
.kk-instructor-card {
  background: rgba(12, 12, 24, 0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.04);
  border-radius: 16px;
  padding: 2rem;
  transition: all 0.5s var(--kk-ease-out-expo);
}

.kk-class-card:hover,
.kk-pricing-card:hover,
.kk-feature-card:hover {
  border-color: rgba(255, 20, 147, 0.2);
  transform: translateY(-4px);
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.4), 0 0 40px rgba(255, 20, 147, 0.06);
}

/* ── Class Card ───────────────────────────────────────────────────── */
.kk-class-card {
  position: relative;
  overflow: hidden;
  text-align: center;
}

.kk-class-card__accent {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 3px;
}

.kk-class-card--pink .kk-class-card__accent  { background: var(--kk-hot-pink); box-shadow: 0 0 15px rgba(255, 20, 147, 0.4); }
.kk-class-card--violet .kk-class-card__accent { background: var(--kk-electric-violet); box-shadow: 0 0 15px rgba(124, 58, 237, 0.4); }
.kk-class-card--cyan .kk-class-card__accent   { background: var(--kk-cyan); box-shadow: 0 0 15px rgba(0, 229, 255, 0.4); }
.kk-class-card--gold .kk-class-card__accent   { background: var(--kk-gold); box-shadow: 0 0 15px rgba(255, 214, 0, 0.4); }

.kk-class-card__time {
  font-family: var(--kk-font-display);
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--kk-white);
  margin: 1rem 0 0.5rem;
}

.kk-class-card__group {
  font-family: var(--kk-font-body);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  margin-bottom: 1rem;
}

.kk-class-card--pink .kk-class-card__group  { color: var(--kk-hot-pink); }
.kk-class-card--violet .kk-class-card__group { color: var(--kk-magenta); }
.kk-class-card--cyan .kk-class-card__group   { color: var(--kk-cyan); }

.kk-class-card__desc {
  color: var(--kk-silver);
  font-size: 0.9rem;
  line-height: 1.6;
  margin-bottom: 1.5rem;
}

.kk-class-card__instructor {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-bottom: 1.5rem;
}

.kk-class-card__instructor-label {
  font-size: 0.65rem;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--kk-muted);
}

.kk-class-card__instructor-name {
  font-family: var(--kk-font-display);
  font-size: 1.1rem;
  color: var(--kk-white);
}

/* ── Pricing Card ─────────────────────────────────────────────────── */
.kk-pricing-card {
  text-align: center;
  position: relative;
}

.kk-pricing-card--featured {
  border-color: rgba(255, 20, 147, 0.3);
  box-shadow: 0 0 40px rgba(255, 20, 147, 0.08);
  transform: scale(1.03);
}

.kk-pricing-card__badge {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--kk-gradient-hero);
  color: #fff;
  font-family: var(--kk-font-body);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  padding: 6px 20px;
  border-radius: 0 0 8px 8px;
}

.kk-pricing-card__title {
  font-family: var(--kk-font-display);
  font-size: 1.5rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--kk-white);
  margin: 1rem 0 1.5rem;
}

.kk-pricing-card__amount {
  font-family: var(--kk-font-display);
  font-size: clamp(2.5rem, 5vw, 3.5rem);
  font-weight: 700;
  background: var(--kk-gradient-chrome);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: brightness(1.2) contrast(1.1);
}

.kk-pricing-card__period {
  font-family: var(--kk-font-body);
  font-size: 0.85rem;
  color: var(--kk-muted);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}

.kk-pricing-card__features {
  color: var(--kk-silver);
  font-size: 0.9rem;
  line-height: 1.8;
  margin: 1.5rem 0;
  text-align: left;
}

.kk-pricing-card__features ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.kk-pricing-card__features li::before {
  content: '✦ ';
  color: var(--kk-hot-pink);
}

/* ── Instructor Card ──────────────────────────────────────────────── */
.kk-instructor-card--horizontal {
  display: flex;
  gap: 2.5rem;
  align-items: flex-start;
}

.kk-instructor-card__image-wrap {
  flex-shrink: 0;
}

.kk-instructor-card__image {
  width: 280px;
  height: auto;
  border-radius: 12px;
  object-fit: cover;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}

.kk-instructor-card--vertical .kk-instructor-card__image {
  width: 100%;
  max-width: 320px;
  margin: 0 auto 1.5rem;
  display: block;
}

.kk-instructor-card__name {
  font-family: var(--kk-font-display);
  font-size: 2rem;
  font-weight: 700;
  text-transform: uppercase;
  background: var(--kk-gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 0.25rem;
}

.kk-instructor-card__role {
  display: block;
  font-family: var(--kk-font-body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--kk-cyan);
  margin-bottom: 1.5rem;
}

.kk-instructor-card__bio {
  color: var(--kk-silver);
  font-size: 0.95rem;
  line-height: 1.7;
}

.kk-instructor-card__bio p { margin: 0 0 1rem; }

/* ── Feature Card ─────────────────────────────────────────────────── */
.kk-feature-card__icon {
  font-size: 2rem;
  margin-bottom: 1rem;
  line-height: 1;
}

.kk-feature-card__title {
  font-family: var(--kk-font-display);
  font-size: 1.2rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--kk-white);
  margin: 0 0 0.75rem;
}

.kk-feature-card__desc {
  color: var(--kk-silver);
  font-size: 0.9rem;
  line-height: 1.6;
}

.kk-feature-card__desc p { margin: 0; }

/* ── Stat Card ────────────────────────────────────────────────────── */
.kk-stat-card {
  text-align: center;
  padding: 2rem 1rem;
}

.kk-stat-card__number {
  font-family: var(--kk-font-display);
  font-size: clamp(3rem, 8vw, 5rem);
  font-weight: 700;
  line-height: 1;
  background: var(--kk-gradient-chrome);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  filter: brightness(1.2) contrast(1.1);
  margin-bottom: 0.5rem;
}

.kk-stat-card__label {
  font-family: var(--kk-font-body);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.kk-stat-card__label--pink   { color: var(--kk-hot-pink); }
.kk-stat-card__label--cyan   { color: var(--kk-cyan); }
.kk-stat-card__label--gold   { color: var(--kk-gold); }
.kk-stat-card__label--violet { color: var(--kk-electric-violet); }

/* ── CTA Banner ───────────────────────────────────────────────────── */
.kk-cta-banner {
  text-align: center;
  padding: 4rem 2rem;
  border-radius: 20px;
  position: relative;
  overflow: hidden;
}

.kk-cta-banner--gradient {
  background: linear-gradient(135deg, rgba(255, 20, 147, 0.12), rgba(124, 58, 237, 0.12));
  border: 1px solid rgba(255, 20, 147, 0.1);
}

.kk-cta-banner--surface { background: var(--kk-surface); }
.kk-cta-banner--void    { background: var(--kk-void); }

.kk-cta-banner__headline {
  font-family: var(--kk-font-display);
  font-size: clamp(2rem, 5vw, 3rem);
  font-weight: 700;
  text-transform: uppercase;
  background: var(--kk-gradient-hero);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin: 0 0 1rem;
}

.kk-cta-banner__subtext {
  font-family: var(--kk-font-body);
  color: var(--kk-silver);
  font-size: 1.05rem;
  line-height: 1.6;
  max-width: 600px;
  margin: 0 auto 2rem;
}

.kk-cta-banner__actions {
  display: flex;
  gap: 1rem;
  justify-content: center;
  flex-wrap: wrap;
}

/* ── Info Card ────────────────────────────────────────────────────── */
.kk-info-card__header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

.kk-info-card__icon {
  font-size: 1.5rem;
  line-height: 1;
}

.kk-info-card__title {
  font-family: var(--kk-font-display);
  font-size: 1.3rem;
  font-weight: 700;
  text-transform: uppercase;
  color: var(--kk-white);
  margin: 0;
  flex: 1;
}

.kk-info-card__body {
  color: var(--kk-silver);
  font-size: 0.95rem;
  line-height: 1.7;
  margin-top: 1.25rem;
}

.kk-info-card__body p { margin: 0 0 1rem; }

/* Collapsible variant */
.kk-info-card--collapsible .kk-info-card__header {
  cursor: pointer;
  user-select: none;
}

.kk-info-card__toggle {
  font-size: 1.5rem;
  color: var(--kk-muted);
  transition: transform 0.3s var(--kk-ease-out-expo);
  line-height: 1;
}

.kk-info-card--collapsible .kk-info-card__body {
  max-height: 0;
  overflow: hidden;
  margin-top: 0;
  transition: max-height 0.5s var(--kk-ease-out-expo), margin-top 0.3s;
}

.kk-info-card--collapsible.kk-info-card--open .kk-info-card__body {
  max-height: 2000px;
  margin-top: 1.25rem;
}

.kk-info-card--collapsible.kk-info-card--open .kk-info-card__toggle {
  transform: rotate(45deg);
}


/* ═══════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .kk-card-grid--cols-3 { grid-template-columns: repeat(2, 1fr); }
  .kk-card-grid--cols-4 { grid-template-columns: repeat(2, 1fr); }
  .kk-instructor-card--horizontal { flex-direction: column; }
  .kk-instructor-card__image { width: 100%; max-width: 320px; }
}

@media (max-width: 767px) {
  /* Mobile header is taller — increase body padding */
  body.elementor-default,
  body.elementor-page {
    padding-top: 80px !important;
  }
  .kk-hero { margin-top: -80px; }

  .elementor-top-section, .e-con.e-parent {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .elementor-button { padding: 14px 30px !important; }
  .kk-bokeh-dot { display: none; }
  .kk-hangul-float { font-size: 5rem !important; }
  .kk-has-spotlight::before,
  .kk-has-spotlight-alt::before { display: none; }

  .kk-card-grid--cols-2,
  .kk-card-grid--cols-3,
  .kk-card-grid--cols-4 { grid-template-columns: 1fr; }

  .kk-hero__headline { font-size: 3rem; }
  .kk-hero__content { padding: 3rem 1.5rem; }
  .kk-hero__actions { flex-direction: column; align-items: center; }
  .kk-section-header { flex-direction: column; align-items: center; text-align: center; }
  .kk-cta-banner { padding: 3rem 1.5rem; }
  .kk-pricing-card--featured { transform: none; }
  .kk-instructor-card--horizontal { flex-direction: column; }
  .kk-instructor-card__image { width: 100%; max-width: 280px; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   MOBILE NAV DROPDOWN — dark translucent backdrop
   ═══════════════════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  /* Elementor Nav Menu dropdown wrapper */
  .elementor-location-header .e-n-menu-wrapper {
    background: rgba(10, 10, 20, 0.92) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 20, 147, 0.15) !important;
    border-radius: 12px !important;
    padding: 1.5rem 1rem !important;
    margin-top: 0.5rem !important;
    box-shadow: 0 20px 60px rgba(0, 0, 0, 0.6),
                0 0 30px rgba(255, 20, 147, 0.08) !important;
  }

  /* Menu items inside dropdown — ensure legibility */
  .elementor-location-header .e-n-menu-wrapper a {
    color: var(--kk-white, #ffffff) !important;
    padding: 0.6rem 1rem !important;
    font-size: 1rem !important;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.5) !important;
  }

  .elementor-location-header .e-n-menu-wrapper a:hover {
    color: var(--kk-hot-pink, #ff1493) !important;
    text-shadow: 0 0 20px rgba(255, 20, 147, 0.6) !important;
  }
}
