/* Spliff Loyalty — Front CSS v2.0.8 */
:root{--sl-dark:#1b1b1b;--sl-light:#f9f9f9;--sl-accent:#E8A838;--sl-accent-soft:rgba(232,168,56,0.10);--sl-accent-border:rgba(232,168,56,0.25);--sl-green:#2e7d32;--sl-green-soft:rgba(46,125,50,0.08);--sl-red:#c62828;--sl-radius:14px;--sl-radius-sm:10px;--sl-font:'Syne',-apple-system,BlinkMacSystemFont,sans-serif}
@import url('https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&display=swap');
.sl-club,.sl-club *{box-sizing:border-box;margin:0;padding:0}
.sl-hidden{display:none !important}
.sl-club{font-family:var(--sl-font);background:var(--sl-light);max-width:100%;margin:0 auto;min-height:100vh;-webkit-font-smoothing:antialiased}

/* Guest (non logged-in) wrapper around [woocommerce_my_account] login/register form */
.sl-club-guest{box-sizing:border-box;padding:24px 20px;max-width:1280px;margin:0 auto;width:100%}
.sl-club-guest *{box-sizing:border-box}
@media(min-width:768px){.sl-club-guest{padding:48px 40px}}

/* HERO */
.sl-hero{position:relative;padding:20px;overflow:hidden}
.sl-hero-bg{position:absolute;inset:0;background:var(--sl-dark);background-size:cover;background-position:center;z-index:0}
.sl-hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(27,27,24,0.7) 0%,rgba(27,27,24,0.35) 100%);z-index:1}
.sl-hero-content{position:relative;z-index:2;display:flex;justify-content:space-between;align-items:stretch;gap:16px;padding:0;max-width:740px;margin:0 auto}
.sl-hero-left{display:flex;flex-direction:column;justify-content:space-between;flex:1;min-width:0}
.sl-hero-right{display:flex;flex-direction:column;align-items:flex-end;gap:10px;flex-shrink:0}
.sl-hero-brand{display:flex;align-items:center;gap:20px}
.sl-hero-logo{font-family:var(--sl-font);font-size:14px;font-weight:800;color:var(--sl-light);line-height:1;letter-spacing:.5px}
.sl-hero-logo span{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:2px;opacity:.7}
.sl-tier-pill{font-size:9px;font-weight:800;padding:2px 10px;border-radius:99px;letter-spacing:1.5px;text-transform:uppercase;display:inline-block}
.sl-hero-greeting{font-size:12px;color:rgba(249,249,249,0.75);text-transform:uppercase;letter-spacing:1.5px;font-weight:600}
.sl-hero-account-btn{width:36px;height:36px;border-radius:50%;border:2px solid rgba(249,249,249,0.3);background:rgba(249,249,249,0.1);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}
.sl-hero-account-btn:hover{background:rgba(249,249,249,0.2)}
.sl-hero-balance{background:rgba(249,249,249,0.12);backdrop-filter:blur(8px);border:1px solid rgba(249,249,249,0.15);padding:6px 12px;border-radius:var(--sl-radius-sm);text-align:center;line-height:1.1}
.sl-hero-balance-amount{font-weight:800;font-size:16px;color:var(--sl-light)}
.sl-hero-balance-label{font-size:8px;color:rgba(249,249,249,0.5);text-transform:uppercase;letter-spacing:1px;margin-top:0}

/* HEADER STICKY — hero + tabs stick together */
.sl-header-sticky{position:sticky;top:0;z-index:50;background:var(--sl-dark)}
.sl-header-sticky::after{content:'';display:block;height:0}
body.admin-bar .sl-header-sticky{top:32px}
@media screen and (max-width:782px){body.admin-bar .sl-header-sticky{top:46px}}

