:root{
  --lin:#F0EBE0; --craie:#F8F4EC; --blanc:#FCFAF4;
  --encre:#15201F; --encre-soft:#4C5755;
  --sapin:#0E6E6E; --sapin-700:#0A5151; --corail:#E08A5B;
  --pierre:#CFC7B7; --pierre-soft:#DED7C8;
  --arch:170px 170px 8px 8px; --wrap:1180px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--lin);color:var(--encre);font-family:"Hanken Grotesk",system-ui,-apple-system,sans-serif;font-size:16px;line-height:1.55;-webkit-font-smoothing:antialiased}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 26px}
.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;font-weight:600;color:var(--sapin)}
.serif{font-family:"Fraunces",Georgia,serif;font-weight:400;line-height:1.04}

/* bandeau défilant */
.ticker{background:var(--sapin);color:var(--craie);overflow:hidden;white-space:nowrap}
.ticker__track{display:inline-block;padding:9px 0;animation:slide 26s linear infinite}
.ticker__track span{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:0 2.4rem;opacity:.92}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* en-tête */
.nav{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--lin) 88%,transparent);backdrop-filter:blur(10px);border-bottom:1px solid var(--pierre)}
.nav__in{display:flex;align-items:center;justify-content:space-between;height:74px}
.brand{font-family:"Fraunces",serif;font-size:1.5rem;letter-spacing:.02em;font-weight:500}
.brand span{color:var(--sapin)}
.nav__links{display:flex;gap:34px;list-style:none}
.nav__links a{font-size:.9rem;font-weight:500;position:relative;padding:4px 0;color:var(--encre-soft)}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1.5px;width:0;background:var(--sapin);transition:width .35s var(--ease)}
.nav__links a:hover{color:var(--encre)}
.nav__links a:hover::after{width:100%}
.nav__act{display:flex;align-items:center;gap:16px}
.icon-btn{display:grid;place-items:center;width:40px;height:40px;border-radius:50%;color:var(--encre);transition:background .25s}
.icon-btn:hover{background:var(--pierre-soft)}
.nav__cta{padding:11px 22px;font-size:.86rem}
.burger{display:none}

/* boutons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;font-weight:600;font-size:.92rem;padding:14px 26px;border-radius:40px;transition:transform .25s var(--ease),background .25s,color .25s}
.btn--fill{background:var(--sapin);color:var(--craie)}
.btn--fill:hover{background:var(--sapin-700);transform:translateY(-2px)}
.btn--line{border:1.5px solid var(--encre);color:var(--encre)}
.btn--line:hover{background:var(--encre);color:var(--craie);transform:translateY(-2px)}
.btn--wa{background:#1FAE54;color:#fff}
.btn--wa:hover{background:#179247;transform:translateY(-2px)}
.btn svg{width:16px;height:16px}

/* héro */
.hero{padding:64px 0 30px}
.hero__in{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.hero h1{font-size:clamp(2.8rem,6vw,4.6rem);margin:18px 0 22px;letter-spacing:-.01em}
.hero h1 em{font-style:italic;color:var(--sapin)}
.hero p{font-size:1.08rem;color:var(--encre-soft);max-width:34ch;margin-bottom:30px}
.btns{display:flex;gap:14px;flex-wrap:wrap}
.vitrines{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.vitrine--tall{grid-row:span 2}
.frame{border-radius:var(--arch);overflow:hidden;position:relative;box-shadow:0 22px 50px -28px rgba(21,32,31,.5);border:1px solid var(--pierre)}
.frame::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,rgba(255,255,255,.18),rgba(255,255,255,0) 38%)}
.ph{aspect-ratio:3/4;position:relative;display:grid;place-items:center;background:repeating-linear-gradient(135deg,rgba(0,0,0,.022) 0 9px,transparent 9px 18px),linear-gradient(160deg,var(--c1),var(--c2));background-size:cover;background-position:center}
.vitrine--tall .ph{aspect-ratio:3/4.5}
.ph svg{width:50%;opacity:.5;color:var(--craie)}
.ph--img{background:#ddd center/cover no-repeat}
.vit-cap{position:absolute;left:14px;bottom:13px;z-index:2;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--craie);text-shadow:0 1px 8px rgba(0,0,0,.4)}

