/* =====================================
   SÈVE & PÉTALE — Fleuriste de quartier
   Light pastel · organique · header centré
   ===================================== */

:root {
  --cream:#faf3e8;
  --cream-soft:#f4ebda;
  --blush:#e8c5b8;
  --blush-deep:#d99a8a;
  --sage:#95a584;
  --sage-deep:#6f7f5f;
  --leaf:#2d4030;
  --leaf-soft:#4a5e4c;
  --terracotta:#c97b5a;
  --ink:#1c211b;
  --serif:"Spectral","Times New Roman",serif;
  --sans:"DM Sans",-apple-system,BlinkMacSystemFont,sans-serif;
  --pad:clamp(20px,4vw,56px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--cream);
  color:var(--leaf);
  font-family:var(--sans);
  font-size:16px;
  line-height:1.65;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .25s ease}
a:hover{color:var(--terracotta)}

h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.05;color:var(--leaf);letter-spacing:-0.01em}
h1{font-size:clamp(48px,8vw,128px);font-style:italic;font-weight:300}
h2{font-size:clamp(36px,5vw,72px);font-style:italic;font-weight:300}
h3{font-size:clamp(22px,2.4vw,34px);font-style:italic;font-weight:400}
h4{font-size:14px;font-family:var(--sans);font-weight:500;letter-spacing:0.18em;text-transform:uppercase}

em{color:var(--terracotta);font-style:italic}

.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.32em;
  text-transform:uppercase;
  color:var(--sage-deep);
  display:inline-flex;align-items:center;gap:14px;font-weight:500
}
.eyebrow::before{content:"❀";color:var(--terracotta);font-size:14px}

/* ========== HEADER CENTRÉ ========== */
.site-header{
  position:sticky;top:0;z-index:50;
  background:var(--cream);
  border-bottom:1px solid rgba(45,64,48,.08);
  padding:18px var(--pad);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:24px;
}
.header-left,.header-right{display:flex;gap:24px;align-items:center;font-size:13px;color:var(--leaf-soft)}
.header-right{justify-content:flex-end}
.header-left a,.header-right a{position:relative;padding:6px 2px}
.header-left a:hover,.header-right a:hover{color:var(--terracotta)}

.brand-block{display:flex;flex-direction:column;align-items:center;line-height:1}
.brand-block .brand-mark{
  font-family:var(--serif);font-style:italic;font-size:34px;font-weight:300;letter-spacing:-0.02em;
  color:var(--leaf);
}
.brand-block .brand-mark .amp{color:var(--terracotta);font-style:italic;padding:0 4px}
.brand-block .brand-sub{
  margin-top:6px;font-family:var(--sans);font-size:9px;letter-spacing:0.45em;text-transform:uppercase;color:var(--sage-deep)
}

.basket{
  display:inline-flex;align-items:center;gap:10px;
  padding:10px 18px;border:1px solid var(--leaf);border-radius:999px;font-size:12px;letter-spacing:0.1em;text-transform:uppercase
}
.basket .count{
  background:var(--terracotta);color:var(--cream);width:22px;height:22px;border-radius:50%;
  display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:600
}

.nav-row{
  display:flex;justify-content:center;gap:36px;
  padding:14px var(--pad);
  border-bottom:1px solid rgba(45,64,48,.08);
  background:var(--cream-soft);
}
.nav-row a{font-size:12px;letter-spacing:0.25em;text-transform:uppercase;font-weight:500;color:var(--leaf-soft);position:relative}
.nav-row a.active{color:var(--terracotta)}
.nav-row a::after{
  content:"";position:absolute;left:50%;bottom:-18px;
  width:6px;height:6px;border-radius:50%;background:var(--terracotta);
  transform:translateX(-50%) scale(0);transition:transform .3s ease
}
.nav-row a.active::after,.nav-row a:hover::after{transform:translateX(-50%) scale(1)}

@media(max-width:800px){
  .site-header{grid-template-columns:auto 1fr auto;gap:16px}
  .header-left{display:none}
  .nav-row{overflow-x:auto;justify-content:flex-start;gap:24px;-webkit-overflow-scrolling:touch}
}

