/* ===========================================
   KIMCOACH THEME — Custom Styles
   CSS matches original index.html design.
   Every margin, padding, and proportion is
   mapped from the original to WP's HTML.
   =========================================== */

/* ----------------------------------------
   KEYFRAME ANIMATIONS
   ---------------------------------------- */
@keyframes float-1 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(30px, -40px) scale(1.05); }
  66% { transform: translate(-20px, 20px) scale(0.95); }
}
@keyframes float-2 {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(-25px, 30px) scale(1.08); }
  66% { transform: translate(35px, -15px) scale(0.92); }
}
@keyframes float-3 {
  0%, 100% { transform: translate(0, 0) rotate(0deg); }
  50% { transform: translate(20px, -30px) rotate(5deg); }
}
@keyframes hero-reveal {
  to { opacity: 1; transform: translateY(0); }
}
@keyframes hero-portrait-reveal {
  to { opacity: 1; transform: translateY(0) scale(1); }
}
@keyframes bounce-arrow {
  0%, 100% { transform: rotate(45deg) translate(0, 0); opacity: 1; }
  50% { transform: rotate(45deg) translate(4px, 4px); opacity: 0.5; }
}
@keyframes glow-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(91, 124, 90, 0); }
  50% { box-shadow: 0 0 20px 4px rgba(91, 124, 90, 0.15); }
}

/* ============================================
   WP NUCLEAR RESET
   Remove ALL automatic spacing/padding that
   WordPress injects. We control everything.
   ============================================ */

/* Remove body root padding (theme.json also set to 0) */
body {
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  padding: 0 !important;
}

/* Remove WP block gap between ALL elements at every nesting level */
.wp-site-blocks > * + * {
  margin-block-start: 0 !important;
}
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact, .site-header, .site-footer) * {
  margin-block-start: 0;
  margin-block-end: 0;
}

/* Override WP constrained max-width on absolutely positioned overlays.
   WP's .is-layout-constrained > :where(:not(.alignfull)) sets
   max-width: 1200px; margin-left: auto !important; margin-right: auto !important;
   This kills our absolutely positioned elements like .kc-floating-circles
   and .kc-scroll-indicator. Force them back to full-width. */
.kc-floating-circles,
.kc-scroll-indicator,
.section-circles {
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
}

/* Remove WP flex/grid gap everywhere inside our elements */
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact, .site-header, .site-footer) :where(.is-layout-flex, .is-layout-grid) {
  gap: 0;
}
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact, .site-header, .site-footer) :where(.is-layout-constrained, .is-layout-flow) > * {
  margin-block: 0;
}

/* Let .alignfull sections break out of constrained post-content */
.is-layout-constrained > .alignfull {
  max-width: none !important;
  margin-left: calc(-50vw + 50%) !important;
  margin-right: calc(-50vw + 50%) !important;
  width: 100vw !important;
}

/* Remove WP default padding on groups with backgrounds */
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact) :where(.wp-block-group.has-background) {
  padding: 0;
}

/* Remove has-global-padding effects (root padding is 0 anyway) */
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact, .site-header, .site-footer).has-global-padding {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Force flex on button containers — PHP template-parts don't add WP's is-layout-flex class */
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact) .wp-block-buttons {
  display: flex;
  flex-wrap: wrap;
}


/* ============================================
   CONTENT MAX-WIDTH
   Constrain all section content to 1200px so text
   lines stay readable on ultrawide screens.
   Floating circles are excluded (they go edge-to-edge).
   ============================================ */
