/* Elevate Her AI — Shared Stylesheet */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500&family=Playfair+Display:wght@400;500&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --cream:       #FAF7F4;
  --brown-dark:  #2C1810;
  --brown-mid:   #6B4E3D;
  --brown-pri:   #5C3D2E;
  --white:       #FFFFFF;
  --border:      rgba(92, 61, 46, 0.15);
  --beige-bg:    rgba(243, 237, 229, 0.45);
  --icon-circle: rgba(92, 61, 46, 0.10);
  --badge-bg:    #E8DDD0;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', sans-serif;
  font-weight: 300;
  background-color: var(--cream);
  color: var(--brown-mid);
  line-height: 1.6;
  hyphens: none;
  -webkit-hyphens: none;
  overflow-wrap: break-word;
}

/* ── NAV ───────────────────────────────────────────────────── */
nav {
  position: sticky; top: 0; z-index: 100;
  background: var(--cream);
  border-bottom: 1px solid var(--border);
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px 32px;
}
.nav-brand { display: flex; flex-direction: column; gap: 2px; text-decoration: none; }
.nav-brand-name {
  font-family: 'Playfair Display', serif; font-weight: 400;
  font-size: 28px; line-height: 36px; color: var(--brown-pri);
}
.nav-brand-tag { font-size: 12px; font-weight: 300; line-height: 16px; color: var(--brown-mid); }
.nav-links { display: flex; align-items: center; gap: 24px; list-style: none; }
.nav-links a {
  font-size: 16px; font-weight: 300; color: var(--brown-dark);
  text-decoration: none; transition: color 0.2s;
}
.nav-links a:hover { color: var(--brown-pri); }
.nav-links a.btn-primary,
.nav-links a.btn-primary:hover { background: #3E2212; color: #fff; transform: none; opacity:1; }
.nav-links a.btn-primary:hover { opacity: 0.88; }

/* ── BUTTONS ───────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 24px; border-radius: 9999px;
  font-family: 'Inter', sans-serif; font-size: 16px; font-weight: 500; line-height: 24px;
  cursor: pointer; text-decoration: none; border: none;
  transition: opacity 0.2s, transform 0.15s;
}
.btn:hover { opacity: 0.88; transform: translateY(-1px); }
.btn-primary { background: var(--brown-pri); color: var(--white); }
.btn-white   { background: var(--white);      color: var(--brown-pri); }
.btn-outline {
  background: transparent; color: var(--brown-pri);
  border: 1.5px solid var(--brown-pri);
}
.btn-outline:hover { background: var(--brown-pri); color: var(--white); opacity: 1; }

/* ── FOOTER ────────────────────────────────────────────────── */
footer {
  background: var(--beige-bg);
  border-top: 1px solid var(--border);
  padding: 48px 32px;
  display: flex; flex-direction: column; gap: 24px;
}
.footer-brand { display: flex; flex-direction: column; gap: 4px; text-decoration: none; }
.footer-brand-name {
  font-family: 'Playfair Display', serif; font-weight: 400;
  font-size: 24px; line-height: 32px; color: var(--brown-pri);
}
.footer-brand-tag { font-size: 12px; font-weight: 300; color: var(--brown-mid); }
.footer-bottom {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 24px; border-top: 1px solid var(--border);
  flex-wrap: wrap; gap: 12px;
}
.footer-copy { font-size: 14px; font-weight: 300; color: var(--brown-mid); }
.footer-links { display: flex; gap: 24px; }
.footer-links a { font-size: 14px; font-weight: 300; color: var(--brown-mid); text-decoration: none; }
.footer-links a:hover { color: var(--brown-pri); }
.footer-right { display: flex; align-items: center; gap: 24px; flex-wrap: wrap; }
.footer-social { display: flex; gap: 16px; align-items: center; }
.footer-social a { color: var(--brown-mid); text-decoration: none; transition: color 0.2s; display: flex; }
.footer-social a:hover { color: var(--brown-pri); }
.footer-social-link { color: var(--brown-mid); text-decoration: none; transition: color 0.2s; display: flex; }
.footer-social-link:hover { color: var(--brown-pri); }

/* ── TESTIMONIALS ──────────────────────────────────────────── */
.testimonials-section {
  background: var(--brown-dark);
  padding: 80px 32px;
}
.testimonial-inner {
  max-width: 640px;
  margin: 0 auto;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 16px;
  padding: 48px 52px;
}
.testimonial-label {
  font-size: 11px; font-weight: 500; letter-spacing: 0.14em;
  text-transform: uppercase; color: rgba(255,255,255,0.4);
  margin-bottom: 20px;
}
.testimonial-quote {
  font-family: 'Playfair Display', serif;
  font-size: 18px; font-weight: 400; line-height: 32px;
  color: rgba(255,255,255,0.90);
  margin-bottom: 28px;
  font-style: italic;
  text-wrap: pretty;
}
.testimonial-divider {
  width: 32px; height: 1px;
  background: rgba(255,255,255,0.20);
  margin-bottom: 20px;
}
.testimonial-attribution {
  font-size: 14px; font-weight: 400;
  color: rgba(255,255,255,0.50);
  letter-spacing: 0.02em;
}
.testimonial-attribution strong { color: rgba(255,255,255,0.85); font-weight: 500; }

/* ── PAGE HERO (inner pages) ───────────────────────────────── */
.page-hero {
  padding: 64px 32px 48px;
  border-bottom: 1px solid var(--border);
  background: var(--cream);
}
.page-hero-inner { max-width: 760px; margin: 0 auto; }
.breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 300; color: var(--brown-mid);
  margin-bottom: 24px;
}
.breadcrumb a { color: var(--brown-pri); text-decoration: none; }
.breadcrumb a:hover { text-decoration: underline; }
.breadcrumb-sep { color: var(--border); }

