/*
Theme Name: House of Hers
Theme URI: https://thehouseofhers.com
Author: House of Hers
Author URI: https://thehouseofhers.com
Description: A bespoke romantic editorial WordPress theme for House of Hers. Features: split navigation, full-width hero, marquee ticker, numbered services, journal grid, freebie capture, testimonials, Instagram links page, sales page, WooCommerce support. All sections toggleable via Customizer.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.7
Requires PHP: 7.4
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: house-of-hers
Tags: blog, e-commerce, one-column, two-columns, custom-menu, featured-images, full-width-template, theme-options, translation-ready
*/

/* ================================================
   VARIABLES
   ================================================ */
:root {
  --cream: #FAF8F3;
  --cream-warm: #F3EEE5;
  --forest: #2D4A2F;
  --forest-light: #4A6B4C;
  --forest-pale: #E5EBE5;
  --sage: #7A8E72;
  --charcoal: #1A1A1A;
  --text: #2C2C2C;
  --text-light: #6B6B6B;
  --text-muted: #999;
  --rose: #C4A7A0;
  --gold: #B5A07A;
  --border: #D8D2C8;
  --border-light: #E8E2D8;
  --white: #fff;
  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'Lora', Georgia, serif;
  --font-script: 'Pinyon Script', cursive;
  --radius: 0px;
  --shadow-sm: 0 2px 12px rgba(0,0,0,0.04);
  --shadow-md: 0 8px 32px rgba(0,0,0,0.06);
  --shadow-lg: 0 16px 48px rgba(0,0,0,0.08);
  --transition: 0.35s cubic-bezier(0.4, 0, 0.2, 1);
}

/* ================================================
   RESET
   ================================================ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--text);background:var(--cream);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden;line-height:1.7}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
img{max-width:100%;height:auto;display:block}
ul,ol{list-style:none}
button,input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;border:none;outline:none;background:none}
::selection{background:var(--forest);color:var(--cream)}
:focus-visible{outline:2px solid var(--forest);outline-offset:2px}

/* ================================================
   UTILITY
   ================================================ */
.container{max-width:1240px;margin:0 auto;padding:0 40px}
.container-narrow{max-width:720px;margin:0 auto;padding:0 40px}
.container-wide{max-width:1400px;margin:0 auto;padding:0 40px}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ================================================
   TYPOGRAPHY
   ================================================ */
.eyebrow{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.5em;
  text-transform:uppercase;color:var(--sage);margin-bottom:14px;
}
.section-label{
  font-family:var(--font-script);font-size:26px;color:var(--forest);margin-bottom:8px;
}
.section-title{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  line-height:1.2;color:var(--charcoal);
}
.section-title--lg{font-size:clamp(36px,5vw,64px)}
.section-title--md{font-size:clamp(28px,3.5vw,44px)}
.section-title--sm{font-size:clamp(22px,2.5vw,32px)}

.body-text{font-size:15px;line-height:1.9;color:var(--text)}
.body-text em{color:var(--forest);font-style:italic}
.body-text--sm{font-size:13px}
.body-text--lg{font-size:17px}

.script-accent{font-family:var(--font-script);color:var(--forest)}

/* ================================================
   BUTTONS
   ================================================ */
.btn{
  display:inline-block;font-family:var(--font-body);font-size:9.5px;
  letter-spacing:0.4em;text-transform:uppercase;padding:16px 44px;
  cursor:pointer;transition:all var(--transition);text-align:center;
  border-radius:var(--radius);
}
.btn--primary{background:var(--forest);color:var(--cream);border:1px solid var(--forest)}
.btn--primary:hover{background:var(--forest-light);transform:translateY(-2px);box-shadow:var(--shadow-md)}
.btn--outline{background:transparent;color:var(--forest);border:1px solid var(--forest)}
.btn--outline:hover{background:var(--forest);color:var(--cream)}
.btn--ghost{background:transparent;color:var(--cream);border:1px solid rgba(250,248,243,0.4)}
.btn--ghost:hover{background:rgba(250,248,243,0.15);border-color:var(--cream)}
.btn--sm{padding:10px 28px;font-size:8px}
.btn--block{display:block;width:100%}
.btn--link{
  padding:0;border:none;background:none;
  font-family:var(--font-body);font-style:italic;font-size:13px;
  color:var(--forest);border-bottom:1px solid var(--sage);
  padding-bottom:2px;letter-spacing:0;text-transform:none;
}
.btn--link:hover{border-color:var(--forest)}

/* ================================================
   NAVIGATION — SPLIT MENU (Lilou style)
   ================================================ */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:1000;
  background:rgba(250,248,243,0.96);
  backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(45,74,47,0.06);
  transition:box-shadow var(--transition);
}
.site-nav.scrolled{box-shadow:var(--shadow-sm)}

.nav-inner{
  max-width:1400px;margin:0 auto;padding:16px 40px;
  display:grid;grid-template-columns:1fr auto 1fr;
  align-items:center;gap:20px;
}

