/*
Theme Name: Doula Sabrina
Theme URI: https://doulasabrina.com
Author: Sabrina
Description: A refined, elegant postpartum doula website theme — cobalt blue, periwinkle, and warm gold.
Version: 1.0.0
License: GNU General Public License v2 or later
Text Domain: doulasabrina
*/

:root {
  --cobalt:     #0e4b8b;
  --periwinkle: #6798dd;
  --gold:       #d1a76a;
  --gold-light: #e8c898;
  --white:      #ffffff;
  --off-white:  #f8f5f0;
  --text-dark:  #1a1a3e;
  --text-muted: #5a5a7a;
  --text-mid:   #5a5a7a;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: 'Montserrat', sans-serif;
  background: var(--off-white);
  color: var(--text-dark);
  overflow-x: hidden;
  line-height: 1.6;
}
img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; transition: color 0.3s; }

h1,h2,h3,h4,h5 { font-family: 'Cormorant Garamond', Georgia, serif; font-weight: 300; line-height: 1.1; color: var(--text-dark); }
h1 { font-size: clamp(40px,6vw,80px); }
h2 { font-size: clamp(32px,4.5vw,58px); }
h3 { font-size: clamp(22px,3vw,30px); }
p  { font-size: 13px; font-weight: 300; line-height: 2; color: var(--text-muted); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 5%; }
.section-pad { padding: 100px 0; }
.eyebrow { font-size:9px; font-weight:500; letter-spacing:5px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:20px; }

.btn-primary {
  display:inline-block; font-family:'Montserrat',sans-serif;
  font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  padding:16px 40px; background:var(--gold); color:var(--cobalt);
  border:none; cursor:pointer; transition:all 0.3s;
}
.btn-primary:hover { background:var(--gold-light); transform:translateY(-2px); color:var(--cobalt); }

.btn-ghost {
  display:inline-block; font-family:'Montserrat',sans-serif;
  font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase;
  padding:16px 40px; border:1px solid rgba(103,152,221,0.5); color:rgba(255,255,255,0.85);
  background:transparent; cursor:pointer; transition:all 0.3s;
}
.btn-ghost:hover { border-color:var(--periwinkle); color:var(--white); }

.btn-dark {
  display:inline-block; font-family:'Montserrat',sans-serif;
  font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  padding:16px 40px; background:var(--cobalt); color:var(--white);
  border:none; cursor:pointer; transition:all 0.3s;
}
.btn-dark:hover { background:#0d4278; transform:translateY(-2px); color:var(--white); }

/* NAV */
#site-header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(14,75,139,0.97); backdrop-filter:blur(12px);
  height:72px; border-bottom:1px solid rgba(103,152,221,0.18);
}
.header-inner { display:flex; align-items:center; justify-content:space-between; height:72px; padding:0 5%; }
.site-logo img { height:44px; width:auto; }
.site-logo .text-logo { font-family:'Cormorant Garamond',serif; font-size:22px; font-weight:300; letter-spacing:4px; color:var(--white); text-transform:uppercase; }
#site-navigation ul { display:flex; gap:36px; list-style:none; }
#site-navigation ul li a { font-family:'Montserrat',sans-serif; font-size:10px; font-weight:500; letter-spacing:3px; text-transform:uppercase; color:rgba(255,255,255,0.75); }
#site-navigation ul li a:hover, #site-navigation ul li.current-menu-item a { color:var(--gold); }
.header-cta { font-family:'Montserrat',sans-serif; font-size:10px; font-weight:600; letter-spacing:2px; text-transform:uppercase; padding:10px 24px; border:1px solid var(--gold); color:var(--gold); transition:all 0.3s; }
.header-cta:hover { background:var(--gold); color:var(--cobalt); }
.menu-toggle { display:none; background:none; border:none; cursor:pointer; padding:8px; }
.menu-toggle span { display:block; width:24px; height:1.5px; background:var(--white); margin:5px 0; transition:all 0.3s; }
.page-content { padding-top:72px; }