:is(.kc-hero, .kc-about, .kc-act, .kc-courses, .kc-coaching, .kc-news, .kc-tiktok, .kc-contact) > :not(.kc-floating-circles, .section-circles, .kc-scroll-indicator) {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

/* ============================================
   SECTION SPACING
   Original: .section-padding { padding: 8rem 0; }
   + .container { max-width: 1200px; padding: 0 1.5rem; margin: auto; }
   WP: section = full-width, is-layout-constrained = content max-width.
   We add side padding on sections to replace .container padding.
   ============================================ */
.kc-about,
.kc-act,
.kc-courses,
.kc-coaching,
.kc-news,
.kc-tiktok,
.kc-contact {
  padding: 8rem 1.5rem !important;
}

/* Hero: NO side padding on section (circles go edge-to-edge).
   Side padding goes on the content columns instead. */
.kc-hero {
  padding: calc(8rem + 60px) 0 8rem !important;
}

.site-header {
  padding: 1rem 1.5rem !important;
}

.site-footer {
  padding: 2.5rem 1.5rem !important;
}
/* Restore footer flex gaps (killed by nuclear reset) */
.site-footer > .is-layout-flex {
  flex-wrap: wrap;
  gap: 1rem;
}
.site-footer .is-nowrap.is-layout-flex {
  gap: 1.5rem;
}

/* ============================================
   SCROLL REVEAL
   ============================================ */
.kc-reveal {
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              transform 0.7s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.kc-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.kc-stagger .kc-reveal {
  transition-delay: calc(var(--i, 0) * 80ms);
}

/* ============================================
   FLOATING CIRCLES (injected via JS)
   ============================================ */
.kc-floating-circles {
  position: absolute;
  inset: 0;
  pointer-events: none;
  overflow: hidden;
  z-index: 0;
}
.kc-floating-circle {
  position: absolute;
  border-radius: 50%;
}

/* Hero circles — opacity 0.12 */
.kc-hero .kc-floating-circle:nth-child(1) {
  width: 400px; height: 400px;
  top: -80px; right: -100px;
  background: var(--wp--preset--color--primary);
  opacity: 0.12;
  animation: float-1 22s ease-in-out infinite;
}
.kc-hero .kc-floating-circle:nth-child(2) {
  width: 250px; height: 250px;
  bottom: 10%; left: -60px;
  background: var(--wp--preset--color--accent);
  opacity: 0.12;
  animation: float-2 25s ease-in-out infinite;
}
.kc-hero .kc-floating-circle:nth-child(3) {
  width: 150px; height: 150px;
  top: 30%; right: 15%;
  background: var(--wp--preset--color--highlight);
  opacity: 0.12;
  animation: float-3 20s ease-in-out infinite;
}
.kc-hero .kc-floating-circle:nth-child(4) {
  width: 80px; height: 80px;
  bottom: 25%; right: 35%;
  background: var(--wp--preset--color--primary-light);
  opacity: 0.12;
  animation: float-1 18s ease-in-out infinite reverse;
}
.kc-hero .kc-floating-circle:nth-child(5) {
  width: 180px; height: 180px;
  top: 60%; left: 10%;
  background: var(--wp--preset--color--accent-light);
  opacity: 0.12;
  animation: float-2 23s ease-in-out infinite reverse;
}
.kc-hero .kc-floating-circle:nth-child(6) {
  width: 60px; height: 60px;
  top: 15%; left: 30%;
  background: var(--wp--preset--color--highlight);
  opacity: 0.12;
  animation: float-3 16s ease-in-out infinite;
}

/* ACT section circles */
.kc-act .kc-floating-circle:nth-child(1) {
  width: 200px; height: 200px;
  top: -60px; right: -40px;
  background: var(--wp--preset--color--primary);
  opacity: 0.05;
  animation: float-2 24s ease-in-out infinite;
}
.kc-act .kc-floating-circle:nth-child(2) {
  width: 120px; height: 120px;
  bottom: 5%; left: -30px;
  background: var(--wp--preset--color--accent);
  opacity: 0.06;
  animation: float-3 20s ease-in-out infinite;
}
.kc-act .kc-floating-circle:nth-child(3) {
  width: 70px; height: 70px;
  top: 40%; left: 8%;
  background: var(--wp--preset--color--highlight);
  opacity: 0.08;
  animation: float-1 18s ease-in-out infinite reverse;
}

/* Courses section circles */
.kc-courses .kc-floating-circle:nth-child(1) {
  width: 160px; height: 160px;
  top: -40px; left: -50px;
  background: var(--wp--preset--color--highlight);
  opacity: 0.06;
  animation: float-1 22s ease-in-out infinite;
}
.kc-courses .kc-floating-circle:nth-child(2) {
  width: 100px; height: 100px;
  bottom: 10%; right: -20px;
  background: var(--wp--preset--color--primary);
  opacity: 0.05;
  animation: float-3 19s ease-in-out infinite;
}

/* Coaching section circles */
/* Coaching circles hidden — too visible with constrained content width */
.kc-coaching .kc-floating-circles {
  display: none;
}

/* Contact section circles */
.kc-contact .kc-floating-circle:nth-child(1) {
  width: 180px; height: 180px;
  top: -50px; right: 10%;
  background: var(--wp--preset--color--primary);
  opacity: 0.04;
  animation: float-3 23s ease-in-out infinite;
}
.kc-contact .kc-floating-circle:nth-child(2) {
  width: 100px; height: 100px;
  bottom: 5%; left: -30px;
  background: var(--wp--preset--color--accent);
  opacity: 0.05;
  animation: float-1 20s ease-in-out infinite reverse;
}

/* Site title leaf icon */
.site-header__logo a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-decoration: none;
}
.site-header__logo a::before {
  content: '';
  display: inline-block;
  width: 1.4rem;
  height: 1.4rem;
  background: url('../img/favicon.svg') no-repeat center / contain;
  flex-shrink: 0;
}

/* ============================================
   HEADER / NAVIGATION
   Original: .nav { position: fixed; top: 0; left: 0; right: 0; }
   ============================================ */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  transition: background-color 0.4s ease, padding 0.4s ease, box-shadow 0.4s ease;
}
/* Restore flex layout killed by nuclear reset */
.site-header > .wp-block-group {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2rem;
}
.site-header.is-scrolled {
  background-color: rgba(250, 246, 241, 0.95) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 20px rgba(44, 41, 38, 0.06);
  padding-top: 0.6rem !important;
  padding-bottom: 0.6rem !important;
}