/* ========== HERO ORGANIQUE ========== */
.hero{
  position:relative;padding:60px var(--pad) 100px;
  display:grid;grid-template-columns:1.1fr 1fr;gap:60px;align-items:center;
  overflow:hidden;
}
.hero::before{
  content:"";position:absolute;
  width:600px;height:600px;border-radius:50%;
  background:radial-gradient(circle, rgba(232,197,184,.6) 0%, rgba(232,197,184,0) 70%);
  top:-100px;right:-150px;z-index:0;pointer-events:none;
}
.hero::after{
  content:"";position:absolute;
  width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle, rgba(149,165,132,.4) 0%, rgba(149,165,132,0) 70%);
  bottom:-80px;left:30%;z-index:0;pointer-events:none;
}
.hero-text{position:relative;z-index:2}
.hero h1{margin:20px 0 28px;max-width:14ch}
.hero h1 .accent{color:var(--terracotta);font-style:italic}
.hero-lede{
  font-size:19px;line-height:1.6;color:var(--leaf-soft);max-width:46ch;margin-bottom:36px
}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:12px;
  padding:18px 30px;border-radius:999px;
  font-family:var(--sans);font-size:13px;font-weight:500;letter-spacing:0.16em;text-transform:uppercase;
  cursor:pointer;transition:all .3s ease;border:1px solid var(--leaf)
}
.btn.primary{background:var(--leaf);color:var(--cream);border-color:var(--leaf)}
.btn.primary:hover{background:var(--terracotta);border-color:var(--terracotta);color:var(--cream)}
.btn.ghost{background:transparent;color:var(--leaf)}
.btn.ghost:hover{background:var(--leaf);color:var(--cream)}
.btn .ico{width:18px;height:18px}

.hero-visual{position:relative;z-index:2}
.hero-photo{
  width:100%;aspect-ratio:4/5;object-fit:cover;
  border-top-left-radius:50% 40%;
  border-top-right-radius:50% 40%;
  border-bottom-left-radius:50% 40%;
  border-bottom-right-radius:50% 40%;
  border-radius:48% 52% 38% 62% / 55% 45% 55% 45%;
  box-shadow:0 30px 60px -20px rgba(45,64,48,.25);
}
.hero-tag{
  position:absolute;bottom:30px;left:-20px;
  background:var(--cream);padding:18px 24px;border-radius:999px;
  display:flex;align-items:center;gap:12px;
  box-shadow:0 12px 30px -10px rgba(45,64,48,.18);
  font-family:var(--serif);font-style:italic;font-size:18px;
}
.hero-tag .dot{width:8px;height:8px;border-radius:50%;background:var(--sage)}

@media(max-width:800px){
  .hero{grid-template-columns:1fr;padding-bottom:60px}
}

/* ========== BLOB DECORATIVE ========== */
.botanic{
  position:absolute;pointer-events:none;opacity:.4;
}

/* ========== ABOUT INLINE ========== */
.our-story{
  padding:100px var(--pad);
  background:var(--cream-soft);
  display:grid;grid-template-columns:1fr 1.4fr;gap:80px;align-items:center;
}
.our-story-img{
  aspect-ratio:1;object-fit:cover;
  border-radius:55% 45% 50% 50% / 45% 55% 50% 50%;
  width:100%
}
.our-story-text h2{margin:18px 0 24px}
.our-story-text p{font-size:17px;line-height:1.7;color:var(--leaf-soft);margin-bottom:16px;max-width:48ch}
.signature-pen{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--terracotta);margin-top:24px;display:block}

@media(max-width:800px){
  .our-story{grid-template-columns:1fr;gap:40px}
}

/* ========== COLLECTIONS ========== */
.collections{
  padding:100px var(--pad);
}
.section-head{text-align:center;margin-bottom:60px}
.section-head h2{margin-top:14px}
.coll-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
}
.coll{
  background:var(--cream-soft);padding:30px;
  border-radius:30px;text-align:center;
  transition:transform .4s ease,box-shadow .4s ease;
}
.coll:hover{transform:translateY(-8px);box-shadow:0 20px 40px -15px rgba(45,64,48,.15)}
.coll img{
  width:100%;aspect-ratio:1;object-fit:cover;border-radius:50%;margin-bottom:22px
}
.coll h3{margin-bottom:8px}
.coll .desc{color:var(--leaf-soft);font-size:14px;margin-bottom:18px;line-height:1.6}
.coll .price{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--terracotta)}
@media(max-width:800px){.coll-grid{grid-template-columns:1fr}}