/* univers */
.univers{padding:74px 0 30px}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:34px}
.sec-head h2{font-size:clamp(2rem,3.6vw,2.9rem);letter-spacing:-.01em}
.sec-head p{color:var(--encre-soft);max-width:34ch;font-size:.96rem}
.uni-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.uni{background:var(--craie);border:1px solid var(--pierre);border-radius:14px;padding:18px 18px 22px;transition:transform .35s var(--ease),box-shadow .35s;cursor:pointer}
.uni:hover{transform:translateY(-5px);box-shadow:0 24px 44px -30px rgba(21,32,31,.5)}
.uni__art{border-radius:120px 120px 8px 8px;overflow:hidden;margin-bottom:16px;aspect-ratio:4/5;display:grid;place-items:center;position:relative;background:linear-gradient(160deg,var(--c1),var(--c2))}
.uni__art svg{width:44%;opacity:.55;color:var(--craie)}
.uni h3{font-family:"Fraunces",serif;font-size:1.34rem;font-weight:500;margin-bottom:3px}
.uni small{color:var(--encre-soft);font-size:.84rem;display:block;margin-bottom:12px}
.uni__link{font-size:.82rem;font-weight:700;letter-spacing:.04em;color:var(--sapin);display:inline-flex;gap:7px;align-items:center}
.uni__link svg{width:14px;height:14px;transition:transform .3s}
.uni:hover .uni__link svg{transform:translateX(4px)}