/* HERO */
.hero { min-height:100vh; background:var(--cobalt); position:relative; overflow:hidden; display:flex; align-items:center; }
.hero-bg { position:absolute; inset:0; background: radial-gradient(ellipse 70% 60% at 80% 50%, rgba(103,152,221,0.35) 0%, transparent 70%), radial-gradient(ellipse 40% 40% at 20% 80%, rgba(209,167,106,0.15) 0%, transparent 60%); }
.hero-bg::before { content:''; position:absolute; inset:0; background-image:repeating-linear-gradient(-45deg,transparent,transparent 60px,rgba(103,152,221,0.04) 60px,rgba(103,152,221,0.04) 61px); }
.hero-content { position:relative; z-index:2; padding:80px 5%; max-width:860px; }
.hero-eyebrow { font-size:10px; font-weight:500; letter-spacing:5px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:28px; opacity:0; animation:fadeUp 0.8s 0.3s forwards; }
.hero h1 { color:var(--white); margin-bottom:32px; opacity:0; animation:fadeUp 0.8s 0.5s forwards; }
.hero h1 em { font-style:italic; color:var(--gold); }
.hero .hero-sub { font-size:13px; font-weight:300; letter-spacing:1.5px; line-height:1.9; color:rgba(255,255,255,0.65); max-width:480px; margin-bottom:52px; opacity:0; animation:fadeUp 0.8s 0.7s forwards; }
.hero-actions { display:flex; gap:20px; flex-wrap:wrap; opacity:0; animation:fadeUp 0.8s 0.9s forwards; }
.hero-mark { position:absolute; right:6%; top:50%; transform:translateY(-50%); opacity:0.08; width:min(420px,45vw); animation:floatMark 6s ease-in-out infinite; }
@keyframes floatMark { 0%,100%{transform:translateY(-50%) scale(1);}50%{transform:translateY(-53%) scale(1.02);} }
@keyframes fadeUp { from{opacity:0;transform:translateY(24px);}to{opacity:1;transform:translateY(0);} }

/* WARM BANNER */
.warm-banner { background:var(--cobalt); padding:52px 5%; text-align:center; border-top:1px solid rgba(103,152,221,0.15); }
.warm-banner p { font-family:'Cormorant Garamond',serif; font-size:clamp(18px,2.5vw,26px); font-weight:300; font-style:italic; color:rgba(255,255,255,0.85); letter-spacing:1px; max-width:760px; margin:0 auto; }

/* ABOUT TEASER */
.about-teaser { background:var(--off-white); padding:100px 5%; }
.about-teaser-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.about-teaser-quote { padding-left:40px; border-left:2px solid rgba(209,167,106,0.3); }
.about-teaser-quote blockquote { font-family:'Cormorant Garamond',serif; font-size:24px; font-weight:300; font-style:italic; color:var(--text-dark); line-height:1.7; margin-bottom:24px; }
.about-teaser-quote cite { font-size:9px; font-weight:500; letter-spacing:4px; text-transform:uppercase; color:var(--gold); font-style:normal; }

/* SERVICES TEASER */
.services-teaser { background:var(--white); padding:100px 5%; }
.services-teaser-header { text-align:center; max-width:560px; margin:0 auto 64px; }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:2px; background:rgba(103,152,221,0.1); }

/* SERVICE CARD */
.service-card { background:var(--white); padding:52px 40px; position:relative; overflow:hidden; transition:background 0.3s; }
.service-card::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--gold); transform:scaleX(0); transition:transform 0.4s; }
.service-card:hover::before { transform:scaleX(1); }
.service-card:hover { background:#fdfbf8; }
.service-num { font-family:'Cormorant Garamond',serif; font-size:64px; font-weight:300; color:rgba(103,152,221,0.1); position:absolute; top:24px; right:28px; line-height:1; pointer-events:none; }
.service-card h3 { font-size:26px; color:var(--text-dark); margin-bottom:16px; }
.service-card p { margin-bottom:24px; }
.service-includes { list-style:none; }
.service-includes li { font-size:11px; font-weight:400; letter-spacing:0.5px; color:var(--text-muted); padding:5px 0; display:flex; align-items:center; gap:10px; }
.service-includes li::before { content:'—'; color:var(--gold); font-size:10px; }

/* PRICING */
.pricing-section { background:var(--cobalt); padding:80px 5%; }
.pricing-header { text-align:center; margin-bottom:56px; }
.pricing-header h2 { color:var(--white); }
.pricing-header h2 em { color:var(--gold); }
.pricing-header p { color:rgba(255,255,255,0.6); max-width:500px; margin:0 auto; }
.pricing-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; max-width:1000px; margin:0 auto; }
.price-card { padding:40px 28px; text-align:center; border:1px solid rgba(103,152,221,0.2); position:relative; transition:border-color 0.3s; }
.price-card:hover,.price-card.featured { border-color:var(--gold); }
.price-card.featured::before { content:'MOST POPULAR'; position:absolute; top:-1px; left:50%; transform:translateX(-50%); background:var(--gold); color:var(--cobalt); font-size:8px; font-weight:700; letter-spacing:3px; padding:4px 16px; white-space:nowrap; }
.price-tier { font-size:9px; font-weight:500; letter-spacing:4px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; display:block; }
.price-amount { font-family:'Cormorant Garamond',serif; font-size:52px; font-weight:300; color:var(--white); line-height:1; }
.price-unit { font-size:10px; font-weight:300; letter-spacing:2px; color:rgba(255,255,255,0.4); display:block; margin-bottom:28px; }
.price-features { list-style:none; margin-bottom:36px; }
.price-features li { font-size:11px; font-weight:300; color:rgba(255,255,255,0.65); padding:7px 0; border-bottom:1px solid rgba(103,152,221,0.1); }