.nav-left,.nav-right-menu{display:flex;gap:28px;align-items:center;list-style:none}
.nav-left li,.nav-right-menu li{list-style:none}
.nav-left ul,.nav-right-menu ul{display:flex;gap:28px;align-items:center;list-style:none;margin:0;padding:0}
.nav-right-menu{justify-content:flex-end}

.nav-left a,.nav-right-menu a{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.28em;
  text-transform:uppercase;color:var(--text-light);transition:color var(--transition);
}
.nav-left a:hover,.nav-right-menu a:hover,
.nav-left .current-menu-item>a,.nav-right-menu .current-menu-item>a{color:var(--forest)}

/* Dropdown */
.nav-left li,.nav-right-menu li{position:relative}
.nav-left .sub-menu,.nav-right-menu .sub-menu{
  position:absolute;top:100%;left:0;min-width:200px;
  background:var(--cream);border:1px solid var(--border-light);
  padding:14px 0;opacity:0;visibility:hidden;
  transform:translateY(8px);transition:all var(--transition);
  box-shadow:var(--shadow-md);z-index:100;
  flex-direction:column;gap:0;
}
.nav-left li:hover>.sub-menu,.nav-right-menu li:hover>.sub-menu{
  opacity:1;visibility:visible;transform:translateY(0);display:flex;
}
.nav-left .sub-menu li,.nav-right-menu .sub-menu li{list-style:none}
.nav-left .sub-menu a,.nav-right-menu .sub-menu a{
  display:block;padding:8px 24px;font-size:9px;
  letter-spacing:0.2em;color:var(--text-light);
}
.nav-left .sub-menu a:hover,.nav-right-menu .sub-menu a:hover{color:var(--forest);background:var(--forest-pale)}

.nav-logo{
  text-align:center;justify-self:center;
}
.nav-logo-img{
  display:block;margin:0 auto 6px;max-height:50px;width:auto;
}
.nav-logo a{
  font-family:var(--font-display);font-style:italic;
  font-size:28px;color:var(--charcoal);display:block;
}
.nav-logo .site-tagline{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--sage);margin-top:2px;
}

.nav-cta-btn{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.3em;
  text-transform:uppercase;padding:8px 20px;
  border:1px solid var(--forest);color:var(--forest);
  transition:all var(--transition);margin-left:12px;
}
.nav-cta-btn:hover{background:var(--forest);color:var(--cream)}

/* Mobile toggle */
.mobile-toggle{
  display:none;cursor:pointer;background:none;border:none;
  width:28px;height:20px;position:relative;z-index:1001;
}
.mobile-toggle span{
  display:block;position:absolute;height:1px;width:100%;
  background:var(--charcoal);transition:var(--transition);left:0;
}
.mobile-toggle span:nth-child(1){top:0}
.mobile-toggle span:nth-child(2){top:50%;transform:translateY(-50%)}
.mobile-toggle span:nth-child(3){bottom:0}
.mobile-toggle.active span:nth-child(1){top:50%;transform:rotate(45deg) translateY(-50%)}
.mobile-toggle.active span:nth-child(2){opacity:0}
.mobile-toggle.active span:nth-child(3){bottom:50%;transform:rotate(-45deg) translateY(50%)}

/* Mobile overlay */
.mobile-menu-overlay{
  position:fixed;inset:0;background:var(--cream);z-index:999;
  display:flex;flex-direction:column;justify-content:center;
  align-items:center;text-align:center;padding:40px;
  opacity:0;visibility:hidden;transition:all 0.4s ease;
}
.mobile-menu-overlay.active{opacity:1;visibility:visible}

.mobile-menu-overlay .mobile-nav{margin-bottom:32px}
.mobile-menu-overlay .mobile-nav a{
  display:block;font-family:var(--font-display);font-style:italic;
  font-size:28px;color:var(--charcoal);padding:12px 0;
  transition:color var(--transition);
}
.mobile-menu-overlay .mobile-nav a:hover{color:var(--forest)}
.mobile-menu-overlay .mobile-nav .sub-menu{margin-top:4px}
.mobile-menu-overlay .mobile-nav .sub-menu a{font-size:16px;color:var(--text-light);padding:6px 0}
.mobile-menu-overlay .mobile-social{display:flex;gap:20px;margin-top:24px}
.mobile-menu-overlay .mobile-social a{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--text-muted);
}

/* ================================================
   HERO SECTIONS
   ================================================ */
