/* ===== Formed with Love — styles.css ===== */

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;-webkit-font-smoothing:antialiased;background:#FBF6F2;color:#3D2820;overflow-x:hidden}
a{text-decoration:none;color:inherit;transition:opacity .3s}
a:hover{opacity:.85}
button{cursor:pointer;border:none;background:none;font-family:inherit}
img{max-width:100%;display:block}

/* VARIABLES */
:root{
  --cream:#F5EDE4;--blush:#F0DDD4;--rose-clay:#C4917E;--rose-deep:#A86E5A;
  --warm-umber:#8B6F5E;--cocoa:#5C3D2E;--dark-cocoa:#3D2820;--white:#FFFFFF;
  --off-white:#FBF6F2;--soft-pink:#EACFC3;
}

/* ANIMATIONS */
@keyframes fadeUp{from{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes scrollBounce{0%,100%{transform:translateY(0) translateX(-50%)}50%{transform:translateY(6px) translateX(-50%)}}
.fade-up{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
.fade-up.visible{opacity:1;transform:translateY(0)}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;padding:16px 24px;transition:all .4s ease}
.nav.scrolled{padding:8px 24px;background:rgba(251,246,242,.97);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--blush)}
.nav-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center}
.nav-logo{display:flex;align-items:center}
.nav-logo-img{height:88px;width:auto;transition:height .3s}
.nav.scrolled .nav-logo-img{height:68px}
.nav-toggle{display:flex;flex-direction:column;gap:5px;padding:8px;z-index:1001}
.nav-toggle span{width:24px;height:2px;background:var(--dark-cocoa);border-radius:2px;transition:all .3s}
.nav-toggle.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.nav-toggle.open span:nth-child(2){opacity:0}
.nav-toggle.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}
.nav-menu{position:absolute;top:100%;left:0;right:0;background:rgba(251,246,242,.98);backdrop-filter:blur(16px);border-bottom:1px solid var(--blush);padding:16px 24px 24px;display:none}
.nav-menu.open{display:block;animation:fadeIn .3s ease}
.nav-menu a{display:block;padding:14px 0;font-size:15px;color:var(--dark-cocoa);border-bottom:1px solid var(--blush);letter-spacing:.5px}
.nav-menu a:last-child{border-bottom:none}

/* HERO */
.hero{min-height:100vh;min-height:100dvh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:100px 24px 60px;position:relative;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center}
.hero-bg-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(251,246,242,.6) 0%,rgba(245,237,228,.55) 40%,rgba(240,221,212,.5) 100%)}
.hero-content{position:relative;z-index:1}
.hero-logo-img{max-width:min(440px,88vw);width:100%;height:auto;margin:0 auto 16px;animation:fadeUp 1s ease .2s both}
.hero-divider{width:60px;height:1px;background:var(--rose-clay);margin:20px auto;opacity:.5;animation:fadeIn 1s ease .5s both}
.hero-tagline{font-family:'Cormorant Garamond',serif;font-size:clamp(18px,4vw,24px);color:var(--warm-umber);font-style:italic;letter-spacing:1px;animation:fadeUp 1s ease .6s both}
.hero-desc{font-size:15px;color:var(--cocoa);max-width:420px;line-height:1.7;margin:16px auto 32px;opacity:.85;animation:fadeUp 1s ease .8s both}
.hero-cta{display:inline-block;font-size:13px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--white);background:linear-gradient(135deg,var(--rose-clay),var(--rose-deep));padding:16px 40px;border-radius:50px;box-shadow:0 8px 24px rgba(196,145,126,.3);transition:transform .3s,box-shadow .3s;animation:fadeUp 1s ease 1s both}
.hero-cta:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(196,145,126,.4);opacity:1}
.hero-sub{font-size:11px;color:var(--warm-umber);margin-top:16px;opacity:.6;letter-spacing:.5px;animation:fadeUp 1s ease 1.1s both}
.scroll-indicator{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:6px;opacity:.35;animation:scrollBounce 2s ease-in-out infinite;z-index:1}
.scroll-indicator span{font-size:9px;letter-spacing:2px;text-transform:uppercase;color:var(--cocoa)}

/* COMMON SECTION */
.section-label{font-size:11px;letter-spacing:3px;text-transform:uppercase;color:var(--rose-clay);margin-bottom:12px;font-weight:600}
.section-title{font-family:'Playfair Display',serif;font-size:28px;font-weight:700;color:var(--dark-cocoa);margin-bottom:12px}
.section-divider{width:40px;height:1px;background:var(--rose-clay);margin:0 auto 40px;opacity:.4}