/* ── BLOG CARD (reusable) ──────────────────────────────────── */
.blog-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 12px; padding: 25px;
  display: flex; flex-direction: column; gap: 12px;
  transition: box-shadow 0.2s, transform 0.15s;
  text-decoration: none;
}
.blog-card:hover { box-shadow: 0 4px 20px rgba(92,61,46,0.10); transform: translateY(-2px); }
.blog-date { font-size: 14px; font-weight: 300; line-height: 20px; color: var(--brown-mid); }
.blog-title {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 20px; line-height: 28px; color: var(--brown-dark);
}
.blog-excerpt { font-size: 16px; font-weight: 300; line-height: 26px; color: var(--brown-mid); flex: 1; text-wrap: pretty; }
.read-more {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 16px; font-weight: 300; color: var(--brown-pri);
  text-decoration: none; margin-top: 8px; transition: gap 0.2s;
}
.read-more:hover { gap: 10px; }

/* ── TAG / BADGE ───────────────────────────────────────────── */
.tag {
  display: inline-flex; align-items: center;
  padding: 4px 12px; border-radius: 9999px;
  font-size: 13px; font-weight: 300; letter-spacing: 0.01em;
  background: var(--badge-bg); color: var(--brown-dark);
  text-decoration: none;
}

/* ── PROSE (article body) ──────────────────────────────────── */
.prose {
  max-width: 760px; margin: 0 auto;
  padding: 48px 32px 64px;
  font-size: 18px; font-weight: 300; line-height: 32px;
  color: var(--brown-mid);
}
.prose h2 {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 32px; line-height: 40px; color: var(--brown-dark);
  margin: 48px 0 20px;
}
.prose h3 {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 24px; line-height: 32px; color: var(--brown-dark);
  margin: 36px 0 16px;
}
.prose p { margin-bottom: 24px; text-wrap: pretty; }
.prose p:last-child { margin-bottom: 0; }
.prose strong { font-weight: 500; color: var(--brown-dark); }
.prose em { font-style: italic; }
.prose blockquote {
  border-left: 3px solid var(--brown-pri);
  padding: 12px 24px; margin: 32px 0;
  font-style: italic; font-size: 20px; line-height: 32px;
  color: var(--brown-pri); background: rgba(92,61,46,0.04);
  border-radius: 0 8px 8px 0;
}
.prose ul, .prose ol {
  margin: 0 0 24px 0; padding-left: 0;
  list-style: none;
}
.prose ul li, .prose ol li {
  display: flex; gap: 12px; align-items: flex-start;
  margin-bottom: 12px; font-size: 18px; line-height: 28px;
}
.prose ul li::before {
  content: ''; flex-shrink: 0;
  width: 6px; height: 6px; border-radius: 9999px;
  background: var(--brown-pri); margin-top: 11px;
}
.prose ol { counter-reset: prose-counter; }
.prose ol li::before {
  content: counter(prose-counter); counter-increment: prose-counter;
  flex-shrink: 0; font-weight: 500; font-size: 14px;
  color: var(--brown-pri); min-width: 24px;
}
.prose hr {
  border: none; border-top: 1px solid var(--border);
  margin: 48px 0;
}
.prose .medium-link {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; color: var(--brown-mid); text-decoration: none;
  padding: 12px 20px; border: 1px solid var(--border);
  border-radius: 8px; margin-top: 16px; transition: border-color 0.2s;
}
.prose .medium-link:hover { border-color: var(--brown-pri); color: var(--brown-pri); }