/* --- Hero Slider (Home) --- */
.hero-slider{
  margin-top:64px;position:relative;height:90vh;min-height:550px;
  overflow:hidden;
}
.hero-slide{
  position:absolute;inset:0;display:flex;align-items:center;
  opacity:0;transition:opacity 1s ease;
}
.hero-slide.active{opacity:1;z-index:2}
.hero-slide .slide-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
}
.hero-slide .slide-overlay{
  position:absolute;inset:0;background:rgba(250,248,243,0.45);
}
.hero-slide .slide-content{
  position:relative;z-index:3;width:100%;
  padding:60px 80px;max-width:650px;
}
.hero-slide .slide-eyebrow{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.5em;
  text-transform:uppercase;color:var(--forest);margin-bottom:14px;
}
.hero-slide .slide-title{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(36px,5vw,60px);line-height:1.15;color:var(--charcoal);
  margin-bottom:16px;
}
.hero-slide .slide-text{
  font-family:var(--font-body);font-size:14px;line-height:1.7;
  color:var(--text-light);margin-bottom:28px;max-width:420px;
}

.hero-slider-dots{
  position:absolute;bottom:32px;left:50%;transform:translateX(-50%);
  z-index:10;display:flex;gap:10px;
}
.hero-slider-dots .dot{
  width:8px;height:8px;border-radius:50%;border:1px solid var(--forest);
  background:transparent;cursor:pointer;transition:all var(--transition);
}
.hero-slider-dots .dot.active{background:var(--forest)}

/* --- Hero Simple (subpages) --- */
.hero-simple{
  margin-top:64px;padding:100px 40px 80px;text-align:center;
  background:var(--cream-warm);border-bottom:1px solid var(--border-light);
}
.hero-simple .section-label{margin-bottom:8px}
.hero-simple h1{
  font-family:var(--font-display);font-weight:400;font-size:clamp(36px,5vw,56px);
  color:var(--charcoal);margin-bottom:14px;
}
.hero-simple .hero-description{
  font-family:var(--font-body);font-style:italic;font-size:14px;
  color:var(--text-light);max-width:500px;margin:0 auto;line-height:1.7;
}

/* --- Hero Split (About) --- */
.hero-split{
  margin-top:64px;display:grid;grid-template-columns:1fr 1fr;
  min-height:85vh;
}
.hero-split .hero-img{background-size:cover;background-position:center;min-height:500px}
.hero-split .hero-text{
  display:flex;flex-direction:column;justify-content:center;
  padding:80px 64px;background:var(--cream);
}

/* ================================================
   MARQUEE TICKER
   ================================================ */
.marquee{
  overflow:hidden;padding:28px 0;border-top:1px solid var(--border-light);
  border-bottom:1px solid var(--border-light);background:var(--cream);
}
.marquee-track{
  display:flex;gap:0;animation:marquee-scroll 20s linear infinite;
  white-space:nowrap;
}
.marquee-item{
  font-family:var(--font-display);font-style:italic;font-size:clamp(18px,2.5vw,28px);
  color:var(--charcoal);padding:0 20px;flex-shrink:0;
}
.marquee-item .sep{
  color:var(--sage);margin:0 16px;font-style:normal;
}

@keyframes marquee-scroll{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}

/* ================================================
   SECTIONS — SHARED
   ================================================ */
.section{padding:120px 40px}
.section--alt{background:var(--cream-warm)}
.section--forest{background:var(--forest);color:var(--cream)}
.section--forest .section-label{color:var(--sage)}
.section--forest .section-title{color:var(--cream)}
.section--forest .body-text{color:rgba(250,248,243,0.8)}
.section--forest .eyebrow{color:var(--sage)}

.section-header{text-align:center;margin-bottom:56px}
.section-header .section-title{margin-bottom:16px}
.section-header .section-desc{
  font-family:var(--font-body);font-style:italic;font-size:14px;
  color:var(--text-light);max-width:540px;margin:0 auto;line-height:1.7;
}

/* ================================================
   FEATURED BLOCK (image + text side by side)
   ================================================ */
.featured-block{
  display:grid;grid-template-columns:1fr 1fr;gap:0;min-height:500px;
}
.featured-block--reverse{direction:rtl}
.featured-block--reverse>*{direction:ltr}
.featured-img{background-size:cover;background-position:center;min-height:500px}
.featured-content{
  display:flex;flex-direction:column;justify-content:center;
  padding:64px 60px;
}
.featured-content .section-label{margin-bottom:14px}
.featured-content .section-title{font-size:clamp(26px,3vw,36px);margin-bottom:14px}
.featured-content .body-text{margin-bottom:28px}

/* ================================================
   NUMBERED SERVICES (01, 02, 03)
   ================================================ */
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

.service-card{overflow:hidden;transition:transform var(--transition)}
.service-card:hover{transform:translateY(-6px)}
.service-card .service-img{
  width:100%;aspect-ratio:2/3;object-fit:cover;
  background:var(--cream-warm);
}
.service-card .service-img-placeholder{
  width:100%;aspect-ratio:2/3;
  background:linear-gradient(145deg,var(--cream-warm),var(--border-light));
}
.service-card .service-body{padding:24px 4px}
.service-card .service-num{
  font-family:var(--font-display);font-size:42px;font-weight:300;
  color:var(--forest);line-height:1;margin-bottom:8px;
}
.service-card .service-title{
  font-family:var(--font-display);font-style:italic;font-size:20px;
  color:var(--charcoal);line-height:1.3;
}
.service-card .service-text{
  font-family:var(--font-body);font-size:12px;line-height:1.7;
  color:var(--text-light);margin-top:8px;
}