/* HOW IT WORKS */
.how-section{padding:80px 24px;background:var(--white)}
.how-inner{max-width:600px;margin:0 auto;text-align:center}
.step-card{padding:28px 20px;border-radius:16px;position:relative;z-index:1}
.step-card:nth-child(odd){background:rgba(245,237,228,.5)}
.step-icon{font-size:28px;margin-bottom:12px}
.step-num{font-family:'Cormorant Garamond',serif;font-size:12px;color:var(--rose-clay);letter-spacing:2px;font-weight:600;margin-bottom:6px}
.step-title{font-family:'Playfair Display',serif;font-size:22px;font-weight:600;color:var(--dark-cocoa);margin-bottom:8px}
.step-desc{font-size:14px;color:var(--cocoa);line-height:1.6;opacity:.8}

/* SCAN OPTIONS */
.options-section{padding:80px 24px;background:linear-gradient(180deg,var(--off-white),rgba(245,237,228,.4))}
.options-inner{max-width:600px;margin:0 auto;text-align:center}
.options-subtitle{font-size:14px;color:var(--cocoa);opacity:.7;line-height:1.6;margin-bottom:40px}
.option-card{padding:28px 24px;border-radius:20px;border:1px solid var(--blush);background:rgba(255,255,255,.5);cursor:pointer;transition:all .3s ease;position:relative;margin-bottom:16px}
.option-card:last-child{margin-bottom:0}
.option-card.active{border:2px solid var(--rose-clay);background:var(--white);box-shadow:0 8px 32px rgba(196,145,126,.12)}
.option-card:hover{border-color:var(--rose-clay)}
.option-popular{position:absolute;top:-10px;right:20px;background:linear-gradient(135deg,var(--rose-clay),var(--rose-deep));color:var(--white);font-size:9px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;padding:5px 14px;border-radius:20px}
.option-inner{display:flex;align-items:center;gap:20px}
.option-icon{flex-shrink:0}
.option-img{width:80px;height:80px;object-fit:contain;border-radius:12px}
.option-text{text-align:left}
.option-title{font-family:'Playfair Display',serif;font-size:20px;font-weight:600;color:var(--dark-cocoa);margin-bottom:2px}
.option-sub{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--rose-clay);font-weight:600;margin-bottom:8px}
.option-desc{font-size:13px;color:var(--cocoa);line-height:1.6;opacity:.75}

/* UPSELL SHOWCASE */
.upsell-section{padding:80px 24px;background:var(--white);overflow:hidden}
.upsell-inner{max-width:600px;margin:0 auto;text-align:center}
.upsell-img{width:100%;max-width:520px;margin:0 auto 28px;border-radius:20px;box-shadow:0 12px 40px rgba(92,61,46,.12)}
.upsell-desc{font-size:14px;color:var(--cocoa);line-height:1.7;opacity:.8;margin-bottom:24px;max-width:460px;margin-left:auto;margin-right:auto}
.upsell-features{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-bottom:28px}
.upsell-tag{font-size:11px;color:var(--cocoa);background:var(--cream);padding:8px 16px;border-radius:20px;letter-spacing:.5px}
.upsell-cta{display:inline-block;font-size:12px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--rose-deep);border:2px solid var(--rose-clay);padding:14px 36px;border-radius:50px;transition:all .3s}
.upsell-cta:hover{background:var(--rose-clay);color:var(--white);opacity:1}

