/* === Laetitia Saint-Olive — Style === */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&family=Inter:wght@300;400;500;600&display=swap');

/* --- Reset & base --- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --white:#ffffff;--cream:#faf8f5;--charcoal:#2d2d2d;--grey-light:#e8e4df;
  --mauve:#c9a0dc;--gold:#c5a55a;--sage:#8a9a5b;
  --mauve-light:#e8d4f0;--gold-light:#f5ecd0;--sage-light:#d5e0b8;
  --font-heading:'Playfair Display',Georgia,serif;
  --font-body:'Inter','Helvetica Neue',Arial,sans-serif;
  --max-w:1200px;--header-h:72px;
  --transition:0.3s ease;
}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:var(--font-body);color:var(--charcoal);background:var(--white);line-height:1.7;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:var(--mauve);text-decoration:none;transition:color var(--transition)}
a:hover{color:var(--gold)}
h1,h2,h3,h4{font-family:var(--font-heading);font-weight:600;line-height:1.25}
h1{font-size:clamp(2rem,5vw,3.2rem)}
h2{font-size:clamp(1.6rem,3.5vw,2.4rem)}
h3{font-size:clamp(1.2rem,2.5vw,1.6rem)}
p{margin-bottom:1rem}
ul,ol{padding-left:1.5rem}

/* --- Utility --- */
.container{width:90%;max-width:var(--max-w);margin:0 auto}
.section{padding:5rem 0}
.section-cream{background:var(--cream)}
.text-center{text-align:center}
.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}

/* --- Reveal animations --- */
.reveal{opacity:0;transform:translateY(30px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* --- Header --- */
.site-header{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,0.97);backdrop-filter:blur(8px);border-bottom:1px solid transparent;transition:box-shadow var(--transition),border-color var(--transition);height:var(--header-h)}
.site-header.scrolled{box-shadow:0 2px 20px rgba(0,0,0,0.06);border-bottom-color:var(--grey-light)}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:var(--header-h);max-width:var(--max-w);margin:0 auto;padding:0 5%}
.logo{font-family:var(--font-heading);font-size:1.4rem;font-weight:700;color:var(--charcoal);letter-spacing:.02em}
.logo span{color:var(--mauve)}

.main-nav ul{display:flex;gap:1.8rem;list-style:none}
.main-nav a{font-size:.9rem;font-weight:500;color:var(--charcoal);position:relative;padding:.2rem 0}
.main-nav a::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--mauve);transition:width var(--transition)}
.main-nav a:hover::after,.main-nav a.active::after{width:100%}
.main-nav a:hover{color:var(--mauve)}