/* ================================================
   PRESS / LOGOS BAR
   ================================================ */
.press-bar{
  padding:48px 40px;border-top:1px solid var(--border-light);
  border-bottom:1px solid var(--border-light);
}
.press-logos{
  display:flex;justify-content:center;align-items:center;
  gap:48px;flex-wrap:wrap;
}
.press-logos img{
  height:24px;opacity:0.35;transition:opacity var(--transition);
  filter:grayscale(100%);
}
.press-logos img:hover{opacity:0.7}

/* ================================================
   FREEBIE / LEAD CAPTURE
   ================================================ */
.freebie-section{padding:120px 40px}
.freebie-box{
  display:flex;gap:60px;align-items:center;max-width:900px;margin:0 auto;
}
.freebie-mock{
  flex:0 0 240px;height:340px;background:var(--cream);
  border:1px solid var(--border);display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  padding:30px 22px;box-shadow:var(--shadow-lg);
}
.freebie-mock .fleuron{font-size:16px;color:var(--sage);margin-bottom:14px}
.freebie-mock .mock-label{
  font-family:var(--font-body);font-size:7px;letter-spacing:0.5em;
  text-transform:uppercase;color:var(--forest);margin-bottom:14px;
}
.freebie-mock .mock-title{
  font-family:var(--font-display);font-style:italic;font-size:22px;
  line-height:1.2;color:var(--charcoal);margin-bottom:10px;
}
.freebie-mock .mock-sub{
  font-family:var(--font-body);font-style:italic;font-size:9.5px;
  color:var(--text-light);line-height:1.5;
}
.freebie-info{flex:1}
.freebie-info h2{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(26px,3vw,34px);color:var(--charcoal);margin-bottom:10px;line-height:1.2;
}
.freebie-info .freebie-subtitle{
  font-family:var(--font-body);font-style:italic;font-size:13px;
  color:var(--text-light);margin-bottom:20px;line-height:1.6;
}
.freebie-info .body-text{margin-bottom:28px}

/* ================================================
   FORMS
   ================================================ */
.form-field{
  font-family:var(--font-body);font-size:13px;padding:14px 18px;
  border:1px solid var(--border);background:var(--cream);
  color:var(--text);transition:border-color var(--transition);
  width:100%;
}
.form-field::placeholder{color:var(--sage);font-style:italic}
.form-field:focus{border-color:var(--forest)}

textarea.form-field{min-height:140px;resize:vertical}

.form-stack{display:flex;flex-direction:column;gap:12px;max-width:380px}
.form-privacy{font-family:var(--font-body);font-style:italic;font-size:10px;color:var(--sage)}

/* ================================================
   JOURNAL / BLOG GRID
   ================================================ */
.journal-header{
  display:flex;flex-direction:column;align-items:center;margin-bottom:56px;
}
.journal-header .from{
  font-family:var(--font-display);font-style:italic;font-size:clamp(36px,5vw,56px);
  color:var(--charcoal);line-height:0.9;
}
.journal-header .the{
  font-family:var(--font-display);font-style:italic;font-size:clamp(30px,4vw,48px);
  color:var(--charcoal);line-height:0.9;
}
.journal-header .journal-word{
  font-family:var(--font-display);font-style:italic;font-size:clamp(48px,7vw,80px);
  color:var(--charcoal);line-height:0.9;text-transform:uppercase;
  letter-spacing:0.05em;
}
.journal-header .journal-sub{
  font-family:var(--font-body);font-style:italic;font-size:13px;
  color:var(--text-light);margin-top:12px;
}

.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

.post-card{transition:transform var(--transition)}
.post-card:hover{transform:translateY(-4px)}
.post-card .post-thumbnail{
  width:100%;aspect-ratio:1;object-fit:cover;
  background:var(--cream-warm);margin-bottom:16px;
}
.post-card .post-thumbnail-placeholder{
  width:100%;aspect-ratio:1;
  background:linear-gradient(145deg,var(--cream-warm),var(--border-light));
  margin-bottom:16px;
}
.post-card .post-cat{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--sage);margin-bottom:6px;
}
.post-card .post-title{
  font-family:var(--font-display);font-style:italic;font-size:20px;
  color:var(--charcoal);line-height:1.3;
}
.post-card .post-title a{transition:color var(--transition)}
.post-card .post-title a:hover{color:var(--forest)}

/* ================================================
   TESTIMONIALS
   ================================================ */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}

.testimonial{
  padding:36px 28px;background:var(--cream);
  border:1px solid var(--border-light);text-align:center;
  transition:transform var(--transition),box-shadow var(--transition);
}
.testimonial:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}
.testimonial .quote-mark{
  font-family:var(--font-display);font-size:48px;color:var(--sage);
  line-height:1;margin-bottom:8px;
}
.testimonial .testimonial-text{
  font-family:var(--font-body);font-style:italic;font-size:14px;
  line-height:1.7;color:var(--text);margin-bottom:16px;
}
.testimonial .testimonial-author{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--sage);
}

