/*
Theme Name: GAIA Blog
Theme URI: https://gaiaheadspa.com
Description: Child theme of Twenty Twenty-Five, styled to match the GAIA Head Spa static site (gaiaheadspa.com). Built by LIT Performance.
Author: LIT Performance
Template: twentytwentyfive
Version: 1.0.0
Text Domain: gaia-blog
*/

/* ============================================================
   GAIA HEAD SPA — BRAND VARIABLES
   Mirrors the :root block from the static HTML site exactly.
   ============================================================ */
:root{
  --bg:#0D0D0B;--bg2:#111110;--bg3:#141412;
  --cream:#F5F1EB;--taupe:rgba(245,241,235,.65);--muted:rgba(245,241,235,.52);
  --olive:#6F7D6B;--olive-l:#8A9E85;--olive-dk:#1C2B1A;
  --border:rgba(245,241,235,.07);
  --cr-bg:#FFFCF2;--cr-bg2:#F5F1EB;--cr-bg3:#EDE9DF;
  --cr-ink:#0D0D0B;--cr-ink2:rgba(13,13,11,.68);--cr-ink3:rgba(13,13,11,.48);
  --cr-border:rgba(13,13,11,.09);
  --ease:cubic-bezier(.22,1,.36,1);--sp:80px;
}

/* ============================================================
   RESET + BASE TYPOGRAPHY
   ============================================================ */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}

body{
  font-family:'Inter',sans-serif !important;
  font-weight:300;
  background:var(--cr-bg) !important;
  color:var(--cr-ink) !important;
  line-height:1.7;
}

/* Blog content area sits on cream background like the rest of the site */
body.blog,
body.single-post,
body.archive,
body.search{
  background:var(--cr-bg) !important;
}

h1,h2,h3,h4,h5,h6{
  font-family:'Playfair Display',serif !important;
  font-weight:400 !important;
  line-height:1.05;
  text-transform:uppercase;
  letter-spacing:-.015em;
  color:var(--cr-ink) !important;
}

h1{font-size:clamp(2.6rem,6vw,4.5rem)}
h2{font-size:clamp(2rem,4vw,3.2rem)}
h3{font-size:1.5rem}

/* Article body text should NOT be uppercase — only true headings */
.entry-content h1,.entry-content h2,.entry-content h3,
.entry-content h4,.entry-content h5,.entry-content h6{
  text-transform:none;
  letter-spacing:-.01em;
}

em,i{
  font-style:italic;
  color:var(--olive);
  text-transform:none;
}

p{color:var(--cr-ink2);font-size:1rem;line-height:1.8;margin-bottom:1.2em}

a{color:var(--olive);text-decoration:none;transition:color .2s}
a:hover{color:var(--olive-l)}

.entry-content a{
  border-bottom:1px solid rgba(111,125,107,.35);
}
.entry-content a:hover{
  border-color:var(--olive-l);
}

img{max-width:100%;height:auto;display:block}

/* ============================================================
   BUTTONS — match .btn / .btn-fill / .btn-ghost / .btn-olive
   ============================================================ */
.btn,.wp-block-button__link{
  display:inline-block;
  font-family:'Inter',sans-serif !important;
  font-size:.72rem !important;
  font-weight:500 !important;
  letter-spacing:.13em !important;
  text-transform:uppercase !important;
  padding:13px 28px !important;
  border:1px solid;
  border-radius:0 !important;
  transition:background .25s,color .25s,border-color .25s;
  white-space:nowrap;
}
.btn-fill,.wp-block-button.is-style-fill .wp-block-button__link{
  background:var(--cream) !important;color:var(--bg) !important;border-color:var(--cream) !important;
}
.btn-fill:hover,.wp-block-button.is-style-fill .wp-block-button__link:hover{
  background:var(--olive) !important;border-color:var(--olive) !important;color:var(--cream) !important;
}
.btn-ghost,.wp-block-button.is-style-outline .wp-block-button__link{
  background:transparent !important;color:var(--cr-ink3) !important;border-color:rgba(13,13,11,.22) !important;
}
.btn-ghost:hover,.wp-block-button.is-style-outline .wp-block-button__link:hover{
  border-color:var(--cr-ink) !important;color:var(--cr-ink) !important;
}
.btn-olive{
  background:transparent !important;color:var(--olive) !important;border-color:var(--olive) !important;
}
.btn-olive:hover{
  background:var(--olive-dk) !important;color:var(--olive-l) !important;
}

/* ============================================================
   SECTION LABEL (eyebrow) — matches .sec-label
   ============================================================ */
.sec-label{
  display:inline-block;
  font-family:'Inter',sans-serif;
  font-size:.68rem;
  font-weight:500;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--olive);
  margin-bottom:14px;
}