.header-actions{display:flex;align-items:center;gap:1rem}
.cart-icon{position:relative;cursor:pointer;font-size:1.3rem;color:var(--charcoal);background:none;border:none;transition:color var(--transition)}
.cart-icon:hover{color:var(--mauve)}
.cart-badge{position:absolute;top:-6px;right:-8px;background:var(--sage);color:#fff;font-size:.65rem;font-weight:700;width:18px;height:18px;border-radius:50%;display:none;align-items:center;justify-content:center}

/* Burger */
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.burger span{display:block;width:24px;height:2px;background:var(--charcoal);transition:all var(--transition)}
.burger.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.burger.active span:nth-child(2){opacity:0}
.burger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

@media(max-width:860px){
  .burger{display:flex}
  .main-nav{position:fixed;top:var(--header-h);left:0;right:0;background:var(--white);padding:2rem 5%;transform:translateY(-120%);transition:transform 0.4s ease;box-shadow:0 10px 30px rgba(0,0,0,0.08);z-index:999}
  .main-nav.open{transform:translateY(0)}
  .main-nav ul{flex-direction:column;gap:1.2rem}
}

/* --- Hero --- */
.hero{position:relative;min-height:85vh;display:flex;align-items:center;justify-content:center;text-align:center;background:url('../img/ambiance/hero-home.webp') center/cover no-repeat;overflow:hidden}
.hero::before{content:'';position:absolute;inset:0;background:rgba(255,255,255,0.65)}
.hero-content{position:relative;z-index:2;max-width:700px;padding:2rem}
.hero h1{margin-bottom:1.2rem;color:var(--charcoal)}
.hero p{font-size:1.15rem;margin-bottom:2rem;color:#555}

/* --- Buttons --- */
.btn{display:inline-block;padding:.85rem 2.2rem;border-radius:50px;font-weight:600;font-size:.95rem;transition:all var(--transition);cursor:pointer;border:none;text-align:center}
.btn-primary{background:var(--sage);color:#fff}
.btn-primary:hover{background:#748a4a;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(138,154,91,0.3)}
.btn-outline{border:2px solid var(--mauve);color:var(--mauve);background:transparent}
.btn-outline:hover{background:var(--mauve);color:#fff;transform:translateY(-2px)}
.btn-gold{background:var(--gold);color:#fff}
.btn-gold:hover{background:#a88b3a;color:#fff;transform:translateY(-2px);box-shadow:0 6px 20px rgba(197,165,90,0.3)}
.btn-small{padding:.55rem 1.4rem;font-size:.85rem}

/* --- Section titles --- */
.section-title{text-align:center;margin-bottom:3rem}
.section-title h2{margin-bottom:.8rem}
.section-title p{color:#777;max-width:600px;margin:0 auto;font-size:1.05rem}
.section-title .accent-line{width:60px;height:3px;background:var(--mauve);margin:1rem auto 0;border-radius:2px}

/* --- Product cards --- */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2rem}
.product-card{background:var(--white);border-radius:12px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.05);transition:all var(--transition)}
.product-card:hover{transform:translateY(-4px);box-shadow:0 8px 30px rgba(0,0,0,0.1)}
.product-img{height:280px;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.3rem;color:rgba(255,255,255,0.9);text-shadow:0 1px 4px rgba(0,0,0,0.2);transition:transform 0.5s ease;position:relative;overflow:hidden}
.product-card:hover .product-img{transform:scale(1.05)}
.product-body{padding:1.2rem 1.4rem 1.5rem}
.product-name{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;margin-bottom:.3rem}
.product-desc{font-size:.85rem;color:#888;margin-bottom:.8rem}
.product-bottom{display:flex;align-items:center;justify-content:space-between}
.product-price{font-size:1.15rem;font-weight:700;color:var(--charcoal)}
.product-price span{font-size:.8rem;font-weight:400;color:#999}
.add-to-cart{background:var(--sage);color:#fff;border:none;padding:.5rem 1.1rem;border-radius:50px;font-size:.82rem;font-weight:600;cursor:pointer;transition:all var(--transition)}
.add-to-cart:hover{background:#748a4a;transform:scale(1.05)}

/* --- Collections grid (home) --- */
.collections-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem}
.collection-card{position:relative;border-radius:12px;overflow:hidden;height:300px;display:flex;align-items:flex-end;padding:1.5rem;cursor:pointer;transition:transform var(--transition)}
.collection-card:hover{transform:scale(1.02)}
.collection-card::before{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,transparent 60%);z-index:1}
.collection-card-content{position:relative;z-index:2;color:#fff}
.collection-card h3{margin-bottom:.3rem;font-size:1.3rem}
.collection-card p{font-size:.9rem;opacity:.9}

/* --- Testimonials --- */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:1.5rem}
.testimonial{background:var(--white);border-radius:12px;padding:2rem;box-shadow:0 2px 12px rgba(0,0,0,0.05)}
.testimonial-stars{color:var(--gold);margin-bottom:.8rem;font-size:1.1rem}
.testimonial-text{font-style:italic;margin-bottom:1rem;color:#555}
.testimonial-author{font-weight:600;color:var(--charcoal)}

/* --- Features --- */
.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:2rem}
.feature{text-align:center;padding:2rem 1.5rem}
.feature-icon{font-size:2.5rem;margin-bottom:1rem}
.feature h3{margin-bottom:.6rem}
.feature p{color:#777;font-size:.95rem}

/* --- Newsletter --- */
.newsletter{background:linear-gradient(135deg,var(--mauve-light) 0%,var(--gold-light) 100%);padding:4rem 0;text-align:center}
.newsletter h2{margin-bottom:.6rem}
.newsletter p{color:#666;margin-bottom:1.5rem}
.newsletter-form{display:flex;gap:.8rem;max-width:460px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.newsletter-form input[type="email"]{flex:1;min-width:200px;padding:.8rem 1.2rem;border:2px solid var(--grey-light);border-radius:50px;font-size:.95rem;font-family:var(--font-body);outline:none;transition:border-color var(--transition)}
.newsletter-form input[type="email"]:focus{border-color:var(--mauve)}

/* --- Breadcrumbs --- */
.breadcrumbs{padding:1rem 0;font-size:.85rem;color:#999}
.breadcrumbs a{color:var(--mauve)}
.breadcrumbs span{margin:0 .4rem}

/* --- Filters --- */
.filters{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2rem}
.filter-group{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.filter-group label{font-weight:600;font-size:.85rem;margin-right:.3rem}
.filter-btn{padding:.4rem 1rem;border:1px solid var(--grey-light);border-radius:50px;background:transparent;font-size:.82rem;cursor:pointer;transition:all var(--transition);font-family:var(--font-body)}
.filter-btn:hover,.filter-btn.active{background:var(--mauve);color:#fff;border-color:var(--mauve)}

/* --- SEO text --- */
.seo-content{max-width:800px;margin:3rem auto 0;padding-top:3rem;border-top:1px solid var(--grey-light)}
.seo-content h2{font-size:1.6rem;margin-bottom:1rem}
.seo-content h3{font-size:1.2rem;margin:1.5rem 0 .6rem}
.seo-content p,.seo-content li{color:#555;line-height:1.8}

/* --- Guide content --- */
.guide-content{max-width:800px;margin:0 auto}
.guide-step{margin-bottom:3rem;padding-bottom:2rem;border-bottom:1px solid var(--grey-light)}
.guide-step:last-child{border-bottom:none}
.guide-step h3{color:var(--charcoal);margin-bottom:.8rem}
.guide-step h3 span{color:var(--mauve);font-size:1.8rem;margin-right:.5rem}

/* --- About --- */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;align-items:center}
.about-img{height:400px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-family:var(--font-heading);font-size:1.5rem;color:rgba(255,255,255,0.9);text-shadow:0 1px 4px rgba(0,0,0,0.2)}
.about-values{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:2rem}
.value-card{background:var(--cream);padding:1.5rem;border-radius:12px;text-align:center}
.value-card .feature-icon{font-size:2rem;margin-bottom:.6rem}
@media(max-width:768px){
  .about-grid{grid-template-columns:1fr}
  .about-img{height:250px}
}

/* --- Contact --- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem}
.contact-form label{display:block;font-weight:500;margin-bottom:.3rem;font-size:.9rem}
.contact-form input,.contact-form select,.contact-form textarea{width:100%;padding:.75rem 1rem;border:2px solid var(--grey-light);border-radius:8px;font-family:var(--font-body);font-size:.95rem;outline:none;transition:border-color var(--transition);margin-bottom:1.2rem}
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:var(--mauve)}
.contact-form textarea{min-height:150px;resize:vertical}
.contact-info-card{background:var(--cream);border-radius:12px;padding:2.5rem}
.contact-info-item{display:flex;gap:1rem;margin-bottom:1.5rem}
.contact-info-item .icon{font-size:1.5rem}

/* --- FAQ --- */
.faq{max-width:800px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--grey-light);padding:1.2rem 0}
.faq-question{font-weight:600;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.faq-question::after{content:'+';font-size:1.3rem;color:var(--mauve);transition:transform var(--transition)}
.faq-item.open .faq-question::after{transform:rotate(45deg)}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s ease,padding 0.4s ease;color:#666}
.faq-item.open .faq-answer{max-height:500px;padding-top:.8rem}

/* --- Cart panel --- */
#cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.3);z-index:2000;opacity:0;pointer-events:none;transition:opacity var(--transition)}
body.cart-open #cart-overlay{opacity:1;pointer-events:auto}
#cart-panel{position:fixed;top:0;right:0;bottom:0;width:380px;max-width:90vw;background:var(--white);z-index:2001;transform:translateX(100%);transition:transform 0.4s ease;display:flex;flex-direction:column;box-shadow:-4px 0 30px rgba(0,0,0,0.1)}
#cart-panel.open{transform:translateX(0)}
.cart-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--grey-light)}
.cart-panel-header h3{margin:0}
.cart-panel-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--charcoal)}
#cart-panel-items{flex:1;overflow-y:auto;padding:1rem 1.5rem}
.cart-item{display:flex;gap:1rem;padding:.8rem 0;border-bottom:1px solid #f0f0f0}
.cart-item-img{width:55px;height:55px;border-radius:8px;flex-shrink:0}
.cart-item-info{flex:1}
.cart-item-name{font-weight:600;font-size:.9rem;display:block}
.cart-item-price{font-size:.85rem;color:#888}
.cart-item-qty{display:flex;align-items:center;gap:.5rem;margin-top:.4rem}
.cart-item-qty button{width:26px;height:26px;border-radius:50%;border:1px solid var(--grey-light);background:var(--white);cursor:pointer;font-size:.9rem;display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.cart-item-qty button:hover{background:var(--mauve);color:#fff;border-color:var(--mauve)}
.cart-item-remove{background:none!important;border:none!important;color:#ccc;font-size:.9rem;margin-left:auto}
.cart-item-remove:hover{color:#e55}
.cart-empty{text-align:center;color:#999;padding:2rem 0}
.cart-panel-footer{padding:1.5rem;border-top:1px solid var(--grey-light)}
.cart-panel-row{display:flex;justify-content:space-between;margin-bottom:.4rem;font-size:.9rem}
.cart-panel-row.total{font-weight:700;font-size:1.05rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--grey-light)}
.cart-panel-footer .btn{width:100%;margin-top:1rem;text-align:center}

/* --- Cart toast --- */
#cart-toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(100px);background:var(--sage);color:#fff;padding:.8rem 1.5rem;border-radius:50px;font-weight:600;font-size:.9rem;z-index:3000;transition:transform 0.3s ease,opacity 0.3s ease;opacity:0;pointer-events:none}
#cart-toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* --- Cart page --- */
.cart-page-header-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 40px;gap:1rem;padding:.8rem 0;border-bottom:2px solid var(--grey-light);font-weight:600;font-size:.85rem;color:#999}
.cart-page-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 40px;gap:1rem;padding:1rem 0;border-bottom:1px solid #f0f0f0;align-items:center}
.cart-page-product{display:flex;align-items:center;gap:1rem}
.cart-page-img{width:60px;height:60px;border-radius:8px;flex-shrink:0}
.cart-page-qty{display:flex;align-items:center;gap:.5rem}
.cart-page-qty button{width:30px;height:30px;border-radius:50%;border:1px solid var(--grey-light);background:var(--white);cursor:pointer;font-size:1rem;transition:all var(--transition)}
.cart-page-qty button:hover{background:var(--mauve);color:#fff;border-color:var(--mauve)}
.cart-page-remove{background:none;border:none;color:#ccc;font-size:1.1rem;cursor:pointer}
.cart-page-remove:hover{color:#e55}
.cart-page-summary{background:var(--cream);border-radius:12px;padding:2rem;margin-top:2rem;max-width:400px;margin-left:auto}
.cart-page-summary .cart-panel-row{margin-bottom:.5rem}
.promo-row{display:flex;gap:.5rem;margin-bottom:1rem}
.promo-row input{flex:1;padding:.6rem 1rem;border:2px solid var(--grey-light);border-radius:50px;font-family:var(--font-body);font-size:.9rem;outline:none}
.promo-row input:focus{border-color:var(--mauve)}
.promo-row button{padding:.6rem 1.2rem;border-radius:50px;border:none;background:var(--mauve);color:#fff;font-weight:600;cursor:pointer;font-size:.85rem;transition:all var(--transition)}
.promo-row button:hover{background:#b080c8}
.promo-msg{font-size:.85rem;margin-bottom:.5rem}
.promo-msg.success{color:var(--sage)}
.promo-msg.error{color:#c55}

@media(max-width:768px){
  .cart-page-header-row{display:none}
  .cart-page-row{grid-template-columns:1fr;gap:.5rem;position:relative;padding:1rem 0}
  .cart-page-remove{position:absolute;top:1rem;right:0}
  .contact-grid{grid-template-columns:1fr}
  .about-values{grid-template-columns:1fr}
}

/* --- Footer --- */
.site-footer{background:var(--charcoal);color:rgba(255,255,255,0.8);padding:4rem 0 2rem}
.footer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:3rem}
.footer-col h4{color:#fff;margin-bottom:1rem;font-family:var(--font-heading)}
.footer-col a{color:rgba(255,255,255,0.7);display:block;padding:.25rem 0;font-size:.9rem;transition:color var(--transition)}
.footer-col a:hover{color:var(--mauve)}
.footer-col p{font-size:.9rem;line-height:1.6}
.footer-bottom{text-align:center;padding-top:2rem;border-top:1px solid rgba(255,255,255,0.1);font-size:.85rem;color:rgba(255,255,255,0.5)}

/* --- Page header --- */
.page-header{background:var(--cream);padding:3rem 0 2rem;text-align:center}
.page-header h1{margin-bottom:.5rem}
.page-header p{color:#777;font-size:1.05rem}

/* Product images */
.product-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.product-card:hover .product-img img {
  transform: scale(1.05);
}
.product-img {
  overflow: hidden;
}