/* ========== PROCESS RIBBON ========== */
.ribbon{
  background:var(--leaf);color:var(--cream);
  padding:80px var(--pad);
  display:grid;grid-template-columns:repeat(4,1fr);gap:30px;
  position:relative;overflow:hidden;
}
.ribbon::before{
  content:"❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀ ❀";
  position:absolute;inset:0;font-size:200px;opacity:.05;line-height:1;overflow:hidden;
  white-space:nowrap;
}
.ribbon .step{position:relative;z-index:1;border-left:1px solid rgba(250,243,232,.2);padding-left:24px}
.ribbon .step:first-child{border-left:none;padding-left:0}
.ribbon .num{
  font-family:var(--serif);font-style:italic;font-size:36px;color:var(--blush);display:block;margin-bottom:14px
}
.ribbon h4{color:var(--cream);margin-bottom:8px;letter-spacing:0.1em}
.ribbon .step p{color:rgba(250,243,232,.7);font-size:13px;line-height:1.6}
@media(max-width:800px){.ribbon{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.ribbon{grid-template-columns:1fr}.ribbon .step{border-left:none;padding-left:0;border-top:1px solid rgba(250,243,232,.2);padding-top:20px}.ribbon .step:first-child{border-top:none;padding-top:0}}

/* ========== TESTIMONIAL ========== */
.testimonials{
  padding:100px var(--pad);background:var(--cream);
}
.test-grid{
  display:grid;grid-template-columns:repeat(2,1fr);gap:30px;margin-top:50px
}
.test{
  padding:36px;background:var(--cream-soft);border-radius:30px;position:relative
}
.test::before{
  content:"\201C";position:absolute;top:-10px;left:24px;font-family:var(--serif);font-style:italic;font-size:80px;color:var(--blush-deep);line-height:1
}
.test p{font-family:var(--serif);font-style:italic;font-size:18px;line-height:1.55;color:var(--leaf);margin-bottom:24px;padding-top:20px}
.test cite{display:flex;align-items:center;gap:14px;font-style:normal;font-size:13px;color:var(--leaf-soft)}
.test cite .avatar{width:40px;height:40px;border-radius:50%;background:var(--sage);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-style:italic;color:var(--cream);font-size:18px}
.test cite strong{display:block;color:var(--leaf);font-size:14px;font-weight:600}
@media(max-width:700px){.test-grid{grid-template-columns:1fr}}

/* ========== CTA FOOTER BAND ========== */
.cta-band{
  padding:100px var(--pad);text-align:center;background:var(--blush);position:relative;overflow:hidden
}
.cta-band::before,.cta-band::after{
  content:"";position:absolute;width:400px;height:400px;border-radius:50%;
  background:radial-gradient(circle,rgba(250,243,232,.5),transparent 70%)
}
.cta-band::before{top:-150px;left:-100px}
.cta-band::after{bottom:-150px;right:-100px}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{max-width:18ch;margin:14px auto 26px}
.cta-band p{max-width:48ch;margin:0 auto 32px;color:var(--leaf-soft);font-size:17px}

/* ========== PAGE BOUQUETS ========== */
.page-hero{
  padding:80px var(--pad) 60px;text-align:center;background:var(--cream-soft)
}
.page-hero h1{margin:18px 0 18px}
.page-hero p{max-width:50ch;margin:0 auto;color:var(--leaf-soft);font-size:17px}

.filters{
  display:flex;justify-content:center;gap:8px;flex-wrap:wrap;padding:30px var(--pad);background:var(--cream)
}
.filters button{
  border:1px solid var(--leaf);background:transparent;color:var(--leaf);
  padding:10px 22px;border-radius:999px;font-size:12px;letter-spacing:0.15em;text-transform:uppercase;cursor:pointer;transition:all .25s ease;font-weight:500
}
.filters button:hover{background:var(--cream-soft)}
.filters button.is-active{background:var(--leaf);color:var(--cream)}

.shop-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:30px;
  padding:50px var(--pad) 100px
}
.product{
  border-radius:24px;overflow:hidden;background:var(--cream-soft);
  transition:transform .4s ease,box-shadow .4s ease;cursor:pointer
}
.product:hover{transform:translateY(-6px);box-shadow:0 18px 40px -16px rgba(45,64,48,.18)}
.product .img{aspect-ratio:4/5;overflow:hidden}
.product .img img{width:100%;height:100%;object-fit:cover;transition:transform .8s ease}
.product:hover .img img{transform:scale(1.06)}
.product .info{padding:22px 22px 24px}
.product .info h3{font-size:24px;margin-bottom:6px}
.product .info .cat{font-size:11px;letter-spacing:0.2em;text-transform:uppercase;color:var(--sage-deep);font-weight:500}
.product .info .row{display:flex;justify-content:space-between;align-items:center;margin-top:14px}
.product .info .price{font-family:var(--serif);font-style:italic;font-size:24px;color:var(--terracotta)}
.product .info .add{
  width:38px;height:38px;border-radius:50%;background:var(--leaf);color:var(--cream);
  display:flex;align-items:center;justify-content:center;font-size:20px;line-height:1
}
.product:hover .info .add{background:var(--terracotta)}
.is-hidden{display:none!important}
@media(max-width:800px){.shop-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:500px){.shop-grid{grid-template-columns:1fr}}