/* ============================================================
   HEADER / NAV — matches header.html exactly
   ============================================================ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 5%;
  background:rgba(13,13,11,.92);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border);
  transition:background .4s,padding .4s;
}
.nav-logo-text{display:flex;align-items:center}
.nav-links{display:flex;gap:32px;list-style:none;margin:0;padding:0}
.nav-links a{
  font-family:'Inter',sans-serif;
  font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(245,241,235,.72);
  border-bottom:none;
  transition:color .2s;
}
.nav-links a:hover{color:var(--cream)}
.nav-ctas{display:flex;gap:10px;align-items:center}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:var(--cream)}

#mobile-menu a{border-bottom:none}

/* Push page content below the fixed nav */
body{padding-top:88px}

@media(max-width:960px){
  .nav-links,.nav-ctas{display:none}
  .hamburger{display:flex}
}

/* ============================================================
   FOOTER — matches footer.html exactly
   ============================================================ */
footer.site-footer,footer#gaia-footer{
  background:var(--bg2);
  padding:60px 5% 28px;
  border-top:1px solid var(--border);
  color:var(--cream);
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;margin-bottom:48px;
}
.footer-brand{display:flex;flex-direction:column}
.footer-logo{
  font-family:'Playfair Display',serif !important;font-size:1.1rem !important;
  color:var(--cream) !important;display:block;margin-bottom:12px;text-transform:none !important;
  font-weight:400 !important;line-height:1.2 !important;
}
.footer-tagline{font-size:.8rem !important;color:var(--muted) !important;line-height:1.8 !important;margin:0 0 14px 0 !important}
.footer-map-links{display:flex;flex-direction:column;gap:6px;margin-top:16px}
.map-link{display:inline-flex;align-items:center;gap:8px;font-size:.78rem !important;color:var(--muted) !important;border-bottom:none}
.map-link:hover{color:var(--olive-l) !important}
.map-link svg{
  width:16px !important;height:16px !important;
  fill:currentColor !important;stroke:none !important;
  flex-shrink:0;display:inline-block !important;
}
.footer-col h5{
  font-family:'Inter',sans-serif !important;font-size:.65rem !important;font-weight:500 !important;
  letter-spacing:.18em !important;text-transform:uppercase !important;color:var(--olive) !important;
  margin:0 0 16px 0 !important;line-height:1.4 !important;
}
.footer-col ul{list-style:none !important;display:flex;flex-direction:column;gap:8px;margin:0 !important;padding:0 !important}
.footer-col ul li{margin:0 !important;padding:0 !important;list-style:none !important}
.footer-col ul li a{font-size:.82rem !important;color:var(--muted) !important;border-bottom:none !important}
.footer-col ul li a:hover{color:var(--cream) !important}
.footer-bottom{
  border-top:1px solid var(--border);padding-top:24px;
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px;
}
.footer-copy{font-size:.72rem !important;color:rgba(245,241,235,.35) !important}
.footer-copy a{color:rgba(245,241,235,.35) !important;border-bottom:1px solid rgba(245,241,235,.12) !important}
.footer-copy a:hover{color:var(--olive-l) !important}
.footer-social{display:flex;gap:24px}
.footer-social a{font-size:.72rem !important;color:rgba(245,241,235,.38) !important;border-bottom:none !important}
.footer-social a:hover{color:var(--olive-l) !important}

#gaia-footer p{margin:0 0 14px 0 !important;color:var(--muted) !important}
#gaia-footer a{text-decoration:none !important}

@media(max-width:960px){
  .footer-grid{grid-template-columns:1fr}
}

/* ============================================================
   BLOG-SPECIFIC LAYOUT
   ============================================================ */
.gaia-blog-wrap{
  max-width:760px;
  margin:0 auto;
  padding:64px 5% var(--sp);
}
.gaia-blog-eyebrow{
  font-family:'Inter',sans-serif;font-size:.68rem;font-weight:500;
  letter-spacing:.22em;text-transform:uppercase;color:var(--olive);
  margin-bottom:14px;display:block;
}
.gaia-blog-title{
  font-family:'Playfair Display',serif;
  font-size:clamp(2.2rem,5vw,3.6rem);
  text-transform:uppercase;letter-spacing:-.02em;
  color:var(--cr-ink);margin-bottom:18px;line-height:1.05;
}
.gaia-blog-meta{
  font-family:'Inter',sans-serif;font-size:.78rem;color:var(--cr-ink3);
  margin-bottom:36px;letter-spacing:.04em;
}
.gaia-blog-grid{
  max-width:1100px;margin:0 auto;padding:64px 5% var(--sp);
  display:grid;grid-template-columns:repeat(3,1fr);gap:32px;
}
.gaia-blog-card{
  background:#fff;border:1px solid var(--cr-border);
  transition:box-shadow .3s;
}
.gaia-blog-card:hover{box-shadow:0 4px 24px rgba(13,13,11,.07)}
.gaia-blog-card img{width:100%;height:220px;object-fit:cover;filter:brightness(.92) saturate(.92)}
.gaia-blog-card-body{padding:24px}
.gaia-blog-card h3{
  font-size:1.2rem;margin-bottom:10px;text-transform:none;letter-spacing:-.01em;
}
.gaia-blog-card p{font-size:.85rem;color:var(--cr-ink3);margin-bottom:0}