/* ================================================
   NEWSLETTER SECTION
   ================================================ */
.newsletter-section{
  padding:100px 40px;background:var(--forest);color:var(--cream);text-align:center;
}
.newsletter-section .section-label{color:var(--sage)}
.newsletter-section h2{
  font-family:var(--font-display);font-style:italic;font-size:clamp(28px,3.5vw,42px);
  color:var(--cream);margin-bottom:16px;
}
.newsletter-section .body-text{color:rgba(250,248,243,0.75);margin-bottom:32px}

.newsletter-form{
  display:flex;gap:0;max-width:480px;margin:0 auto;
}
.newsletter-form input{
  flex:1;padding:16px 20px;background:rgba(250,248,243,0.1);
  border:1px solid rgba(250,248,243,0.2);color:var(--cream);
  font-family:var(--font-body);font-size:12px;
}
.newsletter-form input::placeholder{color:rgba(250,248,243,0.4);font-style:italic}
.newsletter-form button{
  padding:16px 28px;background:var(--cream);color:var(--forest);
  font-family:var(--font-body);font-size:8px;letter-spacing:0.4em;
  text-transform:uppercase;cursor:pointer;transition:all var(--transition);
  border:1px solid var(--cream);white-space:nowrap;
}
.newsletter-form button:hover{background:transparent;color:var(--cream)}

/* ================================================
   SHOP / PRODUCT GRID
   ================================================ */
.product-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px}

.product-card{text-align:center;transition:transform var(--transition)}
.product-card:hover{transform:translateY(-4px)}
.product-card .product-img{
  width:100%;aspect-ratio:2/3;object-fit:cover;
  background:var(--cream-warm);border:1px solid var(--border-light);
  margin-bottom:14px;
}
.product-card .product-img-placeholder{
  width:100%;aspect-ratio:2/3;border:1px solid var(--border-light);
  background:var(--cream-warm);display:flex;flex-direction:column;
  justify-content:center;align-items:center;padding:24px;margin-bottom:14px;
}
.product-card .product-name{
  font-family:var(--font-display);font-style:italic;font-size:18px;
  color:var(--charcoal);margin-bottom:4px;
}
.product-card .product-price{
  font-family:var(--font-body);font-size:12px;color:var(--forest);
  letter-spacing:0.1em;
}
.product-card .product-tag{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--sage);margin-top:4px;
}

/* ================================================
   PILLARS (CALM METHOD)
   ================================================ */
.pillars-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}

.pillar{
  background:var(--forest-pale);border-left:3px solid var(--forest);
  padding:36px 32px;transition:transform var(--transition),box-shadow var(--transition);
}
.pillar:hover{transform:translateY(-3px);box-shadow:0 12px 40px rgba(45,74,47,0.05)}
.pillar .pillar-letter{
  font-family:var(--font-display);font-size:48px;font-weight:300;
  color:var(--forest);line-height:1;margin-bottom:4px;
}
.pillar h3{
  font-family:var(--font-body);font-size:9.5px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--charcoal);margin-bottom:8px;
}
.pillar .pillar-tagline{
  font-family:var(--font-body);font-style:italic;font-size:12.5px;
  color:var(--forest);margin-bottom:12px;line-height:1.5;
}
.pillar p{font-size:12.5px;line-height:1.75}

/* ================================================
   CONTACT PAGE
   ================================================ */
.contact-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:60px;
  max-width:900px;margin:0 auto;align-items:start;
}
.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-info h3{
  font-family:var(--font-display);font-style:italic;font-size:24px;
  color:var(--charcoal);margin-bottom:20px;
}
.contact-info .body-text{margin-bottom:16px}
.contact-info .contact-email{
  font-family:var(--font-body);font-style:italic;color:var(--forest);
  margin-bottom:24px;display:block;
}

.social-links{display:flex;gap:20px;flex-wrap:wrap}
.social-links a{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--text-light);
  border-bottom:1px solid var(--border);transition:all var(--transition);
}
.social-links a:hover{color:var(--forest);border-color:var(--forest)}

/* ================================================
   INSTAGRAM LINKS PAGE (Linktree style)
   ================================================ */
