/*
 * Essence of Me - Global Stylesheet
 * Loads on every page. Brand tokens, typography, utilities.
 * Child theme: essence-of-me-child | Prefix: eom
 */

/* =============================================
   ROOT TOKENS
============================================= */
:root {
  /* Brand palette */
  --eom-primary:       #764B92;   /* Royal Purple */
  --eom-secondary:     #CCABD6;   /* Lilac */
  --eom-accent:        #008C99;   /* Teal */
  --eom-accent-light:  #5EC8D4;   /* Light Teal for dark sections */
  --eom-dark:          #004E4E;   /* Dark Teal (footer) */
  --eom-bluegray:      #6089B7;   /* Blue-Gray supporting */

  /* Neutrals */
  --eom-off-white:     #FAF8F6;
  --eom-lilac-soft:    #F5F0FA;
  --eom-gray-200:      #E9E3F0;
  --eom-gray-400:      #BBA8CC;
  --eom-gray-600:      #7A6A8A;
  --eom-text-dark:     #2C2C2C;
  --eom-text-mid:      #5A5A5A;
  --eom-text-light:    #8A8A8A;
  --eom-white:         #FFFFFF;
}

/* =============================================
   BASE
============================================= */
html {
  scroll-behavior: smooth !important;
}

[id] {
  scroll-margin-top: 100px !important;
}

body {
  font-family: 'Nunito', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight: 400;
  font-size: 17px;
  line-height: 1.85;
  color: var(--eom-text-dark);
  background: var(--eom-off-white);
}

/* =============================================
   TYPOGRAPHY
============================================= */
.eom-script-heading {
  font-family: 'Dancing Script', cursive;
  font-weight: 700;
  line-height: 1.15;
  color: var(--eom-primary);
}

.eom-serif-heading {
  font-family: 'Playfair Display', serif;
  font-weight: 500;
  line-height: 1.3;
  color: var(--eom-primary);
}

.eom-section-label {
  display: block;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--eom-accent);
  margin-bottom: 12px;
}

.eom-eyebrow {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--eom-accent);
  background: rgba(0, 140, 153, 0.1);
  padding: 6px 18px;
  border-radius: 50px;
  margin-bottom: 24px;
}

/* =============================================
   BUTTONS
============================================= */
.eom-btn {
  display: inline-block;
  padding: 15px 40px;
  border-radius: 50px;
  font-family: 'Nunito', sans-serif;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.25s, color 0.25s, transform 0.2s, box-shadow 0.2s;
}

.eom-btn--primary {
  background: var(--eom-accent);
  color: var(--eom-white);
  border: none;
}
.eom-btn--primary:hover {
  background: var(--eom-dark);
  color: var(--eom-white);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 78, 78, 0.25);
}

.eom-btn--outline {
  background: transparent;
  color: var(--eom-primary);
  border: 2px solid var(--eom-primary);
}
.eom-btn--outline:hover {
  background: var(--eom-primary);
  color: var(--eom-white);
  transform: translateY(-2px);
}

.eom-btn--light {
  background: var(--eom-white);
  color: var(--eom-accent);
  border: none;
}
.eom-btn--light:hover {
  background: var(--eom-lilac-soft);
  color: var(--eom-primary);
}

/* =============================================
   SECTION WRAPPERS
============================================= */
.eom-section-light   { background: var(--eom-white); }
.eom-section-cream   { background: var(--eom-off-white); }
.eom-section-lilac   { background: var(--eom-lilac-soft); }
.eom-section-dark    { background: var(--eom-dark); }
.eom-section-purple  { background: var(--eom-primary); }

/* Container */
.eom-container {
  max-width: 1140px;
  margin: 0 auto;
  padding: 0 28px;
}

/* =============================================
   ASTRA OVERRIDES
============================================= */
/* Allow ACF block pages to stretch full width */
.ast-container { max-width: 100% !important; }

/* ACF block pages -- no padding so blocks handle their own spacing */
.page .entry-content {
  max-width: 100% !important;
  padding: 0 !important;
}

/* =============================================
   SINGLE POST -- readable content width
============================================= */
.single .entry-header,
.single .entry-content,
.single .entry-footer,
.single .post-navigation {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 28px !important;
  padding-right: 28px !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Single post title */
.single .entry-title {
  font-family: 'Playfair Display', serif !important;
  font-size: clamp(1.8rem, 3.5vw, 2.6rem) !important;
  font-weight: 500 !important;
  color: #764B92 !important;
  line-height: 1.3 !important;
  margin-bottom: 20px !important;
}

/* Single post body */
.single .entry-content p,
.single .entry-content li {
  font-family: 'Nunito', sans-serif !important;
  font-size: 1.05rem !important;
  font-weight: 300 !important;
  line-height: 1.95 !important;
  color: #5A5A5A !important;
}

/* Single post headings */
.single .entry-content h2 {
  font-family: 'Playfair Display', serif !important;
  color: #764B92 !important;
  font-size: 1.6rem !important;
  margin-top: 40px !important;
}
.single .entry-content h3 {
  font-family: 'Playfair Display', serif !important;
  color: #764B92 !important;
  font-size: 1.25rem !important;
  margin-top: 28px !important;
}

/* Post navigation */
.single .post-navigation {
  border-top: 1px solid #E9E3F0 !important;
  padding-top: 32px !important;
  margin-top: 56px !important;
}
.single .post-navigation .nav-previous a,
.single .post-navigation .nav-next a {
  color: #008C99 !important;
  font-weight: 600 !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
}
.single .post-navigation .nav-previous a:hover,
.single .post-navigation .nav-next a:hover {
  color: #764B92 !important;
}

/* =============================================
   BLOG / ARCHIVE LISTING
============================================= */
.blog .site-main,
.archive .site-main,
.search .site-main {
  max-width: 1100px !important;
  margin: 40px auto !important;
  padding: 0 28px !important;
  box-sizing: border-box !important;
}

/* Hide Astra page title on pages using a hero block */
.eom-page-no-title .entry-header,
.eom-page-no-title .entry-title { display: none !important; }