/* ── POST HEADER ───────────────────────────────────────────── */
.post-header {
  max-width: 760px; margin: 0 auto;
  padding: 48px 32px 0;
}
.post-meta {
  display: flex; align-items: center; gap: 16px;
  font-size: 14px; font-weight: 300; color: var(--brown-mid);
  margin-top: 16px; flex-wrap: wrap;
}
.post-meta-sep { color: var(--border); }
.post-title {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 48px; line-height: 58px; color: var(--brown-dark);
  margin: 20px 0 0;
}

/* ── RELATED POSTS ─────────────────────────────────────────── */
.related-posts {
  background: var(--beige-bg);
  padding: 64px 32px;
  margin-top: 0;
}
.related-posts-inner { max-width: 1037px; margin: 0 auto; }
.related-heading {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 32px; line-height: 40px; color: var(--brown-dark);
  margin-bottom: 32px;
}
.related-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}

/* ── BOOKING PAGE ──────────────────────────────────────────── */
.booking-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 32px;
  max-width: 1037px; margin: 0 auto;
  padding: 0 32px 64px;
}
.booking-package {
  background: linear-gradient(135deg, rgba(92,61,46,0.05) 0%, rgba(139,111,71,0.10) 100%);
  border: 1px solid rgba(92,61,46,0.20);
  border-radius: 16px; padding: 40px;
  display: flex; flex-direction: column; gap: 20px;
}
.booking-package-label {
  font-size: 13px; font-weight: 500; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--brown-pri);
}
.booking-package-title {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 28px; line-height: 36px; color: var(--brown-dark);
}
.booking-package-desc { font-size: 16px; font-weight: 300; line-height: 26px; color: var(--brown-mid); }
.booking-list { list-style: none; display: flex; flex-direction: column; gap: 12px; }
.booking-list li {
  display: flex; align-items: flex-start; gap: 12px;
  font-size: 16px; font-weight: 300; line-height: 24px; color: var(--brown-mid);
}
.bullet-dot {
  width: 6px; height: 6px; border-radius: 9999px;
  background: var(--brown-pri); flex-shrink: 0; margin-top: 9px;
}
.booking-form-section {
  max-width: 760px; margin: 0 auto;
  padding: 0 32px 64px;
}
.booking-form-section h2 {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 32px; line-height: 40px; color: var(--brown-dark);
  margin-bottom: 8px;
}
.booking-form-section p { font-size: 16px; color: var(--brown-mid); margin-bottom: 32px; }
.form-group { display: flex; flex-direction: column; gap: 8px; margin-bottom: 20px; }
.form-label { font-size: 14px; font-weight: 500; color: var(--brown-dark); }
.form-input, .form-select, .form-textarea {
  padding: 12px 16px; border: 1px solid var(--border); border-radius: 8px;
  font-family: 'Inter', sans-serif; font-size: 16px; font-weight: 300;
  color: var(--brown-dark); background: var(--white);
  transition: border-color 0.2s; outline: none; resize: vertical;
}
.form-input:focus, .form-select:focus, .form-textarea:focus {
  border-color: var(--brown-pri);
}
.form-textarea { min-height: 120px; }
.calendly-placeholder {
  background: var(--beige-bg); border: 2px dashed var(--border);
  border-radius: 16px; padding: 48px; text-align: center;
  margin: 0 32px 64px; max-width: calc(1037px - 0px);
  margin-left: auto; margin-right: auto;
}
.calendly-placeholder h3 {
  font-family: 'Playfair Display', serif; font-size: 24px; color: var(--brown-dark);
  margin-bottom: 12px;
}
.calendly-placeholder p { font-size: 14px; color: var(--brown-mid); }

/* ── RESOURCES PAGE ────────────────────────────────────────── */
.resource-card {
  background: var(--white); border: 1px solid var(--border);
  border-radius: 16px; padding: 40px;
  display: flex; align-items: flex-start; gap: 32px;
  max-width: 1037px; margin: 0 auto 32px;
}
.resource-icon {
  width: 64px; height: 64px; border-radius: 12px;
  background: var(--icon-circle); display: flex;
  align-items: center; justify-content: center; flex-shrink: 0;
}
.resource-content { flex: 1; }
.resource-type {
  font-size: 12px; font-weight: 500; letter-spacing: 0.1em;
  text-transform: uppercase; color: var(--brown-pri);
  margin-bottom: 8px; display: block;
}
.resource-title {
  font-family: 'Playfair Display', serif; font-weight: 500;
  font-size: 24px; line-height: 32px; color: var(--brown-dark);
  margin-bottom: 12px;
}
.resource-desc { font-size: 16px; font-weight: 300; line-height: 26px; color: var(--brown-mid); margin-bottom: 24px; }