/* ESTIMATOR */
.estimator-section{padding:80px 24px;background:linear-gradient(180deg,rgba(245,237,228,.3),var(--off-white))}
.estimator-inner{max-width:520px;margin:0 auto}
.est-card{background:var(--white);border-radius:20px;padding:32px 24px;border:1px solid var(--blush);box-shadow:0 4px 20px rgba(92,61,46,.06)}
.est-group{margin-bottom:24px}
.est-label{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--cocoa);margin-bottom:10px;display:block}
.est-options{display:flex;flex-wrap:wrap;gap:8px}
.est-btn{font-size:13px;padding:10px 18px;border-radius:30px;border:1.5px solid var(--blush);background:var(--off-white);color:var(--cocoa);transition:all .2s;cursor:pointer;font-family:'DM Sans',sans-serif;line-height:1.3}
.est-btn.selected{background:var(--rose-clay);color:var(--white);border-color:var(--rose-clay)}
.est-btn:hover{border-color:var(--rose-clay)}
.est-zip-row{display:flex;gap:10px;align-items:flex-start;flex-wrap:wrap}
.est-zip-input{font-family:'DM Sans',sans-serif;font-size:14px;padding:10px 16px;border-radius:12px;border:1.5px solid var(--blush);background:var(--off-white);color:var(--dark-cocoa);width:130px;outline:none;transition:border-color .2s}
.est-zip-input:focus{border-color:var(--rose-clay)}
.est-zip-btn{font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;padding:10px 20px;border-radius:30px;background:var(--rose-clay);color:var(--white);border:none;cursor:pointer;letter-spacing:.5px;transition:background .2s}
.est-zip-btn:hover{background:var(--rose-deep)}
.est-zip-result{font-size:13px;color:var(--cocoa);margin-top:10px;min-height:20px}
.est-zip-result.error{color:#c0392b}
.est-zip-result.success{color:var(--rose-deep);font-weight:600}
.est-divider{width:100%;height:1px;background:var(--blush);margin:28px 0}
.est-result{text-align:center;padding:20px 0 0}
.est-total-label{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--rose-clay);font-weight:600;margin-bottom:6px}
.est-total{font-family:'Playfair Display',serif;font-size:42px;font-weight:700;color:var(--dark-cocoa)}
.est-breakdown{font-size:12px;color:var(--warm-umber);margin-top:8px;opacity:.7;line-height:1.6}
.est-note{font-size:11px;color:var(--warm-umber);margin-top:16px;opacity:.5;font-style:italic}
.est-contact-msg{text-align:center;padding:24px 0 0}
.est-contact-msg p{font-family:'Playfair Display',serif;font-size:20px;color:var(--dark-cocoa);margin-bottom:8px}
.est-contact-msg span{font-size:13px;color:var(--cocoa);opacity:.7;line-height:1.6;display:block;margin-bottom:16px}
.est-contact-msg a{display:inline-block;font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--rose-deep);border:1.5px solid var(--rose-clay);padding:10px 28px;border-radius:30px;transition:all .3s}
.est-contact-msg a:hover{background:var(--rose-clay);color:var(--white);opacity:1}

/* GIFT CERTIFICATE */
.gift-section{padding:80px 24px;background:var(--white)}
.gift-inner{max-width:560px;margin:0 auto;text-align:center}
.gift-card{background:var(--off-white);border:1px solid var(--blush);border-radius:20px;padding:32px 24px;margin-top:32px}
.gift-summary{text-align:left;margin-bottom:20px;font-size:13px;color:var(--cocoa);line-height:1.8}
.gift-summary-line{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--blush)}
.gift-summary-line:last-child{border-bottom:none;font-weight:700;color:var(--dark-cocoa);font-size:15px;padding-top:12px}
.gift-form-group{margin-bottom:16px;text-align:left}
.gift-form-label{font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--cocoa);margin-bottom:6px;display:block}
.gift-form-input{font-family:'DM Sans',sans-serif;font-size:14px;padding:12px 16px;border-radius:12px;border:1.5px solid var(--blush);background:var(--white);color:var(--dark-cocoa);width:100%;outline:none;transition:border-color .2s}
.gift-form-input:focus{border-color:var(--rose-clay)}
textarea.gift-form-input{resize:vertical;min-height:70px}
.gift-paypal-wrap{margin-top:20px;min-height:50px}
.gift-or{font-size:12px;color:var(--warm-umber);opacity:.6;margin:16px 0}

/* TESTIMONIALS */
.testimonials-section{padding:80px 24px;background:var(--white)}
.testimonials-inner{max-width:600px;margin:0 auto;text-align:center}
.testimonial-card{padding:28px 24px;border-radius:16px;background:rgba(245,237,228,.4);border-left:3px solid rgba(196,145,126,.3);margin-bottom:24px;text-align:center}
.testimonial-card:last-child{margin-bottom:0}
.testimonial-hearts{display:flex;gap:4px;justify-content:center;margin-bottom:14px}
.testimonial-text{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--dark-cocoa);line-height:1.6;font-style:italic;margin-bottom:16px}
.testimonial-name{font-size:13px;font-weight:600;color:var(--cocoa);margin-bottom:2px}
.testimonial-detail{font-size:11px;color:var(--warm-umber);opacity:.6}