/* Navigation CTA link — .nav__cta */
.nav-cta .wp-block-navigation-item__content {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 1.4rem;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--text-light) !important;
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: 100px;
  transition: background-color 0.3s ease, transform 0.3s ease;
}
.nav-cta .wp-block-navigation-item__content:hover {
  background: var(--wp--preset--color--primary-dark);
  transform: translateY(-1px);
}

/* Nav link hover underline — .nav__link::after */
.site-header .wp-block-navigation-item:not(.nav-cta):not(.nav-login) .wp-block-navigation-item__content {
  position: relative;
  color: var(--wp--preset--color--text-muted);
  transition: color 0.3s ease;
}
.site-header .wp-block-navigation-item:not(.nav-cta):not(.nav-login) .wp-block-navigation-item__content::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--wp--preset--color--primary);
  transition: width 0.3s ease;
}
.site-header .wp-block-navigation-item:not(.nav-cta):not(.nav-login) .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--text);
}
.site-header .wp-block-navigation-item:not(.nav-cta):not(.nav-login) .wp-block-navigation-item__content:hover::after {
  width: 100%;
}

/* Nav links gap — original: gap: 2.5rem */
.site-header .wp-block-navigation__container {
  gap: 2.5rem;
}

/* ============================================
   HERO
   Original: .hero { min-height: 100svh; display: flex; align-items: center; justify-content: center; }
   .hero__inner { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; }
   ============================================ */
.kc-hero {
  min-height: 100svh;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(ellipse 80% 60% at 20% 80%, rgba(91, 124, 90, 0.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 80% 20%, rgba(193, 125, 74, 0.06) 0%, transparent 50%),
    var(--wp--preset--color--bg) !important;
}

/* Hero columns — .hero__inner */
.kc-hero > .wp-block-columns {
  display: grid !important;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 1.5rem;
  position: relative;
  z-index: 1;
  align-items: center;
}
/* Override WP flex on hero columns */
.kc-hero > .wp-block-columns > .wp-block-column {
  flex-basis: auto !important;
  width: auto !important;
}

/* Hero element spacing — matches original */
.kc-hero .kc-section-label {
  margin-bottom: 1.5rem;
}
.kc-hero__title {
  margin-bottom: 1.5rem;
}
.kc-hero__title em {
  font-style: italic;
  color: var(--wp--preset--color--primary);
}
.kc-hero .has-text-muted-color {
  max-width: 560px;
  margin-bottom: 2.5rem;
}
/* Buttons row — gap from original .hero__actions */
.kc-hero .wp-block-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

/* Outline button — matches original .btn--outline */
.is-style-outline .wp-block-button__link {
  background: transparent !important;
  border: 2px solid var(--wp--preset--color--border) !important;
  color: var(--wp--preset--color--text) !important;
}
.is-style-outline .wp-block-button__link:hover {
  border-color: var(--wp--preset--color--primary) !important;
  color: var(--wp--preset--color--primary) !important;
  transform: translateY(-2px);
}

/* Primary button hover enhancement — translateY + shadow */
.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(91, 124, 90, 0.25);
}

/* Hero portrait image — .hero__portrait-img */
.kc-hero__portrait img {
  max-height: 480px;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center 20%;
  border-radius: 20px;
  box-shadow: 0 25px 60px rgba(44, 41, 38, 0.12);
  margin: 0 auto;
}

/* Hero load animations */
.kc-hero .kc-section-label {
  opacity: 0;
  transform: translateY(20px);
  animation: hero-reveal 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.3s forwards;
}
.kc-hero .kc-hero__title {
  opacity: 0;
  transform: translateY(25px);
  animation: hero-reveal 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.5s forwards;
}
.kc-hero .has-text-muted-color {
  opacity: 0;
  transform: translateY(25px);
  animation: hero-reveal 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.7s forwards;
}
.kc-hero .wp-block-buttons {
  opacity: 0;
  transform: translateY(25px);
  animation: hero-reveal 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.9s forwards;
}
.kc-hero__portrait {
  opacity: 0;
  transform: translateY(30px) scale(0.97);
  animation: hero-portrait-reveal 1s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.6s forwards;
}

/* Scroll indicator (injected via JS) */
.kc-scroll-indicator {
  position: absolute;
  bottom: 2.5rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  color: var(--wp--preset--color--text-muted);
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  opacity: 0;
  animation: hero-reveal 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94) 1.3s forwards;
  z-index: 2;
}
.kc-scroll-indicator__arrow {
  width: 20px;
  height: 20px;
  border-right: 2px solid var(--wp--preset--color--text-muted);
  border-bottom: 2px solid var(--wp--preset--color--text-muted);
  transform: rotate(45deg);
  animation: bounce-arrow 2s ease-in-out infinite;
}

/* Section label — reused across sections */
.kc-section-label {
  font-family: var(--wp--preset--font-family--body);
}

/* ============================================
   OM KIM (About)
   Original: .about__grid { display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; }
   ============================================ */
.kc-about {
  position: relative;
  overflow: hidden;
}