/* ─── SUBSCRIBE FORM ──────────────────────────────────────── */
.subscribe-form {
  display: flex;
  max-width: 420px;
  margin: 0 auto;
  border: 1px solid var(--border);
  border-radius: 9999px;
  overflow: hidden;
  background: white;
  box-shadow: 0 2px 12px rgba(92,61,46,0.07);
}
.subscribe-form input[type="email"] {
  flex: 1; min-width: 0;
  border: none; outline: none;
  padding: 14px 20px;
  font-family: 'Inter', sans-serif;
  font-size: 15px; font-weight: 300;
  color: var(--brown-dark);
  background: transparent;
}
.subscribe-form input[type="email"]::placeholder { color: var(--brown-mid); opacity: 0.6; }
.subscribe-form button {
  background: var(--brown-pri); color: white;
  border: none; cursor: pointer;
  padding: 14px 24px;
  font-family: 'Inter', sans-serif;
  font-size: 14px; font-weight: 500;
  border-radius: 9999px;
  white-space: nowrap;
  transition: opacity 0.2s;
}
.subscribe-form button:hover { opacity: 0.88; }

/* Nav brand tag hidden when not needed */
.nav-brand-tag-hidden { display: none; }

/* ── MOBILE ────────────────────────────────────────────────── */
@media (max-width: 768px) {

  /* Consistent horizontal padding — never flush to edge */
  section { padding-left: 20px !important; padding-right: 20px !important; }

  /* NAV: hide all text links except Blog, Resources, Book */
  nav { padding: 14px 20px; gap: 24px; }
  .nav-links li { display: none !important; }
  .nav-links li:nth-child(3),
  .nav-links li:nth-child(4),
  .nav-links li:nth-child(6) { display: list-item !important; }
  .nav-links { gap: 16px; }
  .nav-links a:not(.btn) { font-size: 14px; }
  .nav-brand-name { font-size: 22px; line-height: 28px; }

  /* PAGE HERO */
  .page-hero { padding: 40px 20px 32px; }
  .page-hero h1 { font-size: 36px !important; line-height: 44px !important; }

  /* PROSE */
  .prose { font-size: 16px; line-height: 28px; padding: 32px 20px 48px; }
  .prose h2 { font-size: 24px; line-height: 32px; }
  .prose h3 { font-size: 20px; line-height: 28px; }
  .prose blockquote { font-size: 17px; padding: 12px 16px; }

  /* POST */
  .post-header { padding: 32px 20px 0; }
  .post-title { font-size: 32px !important; line-height: 42px !important; }

  /* RELATED POSTS */
  .related-posts { padding: 48px 20px; }
  .related-grid { grid-template-columns: 1fr; }

  /* BOOKING */
  .booking-grid { grid-template-columns: 1fr; padding: 0 20px 48px; }
  .booking-package { padding: 28px 24px; }
  .booking-form-section { padding: 0 20px 48px; }
  .form-2col { grid-template-columns: 1fr !important; }

  /* RESOURCE CARDS */
  .resource-card { flex-direction: column; gap: 20px; padding: 24px 20px; margin: 0 20px 24px; }
  .free-reading-grid { grid-template-columns: 1fr !important; }
  .free-reading-grid a:nth-child(3) { display: none; }

  /* CONTACT */
  .contact-layout { grid-template-columns: 1fr !important; gap: 40px !important; }
  .contact-section { padding: 48px 20px 64px !important; }

  /* BLOG LISTING */
  .blog-posts-grid { grid-template-columns: 1fr !important; }
  .blog-posts-section { padding: 48px 20px 64px !important; }

  /* START HERE */
  .start-here-body { padding: 48px 20px 64px !important; }

  /* TESTIMONIALS */
  .testimonials-section { padding: 48px 20px; }
  .testimonial-inner { padding: 32px 28px; }
  .testimonial-quote { font-size: 17px; line-height: 30px; }

  /* FOOTER */
  footer { padding: 40px 20px; }
  .footer-bottom { flex-direction: column; align-items: flex-start; }
  .footer-right { flex-direction: column; align-items: flex-start; gap: 16px; }

  /* SUBSCRIBE FORM */
  .subscribe-form { max-width: 100%; }

}