/* ========== ABONNEMENT BAND ========== */
.subscribe-band{
  padding:100px var(--pad);background:var(--sage);color:var(--cream);position:relative;overflow:hidden
}
.subscribe-band::before{
  content:"";position:absolute;width:500px;height:500px;border-radius:50%;
  background:radial-gradient(circle,rgba(250,243,232,.15),transparent 70%);
  top:-100px;right:-100px
}
.subscribe-band-grid{
  position:relative;z-index:1;display:grid;grid-template-columns:1fr 1.2fr;gap:60px;align-items:center
}
.subscribe-band h2{color:var(--cream)}
.subscribe-band p{color:rgba(250,243,232,.85);font-size:17px;max-width:50ch;margin:16px 0 24px}
.subscribe-band .btn.primary{background:var(--cream);color:var(--leaf);border-color:var(--cream)}
.subscribe-band .btn.primary:hover{background:var(--terracotta);color:var(--cream);border-color:var(--terracotta)}
.formula{background:rgba(250,243,232,.1);border-radius:28px;padding:32px;backdrop-filter:blur(4px)}
.formula h3{color:var(--cream);margin-bottom:18px;font-size:30px}
.formula ul{list-style:none;display:grid;gap:10px}
.formula li{font-size:14px;color:rgba(250,243,232,.9);padding-left:24px;position:relative}
.formula li::before{content:"❀";position:absolute;left:0;color:var(--blush)}
@media(max-width:800px){.subscribe-band-grid{grid-template-columns:1fr}}

/* ========== CONTACT PAGE ========== */
.contact-hero{
  padding:80px var(--pad) 50px;text-align:center;background:var(--cream-soft);
}
.contact-grid{
  display:grid;grid-template-columns:1fr 1.4fr;gap:60px;padding:60px var(--pad) 100px
}
.contact-info .card{background:var(--cream-soft);padding:28px;border-radius:24px;margin-bottom:20px}
.contact-info .card h4{margin-bottom:10px;color:var(--sage-deep)}
.contact-info .card p{font-family:var(--serif);font-style:italic;font-size:20px;color:var(--leaf);line-height:1.4}
.contact-info .card a{color:var(--leaf);border-bottom:1px solid var(--blush-deep)}
.contact-info .card a:hover{color:var(--terracotta);border-color:var(--terracotta)}

form.flower-form{display:grid;gap:22px;background:var(--cream-soft);padding:40px;border-radius:30px}
form.flower-form .row{display:grid;grid-template-columns:1fr 1fr;gap:18px}
form.flower-form .field label{font-size:11px;letter-spacing:0.22em;text-transform:uppercase;color:var(--sage-deep);font-weight:500;margin-bottom:8px;display:block}
form.flower-form input,form.flower-form textarea,form.flower-form select{
  width:100%;padding:14px 16px;border:1px solid rgba(45,64,48,.15);border-radius:14px;
  background:var(--cream);color:var(--leaf);font-family:var(--sans);font-size:15px;outline:none;transition:border-color .25s ease
}
form.flower-form input:focus,form.flower-form textarea:focus,form.flower-form select:focus{border-color:var(--terracotta)}
form.flower-form textarea{min-height:130px;resize:vertical}
@media(max-width:800px){.contact-grid{grid-template-columns:1fr}form.flower-form .row{grid-template-columns:1fr}}

/* ========== FOOTER ========== */
.site-footer{
  background:var(--leaf);color:var(--cream-soft);padding:80px var(--pad) 30px;
}
.footer-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:40px;padding-bottom:50px;border-bottom:1px solid rgba(250,243,232,.1)}
.footer-brand .brand-mark{font-family:var(--serif);font-style:italic;font-size:36px;color:var(--cream);display:block;margin-bottom:14px}
.footer-brand p{color:rgba(250,243,232,.7);max-width:36ch;font-size:14px;line-height:1.6}
.footer-col h4{color:var(--blush);margin-bottom:18px;letter-spacing:0.15em}
.footer-col a,.footer-col span{display:block;padding:5px 0;color:rgba(250,243,232,.7);font-size:14px}
.footer-col a:hover{color:var(--blush)}
.footer-bottom{padding-top:24px;display:flex;justify-content:space-between;gap:24px;font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:rgba(250,243,232,.5)}
@media(max-width:800px){.footer-top{grid-template-columns:1fr 1fr;gap:30px}.footer-bottom{flex-direction:column;text-align:center}}

/* ========== REVEAL ========== */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .9s ease,transform .9s cubic-bezier(.16,1,.3,1)}
.reveal.is-visible{opacity:1;transform:translateY(0)}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}
