/* ============================== MULTI-PAGE ADDITIONS ============================== */
.page{padding-top:96px}
.page-head{padding:clamp(40px,8vw,90px) 0 10px}
.page-head h1{font-family:var(--ff-display);text-transform:uppercase;font-size:clamp(40px,8vw,96px);line-height:.9}
.page-head h1 em{font-style:normal;color:var(--sage)}
.page-head .tag{display:block;margin-bottom:14px}
.page-head .lead{color:var(--creme-dim);max-width:560px;margin-top:16px;font-size:16px}

/* nav: cart + account */
.nav__tools{display:flex;align-items:center;gap:18px}
.nav__icon{position:relative;display:inline-flex;align-items:center;gap:7px;font-family:var(--ff-mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--creme-dim);transition:color .2s}
.nav__icon:hover{color:var(--creme)}
.nav__icon svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.6}
.nav__count{position:absolute;top:-9px;right:-12px;min-width:17px;height:17px;padding:0 4px;border-radius:9px;background:var(--or);color:var(--noir);font-family:var(--ff-mono);font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1;transform:scale(0);transition:transform .25s cubic-bezier(.5,1.6,.5,1)}
.nav__count.show{transform:scale(1)}
.nav__links a.active{color:var(--or)}
@media(max-width:860px){.nav__tools{margin-right:46px}.nav__icon span.lbl{display:none}}

/* add-to-cart button on cards / lightbox */
.jcard__add{position:absolute;bottom:14px;right:14px;z-index:3;width:38px;height:38px;border-radius:50%;border:1px solid var(--or);background:rgba(14,16,15,.78);color:var(--or);cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;opacity:0;transform:translateY(8px);transition:.3s}
.jcard:hover .jcard__add,.jcard:focus-within .jcard__add{opacity:1;transform:none}
.jcard__add:hover{background:var(--or);color:var(--noir)}
.jcard__add.added{background:var(--sage);border-color:var(--sage);color:var(--noir)}
.lb-actions{display:flex;flex-wrap:wrap;gap:12px;margin:6px 0 18px}
.lb-price{font-family:var(--ff-display);font-size:30px;color:var(--or);line-height:1;margin:4px 0 14px}

/* toast */
.toast-wrap{position:fixed;left:50%;bottom:28px;transform:translateX(-50%);z-index:200;display:flex;flex-direction:column;gap:10px;align-items:center;pointer-events:none}
.toast{background:var(--noir-2);border:1px solid var(--or);color:var(--creme);font-family:var(--ff-mono);font-size:13px;padding:13px 20px;border-radius:4px;box-shadow:0 16px 40px rgba(0,0,0,.5);opacity:0;transform:translateY(14px);transition:.35s;display:flex;gap:10px;align-items:center}
.toast.show{opacity:1;transform:none}
.toast .ok{color:var(--sage)}

/* homepage teaser */
.teaser__head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:30px}
.teaser__link{font-family:var(--ff-mono);font-size:13px;color:var(--or);letter-spacing:.08em;border-bottom:1px solid var(--or);padding-bottom:2px;white-space:nowrap}