/* SLIDING SCALE */
.sliding-scale-section { background:var(--off-white); padding:80px 5%; border-top:1px solid rgba(103,152,221,0.12); }
.sliding-scale-section .pricing-header h2 { color:var(--text-dark); }
.sliding-scale-section .pricing-header h2 em { color:var(--cobalt); }
.sliding-scale-section .pricing-header p { color:var(--text-muted); max-width:560px; }
.sliding-scale-section .price-card { background:var(--white); border:1px solid rgba(103,152,221,0.15); }
.sliding-scale-section .price-card:hover { border-color:var(--gold); }
.sliding-scale-section .price-amount { color:var(--cobalt); }
.sliding-scale-section .price-tier { color:var(--gold); }

/* ABOUT PAGE */
.about-page { background:var(--off-white); padding:100px 5%; }
.about-grid { display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:start; }
.about-img-block { position:relative; }
.about-img-block img { width:100%; aspect-ratio:3/4; object-fit:cover; }
.about-img-placeholder { width:100%; aspect-ratio:3/4; background:linear-gradient(145deg,var(--cobalt) 0%,var(--periwinkle) 100%); display:flex; align-items:center; justify-content:center; }
.about-gold-corner { position:absolute; bottom:-24px; right:-24px; width:120px; height:120px; border:2px solid var(--gold); opacity:0.4; pointer-events:none; }
.about-values { margin-top:52px; display:grid; grid-template-columns:1fr 1fr; gap:28px; }
.value-item { border-left:2px solid var(--gold); padding-left:20px; }
.value-title { font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--text-dark); margin-bottom:8px; display:block; }
.value-desc { font-size:12px; font-weight:300; line-height:1.8; color:var(--text-muted); }
.credentials { margin-top:48px; padding:32px 36px; background:var(--cobalt); }
.cred-label { font-size:9px; font-weight:500; letter-spacing:4px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:16px; }
.cred-list { list-style:none; }
.cred-list li { font-size:12px; font-weight:300; letter-spacing:1px; color:rgba(255,255,255,0.75); padding:6px 0; border-bottom:1px solid rgba(103,152,221,0.12); display:flex; align-items:center; gap:12px; }
.cred-list li::before { content:'◆'; color:var(--gold); font-size:7px; flex-shrink:0; }
.credentials a { color:rgba(255,255,255,0.75); text-decoration:underline; text-decoration-color:var(--gold); text-underline-offset:3px; }
.credentials a:hover { color:var(--gold); }

/* CONTACT PAGE */
.contact-page { background:var(--off-white); padding:100px 5%; }
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:80px; align-items:start; }
.contact-details { display:flex; flex-direction:column; gap:28px; margin-top:48px; }
.contact-item { display:flex; align-items:flex-start; gap:20px; }
.contact-icon { width:40px; height:40px; flex-shrink:0; background:var(--cobalt); border:1px solid rgba(103,152,221,0.3); display:flex; align-items:center; justify-content:center; }
.contact-icon svg { width:16px; height:16px; }
.contact-label { font-size:8px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:4px; }
.contact-value { font-size:13px; font-weight:300; color:var(--text-dark); }
.availability-box { margin-top:52px; padding:32px; background:var(--cobalt); }
.availability-box .eyebrow { margin-bottom:16px; }
.availability-box p { color:rgba(255,255,255,0.65); }