/* catalogue */
.shop{padding:74px 0 40px}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:30px}
.chip{font-size:.85rem;font-weight:600;padding:9px 18px;border-radius:30px;border:1.5px solid var(--pierre);color:var(--encre-soft);transition:all .25s}
.chip:hover{border-color:var(--encre)}
.chip.is-on{background:var(--sapin);border-color:var(--sapin);color:var(--craie)}
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:22px 20px}
.card{display:flex;flex-direction:column}
.card.is-hidden{display:none}
.card__art{border-radius:var(--arch);overflow:hidden;position:relative;margin-bottom:14px;border:1px solid var(--pierre)}
.card__art .ph{aspect-ratio:4/5}
.card__art::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(115deg,rgba(255,255,255,.14),rgba(255,255,255,0) 40%)}
.tag{position:absolute;top:12px;left:12px;z-index:3;background:var(--corail);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 11px;border-radius:20px}
.order{position:absolute;right:12px;bottom:12px;z-index:3;background:var(--encre);color:var(--craie);font-size:.76rem;font-weight:700;padding:9px 15px;border-radius:30px;display:inline-flex;align-items:center;gap:7px;box-shadow:0 8px 20px -10px rgba(0,0,0,.5);transition:background .25s,transform .25s var(--ease)}
.order:hover{background:var(--sapin);transform:translateY(-2px)}
.order svg{width:15px;height:15px}
.card__cat{font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;color:var(--encre-soft);font-weight:600}
.card__name{font-family:"Fraunces",serif;font-size:1.12rem;font-weight:500;margin:3px 0 6px;line-height:1.2}
.card__price{font-weight:700;font-size:1rem}
.card__foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:2px}
.tag--out{background:#6b7280}
.tag--low{background:#E0A33B}
.img-count{position:absolute;left:12px;bottom:12px;z-index:3;display:inline-flex;align-items:center;gap:5px;background:rgba(21,32,31,.78);color:#fff;font-size:.74rem;font-weight:700;padding:5px 10px;border-radius:20px}
.img-count svg{width:13px;height:13px}
.card.is-out .ph{filter:grayscale(.4);opacity:.6}
.stockline{font-size:.74rem;font-weight:700;letter-spacing:.02em;padding:3px 9px;border-radius:20px;white-space:nowrap}
.stockline.ok{background:#e6f4ea;color:#1c6b3a}
.stockline.low{background:#fff4e5;color:#b26a00}
.stockline.out{background:#fdecea;color:#b3261e}
.card{cursor:pointer}
.empty{padding:50px 0;text-align:center;color:var(--encre-soft);border:1.5px dashed var(--pierre);border-radius:16px}

/* infos pratiques */
.infos{padding:54px 0 20px}
.infos .sec-head{margin-bottom:28px}
.infos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.info-card{background:var(--craie);border:1px solid var(--pierre);border-radius:16px;padding:24px 22px;position:relative;overflow:hidden;transition:transform .3s var(--ease),box-shadow .3s}
.info-card::before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--sapin)}
.info-card:hover{transform:translateY(-4px);box-shadow:0 22px 40px -28px rgba(21,32,31,.5)}
.info-badge{display:grid;place-items:center;width:50px;height:50px;border-radius:14px;background:#E4F0EE;font-size:1.5rem;margin-bottom:14px}
.info-card h3{font-family:"Fraunces",serif;font-size:1.2rem;font-weight:500;margin-bottom:8px}
.info-card p{font-size:.92rem;color:var(--encre-soft);line-height:1.5}
.info-card strong{color:var(--encre);font-weight:700}

/* avis */
.avis{padding:30px 0 20px}
.avis-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.avis-card{background:var(--craie);border:1px solid var(--pierre);border-radius:16px;padding:24px}
.avis-stars{display:flex;gap:2px;margin-bottom:12px}
.star{width:17px;height:17px;fill:var(--pierre)}
.star.on{fill:var(--corail)}
.avis-text{font-family:"Fraunces",serif;font-size:1.05rem;line-height:1.4;margin-bottom:16px}
.avis-foot{display:flex;align-items:center;gap:12px}
.avis-foot img{width:42px;height:42px;border-radius:50%;object-fit:cover;border:1px solid var(--pierre)}
.avis-ini{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;background:var(--sapin);color:var(--craie);font-weight:700}
.avis-name{font-weight:700;font-size:.92rem}
.avis-sub{font-size:.78rem;color:var(--encre-soft)}

/* manifeste */
.manifesto{background:var(--sapin);color:var(--craie);margin-top:70px;padding:72px 0}
.mani-in{display:grid;grid-template-columns:1.1fr .9fr;gap:50px;align-items:center}
.manifesto .eyebrow{color:#7FD0CC}
.manifesto h2{font-family:"Fraunces",serif;font-size:clamp(2rem,4vw,3rem);font-weight:400;margin:16px 0 20px;line-height:1.08}
.manifesto p{color:#CFE6E2;max-width:42ch}
.facts{display:flex;gap:14px;flex-wrap:wrap}
.fact{border:1px solid rgba(255,255,255,.22);border-radius:14px;padding:20px 22px;flex:1;min-width:120px}
.fact b{font-family:"Fraunces",serif;font-size:2.1rem;font-weight:400;display:block;line-height:1}
.fact span{font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:#7FD0CC;margin-top:7px;display:block}

/* contact */
.news{padding:70px 0}
.news-in{background:var(--craie);border:1px solid var(--pierre);border-radius:20px;padding:48px;text-align:center;max-width:680px;margin:0 auto}
.news h2{font-family:"Fraunces",serif;font-size:2rem;font-weight:500;margin:12px 0 8px}
.news p{color:var(--encre-soft);margin-bottom:24px}
.news__row{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}

/* pied */
footer{background:var(--sapin-700);color:#BFDBD7;padding:60px 0 28px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:34px}
.foot-brand .brand{color:var(--craie)}
.foot-brand p{font-size:.88rem;max-width:34ch;margin-top:12px;color:#8FB8B3}
.foot-col h4{font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#76A8A2;margin-bottom:14px}
.foot-col a{display:block;font-size:.9rem;padding:5px 0;color:#BFDBD7;transition:color .2s}
.foot-col a:hover{color:var(--craie)}
.foot-bottom{border-top:1px solid rgba(255,255,255,.12);margin-top:42px;padding-top:22px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px;font-size:.8rem;color:#76A8A2}
.foot-bottom a{color:#76A8A2}

/* modale commander */
.modal{position:fixed;inset:0;z-index:80;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(21,32,31,.55);backdrop-filter:blur(3px)}
.modal.is-on{display:flex}
.modal__box{background:var(--lin);border-radius:22px;max-width:420px;width:100%;padding:30px;position:relative;box-shadow:0 30px 70px -20px rgba(0,0,0,.5)}
.modal__box--wide{max-width:480px}
.gallery{position:relative;margin-bottom:20px}
.gstage{aspect-ratio:4/3;border-radius:16px;border:1px solid var(--pierre);background:#cdd6d2 center/cover no-repeat;box-shadow:0 14px 34px -22px rgba(0,0,0,.5)}
.gstage__ph{width:100%;height:100%;display:grid;place-items:center;color:var(--encre-soft);font-size:.9rem;font-weight:600}
.gnav{position:absolute;top:50%;transform:translateY(-50%);width:38px;height:38px;border-radius:50%;background:#fff;border:1px solid var(--pierre);display:grid;place-items:center;cursor:pointer;box-shadow:0 6px 16px -8px rgba(0,0,0,.4)}
.gnav svg{width:18px;height:18px;color:var(--encre)}
.gprev{left:10px}.gnext{right:10px}
.gnav:hover{background:var(--sapin);border-color:var(--sapin)}
.gnav:hover svg{color:#fff}
.gdots{display:flex;justify-content:center;gap:6px;margin-top:12px}
.gdot{width:8px;height:8px;border-radius:50%;background:var(--pierre);cursor:pointer;transition:background .2s}
.gdot.on{background:var(--sapin)}
.modal__close{position:absolute;top:16px;right:16px;z-index:5;background:#fff;border:1px solid var(--pierre)}
.modal__box .eyebrow{display:block;margin-bottom:6px}
.modal__box h3{font-family:"Fraunces",serif;font-size:1.5rem;font-weight:500;margin-bottom:4px;line-height:1.1}
.modal__price{color:var(--sapin);font-weight:700;margin-bottom:6px}
.modal__stock{font-size:.85rem;font-weight:700;margin-bottom:18px}
.modal__stock.ok{color:#1c6b3a}
.modal__stock.low{color:#b26a00}
.modal__stock.out{color:#b3261e}
.modal__opts{display:flex;flex-direction:column;gap:10px}
.modal__opts .btn{width:100%}
.btn--ig{background:#E1306C;color:#fff}
.btn--snap{background:#FFFC00;color:#1a1a1a}
.modal__hint{font-size:.8rem;color:var(--encre-soft);margin-top:16px;text-align:center}

/* menu mobile */
.mobile{position:fixed;inset:0;z-index:60;background:var(--lin);transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;padding:30px 26px}
.mobile.is-on{transform:none}
.mobile__top{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}
.mobile a{font-family:"Fraunces",serif;font-size:2rem;padding:14px 0;border-bottom:1px solid var(--pierre)}

/* révélation */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.in{opacity:1;transform:none}

@media(max-width:920px){
  .nav__links{display:none}
  .burger{display:grid}
  .hero__in,.mani-in{grid-template-columns:1fr;gap:34px}
  .hero{padding-top:44px}
  .uni-grid,.grid,.avis-grid,.infos-grid{grid-template-columns:repeat(2,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .news-in{padding:34px 22px}
}
@media(max-width:540px){
  .nav__cta{display:none}
  .grid{grid-template-columns:1fr 1fr;gap:18px 14px}
  .uni-grid,.avis-grid,.infos-grid{grid-template-columns:1fr}
  .sec-head{flex-direction:column;align-items:flex-start}
  .foot-grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