/* TABS — tier colored */
.sl-tabs-wrap{background:#fff;border-bottom:1px solid #EBEBEB;position:static;width:100%}
.sl-tabs{display:flex;gap:0;max-width:100%;margin:0 auto}
.sl-tab{display:flex;flex-direction:column;align-items:center;gap:4px;padding:12px 4px 10px;border:none;background:none;cursor:pointer;font-family:var(--sl-font);font-size:9px;font-weight:600;color:#AAA;letter-spacing:.8px;text-transform:uppercase;transition:color .2s,border-color .2s;border-bottom:2.5px solid transparent;flex:1;white-space:nowrap}
.sl-tab.active{color:var(--tier-color,var(--sl-dark));border-bottom-color:var(--tier-color,var(--sl-dark));background:none !important;box-shadow:none !important;outline:none !important}
.sl-tab:hover:not(:focus-visible){background:rgba(0,0,0,0.03) !important}
.sl-tab:focus,.sl-tab:active,.sl-tab:focus-visible{background:none !important;box-shadow:none !important;outline:none !important}
.sl-tab:not(.active):hover:not(:focus-visible){color:var(--tier-color,#666);border-bottom-color:rgba(0,0,0,0.08)}

.sl-content{padding:18px 16px 50px}
.sl-panel{display:none;flex-direction:column;gap:18px}
.sl-panel.active{display:flex}
.sl-card{background:#fff;border-radius:var(--sl-radius);border:1px solid #EBEBEB;padding:18px;transition:box-shadow .25s;overflow:hidden}
.sl-card:hover{box-shadow:0 4px 16px rgba(0,0,0,0.04)}
.sl-section{display:flex;flex-direction:column;gap:10px}
.sl-section-title{font-weight:800;font-size:16px;color:var(--sl-dark);text-transform:uppercase;letter-spacing:1px}
.sl-section-sub{font-size:11px;color:#999}
.sl-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* ══════ STEPPER v8 ══════ */
.sl-stepper{background:#fff;border-radius:var(--sl-radius);border:1px solid #EBEBEB;padding:18px 16px 10px;overflow:visible}
.sl-stepper-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}
.sl-stepper-head-left{display:flex;align-items:center;gap:10px}
.sl-stepper-rate{font-size:14px;font-weight:700}
.sl-stepper-spent{font-size:11px;color:#999;font-weight:600}
.sl-stepper-spent strong{color:var(--sl-dark)}
.sl-stepper-track{display:flex;align-items:center;position:relative}
.sl-stepper-step{display:flex;flex-direction:column;align-items:center;gap:4px;min-width:0;position:relative;z-index:2}
.sl-stepper-info{text-align:center;line-height:1.2;margin-top:2px}
.sl-stepper-name{font-weight:800;letter-spacing:1.2px;text-transform:uppercase}
.sl-sn-reached{color:#ccc;font-size:7px}
.sl-sn-current{color:var(--sl-dark);font-size:10px}
.sl-sn-next{color:#999;font-size:8px}
.sl-sn-upcoming{color:#ccc;font-size:7px}
.sl-stepper-pct{font-weight:700;margin-top:0}
.sl-sp-reached{color:#ddd;font-size:10px}
.sl-sp-current{color:var(--sl-dark);font-size:13px}
.sl-sp-next{color:#bbb;font-size:11px}
.sl-sp-upcoming{color:#ddd;font-size:10px}
.sl-stepper-threshold{font-size:8px;color:#bbb;font-weight:600;margin-top:0}
.sl-si-current .sl-stepper-name{font-size:9px}
.sl-si-next{opacity:.6}
.sl-si-upcoming{opacity:.35}
.sl-si-reached{opacity:.45}
.sl-stepper-dot{border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s;position:relative;border:2.5px solid #ddd;background:#fafafa;cursor:pointer}
.sl-stepper-dot-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);font-size:10px;font-weight:800;color:#fff;padding:3px 9px;border-radius:8px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .3s;z-index:10;background:var(--sl-dark)}
.sl-stepper-dot-tooltip.show{opacity:1}
.sl-stepper-dot-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:4px solid var(--sl-dark)}
.sl-dot-reached{width:26px;height:26px;font-size:12px;opacity:.45}
.sl-dot-current{width:44px;height:44px;font-size:20px;box-shadow:0 0 0 6px rgba(0,0,0,0.05);transform:scale(1.08)}
.sl-dot-next{width:28px;height:28px;font-size:13px;opacity:.55}
.sl-dot-upcoming{width:24px;height:24px;font-size:11px;opacity:.2;border-style:dashed}
.sl-dot-check{position:absolute;bottom:-3px;right:-3px;width:14px;height:14px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:800;color:#fff;border:2px solid #fff;z-index:3}
.sl-stepper-line{flex:1 1 20px;min-width:16px;height:3px;border-radius:99px;background:#EAEAEA;position:relative;z-index:1;align-self:flex-start;margin-top:22px;margin-left:-4px;margin-right:-4px}
.sl-stepper-line-fill{position:absolute;left:0;top:0;height:100%;border-radius:99px;transition:width 1.2s cubic-bezier(.4,0,.2,1)}
.sl-stepper-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px;flex-wrap:wrap;gap:8px}
.sl-stepper-msg{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}
.sl-stepper-next-pill{font-size:11px;font-weight:700;display:flex;align-items:center;gap:4px}
.sl-bar-wrap{padding:0 2px;margin-top:10px;position:relative;padding-bottom:16px}
.sl-bar-ends{display:flex;justify-content:space-between;font-size:9px;color:#999;margin-bottom:4px;font-weight:700;position:relative}
.sl-bar-cp-label{font-size:8px;color:#bbb;font-weight:600}
.sl-bar-track{position:relative;height:6px;background:#EAEAEA;border-radius:3px}
.sl-bar-fill{height:100%;border-radius:3px;transition:width 1s ease;position:relative;min-width:14px}
.sl-bar-dot{position:absolute;right:-8px;top:50%;transform:translateY(-50%);width:20px;height:20px;border-radius:50%;border:3px solid #fff;box-shadow:0 1px 6px rgba(0,0,0,0.18);cursor:pointer;transition:transform .15s;z-index:3}
.sl-bar-dot:active{transform:translateY(-50%) scale(1.2)}
.sl-bar-dot-tooltip{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);font-size:11px;font-weight:800;color:#fff;padding:4px 10px;border-radius:10px;white-space:nowrap;pointer-events:none;opacity:0;transition:opacity .3s}
.sl-bar-dot-tooltip.show{opacity:1}
.sl-bar-dot-tooltip::after{content:'';position:absolute;top:100%;left:50%;transform:translateX(-50%);width:0;height:0;border-left:5px solid transparent;border-right:5px solid transparent;border-top:5px solid;border-top-color:inherit}
.sl-cp{position:absolute;top:50%;transform:translate(-50%,-50%);width:8px;height:8px;border-radius:50%;border:1.5px solid #ddd;background:#fff;z-index:2}
.sl-cp-on{border-color:currentColor;background:currentColor}
.sl-cp-on::after{content:'';position:absolute;inset:1.5px;border-radius:50%;background:#fff}
.sl-bar-bottom{display:flex;justify-content:space-between;font-size:8px;color:#bbb;margin-top:4px;position:relative;font-weight:600}
.sl-bar-step-label{color:#bbb;font-weight:600;font-size:8px;transition:color .3s}
.sl-step-on{font-weight:800;color:var(--tier-color,var(--sl-accent)) !important}
.sl-cp-label-on{font-weight:700;color:var(--tier-color,var(--sl-accent)) !important}
.sl-bar-levelup{font-weight:700;font-size:8px;color:#999}

/* BENEFITS */
.sl-benefit{display:flex;align-items:center;gap:10px;padding:12px;background:#fff;border:1px solid #EBEBEB;border-radius:var(--sl-radius-sm)}
.sl-benefit-icon{width:36px;height:36px;border-radius:10px;background:var(--sl-accent-soft);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.sl-benefit-label{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.5px}
.sl-benefit-value{font-size:14px;font-weight:800;color:var(--sl-dark)}
.sl-next-tier{border:1.5px dashed #5a8bff;background:rgba(90,139,255,0.03)}
.sl-next-tier-header{display:flex;align-items:center;gap:12px}
.sl-next-tier-icon{font-size:28px}
.sl-next-tier-title{font-weight:800;font-size:14px;color:var(--sl-dark)}
.sl-next-tier-sub{font-size:11px;color:#999}
.sl-next-tier-details{margin-top:10px;font-size:12px;color:#777;line-height:1.5;padding-top:10px;border-top:1px solid rgba(90,139,255,0.1)}

/* REFERRAL */
.sl-referral-locked{position:relative;overflow:hidden}
.sl-referral-locked>*:not(.sl-referral-overlay){filter:blur(6px);pointer-events:none;user-select:none}
.sl-referral-overlay{position:absolute;inset:0;z-index:10;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(255,255,255,0.25);border-radius:12px}
.sl-referral-overlay__text{text-align:center;font-size:14px;font-weight:700;color:var(--sl-dark);line-height:1.5;max-width:280px;padding:16px 20px;background:rgba(255,255,255,0.92);border-radius:10px;box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.sl-referral-hero{background:linear-gradient(135deg,#1b1b1b,#2D4A1B)}
.sl-referral-title{font-weight:800;font-size:18px;color:var(--sl-light)}
.sl-referral-sub{font-size:12px;color:rgba(249,249,249,0.65);margin-top:4px}
.sl-referral-grid{display:flex;flex-direction:column;gap:12px;margin-top:12px}
.sl-reward-card{text-align:center;border-color:var(--sl-accent-border);padding:18px 10px;width:100%}
.sl-reward-icon{font-size:28px;margin-bottom:4px}
.sl-reward-label{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.5px}
.sl-reward-value{font-size:22px;font-weight:800;color:var(--sl-dark)}
.sl-reward-desc{font-size:11px;color:#999}
.sl-referral-code-label{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}
.sl-referral-code-row{display:flex;gap:8px}
.sl-share-row{display:flex;gap:8px;margin-top:10px}
.sl-share-btn{display:flex;align-items:center;justify-content:center;gap:6px;flex:1;padding:10px 12px;border-radius:8px;font-family:var(--sl-font);font-size:12px;font-weight:600;text-decoration:none;cursor:pointer;transition:opacity .2s;border:none}
.sl-share-btn:hover{opacity:.85}
.sl-share-whatsapp{background:#25D366;color:#fff}
.sl-share-email{background:#555;color:#fff}
.sl-referral-code{flex:1;padding:10px;background:#f5f5f2;border-radius:8px;font-family:monospace;font-size:16px;font-weight:800;letter-spacing:3px;text-align:center;color:var(--sl-dark)}
.sl-btn-copy{padding:10px 14px;background:var(--sl-dark);color:var(--sl-light);border:none;border-radius:8px;font-family:var(--sl-font);font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap}
.sl-referral-input-row{display:flex;gap:8px;margin-top:8px}
.sl-sponsor-info{display:flex;justify-content:space-between;align-items:center;padding:8px 0}
.sl-sponsor-name{font-weight:700;font-size:14px;color:var(--sl-dark)}
.sl-sponsor-since{font-size:11px;color:#999}
.sl-sponsor-none-text{font-size:12px;color:#999;margin-bottom:4px}
.sl-referees-list{display:flex;flex-direction:column}
.sl-referee-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f5f5f5}
.sl-referee-row:last-child{border-bottom:none}
.sl-referee-name{font-weight:600;font-size:13px;color:var(--sl-dark)}
.sl-referee-date{font-size:10px;color:#bbb}
.sl-referee-right{display:flex;align-items:center;gap:8px}
.sl-referee-status{font-size:9px;font-weight:700;padding:2px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px}
.sl-referee-status.converted{background:var(--sl-green-soft);color:var(--sl-green)}
.sl-referee-status.pending{background:rgba(232,168,56,0.12);color:#b8860b}
.sl-referee-reward{font-weight:800;font-size:13px;color:var(--sl-green)}

/* BALANCE v2 */
.sl-balance-card-v2{background:#fff;border-radius:var(--sl-radius);border:1px solid #EBEBEB;padding:24px 20px;text-align:center;position:relative;overflow:hidden}
.sl-bal-deco1{position:absolute;top:-30px;right:-30px;width:120px;height:120px;border-radius:50%;background:rgba(232,168,56,0.06);pointer-events:none}
.sl-bal-deco2{position:absolute;bottom:-20px;left:-20px;width:80px;height:80px;border-radius:50%;background:rgba(232,168,56,0.04);pointer-events:none}
.sl-bal-amount{font-size:42px;font-weight:800;color:var(--sl-dark);font-style:italic;position:relative;z-index:1;line-height:1.05;margin-bottom:2px}
.sl-bal-label{font-size:11px;color:#999;text-transform:uppercase;letter-spacing:1px;margin-top:2px;position:relative;z-index:1}
.sl-bal-tip{display:flex;align-items:center;gap:8px;margin-top:16px;padding:10px 14px;background:rgba(232,168,56,0.08);border:1px solid rgba(232,168,56,0.25);border-radius:10px;font-size:12px;color:#8B6914;font-weight:600;text-align:left;position:relative;z-index:1;line-height:1.4}
.sl-bal-tip-ico{flex-shrink:0;width:20px;height:20px;border-radius:50%;background:rgba(232,168,56,0.12);display:flex;align-items:center;justify-content:center;font-size:11px}

/* INPUTS */
.sl-input{flex:1;padding:10px 14px;border:1px solid #ddd;border-radius:8px;font-family:var(--sl-font);font-size:14px;outline:none;transition:border .2s}
.sl-input:focus{border-color:var(--tier-color,var(--sl-accent))}
.sl-result-msg{margin-top:8px;padding:10px;border-radius:8px;font-size:12px;font-weight:600;text-align:center}
.sl-result-msg.success{background:var(--sl-green-soft);color:var(--sl-green)}
.sl-result-msg.error{background:rgba(198,40,40,0.08);color:var(--sl-red)}

/* HISTORY v2 */
.sl-history-head{display:flex;justify-content:space-between;align-items:center}
.sl-filter-bar{display:flex;gap:5px}
.sl-filter-btn{padding:5px 12px;border:1px solid #eee;border-radius:99px;background:#fff;font-family:var(--sl-font);font-size:10px;font-weight:600;color:#bbb;cursor:pointer;transition:all .2s}
.sl-filter-btn.active{background:var(--sl-dark);color:var(--sl-light);border-color:var(--sl-dark)}
.sl-history-list{display:flex;flex-direction:column}
.sl-tx{display:flex;align-items:center;gap:10px;padding:11px 0;border-bottom:1px solid #f5f5f5}
.sl-tx:last-child{border-bottom:none}
.sl-tx-ico{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;flex-shrink:0}
.sl-tx-ico.earn{background:var(--sl-green-soft);color:var(--sl-green)}
.sl-tx-ico.spend{background:rgba(198,40,40,0.06);color:var(--sl-red)}
.sl-tx-mid{flex:1;min-width:0}
.sl-tx-lbl{font-size:12px;font-weight:600;color:var(--sl-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-tx-cat{display:inline-block;font-size:7px;font-weight:700;padding:1px 6px;border-radius:99px;margin-left:4px;vertical-align:middle;text-transform:uppercase;letter-spacing:.5px}
.sl-tx-cat.mission{background:rgba(232,168,56,0.1);color:#b8860b}
.sl-tx-cat.order{background:rgba(90,139,255,0.08);color:#185FA5}
.sl-tx-cat.referral{background:var(--sl-green-soft);color:var(--sl-green)}
.sl-tx-cat.coupon{background:rgba(198,40,40,0.06);color:var(--sl-red)}
.sl-tx-note{font-size:10px;color:#999;margin-top:1px}
.sl-tx-dt{font-size:9px;color:#ccc;margin-top:1px}
.sl-tx-amt{font-weight:800;font-size:13px;white-space:nowrap;flex-shrink:0}
.sl-tx-amt.earn{color:var(--sl-green)}
.sl-tx-amt.spend{color:var(--sl-red)}

/* TRACKING CARD */
.sl-tracking-card{background:var(--sl-dark);border-radius:var(--sl-radius);padding:18px;cursor:pointer;transition:box-shadow .25s;color:var(--sl-light)}
.sl-tracking-card:hover{box-shadow:0 4px 20px rgba(0,0,0,0.15)}
.sl-tracking-card-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.sl-tracking-card-label{font-size:9px;text-transform:uppercase;letter-spacing:1px;color:rgba(249,249,249,0.5);font-weight:600}
.sl-tracking-card-order{font-size:16px;font-weight:800;margin-top:2px}
.sl-tracking-card-status{font-size:10px;font-weight:700;padding:3px 10px;border-radius:99px;background:rgba(90,139,255,0.2);color:#7BA4FF;text-transform:uppercase;letter-spacing:.5px;text-align:center;line-height:1.4 !important}
.sl-tracking-timeline{display:flex;align-items:center;margin-bottom:14px}
.sl-tl-step{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0}
.sl-tl-step span{font-size:8px;text-transform:uppercase;letter-spacing:.5px;font-weight:600;color:rgba(249,249,249,0.4)}
.sl-tl-step.done span,.sl-tl-step.current span{color:rgba(249,249,249,0.8)}
.sl-tl-dot{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;border:2px solid rgba(249,249,249,0.15);background:transparent;color:rgba(249,249,249,0.3)}
.sl-tl-dot.done{background:var(--sl-green);border-color:var(--sl-green);color:#fff;font-size:10px;font-weight:800}
.sl-tl-dot.current{background:var(--sl-accent);border-color:var(--sl-accent);color:var(--sl-dark);font-size:13px;width:32px;height:32px;box-shadow:0 0 0 4px rgba(232,168,56,0.2)}
.sl-tl-line{flex:1;height:3px;background:rgba(249,249,249,0.1);border-radius:2px;margin:0 4px;margin-bottom:18px;position:relative;overflow:hidden}
.sl-tl-line.active{background:var(--sl-green)}
.sl-tl-line.half::after{content:'';position:absolute;left:0;top:0;width:50%;height:100%;background:var(--sl-green);border-radius:2px}
.sl-tracking-card-info{display:flex;justify-content:space-between;align-items:flex-end;padding-top:12px;border-top:1px solid rgba(249,249,249,0.08)}
.sl-tracking-card-loc{font-size:11px;color:rgba(249,249,249,0.6);line-height:1.5}
.sl-tracking-card-num{font-size:10px;font-family:monospace;color:rgba(249,249,249,0.4);letter-spacing:1px}
.sl-tracking-card-clickable{cursor:pointer}

/* Awaiting payment alert */
.sl-tracking-card--awaiting .sl-tracking-card-status{background:rgba(255,180,50,0.2);color:#FFB432}
.sl-tracking-alert{display:flex;gap:10px;align-items:flex-start;padding:12px 14px;border-radius:10px;background:rgba(255,180,50,0.1);border:1px solid rgba(255,180,50,0.25);margin-bottom:4px}
.sl-tracking-alert-icon{font-size:20px;flex-shrink:0;line-height:1}
.sl-tracking-alert-title{font-size:12px;font-weight:700;color:#FFB432;margin-bottom:2px}
.sl-tracking-alert-desc{font-size:11px;color:rgba(249,249,249,0.55);line-height:1.4}

/* Tracking card details (items + address) */
.sl-tracking-card-details{display:flex;justify-content:space-between;align-items:center;padding-top:12px;border-top:1px solid rgba(249,249,249,0.08);margin-top:14px;gap:12px}
.sl-tracking-card-items{display:flex;gap:8px;flex-shrink:0}
.sl-tracking-item{display:flex;align-items:center;gap:6px;background:rgba(249,249,249,0.08);border-radius:8px;padding:4px 8px 4px 4px}
.sl-tracking-item-img{width:28px;height:28px;border-radius:6px;object-fit:cover;display:block;flex-shrink:0}
.sl-tracking-item-qty{font-size:11px;font-weight:700;color:rgba(249,249,249,0.7)}
.sl-tracking-item-name{display:none}
.sl-tracking-card-address{font-size:11px;color:rgba(249,249,249,0.45);display:flex;gap:5px;align-items:center;text-align:right;line-height:1.3}
.sl-tracking-card-address-label{font-weight:700;color:rgba(249,249,249,0.6);font-size:9px;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap}

/* ORDERS */
.sl-orders-list{display:flex;flex-direction:column;gap:10px}
.sl-order-card{padding:16px}
.sl-order-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.sl-order-id{font-weight:800;font-size:12px;color:var(--sl-dark)}
.sl-order-meta{font-size:11px;color:#999}
.sl-order-status{font-size:9px;font-weight:700;padding:3px 8px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px}
.sl-order-status.delivered{background:rgba(37,99,235,0.1);color:#2563eb}
.sl-order-status.processing{background:var(--sl-green-soft);color:var(--sl-green)}
.sl-order-status.pending{background:rgba(0,0,0,0.06);color:#999}
.sl-order-status.cancelled{background:rgba(198,40,40,0.08);color:var(--sl-red)}
.sl-order-status.refunded{background:rgba(232,168,56,0.12);color:#b8860b}
.sl-order-footer{display:flex;justify-content:space-between;align-items:center}
.sl-order-total-wrap{display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.sl-order-total{font-weight:700;font-size:15px;color:var(--sl-dark)}
.sl-order-cashback{font-size:11px;font-weight:700;color:var(--sl-green)}

/* LIFETIME in balance */
.sl-bal-lifetime{display:flex;align-items:center;justify-content:center;gap:6px;margin-top:10px;font-size:11px;color:#999;position:relative;z-index:1;flex-wrap:wrap}
.sl-bal-lifetime strong{color:var(--sl-dark)}
.sl-bal-lifetime-sep{color:#ddd}

/* MISSIONS v2 */
.sl-ms-summary{background:#fff;border-radius:var(--sl-radius);border:1px solid #EBEBEB;padding:18px;display:flex;align-items:center;gap:14px}
.sl-ms-summary-left{flex:1}
.sl-ms-earned{font-size:28px;font-weight:800;color:var(--sl-dark)}
.sl-ms-earned-lbl{font-size:10px;color:#999;text-transform:uppercase;letter-spacing:.5px}
.sl-ms-summary-right{font-size:14px;font-weight:700;color:#999}
.sl-ms-bar{width:100%;height:5px;background:#eee;border-radius:3px;overflow:hidden}
.sl-ms-bar-fill{height:100%;background:var(--tier-color,var(--sl-accent));border-radius:3px;transition:width .5s}
.sl-ms-cats{display:flex;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding:2px 0}
.sl-ms-cats::-webkit-scrollbar{display:none}
.sl-ms-cat{padding:6px 14px;border:1px solid #eee;border-radius:99px;background:#fff;font-size:10px;font-weight:700;color:#999;cursor:pointer;white-space:nowrap;transition:all .15s;flex-shrink:0;font-family:var(--sl-font)}
.sl-ms-cat.active{background:var(--sl-dark);color:var(--sl-light);border-color:var(--sl-dark)}
.sl-ms-list{display:flex;flex-direction:column;gap:8px}
/* Mission card — structured layout:
   [icon]  [title        ] [reward/check]
   [icon]  [description  ]
   [icon]  [badges  …  button (shared row, vertically centered)]
           [progress bar (full width below)]  */
.sl-mc{background:#fff;border-radius:14px;border:1px solid #f0f0f0;padding:14px;transition:all .15s;
	display:grid;grid-template-columns:auto 1fr auto;grid-template-rows:auto auto auto;gap:0 12px;align-items:start}
.sl-mc:hover{border-color:#e0e0e0;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.sl-mc-done{opacity:1;background:rgba(46,125,50,0.04);border-color:rgba(46,125,50,0.12)}
.sl-mc-done .sl-mc-title{color:#666}
.sl-mc-done .sl-mc-ico{opacity:.6}
/* Icon: spans top row + actions row */
.sl-mc-ico{grid-column:1;grid-row:1/3;width:44px;height:44px;border-radius:12px;background:rgba(232,168,56,0.08);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0;align-self:center}
/* Mid column: title + description (top row only) */
.sl-mc-mid{grid-column:2;grid-row:1;min-width:0;display:flex;flex-direction:column;gap:0}
.sl-mc-title{font-size:13px;font-weight:700;color:var(--sl-dark);line-height:1.3}
.sl-mc-desc{font-size:10px;color:#888;line-height:1.3;margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* Actions row: badges + button, shared row vertically centered */
.sl-mc-actions{grid-column:2/4;grid-row:2;display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:6px;min-width:0}
.sl-mc-badges{display:flex;gap:4px;flex-wrap:wrap;min-width:0}
.sl-mc-theme,.sl-mc-freq{display:inline-block;font-size:7px;font-weight:700;padding:2px 6px;border-radius:99px;text-transform:uppercase;letter-spacing:.5px}
.sl-mc-theme.social{background:rgba(90,139,255,0.08);color:#185FA5}
.sl-mc-theme.start{background:rgba(232,168,56,0.1);color:#b8860b}
.sl-mc-theme.loyalty{background:rgba(46,125,50,0.08);color:var(--sl-green)}
.sl-mc-theme.review{background:rgba(148,103,189,0.08);color:#6B4FA0}
.sl-mc-theme.engage{background:rgba(255,152,0,0.08);color:#e65100}
.sl-mc-freq{background:none;border:1px solid #eee;color:#bbb}
.sl-mc-freq.event{border-color:rgba(198,40,40,0.2);color:var(--sl-red);background:rgba(198,40,40,0.04)}
.sl-mc-freq.monthly{border-color:rgba(90,139,255,0.2);color:#185FA5;background:rgba(90,139,255,0.04)}
.sl-mc-freq.recurring{border-color:rgba(46,125,50,0.2);color:var(--sl-green);background:rgba(46,125,50,0.04)}
/* Progress bar: full width below */
.sl-mc-prog{grid-column:1/-1;grid-row:3;margin-top:8px;display:flex;align-items:center;gap:8px}
.sl-mc-prog-bar{flex:1;height:4px;background:#f0f0f0;border-radius:3px}
.sl-mc-prog-fill{height:100%;background:var(--tier-color,var(--sl-accent));border-radius:3px;transition:width .3s ease}
.sl-mc-prog-txt{font-size:10px;color:#999;font-weight:700}
/* Right column: reward (or check) top-right only */
.sl-mc-right{grid-column:3;grid-row:1;align-self:start;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.sl-mc-reward{font-weight:800;font-size:15px;color:#E8781E}
.sl-mc-check{width:24px;height:24px;border-radius:8px;background:var(--sl-green);display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:800}
.sl-mc-btn{padding:6px 12px;background:var(--sl-dark);color:var(--sl-light);border:none;border-radius:6px;font-size:9px;font-weight:700;cursor:pointer;font-family:var(--sl-font);text-transform:uppercase;letter-spacing:.3px;transition:background .15s;white-space:nowrap}
.sl-mc-btn:hover{background:#333}

/* Completed missions collapsible */
.sl-ms-done-section{margin-top:12px}
.sl-ms-done-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:#f5f5f2;border-radius:12px;cursor:pointer;font-size:13px;font-weight:700;color:#999;transition:all .15s}
.sl-ms-done-header:hover{background:#eee}
.sl-ms-done-chevron{font-size:16px;transition:transform .2s;font-weight:400}
.sl-ms-done-section.open .sl-ms-done-chevron{transform:rotate(90deg)}
.sl-ms-done-list{display:none !important;flex-direction:column;gap:8px;margin-top:10px}
.sl-ms-done-section.open .sl-ms-done-list{display:flex !important}
/* Slide-in animation for completed cards */
@keyframes sl-mc-slide-in{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}
.sl-ms-done-section.open .sl-ms-done-list .sl-mc{animation:sl-mc-slide-in .25s ease both}
.sl-ms-done-section.open .sl-ms-done-list .sl-mc:nth-child(2){animation-delay:.05s}
.sl-ms-done-section.open .sl-ms-done-list .sl-mc:nth-child(3){animation-delay:.1s}
.sl-ms-done-section.open .sl-ms-done-list .sl-mc:nth-child(4){animation-delay:.15s}
.sl-ms-done-section.open .sl-ms-done-list .sl-mc:nth-child(5){animation-delay:.2s}

/* Coming soon missions */
.sl-ms-coming-section{margin-top:16px}
.sl-ms-coming-header{font-size:11px;font-weight:700;color:#999;margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}
.sl-ms-coming-list{display:flex;flex-direction:column;gap:6px}
.sl-mc-coming{position:relative;overflow:hidden;pointer-events:none;user-select:none}
.sl-mc-coming .sl-mc-ico,.sl-mc-coming .sl-mc-mid,.sl-mc-coming .sl-mc-right,.sl-mc-coming .sl-mc-actions{filter:blur(5px);opacity:.35}
.sl-mc-coming::after{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,0.15) 0%,rgba(255,255,255,0.4) 100%);border-radius:12px;pointer-events:none}
.sl-mc-coming-badge{display:inline-block;font-size:8px;font-weight:800;padding:3px 10px;border-radius:99px;text-transform:uppercase;letter-spacing:.8px;background:rgba(90,139,255,0.1);color:#5A8BFF;border:1px solid rgba(90,139,255,0.2)}

/* Order card v2: clickable */
.sl-order-card-v2{background:#fff;border-radius:12px;border:1px solid #EBEBEB;padding:14px;cursor:pointer;transition:all .15s}
.sl-order-card-v2:hover{border-color:#ccc;box-shadow:0 2px 8px rgba(0,0,0,0.04)}
.sl-order-card-v2:active{transform:scale(0.99)}
.sl-order-arrow{font-size:18px;color:#ccc;font-weight:300}

/* Order detail modal */
.sl-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:99999;opacity:0;pointer-events:none;transition:opacity .3s}
.sl-modal-overlay.open{opacity:1;pointer-events:auto}
.sl-modal{position:fixed;bottom:0;left:0;right:0;max-height:85vh;background:var(--sl-light);z-index:100000;border-radius:20px 20px 0 0;transform:translateY(100%);transition:transform .35s cubic-bezier(.4,0,.2,1);overflow-y:auto;box-shadow:0 -4px 24px rgba(0,0,0,0.12);pointer-events:none;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,0.15) transparent}
.sl-modal::-webkit-scrollbar{width:6px}
.sl-modal::-webkit-scrollbar-track{background:transparent;margin-top:20px}
.sl-modal::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.12);border-radius:3px}
.sl-modal::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,0.25)}
.sl-modal.open{transform:translateY(0);pointer-events:auto}
.sl-modal-header{padding:16px 20px;background:#fff;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #EBEBEB;position:sticky;top:0;z-index:2;border-radius:20px 20px 0 0}
.sl-modal-title{font-size:15px;font-weight:800;color:var(--sl-dark)}
.sl-modal-close{width:28px;height:28px;border-radius:50%;border:none;background:#f5f5f5;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:#999}
.sl-modal-body{padding:16px 20px 30px}
.sl-modal-loading{text-align:center;padding:40px 0;color:#999;font-size:13px}

/* Order detail content */
.sl-od-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:4px;gap:10px}
.sl-od-num{font-weight:800;font-size:16px;color:var(--sl-dark)}
.sl-od-head .sl-order-status{flex-shrink:0;text-align:center;line-height:1.3}
.sl-od-date{font-size:11px;color:#999;margin-bottom:16px}
.sl-modal-tracking-card{background:var(--sl-dark);border-radius:14px;padding:16px;margin-bottom:16px}
.sl-modal-tracking-card .sl-tracking-timeline{margin-bottom:0}
.sl-modal-tracking-card .sl-tracking-card-info{margin-top:12px;padding-top:10px;border-top:1px solid rgba(255,255,255,0.08)}
.sl-od-tracking{background:#f8f8f5;padding:10px 14px;border-radius:10px;margin-bottom:14px;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px}
.sl-od-tracking-label{font-weight:700;color:var(--sl-dark)}
.sl-od-tracking-num{font-family:monospace;font-weight:700;letter-spacing:1px;color:#666}
.sl-od-tracking-link{color:#185FA5;font-weight:700;text-decoration:none}
.sl-od-track-loc{font-weight:600;color:var(--sl-dark)}
.sl-od-track-date{font-size:10px;color:#999}
.sl-od-track-num{font-family:monospace;font-size:10px;color:#bbb;letter-spacing:1px}
.sl-od-tl-dot.done{background:var(--sl-green);border-color:var(--sl-green);color:#fff;font-size:9px;font-weight:800}
.sl-od-tl-dot.current{background:var(--sl-accent);border-color:var(--sl-accent)}
.sl-od-section-title{font-weight:800;font-size:11px;color:#999;text-transform:uppercase;letter-spacing:.5px;margin:14px 0 8px}
.sl-od-items{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.sl-od-item{display:flex;align-items:center;gap:10px}
.sl-od-item-img{width:40px;height:40px;border-radius:8px;object-fit:cover;flex-shrink:0}
.sl-od-item-placeholder{background:#f5f5f2;display:flex;align-items:center;justify-content:center;font-size:16px}
.sl-od-item-mid{flex:1;min-width:0}
.sl-od-item-name{font-size:12px;font-weight:600;color:var(--sl-dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sl-od-item-qty{font-size:10px;color:#999}
.sl-od-item-price{font-size:12px;font-weight:700;color:var(--sl-dark);flex-shrink:0}
.sl-od-totals{border-top:1px solid #f0f0f0;padding-top:10px;margin-bottom:10px}
.sl-od-total-row{display:flex;justify-content:space-between;font-size:12px;color:#999;padding:3px 0}
.sl-od-grand{font-weight:800;font-size:14px;color:var(--sl-dark);border-top:1px solid #eee;padding-top:8px;margin-top:4px}
.sl-od-discount span:last-child{color:var(--sl-green)}
.sl-od-cb{color:var(--sl-green)}
.sl-od-cb span{color:var(--sl-green)}
.sl-od-info-row{display:flex;justify-content:space-between;font-size:12px;color:#999;padding:6px 0;border-bottom:1px solid #f5f5f5}
.sl-od-address{font-size:12px;line-height:1.6;color:var(--sl-dark)}
.sl-od-bacs-box{background:linear-gradient(135deg,#f0f4ff 0%,#f5f3ff 100%);border:1px solid #ddd5f3;border-radius:12px;padding:18px;margin-top:10px;margin-bottom:6px}
.sl-od-bacs-title{font-size:14px;font-weight:800;color:var(--sl-dark);margin-bottom:8px}
.sl-od-bacs-intro{font-size:13px;color:#444;line-height:1.5;margin-bottom:12px}
.sl-od-bacs-intro strong{color:var(--sl-dark);font-weight:800;font-size:14px}
.sl-od-bacs-details{display:flex;flex-direction:column;gap:8px;background:#fff;border-radius:8px;padding:14px;margin-bottom:12px;border:1px solid #e8e5f0}
.sl-od-bacs-row{display:flex;justify-content:space-between;font-size:13px;gap:8px}
.sl-od-bacs-row span:first-child{color:#888;font-weight:500;white-space:nowrap;flex-shrink:0}
.sl-od-bacs-row span:last-child{color:var(--sl-dark);font-weight:700;text-align:right;font-family:monospace;font-size:12px;word-break:break-all}
.sl-od-bacs-notice{font-size:13px;color:var(--sl-dark);line-height:1.5;background:#fff;border-radius:8px;padding:12px 14px;border:1px solid #e8e5f0;margin-bottom:8px}
.sl-od-bacs-notice strong{font-weight:800;color:#000}
.sl-od-bacs-note{font-size:12px;color:#666;line-height:1.5;margin-bottom:4px}

/* DRAWER */
.sl-drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.4);z-index:99999;opacity:0;pointer-events:none;transition:opacity .3s}
.sl-drawer-overlay.open{opacity:1;pointer-events:auto}
.sl-drawer{position:fixed;top:0;right:-100%;width:min(460px,calc(100vw - 14px));height:100%;background:var(--sl-light);z-index:100000;overflow:hidden;display:flex;flex-direction:column;transition:right .35s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 24px rgba(0,0,0,0.12);pointer-events:none}
.sl-drawer.open{right:0;pointer-events:auto}
.sl-drawer-header{padding:20px;background:#fff;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #EBEBEB;flex-shrink:0;z-index:2}
.sl-drawer-header-left{display:flex;align-items:center;gap:10px}
.sl-drawer-back{width:32px !important;height:32px !important;min-width:32px;min-height:32px;border-radius:50% !important;border:none !important;background:#f5f5f5 !important;cursor:pointer;align-items:center;justify-content:center;color:#666 !important;transition:background .2s;padding:0 !important;margin:0;line-height:1;overflow:visible}
.sl-drawer-back svg{width:16px;height:16px;display:block;flex-shrink:0;stroke:#666}
.sl-drawer-back:hover{background:#eee !important}
.sl-drawer-title{font-size:16px;font-weight:800;color:var(--sl-dark)}
.sl-drawer-close{width:32px;height:32px;border-radius:50%;border:none;background:#f5f5f5;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;color:#999}
.sl-drawer-body{padding:16px 20px 40px;display:flex;flex-direction:column;gap:16px;flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:thin;scrollbar-color:rgba(0,0,0,0.18) transparent}
.sl-drawer-body::-webkit-scrollbar{width:6px}
.sl-drawer-body::-webkit-scrollbar-track{background:transparent}
.sl-drawer-body::-webkit-scrollbar-thumb{background:rgba(0,0,0,0.18);border-radius:3px}
.sl-drawer-body::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,0.3)}

/* Drawer views */
.sl-drawer-view{display:none}
.sl-drawer-view.active{display:flex;flex-direction:column;gap:16px}

.sl-field-row{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid #f5f5f5;font-size:13px}
.sl-field-label{color:#999}
.sl-field-value{font-weight:600;color:var(--sl-dark)}
.sl-address{font-size:13px;line-height:1.6;color:var(--sl-dark)}
.sl-drawer-actions{display:flex;flex-direction:column;gap:8px}
.sl-btn-outline{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:1px solid #ddd;border-radius:var(--sl-radius-sm);background:#fff;font-family:var(--sl-font);font-size:13px;font-weight:600;color:var(--sl-dark);cursor:pointer;text-decoration:none;text-align:center;transition:all .2s}
.sl-btn-outline:hover{background:#f5f5f2}
.sl-btn-outline.danger{color:var(--sl-red);border-color:rgba(198,40,40,0.2)}

/* Drawer forms */
.sl-drawer-form{display:flex;flex-direction:column;gap:14px}
.sl-form-group{display:flex;flex-direction:column;gap:4px}
.sl-form-label{font-size:11px;font-weight:700;color:#999;text-transform:uppercase;letter-spacing:.5px}
.sl-form-input{padding:10px 14px;border:1px solid #ddd;border-radius:var(--sl-radius-sm);font-family:var(--sl-font);font-size:14px;color:var(--sl-dark);background:#fff;transition:border-color .2s;outline:none;width:100%;box-sizing:border-box}
.sl-form-input:focus{border-color:var(--sl-accent)}
.sl-form-input::placeholder{color:#bbb}
select.sl-form-input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath d='M7 10l5 5 5-5' fill='none' stroke='%23999' stroke-width='2'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.sl-form-row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sl-btn-primary{display:flex;align-items:center;justify-content:center;width:100%;padding:13px 16px;border:none;border-radius:var(--sl-radius-sm);background:var(--sl-dark);color:#fff;font-family:var(--sl-font);font-size:14px;font-weight:700;cursor:pointer;transition:opacity .2s}
.sl-btn-primary:hover{opacity:.9}
.sl-btn-primary:disabled{opacity:.5;cursor:not-allowed}
.sl-btn-primary.danger{background:var(--sl-red)}
.sl-form-msg{font-size:12px;text-align:center;padding:8px;border-radius:var(--sl-radius-sm)}
.sl-form-msg:empty{display:none}
.sl-form-msg.success{background:rgba(76,175,80,0.08);color:var(--sl-green)}
.sl-form-msg.error{background:rgba(198,40,40,0.08);color:var(--sl-red)}

/* Logout confirmation */
.sl-logout-confirm{display:flex;flex-direction:column;align-items:center;text-align:center;padding:40px 20px;gap:12px}
.sl-logout-icon{font-size:48px}
.sl-logout-title{font-size:18px;font-weight:800;color:var(--sl-dark);margin:0}
.sl-logout-text{font-size:14px;color:#999;margin:0}
.sl-logout-btns{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:12px}

.sl-toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--sl-dark);color:var(--sl-light);padding:12px 24px;border-radius:12px;font-family:var(--sl-font);font-size:13px;font-weight:600;box-shadow:0 8px 32px rgba(0,0,0,0.2);z-index:200000;opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1)}
.sl-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
@media(min-width:768px){.sl-toast{bottom:32px;padding:18px 36px;border-radius:14px;font-size:16px;box-shadow:0 12px 40px rgba(0,0,0,0.25)}}

.sl-login-prompt{text-align:center;padding:60px 20px;font-family:var(--sl-font)}
.sl-login-prompt a{display:inline-block;margin-top:16px;padding:12px 28px;background:var(--sl-dark);color:var(--sl-light);border-radius:8px;text-decoration:none;font-weight:700}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — TABLET (≥ 768px)
   ══════════════════════════════════════════════════════════ */
@media (min-width: 768px) {

	/* Container */
	.sl-club { max-width: 100% }
	.sl-content { max-width: 740px; margin: 0 auto; padding: 24px 24px 60px }

	/* Hero */
	.sl-hero { padding: 24px 32px 20px }
	.sl-hero-greeting { font-size: 12px; letter-spacing: 2px }

	/* Tabs: match content width */
	.sl-tabs { max-width: 740px; margin: 0 auto; gap: 0 }
	.sl-tab { flex: 1; padding: 14px 8px 12px; font-size: 10px; gap: 5px; justify-content: center }
	.sl-tab svg { width: 22px; height: 22px }

	/* Cards & sections */
	.sl-card { padding: 22px }
	.sl-section-title { font-size: 18px }
	.sl-panel { gap: 20px }

	/* Stepper: stretch lines between dots */
	.sl-stepper { padding: 22px 20px 14px }
	.sl-stepper-dot { width: 42px; height: 42px; font-size: 18px }
	.sl-sn-current { font-size: 11px }
	.sl-sp-current { font-size: 18px }
	.sl-stepper-line { flex: 1 1 40px; min-width: 40px; margin-top: 21px; height: 3px; margin-left: 6px; margin-right: 6px }
	.sl-stepper-step { flex: 0 1 auto !important }

	/* Benefits: still 2 cols but bigger */
	.sl-grid-2 { gap: 14px }
	.sl-benefit { padding: 16px }
	.sl-benefit-icon { width: 42px; height: 42px; font-size: 20px }
	.sl-benefit-value { font-size: 16px }

	/* Referral */
	.sl-referral-hero { padding: 24px }
	.sl-referral-title { font-size: 20px }
	.sl-referral-code { font-size: 18px; padding: 12px }
	.sl-reward-card { padding: 22px 14px }
	.sl-reward-value { font-size: 26px }

	/* Balance card: toned down */
	.sl-balance-card-v2 { padding: 28px 24px }
	.sl-bal-amount { font-size: 40px; line-height: 1.05 }

	/* History transactions */
	.sl-tx { padding: 14px 0 }
	.sl-tx-lbl { font-size: 13px }
	.sl-tx-amt { font-size: 14px }

	/* Orders */
	.sl-order-card-v2 { padding: 18px }
	.sl-order-id { font-size: 15px }

	/* Order modal: centered dialog on tablet */
	.sl-modal {
		bottom: auto; left: 50%; right: auto; top: 50%;
		transform: translate(-50%, -50%) scale(0.95);
		opacity: 0;
		max-height: 80vh; max-width: 560px; width: 92vw;
		border-radius: 20px;
		transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s;
	}
	.sl-modal.open {
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
	}
	.sl-modal-header { border-radius: 20px 20px 0 0 }

	/* Missions */
	.sl-ms-summary { padding: 22px }
	.sl-ms-earned { font-size: 32px }
	.sl-mc { padding: 16px }
	.sl-mc-title { font-size: 14px }
	.sl-mc-ico { width: 40px; height: 40px; font-size: 20px }

	/* Drawer wider */
	/* Drawer → centered modal on tablet */
	.sl-drawer {
		width: 560px; max-width: 90vw;
		height: auto; max-height: 80vh;
		top: 50%; right: auto; left: 50%;
		transform: translate(-50%, -50%) scale(0.95);
		opacity: 0;
		border-radius: 20px;
		box-shadow: 0 12px 40px rgba(0,0,0,0.18);
		transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s;
	}
	.sl-drawer.open {
		right: auto;
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
	}
	.sl-drawer-header { border-radius: 20px 20px 0 0 }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — DESKTOP (≥ 1024px)
   ══════════════════════════════════════════════════════════ */
@media (min-width: 1024px) {

	/* Container */
	.sl-content { max-width: 960px; padding: 28px 32px 60px }

	/* Hero */
	.sl-hero { padding: 28px 40px 22px }
	.sl-hero-content { max-width: 960px; padding: 0 4% }
	.sl-hero-greeting { font-size: 13px }

	/* Tabs: match content width */
	.sl-tabs { max-width: 960px; margin: 0 auto; gap: 0 }
	.sl-tab { flex: 1; padding: 16px 12px 12px; font-size: 11px; gap: 6px; flex-direction: row; justify-content: center }
	.sl-tab svg { width: 18px; height: 18px }

	/* Benefits: 4 columns on desktop, reward cards stay 2 cols */
	.sl-grid-2 { grid-template-columns: repeat(4, 1fr); gap: 14px }
	.sl-grid-2:has(.sl-reward-card) { grid-template-columns: 1fr 1fr }

	/* Club panel */
	#sl-panel-club { gap: 22px }

	/* Stepper lines: much wider on desktop */
	.sl-stepper-line { flex: 2 1 80px; min-width: 60px; height: 4px; margin-left: 8px; margin-right: 8px }
	.sl-stepper-step { flex: 0 1 auto !important }
	.sl-bar-track { height: 7px }
	.sl-bar-dot { width: 22px; height: 22px }
	.sl-cp { width: 9px; height: 9px }
	.sl-bar-ends { font-size: 10px }
	.sl-bar-step-label { font-size: 9px }
	.sl-bar-cp-label { font-size: 9px }

	/* Referral section internals: code + sponsor side by side */
	.sl-referral-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px }

	/* Referral cards row */
	.sl-referral-code-row { gap: 12px }
	.sl-referral-code { font-size: 20px; padding: 14px }
	.sl-btn-copy { padding: 14px 20px; font-size: 13px }

	/* Referral rewards bigger */
	.sl-reward-value { font-size: 28px }
	.sl-reward-card { padding: 26px 16px }

	/* Balance: controlled size */
	.sl-balance-card-v2 { padding: 36px 32px }
	.sl-bal-amount { font-size: 46px; line-height: 1.05 }
	.sl-bal-label { font-size: 12px; letter-spacing: 1.5px; margin-top: 4px }
	.sl-bal-lifetime { font-size: 13px; margin-top: 14px }
	.sl-bal-tip { font-size: 13px }

	/* History: slightly wider rows */
	.sl-tx-ico { width: 32px; height: 32px; font-size: 14px }
	.sl-tx-lbl { font-size: 14px }
	.sl-tx-cat { font-size: 8px; padding: 2px 8px }
	.sl-tx-dt { font-size: 10px }
	.sl-tx-amt { font-size: 15px }

	/* Orders: single column, compact horizontal layout on desktop */
	.sl-orders-list { display: flex; flex-direction: column; gap: 10px }
	.sl-order-card-v2 { display: flex; align-items: center; gap: 20px; padding: 14px 20px }
	.sl-order-header { flex: 1; margin-bottom: 0 }
	.sl-order-footer { margin-top: 0; flex-shrink: 0; gap: 16px }

	/* Order modal: centered on desktop */
	.sl-modal {
		max-width: 640px;
		left: 50%; right: auto;
		top: 50%; bottom: auto;
		border-radius: 16px;
		transform: translate(-50%, -50%) scale(0.95);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		transition: transform .3s, opacity .3s, visibility 0s .3s;
	}
	.sl-modal.open {
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transition: transform .3s, opacity .3s, visibility 0s;
	}

	/* Missions: single column on all screens */
	.sl-ms-list { display: flex !important; flex-direction: column; gap: 12px }
	.sl-ms-coming-list { display: flex !important; flex-direction: column; gap: 10px }
	.sl-ms-done-section.open .sl-ms-done-list { display: flex !important; flex-direction: column; gap: 10px }
	/* Desktop: bigger cards */
	.sl-mc { padding: 16px 18px; column-gap: 14px }
	.sl-mc-ico { width: 48px; height: 48px; font-size: 24px; border-radius: 14px }
	.sl-mc-title { font-size: 15px }
	.sl-mc-desc { font-size: 11px }
	.sl-mc-reward { font-size: 16px }
	.sl-mc-btn { padding: 8px 16px; font-size: 10px; border-radius: 8px }

	/* Missions summary bigger */
	.sl-ms-summary { padding: 24px }
	.sl-ms-earned { font-size: 36px }
	.sl-ms-summary-right { font-size: 16px }
	.sl-ms-cats { gap: 8px }
	.sl-ms-cat { padding: 8px 18px; font-size: 11px }

	/* Drawer → centered modal on desktop */
	.sl-drawer {
		width: 720px; max-width: 90vw;
		height: auto; max-height: 80vh;
		top: 50%; right: auto; left: 50%;
		transform: translate(-50%, -50%) scale(0.95);
		opacity: 0;
		visibility: hidden;
		pointer-events: none;
		border-radius: 20px;
		box-shadow: 0 16px 48px rgba(0,0,0,0.2);
		transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s, visibility 0s .3s;
	}
	.sl-drawer.open {
		right: auto;
		transform: translate(-50%, -50%) scale(1);
		opacity: 1;
		visibility: visible;
		pointer-events: auto;
		transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s, visibility 0s;
	}
	.sl-drawer-header { padding: 24px; border-radius: 20px 20px 0 0 }
	.sl-drawer-body { padding: 20px 24px 40px }
}

/* ══════════════════════════════════════════════════════════
   RESPONSIVE — LARGE DESKTOP (≥ 1280px)
   ══════════════════════════════════════════════════════════ */
@media (min-width: 1280px) {

	/* Wider container */
	.sl-content { max-width: 1080px; padding: 32px 40px 60px }

	/* Tabs: match content width */
	.sl-tabs { max-width: 1080px; margin: 0 auto }

	/* Hero more spacious */
	.sl-hero { padding: 32px 48px 24px }
	.sl-hero-content { max-width: 1080px }
	.sl-hero-greeting { font-size: 14px }
	.sl-hero-left { gap: 14px }
	.sl-hero-cashback-rate { font-size: 20px }
	.sl-tier-pill { font-size: 12px; padding: 5px 18px }

	/* Stepper bigger */
	.sl-stepper { padding: 28px 24px 16px }
	.sl-stepper-head { margin-bottom: 20px }
	.sl-stepper-rate { font-size: 16px }
	.sl-stepper-spent { font-size: 12px }
	.sl-stepper-line { flex: 3 1 100px; min-width: 80px; height: 4px; margin-left: 10px; margin-right: 10px }
	.sl-dot-current { width: 46px; height: 46px; font-size: 20px }
	.sl-dot-next { width: 36px; height: 36px; font-size: 17px }
	.sl-dot-reached, .sl-dot-upcoming { width: 30px; height: 30px; font-size: 14px }
	.sl-stepper-msg { font-size: 15px; margin-top: 16px }
	.sl-bar-wrap { margin-top: 14px }
	.sl-bar-track { height: 8px }
	.sl-bar-dot { width: 24px; height: 24px }
	.sl-bar-ends { font-size: 10px }
	.sl-cp { width: 10px; height: 10px }
	.sl-bar-step-label { font-size: 9px }
	.sl-bar-cp-label { font-size: 9px }
	.sl-bar-bottom { margin-top: 6px }

	/* Section titles */
	.sl-section-title { font-size: 20px; letter-spacing: 1.2px }

	/* Benefits: stay 4 cols, bigger cards */
	.sl-benefit { padding: 18px; gap: 12px }
	.sl-benefit-icon { width: 46px; height: 46px; font-size: 22px; border-radius: 12px }
	.sl-benefit-label { font-size: 11px }
	.sl-benefit-value { font-size: 18px }

	/* Referral section: two-column layout for code + sponsor + filleuls */

	/* Balance: controlled at large screen */
	.sl-balance-card-v2 { padding: 40px 40px }
	.sl-bal-amount { font-size: 50px; line-height: 1.05 }

	/* Orders: still 2 cols but bigger cards */
	.sl-order-card-v2 { padding: 20px }
	.sl-order-id { font-size: 16px }
	.sl-order-meta { font-size: 12px }
	.sl-order-total { font-size: 17px }

	/* Order modal even wider */
	.sl-modal { max-width: 720px }
	.sl-modal-body { padding: 24px 28px 36px }
	.sl-modal-header { padding: 20px 24px }
	.sl-modal-title { font-size: 17px }

	/* Missions: bigger cards */
	.sl-ms-list { gap: 14px }
	.sl-mc { padding: 18px; gap: 14px }
	.sl-mc-ico { width: 44px; height: 44px; font-size: 22px; border-radius: 12px }
	.sl-mc-title { font-size: 15px }
	.sl-mc-desc { font-size: 11px }
	.sl-mc-reward { font-size: 16px }
	.sl-mc-badges { gap: 6px; margin-top: 6px }
	.sl-mc-theme, .sl-mc-freq { font-size: 8px; padding: 3px 8px }
	.sl-mc-check { width: 28px; height: 28px; font-size: 15px }
}

/* ══════════════════════════════════════════════════════════
   CLUB TAB — Desktop 2-column referral layout (≥ 1024px)
   ══════════════════════════════════════════════════════════ */
@media (min-width: 1024px) {
	/* Next tier card: make it more prominent */
	.sl-next-tier { display: flex; align-items: center }
	.sl-next-tier-header { gap: 16px }
	.sl-next-tier-icon { font-size: 32px }
	.sl-next-tier-title { font-size: 16px }
	.sl-next-tier-sub { font-size: 12px }
}

/* ══════════════════════════════════════════════════════════
   HOVER ENHANCEMENTS — Desktop only (pointer: fine)
   ══════════════════════════════════════════════════════════ */
@media (hover: hover) and (pointer: fine) {
	.sl-order-card-v2:hover { border-color: var(--tier-color, var(--sl-accent)); box-shadow: 0 4px 16px rgba(0,0,0,0.06) }
	.sl-mc:not(.sl-mc-done):hover { border-color: var(--tier-color, var(--sl-accent)); box-shadow: 0 4px 16px rgba(0,0,0,0.06); transform: translateY(-1px) }
	.sl-benefit:hover { border-color: var(--sl-accent-border); box-shadow: 0 2px 12px rgba(0,0,0,0.04) }
	.sl-btn-primary:hover { opacity: 0.9; transform: translateY(-1px) }
	.sl-btn-copy:hover { background: #333 }
	.sl-tab:not(.active):hover svg { opacity: 0.8 }
	.sl-mc-btn:hover { background: #333 }
	.sl-hero-account-btn:hover { border-color: rgba(249,249,249,0.6) }
	.sl-filter-btn:hover:not(.active) { border-color: #ccc; color: #999 }
	.sl-ms-cat:hover:not(.active) { border-color: #ccc; color: #777 }
}

/* ══════ ONBOARDING WIZARD (bottom sheet, mandatory) ══════ */
/* z-index 100001 = above drawer (100000) and overlays (99999) so the wizard stays clickable on step 5 when the account drawer opens. */
.sl-onboarding{position:fixed;left:0;right:0;bottom:0;z-index:100001;padding:12px;pointer-events:none}
.sl-onboarding.sl-ob-hidden{display:none}
.sl-onboarding-panel{pointer-events:auto;max-width:440px;margin:0 auto;background:var(--sl-dark);color:var(--sl-light);border-radius:var(--sl-radius);padding:18px 20px 16px;box-shadow:0 12px 32px rgba(0,0,0,.35);border:1px solid rgba(249,249,249,.08);animation:sl-ob-slide-up .28s ease-out}
@keyframes sl-ob-slide-up{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.sl-ob-progress{display:flex;gap:6px;margin-bottom:14px}
.sl-ob-dot{flex:1;height:3px;border:none;padding:0;background:rgba(249,249,249,.18);border-radius:2px;cursor:pointer;transition:background .2s;appearance:none;outline:none}
.sl-ob-dot.active{background:var(--tier-color,#5A8BFF)}
.sl-ob-dot.done{background:rgba(90,139,255,.55)}
.sl-ob-dot:focus-visible{outline:2px solid var(--tier-color,#5A8BFF);outline-offset:2px}
.sl-ob-head{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:rgba(249,249,249,.55);margin-bottom:10px}
.sl-ob-step{color:rgba(249,249,249,.9)}
.sl-ob-sep{opacity:.4}
.sl-ob-section{color:var(--tier-color,#5A8BFF)}
.sl-ob-title{font-family:var(--sl-font);font-size:17px;font-weight:800;line-height:1.25;margin:0 0 8px;color:var(--sl-light)}
.sl-ob-body{font-size:13px;line-height:1.5;color:rgba(249,249,249,.8);margin:0 0 16px}
.sl-ob-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;min-height:44px}
.sl-ob-spacer{flex:1}
.sl-ob-btn{font-family:var(--sl-font);font-size:13px;font-weight:700;padding:10px 18px;border-radius:var(--sl-radius-sm);cursor:pointer;transition:all .18s;border:1.5px solid transparent;white-space:nowrap}
.sl-ob-btn--ghost{background:transparent;color:rgba(249,249,249,.8);border-color:rgba(249,249,249,.22)}
.sl-ob-btn--ghost:hover{background:rgba(249,249,249,.08);border-color:rgba(249,249,249,.4)}
.sl-ob-btn--primary{background:transparent;color:var(--sl-light);border-color:var(--tier-color,#5A8BFF)}
.sl-ob-btn--primary:hover{background:var(--tier-color,#5A8BFF);color:var(--sl-dark)}
.sl-ob-hidden{display:none !important}
body.sl-ob-active .sl-content{padding-bottom:260px}
@media (min-width:768px){
	.sl-onboarding{padding:20px}
	.sl-onboarding-panel{max-width:480px;padding:22px 24px 20px}
	.sl-ob-title{font-size:19px}
	.sl-ob-body{font-size:14px}
}
/* Desktop : floating card centered at bottom, prominent & always above the fold */
@media (min-width:1024px){
	.sl-onboarding{padding:28px 32px}
	.sl-onboarding-panel{max-width:620px;padding:26px 32px 22px;border-radius:18px;box-shadow:0 20px 48px rgba(0,0,0,.45),0 0 0 1px rgba(249,249,249,.06)}
	.sl-ob-progress{gap:8px;margin-bottom:18px}
	.sl-ob-dot{height:4px;border-radius:3px}
	.sl-ob-head{font-size:11px;margin-bottom:14px}
	.sl-ob-title{font-size:22px;line-height:1.22;margin-bottom:10px}
	.sl-ob-body{font-size:15px;line-height:1.55;margin-bottom:22px}
	.sl-ob-actions{min-height:48px;gap:14px}
	.sl-ob-btn{font-size:14px;padding:12px 22px}
	body.sl-ob-active .sl-content{padding-bottom:320px}
}

/* ══════ DRAWER COMPTE — formulaire unifié ══════ */
.sl-account-card{padding:14px 16px;display:flex;flex-direction:column;gap:12px}
.sl-account-actions{display:flex;flex-wrap:wrap-reverse;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid rgba(0,0,0,0.06)}
.sl-account-actions>button{flex:1 1 calc(50% - 5px) !important;min-width:140px;width:auto !important;max-width:none !important;margin:0 !important;min-height:46px}

/* ══════ ORDER ACTION BUTTONS (Pay / Cancel) ══════ */
/* Footer wrapper on the active order card : contains optional Pay button + details row */
.sl-tracking-card-footer{padding-top:12px;border-top:1px solid rgba(249,249,249,0.08);margin-top:14px}
/* When wrapped, the details row no longer needs its own border/padding/margin */
.sl-tracking-card-footer .sl-tracking-card-details{padding-top:0;border-top:none;margin-top:0}
/* Pay button base style (shared mobile + desktop) */
.sl-order-pay-btn{display:flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sl-font,inherit);font-size:14px;font-weight:700;line-height:1.2;color:#fff;background:#2D6A4F;text-decoration:none;padding:12px 26px;border-radius:10px;width:fit-content;max-width:calc(100% - 28px);transition:all .15s;border:none;cursor:pointer}
.sl-order-pay-btn:hover{background:#1F4E3F;transform:translateY(-1px);color:#fff}
.sl-order-pay-btn:active{transform:translateY(0)}
/* Mobile (default) : Pay centered above details */
.sl-tracking-card-footer.has-pay .sl-order-pay-btn{margin:0 auto 14px}
/* Desktop ≥768px : Pay à gauche | items + adresse groupés à droite */
@media (min-width:768px){
	.sl-order-pay-btn{font-size:14px;padding:13px 30px}
	.sl-tracking-card-footer.has-pay{display:flex;align-items:center;gap:20px}
	.sl-tracking-card-footer.has-pay .sl-order-pay-btn{margin:0;flex-shrink:0}
	.sl-tracking-card-footer.has-pay .sl-tracking-card-details{flex:1;min-width:0;justify-content:flex-end;gap:20px}
}

/* Action row inside the order detail modal */
.sl-od-actions{display:flex;flex-direction:column;gap:10px;margin-top:16px;padding-top:16px;border-top:1px solid #E4E4DF}
.sl-od-btn{display:flex;align-items:center;justify-content:center;gap:6px;font-family:var(--sl-font,inherit);font-size:14px;font-weight:700;padding:13px 16px;border-radius:12px;text-decoration:none;border:none;cursor:pointer;transition:all .15s}
.sl-od-btn-pay{background:#2D6A4F;color:#fff}
.sl-od-btn-pay:hover{background:#1F4E3F;transform:translateY(-1px);color:#fff}
.sl-od-btn-cancel{background:transparent;color:#C62828;border:1.5px solid #C62828}
.sl-od-btn-cancel:hover{background:#C62828;color:#fff}
@media (min-width:640px){
	.sl-od-actions{flex-direction:row}
	.sl-od-btn{flex:1}
}

/* ══════ MISSION DETAIL MODAL ══════ */
.sl-mc{cursor:pointer}
.sl-md{display:flex;flex-direction:column;gap:16px;padding:4px 2px 2px}
.sl-md-hero{display:flex;gap:14px;align-items:flex-start}
.sl-md-ico{flex-shrink:0;width:52px;height:52px;border-radius:14px;background:var(--sl-bg-soft,#F5F5F0);display:flex;align-items:center;justify-content:center;font-size:28px;line-height:1}
.sl-md-hero-mid{flex:1;min-width:0}
.sl-md-title{font-size:18px;font-weight:800;line-height:1.25;color:var(--sl-dark,#1b1b1b);margin-bottom:8px;word-break:break-word}
.sl-md-badges{display:flex;flex-wrap:wrap;gap:6px;align-items:center}
.sl-md-reward{display:inline-flex;align-items:center;font-size:13px;font-weight:800;color:#2D6A4F;background:#E8F5EE;padding:3px 10px;border-radius:99px;letter-spacing:.01em}
.sl-md-badge{display:inline-flex;align-items:center;font-size:11px;font-weight:700;padding:3px 9px;border-radius:99px;text-transform:uppercase;letter-spacing:.06em;background:#F0F0EB;color:#6B6B65}
.sl-md-badge.social{background:#FCE7F3;color:#BE185D}
.sl-md-badge.review{background:#FEF3C7;color:#92400E}
.sl-md-badge.start{background:#DBEAFE;color:#1E40AF}
.sl-md-badge.loyalty{background:#E8F5EE;color:#2D6A4F}
.sl-md-badge.engage{background:#EDE9FE;color:#5B21B6}
.sl-md-badge--muted{background:#F0F0EB;color:#9B9B95}
.sl-md-desc{font-size:14px;line-height:1.5;color:#4A4A45;padding:12px 14px;background:#FAFAF7;border-radius:10px;border-left:3px solid var(--tier-color,#D4D4CE)}
.sl-md-progress{background:#FAFAF7;border-radius:10px;padding:12px 14px}
.sl-md-progress-head{display:flex;justify-content:space-between;font-size:12px;font-weight:700;color:#6B6B65;margin-bottom:8px;text-transform:uppercase;letter-spacing:.05em}
.sl-md-progress-head span:last-child{color:var(--tier-color,#2D6A4F)}
.sl-md-progress-bar{height:6px;background:#E4E4DF;border-radius:99px;overflow:hidden}
.sl-md-progress-fill{height:100%;background:var(--tier-color,#2D6A4F);border-radius:99px;transition:width .3s ease}
.sl-md-section{display:flex;flex-direction:column;gap:8px}
.sl-md-section-title{font-size:13px;font-weight:800;color:var(--sl-dark,#1b1b1b);display:flex;align-items:center;gap:6px}
.sl-md-instructions{font-size:14px;line-height:1.6;color:#3A3A35;white-space:pre-wrap;word-break:break-word}
.sl-md-cta{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:14px;font-weight:700;color:#fff;background:var(--sl-dark,#1b1b1b);border:none;border-radius:12px;padding:13px 20px;cursor:pointer;transition:all .15s;margin-top:4px}
.sl-md-cta:hover{background:#333;transform:translateY(-1px)}
.sl-md-check{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:inherit;font-size:13px;font-weight:600;color:var(--sl-dark,#1b1b1b);background:transparent;border:1.5px solid #ddd;border-radius:12px;padding:11px 20px;cursor:pointer;transition:all .15s;margin-top:8px;-webkit-tap-highlight-color:transparent;outline:none}
@media (hover:hover){.sl-md-check:hover{background:#f5f5f2;border-color:#bbb}}
.sl-md-check:focus{outline:none;background:transparent;border-color:#ddd}
.sl-md-check:focus-visible{outline:2px solid var(--sl-dark,#1b1b1b);outline-offset:2px}
.sl-md-check:disabled{opacity:.5;cursor:not-allowed;background:transparent;border-color:#ddd;color:var(--sl-dark,#1b1b1b)}
.sl-md-done{display:flex;align-items:center;justify-content:center;gap:6px;font-size:13px;font-weight:700;color:#2D6A4F;background:#E8F5EE;padding:12px;border-radius:10px;margin-top:4px}
@media (min-width:768px){
	.sl-md-title{font-size:20px}
	.sl-md-ico{width:60px;height:60px;font-size:32px}
	.sl-md-desc,.sl-md-instructions{font-size:15px}
}

/* ════════════════════════════════════════════════════════════════════════
 * Tracking v4.12 — Timeline 5 étapes + bloc info contextuel (relais/domicile/préparation)
 * ════════════════════════════════════════════════════════════════════════ */

/* ── Timeline 5 étapes ───────────────────────────────────────────── */
.sl-tl5{position:relative;display:flex;justify-content:space-between;align-items:flex-start;padding:6px 4px 0;margin:6px 0 4px}
.sl-tl5-bar{position:absolute;top:17px;left:10%;right:10%;height:2px;background:rgba(255,255,255,.12);z-index:0;border-radius:1px;overflow:hidden}
.sl-tl5-bar-fill{height:100%;background:linear-gradient(90deg,#3FB37F,#1D9E75);border-radius:1px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.sl-tl5-step{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;gap:6px;flex:1;min-width:0}
.sl-tl5-dot{width:24px;height:24px;border-radius:50%;background:var(--sl-dark,#1b1b1b);border:1.5px solid rgba(255,255,255,.18);display:flex;align-items:center;justify-content:center;font-size:11px;color:rgba(255,255,255,.4);transition:all .25s;position:relative;z-index:3}
.sl-tl5-step.done .sl-tl5-dot{background:#1D9E75;border-color:#1D9E75;color:#fff}
.sl-tl5-step.current .sl-tl5-dot{background:#EF9F27;border-color:#EF9F27;color:#fff;animation:sl-tl5-pulse 2s ease-in-out infinite}
.sl-tl5-label{font-size:9px;font-weight:600;color:rgba(255,255,255,.4);text-align:center;line-height:1.25;letter-spacing:.02em;text-transform:uppercase}
.sl-tl5-step.done .sl-tl5-label,.sl-tl5-step.current .sl-tl5-label{color:#fff}
@keyframes sl-tl5-pulse{0%,100%{box-shadow:0 0 0 0 rgba(239,159,39,.45)}50%{box-shadow:0 0 0 6px rgba(239,159,39,0)}}
.sl-tl5-updated{font-size:10px;color:rgba(255,255,255,.4);text-align:center;margin-top:6px;font-style:italic;letter-spacing:.02em}

/* ── Bloc info contextuel ────────────────────────────────────────── */
.sl-trk-info{margin-top:14px;padding:12px;border-radius:10px;background:rgba(255,255,255,.04);border:0.5px solid rgba(255,255,255,.08)}
.sl-trk-info-row{display:flex;align-items:flex-start;gap:11px}
.sl-trk-info-icon{width:34px;height:34px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:rgba(255,255,255,.06);border:0.5px solid rgba(255,255,255,.1)}
.sl-trk-info-icon svg{width:16px;height:16px}
.sl-trk-icon--prep svg{color:#EF9F27}
.sl-trk-icon--home svg{color:#3B82F6}
.sl-trk-icon--relay svg{color:#3B82F6}
.sl-trk-info-body{flex:1;min-width:0}
.sl-trk-info-eyebrow{font-size:9px;font-weight:600;color:rgba(255,255,255,.4);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.sl-trk-info-title{font-size:13px;font-weight:600;color:#fff;line-height:1.3;margin-bottom:2px}
.sl-trk-info-meta{font-size:11px;color:rgba(255,255,255,.6);line-height:1.45;margin-top:3px}
.sl-trk-info-tag{display:inline-block;font-size:9px;padding:2px 7px;border-radius:4px;background:rgba(29,158,117,.18);color:#3FB37F;font-weight:700;margin-left:4px;vertical-align:middle;text-transform:uppercase;letter-spacing:.04em}

/* ── Pin adresse + tel ─────────────────────────────────────────────── */
.sl-trk-pin,.sl-trk-phone{font-size:11px;color:rgba(255,255,255,.65);display:flex;align-items:center;gap:6px;margin-top:4px;line-height:1.4}
.sl-trk-pin svg,.sl-trk-phone svg{width:11px;height:11px;color:rgba(255,255,255,.4);flex-shrink:0}
.sl-trk-phone a{color:#3B82F6;text-decoration:none}
.sl-trk-phone a:hover{text-decoration:underline}

/* ── Créneau de livraison estimé ────────────────────────────────────── */
.sl-trk-slot{margin-top:9px;padding:9px 11px;background:rgba(59,130,246,.12);border:0.5px solid rgba(59,130,246,.25);border-radius:8px;display:flex;align-items:center;gap:9px}
.sl-trk-slot-icon{width:26px;height:26px;border-radius:50%;background:#3B82F6;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sl-trk-slot-icon svg{width:12px;height:12px;color:#fff}
.sl-trk-slot-day{font-size:9px;font-weight:700;color:#7DB0EA;text-transform:uppercase;letter-spacing:.05em;margin-bottom:1px}
.sl-trk-slot-time{font-size:14px;font-weight:700;color:#fff;font-variant-numeric:tabular-nums;letter-spacing:-0.01em}

/* ── Warning conservation point relais ──────────────────────────────── */
.sl-trk-warning{margin-top:10px;padding:9px 11px;background:rgba(239,159,39,.14);border:0.5px solid rgba(239,159,39,.3);border-radius:8px;display:flex;align-items:flex-start;gap:8px;font-size:11px;color:#F0BB6E;line-height:1.4}
.sl-trk-warning svg{width:13px;height:13px;flex-shrink:0;margin-top:1px;color:#EF9F27}

/* ── CTA tracking GLS ─────────────────────────────────────────────── */
.sl-trk-cta-row{margin-top:11px;padding:9px 11px;background:rgba(255,255,255,.04);border:0.5px solid rgba(255,255,255,.08);border-radius:8px;display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.sl-trk-cta-num{font-size:11px;color:rgba(255,255,255,.55)}
.sl-trk-cta-num code{font-family:'SF Mono','Menlo',monospace;color:#fff;background:rgba(255,255,255,.08);padding:2px 6px;border-radius:4px;font-size:10px;letter-spacing:.02em}
.sl-trk-cta-btn{font-size:11px;font-weight:600;color:#fff;background:#3B82F6;border:none;padding:7px 12px;border-radius:6px;cursor:pointer;display:inline-flex;align-items:center;gap:5px;text-decoration:none;transition:all .15s;letter-spacing:.01em}
.sl-trk-cta-btn:hover{background:#2563EB;color:#fff}
.sl-trk-cta-btn svg{width:11px;height:11px}

/* ── Mobile : timeline plus serrée ───────────────────────────────────── */
@media (max-width:520px){
.sl-tl5-label{font-size:8px}
.sl-tl5-dot{width:22px;height:22px;font-size:10px}
.sl-tl5-bar{top:10px}
.sl-trk-info{padding:10px}
.sl-trk-info-icon{width:30px;height:30px}
.sl-trk-info-title{font-size:12px}
.sl-trk-slot-time{font-size:13px}
.sl-trk-cta-row{flex-direction:column;align-items:stretch}
.sl-trk-cta-num{text-align:center}
.sl-trk-cta-btn{justify-content:center}
}
