/*
Theme Name:   SOUL Child
Template:     kadence
Version:      1.3.3
Description:  Child theme for Science Of Unitive Love — scienceofunitivelove.net
              The science and practice of a Whole Spectrum Reality
Author:       Grant Storry
Text Domain:  soul-child
*/


/* ─── DESIGN TOKENS ─────────────────────────────────────────────────────────── */

:root {
  --soul-gold:         #c9a55a;
  --soul-gold-warm:    #e0c07a;
  --soul-gold-dim:     rgba(201, 165, 90, 0.18);
  --soul-cosmos:       #07090f;
  --soul-midnight:     #0d1120;
  --soul-navy:         #141928;
  --soul-navy-light:   #1a2035;
  --soul-cream:        #f2ead8;
  --soul-warm:         #d4cfc5;
  --soul-muted:        #9a9488;
  --soul-emerald:      #2e7a56;
  --soul-rose:         #9b5c6a;
  --soul-blue:         #4a6fa5;
  --soul-font-heading: 'Cormorant Garamond', Georgia, serif;
  --soul-font-body:    'Inter', system-ui, sans-serif;
}


/* ─── BASE ───────────────────────────────────────────────────────────────────── */

body {
  font-family: var(--soul-font-body);
  font-weight: 300;
  background-color: var(--soul-cosmos);
  color: var(--soul-warm);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* ─── HIDE KADENCE PAGE TITLE BANNER ─────────────────────────────────────────── */
/* The Kadence "page hero" / entry-header appears above page content by default.
   Hide it globally — page titles live inside each page's block content instead. */

.entry-header.hero-section,
.kadence-page-header,
.kadence-page-header-wrapper,
.page-title-wrap,
.entry-header:not(.post-entry-header) {
  display: none !important;
}


/* ─── REMOVE LIGHT BARS / BOXED CONTENT BACKGROUND ──────────────────────────── */
/* Kadence body classes: content-style-boxed adds a white card;
   content-vertical-padding-show adds top/bottom padding that reveals white bg.
   Nuke backgrounds and padding on all Kadence content containers. */

.site-main,
.hentry,
.content-bg,
.entry-content,
.content-area,
.inner-wrap,
.entry-content-wrap {
  background-color: transparent !important;
}

/* Remove the vertical padding Kadence adds via content-vertical-padding-show */
.content-vertical-padding-show .site-main,
.content-vertical-padding-show .inner-wrap,
.content-vertical-padding-show .entry-content-wrap {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/* Remove boxed-content card background and shadow */
.content-style-boxed .hentry,
.content-style-boxed .entry-content-wrap,
.content-style-boxed .inner-wrap {
  background-color: transparent !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

/* Zero inter-block vertical margins so blocks stack flush */
.entry-content > * {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* Remove any block-level borders Kadence or Gutenberg may add */
.entry-content .wp-block-group,
.entry-content .wp-block-cover {
  border: none !important;
  outline: none !important;
}

h1, h2, h3, h4 {
  font-family: var(--soul-font-heading);
  font-weight: 300;
}

a {
  transition: color 0.2s ease;
}

strong {
  font-weight: 400;
}


/* ─── SITE HEADER — Cream / Light of the Head ───────────────────────────────── */

.site-header {
  background-color: var(--soul-cream) !important;
  border-bottom: 1px solid rgba(201, 165, 90, 0.15);
  transition: background-color 0.4s ease, box-shadow 0.4s ease;
}

.site-header.is-scrolled {
  background-color: rgba(242, 234, 216, 0.97) !important;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  box-shadow: 0 1px 24px rgba(13, 17, 32, 0.08);
}

/* Site title on cream header */
.site-title a,
.site-title a:visited {
  color: var(--soul-cosmos) !important;
}

/* Nav links on cream header */
#site-header .main-navigation a,
.site-header .kadence-navigation a,
.site-header .nav--toggle-sub a {
  color: var(--soul-cosmos) !important;
}

#site-header .main-navigation a:hover,
.site-header .kadence-navigation a:hover,
.site-header .main-navigation .current-menu-item > a,
.site-header .kadence-navigation .current-menu-item > a {
  color: var(--soul-gold) !important;
}

/* ─── NAV CTA BUTTON — "Connect" menu item ───────────────────────────────────── */
/* Step 1: In WP Admin → Appearance → Menus → Screen Options → enable "CSS Classes"
   Step 2: On the Connect menu item, add class:  soul-nav-cta
   Step 3: Save Menu — done. */

.soul-nav-cta > a,
.soul-nav-cta > a:visited {
  color: var(--soul-cosmos) !important;
  border: 1px solid var(--soul-cosmos) !important;
  padding: 0.42rem 1.15rem !important;
  line-height: 1 !important;
  display: inline-block !important;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease !important;
  margin-left: 0.4rem;
}

.soul-nav-cta > a:hover {
  background-color: var(--soul-cosmos) !important;
  color: var(--soul-cream) !important;
  border-color: var(--soul-cosmos) !important;
}

/* Tighten nav spacing so it stays on one line */
#site-header .main-navigation li,
.site-header .kadence-navigation li {
  margin: 0 !important;
}

#site-header .main-navigation > div > ul > li > a,
.site-header .kadence-navigation > ul > li > a {
  padding-left: 0.55rem !important;
  padding-right: 0.55rem !important;
  font-size: 0.78rem !important;
  letter-spacing: 0.02em !important;
}

/* Hide site title text — keep logo image only.
   (Also toggle off in Kadence Customizer → Header → Logo → Display Title) */
.site-title {
  display: none !important;
}

/* ─── HEADER SEARCH ROW ──────────────────────────────────────────────────────── */
/* Styles for the Kadence Header Row 2 search bar
   In Header Builder: add Row 2 → drag "Search" widget to Right column
   Set Row 2 background to var(--soul-cream) / #f2ead8, padding minimal */

.kadence-header-row-2 {
  background-color: var(--soul-cream) !important;
  border-top: 1px solid rgba(201, 165, 90, 0.1);
  padding-top: 0.3rem !important;
  padding-bottom: 0.3rem !important;
}

/* Search input within header */
.kadence-header-row-2 .wp-block-search__input,
.kadence-header-row-2 input[type="search"] {
  background: transparent;
  border: none;
  border-bottom: 1px solid rgba(201, 165, 90, 0.3);
  border-radius: 0;
  color: var(--soul-cosmos);
  font-family: var(--soul-font-body);
  font-size: 0.75rem;
  letter-spacing: 0.08em;
  padding: 0.3rem 0.5rem;
  width: 200px;
  outline: none;
  transition: border-color 0.2s ease;
}

.kadence-header-row-2 input[type="search"]:focus {
  border-bottom-color: var(--soul-gold);
}

.kadence-header-row-2 input[type="search"]::placeholder {
  color: var(--soul-muted);
}

/* Search submit button — hide it, rely on Enter key */
.kadence-header-row-2 .wp-block-search__button,
.kadence-header-row-2 button[type="submit"] {
  background: none;
  border: none;
  color: var(--soul-gold);
  cursor: pointer;
  padding: 0 0.4rem;
  font-size: 0.85rem;
}

/* Site tagline — enable in Appearance > Customize > Header > Logo > Show Tagline */
.site-description {
  font-family: var(--soul-font-body);
  font-weight: 300;
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  color: var(--soul-muted);
  font-style: italic;
  margin: 0;
  line-height: 1.4;
  display: block;
}


/* ─── GRADIENT BRIDGES — yin/yang transitions ────────────────────────────────── */

/* Dark hero → Cream breath */
.soul-bridge-to-light {
  height: 100px;
  background: linear-gradient(to bottom, var(--soul-midnight), var(--soul-cream));
  display: block;
}

/* Cream breath → Dark */
.soul-bridge-to-dark {
  height: 100px;
  background: linear-gradient(to bottom, var(--soul-cream), var(--soul-midnight));
  display: block;
}

/* Cosmos variant (slightly deeper dark) */
.soul-bridge-cosmos-to-light {
  height: 100px;
  background: linear-gradient(to bottom, var(--soul-cosmos), var(--soul-cream));
  display: block;
}

.soul-bridge-light-to-cosmos {
  height: 100px;
  background: linear-gradient(to bottom, var(--soul-cream), var(--soul-cosmos));
  display: block;
}


/* ─── BREATH SECTIONS — spacious cream with quote ────────────────────────────── */

/* Break out of Gutenberg/Kadence constrained content width */
.soul-breath,
.soul-bridge-to-light,
.soul-bridge-to-dark,
.soul-bridge-cosmos-to-light,
.soul-bridge-light-to-cosmos {
  width: 100vw;
  margin-left: calc(50% - 50vw);
}

.soul-breath {
  background-color: var(--soul-cream);
  padding: 5rem 3rem 5rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}

/* Torch-flicker warm light overlay — fast, erratic, fire-like */
.soul-breath::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(ellipse at 50% 38%, rgba(255, 238, 160, 0.5) 0%, transparent 65%);
  animation: soul-flicker 1.1s linear infinite;
  pointer-events: none;
  z-index: 0;
}

@keyframes soul-flicker {
  0%   { opacity: 1;    }
  4%   { opacity: 0.55; }
  8%   { opacity: 0.95; }
  13%  { opacity: 0.7;  }
  17%  { opacity: 1;    }
  21%  { opacity: 0.6;  }
  26%  { opacity: 0.88; }
  31%  { opacity: 0.5;  }
  35%  { opacity: 1;    }
  40%  { opacity: 0.75; }
  45%  { opacity: 0.62; }
  50%  { opacity: 1;    }
  55%  { opacity: 0.58; }
  60%  { opacity: 0.9;  }
  65%  { opacity: 0.65; }
  70%  { opacity: 1;    }
  75%  { opacity: 0.72; }
  80%  { opacity: 0.52; }
  85%  { opacity: 0.95; }
  90%  { opacity: 0.68; }
  95%  { opacity: 1;    }
  100% { opacity: 0.78; }
}

/* Floating esoteric symbols — multiple direction keyframes */
@keyframes soul-sym-up {
  0%   { transform: translateY(0)    rotate(0deg);   opacity: 0; }
  8%   { opacity: 1; }
  90%  { opacity: 0.7; }
  100% { transform: translateY(-220px) rotate(40deg);  opacity: 0; }
}
@keyframes soul-sym-up-left {
  0%   { transform: translate(0,0)         rotate(0deg);  opacity: 0; }
  8%   { opacity: 1; }
  90%  { opacity: 0.7; }
  100% { transform: translate(-100px,-200px) rotate(-35deg); opacity: 0; }
}
@keyframes soul-sym-up-right {
  0%   { transform: translate(0,0)        rotate(0deg);  opacity: 0; }
  8%   { opacity: 1; }
  90%  { opacity: 0.7; }
  100% { transform: translate(100px,-200px) rotate(35deg); opacity: 0; }
}
@keyframes soul-sym-drift-left {
  0%   { transform: translate(0,0)          rotate(0deg);  opacity: 0; }
  8%   { opacity: 1; }
  90%  { opacity: 0.6; }
  100% { transform: translate(-160px,-80px) rotate(-55deg); opacity: 0; }
}
@keyframes soul-sym-drift-right {
  0%   { transform: translate(0,0)         rotate(0deg);  opacity: 0; }
  8%   { opacity: 1; }
  90%  { opacity: 0.6; }
  100% { transform: translate(160px,-80px) rotate(55deg);  opacity: 0; }
}
@keyframes soul-sym-down {
  0%   { transform: translateY(0)    rotate(0deg);    opacity: 0; }
  8%   { opacity: 0.9; }
  90%  { opacity: 0.5; }
  100% { transform: translateY(200px) rotate(-40deg); opacity: 0; }
}

.soul-breath-inner {
  max-width: 700px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

.soul-breath-quote {
  font-family: var(--soul-font-heading);
  font-size: clamp(1.7rem, 3vw, 2.5rem);
  font-weight: 300;
  font-style: italic;
  color: var(--soul-gold);
  line-height: 1.55;
  margin: 0 0 1.8rem;
  border: none;
  padding: 0;
}

.soul-breath-attribution {
  font-family: var(--soul-font-body);
  font-size: 0.68rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--soul-muted);
  margin: 0;
}


/* ─── FADE-IN ANIMATION ──────────────────────────────────────────────────────── */

.soul-fade {
  opacity: 0;
  transform: translateY(16px);
  transition: opacity 0.65s ease, transform 0.65s ease;
}

.soul-fade.is-visible {
  opacity: 1;
  transform: translateY(0);
}


/* ─── SIGNAL / INFO CARDS ────────────────────────────────────────────────────── */

.soul-signal-card {
  transition: border-left 0.2s ease;
}

.soul-signal-card:hover {
  border-left: 2px solid var(--soul-gold);
}


/* ─── ENTRYWAY CARDS ─────────────────────────────────────────────────────────── */

.soul-entryway {
  transition: transform 0.22s ease;
}

.soul-entryway:hover {
  transform: translateY(-3px);
}


/* ─── PATH ITEMS (stacked list) ──────────────────────────────────────────────── */

.soul-path-item {
  transition: background-color 0.2s ease, border-left-color 0.2s ease;
  border-left: 2px solid transparent;
}

.soul-path-item:hover {
  background-color: #1f2840 !important;
  border-left-color: var(--soul-gold);
}


/* ─── BUTTONS ────────────────────────────────────────────────────────────────── */

.wp-element-button,
.wp-block-button__link {
  font-family: var(--soul-font-body) !important;
  font-weight: 400 !important;
  letter-spacing: 0.1em !important;
  font-size: 0.8rem !important;
  padding: 0.78rem 2rem !important;
  border-radius: 0 !important;
  transition: all 0.22s ease !important;
  text-transform: none !important;
}

.is-style-fill .wp-block-button__link {
  background-color: var(--soul-gold) !important;
  color: var(--soul-cosmos) !important;
  border: 1px solid var(--soul-gold) !important;
}

.is-style-fill .wp-block-button__link:hover {
  background-color: var(--soul-gold-warm) !important;
  border-color: var(--soul-gold-warm) !important;
}

.is-style-outline .wp-block-button__link {
  background-color: transparent !important;
  color: var(--soul-cream) !important;
  border: 1px solid rgba(242, 234, 216, 0.3) !important;
}

.is-style-outline .wp-block-button__link:hover {
  border-color: var(--soul-gold) !important;
  color: var(--soul-gold) !important;
}


/* ─── LINEAGE FILTER TABS ────────────────────────────────────────────────────── */

.soul-lineage-filter {
  display: flex;
  gap: 0;
  margin-bottom: 3rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}

.soul-lineage-filter-btn {
  font-family: var(--soul-font-body);
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--soul-muted);
  background: none;
  border: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  padding: 0.85rem 1.6rem;
  cursor: pointer;
  transition: color 0.2s ease, border-bottom-color 0.2s ease;
}

.soul-lineage-filter-btn:hover {
  color: var(--soul-cream);
}

.soul-lineage-filter-btn.active {
  color: var(--soul-gold);
  border-bottom-color: var(--soul-gold);
}

.soul-lineage-panel {
  display: none;
}


/* ─── OFFERINGS CLUSTER NAVIGATION ──────────────────────────────────────────── */

.soul-cluster-nav {
  display: flex;
  gap: 2px;
  margin-bottom: 0;
}

.soul-cluster-btn {
  font-family: var(--soul-font-body);
  font-weight: 300;
  font-size: 0.72rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--soul-muted);
  background: var(--soul-navy);
  border: none;
  border-top: 2px solid transparent;
  padding: 1.1rem 2rem;
  cursor: pointer;
  transition: all 0.2s ease;
  flex: 1;
  text-align: center;
}

.soul-cluster-btn:hover {
  color: var(--soul-cream);
  background: var(--soul-navy-light);
}

.soul-cluster-btn.active {
  color: var(--soul-gold);
  background: var(--soul-navy-light);
  border-top-color: var(--soul-gold);
}

.soul-cluster-panel {
  display: none;
}

.soul-cluster-panel.active {
  display: block;
}


/* ─── OFFERING CARDS ─────────────────────────────────────────────────────────── */

.soul-offering-card {
  transition: transform 0.2s ease, border-left-color 0.2s ease;
  border-left: 2px solid transparent;
}

.soul-offering-card:hover {
  transform: translateY(-2px);
  border-left-color: var(--soul-gold);
}

/* Relationship Web tags */
.soul-offering-tag {
  font-size: 0.6rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  padding: 0.18rem 0.5rem;
  border-radius: 2px;
  display: inline-block;
  margin-right: 0.3rem;
  margin-bottom: 0.3rem;
  font-family: var(--soul-font-body);
  font-weight: 400;
}

.soul-offering-tag--depth-orienting {
  background: rgba(46, 122, 86, 0.14);
  color: var(--soul-emerald);
}

.soul-offering-tag--depth-deepening {
  background: rgba(201, 165, 90, 0.12);
  color: var(--soul-gold);
}

.soul-offering-tag--depth-integrating {
  background: rgba(155, 92, 106, 0.14);
  color: var(--soul-rose);
}

.soul-offering-tag--guide {
  background: rgba(74, 111, 165, 0.14);
  color: var(--soul-blue);
}

.soul-offering-tag--concept {
  background: rgba(255, 255, 255, 0.05);
  color: var(--soul-muted);
}


/* ─── FEATURED EVENT CARD ────────────────────────────────────────────────────── */

.soul-event-featured {
  border: 1px solid rgba(201, 165, 90, 0.25);
  background: var(--soul-navy);
  position: relative;
}

.soul-event-featured::before {
  content: 'UPCOMING';
  position: absolute;
  top: -1px;
  left: 2.5rem;
  font-size: 0.58rem;
  letter-spacing: 0.28em;
  color: var(--soul-cosmos);
  background: var(--soul-gold);
  padding: 0.22rem 0.65rem;
  font-family: var(--soul-font-body);
  font-weight: 400;
}


/* ─── FOOTER TAGLINE ─────────────────────────────────────────────────────────── */

/* Add a widget or text block in Kadence Footer Builder with class "soul-footer-tagline" */
.soul-footer-tagline {
  font-family: var(--soul-font-body);
  font-weight: 300;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  color: var(--soul-muted);
  font-style: italic;
  margin-top: 0.25rem;
  display: block;
}


/* ─── GLOSSARY ARCHIVE ───────────────────────────────────────────────────────── */

.soul-glossary-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 2px;
}


/* ─── RESPONSIVE ─────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {

  /* Lineage filter stacks vertically on mobile */
  .soul-lineage-filter {
    flex-direction: column;
    border-bottom: none;
    gap: 2px;
  }

  .soul-lineage-filter-btn {
    border-bottom: none;
    border-left: 2px solid transparent;
    text-align: left;
    margin-bottom: 0;
    padding: 0.75rem 1rem;
  }

  .soul-lineage-filter-btn.active {
    border-bottom: none;
    border-left-color: var(--soul-gold);
  }

  /* Cluster nav stacks on mobile */
  .soul-cluster-nav {
    flex-direction: column;
    gap: 2px;
  }

  .soul-cluster-btn {
    text-align: left;
    border-top: none;
    border-left: 2px solid transparent;
  }

  .soul-cluster-btn.active {
    border-top: none;
    border-left-color: var(--soul-gold);
  }
}
