/* ===== BASE ===== */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: 'Mulish', sans-serif; color: #322D28; background: #FBF6F0; line-height: 1.6; -webkit-font-smoothing: antialiased; overflow-x: hidden; }
::selection { background: #EAD7C6; }
details > summary { list-style: none; cursor: pointer; }
details > summary::-webkit-details-marker { display: none; }

/* ===== ANIMATIONS ===== */
@keyframes floaty { 0%,100% { transform: translateY(0); } 50% { transform: translateY(-14px); } }

/* ===== NAV ===== */
.site-nav {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  padding: 16px clamp(20px, 5vw, 72px);
  background: rgba(251,246,240,0.88); backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(50,45,40,0.07);
  font-family: 'Mulish', sans-serif;
}
.nav-logo { font-family: 'Cormorant Garamond', serif; font-size: 23px; font-weight: 700; color: #322D28; text-decoration: none; letter-spacing: 0.4px; white-space: nowrap; }
.nav-links { display: flex; align-items: center; gap: clamp(10px, 2vw, 30px); font-size: 14.5px; flex-wrap: wrap; }
.nav-links a { text-decoration: none; color: #5a5249; font-weight: 600; white-space: nowrap; transition: color 0.2s; }
.nav-links a:hover, .nav-links a.active { color: #C56B4C; font-weight: 700; }
.nav-links .nav-cta { background: #C56B4C; color: #fff !important; font-weight: 700 !important; padding: 11px 22px; border-radius: 100px; box-shadow: 0 6px 18px rgba(197,107,76,0.28); transition: background 0.2s; }
.nav-links .nav-cta:hover { background: #A8503A; }

/* ===== FOOTER ===== */
.footer-cta-section { background: linear-gradient(160deg, #C56B4C, #A8503A); color: #FBF6F0; padding: clamp(56px, 7vw, 96px) clamp(20px, 5vw, 72px); }
.footer-cta { max-width: 760px; margin: 0 auto; text-align: center; }
.footer-cta h2 { font-family: 'Cormorant Garamond', serif; font-weight: 700; font-size: clamp(30px, 4.5vw, 52px); line-height: 1.08; margin: 0 0 16px; }
.footer-cta p { font-size: 17.5px; color: rgba(251,246,240,0.85); max-width: 28em; margin: 0 auto 30px; }
.footer-cta-btns { display: flex; flex-wrap: wrap; gap: 14px; justify-content: center; }
.footer-cta-btns a:first-child { background: #FBF6F0; color: #A8503A; text-decoration: none; font-weight: 700; font-size: 16px; padding: 15px 32px; border-radius: 100px; transition: transform 0.2s; }
.footer-cta-btns a:first-child:hover { transform: translateY(-2px); }
.footer-cta-btns a:last-child { border: 2px solid rgba(251,246,240,0.6); color: #FBF6F0; text-decoration: none; font-weight: 700; font-size: 16px; padding: 13px 30px; border-radius: 100px; transition: background 0.2s; }
.footer-cta-btns a:last-child:hover { background: rgba(251,246,240,0.12); }
.footer-bar-section { background: #322D28; color: #FBF6F0; padding: 34px clamp(20px, 5vw, 72px); }
.footer-bar { max-width: 1180px; margin: 0 auto; display: flex; flex-wrap: wrap; gap: 18px; align-items: center; justify-content: space-between; }
.footer-bar-logo { font-family: 'Cormorant Garamond', serif; font-size: 20px; font-weight: 700; }
.footer-bar-links { display: flex; flex-wrap: wrap; gap: 22px; font-size: 14px; font-weight: 600; }
.footer-bar-links a { color: rgba(251,246,240,0.82); text-decoration: none; transition: color 0.2s; }
.footer-bar-links a:hover { color: #fff; }
.footer-bar-copy { font-size: 12.5px; color: rgba(251,246,240,0.55); }

/* ===== BUTTONS ===== */
.btn-primary { background: #C56B4C; color: #fff; text-decoration: none; font-weight: 700; font-size: 16px; padding: 16px 30px; border-radius: 100px; box-shadow: 0 12px 30px rgba(197,107,76,0.32); transition: background 0.2s, transform 0.2s; display: inline-block; }
.btn-primary:hover { background: #A8503A; transform: translateY(-2px); }
.btn-ghost { color: #322D28; text-decoration: none; font-weight: 700; font-size: 16px; padding: 16px 8px; border-bottom: 2px solid #EAD7C6; transition: border-color 0.2s; }
.btn-ghost:hover { border-color: #C56B4C; }
.btn-card-primary { display: block; text-align: center; background: #C56B4C; color: #fff; text-decoration: none; font-weight: 700; padding: 15px; border-radius: 100px; box-shadow: 0 10px 24px rgba(197,107,76,0.28); transition: background 0.2s; margin-top: auto; }
.btn-card-primary:hover { background: #A8503A; }
.btn-card-outline { display: block; text-align: center; background: #fff; color: #322D28; text-decoration: none; font-weight: 700; padding: 15px; border-radius: 100px; border: 2px solid #889A7B; transition: background 0.2s, color 0.2s; margin-top: auto; }
.btn-card-outline:hover { background: #889A7B; color: #fff; }

/* ===== TYPOGRAPHY HELPERS ===== */
.eyebrow-green { font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #889A7B; }
.eyebrow-red { font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #C56B4C; }
.eyebrow-light { font-size: 13px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: #D89B82; }
.section-title { font-family: 'Cormorant Garamond', serif; font-weight: 700; font-size: clamp(32px, 4.5vw, 54px); line-height: 1.08; margin: 14px auto 0; }
.section-center { text-align: center; margin-bottom: 52px; }

/* ===== SERVICE CARDS ===== */
.services-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: 28px; }
.service-card { position: relative; background: #fff; border-radius: 26px; padding: 40px 36px; display: flex; flex-direction: column; }
.service-card.primary { box-shadow: 0 18px 50px rgba(50,45,40,0.08); border: 1px solid rgba(197,107,76,0.18); }
.service-card.secondary { box-shadow: 0 18px 50px rgba(50,45,40,0.06); border: 1px solid rgba(136,154,123,0.25); }
.offer-label-red { font-family: 'Cormorant Garamond', serif; font-size: 15px; font-weight: 600; color: #C56B4C; letter-spacing: 1px; text-transform: uppercase; }
.offer-label-green { font-family: 'Cormorant Garamond', serif; font-size: 15px; font-weight: 600; color: #889A7B; letter-spacing: 1px; text-transform: uppercase; }
.badge-pill { position: absolute; top: 28px; right: 28px; font-size: 12px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; background: #C56B4C; color: #fff; padding: 6px 12px; border-radius: 100px; }
.service-card h3 { font-family: 'Cormorant Garamond', serif; font-weight: 700; font-size: 34px; line-height: 1.1; margin: 10px 0 6px; }
.service-card .card-subtitle { font-weight: 700; color: #322D28; margin: 0 0 18px; }
.service-card .card-desc { color: #6b6258; margin: 0 0 22px; font-size: 15.5px; }
.service-card ul { list-style: none; padding: 0; margin: 0 0 28px; display: flex; flex-direction: column; gap: 12px; }
.service-card li { display: flex; gap: 11px; font-size: 15px; color: #4a443d; }
.check-red { color: #C56B4C; font-weight: 700; }
.check-green { color: #889A7B; font-weight: 700; }
.info-box-red { background: #F3E5D8; border-radius: 14px; padding: 14px 18px; margin-bottom: 26px; font-size: 13.5px; color: #8a6d56; }
.info-box-green { background: #EEF1EA; border-radius: 14px; padding: 14px 18px; margin-bottom: 26px; font-size: 13.5px; color: #5f6b54; }

/* ===== PAINS / DARK SECTION ===== */
.section-dark { background: #322D28; color: #FBF6F0; padding: clamp(60px, 8vw, 104px) clamp(20px, 5vw, 72px); }
.pains-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 16px; text-align: left; margin-top: 46px; }
.pain-card { background: rgba(251,246,240,0.05); border: 1px solid rgba(251,246,240,0.1); border-radius: 18px; padding: 24px 22px; }
.pain-card .icon { font-size: 22px; margin-bottom: 10px; }
.pain-card p { margin: 0; font-size: 15.5px; color: #FBF6F0; font-weight: 500; }

/* ===== TESTIMONIALS ===== */
.testimonials-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 24px; }
figure.testi { background: rgba(251,246,240,0.05); border: 1px solid rgba(251,246,240,0.1); border-radius: 22px; padding: 32px 28px; margin: 0; display: flex; flex-direction: column; }
.stars { color: #D89B82; font-size: 18px; letter-spacing: 2px; margin-bottom: 14px; }
blockquote { margin: 0 0 22px; font-size: 16px; line-height: 1.6; }
figcaption { margin-top: auto; display: flex; align-items: center; gap: 13px; }
.testi-avatar { width: 44px; height: 44px; border-radius: 50%; background: linear-gradient(150deg, #C56B4C, #EAD7C6); display: flex; align-items: center; justify-content: center; font-family: 'Cormorant Garamond', serif; font-weight: 700; font-size: 18px; color: #fff; flex-shrink: 0; }
.testi-name { font-size: 15px; font-weight: 700; display: block; }
.testi-role { font-size: 13px; color: rgba(251,246,240,0.6); }

/* ===== FAQ ===== */
details.faq-item { background: #fff; border: 1px solid #EAD7C6; border-radius: 18px; padding: 4px 26px; }
details.faq-item summary { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 20px 0; font-family: 'Cormorant Garamond', serif; font-weight: 600; font-size: 21px; color: #322D28; }
details.faq-item summary .faq-plus { color: #C56B4C; font-size: 26px; font-weight: 400; flex-shrink: 0; transition: transform 0.3s; }
details.faq-item[open] summary .faq-plus { transform: rotate(45deg); }
details.faq-item p { margin: 0; padding: 0 0 22px; color: #6b6258; font-size: 16px; line-height: 1.65; }

/* ===== QUIZ ===== */
.quiz-section { background: linear-gradient(160deg, #F3E5D8, #EAD7C6); padding: clamp(48px, 6vw, 88px) clamp(20px, 5vw, 72px) clamp(64px, 8vw, 110px); min-height: 70vh; display: flex; align-items: center; }
.quiz-box { max-width: 720px; margin: 0 auto; width: 100%; background: #fff; border-radius: 30px; box-shadow: 0 30px 70px rgba(50,45,40,0.14); padding: clamp(32px, 5vw, 60px); position: relative; overflow: hidden; }
.quiz-deco { position: absolute; top: -40px; right: -40px; width: 160px; height: 160px; background: #EAD7C6; border-radius: 50%; opacity: 0.5; pointer-events: none; }
.quiz-inner { position: relative; z-index: 2; }
.quiz-phase { display: none; }
.quiz-phase.active { display: block; }
.quiz-progress-bar { height: 6px; background: #F3E5D8; border-radius: 100px; overflow: hidden; margin-bottom: 30px; }
.quiz-progress-fill { height: 100%; background: #C56B4C; border-radius: 100px; transition: width 0.4s ease; }
.quiz-options { display: flex; flex-direction: column; gap: 12px; }
.btn-option { text-align: left; cursor: pointer; background: #FBF6F0; border: 2px solid #EAD7C6; border-radius: 16px; padding: 17px 20px; font-family: 'Mulish', sans-serif; font-size: 15.5px; font-weight: 600; color: #322D28; transition: border-color 0.2s, background 0.2s; width: 100%; }
.btn-option:hover { border-color: #C56B4C; background: #fff; }
.btn-quiz-start { border: none; cursor: pointer; background: #C56B4C; color: #fff; font-family: 'Mulish', sans-serif; font-weight: 700; font-size: 17px; padding: 17px 38px; border-radius: 100px; box-shadow: 0 12px 30px rgba(197,107,76,0.32); transition: background 0.2s; }
.btn-quiz-start:hover { background: #A8503A; }
.lead-box { background: #FBF6F0; border-radius: 20px; padding: 28px 26px; text-align: left; margin-top: 30px; }
.lead-form { display: flex; flex-direction: column; gap: 12px; }
.lead-form input { font-family: 'Mulish', sans-serif; font-size: 15.5px; padding: 15px 18px; border-radius: 12px; border: 2px solid #EAD7C6; background: #fff; color: #322D28; outline: none; transition: border-color 0.2s; }
.lead-form input:focus { border-color: #C56B4C; }
.btn-lead { border: none; cursor: pointer; background: #C56B4C; color: #fff; font-family: 'Mulish', sans-serif; font-weight: 700; font-size: 16px; padding: 16px; border-radius: 12px; box-shadow: 0 10px 24px rgba(197,107,76,0.3); transition: background 0.2s; width: 100%; }
.btn-lead:hover { background: #A8503A; }
.rgpd { margin: 14px 0 0; font-size: 12px; color: #9a9087; text-align: center; }
.rgpd a { color: #9a9087; }

/* ===== RESPONSIVE ===== */
@media (max-width: 768px) {
  .nav-links { gap: 8px; }
  .nav-links a:not(.nav-cta):not(:last-of-type) { display: none; }
}
@media (max-width: 480px) {
  .nav-links a:not(.nav-cta) { display: none; }
}