/* FAQ */
.faq-section{padding:80px 24px;background:linear-gradient(180deg,rgba(245,237,228,.3),var(--off-white))}
.faq-inner{max-width:600px;margin:0 auto}
.faq-item{border-radius:14px;overflow:hidden;background:var(--white);border:1px solid var(--blush);margin-bottom:8px;transition:all .3s ease}
.faq-item:last-child{margin-bottom:0}
.faq-item.open{border-color:rgba(196,145,126,.35)}
.faq-question{width:100%;padding:18px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px;text-align:left}
.faq-question-text{font-size:14px;font-weight:600;color:var(--dark-cocoa);line-height:1.4}
.faq-toggle{flex-shrink:0;width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s;font-size:16px;font-weight:300;background:var(--blush);color:var(--cocoa)}
.faq-item.open .faq-toggle{background:var(--rose-clay);color:var(--white)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height .4s ease,padding .3s ease;padding:0 20px}
.faq-item.open .faq-answer{max-height:300px;padding:0 20px 20px}
.faq-answer p{font-size:13px;color:var(--cocoa);line-height:1.7;opacity:.8}

/* BOOKING */
.booking-section{padding:80px 24px;background:var(--white);text-align:center}
.booking-inner{max-width:600px;margin:0 auto}
.booking-subtitle{font-size:14px;color:var(--cocoa);line-height:1.6;opacity:.75;max-width:400px;margin:0 auto 32px}
.booking-widget{border-radius:20px;border:1px solid var(--blush);background:rgba(245,237,228,.3);padding:48px 24px;margin-bottom:24px}
.booking-widget-title{font-family:'Playfair Display',serif;font-size:18px;color:var(--dark-cocoa);font-weight:600;margin:24px 0 8px}
.booking-widget-desc{font-size:13px;color:var(--cocoa);line-height:1.6;opacity:.6;margin-bottom:24px}
.booking-setup{background:var(--white);border-radius:12px;padding:20px;border:1px dashed rgba(196,145,126,.3);text-align:left;font-size:12px;color:var(--cocoa);line-height:1.8}
.booking-setup strong{color:var(--dark-cocoa)}
.booking-setup-title{font-weight:700;color:var(--dark-cocoa);font-size:13px;margin-bottom:8px}
.booking-tags{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.booking-tag{font-size:11px;color:var(--cocoa);background:var(--cream);padding:8px 16px;border-radius:20px;letter-spacing:.5px;display:flex;align-items:center;gap:6px}

/* FOOTER */
.footer{padding:48px 24px 32px;background:var(--dark-cocoa);text-align:center}
.footer-inner{max-width:600px;margin:0 auto}
.footer-logo-img{height:104px;width:auto;margin:0 auto 8px;filter:brightness(1.6) contrast(.85)}
.footer-tagline{font-family:'Cormorant Garamond',serif;font-size:14px;color:var(--rose-clay);font-style:italic;opacity:.7;margin-bottom:28px}
.footer-divider{width:40px;height:1px;background:var(--rose-clay);margin:0 auto 28px;opacity:.3}
.footer-links{display:flex;justify-content:center;gap:24px;flex-wrap:wrap;margin-bottom:28px}
.footer-links a{font-size:12px;color:var(--soft-pink);letter-spacing:.5px;opacity:.7}
.footer-links a:hover{opacity:1}
.footer-email{font-size:13px;color:var(--rose-clay)}
.footer-domain{font-size:11px;color:var(--warm-umber);margin-top:20px;opacity:.4}
.footer-hearts{display:flex;justify-content:center;gap:8px;margin-top:24px;opacity:.4}
.footer-copyright{font-size:10px;color:var(--warm-umber);margin-top:20px;opacity:.3}

/* SVG HEARTS */
.heart-sm{display:inline-block;width:12px;height:12px}
.heart-xs{display:inline-block;width:8px;height:8px}
.heart-tag{display:inline-block;width:10px;height:10px}

/* RESPONSIVE */
@media(min-width:768px){
  .nav-toggle{display:none}
  .nav-menu{display:flex!important;position:static;background:none;backdrop-filter:none;border:none;padding:0;gap:32px}
  .nav-menu a{padding:0;border:none;font-size:13px;letter-spacing:1px;text-transform:uppercase;font-weight:500;opacity:.7}
  .nav-menu a:hover{opacity:1}
  .section-title{font-size:34px}
  .step-card{padding:36px 28px}
  .option-card{padding:32px 28px}
  .option-img{width:100px;height:100px}
  .testimonial-card{padding:36px 32px}
  .booking-widget{padding:56px 40px}
  .est-card{padding:40px 32px}
  .gift-card{padding:40px 32px}
}