.linktree{
  margin-top:0;min-height:100vh;display:flex;flex-direction:column;
  align-items:center;padding:60px 24px 40px;background:var(--cream);
  max-width:480px;margin-left:auto;margin-right:auto;
}
.linktree .lt-avatar{
  width:100px;height:100px;border-radius:50%;object-fit:cover;
  border:2px solid var(--border);margin-bottom:16px;
}
.linktree .lt-avatar-placeholder{
  width:100px;height:100px;border-radius:50%;
  background:var(--cream-warm);border:2px solid var(--border);
  margin-bottom:16px;display:flex;align-items:center;justify-content:center;
  font-size:28px;color:var(--sage);
}
.linktree .lt-signature{
  font-family:var(--font-script);font-size:32px;color:var(--forest);
  margin-bottom:4px;
}
.linktree .lt-role{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--sage);margin-bottom:12px;
}
.linktree .lt-bio{
  font-family:var(--font-body);font-style:italic;font-size:13px;
  color:var(--text-light);text-align:center;line-height:1.6;
  margin-bottom:28px;max-width:360px;
}
.linktree .lt-links{
  display:flex;flex-direction:column;gap:10px;width:100%;
  margin-bottom:32px;
}
.linktree .lt-link{
  display:block;width:100%;padding:14px 20px;text-align:center;
  border:1px solid var(--forest);font-family:var(--font-body);
  font-size:10px;letter-spacing:0.3em;text-transform:uppercase;
  color:var(--forest);transition:all var(--transition);
}
.linktree .lt-link:hover{background:var(--forest);color:var(--cream)}

.linktree .lt-shop-label{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.5em;
  text-transform:uppercase;color:var(--sage);margin-bottom:16px;
}
.linktree .lt-shop-grid{
  display:grid;grid-template-columns:1fr 1fr;gap:14px;width:100%;
  margin-bottom:32px;
}
.linktree .lt-product{text-align:center}
.linktree .lt-product img,.linktree .lt-product .lt-product-placeholder{
  width:100%;aspect-ratio:1;object-fit:cover;background:var(--cream-warm);
  border:1px solid var(--border-light);margin-bottom:8px;
}
.linktree .lt-product-name{
  font-family:var(--font-display);font-style:italic;font-size:14px;
  color:var(--charcoal);line-height:1.3;margin-bottom:2px;
}
.linktree .lt-product-price{
  font-family:var(--font-body);font-size:11px;color:var(--forest);
}

.linktree .lt-newsletter{
  width:100%;padding:24px 0;border-top:1px solid var(--border-light);
  text-align:center;
}
.linktree .lt-newsletter h4{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.5em;
  text-transform:uppercase;color:var(--sage);margin-bottom:14px;
}

.linktree .lt-footer{
  margin-top:auto;padding-top:24px;text-align:center;
}
.linktree .lt-footer .lt-social{
  display:flex;gap:16px;justify-content:center;margin-bottom:12px;
}
.linktree .lt-footer .lt-social a{
  font-family:var(--font-body);font-size:8px;letter-spacing:0.3em;
  text-transform:uppercase;color:var(--text-muted);
}
.linktree .lt-footer .lt-copy{
  font-family:var(--font-body);font-size:9px;color:var(--text-muted);
}

/* ================================================
   SALES PAGE
   ================================================ */
.sales-hero{
  margin-top:64px;padding:120px 40px;text-align:center;
  background:var(--cream-warm);
}
.sales-hero .eyebrow{margin-bottom:16px}
.sales-hero h1{
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:clamp(36px,5vw,60px);line-height:1.15;
  color:var(--charcoal);max-width:700px;margin:0 auto 20px;
}
.sales-hero .hero-text{
  font-family:var(--font-body);font-size:15px;color:var(--text-light);
  max-width:520px;margin:0 auto 32px;line-height:1.8;
}

.sales-results{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  max-width:800px;margin:0 auto;
}
.sales-result{
  text-align:center;padding:28px 20px;
  border:1px solid var(--border-light);
}
.sales-result h3{
  font-family:var(--font-display);font-style:italic;font-size:18px;
  color:var(--charcoal);line-height:1.3;
}

/* ================================================
   LANDING PAGE (no nav, no footer, conversion only)
   ================================================ */
.landing-page{
  min-height:100vh;background:var(--cream);
}
.landing-hero{
  padding:80px 40px 60px;text-align:center;max-width:640px;margin:0 auto;
}
.landing-hero .landing-badge{
  display:inline-block;font-family:var(--font-body);font-size:8px;
  letter-spacing:0.5em;text-transform:uppercase;color:var(--forest);
  border:1px solid var(--forest);padding:6px 18px;margin-bottom:28px;
}
.landing-hero h1{
  font-family:var(--font-display);font-weight:300;font-style:italic;
  font-size:clamp(36px,5.5vw,56px);line-height:1.15;
  color:var(--charcoal);margin-bottom:12px;
}
.landing-hero .landing-subtitle{
  font-family:var(--font-body);font-style:italic;font-size:15px;
  color:var(--text-light);margin-bottom:24px;line-height:1.6;
}
.landing-hero .landing-text{
  font-family:var(--font-body);font-size:15px;line-height:1.8;
  color:var(--text);margin-bottom:32px;
}
.landing-form{
  display:flex;flex-direction:column;gap:10px;
  max-width:400px;margin:0 auto;
}
.landing-form input{
  font-family:var(--font-body);font-size:13px;padding:16px 20px;
  border:1px solid var(--border);background:var(--cream-warm);
  color:var(--text);text-align:center;transition:border-color var(--transition);
}
.landing-form input::placeholder{color:var(--sage);font-style:italic}
.landing-form input:focus{border-color:var(--forest)}
.landing-form button{
  font-family:var(--font-body);font-size:9.5px;letter-spacing:0.4em;
  text-transform:uppercase;padding:16px 32px;background:var(--forest);
  color:var(--cream);border:none;cursor:pointer;transition:all var(--transition);
}
.landing-form button:hover{background:var(--forest-light);transform:translateY(-1px)}
.landing-form .landing-privacy{
  font-family:var(--font-body);font-style:italic;font-size:10px;color:var(--sage);
}
.landing-social-proof{
  font-family:var(--font-body);font-style:italic;font-size:12px;
  color:var(--text-muted);margin-top:16px;
}