/* About columns — .about__grid */
.kc-about > .wp-block-columns {
  display: grid !important;
  grid-template-columns: 1fr 1.2fr;
  gap: 4rem;
  align-items: start;
}
.kc-about > .wp-block-columns > .wp-block-column {
  flex-basis: auto !important;
  width: auto !important;
}
/* Original: .about__text { padding-top: var(--space-sm); } */
.kc-about > .wp-block-columns > .wp-block-column:last-child {
  padding-top: 1rem;
}

/* About image — .about__image-wrapper */
.kc-about__image {
  position: relative;
  overflow: hidden;
  border-radius: 20px;
  background: linear-gradient(135deg, var(--wp--preset--color--primary-light), var(--wp--preset--color--primary-dark));
}
.kc-about__image img {
  width: 100%;
  height: auto;
  max-height: 560px;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  object-position: center top;
}
.kc-about__image::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 35%;
  background: linear-gradient(to top, rgba(61, 90, 60, 0.3), transparent);
  pointer-events: none;
}

/* About text spacing — matches original .about__text rules */
.kc-about .kc-section-label {
  margin-bottom: 1rem;
}
.kc-about h2 {
  margin-bottom: 2.5rem;
}
.kc-about p.has-text-muted-color {
  margin-bottom: 1.5rem;
  color: var(--wp--preset--color--text-muted);
}

/* Esport highlight — .about__esport */
.kc-about__esport {
  border-left: 3px solid var(--wp--preset--color--highlight) !important;
  padding-left: 1.5rem;
  margin: 2.5rem 0;
}
.kc-about__esport p {
  font-weight: 500;
  color: var(--wp--preset--color--text) !important;
}

/* Credential badges — .about__badges */
.kc-badges {
  display: flex;
  flex-wrap: wrap;
  margin-top: 2.5rem;
  gap: 0.6rem;
}
.kc-badges .kc-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 1rem;
  background: rgba(91, 124, 90, 0.08);
  color: var(--wp--preset--color--primary-dark);
  border-radius: 100px;
  border: 1px solid rgba(91, 124, 90, 0.15);
}

/* ============================================
   SECTION INTRO (shared by ACT, Courses, Coaching)
   Original: text-align: center; max-width: 640px; margin: 0 auto var(--space-xl);
   ============================================ */
.kc-section-intro {
  text-align: center;
  max-width: 640px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 4rem;
}
.kc-section-intro .kc-section-label {
  margin-bottom: 1rem;
}
.kc-section-intro h2 {
  margin-bottom: 1.5rem;
}

/* ============================================
   ACT SECTION
   Original: .act { background: bg-alt; }
   .act__pillars { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
   ============================================ */
.kc-act {
  position: relative;
  overflow: hidden;
}

/* Pillar columns — .act__pillars */
.kc-pillars {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
  margin-bottom: 4rem;
}
.kc-pillars > .kc-pillar {
  flex-basis: auto !important;
  width: auto !important;
}

/* Pillar card — .pillar */
.kc-pillar__inner {
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  border: 1px solid rgba(0, 0, 0, 0.04);
  padding: 2.5rem;
  height: 100%;
}
.kc-pillar__inner:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(44, 41, 38, 0.08);
}

/* Pillar icons */
.kc-pillar__icon--green,
.kc-pillar__icon--accent,
.kc-pillar__icon--highlight {
  width: 52px;
  height: 52px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
}
.kc-pillar__icon--green {
  background: rgba(91, 124, 90, 0.1);
  color: var(--wp--preset--color--primary);
}
.kc-pillar__icon--accent {
  background: rgba(193, 125, 74, 0.1);
  color: var(--wp--preset--color--accent);
}
.kc-pillar__icon--highlight {
  background: rgba(232, 201, 122, 0.15);
  color: var(--wp--preset--color--accent);
}

/* Pillar text spacing */
.kc-pillar__inner h3 {
  margin-bottom: 0.5rem;
}
.kc-pillar__inner p.has-text-muted-color {
  font-size: 0.92rem;
}

/* ACT quote — .act__quote */
.kc-act__quote {
  border: none;
  padding: 2.5rem;
  text-align: center;
  max-width: 600px;
  margin: 0 auto;
}
.kc-act__quote p {
  line-height: 1.4;
}

/* Evidence badge — .act__evidence */
.kc-evidence {
  background: rgba(91, 124, 90, 0.05);
  display: inline-block;
  margin-top: 1.5rem;
}
/* Center the evidence text wrapper */
.kc-act > .wp-block-group:last-child {
  text-align: center;
  margin-top: 4rem;
}

/* ============================================
   VIDEOKURSER (Courses)
   Original: .courses__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
   ============================================ */
.kc-courses {
  position: relative;
  overflow: hidden;
}

/* Course cards grid — .courses__grid */
.kc-course-cards {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 1.5rem;
  margin-bottom: 4rem;
  max-width: 960px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}
.kc-course-cards > .kc-course-card {
  flex-basis: auto !important;
  width: auto !important;
  min-width: 0;
}

