/* Poésie Parfumée — Onepage (root) */
:root{
  --bg: #fbfbfb;
  --card: #ffffff;
  --text: #111318;
  --muted: rgba(17,19,24,.72);
  --border: rgba(17,19,24,.10);

  --green: #58A662;
  --pink: #FFD5D6;
  --shadow: 0 18px 45px rgba(16,24,40,.08);

  --radius: 22px;
  --container: 1120px;
}
*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background:
    radial-gradient(900px 420px at 20% 0%, rgba(88,166,98,.08), rgba(0,0,0,0)),
    radial-gradient(900px 420px at 80% 10%, rgba(255,213,214,.22), rgba(0,0,0,0)),
    var(--bg);
}
img{ max-width:100%; display:block; }
a{ color:inherit; }
.container{ max-width: var(--container); margin:0 auto; padding: 0 18px; }

.skip{ position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden; }
.skip:focus{ left: 1rem; top: 1rem; width:auto; height:auto; background:#fff; padding:.6rem 1rem; border-radius:12px; box-shadow: var(--shadow); z-index: 999; }

.topbar{
  background: linear-gradient(90deg, rgba(88,166,98,.14), rgba(255,213,214,.35));
  border-bottom: 1px solid var(--border);
}
.topbar__inner{ display:flex; align-items:center; justify-content:space-between; padding: .55rem 0; font-weight: 600; gap: 1rem; }
.topbar__left{ display:flex; gap:.6rem; align-items:center; color: rgba(17,19,24,.78); }
.dot{ width:10px; height:10px; border-radius:999px; background: var(--green); box-shadow: 0 0 0 4px rgba(88,166,98,.14); }
.topbar__right{ display:flex; gap:.7rem; align-items:center; }
.topbar__right a{ text-decoration:none; opacity:.9; }
.topbar__right a:hover{ text-decoration:underline; opacity:1; }
.sep{ opacity:.6; }

.header{
  position: sticky; top: 0; z-index: 40;
  background: rgba(251,251,251,.82);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
}
.header__inner{ display:flex; align-items:center; justify-content:space-between; padding: .85rem 0; gap: 1rem; }
.brand{ display:flex; align-items:center; gap:.8rem; text-decoration:none; }
.brand img{ width:44px; height:44px; object-fit:contain; }
.brand__txt strong{ display:block; font-weight: 800; letter-spacing:-.02em; }
.brand__txt small{ color: var(--muted); font-weight: 700; }

.nav{ display:flex; gap: 1.05rem; align-items:center; }
.nav a{ text-decoration:none; font-weight: 700; color: rgba(17,19,24,.82); padding: .45rem .5rem; border-radius: 10px; }
.nav a:hover{ background: rgba(255,213,214,.35); }

.header__actions{ display:flex; gap:.6rem; align-items:center; }
.icon-btn{
  appearance:none; border: 1px solid var(--border); background:#fff;
  border-radius: 999px; padding: .45rem .7rem;
  display:inline-flex; align-items:center; gap:.45rem;
  cursor:pointer; box-shadow: 0 8px 22px rgba(16,24,40,.06);
}
.count{
  font-weight: 900;
  background: rgba(88,166,98,.12);
  color: #1e6d2a;
  border-radius: 999px;
  padding: .1rem .45rem;
  border: 1px solid rgba(88,166,98,.18);
}
.hamburger{
  display:none;
  width: 44px; height: 42px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background:#fff; cursor:pointer;
  box-shadow: 0 8px 22px rgba(16,24,40,.06);
}
.hamburger span{ display:block; height:2px; margin: 6px 10px; background: rgba(17,19,24,.75); border-radius: 999px; }

.mobile{ border-top: 1px solid var(--border); background:#fff; }
.mobile__inner{ padding: .9rem 0 1.1rem; display:grid; gap: .55rem; }
.m-link{ text-decoration:none; font-weight: 800; padding: .7rem .8rem; border-radius: 14px; border: 1px solid rgba(17,19,24,.08); background: rgba(255,213,214,.18); }
.m-link:hover{ background: rgba(255,213,214,.32); }
.m-link.btn{ background: var(--green); color:#fff; border-color: transparent; }

.section{ padding: 72px 0; }
.section.alt{
  background: linear-gradient(180deg, rgba(255,213,214,.22), rgba(255,213,214,0));
  border-top: 1px solid rgba(17,19,24,.06);
  border-bottom: 1px solid rgba(17,19,24,.06);
}
h1,h2,h3{ font-family: "Playfair Display", ui-serif, Georgia, Cambria, "Times New Roman", Times, serif; letter-spacing:-.02em; }
h1{ font-size: clamp(2.1rem, 4vw, 3.2rem); line-height:1.05; margin:.35rem 0 1rem; }
h2{ font-size: clamp(1.6rem, 2.6vw, 2.15rem); line-height:1.1; margin:0; }
h3{ font-size: 1.2rem; margin: 0 0 .55rem; }
p{ line-height: 1.6; }
.muted{ color: var(--muted); }

.section-head{ display:flex; justify-content:space-between; gap:1rem; align-items:flex-end; flex-wrap:wrap; margin-bottom: 22px; }
.section-sub{ margin:0; color: var(--muted); max-width: 70ch; }

.hero{ padding: 54px 0 62px; }
.hero__grid{ display:grid; grid-template-columns: 1.15fr .85fr; gap: 1.35rem; align-items:center; }
.kicker{
  display:inline-block; background: rgba(88,166,98,.12);
  color: #1f6f2d; border: 1px solid rgba(88,166,98,.20);
  border-radius: 999px; padding: .35rem .7rem;
  font-weight: 900; font-size: .9rem;
}
.lead{ font-size: 1.08rem; color: rgba(17,19,24,.83); max-width: 62ch; }

.bullets{ margin: 1.05rem 0 0; padding:0; list-style:none; display:grid; gap:.55rem; }
.bullets li{ display:flex; gap:.6rem; align-items:flex-start; color: rgba(17,19,24,.80); font-weight: 650; }
.bullets span{ color: var(--green); font-weight: 1000; }

.cta-row{ display:flex; gap:.75rem; align-items:center; flex-wrap:wrap; margin-top: 1.25rem; }
.cta-row.center{ justify-content:center; }
.btn{
  text-decoration:none; border-radius: 999px;
  padding: .72rem 1rem; font-weight: 900;
  border: 1px solid rgba(17,19,24,.12);
  background:#fff;
  display:inline-flex; align-items:center; justify-content:center;
  gap:.55rem; cursor:pointer;
}
.btn.primary{ background: var(--green); color:#fff; border-color: transparent; box-shadow: 0 12px 30px rgba(88,166,98,.18); }
.btn.primary:hover{ filter: brightness(.98); }
.btn.ghost{ background: rgba(255,213,214,.32); border-color: rgba(255,213,214,.75); }
.btn.ghost:hover{ background: rgba(255,213,214,.45); }
.btn.small{ padding: .62rem .9rem; font-size: .95rem; }
.btn.full{ width:100%; }

.trust{ display:flex; flex-wrap:wrap; gap:.55rem; margin-top: 1.1rem; }
.chip{ background:#fff; border:1px solid rgba(17,19,24,.10); border-radius: 999px; padding: .35rem .65rem; font-weight: 800; color: rgba(17,19,24,.78); }

.hero__media{ position:relative; }
.banner{ border-radius: var(--radius); border: 1px solid rgba(17,19,24,.08); box-shadow: var(--shadow); background:#fff; }
.cards{ display:grid; gap:.75rem; margin-top: .75rem; }
.mini{ display:flex; gap:.75rem; align-items:center; background:#fff; border: 1px solid rgba(17,19,24,.08); border-radius: 18px; padding: .7rem .7rem; box-shadow: 0 10px 28px rgba(16,24,40,.06); }
.mini img{ width:56px; height:56px; object-fit:cover; border-radius: 14px; }
.mini small{ color: var(--muted); display:block; font-weight: 750; }

.split{ display:grid; grid-template-columns: 1.05fr .95fr; gap: 1.2rem; align-items:start; }
.panel{ background:#fff; border: 1px solid rgba(17,19,24,.10); border-radius: var(--radius); padding: 18px 18px; box-shadow: var(--shadow); }

.spirit-grid{ display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap: .65rem; margin-top: .9rem; }
.spirit{ display:flex; gap:.65rem; align-items:center; border-radius: 16px; border: 1px solid rgba(17,19,24,.08); background: rgba(255,213,214,.18); padding: .65rem .7rem; }
.spirit span{ font-size: 1.2rem; }
.spirit small{ color: var(--muted); font-weight: 700; }

.grid{ display:grid; gap: 1rem; }
.grid.products{ grid-template-columns: repeat(4, minmax(0,1fr)); }
.grid.features{ grid-template-columns: repeat(4, minmax(0,1fr)); }
.grid.reviews{ grid-template-columns: repeat(3, minmax(0,1fr)); }

.card{ background: var(--card); border: 1px solid rgba(17,19,24,.10); border-radius: var(--radius); box-shadow: var(--shadow); }
.product .imgwrap{
  border-bottom: 1px solid rgba(17,19,24,.08);
  border-radius: var(--radius) var(--radius) 0 0;
  overflow:hidden; position:relative;
  background: linear-gradient(180deg, rgba(255,213,214,.25), rgba(255,213,214,0));
}
.product .imgwrap img{ width:100%; aspect-ratio: 1/1; object-fit: cover; }
.tag{
  position:absolute; left: 12px; top: 12px;
  background: rgba(255,255,255,.92);
  border: 1px solid rgba(17,19,24,.10);
  border-radius: 999px;
  padding: .25rem .55rem;
  font-weight: 900;
  color: rgba(17,19,24,.78);
}
.product .content{ padding: 14px 14px 16px; }
.row{ display:flex; justify-content:space-between; gap:.7rem; align-items:center; margin-top: .6rem; }
.price{ font-weight: 1000; color: #1f6f2d; }
.link{ color: rgba(17,19,24,.70); text-decoration:none; font-weight: 850; }
.link:hover{ text-decoration:underline; }
.pill{ font-weight: 900; border-radius: 999px; padding: .25rem .55rem; background: rgba(88,166,98,.10); border: 1px solid rgba(88,166,98,.18); color: #1f6f2d; font-size: .85rem; }

.placeholder{ aspect-ratio: 1/1; display:grid; place-items:center; }
.placeholder .ph{
  width: 100%; height: 100%;
  display:grid; place-items:center;
  font-weight: 1000; color: rgba(17,19,24,.70);
  background:
    radial-gradient(400px 200px at 30% 20%, rgba(88,166,98,.15), rgba(0,0,0,0)),
    radial-gradient(400px 200px at 70% 60%, rgba(255,213,214,.30), rgba(0,0,0,0)),
    #fff;
}

.feature{ padding: 16px 16px; }
.review{ padding: 16px 16px; }
.review p{ margin:0; color: rgba(17,19,24,.82); }
.who{ margin-top: .85rem; display:flex; gap:.55rem; align-items:center; color: var(--muted); font-weight: 800; }

.faq{ display:grid; gap:.75rem; }
details.card{ padding: 14px 14px; }
summary{ cursor:pointer; font-weight: 1000; list-style:none; }
summary::-webkit-details-marker{ display:none; }
details .muted{ margin-top: .65rem; }

.table-wrap{
  overflow:auto; border-radius: var(--radius);
  border: 1px solid rgba(17,19,24,.10);
  box-shadow: var(--shadow); background:#fff;
}
.table{ width:100%; border-collapse: collapse; min-width: 720px; }
.table th, .table td{ padding: 14px 14px; border-bottom: 1px solid rgba(17,19,24,.08); text-align:left; vertical-align:top; }
.table thead th{ background: rgba(255,213,214,.26); font-weight: 1000; }
.note{ color: var(--muted); margin-top: .8rem; }

.embed-top{ display:flex; justify-content:flex-end; margin: .4rem 0 .6rem; }
.embed{ border-radius: 18px; overflow:hidden; border: 1px solid rgba(17,19,24,.10); background:#fff; }
.embed iframe{ width:100%; height: 320px; border:0; display:block; }

.cart{ position:fixed; inset:0; z-index: 60; pointer-events:none; }
.cart[aria-hidden="false"]{ pointer-events:auto; }
.cart__backdrop{ position:absolute; inset:0; background: rgba(10,12,16,.35); border:0; width:100%; height:100%; }
.cart__panel{
  position:absolute; right:0; top:0; bottom:0;
  width: min(430px, 92vw);
  background:#fff;
  border-left: 1px solid rgba(17,19,24,.10);
  box-shadow: -20px 0 60px rgba(16,24,40,.20);
  transform: translateX(110%);
  transition: transform .25s ease;
  display:flex; flex-direction:column;
}
.cart[aria-hidden="false"] .cart__panel{ transform: translateX(0); }
.cart__head{ display:flex; align-items:center; justify-content:space-between; padding: 14px 14px; border-bottom: 1px solid rgba(17,19,24,.10); }
.cart__body{ padding: 14px 14px; overflow:auto; display:grid; gap:.75rem; }
.cart__foot{ padding: 14px 14px; border-top: 1px solid rgba(17,19,24,.10); }
.total{ display:flex; justify-content:space-between; align-items:center; margin-bottom: .75rem; }
.item{
  display:flex; gap:.75rem; align-items:center;
  border: 1px solid rgba(17,19,24,.08);
  border-radius: 18px;
  padding: .65rem .65rem;
}
.item img{ width:56px; height:56px; border-radius: 14px; object-fit:cover; }
.item .meta{ flex:1; }
.item .meta strong{ display:block; }
.item .meta small{ color: var(--muted); font-weight: 750; }
.qty{
  display:flex; align-items:center; gap:.35rem;
  border: 1px solid rgba(17,19,24,.10);
  border-radius: 999px;
  padding: .25rem .35rem;
}
.qty button{
  appearance:none; border:0; background:transparent; cursor:pointer;
  width: 28px; height: 28px; border-radius: 999px;
  font-weight: 1000;
}
.qty button:hover{ background: rgba(255,213,214,.35); }

.footer{ padding: 42px 0 34px; border-top: 1px solid rgba(17,19,24,.08); background:#fff; }
.footer__banner img{ border-radius: 18px; border: 1px solid rgba(17,19,24,.08); }
.footer__grid{ margin-top: 18px; display:grid; grid-template-columns: 1.2fr 1fr 1fr; gap: 1rem; }
.links{ list-style:none; padding:0; margin:0; display:grid; gap: .5rem; }
.links a{ text-decoration:none; color: rgba(17,19,24,.76); font-weight: 800; }
.links a:hover{ text-decoration:underline; color: rgba(17,19,24,.92); }
.footer__bottom{ margin-top: 18px; padding-top: 14px; border-top: 1px solid rgba(17,19,24,.08); display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; color: rgba(17,19,24,.72); }

@media (max-width: 980px){
  .nav{ display:none; }
  .hamburger{ display:inline-block; }
  .hero__grid{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .grid.products{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .grid.features{ grid-template-columns: repeat(2, minmax(0,1fr)); }
  .grid.reviews{ grid-template-columns: 1fr; }
  .footer__grid{ grid-template-columns: 1fr; }
}
@media (max-width: 520px){
  .grid.products{ grid-template-columns: 1fr; }
  .topbar__right .sep{ display:none; }
}