@media(max-width:960px){
  .gaia-blog-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:600px){
  .gaia-blog-grid{grid-template-columns:1fr}
  .gaia-blog-wrap{padding:48px 6%}
}

/* ============================================================
   WP admin bar offset fix (when logged in)
   ============================================================ */
.admin-bar #nav{top:32px}
@media(max-width:782px){
  .admin-bar #nav{top:46px}
}

/* ============================================================
   ANNIVERSARY POPUP — matches footer.html popup exactly
   ============================================================ */
#gaia-popup-overlay{
  position:fixed !important;inset:0;z-index:9000;
  background:rgba(13,13,11,.78);backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .45s cubic-bezier(.22,1,.36,1);
}
#gaia-popup-overlay.visible{opacity:1;pointer-events:all}
#gaia-popup{
  position:relative;
  background:#0D0D0B;
  border:1px solid rgba(245,241,235,.1);
  max-width:480px;width:100%;
  padding:52px 44px 44px;
  text-align:center;
  transform:translateY(24px);
  transition:transform .45s cubic-bezier(.22,1,.36,1);
  overflow:hidden;
}
#gaia-popup-overlay.visible #gaia-popup{transform:translateY(0)}
#gaia-popup::before{
  content:'';position:absolute;top:0;left:10%;right:10%;height:1px;
  background:linear-gradient(to right,transparent,rgba(111,125,107,.6),transparent);
}
#gaia-popup-close{
  position:absolute;top:16px;right:20px;
  background:none !important;border:none !important;color:rgba(245,241,235,.4);
  font-size:1.2rem;line-height:1;cursor:pointer;padding:4px 8px;
  transition:color .2s;font-family:'Inter',sans-serif;font-weight:300;
  width:auto;height:auto;appearance:none;-webkit-appearance:none;
}
#gaia-popup-close:hover{color:rgba(245,241,235,.9)}
.popup-eyebrow{
  display:inline-block;font-family:'Inter',sans-serif;font-size:.6rem;
  font-weight:500;letter-spacing:.24em;text-transform:uppercase;
  color:#6F7D6B;margin-bottom:20px;
}
#gaia-popup .popup-headline{
  font-family:'Playfair Display',serif !important;font-weight:400 !important;
  font-size:clamp(1.9rem,4vw,2.6rem) !important;line-height:1.05;
  text-transform:uppercase !important;letter-spacing:-.02em;
  color:#F5F1EB !important;margin-bottom:6px;
}
#gaia-popup .popup-headline em{font-style:italic;color:#8A9E85 !important;text-transform:none}
.popup-sub{
  font-family:'Playfair Display',serif;font-style:italic;
  font-size:1rem;color:rgba(245,241,235,.55) !important;margin-bottom:28px;
}
.popup-code-wrap{
  display:inline-flex;align-items:center;gap:0;
  border:1px solid rgba(111,125,107,.35);margin-bottom:10px;
}
.popup-code{
  font-family:'Inter',sans-serif;font-size:1.4rem;font-weight:500;
  letter-spacing:.18em;color:#F5F1EB;padding:14px 24px;
  background:rgba(111,125,107,.08);
}
.popup-copy-btn{
  background:none !important;border:none !important;border-left:1px solid rgba(111,125,107,.35) !important;
  padding:14px 16px !important;color:rgba(245,241,235,.45) !important;cursor:pointer;
  font-size:.65rem !important;font-family:'Inter',sans-serif !important;letter-spacing:.12em !important;
  text-transform:uppercase !important;transition:color .2s,background .2s;white-space:nowrap;
  width:auto;height:auto;appearance:none;-webkit-appearance:none;border-radius:0 !important;
}
.popup-copy-btn:hover{color:#F5F1EB !important;background:rgba(111,125,107,.14) !important}
.popup-copy-btn.copied{color:#8A9E85 !important}
.popup-note{
  font-size:.72rem;color:rgba(245,241,235,.38) !important;
  font-family:'Inter',sans-serif;letter-spacing:.04em;
  margin-bottom:28px;
}
#gaia-popup .popup-cta{
  display:block;width:100%;
  font-family:'Inter',sans-serif !important;font-size:.72rem !important;font-weight:500 !important;
  letter-spacing:.14em !important;text-transform:uppercase !important;
  padding:15px 28px !important;background:#F5F1EB !important;color:#0D0D0B !important;
  border:1px solid #F5F1EB !important;
  transition:background .25s,border-color .25s,color .25s;
  margin-bottom:12px;
}
#gaia-popup .popup-cta:hover{background:#6F7D6B !important;border-color:#6F7D6B !important;color:#F5F1EB !important}
.popup-dismiss{
  display:inline-block;font-size:.68rem;color:rgba(245,241,235,.3) !important;
  font-family:'Inter',sans-serif;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:color .2s;background:none !important;border:none !important;
  width:auto;height:auto;appearance:none;-webkit-appearance:none;padding:0;
}
.popup-dismiss:hover{color:rgba(245,241,235,.65) !important}
.popup-expiry{
  font-size:.65rem;color:rgba(245,241,235,.28) !important;
  font-family:'Inter',sans-serif;letter-spacing:.08em;
  margin-top:16px;
}
@media(max-width:480px){
  #gaia-popup{padding:44px 24px 32px}
  .popup-code{font-size:1.15rem;padding:12px 16px}
}

/* ============================================================
   FALLBACK: HIDE NATIVE TWENTY TWENTY-FIVE HEADER / FOOTER
   Primary fix is the empty parts/header.html + parts/footer.html
   override files. This CSS is a safety net in case FSE caching
   delays that override from taking effect immediately.
   ============================================================ */
body > header:not(#gaia-header-wrap){
  display:none !important;
}
body > footer:not(#gaia-footer){
  display:none !important;
}

/* ============================================================
   POST / PAGE CONTENT WIDTH FIX
   Twenty Twenty-Five wraps content in a centered narrow column
   with large empty side gutters (the area marked in yellow).
   We override to use the full readable width consistently.
   ============================================================ */
.wp-site-blocks{
  max-width:none !important;
}

/* Remove the constrained/centered wrapper so content uses our
   .gaia-blog-wrap sizing instead of theme defaults */
.entry-content,
.wp-block-post-content,
.wp-block-group.is-layout-constrained{
  max-width:100% !important;
  margin-left:0 !important;
  margin-right:0 !important;
}

/* The actual content column: align left within the page, matching
   the site's editorial left-aligned layout instead of full centering */
main.wp-block-group,
.wp-block-post-title,
.wp-block-post-content,
.entry-content,
.wp-block-template-part.is-layout-constrained > *{
  max-width:720px !important;
  margin-left:0 !important;
  margin-right:auto !important;
}

/* Page wrapper padding so content aligns with our nav/footer's 5% gutter */
main{
  padding:48px 5% var(--sp) !important;
  max-width:1100px !important;
  margin:0 auto !important;
}

/* Post title sizing consistent with .gaia-blog-title */
.wp-block-post-title{
  font-family:'Playfair Display',serif !important;
  text-transform:uppercase !important;
  font-size:clamp(2.2rem,5vw,3.6rem) !important;
  letter-spacing:-.02em !important;
  margin-bottom:8px !important;
}

/* Author/category meta line under the title */
.wp-block-post-author,
.wp-block-post-terms,
.wp-block-post-date{
  font-family:'Inter',sans-serif !important;
  font-size:.78rem !important;
  color:var(--cr-ink3) !important;
  text-transform:none !important;
}

/* Comments section restyle to match brand (kept functional, not hidden) */
.wp-block-comments,
.comments-area{
  max-width:720px;
  margin:48px 0 0 0 !important;
  border-top:1px solid var(--cr-border);
  padding-top:32px;
}
.wp-block-comments h2,.comments-area h2,
.wp-block-comments h3,.comments-area h3{
  font-family:'Playfair Display',serif !important;
  text-transform:uppercase !important;
}
.comment-respond input[type="text"],
.comment-respond input[type="email"],
.comment-respond input[type="url"],
.comment-respond textarea{
  border:1px solid var(--cr-border) !important;
  border-radius:0 !important;
  font-family:'Inter',sans-serif !important;
  padding:10px 14px !important;
}
.comment-respond input[type="submit"]{
  background:var(--cr-ink) !important;color:var(--cr-bg) !important;
  border:1px solid var(--cr-ink) !important;border-radius:0 !important;
  font-family:'Inter',sans-serif !important;font-size:.72rem !important;
  font-weight:500 !important;letter-spacing:.13em !important;text-transform:uppercase !important;
  padding:13px 28px !important;cursor:pointer;
}
.comment-respond input[type="submit"]:hover{
  background:var(--olive) !important;border-color:var(--olive) !important;
}

/* "More posts" / related list under a single post */
.wp-block-query-title,
.gaia-more-posts-label{
  font-family:'Inter',sans-serif !important;font-size:.68rem !important;
  letter-spacing:.22em !important;text-transform:uppercase !important;color:var(--olive) !important;
}