/* CONTACT FORM */
.contact-form-wrap { background:var(--white); padding:52px 48px; border-top:3px solid var(--gold); }
.contact-form-wrap h2 { font-size:32px; margin-bottom:36px; color:var(--text-dark); }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.form-group { margin-bottom:24px; }
.form-group label { display:block; font-size:8px; font-weight:600; letter-spacing:3px; text-transform:uppercase; color:var(--cobalt); margin-bottom:10px; }
.form-group input,.form-group select,.form-group textarea,
.wpcf7 input[type="text"],.wpcf7 input[type="email"],.wpcf7 input[type="tel"],.wpcf7 select,.wpcf7 textarea {
  width:100%; padding:14px 16px; border:1px solid rgba(103,152,221,0.25); background:var(--off-white);
  font-family:'Montserrat',sans-serif; font-size:12px; font-weight:300; color:var(--text-dark);
  outline:none; transition:border-color 0.3s; border-radius:0; -webkit-appearance:none;
}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,
.wpcf7 input:focus,.wpcf7 select:focus,.wpcf7 textarea:focus { border-color:var(--gold); background:var(--white); }
.form-group textarea,.wpcf7 textarea { height:120px; resize:vertical; }
.wpcf7 input[type="submit"] {
  width:100%; cursor:pointer; font-family:'Montserrat',sans-serif;
  font-size:10px; font-weight:600; letter-spacing:3px; text-transform:uppercase;
  padding:16px 40px; background:var(--gold); color:var(--cobalt); border:none; transition:all 0.3s;
}
.wpcf7 input[type="submit"]:hover { background:var(--gold-light); }

/* FOOTER */
#site-footer { background:var(--cobalt); border-top:1px solid rgba(103,152,221,0.15); padding:60px 5% 32px; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr; gap:60px; margin-bottom:52px; }
.footer-tagline { font-family:'Cormorant Garamond',serif; font-size:18px; font-weight:300; font-style:italic; color:rgba(255,255,255,0.5); margin-top:16px; line-height:1.6; }
.footer-col-title { font-size:8px; font-weight:600; letter-spacing:4px; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:20px; }
.footer-links { list-style:none; }
.footer-links li { margin-bottom:12px; }
.footer-links a { font-size:11px; font-weight:300; letter-spacing:1px; color:rgba(255,255,255,0.5); }
.footer-links a:hover { color:var(--gold); }
.footer-bottom { border-top:1px solid rgba(103,152,221,0.12); padding-top:28px; display:flex; justify-content:space-between; align-items:center; }
.footer-copy { font-size:10px; font-weight:300; letter-spacing:1px; color:rgba(255,255,255,0.3); }

/* FADE IN */
.fade-in { opacity:0; transform:translateY(20px); transition:opacity 0.7s ease,transform 0.7s ease; }
.fade-in.visible { opacity:1; transform:translateY(0); }

/* RESPONSIVE */
@media (max-width:900px) {
  .about-grid,.contact-grid,.services-grid,.pricing-grid,.footer-grid,.about-teaser-grid { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
  .about-values { grid-template-columns:1fr; }
  .menu-toggle { display:block; }
  #site-navigation { display:none; }
  #site-navigation.open { display:block; position:absolute; top:72px; left:0; right:0; background:rgba(14,75,139,0.98); padding:24px 5%; }
  #site-navigation.open ul { flex-direction:column; gap:20px; }
  .hero-mark { display:none; }
  .header-cta { display:none; }
  .about-teaser-quote { padding-left:0; border-left:none; border-top:2px solid rgba(209,167,106,0.3); padding-top:40px; }
}

/* Highlight box for blog posts */
.highlight-box {
  border-left: 3px solid #d1a76a;
  background: #ffffff;
  padding: 24px 28px;
  margin: 2.5em 0;
}

.highlight-box p {
  font-size: 16px;
  color: #1a1a3e;
  margin-bottom: 0;
}

/* Pull quote styling for blog posts */
.wp-block-quote.pull-quote {
  background: #0e4b8b;
  color: #f8f5f0;
  padding: 36px 40px;
  border-left: none;
  position: relative;
}

.wp-block-quote.pull-quote p {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.2rem;
  font-style: italic;
  color: #f8f5f0;
  line-height: 1.7;
  padding-top: 20px;
}

.wp-block-quote.pull-quote cite {
  color: #6798dd;
}

.wp-block-quote.pull-quote::before {
  content: '\201C';
  font-family: 'Cormorant Garamond', serif;
  font-size: 6rem;
  color: #d1a76a;
  opacity: 0.4;
  position: absolute;
  top: -10px;
  left: 28px;
  line-height: 1;
}