/* Course card — .course-card */
.kc-course-card__inner {
  height: 100%;
  border: 1px solid var(--wp--preset--color--border);
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.kc-course-card__inner .wp-block-cover {
  position: relative;
  aspect-ratio: 16 / 12 !important;
  min-height: 0 !important;
  overflow: hidden;
}
.kc-course-card__inner .wp-block-cover img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.kc-course-card__inner .wp-block-cover__background {
  position: absolute;
  inset: 0;
}
.kc-course-card__inner .wp-block-cover__inner-container {
  position: relative;
  z-index: 1;
  padding: 0.75rem;
}
.kc-course-card__inner:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(44, 41, 38, 0.08);
}

/* Featured card border */
.kc-course-card--featured .kc-course-card__inner {
  border-color: var(--wp--preset--color--primary);
  box-shadow: 0 0 0 1px var(--wp--preset--color--primary);
}

/* Course card body — .course-card__body */
.kc-course-card__inner > .wp-block-group:last-child {
  padding: 1.5rem;
}
.kc-course-card__inner > .wp-block-group:last-child h3 {
  margin-bottom: 0.5rem;
}
.kc-course-card__inner > .wp-block-group:last-child p {
  font-size: 0.9rem;
  color: var(--wp--preset--color--text-muted);
}

/* Course card cover hover zoom */
.kc-course-card__inner .wp-block-cover img {
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.kc-course-card__inner:hover .wp-block-cover img {
  transform: scale(1.05);
}

/* Pill badges */
.kc-pill {
  display: inline-block;
  padding: 0.3rem 0.8rem;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-radius: 100px;
  color: var(--wp--preset--color--text-light);
}
.kc-pill--primary {
  background: var(--wp--preset--color--primary);
}
.kc-pill--accent {
  background: var(--wp--preset--color--accent);
}

/* Course price pill — show struck-through regular price */
.kc-course-price {
  display: inline-flex;
  align-items: baseline;
  gap: 0.4em;
}
.kc-course-price del {
  opacity: 0.7;
  font-weight: 500;
  text-decoration: line-through;
}

/* Newsletter CTA — .courses__newsletter */
.kc-newsletter {
  padding: 2.5rem;
  margin-top: 4rem;
}
.kc-newsletter h3 {
  margin-bottom: 0.5rem;
}
.kc-newsletter p {
  color: var(--wp--preset--color--text-muted);
  margin-bottom: 1.5rem;
  font-size: 0.95rem;
}

/* Newsletter form */
.kc-newsletter-form {
  display: flex;
  gap: 0.6rem;
  max-width: 440px;
  margin: 0 auto;
}
.kc-newsletter-form input {
  flex: 1;
  padding: 0.75rem 1.2rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 100px;
  background: var(--wp--preset--color--bg);
  font-family: inherit;
  font-size: inherit;
  transition: border-color 0.3s ease;
}
.kc-newsletter-form input:focus {
  outline: none;
  border-color: var(--wp--preset--color--primary);
}
.kc-newsletter-form button {
  padding: 0.75rem 1.6rem;
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--text-light);
  font-family: inherit;
  font-weight: 600;
  font-size: 0.9rem;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}
.kc-newsletter-form button:hover {
  background: var(--wp--preset--color--primary-dark);
}

/* ============================================
   COACHING (dark section)
   Original: .coaching { background: bg-dark; color: text-light; }
   .timeline { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
   ============================================ */
.kc-coaching {
  position: relative;
  overflow: hidden;
}

/* Timeline grid — .timeline */
.kc-timeline {
  position: relative;
  margin-bottom: 4rem;
}
.kc-timeline > .wp-block-columns,
.kc-timeline.wp-block-columns {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr);
  gap: 1.5rem;
}
.kc-timeline .wp-block-column {
  flex-basis: auto !important;
  width: auto !important;
  text-align: center;
}
.kc-timeline::before {
  content: '';
  position: absolute;
  top: 28px;
  left: 10%;
  right: 10%;
  height: 2px;
  background: rgba(250, 246, 241, 0.1);
  z-index: 0;
}

/* Timeline step numbers — .timeline__number */
.kc-timeline__number {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: #3d4a3c;
  border: 2px solid var(--wp--preset--color--primary);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1rem;
  color: var(--wp--preset--color--primary-light);
  position: relative;
  z-index: 1;
  animation: glow-pulse 3s ease-in-out infinite;
}
.kc-timeline .wp-block-column:nth-child(2) .kc-timeline__number { animation-delay: 0.4s; }
.kc-timeline .wp-block-column:nth-child(3) .kc-timeline__number { animation-delay: 0.8s; }
.kc-timeline .wp-block-column:nth-child(4) .kc-timeline__number { animation-delay: 1.2s; }

/* Timeline step text */
.kc-timeline .wp-block-column h3 {
  margin-bottom: 0.3rem;
}

/* Coaching info — .coaching__info */
.kc-coaching__info {
  margin-bottom: 4rem;
}