/* ============================== PANIER ============================== */
.cart{display:grid;grid-template-columns:1.6fr .8fr;gap:40px;align-items:start}
@media(max-width:860px){.cart{grid-template-columns:1fr}}
.cart__items{display:flex;flex-direction:column;gap:14px}
.citem{display:grid;grid-template-columns:88px 1fr auto;gap:18px;align-items:center;border:1px solid var(--line);border-radius:8px;background:var(--noir-2);padding:14px}
.citem__img{width:88px;height:88px;border-radius:6px;object-fit:cover;background:var(--noir)}
.citem__t{font-family:var(--ff-display);text-transform:uppercase;font-size:17px;line-height:1.05}
.citem__meta{font-family:var(--ff-mono);font-size:11px;color:var(--creme-dim);letter-spacing:.06em;margin-top:6px}
.citem__price{font-family:var(--ff-mono);color:var(--or);margin-top:8px;font-size:14px}
.citem__right{display:flex;flex-direction:column;align-items:flex-end;gap:10px}
.qty{display:flex;align-items:center;border:1px solid var(--line);border-radius:4px;overflow:hidden}
.qty button{width:30px;height:30px;background:var(--noir);color:var(--creme);border:0;cursor:pointer;font-size:16px}
.qty button:hover{background:var(--or);color:var(--noir)}
.qty span{min-width:34px;text-align:center;font-family:var(--ff-mono);font-size:14px}
.citem__rm{background:none;border:0;color:var(--creme-dim);cursor:pointer;font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase}
.citem__rm:hover{color:#e08a7a}
.summary{border:1px solid var(--line);border-radius:10px;background:var(--noir-2);padding:26px;position:sticky;top:96px}
.summary h3{font-family:var(--ff-display);text-transform:uppercase;font-size:22px;margin-bottom:18px}
.summary .row{display:flex;justify-content:space-between;font-size:14px;color:var(--creme-dim);margin-bottom:12px;font-family:var(--ff-mono)}
.summary .row.total{color:var(--creme);font-size:18px;border-top:1px solid var(--line);padding-top:14px;margin-top:6px;align-items:baseline}
.summary .row.total b{color:var(--or);font-family:var(--ff-display);font-size:26px}
.summary .btn{width:100%;justify-content:center;margin-top:18px}
.summary__note{font-family:var(--ff-mono);font-size:11px;color:var(--creme-dim);margin-top:14px;line-height:1.5}
.cart__empty{text-align:center;padding:80px 20px;color:var(--creme-dim)}
.cart__empty .big{font-family:var(--ff-display);text-transform:uppercase;font-size:30px;color:var(--creme);margin:10px 0 18px}

/* ============================== COMPTE / AUTH ============================== */
.auth{max-width:440px;margin:0 auto}
.auth__tabs{display:flex;border:1px solid var(--line);border-radius:6px;overflow:hidden;margin-bottom:26px}
.auth__tabs button{flex:1;background:var(--noir-2);color:var(--creme-dim);border:0;padding:14px;cursor:pointer;font-family:var(--ff-mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;transition:.2s}
.auth__tabs button.active{background:var(--or);color:var(--noir);font-weight:700}
.field{margin-bottom:18px}
.field label{display:block;font-family:var(--ff-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--creme-dim);margin-bottom:8px}
.field input{width:100%;background:var(--noir);border:1px solid var(--line);color:var(--creme);padding:14px 16px;border-radius:4px;font-family:var(--ff-body);font-size:15px;transition:.2s}
.field input:focus{outline:none;border-color:var(--or)}
.field input.bad{border-color:#c46a5a}
.field input.good{border-color:var(--sage)}
.field__pw{position:relative}
.field__pw input{padding-right:60px}
.field__pw button{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:0;color:var(--creme-dim);cursor:pointer;font-family:var(--ff-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.field__err{font-family:var(--ff-mono);font-size:11px;color:#e08a7a;margin-top:7px;min-height:14px;display:block}
.pwmeter{height:4px;border-radius:2px;background:var(--line);margin-top:10px;overflow:hidden}
.pwmeter i{display:block;height:100%;width:0;transition:width .3s,background .3s}
.pwhint{font-family:var(--ff-mono);font-size:10px;color:var(--creme-dim);margin-top:6px;letter-spacing:.04em}
.auth .btn{width:100%;justify-content:center;margin-top:6px}
.auth__note{text-align:center;margin-top:18px;font-family:var(--ff-mono);font-size:12px;color:var(--creme-dim)}
.auth__msg{text-align:center;font-family:var(--ff-mono);font-size:13px;margin-bottom:16px;min-height:16px}
.auth__msg.err{color:#e08a7a}.auth__msg.ok{color:var(--sage)}
.remember{display:flex;align-items:center;gap:9px;font-family:var(--ff-mono);font-size:12px;color:var(--creme-dim);margin-bottom:18px;cursor:pointer}
.remember input{width:16px;height:16px;accent-color:var(--or)}

/* account dashboard */
.acct{display:grid;grid-template-columns:.9fr 1.4fr;gap:30px;align-items:start}
@media(max-width:760px){.acct{grid-template-columns:1fr}}
.acct__card{border:1px solid var(--line);border-radius:10px;background:var(--noir-2);padding:26px}
.acct__avatar{width:64px;height:64px;border-radius:50%;background:var(--or);color:var(--noir);font-family:var(--ff-display);font-size:28px;display:flex;align-items:center;justify-content:center;margin-bottom:16px}
.acct__name{font-family:var(--ff-display);text-transform:uppercase;font-size:24px;line-height:1}
.acct__mail{font-family:var(--ff-mono);font-size:12px;color:var(--creme-dim);margin-top:6px}
.acct__stat{display:flex;justify-content:space-between;border-top:1px solid var(--line);padding:12px 0;font-family:var(--ff-mono);font-size:13px;color:var(--creme-dim)}
.acct__stat b{color:var(--or)}
.acct__logout{margin-top:18px}
.order{border:1px solid var(--line);border-radius:8px;background:var(--noir-2);padding:18px;margin-bottom:14px}
.order__head{display:flex;justify-content:space-between;font-family:var(--ff-mono);font-size:12px;color:var(--creme-dim);margin-bottom:10px}
.order__head b{color:var(--or)}
.order__line{font-size:14px;color:var(--creme);display:flex;justify-content:space-between;padding:4px 0}
.empty-soft{color:var(--creme-dim);font-family:var(--ff-mono);font-size:13px;padding:20px 0}

/* ============================== FICHE PRODUIT ============================== */
.crumb{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--creme-dim);margin-bottom:22px}
.crumb a{color:var(--creme-dim)}
.crumb a:hover{color:var(--or)}
.crumb span{color:var(--or)}
.product{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,60px);align-items:start}
@media(max-width:860px){.product{grid-template-columns:1fr}}
.gallery__main{position:relative;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:var(--noir-2);aspect-ratio:1/1;display:flex;align-items:center;justify-content:center}
.gallery__main img{width:100%;height:100%;object-fit:cover}
.gallery__nav{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center;pointer-events:none;padding:0 10px}
.gallery__nav button{pointer-events:auto;width:42px;height:42px;border-radius:50%;border:1px solid var(--line);background:rgba(14,16,15,.72);color:var(--creme);cursor:pointer;font-size:20px}
.gallery__nav button:hover{border-color:var(--or);color:var(--or)}
.gallery__thumbs{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;margin-top:10px}
.gallery__thumbs button{border:1px solid var(--line);padding:0;background:var(--noir);border-radius:5px;overflow:hidden;cursor:pointer;aspect-ratio:1}
.gallery__thumbs button.active{border-color:var(--or)}
.gallery__thumbs img{width:100%;height:100%;object-fit:cover}
.pinfo .tag{display:block;margin-bottom:12px}
.pinfo h1{font-family:var(--ff-display);text-transform:uppercase;font-size:clamp(28px,4.4vw,52px);line-height:.95;margin-bottom:14px}
.pinfo__meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.chip{font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--creme);border:1px solid var(--line);border-radius:3px;padding:6px 11px}
.chip--gold{border-color:var(--or);color:var(--or)}
.pinfo__price{font-family:var(--ff-display);font-size:46px;color:var(--or);line-height:1;margin:6px 0 20px}
.pinfo__desc{color:var(--creme-dim);font-size:15px;line-height:1.6;margin-bottom:24px}
.pinfo__buy{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-bottom:22px}
.pinfo__buy .qty{height:50px}
.pinfo__buy .qty button{width:42px;height:48px;font-size:18px}
.pinfo__buy .btn{flex:1;min-width:200px;justify-content:center;height:50px}
.pfeatures{border-top:1px solid var(--line);padding-top:20px;display:grid;gap:12px}
.pfeature{display:flex;gap:12px;align-items:flex-start;font-size:14px;color:var(--creme-dim)}
.pfeature b{color:var(--creme);font-weight:600}
.pfeature .ic{color:var(--sage);flex:none}
.related{margin-top:clamp(60px,10vw,110px)}

/* ============================== CHECKOUT ============================== */
.checkout{display:grid;grid-template-columns:1.3fr .9fr;gap:40px;align-items:start}
@media(max-width:860px){.checkout{grid-template-columns:1fr}}
.co-card{border:1px solid var(--line);border-radius:10px;background:var(--noir-2);padding:26px;margin-bottom:18px}
.co-card h3{font-family:var(--ff-display);text-transform:uppercase;font-size:20px;margin-bottom:18px}
.co-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.co-grid{grid-template-columns:1fr}}
.co-grid .field{margin-bottom:0}
.co-span{grid-column:1/-1}
#payment-element{margin-top:6px}
.co-pay{width:100%;justify-content:center;margin-top:18px}
.co-msg{font-family:var(--ff-mono);font-size:12px;margin-top:14px;min-height:16px}
.co-msg.err{color:#e08a7a}.co-msg.ok{color:var(--sage)}
.co-mock{font-family:var(--ff-mono);font-size:11px;color:var(--creme-dim);border:1px dashed var(--line);border-radius:6px;padding:12px;margin-top:12px;line-height:1.5}
.co-success{text-align:center;padding:70px 20px}
.co-success .big{font-family:var(--ff-display);text-transform:uppercase;font-size:34px;color:var(--sage);margin:14px 0 10px}

/* ============================== SUIVI ============================== */
.track-form{display:flex;gap:12px;flex-wrap:wrap;max-width:560px;margin-bottom:30px}
.track-form input{flex:1;min-width:220px;background:var(--noir);border:1px solid var(--line);color:var(--creme);padding:14px 16px;border-radius:4px;font-family:var(--ff-body);font-size:15px}
.track-form input:focus{outline:none;border-color:var(--or)}
.track-status{display:inline-flex;align-items:center;gap:10px;font-family:var(--ff-mono);font-size:13px;letter-spacing:.08em;text-transform:uppercase;border:1px solid var(--or);color:var(--or);border-radius:3px;padding:8px 14px;margin-bottom:24px}
.timeline{border-left:2px solid var(--line);margin-left:8px;padding-left:24px;display:flex;flex-direction:column;gap:22px}
.tl-item{position:relative}
.tl-item::before{content:"";position:absolute;left:-31px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--noir-2);border:2px solid var(--or)}
.tl-item.done::before{background:var(--sage);border-color:var(--sage)}
.tl-date{font-family:var(--ff-mono);font-size:11px;color:var(--creme-dim);letter-spacing:.06em}
.tl-label{font-size:15px;color:var(--creme);margin-top:4px}

/* ============================== ADMIN ============================== */
.admin{display:grid;grid-template-columns:1.1fr .9fr;gap:34px;align-items:start}
@media(max-width:900px){.admin{grid-template-columns:1fr}}
.admin__panel{border:1px solid var(--line);border-radius:10px;background:var(--noir-2);padding:26px}
.admin__panel h3{font-family:var(--ff-display);text-transform:uppercase;font-size:20px;margin-bottom:18px}
.admin textarea{width:100%;background:var(--noir);border:1px solid var(--line);color:var(--creme);border-radius:4px;padding:12px 14px;font-family:var(--ff-body);font-size:14px;resize:vertical;min-height:70px}
.admin textarea:focus,.admin input:focus{outline:none;border-color:var(--or)}
.admin .field input[type=color]{height:46px;padding:4px;cursor:pointer}
.chip-pick{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.chip-pick button{font-family:var(--ff-mono);font-size:11px;letter-spacing:.06em;border:1px solid var(--line);background:var(--noir);color:var(--creme-dim);border-radius:3px;padding:7px 11px;cursor:pointer;text-transform:uppercase}
.chip-pick button.on{border-color:var(--or);color:var(--or)}
.admin__preview{position:sticky;top:96px}
.season-banner-demo{border-radius:8px;padding:18px 20px;font-family:var(--ff-mono);font-size:13px;border:1px solid var(--line);margin-bottom:14px}
.admin .btn{width:100%;justify-content:center;margin-top:8px}
.admin__row{display:flex;gap:10px;flex-wrap:wrap}
.admin__row .btn{flex:1;margin-top:0}
.admin__note{font-family:var(--ff-mono);font-size:11px;color:var(--creme-dim);margin-top:12px;line-height:1.5}

/* ============================== BANNIÈRE SAISON ============================== */
.season-strip{position:relative;z-index:40;background:linear-gradient(90deg,var(--noir-2),var(--navy));border-bottom:1px solid var(--line);font-family:var(--ff-mono);font-size:12px;letter-spacing:.04em;color:var(--creme);text-align:center;padding:9px 40px}
.season-strip b{color:var(--or)}
.season-strip a{color:var(--creme);border-bottom:1px solid var(--or)}
body.has-strip .nav{position:static}

/* ============================== AI DESCRIPTION (fiche produit) ============================== */
.ai-desc{border:1px solid var(--line);border-left:2px solid var(--or);border-radius:6px;background:var(--noir-2);padding:16px 18px;margin:0 0 22px}
.ai-desc__tag{font-family:var(--ff-mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--or);display:flex;align-items:center;gap:8px;margin-bottom:8px}
.ai-desc__body{font-size:15px;color:var(--creme);line-height:1.6}
.ai-desc.loading .ai-desc__body{color:var(--creme-dim)}

/* ============================== CHAT WIDGET ============================== */
.chat-fab{position:fixed;right:22px;bottom:22px;z-index:120;width:58px;height:58px;border-radius:50%;border:1px solid var(--or);background:var(--or);color:var(--noir);cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 14px 34px rgba(0,0,0,.45);transition:transform .25s}
.chat-fab:hover{transform:translateY(-3px)}
.chat-fab svg{width:26px;height:26px;stroke:currentColor;fill:none;stroke-width:1.8}
.chat-panel{position:fixed;right:22px;bottom:90px;z-index:121;width:min(380px,calc(100vw - 32px));height:min(560px,calc(100vh - 130px));background:var(--noir-2);border:1px solid var(--line);border-radius:14px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 24px 60px rgba(0,0,0,.55);opacity:0;transform:translateY(16px) scale(.98);pointer-events:none;transition:.28s cubic-bezier(.3,0,.2,1)}
.chat-panel.open{opacity:1;transform:none;pointer-events:auto}
.chat-head{display:flex;align-items:center;gap:12px;padding:16px 18px;border-bottom:1px solid var(--line)}
.chat-head img{width:34px;height:34px;border-radius:50%}
.chat-head .t{font-family:var(--ff-display);text-transform:uppercase;font-size:16px;line-height:1}
.chat-head .s{font-family:var(--ff-mono);font-size:10px;color:var(--sage);letter-spacing:.1em}
.chat-head .x{margin-left:auto;background:none;border:0;color:var(--creme-dim);font-size:22px;cursor:pointer}
.chat-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}
.chat-msg{max-width:84%;padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.5}
.chat-msg.bot{align-self:flex-start;background:var(--noir);border:1px solid var(--line);color:var(--creme);border-bottom-left-radius:3px}
.chat-msg.me{align-self:flex-end;background:var(--or);color:var(--noir);border-bottom-right-radius:3px}
.chat-msg.typing{color:var(--creme-dim);font-family:var(--ff-mono);font-size:12px}
.chat-foot{border-top:1px solid var(--line);padding:12px;display:flex;gap:8px}
.chat-foot input{flex:1;background:var(--noir);border:1px solid var(--line);color:var(--creme);border-radius:20px;padding:11px 16px;font-family:var(--ff-body);font-size:14px}
.chat-foot input:focus{outline:none;border-color:var(--or)}
.chat-foot button{width:42px;height:42px;border-radius:50%;border:0;background:var(--or);color:var(--noir);cursor:pointer;font-size:18px;flex:none}
.chat-foot button:disabled{opacity:.5;cursor:default}
@media(max-width:520px){.chat-panel{right:8px;bottom:84px}.chat-fab{right:16px;bottom:16px}}