.landing-section{padding:80px 40px}
.landing-section.alt{background:var(--cream-warm)}
.landing-section .landing-inner{max-width:800px;margin:0 auto}

.landing-features{
  display:grid;grid-template-columns:repeat(3,1fr);gap:28px;
  max-width:800px;margin:0 auto;
}
.landing-feature{text-align:center;padding:20px}
.landing-feature .feature-num{
  font-family:var(--font-display);font-size:36px;font-weight:300;
  color:var(--forest);margin-bottom:8px;
}
.landing-feature .feature-title{
  font-family:var(--font-display);font-style:italic;font-size:18px;
  color:var(--charcoal);margin-bottom:8px;line-height:1.3;
}
.landing-feature .feature-text{
  font-family:var(--font-body);font-size:12px;line-height:1.7;color:var(--text-light);
}

.landing-bullets{
  max-width:540px;margin:0 auto;text-align:center;
}
.landing-bullet{
  font-family:var(--font-body);font-style:italic;font-size:15px;
  color:var(--text);line-height:1.7;padding:12px 0;
  border-bottom:1px solid var(--border-light);
}
.landing-bullet:last-child{border-bottom:none}
.landing-bullet .bullet-ornament{
  color:var(--sage);margin-right:8px;font-style:normal;
}

.landing-author{
  display:grid;grid-template-columns:auto 1fr;gap:24px;
  align-items:center;max-width:540px;margin:0 auto;
}
.landing-author-img{
  width:80px;height:80px;border-radius:50%;object-fit:cover;
  border:1px solid var(--border);
}
.landing-author-text{
  font-family:var(--font-body);font-size:13px;line-height:1.7;color:var(--text);
}
.landing-author-text strong{color:var(--charcoal);font-weight:600}

.landing-cta-final{
  padding:80px 40px;text-align:center;background:var(--cream-warm);
}
.landing-cta-final h2{
  font-family:var(--font-display);font-style:italic;
  font-size:clamp(24px,3.5vw,36px);color:var(--charcoal);margin-bottom:28px;
}

.landing-footer{
  text-align:center;padding:24px;
  font-family:var(--font-body);font-size:9px;color:var(--text-muted);
}

@media(max-width:900px){
  .landing-features{grid-template-columns:1fr}
  .landing-hero{padding:60px 24px 40px}
  .landing-section{padding:60px 24px}
  .landing-author{grid-template-columns:1fr;text-align:center;justify-items:center}
}

/* ================================================
   COMING SOON PAGE
   ================================================ */
.coming-soon{
  min-height:100vh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  padding:60px 40px;background:var(--cream);
}
.coming-soon .section-title{margin-bottom:20px}
.coming-soon .body-text{margin-bottom:36px;max-width:480px}

/* ================================================
   SINGLE POST
   ================================================ */
.single-header{
  margin-top:64px;padding:80px 40px 40px;text-align:center;
}
.single-header .post-cat{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.4em;
  text-transform:uppercase;color:var(--sage);margin-bottom:12px;
}
.single-header h1{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:clamp(32px,4vw,48px);color:var(--charcoal);
  max-width:700px;margin:0 auto 16px;
}
.single-header .post-date{
  font-family:var(--font-body);font-style:italic;font-size:12px;color:var(--text-muted);
}

.single-featured{max-width:900px;margin:0 auto 48px;padding:0 40px}
.single-featured img{width:100%;aspect-ratio:16/9;object-fit:cover}

.single-content{max-width:680px;margin:0 auto;padding:0 40px 80px}
.single-content p{font-size:15px;line-height:1.9;margin-bottom:20px}
.single-content h2{
  font-family:var(--font-display);font-weight:400;font-style:italic;
  font-size:28px;color:var(--charcoal);margin:40px 0 16px;
}
.single-content h3{
  font-family:var(--font-body);font-style:italic;font-size:16px;
  color:var(--charcoal);margin:32px 0 12px;
}
.single-content blockquote{
  border-left:2px solid var(--forest);padding:4px 0 4px 24px;
  margin:24px 0;font-style:italic;color:var(--forest);
}
.single-content ul,.single-content ol{padding-left:20px;margin-bottom:20px}
.single-content li{font-size:15px;line-height:1.9;margin-bottom:8px}
.single-content img{margin:28px 0;border-radius:var(--radius)}