/* Callout glassfrost — .coaching__callout */
.kc-callout {
  max-width: 600px;
  margin-left: auto;
  margin-right: auto;
  background: rgba(250, 246, 241, 0.04) !important;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border: 1px solid rgba(250, 246, 241, 0.08);
  border-left: 3px solid var(--wp--preset--color--accent) !important;
  padding: 2.5rem;
}
.kc-callout h3 {
  margin-bottom: 0.5rem;
}

/* ============================================
   CONTACT FORM
   Original: .contact__grid { display: grid; grid-template-columns: 1fr 1.3fr; gap: 4rem; }
   ============================================ */
.kc-contact {
  position: relative;
  overflow: hidden;
}

/* Contact columns — .contact__grid */
.kc-contact > .wp-block-columns {
  display: grid !important;
  grid-template-columns: 1fr 1.3fr;
  gap: 4rem;
  align-items: start;
}
.kc-contact > .wp-block-columns > .wp-block-column {
  flex-basis: auto !important;
  width: auto !important;
}

/* Contact info text spacing */
.kc-contact .kc-section-label {
  margin-bottom: 1rem;
}
.kc-contact h2 {
  margin-bottom: 1.5rem;
}
.kc-contact p.has-text-muted-color {
  margin-bottom: 1.5rem;
}

/* Contact details — .contact__detail */
.kc-contact-detail {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 1rem;
}

/* Crisis notice — .contact__crisis */
.kc-crisis-notice {
  background: rgba(193, 125, 74, 0.06);
  padding: 1rem 1.5rem;
  margin-top: 2.5rem;
  border-left: 3px solid var(--wp--preset--color--accent);
  border-radius: 0 6px 6px 0;
}

/* Form styling */
.kc-contact-form {
  display: flex;
  flex-direction: column;
  gap: 0;
}
.kc-form-group {
  margin-bottom: 1.5rem;
}
.kc-form-group label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  margin-bottom: 0.4rem;
  color: var(--wp--preset--color--text);
}
.kc-form-group input,
.kc-form-group select,
.kc-form-group textarea {
  width: 100%;
  padding: 0.8rem 1rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: var(--wp--custom--radius--sm);
  background: var(--wp--preset--color--bg);
  font-family: inherit;
  font-size: inherit;
  transition: border-color 0.3s ease, box-shadow 0.3s ease;
}
.kc-form-group input:focus,
.kc-form-group select:focus,
.kc-form-group textarea:focus {
  outline: none;
  border-color: var(--wp--preset--color--primary);
  box-shadow: 0 0 0 3px rgba(91, 124, 90, 0.1);
}
.kc-form-group textarea {
  min-height: 120px;
  resize: vertical;
}
.kc-form-group select {
  cursor: pointer;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B645C' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  padding-right: 2.5rem;
}

/* Form buttons */
.kc-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.9rem 2rem;
  font-family: inherit;
  font-size: 0.95rem;
  font-weight: 600;
  border: none;
  border-radius: 100px;
  cursor: pointer;
  transition: all 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.kc-btn--primary {
  background: var(--wp--preset--color--primary);
  color: var(--wp--preset--color--text-light);
}
.kc-btn--primary:hover {
  background: var(--wp--preset--color--primary-dark);
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(91, 124, 90, 0.25);
}
.kc-btn--full {
  width: 100%;
}

/* Honeypot — hidden from humans */
.kc-hp {
  position: absolute;
  left: -9999px;
  height: 0;
  overflow: hidden;
}

/* Form note */
.kc-form-note {
  font-size: 0.8rem;
  color: var(--wp--preset--color--text-muted);
  margin-top: 1rem;
  text-align: center;
}

/* Form success state */
.kc-form-success {
  display: none;
  text-align: center;
  padding: 4rem 1.5rem;
}
.kc-form-success.is-visible {
  display: block;
}

/* ============================================
   REDUCED MOTION
   ============================================ */
@media (prefers-reduced-motion: reduce) {
  .kc-reveal {
    opacity: 1;
    transform: none;
    transition: none;
  }
  .kc-floating-circle {
    animation: none !important;
  }
  .kc-scroll-indicator {
    animation: none !important;
    opacity: 1;
  }
  .kc-hero .kc-section-label,
  .kc-hero .kc-hero__title,
  .kc-hero .has-text-muted-color,
  .kc-hero .wp-block-buttons,
  .kc-hero__portrait {
    opacity: 1;
    transform: none;
    animation: none !important;
  }
  .kc-timeline__number {
    animation: none !important;
  }
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media (max-width: 900px) {
  .kc-hero {
    min-height: auto;
    padding-top: calc(8rem + 80px) !important;
  }
  .kc-hero > .wp-block-columns {
    grid-template-columns: 1fr;
    text-align: center;
  }
  .kc-hero > .wp-block-columns > .wp-block-column:first-child {
    order: 2;
  }
  .kc-hero > .wp-block-columns > .wp-block-column:last-child {
    order: 1;
  }
  .kc-hero__portrait {
    max-width: 340px;
    margin: 0 auto;
  }
  .kc-hero .has-text-muted-color {
    margin-left: auto;
    margin-right: auto;
  }
  .kc-hero .wp-block-buttons {
    justify-content: center;
  }

  /* About: stack columns */
  .kc-about > .wp-block-columns {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
  .kc-about__image {
    max-width: 400px;
    margin: 0 auto;
  }

  /* Contact: stack columns */
  .kc-contact > .wp-block-columns {
    grid-template-columns: 1fr;
    gap: 2.5rem;
  }
}

@media (max-width: 782px) {
  .kc-timeline::before {
    display: none;
  }
  .kc-newsletter-form {
    flex-direction: column;
  }

  /* Reduce section padding */
  .kc-about,
  .kc-act,
  .kc-courses,
  .kc-coaching,
  .kc-news,
  .kc-tiktok,
  .kc-contact {
    padding: 5rem 1.5rem !important;
  }
}

@media (max-width: 700px) {
  /* Pillar cards: stack */
  .kc-pillars {
    grid-template-columns: 1fr !important;
  }

  /* Course cards: stack */
  .kc-course-cards {
    grid-template-columns: 1fr !important;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }

  /* News grid: 2 columns */
  .kc-news-grid {
    grid-template-columns: 1fr 1fr;
  }

  /* Timeline: 2 columns then 1 */
  .kc-timeline > .wp-block-columns,
  .kc-timeline.wp-block-columns {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 600px) {
  .site-footer .wp-block-group {
    flex-direction: column;
    text-align: center;
  }

  .kc-about,
  .kc-act,
  .kc-courses,
  .kc-coaching,
  .kc-news,
  .kc-tiktok,
  .kc-contact {
    padding: 3.5rem 1rem !important;
  }
  .site-header {
    padding: 0.8rem 1rem !important;
  }
  .kc-hero > .wp-block-columns {
    padding: 0 1rem;
  }
}

@media (max-width: 480px) {
  .kc-timeline > .wp-block-columns,
  .kc-timeline.wp-block-columns {
    grid-template-columns: 1fr !important;
  }

  /* News grid: 1 column */
  .kc-news-grid {
    grid-template-columns: 1fr;
    max-width: 400px;
    margin-left: auto;
    margin-right: auto;
  }

}

/* ============================================
   TESTIMONIALS
   ============================================ */
.kc-testimonials {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 2rem;
  max-width: 1200px;
  margin: 2rem auto;
}

.kc-testimonial {
  background: var(--wp--preset--color--bg-alt);
  border-radius: 12px;
  padding: 2.5rem 2rem 2rem;
  margin: 0;
  border: none;
  position: relative;
}
.kc-testimonial::before {
  content: '\201C';
  font-family: var(--wp--preset--font-family--heading);
  font-size: 5rem;
  line-height: 1;
  color: var(--wp--preset--color--primary);
  opacity: 0.2;
  position: absolute;
  top: 0.3rem;
  left: 1.2rem;
}

.kc-testimonial__quote {
  font-style: italic;
  font-size: 0.95rem;
  line-height: 1.7;
  color: var(--wp--preset--color--text);
}
.kc-testimonial__quote p {
  margin: 0;
}

.kc-testimonial__name {
  display: block;
  margin-top: 1rem;
  font-style: normal;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--wp--preset--color--primary-dark);
}

/* ----------------------------------------
   BLOG STYLES
   ---------------------------------------- */

/* Blog listing cards */
.wp-block-post-template .wp-block-group.has-bg-background-color {
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
  box-shadow: 0 1px 3px rgba(44, 41, 38, 0.06);
}
.wp-block-post-template .wp-block-group.has-bg-background-color:hover {
  transform: translateY(-3px);
  box-shadow: 0 8px 25px rgba(44, 41, 38, 0.08);
}

/* Blog post title links */
.wp-block-post-title a {
  text-decoration: none !important;
  color: var(--wp--preset--color--text) !important;
  transition: color 0.2s ease;
}
.wp-block-post-title a:hover {
  color: var(--wp--preset--color--primary) !important;
}

/* Post date styling */
.wp-block-post-date {
  font-family: var(--wp--preset--font-family--body);
}

/* Post excerpt "Läs mer" link */
.wp-block-post-excerpt__more-link {
  color: var(--wp--preset--color--primary) !important;
  text-decoration: none !important;
  font-weight: 500;
  transition: color 0.2s ease;
}
.wp-block-post-excerpt__more-link:hover {
  color: var(--wp--preset--color--primary-dark) !important;
}

/* Single post CTA box */
.wp-block-post-content + .wp-block-group.has-bg-alt-background-color {
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

/* Post terms (categories) */
.wp-block-post-terms a {
  text-decoration: none !important;
  font-weight: 500;
}
.wp-block-post-terms a:hover {
  text-decoration: underline !important;
}

/* Separator in blog posts */
.wp-block-post-content .wp-block-separator {
  border-color: var(--wp--preset--color--border) !important;
  opacity: 0.5;
}

/* ============================================
   NEWS SECTION (front page)
   ============================================ */
.kc-news .kc-section-intro {
  max-width: 640px;
  margin: 0 auto 2rem;
}
.kc-news .kc-section-label {
  margin-bottom: 1rem;
}

.kc-news-description {
  max-width: 700px;
  margin: 0 auto 4rem;
  color: var(--wp--preset--color--text-muted);
  font-size: 0.95rem;
  line-height: 1.7;
  text-align: center;
}
.kc-news-description p {
  margin: 0;
}

.kc-news-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  max-width: 1200px;
  margin: 0 auto;
}

.kc-news-card {
  display: flex;
  flex-direction: column;
  background: var(--wp--preset--color--bg);
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 12px;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: transform 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94),
              box-shadow 0.3s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.kc-news-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 30px rgba(44, 41, 38, 0.1);
}

.kc-news-card__image {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: linear-gradient(135deg, var(--wp--preset--color--primary-light), var(--wp--preset--color--primary-dark));
}
.kc-news-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}
.kc-news-card:hover .kc-news-card__image img {
  transform: scale(1.05);
}