/* ================================================
   FOOTER
   ================================================ */
.site-footer{
  padding:80px 40px 36px;background:var(--forest);
  color:var(--cream);text-align:center;
}
.site-footer .footer-logo{
  font-family:var(--font-display);font-style:italic;
  font-size:28px;color:var(--cream);margin-bottom:10px;
}
.site-footer .footer-tagline{
  font-family:var(--font-body);font-style:italic;font-size:12px;
  color:var(--sage);margin-bottom:36px;
}
.footer-menu{
  display:flex;justify-content:center;gap:28px;
  margin-bottom:40px;flex-wrap:wrap;
}
.footer-menu a{
  font-family:var(--font-body);font-size:9px;letter-spacing:0.28em;
  text-transform:uppercase;color:rgba(250,248,243,0.4);
  transition:color var(--transition);
}
.footer-menu a:hover{color:var(--cream)}
.footer-ornament{font-size:14px;color:var(--sage);margin-bottom:20px;letter-spacing:0.8em}
.footer-copy{
  font-family:var(--font-body);font-size:9px;
  color:rgba(250,248,243,0.2);letter-spacing:0.1em;
}

/* ================================================
   PAGINATION
   ================================================ */
.pagination{text-align:center;padding:40px 0}
.pagination .page-numbers{
  font-family:var(--font-body);font-size:13px;
  padding:8px 14px;color:var(--text-light);
}
.pagination .page-numbers.current{color:var(--forest);font-weight:600}

/* ================================================
   404 PAGE
   ================================================ */
.page-404{
  min-height:80vh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  padding:120px 40px;margin-top:64px;
}
.page-404 .four-oh-four{
  font-family:var(--font-display);font-size:120px;font-weight:300;
  color:var(--forest-pale);line-height:1;margin-bottom:16px;
}

/* ================================================
   FORM SUBMITTED
   ================================================ */
.form-success{
  min-height:80vh;display:flex;flex-direction:column;
  justify-content:center;align-items:center;text-align:center;
  padding:120px 40px;margin-top:64px;
}

/* ================================================
   WOOCOMMERCE OVERRIDES
   ================================================ */
.woocommerce ul.products li.product .woocommerce-loop-product__title{
  font-family:var(--font-display);font-style:italic;font-size:18px;
  color:var(--charcoal);
}
.woocommerce ul.products li.product .price{
  font-family:var(--font-body);font-size:13px;color:var(--forest);
}
.woocommerce .button,
.woocommerce button.button{
  background:var(--forest) !important;color:var(--cream) !important;
  border-radius:var(--radius) !important;font-family:var(--font-body) !important;
  font-size:9px !important;letter-spacing:0.3em !important;
  text-transform:uppercase !important;
}
.woocommerce .button:hover,
.woocommerce button.button:hover{
  background:var(--forest-light) !important;
}

/* ================================================
   RESPONSIVE
   ================================================ */
@media(max-width:1024px){
  .nav-inner{grid-template-columns:auto 1fr auto}
  .nav-left,.nav-right-menu{display:none}
  .mobile-toggle{display:block}
  .nav-logo{justify-self:center}
}

@media(max-width:900px){
  .section{padding:80px 24px}
  .container,.container-narrow,.container-wide{padding:0 24px}

  .hero-slider{height:70vh;min-height:400px}
  .hero-slide .slide-content{padding:40px 24px;max-width:100%}
  .hero-simple{padding:80px 24px 60px}
  .hero-split{grid-template-columns:1fr}
  .hero-split .hero-img{min-height:300px}
  .hero-split .hero-text{padding:48px 24px}

  .featured-block{grid-template-columns:1fr}
  .featured-block--reverse{direction:ltr}
  .featured-img{min-height:300px}
  .featured-content{padding:40px 24px}

  .services-grid{grid-template-columns:1fr}
  .post-grid{grid-template-columns:1fr}
  .testimonials-grid{grid-template-columns:1fr}
  .pillars-grid{grid-template-columns:1fr}
  .product-grid{grid-template-columns:1fr 1fr}
  .sales-results{grid-template-columns:1fr}
  .contact-grid{grid-template-columns:1fr}

  .freebie-box{flex-direction:column;text-align:center}
  .freebie-mock{flex:none;width:200px;height:290px}
  .form-stack{max-width:100%}

  .newsletter-form{flex-direction:column}
  .newsletter-form input,.newsletter-form button{width:100%}

  .footer-menu{flex-direction:column;gap:12px}

  .single-content{padding:0 24px 60px}
  .single-featured{padding:0 24px}

  .linktree{padding:40px 20px}
}

@media(max-width:600px){
  .product-grid{grid-template-columns:1fr}
  .hero-slider{height:60vh}
  .marquee-item{font-size:16px}
  .linktree .lt-shop-grid{grid-template-columns:1fr}
}