.kc-news-card__body {
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.kc-news-card__date {
  font-size: 0.78rem;
  font-weight: 500;
  color: var(--wp--preset--color--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.kc-news-card__title {
  font-family: var(--wp--preset--font-family--heading);
  font-size: 1.15rem;
  color: var(--wp--preset--color--text);
  line-height: 1.3;
}

.kc-news-card__excerpt {
  font-size: 0.9rem;
  color: var(--wp--preset--color--text-muted);
  line-height: 1.6;
}

.kc-news-cta {
  text-align: center;
  margin-top: 3rem;
}

/* ============================================
   TIKTOK SECTION (front page)
   ============================================ */
.kc-tiktok {
  position: relative;
  overflow: hidden;
}

.kc-tiktok .kc-section-intro {
  max-width: 640px;
  margin: 0 auto 4rem;
}
.kc-tiktok .kc-section-label {
  margin-bottom: 1rem;
}

.kc-tiktok-profile {
  display: flex;
  justify-content: center;
  margin-bottom: 2rem;
}
.kc-tiktok-profile blockquote {
  margin: 0 !important;
}

/* General embed consent placeholder (YouTube, Vimeo, etc in post content) */
.kc-embed-consent {
  text-align: center;
  padding: 2.5rem 2rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 12px;
  background: var(--wp--preset--color--bg-alt);
  margin: 1.5rem 0;
}
.kc-embed-consent__inner {
  max-width: 420px;
  margin: 0 auto;
}
.kc-embed-consent__text {
  font-size: 0.88rem;
  color: var(--wp--preset--color--text-muted);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.kc-embed-consent__text a {
  color: var(--wp--preset--color--primary);
  text-decoration: underline;
}

/* TikTok section consent placeholder */
.kc-tiktok-consent {
  max-width: 500px;
  margin: 0 auto;
  text-align: center;
  padding: 3rem 2rem;
  border: 1px solid var(--wp--preset--color--border);
  border-radius: 12px;
  background: var(--wp--preset--color--bg-alt);
}
.kc-tiktok-consent__icon {
  color: var(--wp--preset--color--text-muted);
  margin-bottom: 1rem;
}
.kc-tiktok-consent__text {
  font-size: 0.88rem;
  color: var(--wp--preset--color--text-muted);
  line-height: 1.6;
  margin-bottom: 1.5rem;
}
.kc-tiktok-consent__text a {
  color: var(--wp--preset--color--primary);
  text-decoration: underline;
}

.kc-tiktok-cta {
  text-align: center;
  margin-top: 3rem;
}

/* ============================================
   NAV LOGIN BUTTON (accent copper)
   ============================================ */
.nav-login .wp-block-navigation-item__content {
  display: inline-flex;
  align-items: center;
  padding: 0.6rem 1.4rem;
  background: var(--wp--preset--color--accent);
  color: var(--wp--preset--color--text-light) !important;
  font-size: 0.85rem;
  font-weight: 600;
  border-radius: 100px;
  transition: background-color 0.3s ease, transform 0.3s ease;
}
.nav-login .wp-block-navigation-item__content:hover {
  background: var(--wp--preset--color--accent-light);
  transform: translateY(-1px);
}

/* NAV "MINA KURSER" — same style as regular nav links */
.nav-my-courses .wp-block-navigation-item__content {
  position: relative;
  color: var(--wp--preset--color--text-muted);
  transition: color 0.3s ease;
}
.nav-my-courses .wp-block-navigation-item__content::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 0;
  height: 2px;
  background: var(--wp--preset--color--primary);
  transition: width 0.3s ease;
}
.nav-my-courses .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--text);
}
.nav-my-courses .wp-block-navigation-item__content:hover::after {
  width: 100%;
}

/* Tighter gap between Kontakt and Logga in/ut buttons */
.nav-cta + .nav-login,
.nav-my-courses + .nav-cta {
  margin-left: -1rem;
}

/* Ensure no underline on login button */
.nav-login .wp-block-navigation-item__content,
.nav-login .wp-block-navigation-item__content:hover {
  text-decoration: none !important;
}
